diff options
-rw-r--r-- | .gitignore | 3 | ||||
-rw-r--r-- | Makefile.am | 7 | ||||
-rw-r--r-- | config/deb.am | 20 | ||||
-rw-r--r-- | config/rpm.am | 99 | ||||
-rw-r--r-- | config/tgz.am | 20 | ||||
-rw-r--r-- | config/zfs-build.m4 | 34 | ||||
-rw-r--r-- | config/zfs-meta.m4 | 3 | ||||
-rw-r--r-- | configure.ac | 12 | ||||
-rw-r--r-- | dkms.conf.in | 36 | ||||
-rw-r--r-- | rpm/Makefile.am | 1 | ||||
-rw-r--r-- | rpm/fedora/.gitignore | 3 | ||||
-rw-r--r-- | rpm/fedora/Makefile.am | 1 | ||||
l--------- | rpm/fedora/zfs-dkms.spec.in | 1 | ||||
-rw-r--r-- | rpm/fedora/zfs-kmod.spec.in | 117 | ||||
l--------- | rpm/fedora/zfs.spec.in | 1 | ||||
-rw-r--r-- | rpm/generic/.gitignore | 3 | ||||
-rw-r--r-- | rpm/generic/Makefile.am | 1 | ||||
-rw-r--r-- | rpm/generic/zfs-dkms.spec.in | 67 | ||||
-rw-r--r-- | rpm/generic/zfs-kmod.spec.in | 130 | ||||
-rw-r--r-- | rpm/generic/zfs.spec.in | 147 | ||||
-rw-r--r-- | scripts/Makefile.am | 3 | ||||
-rwxr-xr-x | scripts/dkms.mkconf | 88 | ||||
-rwxr-xr-x | scripts/dkms.postinst (renamed from dkms.postinst) | 0 | ||||
-rwxr-xr-x | scripts/kmodtool | 552 | ||||
-rw-r--r-- | zfs-modules.spec.in | 658 | ||||
-rw-r--r-- | zfs.spec.in | 110 |
26 files changed, 1222 insertions, 895 deletions
diff --git a/.gitignore b/.gitignore index b2f6c669c..cdebb63a9 100644 --- a/.gitignore +++ b/.gitignore @@ -40,10 +40,7 @@ Makefile.in /libtool /zfs_config.h /zfs_config.h.in -/zfs.spec -/zfs-modules.spec /zfs.release -/dkms.conf /stamp-h1 /.script-config /zfs-script-config.sh diff --git a/Makefile.am b/Makefile.am index c0e82eb68..6bf013ec9 100644 --- a/Makefile.am +++ b/Makefile.am @@ -2,7 +2,7 @@ include $(top_srcdir)/config/rpm.am include $(top_srcdir)/config/deb.am include $(top_srcdir)/config/tgz.am -SUBDIRS = include +SUBDIRS = include rpm if CONFIG_USER SUBDIRS += dracut udev etc man scripts lib cmd endif @@ -17,10 +17,9 @@ nodist_kernel_HEADERS = zfs.release zfs_config.h module/$(LINUX_SYMBOLS) endif AUTOMAKE_OPTIONS = foreign -EXTRA_DIST = autogen.sh zfs.spec.in zfs-modules.spec.in +EXTRA_DIST = autogen.sh copy-builtin EXTRA_DIST += config/config.awk config/rpm.am config/deb.am config/tgz.am EXTRA_DIST += META DISCLAIMER COPYRIGHT README.markdown OPENSOLARIS.LICENSE -EXTRA_DIST += dkms.postinst copy-builtin distclean-local:: -$(RM) -R autom4te*.cache @@ -45,5 +44,5 @@ etags: tags: ctags etags pkg: @DEFAULT_PACKAGE@ -pkg-modules: @DEFAULT_PACKAGE@-modules +pkg-kmod: @DEFAULT_PACKAGE@-kmod pkg-utils: @DEFAULT_PACKAGE@-utils diff --git a/config/deb.am b/config/deb.am index 36204b41c..078dd0c7a 100644 --- a/config/deb.am +++ b/config/deb.am @@ -14,22 +14,20 @@ deb-local: exit 1; \ fi) -deb-modules: deb-local rpm-modules +deb-kmod: deb-local rpm-kmod if CONFIG_KERNEL - name=${PACKAGE}-modules; \ - version=${ZFS_META_VERSION}-${ZFS_META_RELEASE}; \ - release=`echo ${LINUX_VERSION} | $(SED) -e "s/-/_/g"`; \ - arch=`$(RPM) -qp $${name}-$${version}.src.rpm --qf %{arch} | tail -1`; \ - pkg1=$${name}-$${version}_$${release}.$${arch}.rpm; \ - pkg2=$${name}-devel-$${version}_$${release}.$${arch}.rpm; \ - fakeroot $(ALIEN) --scripts --to-deb $$pkg1 $$pkg2; \ - $(RM) $$pkg1 $$pkg2 + name=${PACKAGE}; \ + version=${VERSION}-${RELEASE}; \ + arch=`$(RPM) -qp $${name}-kmod-$${version}.src.rpm --qf %{arch} | tail -1`; \ + pkg1=kmod-$${name}*$${version}.$${arch}.rpm; \ + fakeroot $(ALIEN) --scripts --to-deb $$pkg1; \ + $(RM) $$pkg1 endif deb-utils: deb-local rpm-utils if CONFIG_USER name=${PACKAGE}; \ - version=${ZFS_META_VERSION}-${ZFS_META_RELEASE}; \ + version=${VERSION}-${RELEASE}; \ arch=`$(RPM) -qp $${name}-$${version}.src.rpm --qf %{arch} | tail -1`; \ pkg1=$${name}-$${version}.$${arch}.rpm; \ pkg2=$${name}-devel-$${version}.$${arch}.rpm; \ @@ -39,4 +37,4 @@ if CONFIG_USER $(RM) $$pkg1 $$pkg2 $$pkg3 $$pkg4 endif -deb: deb-modules deb-utils +deb: deb-kmod deb-utils diff --git a/config/rpm.am b/config/rpm.am index 9deafb3de..8b33bb5b6 100644 --- a/config/rpm.am +++ b/config/rpm.am @@ -1,31 +1,40 @@ -srpm-modules: -if CONFIG_KERNEL - $(MAKE) $(AM_MAKEFLAGS) pkg="${PACKAGE}-modules" srpm-common -endif +############################################################################### +# Copyright (C) 2007-2013 Lawrence Livermore National Security, LLC. +# Copyright (C) 2007 The Regents of the University of California. +# Written by Brian Behlendorf <[email protected]>. +############################################################################### +# Build targets for RPM packages. +############################################################################### + +srpm-kmod: + $(MAKE) $(AM_MAKEFLAGS) pkg="${PACKAGE}-kmod" \ + def='${SRPM_DEFINE_COMMON} ${SRPM_DEFINE_KMOD}' srpm-common + +srpm-dkms: + $(MAKE) $(AM_MAKEFLAGS) pkg="${PACKAGE}-dkms" \ + def='${SRPM_DEFINE_COMMON} ${SRPM_DEFINE_DKMS}' srpm-common srpm-utils: -if CONFIG_USER - $(MAKE) $(AM_MAKEFLAGS) pkg="${PACKAGE}" srpm-common -endif + $(MAKE) $(AM_MAKEFLAGS) pkg="${PACKAGE}" \ + def='${SRPM_DEFINE_COMMON} ${SRPM_DEFINE_UTIL}' srpm-common -srpm: srpm-modules srpm-utils +srpm: srpm-kmod srpm-dkms srpm-utils +srpms: srpm-kmod srpm-dkms srpm-utils -rpm-dkms: srpm-modules -if CONFIG_KERNEL - $(MAKE) $(AM_MAKEFLAGS) pkg="${PACKAGE}-modules" dkms-common -endif +rpm-kmod: srpm-kmod + $(MAKE) $(AM_MAKEFLAGS) pkg="${PACKAGE}-kmod" \ + def='${RPM_DEFINE_COMMON} ${RPM_DEFINE_KMOD}' rpm-common -rpm-modules: srpm-modules -if CONFIG_KERNEL - $(MAKE) $(AM_MAKEFLAGS) pkg="${PACKAGE}-modules" rpm-common -endif +rpm-dkms: srpm-dkms + $(MAKE) $(AM_MAKEFLAGS) pkg="${PACKAGE}-dkms" \ + def='${RPM_DEFINE_COMMON} ${RPM_DEFINE_DKMS}' rpm-common rpm-utils: srpm-utils -if CONFIG_USER - $(MAKE) $(AM_MAKEFLAGS) pkg="${PACKAGE}" rpm-common -endif + $(MAKE) $(AM_MAKEFLAGS) pkg="${PACKAGE}" \ + def='${RPM_DEFINE_COMMON} ${RPM_DEFINE_UTIL}' rpm-common -rpm: rpm-modules rpm-utils rpm-dkms +rpm: rpm-kmod rpm-dkms rpm-utils +rpms: rpm-kmod rpm-dkms rpm-utils rpm-local: @(if test "${HAVE_RPMBUILD}" = "no"; then \ @@ -40,32 +49,14 @@ rpm-local: mkdir -p $(rpmbuild)/RPMS && \ mkdir -p $(rpmbuild)/SRPMS && \ mkdir -p $(rpmbuild)/SPECS && \ - cp $(rpmspec) $(rpmbuild)/SPECS && \ + cp ${RPM_SPEC_DIR}/$(rpmspec) $(rpmbuild)/SPECS && \ mkdir -p $(rpmbuild)/SOURCES && \ + cp scripts/kmodtool $(rpmbuild)/SOURCES && \ cp $(distdir).tar.gz $(rpmbuild)/SOURCES) -dkms-common: - rpmpkg=$(pkg)-$(ZFS_META_VERSION)-$(ZFS_META_RELEASE).src.rpm; \ - rpmspec=$(pkg).spec; \ - rpmdkms=$(pkg)-dkms-$(ZFS_META_VERSION)-$(ZFS_META_RELEASE).noarch.rpm;\ - rpmbuild=`mktemp -t -d $(PACKAGE)-build-$$USER-XXXXXXXX`; \ - $(MAKE) $(AM_MAKEFLAGS) \ - rpmbuild="$$rpmbuild" \ - rpmspec="$$rpmspec" \ - rpm-local || exit 1; \ - $(RPMBUILD) \ - --define "_tmppath $$rpmbuild/TMP" \ - --define "_topdir $$rpmbuild" \ - --define "dist %{nil}" \ - --define "_without_kernel 1" \ - --define "_without_kernel_debug 1" \ - --define "_with_kernel_dkms 1" \ - --nodeps --rebuild $$rpmpkg || exit 1; \ - cp $$rpmbuild/RPMS/noarch/$$rpmdkms . || exit 1; \ - $(RM) -R $$rpmbuild - srpm-common: dist - rpmpkg=$(pkg)-$(ZFS_META_VERSION)-$(ZFS_META_RELEASE).src.rpm; \ + @(dist=`$(RPM) --eval %{?dist}`; \ + rpmpkg=$(pkg)-$(VERSION)-$(RELEASE)$$dist*src.rpm; \ rpmspec=$(pkg).spec; \ rpmbuild=`mktemp -t -d $(PACKAGE)-build-$$USER-XXXXXXXX`; \ $(MAKE) $(AM_MAKEFLAGS) \ @@ -75,32 +66,22 @@ srpm-common: dist $(RPMBUILD) \ --define "_tmppath $$rpmbuild/TMP" \ --define "_topdir $$rpmbuild" \ - --define "build_src_rpm 1" \ - --define "dist %{nil}" \ - --nodeps -bs $$rpmbuild/SPECS/$$rpmspec || exit 1; \ + $(def) -bs $$rpmbuild/SPECS/$$rpmspec || exit 1; \ cp $$rpmbuild/SRPMS/$$rpmpkg . || exit 1; \ - $(RM) -R $$rpmbuild + rm -R $$rpmbuild) rpm-common: - rpmpkg=$(pkg)-$(ZFS_META_VERSION)-$(ZFS_META_RELEASE).src.rpm; \ + @(dist=`$(RPM) --eval %{?dist}`; \ + rpmpkg=$(pkg)-$(VERSION)-$(RELEASE)$$dist*src.rpm; \ rpmspec=$(pkg).spec; \ rpmbuild=`mktemp -t -d $(PACKAGE)-build-$$USER-XXXXXXXX`; \ $(MAKE) $(AM_MAKEFLAGS) \ rpmbuild="$$rpmbuild" \ rpmspec="$$rpmspec" \ rpm-local || exit 1; \ - $(RPMBUILD) \ + ${RPMBUILD} \ --define "_tmppath $$rpmbuild/TMP" \ --define "_topdir $$rpmbuild" \ - --define "dist %{nil}" \ - --define "require_kdir $(LINUX)" \ - --define "require_kobj $(LINUX_OBJ)" \ - --define "require_kver $(LINUX_VERSION)" \ - --define "require_spldir $(SPL)" \ - --define "require_splobj $(SPL_OBJ)" \ - --define "require_splver $(SPL_VERSION)" \ - --define "$(DEBUG_ZFS) 1" \ - --define "$(DEBUG_DMU_TX) 1" \ - --nodeps --rebuild $$rpmpkg || exit 1; \ + $(def) --rebuild $$rpmpkg || exit 1; \ cp $$rpmbuild/RPMS/*/* . || exit 1; \ - $(RM) -R $$rpmbuild + rm -R $$rpmbuild) diff --git a/config/tgz.am b/config/tgz.am index 1ed09ca40..2997b1de2 100644 --- a/config/tgz.am +++ b/config/tgz.am @@ -7,22 +7,20 @@ tgz-local: exit 1; \ fi) -tgz-modules: tgz-local rpm-modules +tgz-kmod: tgz-local rpm-kmod if CONFIG_KERNEL - name=${PACKAGE}-modules; \ - version=${ZFS_META_VERSION}-${ZFS_META_RELEASE}; \ - release=`echo ${LINUX_VERSION} | $(SED) -e "s/-/_/g"`; \ - arch=`$(RPM) -qp $${name}-$${version}.src.rpm --qf %{arch} | tail -1`; \ - pkg1=$${name}-$${version}_$${release}.$${arch}.rpm; \ - pkg2=$${name}-devel-$${version}_$${release}.$${arch}.rpm; \ - fakeroot $(ALIEN) --scripts --to-tgz $$pkg1 $$pkg2; \ - $(RM) $$pkg1 $$pkg2 + name=${PACKAGE}; \ + version=${VERSION}-${RELEASE}; \ + arch=`$(RPM) -qp $${name}-kmod-$${version}.src.rpm --qf %{arch} | tail -1`; \ + pkg1=kmod-$${name}*$${version}.$${arch}.rpm; \ + fakeroot $(ALIEN) --scripts --to-tgz $$pkg1; \ + $(RM) $$pkg1 endif tgz-utils: tgz-local rpm-utils if CONFIG_USER name=${PACKAGE}; \ - version=${ZFS_META_VERSION}-${ZFS_META_RELEASE}; \ + version=${VERSION}-${RELEASE}; \ arch=`$(RPM) -qp $${name}-$${version}.src.rpm --qf %{arch} | tail -1`; \ pkg1=$${name}-$${version}.$${arch}.rpm; \ pkg2=$${name}-devel-$${version}.$${arch}.rpm; \ @@ -31,4 +29,4 @@ if CONFIG_USER $(RM) $$pkg1 $$pkg2 $$pkg3 endif -tgz: tgz-modules tgz-utils +tgz: tgz-kmod tgz-utils diff --git a/config/zfs-build.m4 b/config/zfs-build.m4 index f05a4dcd0..cccd87ff2 100644 --- a/config/zfs-build.m4 +++ b/config/zfs-build.m4 @@ -109,6 +109,11 @@ dnl # Check for rpm+rpmbuild to build RPM packages. If these tools dnl # are missing it is non-fatal but you will not be able to build dnl # RPM packages and will be warned if you try too. dnl # +dnl # By default the generic spec file will be used because it requires +dnl # minimal dependencies. Distribution specific spec files can be +dnl # placed under the 'rpm/<distribution>' directory and enabled using +dnl # the --with-spec=<distribution> configure option. +dnl # AC_DEFUN([ZFS_AC_RPM], [ RPM=rpm RPMBUILD=rpmbuild @@ -133,6 +138,25 @@ AC_DEFUN([ZFS_AC_RPM], [ AC_MSG_RESULT([$HAVE_RPMBUILD]) ]) + RPM_DEFINE_COMMON= + RPM_DEFINE_UTIL= + RPM_DEFINE_KMOD='--define "kernels $(LINUX_VERSION)"' + RPM_DEFINE_DKMS= + + SRPM_DEFINE_COMMON='--define "build_src_rpm 1"' + SRPM_DEFINE_UTIL= + SRPM_DEFINE_KMOD= + SRPM_DEFINE_DKMS= + + RPM_SPEC_DIR="rpm/generic" + AC_ARG_WITH([spec], + AS_HELP_STRING([--with-spec=SPEC], + [Spec files 'generic|fedora']), + [RPM_SPEC_DIR="rpm/$withval"]) + + AC_MSG_CHECKING([whether spec files are available]) + AC_MSG_RESULT([yes ($RPM_SPEC_DIR/*.spec.in)]) + AC_SUBST(HAVE_RPM) AC_SUBST(RPM) AC_SUBST(RPM_VERSION) @@ -140,6 +164,16 @@ AC_DEFUN([ZFS_AC_RPM], [ AC_SUBST(HAVE_RPMBUILD) AC_SUBST(RPMBUILD) AC_SUBST(RPMBUILD_VERSION) + + AC_SUBST(RPM_SPEC_DIR) + AC_SUBST(RPM_DEFINE_UTIL) + AC_SUBST(RPM_DEFINE_KMOD) + AC_SUBST(RPM_DEFINE_DKMS) + AC_SUBST(RPM_DEFINE_COMMON) + AC_SUBST(SRPM_DEFINE_UTIL) + AC_SUBST(SRPM_DEFINE_KMOD) + AC_SUBST(SRPM_DEFINE_DKMS) + AC_SUBST(SRPM_DEFINE_COMMON) ]) dnl # diff --git a/config/zfs-meta.m4 b/config/zfs-meta.m4 index 8b3689af7..a961657cd 100644 --- a/config/zfs-meta.m4 +++ b/config/zfs-meta.m4 @@ -46,6 +46,9 @@ AC_DEFUN([ZFS_AC_META], [ [Define the project release.] ) AC_SUBST([ZFS_META_RELEASE]) + + RELEASE="$ZFS_META_RELEASE" + AC_SUBST([RELEASE]) fi ZFS_META_LICENSE=_ZFS_AC_META_GETVAL([LICENSE]); diff --git a/configure.ac b/configure.ac index 669094a55..413114bac 100644 --- a/configure.ac +++ b/configure.ac @@ -119,11 +119,17 @@ AC_CONFIG_FILES([ scripts/zpios-test/Makefile scripts/zpool-config/Makefile scripts/common.sh - zfs.spec - zfs-modules.spec + rpm/Makefile + rpm/fedora/Makefile + rpm/fedora/zfs.spec + rpm/fedora/zfs-kmod.spec + rpm/fedora/zfs-dkms.spec + rpm/generic/Makefile + rpm/generic/zfs.spec + rpm/generic/zfs-kmod.spec + rpm/generic/zfs-dkms.spec zfs-script-config.sh zfs.release - dkms.conf ]) AC_OUTPUT diff --git a/dkms.conf.in b/dkms.conf.in deleted file mode 100644 index 66079dafa..000000000 --- a/dkms.conf.in +++ /dev/null @@ -1,36 +0,0 @@ -AUTOINSTALL="yes" -PACKAGE_NAME="@PACKAGE@" -PACKAGE_VERSION="@VERSION@" -PRE_BUILD="configure - --prefix=/usr - --with-config=kernel - --with-linux=$(case `lsb_release -is` in - (Debian) echo ${kernel_source_dir/%build/source} ;; - (*) echo ${kernel_source_dir} ;; - esac) - --with-linux-obj=${kernel_source_dir} - --with-spl-timeout=180 -" -POST_INSTALL="dkms.postinst -a ${arch} -k ${kernelver} -t ${dkms_tree} - -n ${PACKAGE_NAME} -v ${PACKAGE_VERSION} -" -REMAKE_INITRD="no" -MAKE[0]="make" -BUILT_MODULE_NAME[0]="zavl" -BUILT_MODULE_LOCATION[0]="module/avl/" -DEST_MODULE_LOCATION[0]="/extra/avl/avl" -BUILT_MODULE_NAME[1]="znvpair" -BUILT_MODULE_LOCATION[1]="module/nvpair/" -DEST_MODULE_LOCATION[1]="/extra/nvpair/znvpair" -BUILT_MODULE_NAME[2]="zunicode" -BUILT_MODULE_LOCATION[2]="module/unicode/" -DEST_MODULE_LOCATION[2]="/extra/unicode/zunicode" -BUILT_MODULE_NAME[3]="zcommon" -BUILT_MODULE_LOCATION[3]="module/zcommon/" -DEST_MODULE_LOCATION[3]="/extra/zcommon/zcommon" -BUILT_MODULE_NAME[4]="zfs" -BUILT_MODULE_LOCATION[4]="module/zfs/" -DEST_MODULE_LOCATION[4]="/extra/zfs/zfs" -BUILT_MODULE_NAME[5]="zpios" -BUILT_MODULE_LOCATION[5]="module/zpios/" -DEST_MODULE_LOCATION[5]="/extra/zpios/zpios" diff --git a/rpm/Makefile.am b/rpm/Makefile.am new file mode 100644 index 000000000..e41cdda2e --- /dev/null +++ b/rpm/Makefile.am @@ -0,0 +1 @@ +SUBDIRS = fedora generic diff --git a/rpm/fedora/.gitignore b/rpm/fedora/.gitignore new file mode 100644 index 000000000..7f5daafdd --- /dev/null +++ b/rpm/fedora/.gitignore @@ -0,0 +1,3 @@ +/zfs-dkms.spec +/zfs-kmod.spec +/zfs.spec diff --git a/rpm/fedora/Makefile.am b/rpm/fedora/Makefile.am new file mode 100644 index 000000000..89b13640d --- /dev/null +++ b/rpm/fedora/Makefile.am @@ -0,0 +1 @@ +EXTRA_DIST = zfs.spec.in zfs-kmod.spec.in zfs-dkms.spec.in diff --git a/rpm/fedora/zfs-dkms.spec.in b/rpm/fedora/zfs-dkms.spec.in new file mode 120000 index 000000000..ffa051baa --- /dev/null +++ b/rpm/fedora/zfs-dkms.spec.in @@ -0,0 +1 @@ +../generic/zfs-dkms.spec.in
\ No newline at end of file diff --git a/rpm/fedora/zfs-kmod.spec.in b/rpm/fedora/zfs-kmod.spec.in new file mode 100644 index 000000000..ac5f42a24 --- /dev/null +++ b/rpm/fedora/zfs-kmod.spec.in @@ -0,0 +1,117 @@ +%define module @PACKAGE@ +%define repo rpmfusion + +%define buildforkernels newest +#define buildforkernels current +#define buildforkernels akmod + +%bcond_with debug +%bcond_with debug_dmu_tx + + +Name: %{module}-kmod + +Version: @VERSION@ +Release: @RELEASE@%{?dist} +Summary: Kernel module(s) + +Group: System Environment/Kernel +License: @ZFS_META_LICENSE@ +URL: http://zfsonlinux.org/ +Source0: %{module}-%{version}.tar.gz +Source10: kmodtool +BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n) +ExclusiveArch: i586 i686 x86_64 + +# Likely compiles but is not supported. +ExcludeArch: ppc ppc64 + +# The developments headers will conflict with the dkms packages. +Conflicts: %{module}-dkms + +BuildRequires: %{_bindir}/kmodtool + +%global KmodsBuildRequires kmod-spl-devel +%global KmodsRequires kmod-spl + +%{!?kernels:BuildRequires: buildsys-build-rpmfusion-kerneldevpkgs-%{?buildforkernels:%{buildforkernels}}%{!?buildforkernels:current}-%{_target_cpu} } + +%if 0%{?fedora} >= 17 +%define prefix /usr +%endif + +# Kmodtool does its magic here. A patched version of kmodtool is shipped +# with the source rpm until kmod development packages are supported upstream. +# https://bugzilla.rpmfusion.org/show_bug.cgi?id=2714 +%{expand:%(sh %{SOURCE10} --target %{_target_cpu} --repo %{repo} --kmodname %{name} --devel %{?prefix:--prefix "%{?prefix}"} %{?buildforkernels:--%{buildforkernels}} %{?kernels:--for-kernels "%{?kernels}"} 2>/dev/null) } + + +%description +This package contains the ZFS kernel modules. + +%prep +# Error out if there was something wrong with kmodtool. +%{?kmodtool_check} + +# Print kmodtool output for debugging purposes: +sh %{SOURCE10} --target %{_target_cpu} --repo %{repo} --kmodname %{name} --devel %{?buildforkernels:--%{buildforkernels}} %{?kernels:--for-kernels "%{?kernels}"} 2>/dev/null + +%if %{with debug} + %define debug --enable-debug +%else + %define debug --disable-debug +%endif + +%if %{with debug_dmu_tx} + %define debug_dmu_tx --enable-debug-dmu-tx +%else + %define debug_dmu_tx --disable-debug-dmu-tx +%endif + +# Leverage VPATH from configure to avoid making multiple copies. +%define _configure ../%{module}-%{version}/configure + +%setup -q -c -T -a 0 + +for kernel_version in %{?kernel_versions}; do + %{__mkdir} _kmod_build_${kernel_version%%___*} +done + +%build +for kernel_version in %{?kernel_versions}; do + pushd _kmod_build_${kernel_version%%___*} + %configure \ + --with-config=kernel \ + --with-linux="${kernel_version##*___}" \ + --with-linux-obj="${kernel_version##*___}" \ + --with-spl="/usr/src/spl-%{version}" \ + --with-spl-obj="/usr/src/spl-%{version}/${kernel_version%%___*}" \ + %{debug} \ + %{debug_dmu_tx} + make %{?_smp_mflags} + popd +done + + +%install +rm -rf ${RPM_BUILD_ROOT} + +# Relies on the kernel 'modules_install' make target. +for kernel_version in %{?kernel_versions}; do + pushd _kmod_build_${kernel_version%%___*} + make install \ + DESTDIR=${RPM_BUILD_ROOT} \ + %{?prefix:INSTALL_MOD_PATH=%{?prefix}} \ + INSTALL_MOD_DIR=%{kmodinstdir_postfix} + popd +done +chmod u+x ${RPM_BUILD_ROOT}%{kmodinstdir_prefix}/*/extra/*/*/* +%{?akmod_install} + + +%clean +rm -rf $RPM_BUILD_ROOT + +%changelog +* Tue Mar 12 2013 Brian Behlendorf <[email protected]> - 0.6.0-1 +- Initial kmods2 packaging. diff --git a/rpm/fedora/zfs.spec.in b/rpm/fedora/zfs.spec.in new file mode 120000 index 000000000..4c8079166 --- /dev/null +++ b/rpm/fedora/zfs.spec.in @@ -0,0 +1 @@ +../generic/zfs.spec.in
\ No newline at end of file diff --git a/rpm/generic/.gitignore b/rpm/generic/.gitignore new file mode 100644 index 000000000..7f5daafdd --- /dev/null +++ b/rpm/generic/.gitignore @@ -0,0 +1,3 @@ +/zfs-dkms.spec +/zfs-kmod.spec +/zfs.spec diff --git a/rpm/generic/Makefile.am b/rpm/generic/Makefile.am new file mode 100644 index 000000000..89b13640d --- /dev/null +++ b/rpm/generic/Makefile.am @@ -0,0 +1 @@ +EXTRA_DIST = zfs.spec.in zfs-kmod.spec.in zfs-dkms.spec.in diff --git a/rpm/generic/zfs-dkms.spec.in b/rpm/generic/zfs-dkms.spec.in new file mode 100644 index 000000000..3713b1a90 --- /dev/null +++ b/rpm/generic/zfs-dkms.spec.in @@ -0,0 +1,67 @@ +%define module @PACKAGE@ +%define mkconf scripts/dkms.mkconf + +Name: %{module}-dkms + +Version: @VERSION@ +Release: @RELEASE@%{?dist} +Summary: Kernel module(s) (dkms) + +Group: System Environment/Kernel +License: @ZFS_META_LICENSE@ +URL: http://zfsonlinux.org/ +Source0: %{module}-%{version}.tar.gz +BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n) +BuildArch: noarch + +Requires: dkms >= 2.2.0.2 +Provides: %{module}-kmod = %{version} +Conflicts: %{module}-kmod + +%description +This package contains the dkms ZFS kernel modules. + +%prep +%setup -q -n %{module}-%{version} + +%build +%{mkconf} -n %{module} -v %{version} -f dkms.conf + +%install +if [ "$RPM_BUILD_ROOT" != "/" ]; then + rm -rf $RPM_BUILD_ROOT +fi +mkdir -p $RPM_BUILD_ROOT/usr/src/ +cp -rf ${RPM_BUILD_DIR}/%{module}-%{version} $RPM_BUILD_ROOT/usr/src/ + +%clean +if [ "$RPM_BUILD_ROOT" != "/" ]; then + rm -rf $RPM_BUILD_ROOT +fi + +%files +%defattr(-,root,root) +/usr/src/%{module}-%{version} + +%post +for POSTINST in /usr/lib/dkms/common.postinst; do + if [ -f $POSTINST ]; then + $POSTINST %{module} %{version} + exit $? + fi + echo "WARNING: $POSTINST does not exist." +done +echo -e "ERROR: DKMS version is too old and %{module} was not" +echo -e "built with legacy DKMS support." +echo -e "You must either rebuild %{module} with legacy postinst" +echo -e "support or upgrade DKMS to a more current version." +exit 1 + +%preun +dkms remove -m %{module} -v %{version} --all --rpm_safe_upgrade +exit 0 + +%changelog +* Tue Mar 12 2013 Brian Behlendorf <[email protected]> - 0.6.0-1 +- Initial dkms packaging. + diff --git a/rpm/generic/zfs-kmod.spec.in b/rpm/generic/zfs-kmod.spec.in new file mode 100644 index 000000000..8b2dcd152 --- /dev/null +++ b/rpm/generic/zfs-kmod.spec.in @@ -0,0 +1,130 @@ +%define module @PACKAGE@ + +%bcond_with debug +%bcond_with debug_dmu_tx + + +Name: %{module}-kmod + +Version: @VERSION@ +Release: @RELEASE@%{?dist} +Summary: Kernel module(s) + +Group: System Environment/Kernel +License: @ZFS_META_LICENSE@ +URL: http://zfsonlinux.org/ +Source0: %{module}-%{version}.tar.gz +Source10: kmodtool +BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n) + +# The developments headers will conflict with the dkms packages. +Conflicts: %{module}-dkms + +# Source packages minimally require a kernel-devel dependency. +%{?rhel:BuildRequires: kernel-devel} +%{?fedora:BuildRequires: kernel-devel} +%{?suse_version:BuildRequires: kernel-source} + +%if 0%{?rhel}%{?fedora}%{?suse_version} +%global KmodsBuildRequires kmod-spl-devel +%global KmodsRequires kmod-spl +%endif + +# Binary packages build against all installed kernels by default. +%if !%{defined kernels} && !%{defined build_src_rpm} + %if 0%{?rhel}%{?fedora}%{?suse_version} + %define kernels %(ls -1 /usr/src/kernels) + %else + %define kernels %(ls -1 /lib/modules) + %endif +%endif + +%if 0%{?fedora} >= 17 +%define prefix /usr +%endif + +# Kmodtool does its magic here. A patched version of kmodtool is shipped +# with the source rpm until kmod development packages are supported upstream. +# https://bugzilla.rpmfusion.org/show_bug.cgi?id=2714 +%{expand:%(bash %{SOURCE10} --target %{_target_cpu} --kmodname %{name} --devel %{?prefix:--prefix "%{?prefix}"} %{?kernels:--for-kernels "%{?kernels}"} 2>/dev/null) } + + +%description +This package contains the ZFS kernel modules. + +%prep +# Error out if there was something wrong with kmodtool. +%{?kmodtool_check} + +# Print kmodtool output for debugging purposes: +bash %{SOURCE10} --target %{_target_cpu} --repo %{repo} --kmodname %{name} --devel %{?prefix:--prefix "%{?prefix}"} %{?kernels:--for-kernels "%{?kernels}"} 2>/dev/null + +%if %{with debug} + %define debug --enable-debug +%else + %define debug --disable-debug +%endif + +%if %{with debug_dmu_tx} + %define debug_dmu_tx --enable-debug-dmu-tx +%else + %define debug_dmu_tx --disable-debug-dmu-tx +%endif + +# Leverage VPATH from configure to avoid making multiple copies. +%define _configure ../%{module}-%{version}/configure + +%setup -q -c -T -a 0 + +for kernel_version in %{?kernel_versions}; do + %{__mkdir} _kmod_build_${kernel_version%%___*} +done + +%build +for kernel_version in %{?kernel_versions}; do + cd _kmod_build_${kernel_version%%___*} + %configure \ + --with-config=kernel \ +%if 0%{?rhel}%{?fedora} + --with-linux="${kernel_version##*___}" \ + --with-linux-obj="${kernel_version##*___}" \ +%else + --with-linux=\ + %(if [ -e /lib/modules/${kernel_version%%___*}/source ]; then \ + echo "/lib/modules/${kernel_version%%___*}/source" \ + else \ + echo "/lib/modules/${kernel_version%%___*}/build" \ + fi) \ + --with-linux-obj="/lib/modules/${kernel_version%%___*}/build" \ +%endif + --with-spl="/usr/src/spl-%{version}" \ + --with-spl-obj="/usr/src/spl-%{version}/${kernel_version%%___*}" \ + %{debug} \ + %{debug_dmu_tx} + make %{?_smp_mflags} + cd .. +done + + +%install +rm -rf ${RPM_BUILD_ROOT} + +# Relies on the kernel 'modules_install' make target. +for kernel_version in %{?kernel_versions}; do + cd _kmod_build_${kernel_version%%___*} + make install \ + DESTDIR=${RPM_BUILD_ROOT} \ + %{?prefix:INSTALL_MOD_PATH=%{?prefix}} \ + INSTALL_MOD_DIR=%{kmodinstdir_postfix} + cd .. +done +chmod u+x ${RPM_BUILD_ROOT}%{kmodinstdir_prefix}/*/extra/*/*/* +%{?akmod_install} + + +%clean +rm -rf $RPM_BUILD_ROOT + +%changelog +* Tue Mar 12 2013 Brian Behlendorf <[email protected]> - 0.6.0-1 +- Initial kmods2 packaging. diff --git a/rpm/generic/zfs.spec.in b/rpm/generic/zfs.spec.in new file mode 100644 index 000000000..05d55d975 --- /dev/null +++ b/rpm/generic/zfs.spec.in @@ -0,0 +1,147 @@ +%global _sbindir /sbin +%global _libdir /%{_lib} +%if 0%{?fedora} >= 17 +%global _udevdir %{_prefix}/lib/udev +%global _dracutdir %{_prefix}/lib/dracut +%else +%global _udevdir /lib/udev +%global _dracutdir /lib/dracut +%endif + +%bcond_with debug +%bcond_with blkid +%bcond_with selinux + + +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 + +Requires: %{name}-kmod >= %{version} +Provides: %{name}-kmod-common = %{version} + +%if 0%{?rhel}%{?fedora}%{?suse_version} +BuildRequires: zlib-devel +BuildRequires: libuuid-devel +%if %{with blkid} +BuildRequires: libblkid-devel +%endif +%if %{with selinux} +BuildRequires: libselinux-devel +%endif +%endif + +%description +This package contains the ZFS command line utilities and libraries. + +%package devel +Summary: Development headers +Group: System Environment/Kernel +Requires: %{name}%{?_isa} = %{version}-%{release} + +%description devel +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. + +%prep +%if %{with debug} + %define debug --enable-debug +%else + %define debug --disable-debug +%endif +%if %{with blkid} + %define blkid --with-blkid +%else + %define blkid --without-blkid +%endif +%if %{with selinux} + %define selinux --with-selinux +%else + %define selinux --without-selinux +%endif + +%setup -q + +%build +%configure \ + --with-config=user \ + --with-udevdir=%{_udevdir} \ + --with-dracutdir=%{_dracutdir} \ + --disable-static \ + %{debug} \ + %{blkid} \ + %{selinux} +make %{?_smp_mflags} + +%install +%{__rm} -rf $RPM_BUILD_ROOT +make install DESTDIR=%{?buildroot} +find %{?buildroot}%{_libdir} -name '*.la' -exec rm -f {} \; + +%post -p /sbin/ldconfig + +%postun -p /sbin/ldconfig + +%files +%doc AUTHORS COPYRIGHT DISCLAIMER +%doc OPENSOLARIS.LICENSE README.markdown +%{_sbindir}/* +%{_libdir}/*.so.1* +%{_mandir}/man1/* +%{_mandir}/man5/* +%{_mandir}/man8/* +%{_udevdir}/vdev_id +%{_udevdir}/zvol_id +%{_udevdir}/rules.d/* +%config(noreplace) %{_sysconfdir}/%{name} +# Systemd integration is still required. +%exclude %{_sysconfdir}/init.d/* + +%files devel +%{_libdir}/*.so +%{_includedir}/* + +%files test +%{_datadir}/%{name} + +%files dracut +%doc dracut/README.dracut.markdown +%{_dracutdir}/modules.d/* + +%changelog +* Tue Mar 12 2013 Brian Behlendorf <[email protected]> - 0.6.0-1 +- Refreshed RPM packaging. diff --git a/scripts/Makefile.am b/scripts/Makefile.am index 80e9cd19a..08a32b439 100644 --- a/scripts/Makefile.am +++ b/scripts/Makefile.am @@ -1,5 +1,8 @@ SUBDIRS = zpool-config zpios-test zpios-profile +EXTRA_DIST = dkms.mkconf dkms.postinst kmodtool + +pkgdatadir = $(datadir)/@PACKAGE@ dist_pkgdata_SCRIPTS = \ $(top_builddir)/scripts/common.sh \ $(top_srcdir)/scripts/zconfig.sh \ diff --git a/scripts/dkms.mkconf b/scripts/dkms.mkconf new file mode 100755 index 000000000..2e07be481 --- /dev/null +++ b/scripts/dkms.mkconf @@ -0,0 +1,88 @@ +#!/bin/sh + +PROG=$0 + +pkgcfg=/etc/sysconfig/zfs + +while getopts "n:v:c:f:" opt; do + case $opt in + n) pkgname=$OPTARG ;; + v) pkgver=$OPTARG ;; + c) pkgcfg=$OPTARG ;; + f) filename=$OPTARG ;; + esac +done + +if [ -z "${pkgname}" -o -z "${pkgver}" -o -z "${filename}" ]; then + echo "Usage: $PROG -n <pkgname> -v <pkgver> -c <pkgcfg> -f <filename>" + exit 1 +fi + +cat >${filename} <<EOF +PACKAGE_NAME="${pkgname}" +PACKAGE_VERSION="${pkgver}" +PACKAGE_CONFIG="${pkgcfg}" +PRE_BUILD="configure + --prefix=/usr + --with-config=kernel + --with-spl=\${dkms_tree}/spl/\${PACKAGE_VERSION}/build + --with-spl-obj=\${dkms_tree}/spl/\${PACKAGE_VERSION}/\${kernelver}/\${arch} + --with-spl-timeout=300 + \$( + [[ -r \${PACKAGE_CONFIG} ]] \\ + && source \${PACKAGE_CONFIG} \\ + && shopt -q -s extglob \\ + && \\ + { + if [[ \${ZFS_DKMS_ENABLE_DEBUG,,} == @(y|yes) ]] + then + echo --enable-debug + fi + if [[ \${ZFS_DKMS_ENABLE_DMU_TX,,} == @(y|yes) ]] + then + echo --enable-debug-dmu-tx + fi + } + ) +" +POST_INSTALL="scripts/dkms.postinst + -n \${PACKAGE_NAME} + -v \${PACKAGE_VERSION} + -a \${arch} + -k \${kernelver} + -t \${dkms_tree} +" +AUTOINSTALL="yes" +REMAKE_INITRD="no" +MAKE[0]="make" +STRIP[0]="\$( + [[ -r \${PACKAGE_CONFIG} ]] \\ + && source \${PACKAGE_CONFIG} \\ + && shopt -q -s extglob \\ + && [[ \${ZFS_DKMS_DISABLE_STRIP,,} == @(y|yes) ]] \\ + && echo -n no +)" +STRIP[1]="\${STRIP[0]}" +STRIP[2]="\${STRIP[0]}" +STRIP[3]="\${STRIP[0]}" +STRIP[4]="\${STRIP[0]}" +STRIP[5]="\${STRIP[0]}" +BUILT_MODULE_NAME[0]="zavl" +BUILT_MODULE_LOCATION[0]="module/avl/" +DEST_MODULE_LOCATION[0]="/extra/avl/avl" +BUILT_MODULE_NAME[1]="znvpair" +BUILT_MODULE_LOCATION[1]="module/nvpair/" +DEST_MODULE_LOCATION[1]="/extra/nvpair/znvpair" +BUILT_MODULE_NAME[2]="zunicode" +BUILT_MODULE_LOCATION[2]="module/unicode/" +DEST_MODULE_LOCATION[2]="/extra/unicode/zunicode" +BUILT_MODULE_NAME[3]="zcommon" +BUILT_MODULE_LOCATION[3]="module/zcommon/" +DEST_MODULE_LOCATION[3]="/extra/zcommon/zcommon" +BUILT_MODULE_NAME[4]="zfs" +BUILT_MODULE_LOCATION[4]="module/zfs/" +DEST_MODULE_LOCATION[4]="/extra/zfs/zfs" +BUILT_MODULE_NAME[5]="zpios" +BUILT_MODULE_LOCATION[5]="module/zpios/" +DEST_MODULE_LOCATION[5]="/extra/zpios/zpios" +EOF diff --git a/dkms.postinst b/scripts/dkms.postinst index 3cbc7c7ce..3cbc7c7ce 100755 --- a/dkms.postinst +++ b/scripts/dkms.postinst diff --git a/scripts/kmodtool b/scripts/kmodtool new file mode 100755 index 000000000..2170c4a90 --- /dev/null +++ b/scripts/kmodtool @@ -0,0 +1,552 @@ +#!/bin/bash + +# kmodtool - Helper script for building kernel module RPMs +# Copyright (c) 2003-2012 Ville Skyttä <[email protected]>, +# Thorsten Leemhuis <[email protected]> +# Nicolas Chauvet <[email protected]> +# +# Permission is hereby granted, free of charge, to any person obtaining +# a copy of this software and associated documentation files (the +# "Software"), to deal in the Software without restriction, including +# without limitation the rights to use, copy, modify, merge, publish, +# distribute, sublicense, and/or sell copies of the Software, and to +# permit persons to whom the Software is furnished to do so, subject to +# the following conditions: +# +# The above copyright notice and this permission notice shall be +# included in all copies or substantial portions of the Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND +# NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE +# LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +# OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION +# WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + +shopt -s extglob + +myprog="kmodtool-${repo}" +myver="0.12.1" + +kmodname= +build_kernels="current" +kernels_known_variants= +kernel_versions= +kernel_versions_to_build_for= +prefix= +filterfile= +target= + +error_out() +{ + local errorlevel=${1} + shift + echo "Error: $@" >&2 + # the next line is not multi-line safe -- not needed *yet* + echo "%global kmodtool_check echo \"kmodtool error: $@\"; exit ${errorlevel};" + exit ${errorlevel} +} + +print_rpmtemplate_header() +{ + echo + echo '%global kmodinstdir_prefix '${prefix}/lib/modules/ + echo '%global kmodinstdir_postfix '/extra/${kmodname}/ + echo '%global kernel_versions '${kernel_versions} + echo +} + +print_akmodtemplate () +{ + echo + cat <<EOF + +%global akmod_install mkdir -p \$RPM_BUILD_ROOT/%{_usrsrc}/akmods/; \\\ +rpmbuild --define "_sourcedir %{_sourcedir}" \\\ +--define "_srcrpmdir \$RPM_BUILD_ROOT/%{_usrsrc}/akmods/" \\\ +-bs --nodeps %{_specdir}/%{name}.spec ; \\\ +ln -s \$(ls \$RPM_BUILD_ROOT/%{_usrsrc}/akmods/) \$RPM_BUILD_ROOT/%{_usrsrc}/akmods/${kmodname}-kmod.latest + +%package -n akmod-${kmodname} +Summary: Akmod package for ${kmodname} kernel module(s) +Group: System Environment/Kernel +Requires: kmodtool +Requires: akmods +%{?AkmodsBuildRequires:Requires: %{AkmodsBuildRequires}} +# same requires and provides as a kmods package would have +Requires: ${kmodname}-kmod-common >= %{?epoch:%{epoch}:}%{version} +Provides: ${kmodname}-kmod = %{?epoch:%{epoch}:}%{version}-%{release} +EOF + + if [[ ${obsolete_name} ]]; then + echo "Provides: akmod-${obsolete_name} = ${obsolete_version}" + echo "Obsoletes: akmod-${obsolete_name} < ${obsolete_version}" + fi + + cat <<EOF + +%description -n akmod-${kmodname} +This package provides the akmod package for the ${kmodname} kernel modules. + +%posttrans -n akmod-${kmodname} +nohup ${prefix}/sbin/akmods --from-akmod-posttrans --akmod ${kmodname} &> /dev/null & + +%files -n akmod-${kmodname} +%defattr(-,root,root,-) +%{_usrsrc}/akmods/* + +EOF +} + +print_akmodmeta () +{ + cat <<EOF +%package -n kmod-${kmodname} +Summary: Metapackage which tracks in ${kmodname} kernel module for newest kernel${dashvariant} +Group: System Environment/Kernel + +Provides: ${kmodname}-kmod = %{?epoch:%{epoch}:}%{version}-%{release} +Provides: kmod-${kmodname}-xen = %{?epoch:%{epoch}:}%{version}-%{release} +Provides: kmod-${kmodname}-smp = %{?epoch:%{epoch}:}%{version}-%{release} +Provides: kmod-${kmodname}-PAE = %{?epoch:%{epoch}:}%{version}-%{release} +Requires: akmod-${kmodname} = %{?epoch:%{epoch}:}%{version}-%{release} +EOF + + if [[ ${obsolete_name} ]]; then + echo "Provides: kmod-${obsolete_name} = ${obsolete_version}" + echo "Obsoletes: kmod-${obsolete_name} < ${obsolete_version}" + fi +cat <<EOF + +%description -n kmod-${kmodname}${dashvariant} +This is a meta-package without payload which sole purpose is to require the +${kmodname} kernel module(s) for the newest kernel${dashvariant}, +to make sure you get it together with a new kernel. + +%files -n kmod-${kmodname}${dashvariant} +%defattr(644,root,root,755) +EOF +} + +print_rpmtemplate_per_kmodpkg () +{ + if [[ "${1}" == "--custom" ]]; then + shift + local customkernel=true + elif [[ "${1}" == "--redhat" ]]; then + # this is needed for akmods + shift + local redhatkernel=true + fi + + local kernel_uname_r=${1} + local kernel_variant="${2:+-${2}}" + + # first part + cat <<EOF +%package -n kmod-${kmodname}-${kernel_uname_r} +Summary: ${kmodname} kernel module(s) for ${kernel_uname_r} +Group: System Environment/Kernel +Provides: kernel-modules-for-kernel = ${kernel_uname_r} +Provides: kmod-${kmodname}-uname-r = ${kernel_uname_r} +Provides: ${kmodname}-kmod = %{?epoch:%{epoch}:}%{version}-%{release} +Requires: ${kmodname}-kmod-common >= %{?epoch:%{epoch}:}%{version} +Requires(post): ${prefix}/sbin/depmod +Requires(postun): ${prefix}/sbin/depmod +%{?KmodsRequires:Requires: %{KmodsRequires}-uname-r = ${kernel_uname_r}} +%{?KmodsBuildRequires:BuildRequires: %{KmodsBuildRequires}-uname-r = ${kernel_uname_r}} +%{?KmodsBuildRequires:BuildRequires: %{KmodsBuildRequires}} +EOF + + if [[ ${obsolete_name} ]]; then + echo "Provides: kmod-${obsolete_name}-${kernel_uname_r} = ${obsolete_version}" + echo "Obsoletes: kmod-${obsolete_name}-${kernel_uname_r} < ${obsolete_version}" + fi + + # second part + if [[ ! "${customkernel}" ]]; then + cat <<EOF +Requires: kernel-uname-r = ${kernel_uname_r} +BuildRequires: kernel-devel-uname-r = ${kernel_uname_r} +%post -n kmod-${kmodname}-${kernel_uname_r} +${prefix}/sbin/depmod -aeF /boot/System.map-${kernel_uname_r} ${kernel_uname_r} > /dev/null || : +%postun -n kmod-${kmodname}-${kernel_uname_r} +${prefix}/sbin/depmod -aF /boot/System.map-${kernel_uname_r} ${kernel_uname_r} &> /dev/null || : + +EOF + else + cat <<EOF +%post -n kmod-${kmodname}-${kernel_uname_r} +[[ "$(uname -r)" == "${kernel_uname_r}" ]] && ${prefix}/sbin/depmod -a > /dev/null || : +%postun -n kmod-${kmodname}-${kernel_uname_r} +[[ "$(uname -r)" == "${kernel_uname_r}" ]] && ${prefix}/sbin/depmod -a > /dev/null || : + +EOF + fi + + # third part + cat <<EOF +%description -n kmod-${kmodname}-${kernel_uname_r} +This package provides the ${kmodname} kernel modules built for the Linux +kernel ${kernel_uname_r} for the %{_target_cpu} family of processors. +%files -n kmod-${kmodname}-${kernel_uname_r} +%defattr(644,root,root,755) +%dir $prefix/lib/modules/${kernel_uname_r}/extra +${prefix}/lib/modules/${kernel_uname_r}/extra/${kmodname}/ + + +EOF +} + +print_rpmtemplate_kmoddevelpkg () +{ + cat <<EOF +%package -n kmod-${kmodname}-devel +Summary: ${kmodname} kernel module(s) devel common +Group: System Environment/Kernel +Provides: ${kmodname}-devel-kmod-common = %{?epoch:%{epoch}:}%{version}-%{release} + +%description -n kmod-${kmodname}-devel +This package provides the common header files to build kernel modules +which depend on the ${kmodname} kernel module. +%files -n kmod-${kmodname}-devel +%defattr(644,root,root,755) +%{_usrsrc}/${kmodname}-%{version} +EOF + + for kernel in ${1}; do + local kernel_uname_r=${kernel} + echo "%exclude %{_usrsrc}/${kmodname}-%{version}/${kernel_uname_r}" + done + + echo + echo +} + +print_rpmtemplate_per_kmoddevelpkg () +{ + if [[ "${1}" == "--custom" ]]; then + shift + local customkernel=true + elif [[ "${1}" == "--redhat" ]]; then + # this is needed for akmods + shift + local redhatkernel=true + fi + + local kernel_uname_r=${1} + local kernel_variant="${2:+-${2}}" + + cat <<EOF +%package -n kmod-${kmodname}-devel-${kernel_uname_r} +Summary: ${kmodname} kernel module(s) devel for ${kernel_uname_r} +Group: System Environment/Kernel +Requires: ${kmodname}-devel-kmod-common = %{?epoch:%{epoch}:}%{version}-%{release} +Provides: kmod-${kmodname}-devel-uname-r = ${kernel_uname_r} +EOF + + # second part + if [[ ! "${customkernel}" ]]; then + cat <<EOF +Requires: kernel-uname-r = ${kernel_uname_r} +BuildRequires: kernel-devel-uname-r = ${kernel_uname_r} +EOF + fi + + cat <<EOF +%description -n kmod-${kmodname}-devel-${kernel_uname_r} +This package provides objects and symbols required to build kernel modules +which depend on the ${kmodname} kernel modules built for the Linux +kernel ${kernel_uname_r} for the %{_target_cpu} family of processors. +%files -n kmod-${kmodname}-devel-${kernel_uname_r} +%defattr(644,root,root,755) +%{_usrsrc}/${kmodname}-%{version}/${kernel_uname_r} + + +EOF +} + +print_rpmtemplate_kmodmetapkg () +{ + local kernel_uname_r=${1} + local kernel_variant="${2:+-${2}}" + + cat <<EOF +%package -n kmod-${kmodname}${kernel_variant} +Summary: Metapackage which tracks in ${kmodname} kernel module for newest kernel${kernel_variant} +Group: System Environment/Kernel + +Provides: ${kmodname}-kmod = %{?epoch:%{epoch}:}%{version}-%{release} +Requires: kmod-${kmodname}-${kernel_uname_r} >= %{?epoch:%{epoch}:}%{version}-%{release} +EOF + + if [[ ${obsolete_name} ]]; then + echo "Provides: kmod-${obsolete_name}${kernel_variant} = ${obsolete_version}" + echo "Obsoletes: kmod-${obsolete_name}${kernel_variant} < ${obsolete_version}" + fi + + cat <<EOF + +%description -n kmod-${kmodname}${kernel_variant} +This is a meta-package without payload which sole purpose is to require the +${kmodname} kernel module(s) for the newest kernel${kernel_variant}. +to make sure you get it together with a new kernel. + +%files -n kmod-${kmodname}${kernel_variant} +%defattr(644,root,root,755) + + +EOF +} + +print_customrpmtemplate () +{ + for kernel in ${1} + do + if [[ -e "/usr/src/kernels/${kernel}" ]] ; then + # this looks like a Fedora/RH kernel -- print a normal template (which includes the proper BR) and be happy :) + kernel_versions="${kernel_versions}${kernel}___%{_usrsrc}/kernels/${kernel} " + + # parse kernel versions string and print template + local kernel_verrelarch=${kernel%%${kernels_known_variants}} + print_rpmtemplate_per_kmodpkg --redhat ${kernel} ${kernel##${kernel_verrelarch}} + + # create development package + if [[ "${devel}" ]]; then + print_rpmtemplate_per_kmoddevelpkg --redhat ${kernel} ${kernel##${kernel_verrelarch}} + fi + elif [[ -e ${prefix}/lib/modules/"${kernel}"/build/Makefile ]] ; then + # likely a user-build-kernel with available buildfiles + # fixme: we should check if uname from Makefile is the same as ${kernel} + + kernel_versions="${kernel_versions}${kernel}___${prefix}/lib/modules/${kernel}/build/ " + print_rpmtemplate_per_kmodpkg --custom "${kernel}" + + # create development package + if [[ "${devel}" ]]; then + print_rpmtemplate_per_kmoddevelpkg --custom "${kernel}" + fi + else + error_out 2 "Don't know how to handle ${kernel} -- ${prefix}/lib/modules/${kernel}/build/Makefile not found" + fi + done + + # create common development package + if [[ "${devel}" ]]; then + print_rpmtemplate_kmoddevelpkg "${1}" + fi + + # well, it's no header anymore, but who cares ;-) + print_rpmtemplate_header +} + + +print_rpmtemplate () +{ + # create kernel_versions var + for kernel_version in ${kernel_versions_to_build_for} + do + kernel_versions="${kernel_versions}${kernel_version}___%{_usrsrc}/kernels/${kernel_version} " + done + + # and print it and some other required stuff as macro + print_rpmtemplate_header + + # now print the packages itselfs + for kernel in ${kernel_versions_to_build_for} ; do + + local kernel_verrelarch=${kernel%%${kernels_known_variants}} + + # create metapackage + print_rpmtemplate_kmodmetapkg ${kernel} ${kernel##${kernel_verrelarch}} + + # create package + print_rpmtemplate_per_kmodpkg ${kernel} ${kernel##${kernel_verrelarch}} + + # create development package + if [[ "${devel}" ]]; then + print_rpmtemplate_per_kmoddevelpkg ${kernel} ${kernel##${kernel_verrelarch}} + fi + done + + # create common development package + if [[ "${devel}" ]]; then + print_rpmtemplate_kmoddevelpkg "${1}" + fi +} + +myprog_help () +{ + echo "Usage: $(basename ${0}) [OPTIONS]" + echo $'\n'"Creates a template to be used during kmod building" + echo $'\n'"Available options:" + # FIXME echo " --datadir <dir> -- look for our shared files in <dir>" + echo " --filterfile <file> -- filter the results with grep --file <file>" + echo " --for-kernels <list> -- created templates only for these kernels" + echo " --kmodname <file> -- name of the kmod (required)" + echo " --devel -- make kmod-devel package" + echo " --noakmod -- no akmod package" + echo " --repo <name> -- use buildsys-build-<name>-kerneldevpkgs" + echo " --target <arch> -- target-arch (required)" +} + +while [ "${1}" ] ; do + case "${1}" in + --filterfile) + shift + if [[ ! "${1}" ]] ; then + error_out 2 "Please provide path to a filter-file together with --filterfile" >&2 + elif [[ ! -e "${1}" ]]; then + error_out 2 "Filterfile ${1} not found" >&2 + fi + filterfile="${1}" + shift + ;; + --kmodname) + shift + if [[ ! "${1}" ]] ; then + error_out 2 "Please provide the name of the kmod together with --kmodname" >&2 + fi + # strip pending -kmod + kmodname="${1%%-kmod}" + shift + ;; + --devel) + shift + devel="true" + ;; + --prefix) + shift + if [[ ! "${1}" ]] ; then + error_out 2 "Please provide a prefix with --prefix" >&2 + fi + prefix="${1}" + shift + ;; + --repo) + shift + if [[ ! "${1}" ]] ; then + error_out 2 "Please provide the name of the repo together with --repo" >&2 + fi + repo=${1} + shift + ;; + --for-kernels) + shift + if [[ ! "${1}" ]] ; then + error_out 2 "Please provide the name of the kmod together with --kmodname" >&2 + fi + for_kernels="${1}" + shift + ;; + --noakmod) + shift + noakmod="true" + ;; + --obsolete-name) + shift + if [[ ! "${1}" ]] ; then + error_out 2 "Please provide the name of the kmod to obsolte together with --obsolete-name" >&2 + fi + obsolete_name="${1}" + shift + ;; + --obsolete-version) + shift + if [[ ! "${1}" ]] ; then + error_out 2 "Please provide the version of the kmod to obsolte together with --obsolete-version" >&2 + fi + obsolete_version="${1}" + shift + ;; + --target) + shift + target="${1}" + shift + ;; + --akmod) + shift + build_kernels="akmod" + ;; + --newest) + shift + build_kernels="newest" + ;; + --current) + shift + build_kernels="current" + ;; + --help) + myprog_help + exit 0 + ;; + --version) + echo "${myprog} ${myver}" + exit 0 + ;; + *) + echo "Error: Unknown option '${1}'." >&2 + usage >&2 + exit 2 + ;; + esac +done + +if [[ -e ./kmodtool-kernel-variants ]]; then + kernels_known_variants="$(cat ./kmodtool-kernel-variants)" +elif [[ -e /usr/share/kmodtool/kernel-variants ]] ; then + kernels_known_variants="$(cat /usr/share/kmodtool/kernel-variants)" +else + kernels_known_variants="@(smp?(-debug)|PAE?(-debug)|debug|kdump|xen|kirkwood|highbank|imx|omap|tegra)" +fi + +# general sanity checks +if [[ ! "${target}" ]]; then + error_out 2 "please pass target arch with --target" +elif [[ ! "${kmodname}" ]]; then + error_out 2 "please pass kmodname with --kmodname" +elif [[ ! "${kernels_known_variants}" ]] ; then + error_out 2 "could not determine known variants" +elif ( [[ "${obsolete_name}" ]] && [[ ! "${obsolete_version}" ]] ) || ( [[ ! "${obsolete_name}" ]] && [[ "${obsolete_version}" ]] ) ; then + error_out 2 "you need to provide both --obsolete-name and --obsolete-version" +fi + +# go +if [[ "${for_kernels}" ]]; then + # this is easy: + print_customrpmtemplate "${for_kernels}" +elif [[ "${build_kernels}" == "akmod" ]]; then + # do only a akmod package + print_akmodtemplate + print_akmodmeta +else + # seems we are on out own to decide for which kernels to build + + # we need more sanity checks in this case + if [[ ! "${repo}" ]]; then + error_out 2 "please provide repo name with --repo" + elif ! $(which buildsys-build-${repo}-kerneldevpkgs &> /dev/null) ; then + error_out 2 "buildsys-build-${repo}-kerneldevpkgs not found" + fi + + # call buildsys-build-${repo}-kerneldevpkgs to get the list of kernels + cmdoptions="--target ${target}" + + # filterfile to filter list of kernels? + if [[ "${filterfile}" ]] ; then + cmdoptions="${cmdoptions} --filterfile ${filterfile}" + fi + + kernel_versions_to_build_for="$(buildsys-build-${repo}-kerneldevpkgs --${build_kernels} ${cmdoptions})" + returncode=$? + if (( ${returncode} != 0 )); then + error_out 2 "buildsys-build-${repo}-kerneldevpkgs failed: $(buildsys-build-${repo}-kerneldevpkgs --${build_kernels} ${cmdoptions})" + fi + + if [[ "${build_kernels}" == "current" ]] && [[ ! "${noakmod}" ]]; then + print_akmodtemplate + fi + + print_rpmtemplate +fi diff --git a/zfs-modules.spec.in b/zfs-modules.spec.in deleted file mode 100644 index 4ac965998..000000000 --- a/zfs-modules.spec.in +++ /dev/null @@ -1,658 +0,0 @@ -# The following block is used to allow the source RPM to be rebuilt -# against specific kernels. It is preferable that rpmbuild define the -# require_kver, require_kdir, require_obj constants for us, but if it does not -# not we attempt to determine the correct values based on your distro. - -# kdir: Full path to the kernel source headers -# kobj: Full path to the kernel build objects -# kver: Kernel version -# kpkg: Kernel package name -# kdevpkg: Kernel devel package name -# kverpkg: Kernel package version - -%if %{defined require_kver} -%define kver %{require_kver} -%endif - -%if %{defined require_kdir} -%define kdir %{require_kdir} -%endif - -%if %{defined require_kobj} -%define kobj %{require_kobj} -%endif - -# Set using 'rpmbuild ... --with kernel ...', defaults to enabled. -%if %{defined _with_kernel} - %define with_kernel 1 -%else - %if %{defined _without_kernel} - %define with_kernel 0 - %else - %define with_kernel 1 - %endif -%endif - -# Set using 'rpmbuild ... --with kernel-debug ...', defaults to disabled. -%if %{defined _with_kernel_debug} - %define with_kernel_debug 1 -%else - %if %{defined _without_kernel_debug} - %define with_kernel_debug 0 - %else - %define with_kernel_debug 0 - %endif -%endif - -# Set using 'rpmbuild ... --with kernel-dkms ...', defaults to disabled. -%if %{defined _with_kernel_dkms} - %define with_kernel_dkms 1 -%else - %if %{defined _without_kernel_dkms} - %define with_kernel_dkms 0 - %else - %define with_kernel_dkms 0 - %endif -%endif - -# Set using 'rpmbuild ... --with debug ...', defaults to disabled. -%if %{defined _with_debug} - %define kdebug --enable-debug -%else - %if %{defined _without_debug} - %define kdebug --disable-debug - %else - %define kdebug --disable-debug - %endif -%endif - -# Set using 'rpmbuild ... --with debug-dmu-tx ...', defaults to disabled. -%if %{defined _with_debug_dmu_tx} - %define kdebug_dmu_tx --enable-debug-dmu-tx -%else - %if %{defined _without_debug_dmu_tx} - %define kdebug_dmu_tx --disable-debug-dmu-tx - %else - %define kdebug_dmu_tx --disable-debug-dmu-tx - %endif -%endif - -# SLES: -%if %{defined suse_version} - %if %{undefined kver} - %ifarch ppc64 - %define kverextra ppc64 - %else - %define kverextra default - %endif - - %if %{suse_version} >= 1100 - %define klnk %{_usrsrc}/linux-obj/%{_target_cpu}/%{kverextra} - %define krelease %{klnk}/include/config/kernel.release - %else - %define klnk %{_usrsrc}/linux-obj/%{_target_cpu}/%{kverextra} - %define krelease %{klnk}/.kernelrelease - %endif - - %define kver_kern %((echo X; %{__cat} %{krelease} 2>/dev/null)|tail -1) - %define kver_dbug %{nil} - %else - %define kver_kern %{kver} - %define kver_dbug %{nil} - %endif - - %if %{undefined kverextra} - %define kverextra %(echo %{kver_kern} | cut -f3 -d'-') - %endif - - %define kpkg_kern kernel-%{kverextra} - %define kpkg_dbug %{nil} - %define kpkg_dkms dkms - - %define kdevpkg_kern kernel-source - %define kdevpkg_dbug %{nil} - %define kdevpkg_dkms dkms - - %define kverpkg_kern %(echo %{kver_kern} | %{__sed} -e 's/-%{kverextra}//g') - %define kverpkg_dbug %{nil} - %define kverpkg_dkms 2.2.0.2 - - # The kernel and rpm versions do not strictly match under SLES11 - # e.g. kernel version 2.6.27.19-5 != rpm version 2.6.27.19-5.1 - %if %{suse_version} >= 1100 - %define koppkg >= - %else - %define koppkg = - %endif - - %if %{undefined kdir} - %define kdir_kern %{_usrsrc}/linux-%{kverpkg_kern} - %define kdir_dbug %{nil} - %else - %define kdir_kern %{kdir} - %define kdir_dbug %{nil} - %endif - - %if %{undefined kobj} - %define kobj_kern %{kdir_kern}-obj/%{_target_cpu}/%{kverextra} - %define kobj_dbug %{nil} - %else - %define kobj_kern %{kobj} - %define kobj_dbug %{nil} - %endif -%else - -# RHEL 5.x/6.x, CHAOS 5.x: -%if %{defined el5} || %{defined el6} || %{defined ch5} - %if %{undefined kver} - %define klnk %{_usrsrc}/kernels/*/include/config - %define kver_kern %((echo X; ((%{__cat} %{klnk}/kernel.release - 2>/dev/null) | %{__grep} -v debug)) | tail -1) - %define kver_dbug %((echo X; ((%{__cat} %{klnk}/kernel.release - 2>/dev/null) | %{__grep} debug)) | tail -1) - %else - %define kver_kern %{kver} - %define kver_dbug %{kver}.debug - %endif - - %define kpkg_kern kernel - %define kpkg_dbug kernel-debug - %define kpkg_dkms dkms - - %define kdevpkg_kern kernel-devel - %define kdevpkg_dbug kernel-debug-devel - %define kdevpkg_dkms dkms - - %define kverpkg_dkms 2.2.0.2 - %if %{defined el6} || %{defined ch5} - %define kverpkg_kern %(echo %{kver_kern} | %{__sed} -e 's/.%{_target_cpu}//g') - %define kverpkg_dbug %(echo %{kver_dbug} | %{__sed} -e 's/.%{_target_cpu}//g' | %{__sed} -e 's/.debug//g') - %else - %define kverpkg_kern %{kver_kern} - %define kverpkg_dbug %{kver_dbug} - %endif - - %define koppkg = - - %if %{undefined kdir} - %if %{defined el6} || %{defined ch5} - %define kdir_kern %{_usrsrc}/kernels/%{kver_kern} - %define kdir_dbug %{_usrsrc}/kernels/%{kver_dbug} - %else - %define kdir_kern %{_usrsrc}/kernels/%{kver_kern}-%{_target_cpu} - %define kdir_dbug %{_usrsrc}/kernels/%{kver_dbug}-%{_target_cpu} - %endif - %else - %define kdir_kern %{kdir} - %define kdir_dbug %{kdir}.debug - %endif - - %if %{undefined kobj} - %define kobj_kern %{kdir_kern} - %define kobj_dbug %{kdir_dbug} - %else - %define kobj_kern %{kobj} - %define kobj_dbug %{kobj}.debug - %endif -%else - -# Fedora: -%if %{defined fedora} - %if %{undefined kver} - %define klnk %{_usrsrc}/kernels/*/include/config - %define kver_kern %((echo X; ((%{__cat} %{klnk}/kernel.release - 2>/dev/null) | %{__grep} -v debug)) | tail -1) - %define kver_dbug %((echo X; ((%{__cat} %{klnk}/kernel.release - 2>/dev/null) | %{__grep} debug)) | tail -1) - %else - %define kver_kern %{kver} - %define kver_dbug %{kver}.debug - %endif - - %define kpkg_kern kernel - %define kpkg_dbug kernel-debug - %define kpkg_dkms dkms - - %define kdevpkg_kern kernel-devel - %define kdevpkg_dbug kernel-debug-devel - %define kdevpkg_dkms dkms - - %define kverpkg_dkms 2.2.0.2 - %define kverpkg_kern %(echo %{kver_kern} | %{__sed} -e 's/.%{_target_cpu}//g') - %define kverpkg_dbug %(echo %{kver_dbug} | %{__sed} -e 's/.%{_target_cpu}//g' | %{__sed} -e 's/.debug//g') - - %define koppkg = - - %if %{undefined kdir} - %define kdir_kern %{_usrsrc}/kernels/%{kver_kern} - %define kdir_dbug %{_usrsrc}/kernels/%{kver_dbug} - %else - %define kdir_kern %{kdir} - %define kdir_dbug %{kdir}.debug - %endif - - %if %{undefined kobj} - %define kobj_kern %{kdir_kern} - %define kobj_dbug %{kdir_dbug} - %else - %define kobj_kern %{kobj} - %define kobj_dbug %{kobj}.debug - %endif -%else - -# Unsupported distro: - %if %{undefined kver} - %define kver_kern %(uname -r) - %define kver_dbug %{nil} - %else - %define kver_kern %{kver} - %define kver_dbug %{nil} - %endif - - %define kverpkg_kern %{kver_kern} - %define kverpkg_dbug %{nil} - %define kverpkg_dkms %{nil} - - %if %{undefined kdir} - %define kdir_kern /lib/modules/%{kver_kern}/build - %define kdir_dbug %{nil} - %else - %define kdir_kern %{kdir} - %define kdir_dbug %{nil} - %endif - - %if %{undefined kobj} - %define kobj_kern %{kdir_kern} - %define kobj_dbug %{nil} - %else - %define kobj_kern %{kobj} - %define kobj_dbug %{nil} - %endif - -%endif -%endif -%endif - -# spldir: Full path to the spl source headers -# splobj: Full path to the spl build objects -# splver: Spl version -# splpkg: Spl package name -# spldevpkg: Spl devel package name -# splverpkg: Spl package version - -%if %{defined require_splver} -%define splver %{require_splver} -%endif - -%if %{defined require_spldir} -%define spldir %{require_spldir} -%endif - -%if %{defined require_splobj} -%define splobj %{require_splobj} -%endif - -%if %{undefined splver} - %define spllnk_kern %{_usrsrc}/spl-*/%{kver_kern} - %define spllnk_dbug %{_usrsrc}/spl-*/%{kver_dbug} - %define spllnk_dkms %{_var}/lib/dkms/spl/*/build - - %define splver_kern %((echo X; %{__cat} %{spllnk_kern}/spl.release - 2>/dev/null) | tail -1) - %define splver_dbug %((echo X; %{__cat} %{spllnk_dbug}/spl.release - 2>/dev/null) | tail -1) - %define splver_dkms %((echo X; %{__cat} %{spllnk_dkms}/spl.release - 2>/dev/null) | tail -1) -%else - %define splver_kern %{splver} - %define splver_dbug %{splver} - %define splver_dksm %{splver} -%endif - -%define splpkg_kern spl-modules -%define splpkg_dbug spl-modules-debug -%define splpkg_dkms spl-modules-dkms - -%define spldevpkg_kern spl-modules-devel -%define spldevpkg_dbug spl-modules-debug-devel -%define spldevpkg_dkms spl-modules-dkms - -%define splverpkg_kern %{splver_kern} -%define splverpkg_dbug %{splver_dbug} -%define splverpkg_dkms %{splver_dkms} - -%if %{undefined spldir} - %define spldir_kern %{_usrsrc}/spl-%{splver_kern}/%{kver_kern} - %define spldir_dbug %{_usrsrc}/spl-%{splver_dbug}/%{kver_dbug} - %define spldir_dkms %{_usrsrc}/spl-%{splver_dkms} -%else - %define spldir_kern %{spldir} - %define spldir_dbug %{spldir}.debug - %define spldir_dkms %{spldir} -%endif - -%if %{undefined splobj} - %define splobj_kern %{spldir_kern} - %define splobj_dbug %{spldir_dbug} - %define splobj_dkms %{spldir_dkms} -%else - %define splobj_kern %{splobj} - %define splobj_dbug %{splobj}.debug - %define splobj_dkms %{splobj} -%endif - - -# Distro agnostic: -%define name @PACKAGE@-modules -%define version @VERSION@ - -# The kernel version should only be appended to a binary RPM. When -# building a source RPM it must be kernel version agnostic. This means -# the source RPM must never specify a required kernel version, but the -# final RPM should be keyed to the kernel version it was built against. -%if %{defined build_src_rpm} - -%define rel_kern @ZFS_META_RELEASE@ -%define rel_dbug @ZFS_META_RELEASE@ -%define rel_dkms @ZFS_META_RELEASE@ - -%if %{defined kpkg_kern} -%define req_kern %{kpkg_kern} -%endif -%if %{defined kpkg_dbug} -%define req_dbug %{kpkg_dbug} -%endif -%if %{defined kpkg_dkms} -%define req_dkms %{kpkg_dkms} -%endif - -%define splreq_kern %{splpkg_kern} -%define splreq_dbug %{splpkg_dbug} -%define splreq_dkms %{splpkg_dkms} - -%define spldevreq_kern %{spldevpkg_kern} -%define spldevreq_dbug %{spldevpkg_dbug} -%define spldevreq_dkms %{spldevpkg_dkms} - -%else - -%define relext_kern %(echo %{kverpkg_kern} | %{__sed} -e 's/-/_/g') -%define relext_dbug %(echo %{kverpkg_dbug} | %{__sed} -e 's/-/_/g') -%define rel_kern @ZFS_META_RELEASE@_%{relext_kern} -%define rel_dbug @ZFS_META_RELEASE@_%{relext_dbug} -%define rel_dkms @ZFS_META_RELEASE@ - -%if %{defined kpkg_kern} -%define req_kern %{kpkg_kern} %{koppkg} %{kverpkg_kern} -%endif -%if %{defined kpkg_dbug} -%define req_dbug %{kpkg_dbug} %{koppkg} %{kverpkg_dbug} -%endif -%if %{defined kpkg_dkms} -%define req_dkms %{kpkg_dkms} >= %{kverpkg_dkms} -%endif - -%define splreq_kern %{splpkg_kern} = %{splverpkg_kern}_%{relext_kern} -%define splreq_dbug %{splpkg_dbug} = %{splverpkg_dbug}_%{relext_dbug} -%define splreq_dkms %{splpkg_dkms} = %{splverpkg_dkms} - -%define spldevreq_kern %{spldevpkg_kern} = %{splverpkg_kern}_%{relext_kern} -%define spldevreq_dbug %{spldevpkg_dbug} = %{splverpkg_dbug}_%{relext_dbug} -%define spldevreq_dkms %{spldevpkg_dkms} = %{splverpkg_dkms} - -%endif - -Summary: ZFS File System -Group: Utilities/System -Name: %{name} -Version: %{version} -Release: %{rel_kern} -License: @ZFS_META_LICENSE@ -URL: git://github.com/zfsonlinux/zfs.git -BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-%(%{__id} -un) -Source: @PACKAGE@-%{version}.tar.gz - -%if %{?with_kernel} - -%if %{defined req_kern} -Requires: %{req_kern} -%endif -%if %{defined kdevpkg_kern} -BuildRequires: %{kdevpkg_kern} -%endif -%if %{defined splreq_kern} -Requires: %{splreq_kern} -%endif -%if %{defined spldevpkg_kern} -BuildRequires: %{spldevpkg_kern} -%endif -Provides: lustre-backend-fs - -%endif - -%description -The %{name} package contains kernel modules and support utilities for -the %{name} file system. - -%if %{?with_kernel} - -%package devel -Summary: ZFS File System Headers and Symbols -Group: Development/Libraries -Release: %{rel_kern} -%if %{defined devreq_kern} -Requires: %{devreq_kern} -%endif -%if %{defined kdevpkg_kern} -BuildRequires: %{kdevpkg_kern} -%endif -%if %{defined spldevreq_kern} -Requires: %{spldevreq_kern} -%endif -%if %{defined spldevpkg_kern} -BuildRequires: %{spldevpkg_kern} -%endif - -%description devel -The %{name}-devel package contains the kernel header files and -Module.symvers symbols needed for building additional modules -which use %{name}. - -%endif -%if %{?with_kernel_debug} - -%package debug -Summary: ZFS File System (Debug) -Group: Utilities/System -Release: %{rel_dbug} -%if %{defined req_dbug} -Requires: %{req_dbug} -%endif -%if %{defined kdevpkg_dbug} -BuildRequires: %{kdevpkg_dbug} -%endif -%if %{defined splreq_dbug} -Requires: %{splreq_dbug} -%endif -%if %{defined spldevpkg_dbug} -BuildRequires: %{spldevpkg_dbug} -%endif -Provides: lustre-backend-fs - -%description debug -The %{name}-debug package contains debug kernel modules and support -utilities for the %{name} file system. - -%package debug-devel -Summary: ZFS File System Headers and Symbols (Debug) -Group: Development/Libraries -Release: %{rel_dbug} -%if %{defined devreq_dbug} -Requires: %{devreq_dbug} -%endif -%if %{defined kdevpkg_dbug} -BuildRequires: %{kdevpkg_dbug} -%endif -%if %{defined spldevreq_dbug} -Requires: %{spldevreq_dbug} -%endif -%if %{defined spldevpkg_dbug} -BuildRequires: %{spldevpkg_dbug} -%endif - -%description debug-devel -The %{name}-debug-devel package contains the debug kernel header files -and Module.symvers symbols needed for building additional modules -which use %{name}. - -%endif -%if %{?with_kernel_dkms} - -%package dkms -Summary: ZFS File System (DKMS) -Group: Utilities/System -Release: %{rel_dkms} -Provides: %{name} -BuildArch: noarch -%if %{defined req_dkms} -Requires: %{req_dkms} -%endif -%if %{defined kdevpkg_dkms} -BuildRequires: %{kdevpkg_dkms} -%endif -%if %{defined splreq_dkms} -Requires: %{splreq_dkms} -%endif -%if %{defined spldevpkg_dkms} -BuildRequires: %{spldevpkg_dkms} -%endif -Provides: lustre-backend-fs - -%description dkms -The %{name}-dkms package contains the necessary pieces to build and -install the ZFS kernel modules with Dynamic Kernel Modules Support -(DKMS). - -%endif - -%prep -%setup -n @PACKAGE@-%{version} -%build -rm -rf $RPM_BUILD_ROOT - -%if %{with_kernel} - -%configure --with-linux=%{kdir_kern} --with-linux-obj=%{kobj_kern} \ - --with-spl=%{spldir_kern} --with-spl-obj=%{splobj_kern} \ - --with-config=kernel %{kdebug} %{kdebug_dmu_tx} -make -make DESTDIR=$RPM_BUILD_ROOT install - -%endif -%if %{?with_kernel_debug} - -%configure --with-linux=%{kdir_dbug} --with-linux-obj=%{kobj_dbug} \ - --with-spl=%{spldir_dbug} --with-spl-obj=%{splobj_dbug} \ - --with-config=kernel %{kdebug} %{kdebug_dmu_tx} -make -make DESTDIR=$RPM_BUILD_ROOT install - -%endif -%if %{?with_kernel_dkms} - -%configure %{kdebug} %{kdebug_dmu_tx} -make dist -mkdir -p $RPM_BUILD_ROOT/%{_prefix}/src -tar -xf @PACKAGE@-%{version}.tar.gz -C $RPM_BUILD_ROOT/%{_prefix}/src -cp -af dkms.conf $RPM_BUILD_ROOT/%{_prefix}/src/@PACKAGE@-%{version} - -%endif - -%clean -rm -rf $RPM_BUILD_ROOT - -%if %{?with_kernel} - -%files -%defattr(-, root, root) -/lib/modules/%{kver_kern}/* - -%files devel -%defattr(-,root,root) -%{_prefix}/src/*/%{kver_kern} - -%post -if [ -f /boot/System.map-%{kver_kern} ]; then - /sbin/depmod -ae -F /boot/System.map-%{kver_kern} %{kver_kern} || exit 0 -else - /sbin/depmod -a || exit 0 -fi - -%postun -if [ -f /boot/System.map-%{kver_kern} ]; then - /sbin/depmod -ae -F /boot/System.map-%{kver_kern} %{kver_kern} || exit 0 -else - /sbin/depmod -a || exit 0 -fi - -%postun devel -rmdir %{_prefix}/src/@PACKAGE@-%{version}-@ZFS_META_RELEASE@ 2>/dev/null -exit 0 - -%endif -%if %{?with_kernel_debug} - -%files debug -%defattr(-, root, root) -/lib/modules/%{kver_dbug}/* - -%files debug-devel -%defattr(-,root,root) -%{_prefix}/src/*/%{kver_dbug} - -%post debug -if [ -f /boot/System.map-%{kver_dbug} ]; then - /sbin/depmod -ae -F /boot/System.map-%{kver_dbug} %{kver_dbug} || exit 0 -else - /sbin/depmod -a || exit 0 -fi - -%postun debug -if [ -f /boot/System.map-%{kver_dbug} ]; then - /sbin/depmod -ae -F /boot/System.map-%{kver_dbug} %{kver_dbug} || exit 0 -else - /sbin/depmod -a || exit 0 -fi - -%postun debug-devel -rmdir %{_prefix}/src/@PACKAGE@-%{version}-@ZFS_META_RELEASE@ 2>/dev/null -exit 0 - -%endif -%if %{?with_kernel_dkms} - -%files dkms -%defattr(-,root,root) -%{_prefix}/src/@PACKAGE@-%{version} - -%post dkms -for POSTINST in %{_prefix}/lib/dkms/common.postinst; do - if [ -f $POSTINST ]; then - $POSTINST @PACKAGE@ %{version} - exit $? - fi - echo "WARNING: $POSTINST does not exist." -done -echo -e "ERROR: DKMS version is too old and @PACKAGE@ was not" -echo -e "built with legacy DKMS support." -echo -e "You must either rebuild @PACKAGE@ with legacy postinst" -echo -e "support or upgrade DKMS to a more current version." -exit 1 - -%preun dkms -echo -e -echo -e "Uninstall of @PACKAGE@ module (version %{version}) beginning:" -dkms remove -m @PACKAGE@ -v %{version} --all --rpm_safe_upgrade -exit 0 - -%endif diff --git a/zfs.spec.in b/zfs.spec.in deleted file mode 100644 index 29f6f83e9..000000000 --- a/zfs.spec.in +++ /dev/null @@ -1,110 +0,0 @@ -%define name @PACKAGE@ -%define version @VERSION@ -%define release @ZFS_META_RELEASE@ -%define debug_package %{nil} -%define _sbindir /sbin -%define _libdir /%{_lib} -%define _udevdir /lib/udev -%define _dracutdir %{_datadir}/dracut - -Summary: ZFS Library and Utils -Group: Utilities/System -Name: %{name} -Version: %{version} -Release: %{release}%{?dist} -License: @ZFS_META_LICENSE@ -URL: git://github.com/zfsonlinux/zfs.git -BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-%(%{__id} -un) -Source: %{name}-%{version}.tar.gz -Requires: zfs-modules spl zlib e2fsprogs -BuildRequires: zlib-devel e2fsprogs-devel - -%description -The %{name} package contains the libzfs library and support utilities -for the zfs file system. - -%package devel -Summary: ZFS File System User Headers -Group: Development/Libraries -%if %{defined ch5} || %{defined el6} || %{defined fc12} -Requires: zfs zlib libuuid libblkid -BuildRequires: zlib-devel libuuid-devel libblkid-devel -%else -Requires: zfs zlib e2fsprogs -BuildRequires: zlib-devel e2fsprogs-devel -%endif - -%description devel -The %{name}-devel package contains the header files needed for building -additional applications against the %{name} libraries. - -%package test -Summary: ZFS File System Test Infrastructure -Group: Utilities/System -Requires: zfs parted lsscsi mdadm bc - -%description test -The %{name}-test package contains a test infrastructure for zpios which -can be used to simplfy the benchmarking of various hardware and software -configurations. The test infrastructure additionally integrates with -various system profiling tools to facilitate an in depth analysis. - -%package dracut -Summary: ZFS Dracut Module -Group: System Environment/Base -Requires: zfs dracut - -%description dracut -The %{name}-dracut package allows dracut to construct initramfs images -which are ZFS aware. - -%prep -%setup -%build -%configure --with-config=user \ - --without-blkid \ - --with-udevdir=%{_udevdir} \ - --with-dracutdir=%{_dracutdir} -make - -%install -rm -rf $RPM_BUILD_ROOT -make DESTDIR=$RPM_BUILD_ROOT install - -%clean -rm -rf $RPM_BUILD_ROOT - -%files -%defattr(-, root, root) -%{_sbindir}/* -%{_libdir}/* -%{_mandir}/man1/* -%{_mandir}/man5/* -%{_mandir}/man8/* -%{_udevdir}/* - -%config %{_sysconfdir}/init.d/* -%config %{_sysconfdir}/zfs/* - -%doc AUTHORS COPYING COPYRIGHT DISCLAIMER -%doc OPENSOLARIS.LICENSE README.markdown - -%files devel -%defattr(-,root,root) -%{_includedir}/* - -%files test -%defattr(-,root,root) -%{_datadir}/@PACKAGE@/* - -%files dracut -%defattr(-,root,root) -%{_dracutdir}/* - -%post -[ -x /sbin/chkconfig ] && /sbin/chkconfig --add zfs -exit 0 - -%preun -[ "$1" = 0 ] && [ -x /sbin/chkconfig ] && /sbin/chkconfig --del zfs -exit 0 |