Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Import FreeBSD specific parts - Update tests to work on FreeBSD Signed-off-by: Matt Macy <mmacy@FreeBSD.org> Signed-off-by: Ryan Moeller <ryan@ixsystems.com>
- Loading branch information
Showing
375 changed files
with
87,455 additions
and
406 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,31 +1,90 @@ | ||
![img](http://zfsonlinux.org/images/zfs-linux.png) | ||
![img](https://github.com/zfsonfreebsd/ZoF/raw/master/zof-logo.png) | ||
|
||
ZFS on Linux is an advanced file system and volume manager which was originally | ||
developed for Solaris and is now maintained by the OpenZFS community. | ||
developed for Solaris and is now maintained by the OpenZFS community. ZoF is | ||
the work to bring FreeBSD support into the ZoL repo. | ||
|
||
[![codecov](https://codecov.io/gh/zfsonlinux/zfs/branch/master/graph/badge.svg)](https://codecov.io/gh/zfsonlinux/zfs) | ||
[![coverity](https://scan.coverity.com/projects/1973/badge.svg)](https://scan.coverity.com/projects/zfsonlinux-zfs) | ||
|
||
# Official Resources | ||
|
||
* [Site](http://zfsonlinux.org) | ||
* [Wiki](https://github.com/zfsonlinux/zfs/wiki) | ||
* [Mailing lists](https://github.com/zfsonlinux/zfs/wiki/Mailing-Lists) | ||
* [ZoF GitHub Site](https://zfsonfreebsd.github.io/ZoF/) | ||
* [ZoL Site](http://zfsonlinux.org) | ||
* [ZoL Wiki](https://github.com/zfsonlinux/zfs/wiki) | ||
* [ZoL Mailing lists](https://github.com/zfsonlinux/zfs/wiki/Mailing-Lists) | ||
* [OpenZFS site](http://open-zfs.org/) | ||
|
||
# Installation | ||
|
||
Full documentation for installing ZoL on your favorite Linux distribution can | ||
be found at [our site](http://zfsonlinux.org/). | ||
ZoF is available in the FreeBSD ports tree as sysutils/openzfs and | ||
sysutils/openzfs-kmod. It can be installed on FreeBSD stable/12 or later. | ||
|
||
# Contribute & Develop | ||
# Branches | ||
|
||
We have a separate document with [contribution guidelines](./.github/CONTRIBUTING.md). | ||
* projects/zfsbsd - stable branch used by the port | ||
* projects/pr-rebase-* - development branch, frequently rebased on ZoL master | ||
* projects/pr-rebase - squashed development branch for the ZoL PR | ||
|
||
# Release | ||
We frequently rebase the development branch on ZoL master to keep up with | ||
upstream changes, creating a new branch to preserve the commit history in case | ||
of mismerges and to avoid force pushes. | ||
|
||
ZFS on Linux is released under a CDDL license. | ||
For more details see the NOTICE, LICENSE and COPYRIGHT files; `UCRL-CODE-235197` | ||
# Development | ||
|
||
The following dependencies are required to build ZoF from source: | ||
* FreeBSD sources (in /usr/src or elsewhere specified by passing | ||
`--with-freebsd=$path` to `./configure` | ||
* Packages for build: | ||
``` | ||
autoconf | ||
automake | ||
autotools | ||
bash | ||
git | ||
gmake | ||
``` | ||
* Optional packages for build: | ||
``` | ||
python3 # or your preferred Python version | ||
``` | ||
* Optional packages for test: | ||
``` | ||
base64 | ||
fio | ||
hs-ShellCheck | ||
ksh93 | ||
py36-flake8 # or your preferred Python version | ||
shuf | ||
sudo | ||
``` | ||
The user for running tests must have NOPASSWD sudo permission. | ||
|
||
To build and install: | ||
``` | ||
# as user | ||
git clone https://github.com/zfsonfreebsd/ZoF | ||
cd ZoF | ||
./autogen.sh | ||
./configure | ||
gmake | ||
# as root | ||
gmake install | ||
``` | ||
The ZFS utilities will be installed in /usr/local/sbin/, so make sure your PATH | ||
gets adjusted accordingly. Though not required, `WITHOUT_ZFS` is a useful build | ||
option to avoid installing legacy zfs tools and kmod - see `src.conf(5)`. | ||
|
||
Beware that the FreeBSD boot loader does not allow booting from root pools with | ||
encryption active (even if it is not in use), so do not try encryption on a | ||
pool you boot from. | ||
|
||
# Contributing | ||
|
||
Submit changes to the common code via a ZoL PR. Submit changes to FreeBSD | ||
platform code by way of a PR to ZoF against the latest development branch. | ||
|
||
# Issues | ||
|
||
Issues can be reported via GitHub's [Issue Tracker](https://github.com/zfsonfreebsd/ZoF). | ||
|
||
# Supported Kernels | ||
* The `META` file contains the officially recognized supported kernel versions. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
theme: jekyll-theme-slate |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,136 @@ | ||
/* | ||
* CDDL HEADER START | ||
* | ||
* The contents of this file are subject to the terms of the | ||
* Common Development and Distribution License (the "License"). | ||
* You may not use this file except in compliance with the License. | ||
* | ||
* You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE | ||
* or http://www.opensolaris.org/os/licensing. | ||
* See the License for the specific language governing permissions | ||
* and limitations under the License. | ||
* | ||
* When distributing Covered Code, include this CDDL HEADER in each | ||
* file and include the License file at usr/src/OPENSOLARIS.LICENSE. | ||
* If applicable, add the following below this CDDL HEADER, with the | ||
* fields enclosed by brackets "[]" replaced with your own identifying | ||
* information: Portions Copyright [yyyy] [name of copyright owner] | ||
* | ||
* CDDL HEADER END | ||
*/ | ||
|
||
/* | ||
* Copyright (c) 2005, 2010, Oracle and/or its affiliates. All rights reserved. | ||
* Copyright (c) 2013, 2018 by Delphix. All rights reserved. | ||
* Copyright (c) 2016, 2017 Intel Corporation. | ||
* Copyright 2016 Igor Kozhukhov <ikozhukhov@gmail.com>. | ||
*/ | ||
|
||
/* | ||
* Functions to convert between a list of vdevs and an nvlist representing the | ||
* configuration. Each entry in the list can be one of: | ||
* | ||
* Device vdevs | ||
* disk=(path=..., devid=...) | ||
* file=(path=...) | ||
* | ||
* Group vdevs | ||
* raidz[1|2]=(...) | ||
* mirror=(...) | ||
* | ||
* Hot spares | ||
* | ||
* While the underlying implementation supports it, group vdevs cannot contain | ||
* other group vdevs. All userland verification of devices is contained within | ||
* this file. If successful, the nvlist returned can be passed directly to the | ||
* kernel; we've done as much verification as possible in userland. | ||
* | ||
* Hot spares are a special case, and passed down as an array of disk vdevs, at | ||
* the same level as the root of the vdev tree. | ||
* | ||
* The only function exported by this file is 'make_root_vdev'. The | ||
* function performs several passes: | ||
* | ||
* 1. Construct the vdev specification. Performs syntax validation and | ||
* makes sure each device is valid. | ||
* 2. Check for devices in use. Using libdiskmgt, makes sure that no | ||
* devices are also in use. Some can be overridden using the 'force' | ||
* flag, others cannot. | ||
* 3. Check for replication errors if the 'force' flag is not specified. | ||
* validates that the replication level is consistent across the | ||
* entire pool. | ||
* 4. Call libzfs to label any whole disks with an EFI label. | ||
*/ | ||
|
||
#include <assert.h> | ||
#include <errno.h> | ||
#include <fcntl.h> | ||
#include <libintl.h> | ||
#include <libnvpair.h> | ||
#include <libzutil.h> | ||
#include <limits.h> | ||
#include <sys/spa.h> | ||
#include <stdio.h> | ||
#include <string.h> | ||
#include <unistd.h> | ||
#include <paths.h> | ||
#include <sys/stat.h> | ||
#include <sys/disk.h> | ||
#include <sys/mntent.h> | ||
#include <libgeom.h> | ||
|
||
#include "zpool_util.h" | ||
#include <sys/zfs_context.h> | ||
|
||
int | ||
check_device(const char *name, boolean_t force, boolean_t isspare, | ||
boolean_t iswholedisk) | ||
{ | ||
char path[MAXPATHLEN]; | ||
|
||
if (strncmp(name, _PATH_DEV, sizeof (_PATH_DEV) - 1) != 0) | ||
snprintf(path, sizeof (path), "%s%s", _PATH_DEV, name); | ||
else | ||
strlcpy(path, name, sizeof (path)); | ||
|
||
return (check_file(path, force, isspare)); | ||
} | ||
|
||
#ifdef notyet | ||
/* | ||
* By "whole disk" we mean an entire physical disk (something we can | ||
* label, toggle the write cache on, etc.) as opposed to the full | ||
* capacity of a pseudo-device such as lofi or did. We act as if we | ||
* are labeling the disk, which should be a pretty good test of whether | ||
* it's a viable device or not. Returns B_TRUE if it is and B_FALSE if | ||
* it isn't. | ||
*/ | ||
static boolean_t | ||
is_whole_disk(const char *arg) | ||
{ | ||
int fd; | ||
|
||
fd = g_open(arg, 0); | ||
if (fd >= 0) { | ||
g_close(fd); | ||
return (B_TRUE); | ||
} | ||
return (B_FALSE); | ||
} | ||
#endif | ||
|
||
boolean_t | ||
check_sector_size_database(char *path, int *sector_size) | ||
{ | ||
return (0); | ||
} | ||
|
||
void | ||
zpool_vdev_enable_file(struct stat64 *statbuf, boolean_t *wholedisk) | ||
{ | ||
if (S_ISCHR(statbuf->st_mode)) { | ||
statbuf->st_mode &= ~S_IFCHR; | ||
statbuf->st_mode |= S_IFBLK; | ||
*wholedisk = B_FALSE; | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.