2013-02-18 00:10:17 +04:00
|
|
|
%global _sbindir /sbin
|
|
|
|
%global _libdir /%{_lib}
|
2014-06-06 18:07:58 +04:00
|
|
|
|
|
|
|
# Set the default udev directory based on distribution.
|
2014-06-13 00:11:26 +04:00
|
|
|
%if %{undefined _udevdir}
|
2014-06-06 18:07:58 +04:00
|
|
|
%if 0%{?fedora} >= 17 || 0%{?rhel} >= 7 || 0%{?centos} >= 7
|
2013-02-18 00:10:17 +04:00
|
|
|
%global _udevdir %{_prefix}/lib/udev
|
|
|
|
%else
|
|
|
|
%global _udevdir /lib/udev
|
2014-06-06 18:07:58 +04:00
|
|
|
%endif
|
|
|
|
%endif
|
|
|
|
|
|
|
|
# Set the default udevrule directory based on distribution.
|
2014-06-13 00:11:26 +04:00
|
|
|
%if %{undefined _udevruledir}
|
2014-06-06 18:07:58 +04:00
|
|
|
%if 0%{?fedora} >= 17 || 0%{?rhel} >= 7 || 0%{?centos} >= 7
|
2014-06-13 00:11:26 +04:00
|
|
|
%global _udevruledir %{_prefix}/lib/udev/rules.d
|
2014-06-06 18:07:58 +04:00
|
|
|
%else
|
2014-06-13 00:11:26 +04:00
|
|
|
%global _udevruledir /lib/udev/rules.d
|
2014-06-06 18:07:58 +04:00
|
|
|
%endif
|
|
|
|
%endif
|
|
|
|
|
|
|
|
# Set the default dracut directory based on distribution.
|
2014-06-13 00:11:26 +04:00
|
|
|
%if %{undefined _dracutdir}
|
2014-06-06 18:07:58 +04:00
|
|
|
%if 0%{?fedora} >= 17 || 0%{?rhel} >= 7 || 0%{?centos} >= 7
|
|
|
|
%global _dracutdir %{_prefix}/lib/dracut
|
|
|
|
%else
|
2013-12-18 06:33:40 +04:00
|
|
|
%global _dracutdir %{_prefix}/share/dracut
|
2013-02-18 00:10:17 +04:00
|
|
|
%endif
|
2014-06-06 18:07:58 +04:00
|
|
|
%endif
|
2013-02-18 00:10:17 +04:00
|
|
|
|
2015-07-20 23:16:16 +03:00
|
|
|
# Set the default _initconfdir when undefined.
|
|
|
|
%if %{undefined _initconfdir}
|
|
|
|
%global _initconfdir /etc/sysconfig
|
|
|
|
%endif
|
|
|
|
|
2013-02-18 00:10:17 +04:00
|
|
|
%bcond_with debug
|
2014-01-19 18:36:49 +04:00
|
|
|
%bcond_with systemd
|
2013-02-18 00:10:17 +04:00
|
|
|
|
2014-01-19 18:36:49 +04:00
|
|
|
# Generic enable switch for systemd
|
|
|
|
%if %{with systemd}
|
|
|
|
%define _systemd 1
|
|
|
|
%endif
|
|
|
|
|
2014-06-03 00:04:57 +04:00
|
|
|
# RHEL >= 7 comes with systemd
|
|
|
|
%if 0%{?rhel} >= 7
|
|
|
|
%define _systemd 1
|
|
|
|
%endif
|
|
|
|
|
2014-01-19 18:36:49 +04:00
|
|
|
# Fedora >= 15 comes with systemd, but only >= 18 has
|
|
|
|
# the proper macros
|
|
|
|
%if 0%{?fedora} >= 18
|
|
|
|
%define _systemd 1
|
|
|
|
%endif
|
|
|
|
|
|
|
|
# opensuse >= 12.1 comes with systemd, but only >= 13.1
|
|
|
|
# has the proper macros
|
|
|
|
%if 0%{?suse_version} >= 1310
|
|
|
|
%define _systemd 1
|
|
|
|
%endif
|
2013-02-18 00:10:17 +04:00
|
|
|
|
|
|
|
Name: @PACKAGE@
|
|
|
|
Version: @VERSION@
|
|
|
|
Release: @RELEASE@%{?dist}
|
|
|
|
Summary: Commands to control the kernel modules and libraries
|
|
|
|
|
|
|
|
Group: System Environment/Kernel
|
|
|
|
License: @ZFS_META_LICENSE@
|
|
|
|
URL: http://zfsonlinux.org/
|
|
|
|
Source0: %{name}-%{version}.tar.gz
|
|
|
|
BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n)
|
|
|
|
ExclusiveArch: i386 i686 x86_64
|
|
|
|
|
|
|
|
# May build but untested on ppc/ppc64
|
|
|
|
ExcludeArch: ppc ppc64
|
|
|
|
|
2013-03-20 06:25:01 +04:00
|
|
|
Requires: spl = %{version}
|
2014-05-17 15:20:59 +04:00
|
|
|
Requires: libzpool2 = %{version}
|
|
|
|
Requires: libnvpair1 = %{version}
|
|
|
|
Requires: libuutil1 = %{version}
|
|
|
|
Requires: libzfs2 = %{version}
|
2013-08-26 10:04:38 +04:00
|
|
|
Requires: %{name}-kmod = %{version}
|
2013-02-18 00:10:17 +04:00
|
|
|
Provides: %{name}-kmod-common = %{version}
|
|
|
|
|
2014-02-09 01:48:53 +04:00
|
|
|
# zfs-fuse provides the same commands and man pages that ZoL does. Renaming
|
|
|
|
# those on either side would conflict with all available documentation.
|
|
|
|
Conflicts: zfs-fuse
|
|
|
|
|
2013-02-18 00:10:17 +04:00
|
|
|
%if 0%{?rhel}%{?fedora}%{?suse_version}
|
|
|
|
BuildRequires: zlib-devel
|
|
|
|
BuildRequires: libuuid-devel
|
|
|
|
BuildRequires: libblkid-devel
|
|
|
|
%endif
|
2014-01-19 18:36:49 +04:00
|
|
|
%if 0%{?_systemd}
|
|
|
|
Requires(post): systemd
|
|
|
|
Requires(preun): systemd
|
|
|
|
Requires(postun): systemd
|
|
|
|
BuildRequires: systemd
|
|
|
|
%endif
|
2013-02-18 00:10:17 +04:00
|
|
|
|
|
|
|
%description
|
2014-05-17 15:20:59 +04:00
|
|
|
This package contains the ZFS command line utilities.
|
2013-02-18 00:10:17 +04:00
|
|
|
|
2014-05-17 15:20:59 +04:00
|
|
|
%package -n libzpool2
|
|
|
|
Summary: Native ZFS pool library for Linux
|
|
|
|
Group: System Environment/Kernel
|
|
|
|
|
|
|
|
%description -n libzpool2
|
|
|
|
This package contains the zpool library, which provides support
|
|
|
|
for managing zpools
|
|
|
|
|
2014-12-15 07:23:25 +03:00
|
|
|
%post -n libzpool2 -p /sbin/ldconfig
|
2014-05-17 15:20:59 +04:00
|
|
|
%postun -n libzpool2 -p /sbin/ldconfig
|
|
|
|
|
|
|
|
%package -n libnvpair1
|
|
|
|
Summary: Solaris name-value library for Linux
|
|
|
|
Group: System Environment/Kernel
|
|
|
|
|
|
|
|
%description -n libnvpair1
|
|
|
|
This package contains routines for packing and unpacking name-value
|
|
|
|
pairs. This functionality is used to portably transport data across
|
|
|
|
process boundaries, between kernel and user space, and can be used
|
|
|
|
to write self describing data structures on disk.
|
|
|
|
|
2014-12-15 07:23:25 +03:00
|
|
|
%post -n libnvpair1 -p /sbin/ldconfig
|
2014-05-17 15:20:59 +04:00
|
|
|
%postun -n libnvpair1 -p /sbin/ldconfig
|
|
|
|
|
|
|
|
%package -n libuutil1
|
|
|
|
Summary: Solaris userland utility library for Linux
|
|
|
|
Group: System Environment/Kernel
|
|
|
|
|
|
|
|
%description -n libuutil1
|
|
|
|
This library provides a variety of compatibility functions for ZFS on Linux:
|
|
|
|
* libspl: The Solaris Porting Layer userland library, which provides APIs
|
|
|
|
that make it possible to run Solaris user code in a Linux environment
|
|
|
|
with relatively minimal modification.
|
|
|
|
* libavl: The Adelson-Velskii Landis balanced binary tree manipulation
|
|
|
|
library.
|
|
|
|
* libefi: The Extensible Firmware Interface library for GUID disk
|
|
|
|
partitioning.
|
|
|
|
* libshare: NFS, SMB, and iSCSI service integration for ZFS.
|
|
|
|
|
2014-12-15 07:23:25 +03:00
|
|
|
%post -n libuutil1 -p /sbin/ldconfig
|
2014-05-17 15:20:59 +04:00
|
|
|
%postun -n libuutil1 -p /sbin/ldconfig
|
|
|
|
|
|
|
|
%package -n libzfs2
|
|
|
|
Summary: Native ZFS filesystem library for Linux
|
|
|
|
Group: System Environment/Kernel
|
|
|
|
|
|
|
|
%description -n libzfs2
|
|
|
|
This package provides support for managing ZFS filesystems
|
|
|
|
|
2014-12-15 07:23:25 +03:00
|
|
|
%post -n libzfs2 -p /sbin/ldconfig
|
2014-05-17 15:20:59 +04:00
|
|
|
%postun -n libzfs2 -p /sbin/ldconfig
|
|
|
|
|
|
|
|
%package -n libzfs2-devel
|
2013-02-18 00:10:17 +04:00
|
|
|
Summary: Development headers
|
|
|
|
Group: System Environment/Kernel
|
2014-05-17 15:20:59 +04:00
|
|
|
Requires: libzfs2 = %{version}
|
|
|
|
Requires: libzpool2 = %{version}
|
|
|
|
Requires: libnvpair1 = %{version}
|
|
|
|
Requires: libuutil1 = %{version}
|
|
|
|
Provides: libzpool2-devel
|
|
|
|
Provides: libnvpair1-devel
|
|
|
|
Provides: libuutil1-devel
|
|
|
|
Obsoletes: zfs-devel
|
2013-02-18 00:10:17 +04:00
|
|
|
|
2014-05-17 15:20:59 +04:00
|
|
|
%description -n libzfs2-devel
|
2013-02-18 00:10:17 +04:00
|
|
|
This package contains the header files needed for building additional
|
|
|
|
applications against the ZFS libraries.
|
|
|
|
|
|
|
|
%package test
|
|
|
|
Summary: Test infrastructure
|
|
|
|
Group: System Environment/Kernel
|
|
|
|
Requires: %{name}%{?_isa} = %{version}-%{release}
|
|
|
|
Requires: parted
|
|
|
|
Requires: lsscsi
|
|
|
|
Requires: mdadm
|
|
|
|
Requires: bc
|
|
|
|
|
|
|
|
%description test
|
|
|
|
This package contains test infrastructure and support scripts for
|
|
|
|
validating the file system.
|
|
|
|
|
|
|
|
%package dracut
|
|
|
|
Summary: Dracut module
|
|
|
|
Group: System Environment/Kernel
|
|
|
|
Requires: %{name}%{?_isa} = %{version}-%{release}
|
|
|
|
Requires: dracut
|
|
|
|
|
|
|
|
%description dracut
|
|
|
|
This package contains a dracut module used to construct an initramfs
|
|
|
|
image which is ZFS aware.
|
|
|
|
|
Initramfs scripts for ZoL.
* Supports booting of a ZFS snapshot.
Do this by cloning the snapshot into a dataset. If this, the resulting
dataset, already exists, destroy it. Then mount it on root.
* If snapshot does not exist, use base dataset (the part before '@')
as boot filesystem instead.
* If no snapshot is specified on the 'root=' kernel command line, but there
is an '@', then get a list of snapshots below that filesystem and ask the
user which to use.
* Clone with 'mountpoint=none' and 'canmount=noauto' - we mount manually
and explicitly.
* For sub-filesystems, that doesn't have a mountpoint property set, we use
the 'org.zol:mountpoint' to keep track of it's mountpoint.
* Allow rollback of snapshots instead of clone it and boot from the clone.
* Allow mounting a root- and subfs with mountpoint=legacy set
* Allow mounting a filesystem which is using nativ encryption.
* Support all currently used kernel command line arguments
All the different distributions have their own standard on what to specify
on the kernel command line to boot of a ZFS filesystem.
* Extra options:
* zfsdebug=(on,yes,1) Show extra debugging information
* zfsforce=(on,yes,1) Force import the pool
* rollback=(on,yes,1) Rollback (instead of clone) the snapshot
* Only try to import pool if it haven't already been imported
* This will negate the need to force import a pool that have not been exported cleanly.
* Support exclusion of pools to import by setting ZFS_POOL_EXCEPTIONS in /etc/default/zfs.
* Support additional configuration variable ZFS_INITRD_ADDITIONAL_DATASETS
to mount additional filesystems not located under your root dataset.
* Include /etc/modprobe.d/{zfs,spl}.conf in the initrd if it/they exist.
* Include the udev rule to use by-vdev for pool imports.
* Include the /etc/default/zfs file to the initrd.
* Only try /dev/disk/by-* in the initrd if USE_DISK_BY_ID is set.
* Use /dev/disk/by-vdev before anything.
* Add /dev as a last ditch attempt.
* Fallback to using the cache file if that exist if nothing else worked.
* Use /sbin/modprobe instead of built-in (BusyBox) modprobe.
This gets rid of the message "modprobe: can't load module zcommon".
Thanx to pcoultha for finding this.
Signed-off-by: Turbo Fredriksson <turbo@bayour.com>
Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
Closes #2116
Closes #2114
2014-01-30 20:26:48 +04:00
|
|
|
%if 0%{?_initramfs}
|
|
|
|
%package initramfs
|
|
|
|
Summary: Initramfs module
|
|
|
|
Group: System Environment/Kernel
|
|
|
|
Requires: %{name}%{?_isa} = %{version}-%{release}
|
|
|
|
Requires: %{name} = %{version}-%{release}
|
|
|
|
Requires: initramfs-tools
|
|
|
|
|
|
|
|
%description initramfs
|
|
|
|
This package contains a initramfs module used to construct an initramfs
|
|
|
|
image which is ZFS aware.
|
|
|
|
%endif
|
|
|
|
|
2013-02-18 00:10:17 +04:00
|
|
|
%prep
|
|
|
|
%if %{with debug}
|
|
|
|
%define debug --enable-debug
|
|
|
|
%else
|
|
|
|
%define debug --disable-debug
|
|
|
|
%endif
|
2014-01-19 18:36:49 +04:00
|
|
|
%if 0%{?_systemd}
|
|
|
|
%define systemd --enable-systemd --with-systemdunitdir=%{_unitdir} --with-systemdpresetdir=%{_presetdir} --disable-sysvinit
|
|
|
|
%else
|
|
|
|
%define systemd --enable-sysvinit --disable-systemd
|
|
|
|
%endif
|
2013-02-18 00:10:17 +04:00
|
|
|
|
|
|
|
%setup -q
|
|
|
|
|
|
|
|
%build
|
|
|
|
%configure \
|
|
|
|
--with-config=user \
|
|
|
|
--with-udevdir=%{_udevdir} \
|
2014-06-06 18:07:58 +04:00
|
|
|
--with-udevruledir=%{_udevruledir} \
|
2013-02-18 00:10:17 +04:00
|
|
|
--with-dracutdir=%{_dracutdir} \
|
|
|
|
--disable-static \
|
|
|
|
%{debug} \
|
2014-01-19 18:36:49 +04:00
|
|
|
%{systemd}
|
2013-02-18 00:10:17 +04:00
|
|
|
make %{?_smp_mflags}
|
|
|
|
|
|
|
|
%install
|
|
|
|
%{__rm} -rf $RPM_BUILD_ROOT
|
|
|
|
make install DESTDIR=%{?buildroot}
|
|
|
|
find %{?buildroot}%{_libdir} -name '*.la' -exec rm -f {} \;
|
|
|
|
|
2013-07-04 03:12:37 +04:00
|
|
|
%post
|
2014-01-19 18:36:49 +04:00
|
|
|
%if 0%{?_systemd}
|
|
|
|
%systemd_post zfs.target
|
|
|
|
%else
|
Base init scripts for SYSV systems
* Based on the init scripts included with Debian GNU/Linux, then take code
from the already existing ones, trying to merge them into one set of
scripts that will work for 'everyone' for better maintainability.
* Add configurable variables to control the workings of the init scripts:
* ZFS_INITRD_PRE_MOUNTROOT_SLEEP
Set a sleep time before we load the module (used primarily by initrd
scripts to allow for slower media (such as USB devices etc) to be
availible before we load the zfs module).
* ZFS_INITRD_POST_MODPROBE_SLEEP
Set a timed sleep in the initrd to after the load of the zfs module.
* ZFS_INITRD_ADDITIONAL_DATASETS
To allow for mounting additional datasets in the initrd. Primarily used
in initrd scripts to allow for when filesystem needed to boot (such as
/usr, /opt, /var etc) isn't directly under the root dataset.
* ZFS_POOL_EXCEPTIONS
Exclude pools from being imported (in the initrd and/or init scripts).
* ZFS_DKMS_ENABLE_DEBUG, ZFS_DKMS_ENABLE_DEBUG_DMU_TX, ZFS_DKMS_DISABLE_STRIP
Set to control how dkms should build the dkms packages.
* ZPOOL_IMPORT_PATH
Set path(s) where "zpool import" should import pools from.
This was previously the job of "USE_DISK_BY_ID" (which is still used
for backwards compatibility) but was renamed to allow for better
control of import path(s).
* If old USE_DISK_BY_ID is set, but not new ZPOOL_IMPORT_PATH, then we
set ZPOOL_IMPORT_PATH to sane defaults just to be on the safe side.
* ZED_ARGS
To allow for local options to zed without having to change the init script.
* The import function, do_import(), imports pools by name instead of '-a'
for better control of pools to import and from where.
* If USE_DISK_BY_ID is set (for backwards compatibility), but isn't 'yes'
then ignore it.
* If pool(s) isn't found with a simple "zpool import" (seen it happen),
try looking for them in /dev/disk/by-id (if it exists). Any duplicates
(pools found with both commands) is filtered out.
* IF we have found extra pool(s) this way, we must force USE_DISK_BY_ID
so that the first, simple "zpool import $pool" is able to find it.
* Fallback on importing the pool using the cache file (if it exists) only
if 'simple' import (either with ZPOOL_IMPORT_PATH or the 'built in'
defaults) didn't work.
* The export function, do_export(), will export all pools imported, EXCEPT
the root pool (if there is one).
* ZED script from the Debian GNU/Linux packages added.
* Refreshed ZED init script from behlendorf@5e7a660 to be portable so it
may be used on both LSB and Redhat style systems.
* If there is no pool(s) imported and zed successfully shut down, we will
unload the zfs modules.
* The function library file for the ZoL init script is installed as
/etc/init.d/zfs-functions.
* The four init scripts, the /etc/{defaults,sysconfig,conf.d}/zfs config file
as well as the common function library is tagged as '%config(noreplace)' in
the rpm rules file to make sure they are not replaced automatically if locally
modifed.
* Pitfals and workarounds:
* If we're running from init, remove stale /etc/dfs/sharetab before importing
pools in the zfs-import init script.
* On Debian GNU/Linux, there's a 'sendsigs' script that will kill basically
everything quite early in the shutdown phase and zed is/should be stopped
much later than that. We don't want zed to be among the ones killed, so add
the zed pid to list of pids for 'sendsigs' to ignore.
* CentOS uses echo_success() and echo_failure() to print out status of
command. These in turn uses "echo -n \0xx[etc]" to move cursor and choose
colour etc. This doesn't work with the modified IFS variable we need to
use in zfs-import for some reason, so work around that when we define
zfs_log_{end,failure}_msg() for RedHat and derivative distributions.
* All scripts passes ShellCheck (with one false positive in do_mount()).
Signed-off-by: Turbo Fredriksson turbo@bayour.com
Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
Reviewed by: Richard Yao <ryao@gentoo.org>
Reviewed by: Chris Dunlap <cdunlap@llnl.gov>
Closes #2974
Closes #2107
2015-04-23 21:35:45 +03:00
|
|
|
if [ -x /sbin/chkconfig ]; then
|
|
|
|
/sbin/chkconfig --add zfs-import
|
|
|
|
/sbin/chkconfig --add zfs-mount
|
|
|
|
/sbin/chkconfig --add zfs-share
|
|
|
|
/sbin/chkconfig --add zfs-zed
|
|
|
|
fi
|
2014-01-19 18:36:49 +04:00
|
|
|
%endif
|
2013-07-04 08:38:45 +04:00
|
|
|
exit 0
|
2013-07-04 03:12:37 +04:00
|
|
|
|
|
|
|
%preun
|
2014-01-19 18:36:49 +04:00
|
|
|
%if 0%{?_systemd}
|
|
|
|
%systemd_preun zfs.target
|
|
|
|
%else
|
Base init scripts for SYSV systems
* Based on the init scripts included with Debian GNU/Linux, then take code
from the already existing ones, trying to merge them into one set of
scripts that will work for 'everyone' for better maintainability.
* Add configurable variables to control the workings of the init scripts:
* ZFS_INITRD_PRE_MOUNTROOT_SLEEP
Set a sleep time before we load the module (used primarily by initrd
scripts to allow for slower media (such as USB devices etc) to be
availible before we load the zfs module).
* ZFS_INITRD_POST_MODPROBE_SLEEP
Set a timed sleep in the initrd to after the load of the zfs module.
* ZFS_INITRD_ADDITIONAL_DATASETS
To allow for mounting additional datasets in the initrd. Primarily used
in initrd scripts to allow for when filesystem needed to boot (such as
/usr, /opt, /var etc) isn't directly under the root dataset.
* ZFS_POOL_EXCEPTIONS
Exclude pools from being imported (in the initrd and/or init scripts).
* ZFS_DKMS_ENABLE_DEBUG, ZFS_DKMS_ENABLE_DEBUG_DMU_TX, ZFS_DKMS_DISABLE_STRIP
Set to control how dkms should build the dkms packages.
* ZPOOL_IMPORT_PATH
Set path(s) where "zpool import" should import pools from.
This was previously the job of "USE_DISK_BY_ID" (which is still used
for backwards compatibility) but was renamed to allow for better
control of import path(s).
* If old USE_DISK_BY_ID is set, but not new ZPOOL_IMPORT_PATH, then we
set ZPOOL_IMPORT_PATH to sane defaults just to be on the safe side.
* ZED_ARGS
To allow for local options to zed without having to change the init script.
* The import function, do_import(), imports pools by name instead of '-a'
for better control of pools to import and from where.
* If USE_DISK_BY_ID is set (for backwards compatibility), but isn't 'yes'
then ignore it.
* If pool(s) isn't found with a simple "zpool import" (seen it happen),
try looking for them in /dev/disk/by-id (if it exists). Any duplicates
(pools found with both commands) is filtered out.
* IF we have found extra pool(s) this way, we must force USE_DISK_BY_ID
so that the first, simple "zpool import $pool" is able to find it.
* Fallback on importing the pool using the cache file (if it exists) only
if 'simple' import (either with ZPOOL_IMPORT_PATH or the 'built in'
defaults) didn't work.
* The export function, do_export(), will export all pools imported, EXCEPT
the root pool (if there is one).
* ZED script from the Debian GNU/Linux packages added.
* Refreshed ZED init script from behlendorf@5e7a660 to be portable so it
may be used on both LSB and Redhat style systems.
* If there is no pool(s) imported and zed successfully shut down, we will
unload the zfs modules.
* The function library file for the ZoL init script is installed as
/etc/init.d/zfs-functions.
* The four init scripts, the /etc/{defaults,sysconfig,conf.d}/zfs config file
as well as the common function library is tagged as '%config(noreplace)' in
the rpm rules file to make sure they are not replaced automatically if locally
modifed.
* Pitfals and workarounds:
* If we're running from init, remove stale /etc/dfs/sharetab before importing
pools in the zfs-import init script.
* On Debian GNU/Linux, there's a 'sendsigs' script that will kill basically
everything quite early in the shutdown phase and zed is/should be stopped
much later than that. We don't want zed to be among the ones killed, so add
the zed pid to list of pids for 'sendsigs' to ignore.
* CentOS uses echo_success() and echo_failure() to print out status of
command. These in turn uses "echo -n \0xx[etc]" to move cursor and choose
colour etc. This doesn't work with the modified IFS variable we need to
use in zfs-import for some reason, so work around that when we define
zfs_log_{end,failure}_msg() for RedHat and derivative distributions.
* All scripts passes ShellCheck (with one false positive in do_mount()).
Signed-off-by: Turbo Fredriksson turbo@bayour.com
Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
Reviewed by: Richard Yao <ryao@gentoo.org>
Reviewed by: Chris Dunlap <cdunlap@llnl.gov>
Closes #2974
Closes #2107
2015-04-23 21:35:45 +03:00
|
|
|
if [ $1 -eq 0 ] && [ -x /sbin/chkconfig ]; then
|
|
|
|
/sbin/chkconfig --del zfs-import
|
|
|
|
/sbin/chkconfig --del zfs-mount
|
|
|
|
/sbin/chkconfig --del zfs-share
|
|
|
|
/sbin/chkconfig --del zfs-zed
|
2013-07-04 03:12:37 +04:00
|
|
|
fi
|
2014-01-19 18:36:49 +04:00
|
|
|
%endif
|
2013-07-04 08:38:45 +04:00
|
|
|
exit 0
|
2013-02-18 00:10:17 +04:00
|
|
|
|
2014-01-19 18:36:49 +04:00
|
|
|
%postun
|
|
|
|
%if 0%{?_systemd}
|
|
|
|
%systemd_postun zfs.target
|
|
|
|
%endif
|
2013-02-18 00:10:17 +04:00
|
|
|
|
|
|
|
%files
|
|
|
|
%{_sbindir}/*
|
2013-06-07 08:33:01 +04:00
|
|
|
%{_bindir}/*
|
2014-01-22 01:30:03 +04:00
|
|
|
%{_libexecdir}/%{name}
|
2013-02-18 00:10:17 +04:00
|
|
|
%{_mandir}/man1/*
|
|
|
|
%{_mandir}/man5/*
|
|
|
|
%{_mandir}/man8/*
|
|
|
|
%{_udevdir}/vdev_id
|
|
|
|
%{_udevdir}/zvol_id
|
|
|
|
%{_udevdir}/rules.d/*
|
2014-01-19 18:36:49 +04:00
|
|
|
%if 0%{?_systemd}
|
|
|
|
/usr/lib/modules-load.d/*
|
|
|
|
%{_unitdir}/*
|
|
|
|
%{_presetdir}/*
|
|
|
|
%else
|
Base init scripts for SYSV systems
* Based on the init scripts included with Debian GNU/Linux, then take code
from the already existing ones, trying to merge them into one set of
scripts that will work for 'everyone' for better maintainability.
* Add configurable variables to control the workings of the init scripts:
* ZFS_INITRD_PRE_MOUNTROOT_SLEEP
Set a sleep time before we load the module (used primarily by initrd
scripts to allow for slower media (such as USB devices etc) to be
availible before we load the zfs module).
* ZFS_INITRD_POST_MODPROBE_SLEEP
Set a timed sleep in the initrd to after the load of the zfs module.
* ZFS_INITRD_ADDITIONAL_DATASETS
To allow for mounting additional datasets in the initrd. Primarily used
in initrd scripts to allow for when filesystem needed to boot (such as
/usr, /opt, /var etc) isn't directly under the root dataset.
* ZFS_POOL_EXCEPTIONS
Exclude pools from being imported (in the initrd and/or init scripts).
* ZFS_DKMS_ENABLE_DEBUG, ZFS_DKMS_ENABLE_DEBUG_DMU_TX, ZFS_DKMS_DISABLE_STRIP
Set to control how dkms should build the dkms packages.
* ZPOOL_IMPORT_PATH
Set path(s) where "zpool import" should import pools from.
This was previously the job of "USE_DISK_BY_ID" (which is still used
for backwards compatibility) but was renamed to allow for better
control of import path(s).
* If old USE_DISK_BY_ID is set, but not new ZPOOL_IMPORT_PATH, then we
set ZPOOL_IMPORT_PATH to sane defaults just to be on the safe side.
* ZED_ARGS
To allow for local options to zed without having to change the init script.
* The import function, do_import(), imports pools by name instead of '-a'
for better control of pools to import and from where.
* If USE_DISK_BY_ID is set (for backwards compatibility), but isn't 'yes'
then ignore it.
* If pool(s) isn't found with a simple "zpool import" (seen it happen),
try looking for them in /dev/disk/by-id (if it exists). Any duplicates
(pools found with both commands) is filtered out.
* IF we have found extra pool(s) this way, we must force USE_DISK_BY_ID
so that the first, simple "zpool import $pool" is able to find it.
* Fallback on importing the pool using the cache file (if it exists) only
if 'simple' import (either with ZPOOL_IMPORT_PATH or the 'built in'
defaults) didn't work.
* The export function, do_export(), will export all pools imported, EXCEPT
the root pool (if there is one).
* ZED script from the Debian GNU/Linux packages added.
* Refreshed ZED init script from behlendorf@5e7a660 to be portable so it
may be used on both LSB and Redhat style systems.
* If there is no pool(s) imported and zed successfully shut down, we will
unload the zfs modules.
* The function library file for the ZoL init script is installed as
/etc/init.d/zfs-functions.
* The four init scripts, the /etc/{defaults,sysconfig,conf.d}/zfs config file
as well as the common function library is tagged as '%config(noreplace)' in
the rpm rules file to make sure they are not replaced automatically if locally
modifed.
* Pitfals and workarounds:
* If we're running from init, remove stale /etc/dfs/sharetab before importing
pools in the zfs-import init script.
* On Debian GNU/Linux, there's a 'sendsigs' script that will kill basically
everything quite early in the shutdown phase and zed is/should be stopped
much later than that. We don't want zed to be among the ones killed, so add
the zed pid to list of pids for 'sendsigs' to ignore.
* CentOS uses echo_success() and echo_failure() to print out status of
command. These in turn uses "echo -n \0xx[etc]" to move cursor and choose
colour etc. This doesn't work with the modified IFS variable we need to
use in zfs-import for some reason, so work around that when we define
zfs_log_{end,failure}_msg() for RedHat and derivative distributions.
* All scripts passes ShellCheck (with one false positive in do_mount()).
Signed-off-by: Turbo Fredriksson turbo@bayour.com
Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
Reviewed by: Richard Yao <ryao@gentoo.org>
Reviewed by: Chris Dunlap <cdunlap@llnl.gov>
Closes #2974
Closes #2107
2015-04-23 21:35:45 +03:00
|
|
|
%config(noreplace) %{_sysconfdir}/init.d/*
|
|
|
|
%config(noreplace) %{_initconfdir}/zfs
|
2014-01-19 18:36:49 +04:00
|
|
|
%endif
|
Base init scripts for SYSV systems
* Based on the init scripts included with Debian GNU/Linux, then take code
from the already existing ones, trying to merge them into one set of
scripts that will work for 'everyone' for better maintainability.
* Add configurable variables to control the workings of the init scripts:
* ZFS_INITRD_PRE_MOUNTROOT_SLEEP
Set a sleep time before we load the module (used primarily by initrd
scripts to allow for slower media (such as USB devices etc) to be
availible before we load the zfs module).
* ZFS_INITRD_POST_MODPROBE_SLEEP
Set a timed sleep in the initrd to after the load of the zfs module.
* ZFS_INITRD_ADDITIONAL_DATASETS
To allow for mounting additional datasets in the initrd. Primarily used
in initrd scripts to allow for when filesystem needed to boot (such as
/usr, /opt, /var etc) isn't directly under the root dataset.
* ZFS_POOL_EXCEPTIONS
Exclude pools from being imported (in the initrd and/or init scripts).
* ZFS_DKMS_ENABLE_DEBUG, ZFS_DKMS_ENABLE_DEBUG_DMU_TX, ZFS_DKMS_DISABLE_STRIP
Set to control how dkms should build the dkms packages.
* ZPOOL_IMPORT_PATH
Set path(s) where "zpool import" should import pools from.
This was previously the job of "USE_DISK_BY_ID" (which is still used
for backwards compatibility) but was renamed to allow for better
control of import path(s).
* If old USE_DISK_BY_ID is set, but not new ZPOOL_IMPORT_PATH, then we
set ZPOOL_IMPORT_PATH to sane defaults just to be on the safe side.
* ZED_ARGS
To allow for local options to zed without having to change the init script.
* The import function, do_import(), imports pools by name instead of '-a'
for better control of pools to import and from where.
* If USE_DISK_BY_ID is set (for backwards compatibility), but isn't 'yes'
then ignore it.
* If pool(s) isn't found with a simple "zpool import" (seen it happen),
try looking for them in /dev/disk/by-id (if it exists). Any duplicates
(pools found with both commands) is filtered out.
* IF we have found extra pool(s) this way, we must force USE_DISK_BY_ID
so that the first, simple "zpool import $pool" is able to find it.
* Fallback on importing the pool using the cache file (if it exists) only
if 'simple' import (either with ZPOOL_IMPORT_PATH or the 'built in'
defaults) didn't work.
* The export function, do_export(), will export all pools imported, EXCEPT
the root pool (if there is one).
* ZED script from the Debian GNU/Linux packages added.
* Refreshed ZED init script from behlendorf@5e7a660 to be portable so it
may be used on both LSB and Redhat style systems.
* If there is no pool(s) imported and zed successfully shut down, we will
unload the zfs modules.
* The function library file for the ZoL init script is installed as
/etc/init.d/zfs-functions.
* The four init scripts, the /etc/{defaults,sysconfig,conf.d}/zfs config file
as well as the common function library is tagged as '%config(noreplace)' in
the rpm rules file to make sure they are not replaced automatically if locally
modifed.
* Pitfals and workarounds:
* If we're running from init, remove stale /etc/dfs/sharetab before importing
pools in the zfs-import init script.
* On Debian GNU/Linux, there's a 'sendsigs' script that will kill basically
everything quite early in the shutdown phase and zed is/should be stopped
much later than that. We don't want zed to be among the ones killed, so add
the zed pid to list of pids for 'sendsigs' to ignore.
* CentOS uses echo_success() and echo_failure() to print out status of
command. These in turn uses "echo -n \0xx[etc]" to move cursor and choose
colour etc. This doesn't work with the modified IFS variable we need to
use in zfs-import for some reason, so work around that when we define
zfs_log_{end,failure}_msg() for RedHat and derivative distributions.
* All scripts passes ShellCheck (with one false positive in do_mount()).
Signed-off-by: Turbo Fredriksson turbo@bayour.com
Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
Reviewed by: Richard Yao <ryao@gentoo.org>
Reviewed by: Chris Dunlap <cdunlap@llnl.gov>
Closes #2974
Closes #2107
2015-04-23 21:35:45 +03:00
|
|
|
%config(noreplace) %{_sysconfdir}/%{name}
|
2013-02-18 00:10:17 +04:00
|
|
|
|
2014-05-17 15:20:59 +04:00
|
|
|
%files -n libzpool2
|
|
|
|
%{_libdir}/libzpool.so.*
|
|
|
|
|
|
|
|
%files -n libnvpair1
|
|
|
|
%{_libdir}/libnvpair.so.*
|
|
|
|
|
|
|
|
%files -n libuutil1
|
|
|
|
%{_libdir}/libuutil.so.*
|
|
|
|
|
|
|
|
%files -n libzfs2
|
|
|
|
%{_libdir}/libzfs*.so.*
|
|
|
|
|
|
|
|
%files -n libzfs2-devel
|
2014-06-07 03:23:22 +04:00
|
|
|
%{_datadir}/pkgconfig/libzfs.pc
|
|
|
|
%{_datadir}/pkgconfig/libzfs_core.pc
|
2013-02-18 00:10:17 +04:00
|
|
|
%{_libdir}/*.so
|
|
|
|
%{_includedir}/*
|
2014-05-17 15:20:59 +04:00
|
|
|
%doc AUTHORS COPYRIGHT DISCLAIMER
|
|
|
|
%doc OPENSOLARIS.LICENSE README.markdown
|
2013-02-18 00:10:17 +04:00
|
|
|
|
|
|
|
%files test
|
|
|
|
%{_datadir}/%{name}
|
|
|
|
|
|
|
|
%files dracut
|
2015-07-09 21:41:14 +03:00
|
|
|
%doc contrib/dracut/README.dracut.markdown
|
2013-02-18 00:10:17 +04:00
|
|
|
%{_dracutdir}/modules.d/*
|
|
|
|
|
Initramfs scripts for ZoL.
* Supports booting of a ZFS snapshot.
Do this by cloning the snapshot into a dataset. If this, the resulting
dataset, already exists, destroy it. Then mount it on root.
* If snapshot does not exist, use base dataset (the part before '@')
as boot filesystem instead.
* If no snapshot is specified on the 'root=' kernel command line, but there
is an '@', then get a list of snapshots below that filesystem and ask the
user which to use.
* Clone with 'mountpoint=none' and 'canmount=noauto' - we mount manually
and explicitly.
* For sub-filesystems, that doesn't have a mountpoint property set, we use
the 'org.zol:mountpoint' to keep track of it's mountpoint.
* Allow rollback of snapshots instead of clone it and boot from the clone.
* Allow mounting a root- and subfs with mountpoint=legacy set
* Allow mounting a filesystem which is using nativ encryption.
* Support all currently used kernel command line arguments
All the different distributions have their own standard on what to specify
on the kernel command line to boot of a ZFS filesystem.
* Extra options:
* zfsdebug=(on,yes,1) Show extra debugging information
* zfsforce=(on,yes,1) Force import the pool
* rollback=(on,yes,1) Rollback (instead of clone) the snapshot
* Only try to import pool if it haven't already been imported
* This will negate the need to force import a pool that have not been exported cleanly.
* Support exclusion of pools to import by setting ZFS_POOL_EXCEPTIONS in /etc/default/zfs.
* Support additional configuration variable ZFS_INITRD_ADDITIONAL_DATASETS
to mount additional filesystems not located under your root dataset.
* Include /etc/modprobe.d/{zfs,spl}.conf in the initrd if it/they exist.
* Include the udev rule to use by-vdev for pool imports.
* Include the /etc/default/zfs file to the initrd.
* Only try /dev/disk/by-* in the initrd if USE_DISK_BY_ID is set.
* Use /dev/disk/by-vdev before anything.
* Add /dev as a last ditch attempt.
* Fallback to using the cache file if that exist if nothing else worked.
* Use /sbin/modprobe instead of built-in (BusyBox) modprobe.
This gets rid of the message "modprobe: can't load module zcommon".
Thanx to pcoultha for finding this.
Signed-off-by: Turbo Fredriksson <turbo@bayour.com>
Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
Closes #2116
Closes #2114
2014-01-30 20:26:48 +04:00
|
|
|
%if 0%{?_initramfs}
|
|
|
|
%files initramfs
|
|
|
|
%doc contrib/initramfs/README.initramfs.markdown
|
|
|
|
/usr/share/initramfs-tools/*
|
|
|
|
%else
|
|
|
|
# Since we're not building the initramfs package,
|
|
|
|
# ignore those files.
|
|
|
|
%exclude /usr/share/initramfs-tools
|
|
|
|
%endif
|
|
|
|
|
2013-02-18 00:10:17 +04:00
|
|
|
%changelog
|
2015-09-10 01:25:52 +03:00
|
|
|
* Fri Sep 11 2015 Brian Behlendorf <behlendorf1@llnl.gov> - 0.6.5-1
|
|
|
|
- Released 0.6.5-1, detailed release notes are available at:
|
|
|
|
- https://github.com/zfsonlinux/zfs/releases/tag/zfs-0.6.5
|
2015-04-09 06:16:45 +03:00
|
|
|
* Wed Apr 8 2015 Brian Behlendorf <behlendorf1@llnl.gov> - 0.6.4-1
|
|
|
|
- Released 0.6.4-1
|
2014-06-12 22:55:52 +04:00
|
|
|
* Thu Jun 12 2014 Brian Behlendorf <behlendorf1@llnl.gov> - 0.6.3-1
|
|
|
|
- Released 0.6.3-1
|
2013-08-17 02:20:07 +04:00
|
|
|
* Wed Aug 21 2013 Brian Behlendorf <behlendorf1@llnl.gov> - 0.6.2-1
|
|
|
|
- Released 0.6.2-1
|
2013-03-26 00:46:37 +04:00
|
|
|
* Fri Mar 22 2013 Brian Behlendorf <behlendorf1@llnl.gov> - 0.6.1-1
|
|
|
|
- First official stable release.
|