X-Git-Url: https://git.whamcloud.com/?p=fs%2Flustre-release.git;a=blobdiff_plain;f=lustre.spec.in;h=30fdce8ba5f948173c716e41553c826133f5d11e;hp=e844ab72b189ed61fed30e0a00116aba55bc4949;hb=1277c24f9d25359bcb82938678f77d3082989a55;hpb=edbf0947d247c4704a7c19e17e78ed62a7e3894f diff --git a/lustre.spec.in b/lustre.spec.in index e844ab7..30fdce8 100644 --- a/lustre.spec.in +++ b/lustre.spec.in @@ -1,18 +1,25 @@ # lustre.spec -%define version @VERSION@ -%define kversion @LINUXRELEASE@ +%{!?version: %define version @VERSION@} +%{!?kversion: %define kversion @LINUXRELEASE@} +%{!?release: %define release @RELEASE@} +%{!?lustre_name: %define lustre_name lustre} + +%define is_client %(bash -c "if [[ %{lustre_name} = *-client ]]; then echo -n '1'; else echo -n '0'; fi") +# for those uses that don't want the -smp/-bigsmp on the end of %kversion +%define krequires %(bash -c "echo %{kversion} | sed -e 's/-smp$//' -e 's/-bigsmp$//' -e 's/-ppc64$//' -e 's/-default$//'") Summary: Lustre File System -Name: lustre +Name: %{lustre_name} Version: %{version} -Release: @RELEASE@ +Release: %{release} License: GPL Group: Utilities/System Source: lustre-%{version}.tar.gz -URL: http://clusterfs.com/ +URL: http://www.sun.com/software/products/lustre/index.xml BuildRoot: %{_tmppath}/lustre-%{version}-root Obsoletes: lustre-lite, lustre-lite-utils, lustre-ldap nfs-utils-lustre Provides: lustre-lite = %{version}, lustre-lite-utils = %{version} +Requires: %{name}-modules = %{version} # GSS requires this: BuildRequires: pkgconfig, libgssapi-devel >= 0.10 %description @@ -20,7 +27,7 @@ Userspace tools and files for the Lustre file system. %package modules Summary: Kernel Lustre modules for Linux %{kversion} -Requires: modutils >= 2.4.10 +Requires: modutils >= 2.4.10, kernel = %{krequires} Group: Development/Kernel %description modules @@ -51,8 +58,8 @@ Lustre sources for further development Summary: Lustre dependencies meta-package for SLES Group: Utilities/System Provides: lustre-deps = %{version} -Requires: lustre = %{version}, sles-release -Conflicts: lustre-deps-rhel +Requires: %{name} = %{version}, sles-release +Conflicts: %{name}-deps-rhel %description deps-sles This package has RPM dependencies appropriate for SLES systems. @@ -61,8 +68,8 @@ This package has RPM dependencies appropriate for SLES systems. Summary: Lustre dependencies meta-package for RHEL Group: Utilities/System Provides: lustre-deps = %{version} -Requires: lustre = %{version}, redhat-release -Conflicts: lustre-deps-sles +Requires: %{name} = %{version}, redhat-release +Conflicts: %{name}-deps-sles %description deps-rhel This package has RPM dependencies appropriate for RHEL, RHL, and FC @@ -71,8 +78,8 @@ systems. %package tests Summary: Lustre testing framework Group: Development/Kernel -Provides: lustre-tests = %{version} -Requires: lustre = %{version} +Provides: %{name}-tests = %{version} +Requires: %{name} = %{version}, %{name}-modules = %{version} %description tests This package contains a set of test binaries and scripts that are intended @@ -80,6 +87,8 @@ to be used by the Lustre testing framework. %prep %setup -qn lustre-%{version} +ln lustre/ChangeLog ChangeLog-lustre +ln lnet/ChangeLog ChangeLog-lnet %build # if RPM_BUILD_NCPUS unset, set it @@ -124,13 +133,14 @@ mkdir -p $RPM_BUILD_ROOT/usr/src rm -f lustre-source ln -s $RPM_BUILD_ROOT/usr/src lustre-source make distdir distdir=lustre-source/lustre-%{version} +chmod -R go-w lustre-source/lustre-%{version} cat >lustre.files <lustre.files <>lustre.files +fi + if [ -f $RPM_BUILD_ROOT%{_libdir}/liblustre.so ] ; then echo '%attr(-, root, root) %{_libdir}/liblustre.a' >>lustre.files echo '%attr(-, root, root) %{_libdir}/liblustre.so' >>lustre.files @@ -157,12 +171,15 @@ fi # Have universal lustre headers if [ -f $RPM_BUILD_DIR/lustre-%{version}/lustre/include/lustre/lustre_idl.h ] ; then - echo '%attr(-, root, root) /usr/include/linux/lustre_types.h' >>lustre.files echo '%attr(-, root, root) /usr/include/linux/lustre_user.h' >>lustre.files else echo '%attr(-, root, root) /usr/include/linux/lustre_idl.h' >>lustre.files fi +if [ -f $RPM_BUILD_DIR/lustre-%{version}/lustre/include/linux/lustre_types.h ] ; then + echo '%attr(-, root, root) /usr/include/linux/lustre_types.h' >>lustre.files +fi + echo '%attr(-, root, root) %{_libdir}/lustre/tests/*' >lustre-tests.files echo '%attr(-, root, root) /lib/modules/%{kversion}/kernel/fs/lustre/llog_test.*' >>lustre-tests.files modules_excludes="llog_test" @@ -178,6 +195,8 @@ popd >/dev/null %files modules -f lustre-modules.files %attr(-, root, root) %doc COPYING +%attr(-, root, root) %doc ChangeLog-lustre +%attr(-, root, root) %doc ChangeLog-lnet %files source %attr(-, root, root) /usr/src/lustre-%{version} @@ -194,6 +213,13 @@ if [ -f /boot/System.map-%{kversion} ]; then else depmod -ae %{kversion} || exit 0 fi +cat </dev/null 2>&1 && + [ "$(sysctl -n kernel.unsupported 2>/dev/null)" = "0" ] && + ! modprobe -c | grep -q "^allow_unsupported_modules[ \t]1" ; then + echo " + warning: the Lustre modules are not supported by Novell. To use Lustre + on this system, you should put + + allow_unsupported_modules 1 + + into /etc/modprobe.d/unsupported_modules" +fi + %postun modules if [ -f /boot/System.map-%{kversion} ]; then depmod -ae -F /boot/System.map-%{kversion} %{kversion} || exit 0