X-Git-Url: https://git.whamcloud.com/?p=fs%2Flustre-release.git;a=blobdiff_plain;f=lustre-dkms.spec.in;h=e93c8518e647bbc7a33cda190e279a9dc55ebc6e;hp=967d89cc71c4ea6d1dfaa859cb5b2b94615190be;hb=3cce65712d94cffe8f1626545845b95b88aef672;hpb=cb73cb5083ee2db5c6ed607c44e1002788b4eee6;ds=sidebyside diff --git a/lustre-dkms.spec.in b/lustre-dkms.spec.in index 967d89c..e93c851 100644 --- a/lustre-dkms.spec.in +++ b/lustre-dkms.spec.in @@ -1,13 +1,43 @@ %bcond_without servers +%bcond_without zfs +%bcond_with ldiskfs # Set the package name prefix %if %{with servers} - %define module @PACKAGE@ + %if %{with zfs} + %if %{with ldiskfs} + %define module @PACKAGE@-all + %else + %define module @PACKAGE@-zfs + %endif + %else + %if %{without ldiskfs} + %define module @PACKAGE@-BADSTATE + %else + %define module @PACKAGE@-ldiskfs + %endif + %endif + %define lustre_name @PACKAGE@ + %else - %define module @PACKAGE@-client + %define module @PACKAGE@-client + %define lustre_name @PACKAGE@-client +%endif + +%if %{_vendor}=="redhat" || %{_vendor}=="fedora" + %global kmod_name kmod-%{lustre_name} + %define mkconf_options %{nil} +%else #for Suse / Ubuntu + %global kmod_name %{lustre_name}-kmp + %define mkconf_options "-k updates" %endif %define buildid 1 +%define mkconf lustre/scripts/dkms.mkconf + +# There should be a better (non-arch dependent) way to require ext4 +# sources +%define ext4_source_rpm kernel-debuginfo-common-x86_64 Name: %{module}-dkms @@ -26,87 +56,66 @@ BuildArch: noarch # (ie, "BUILD_DEPENDS[#]="), and have latest DKMS fixes integrated # for bugs that prevented our module to build/install. Requires: dkms >= 2.2.0.3-28.git.7c3e7c5 +# for lnetctl +Requires: libyaml-devel +Requires: zlib-devel %if %{with servers} -# Only zfs Lustre DKMS Server is supported -Requires: spl-dkms >= 0.6.1 -Requires: zfs-dkms >= 0.6.1 -Requires: %{module}-osd-zfs-mount +# If client package is installed when installing server, remove it since +# the server package also includes the client. This can be removed if/when +# the packages are split into independent client/server/common packages. +Obsoletes: @PACKAGE@-client < %{version} +%if %{with zfs} +Requires: zfs-dkms >= 0.6.5 +Requires: @PACKAGE@-osd-zfs-mount +Conflicts: @PACKAGE@-ldiskfs-dkms +Conflicts: @PACKAGE@-client-dkms +# lustre-zfs-dkms replicates the functionality old lustre-dkms package +Provides: @PACKAGE@-dkms +Obsoletes: @PACKAGE@-dkms +%endif +%if %{with ldiskfs} +Requires: patch +Requires: %{ext4_source_rpm} +Requires: @PACKAGE@-osd-ldiskfs-mount +Conflicts: @PACKAGE@-zfs-dkms +Conflicts: @PACKAGE@-client-dkms +%if "%{module}" != "@PACKAGE@-all" +Conflicts: @PACKAGE@-dkms +%endif +%endif +%if "%{module}" != "@PACKAGE@-all" +Conflicts: @PACKAGE@-all-dkms +%endif %endif Requires: gcc, make, perl Requires: kernel-devel -Provides: %{module}-kmod = %{version} -Provides: %{module}-modules = %{version} +Provides: %{kmod_name} = %{version} +Provides: @PACKAGE@-modules = %{version} %if %{with servers} -# Only zfs Lustre DKMS Server is supported -Provides: %{module}-osd-zfs = %{version} -Provides: %{module}-osd +%if %{with zfs} +Provides: @PACKAGE@-osd-zfs = %{version} +%endif +%if %{with ldiskfs} +Provides: @PACKAGE@-osd-ldiskfs = %{version} +%endif +Provides: @PACKAGE@-osd +%else +Provides: @PACKAGE@-client %endif %description This package contains the dkms Lustre kernel modules. +%if %{with ldiskfs} + +The required %{ext4_source_rpm} package is available from +the repository with other debuginfo rpms. +%endif %prep %setup -q -n @PACKAGE@-%{version} %build -cat << EOF > dkms.conf -# Embryonic lustre-dkms dkms.conf to allow for on-target accurate and full -# version re-create during first dkms add stage. -PACKAGE_NAME=%{module} -PACKAGE_VERSION=%{version} -POST_ADD="lustre-dkms_post-add.sh \$module \$module_version \$kernelver \ - \$kernel_source_dir \$arch \$source_tree \$dkms_tree" -# at least one DEST_MODULE_LOCATION[] element, along with an install -# path made of either "extra" or "updates" subdir, are required during -# dkms.conf validity check of "dkms add" step. -DEST_MODULE_LOCATION[${#DEST_MODULE_LOCATION[@]}]="/extra/lnet/" -EOF - -cat << EOF > lustre-dkms_post-add.sh -#!/bin/bash -# \$1 : \$module -# \$2 : \$module_version -# \$3 : \$kernelver -# \$4 : \$kernel_source_dir -# \$5 : \$arch -# \$6 : \$source_tree -# \$7 : \$dkms_tree - -if [ \$1 = "lustre-client" ] ; then - SERVER="--disable-server" -else - SPL_VERSION=\$(dkms status -m spl -k \$3/\$5 | awk -F', ' '{print \$2; exit 0}' | sed 's/: added\$//') - ZFS_VERSION=\$(dkms status -m zfs -k \$3/\$5 | awk -F', ' '{print \$2; exit 0}' | sed 's/: added\$//') - - SERVER="--enable-server --disable-ldiskfs --with-linux=\$4 --with-linux-obj=\$4 \\ - --with-spl=\$6/spl-\${SPL_VERSION} \\ - --with-spl-obj=\$7/spl/\${SPL_VERSION}/\$3/\$5 \\ - --with-zfs=\$6/zfs-\${ZFS_VERSION} \\ - --with-zfs-obj=\$7/zfs/\${ZFS_VERSION}/\$3/\$5" -fi - -rpm -qa | grep krb5-devel >/dev/null -if [ \$? == 0 ] ; then - GSS="--enable-gss" -else - GSS="--disable-gss" -fi - -# run a configure pass to clean "--enable-dist" only effect and also to -# ensure local/on-target environment to be taken into account -./configure --enable-modules --disable-iokit --disable-snmp --disable-doc \\ - --disable-utils --disable-tests --disable-maintainer-mode \\ - \$GSS \$SERVER \\ - --disable-manpages --disable-dlc -# re-create dkms.conf based on this -lustre/scripts/dkms.mkconf -n \$1 -v \$2 -f ./dkms.conf -EOF - -chmod 755 lustre-dkms_post-add.sh - -sed -i 's/BUILDID[[:print:]]*/BUILDID = %{buildid}/' META -sed -i 's/PRISTINE[[:print:]]*/PRISTINE = 1/' META -cp META ldiskfs/META +%{mkconf} -n %{module} -v %{version} -f dkms.conf %{mkconf_options} %install if [ "$RPM_BUILD_ROOT" != "/" ]; then @@ -114,10 +123,7 @@ if [ "$RPM_BUILD_ROOT" != "/" ]; then fi mkdir -p $RPM_BUILD_ROOT/usr/src/ cp -rfp ${RPM_BUILD_DIR}/@PACKAGE@-%{version} $RPM_BUILD_ROOT/usr/src/ -%if %{without servers} -# To have the directory reflect the DKMS RPM name! mv $RPM_BUILD_ROOT/usr/src/@PACKAGE@-%{version} $RPM_BUILD_ROOT/usr/src/%{module}-%{version} -%endif %clean if [ "$RPM_BUILD_ROOT" != "/" ]; then @@ -147,8 +153,15 @@ dkms remove -m %{module} -v %{version} --all --rpm_safe_upgrade exit 0 %changelog +* Wed May 16 2018 Joe Grund +- Add patch requirement +* Mon Aug 1 2016 Nathaniel Clark +- Add option to build either ldiskfs or zfs flavour of server version +* Sat Jan 23 2016 Bruno Faccini + - detect and handle cases where [spl,zfs]-dkms packages are not built + - also handle on-target configure issues * Wed Oct 7 2015 Bruno Faccini - adapted for Lustre Client DKMS creation - allow for on-target reconfig to prevent static deps requires -* Fri Apr 8 2013 Brian Behlendorf - 2.3.63-1 +* Mon Apr 8 2013 Brian Behlendorf - 2.3.63-1 - First DKMS packages.