X-Git-Url: https://git.whamcloud.com/?p=fs%2Flustre-release.git;a=blobdiff_plain;f=lustre.spec.in;h=625d8589194debc9e2e97018c6cd069b0fb6817d;hp=6a8ec1b164665d61d6d9a421553fddff5ae86cd3;hb=7c82a9c81d03dec059132dddafd0bdde188b321d;hpb=c844bf47dabeee3f408be049b28e67e600348e0c diff --git a/lustre.spec.in b/lustre.spec.in index 6a8ec1b..625d858 100644 --- a/lustre.spec.in +++ b/lustre.spec.in @@ -1,4 +1,22 @@ # lustre.spec + +# Declare rpmbuild --with/--without parameters +%bcond_without servers +%bcond_without ldiskfs +%bcond_with zfs +%bcond_without lustre_tests +%bcond_without lustre_utils +%bcond_without lustre_iokit +%bcond_without lustre_modules +%bcond_with lnet_dlc + +%if %{without servers} + # --without servers overrides --with {ldiskfs|zfs} + # so undefine the internal variables set by bcond_* + %undefine with_ldiskfs + %undefine with_zfs +%endif + %{!?version: %global version @VERSION@} %{!?kver: %global kver ""} %{!?kdir: %global kdir %(dir=$(echo "%configure_args" | sed -ne 's/.*--with-linux=\\([^ ][^ ]*\\).*$/\\1/p'); if [ -n "$dir" ]; then echo "$dir"; else if [ -n "%kver" ]; then kversion="%kver"; else kversion="$(uname -r)"; fi; echo "/lib/modules/$kversion/source"; fi)} @@ -17,12 +35,6 @@ # always append the buildid, even when the caller defines %release %define fullrelease %{myrelease}%{buildid} -%{!?lustre_name: %global lustre_name lustre} -%{!?build_lustre_tests: %global build_lustre_tests 1} - -%{!?build_lustre_osd_ldiskfs: %global build_lustre_osd_ldiskfs 1} -%{!?build_lustre_osd_zfs: %global build_lustre_osd_zfs 1} - # in order to get kernel symset and/or kernel module dependencies into # the RPM, in order to support weak-modules, the internal dependency gen- # erator needs to be disabled @@ -43,20 +55,41 @@ # response from them #%%global _use_internal_dependency_generator 0 -%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 (or the .arch) on the end # of %kversion %define krequires %(bash -c "echo %{kversion} | sed -e 's/\.x86_64$//' -e 's/\.i[3456]86$//' -e 's/-smp$//' -e 's/-bigsmp$//' -e 's/-ppc64$//' -e 's/-default$//'") -%define sles10 %(bash -c "if [ "%sles_version" = "10" ]; then echo -n '1'; else echo -n '0'; fi") +# Set the package name prefix +%if %{undefined lustre_name} + %if %{with servers} + %global lustre_name lustre + %else + %global lustre_name lustre-client + %endif +%endif + +%if %{undefined kmoddir} + %if %{defined kernel_module_package_moddir} + %global kmoddir %{kernel_module_package_moddir} + %else + %if %{defined suse_kernel_module_package} + %global kmoddir updates + %else + %global kmoddir extra + %endif + %endif +%endif -%if %sles10 -%define flavor %(bash -c "echo %{kversion} | sed -e 's/^.*-//'") +%if %{defined cross_path} && %{defined post_script} +%define rpm_post_base %(echo $(dirname %{cross_path})/%{lustre_name}) %endif -%if %is_client -%define build_lustre_osd_ldiskfs 0 -%define build_lustre_osd_zfs 0 +# SUSE don't support .debug_info section from cross compiler: +# /usr/lib/rpm/debugedit: Unhandled relocation 10 in .debug_info section +%if %{defined cross_path} && 0%{?suse_version} +%global __debug_install_post %{nil} +%global __debug_package %{nil} +%global debug_package %{nil} %endif Summary: Lustre File System @@ -66,42 +99,63 @@ Release: %{fullrelease} License: GPL Group: Utilities/System Source: lustre-%{version}.tar.gz -URL: http://wiki.whamcloud.com/ +URL: https://wiki.hpdd.intel.com/ 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} +BuildRequires: libtool +%if %{with servers} +Requires: lustre-osd +Requires: lustre-osd-mount +%endif +%if %{defined cross_requires} +Requires: %{cross_requires} +AutoReqProv: no +%else # GSS requires this: BuildRequires: pkgconfig, libgssapi-devel >= 0.10 +%if %{_vendor}=="redhat" || %{_vendor}=="fedora" +#suse don't support selinux +BuildRequires: libselinux-devel +Requires: libselinux +%endif +%endif %description Userspace tools and files for the Lustre file system. +%if %{with lustre_modules} %package modules Summary: Kernel Lustre modules for Linux %{kversion} -# for SLES11, we need nothing here -# for SLES10, we need (where %{flavor} is, i.e. smp): -%if %sles10 -Requires: kernel-%{flavor} +%if %{defined cross_requires} +Requires: %{cross_requires} +AutoReqProv: no %else +# for SLES11, we need nothing here %if %{_vendor}=="redhat" || %{_vendor}=="fedora" # for RHEL we need to require the specific kernel still since weak-modules # support on RH is, well, weak, to be punny about it Requires: kernel = %{krequires} +%if %{with lnet_dlc} +Requires: libyaml +BuildRequires: libyaml-devel %endif %endif -%if ! %{is_client} -Requires: lustre-osd %endif Group: Development/Kernel %description modules Lustre file system, server and network drivers for Linux %{kversion}. -%if %{build_lustre_osd_ldiskfs} +%if %{with ldiskfs} %package osd-ldiskfs -Summary: osd-ldiskfs is the mandatory glue for LDISKFS support in Lustre. -Requires: lustre-modules = %{version}, lustre-ldiskfs +Summary: osd-ldiskfs contains both ldiskfs and its osd interface in Lustre. +Requires: lustre-modules = %{version} +Requires: module-init-tools >= 3.9 +Requires: ldiskfsprogs >= 1.42.7.wc1 +Requires: lustre-osd-ldiskfs-mount Provides: lustre-osd +Obsoletes: lustre-ldiskfs Group: Development/Kernel %description osd-ldiskfs @@ -110,12 +164,24 @@ modify data that is supposed to be stored persistently. This API is the interfac to code that bridges individual file systems. This specific package provides an implementation of the OSD API for using the Ldiskfs filesystem as the underlying backing store of a Lustre server. + +%if %{with lustre_utils} +%package osd-ldiskfs-mount +Summary: osd-ldiskfs-mount contains mount's ldiskfs specific dso. +Provides: lustre-osd-mount +Group: Development/Kernel + +%description osd-ldiskfs-mount +LDISKFS hooks for mount/mkfs into a dynamic library. + +%endif %endif -%if %{build_lustre_osd_zfs} +%if %{with zfs} %package osd-zfs Summary: osd-zfs is the mandatory glue for ZFS support in Lustre. -Requires: lustre-modules = %{version}, zfs-modules +Requires: lustre-modules = %{version}, zfs-kmod +Requires: lustre-osd-zfs-mount Provides: lustre-osd Group: Development/Kernel @@ -125,7 +191,19 @@ modify data that is supposed to be stored persistently. This API is the interfac to code that bridges individual file systems. This specific package provides an implementation of the OSD API for using the ZFS filesystem as the underlying backing store of a Lustre server. + +%if %{with lustre_utils} +%package osd-zfs-mount +Summary: osd-zfs-mount contains mount's ldiskfs specific dso. +Provides: lustre-osd-mount +Group: Development/Kernel + +%description osd-zfs-mount +ZFS hooks for mount/mkfs into a dynamic library. + %endif +%endif +%endif # with lustre_modules %package source Summary: Object-Based Disk storage driver source @@ -173,12 +251,49 @@ systems. Summary: Lustre testing framework Group: Development/Kernel Provides: %{name}-tests = %{version} -Requires: %{name} = %{version}, %{name}-modules = %{version} +Requires: %{name} = %{version}, %{name}-modules = %{version}, lustre-iokit +Requires: attr, rsync, perl, lsof, /usr/bin/getconf %description tests This package contains a set of test binaries and scripts that are intended to be used by the Lustre testing framework. +%if %{with lustre_iokit} +%package -n lustre-iokit +Summary: The Lustre IO-Kit is a collection of benchmark tools for a cluster with the Lustre file system. +Group: Applications/System +Requires: python > 2.2, sg3_utils + +%description -n lustre-iokit +This package includes five tools: +sgpdd-survey: +A test of the 'bare metal' performance, bypassing as much of the kernel as we can. Uses the sgp_dd utility. + +obdfilter-survey +This survey can be run in 3 modes to test disk I/O including the filesystem, +network I/O, and disk I/O via the network. The script does sequential I/O +with varying numbers of threads and objects (files) by using lctl::test_brw +to drive the echo_client connected to local or remote obdfilter instances, +or remote obdecho instances. + +ost-survey +This survey tests the client-to-disk performance of individual OSTs, and +ranks then for comparison. + +stats-collect +This script will collect IO stats on a defined set of nodes. + +ior-survey: +A script to run the IOR benchmark. The latest version can be downloaded from +http://www.llnl.gov/asci/purple/benchmarks/limited/ior/ + +mds-survey: +This survey tests the local metadata performance using the echo_client to drive +the MDD layer to perform operations. It is run with multiple threads (to +simulate MDT service threads) locally on the MDS node, and does not need Lustre +clients in order to run +%endif + %if 0%{?suse_version} %debug_package %endif @@ -188,18 +303,6 @@ ln lustre/ChangeLog ChangeLog-lustre ln lnet/ChangeLog ChangeLog-lnet %build -# if RPM_BUILD_NCPUS unset, set it -if [ -z "$RPM_BUILD_NCPUS" ] ; then - RPM_BUILD_NCPUS=$(egrep -c "^cpu[0-9]+" /proc/stat 2>/dev/null || echo 0 :) - if [ $RPM_BUILD_NCPUS -eq 0 ] ; then - RPM_BUILD_NCPUS=1 - fi - if [ $RPM_BUILD_NCPUS -gt 8 ] ; then - RPM_BUILD_NCPUS=8 - fi -fi - -rm -rf $RPM_BUILD_ROOT # Set an explicit path to our Linux tree, if we can. cd $RPM_BUILD_DIR/lustre-%{version} @@ -207,10 +310,39 @@ cd $RPM_BUILD_DIR/lustre-%{version} # build failures %define optflags -g -O2 -Werror CONFIGURE_ARGS="%{?configure_args} --with-release=%release" -%if %{build_lustre_tests} -CONFIGURE_ARGS="$CONFIGURE_ARGS --enable-tests --enable-liblustre-tests" + +%if %{with lustre_tests} +CONFIGURE_ARGS="$CONFIGURE_ARGS --enable-tests" +%else +CONFIGURE_ARGS="$CONFIGURE_ARGS --disable-tests" +%endif + +%if %{with lustre_utils} +CONFIGURE_ARGS="$CONFIGURE_ARGS --enable-utils" +%else +CONFIGURE_ARGS="$CONFIGURE_ARGS --disable-utils" +%endif + +%if %{without lustre_iokit} +CONFIGURE_ARGS="$CONFIGURE_ARGS --disable-iokit" +%endif + +%if %{with lustre_modules} +CONFIGURE_ARGS="$CONFIGURE_ARGS --enable-modules" %else -CONFIGURE_ARGS="$CONFIGURE_ARGS --disable-tests --disable-liblustre-tests" +CONFIGURE_ARGS="$CONFIGURE_ARGS --disable-modules" +%endif + +%if %{without servers} +CONFIGURE_ARGS="$CONFIGURE_ARGS --disable-server" +%endif + +%if %{without ldiskfs} +CONFIGURE_ARGS="$CONFIGURE_ARGS --disable-ldiskfs" +%endif + +%if %{without zfs} +CONFIGURE_ARGS="$CONFIGURE_ARGS --without-zfs" %endif # if %%kdir was given, make sure it's not in the configure arguments @@ -221,152 +353,264 @@ fi if [ -n "%kobjdir" ]; then CONFIGURE_ARGS=$(echo $CONFIGURE_ARGS | sed -e 's/"\?--with-linux-obj=[^ ][^ ]* \?//') fi +# remove --with-kmp-moddir from configure arguments, +# it will be set --with-kmp-moddir=%%kmoddir +CONFIGURE_ARGS=$(echo $CONFIGURE_ARGS | sed -e 's/"\?--with-kmp-moddir=[^ ][^ ]* \?//') # we need to eval "configure" because $CONFIGURE_ARGS could have a quoted # string in it which we don't want word splitted by the shell -%define eval_configure %(echo '%configure' | sed -e 's#\./configure#eval ./configure#') +# also remove (build|host|target) options because they will be specified +# inside $CONFIGURE_ARGS +%define eval_configure %(echo '%configure' | sed -e 's#\./configure#eval ./configure#' -e 's/--\\(build\\|host\\|target\\)=[^ ][^ ]* //g') %eval_configure \ %{?kdir: --with-linux=%kdir} %{?kobjdir: --with-linux-obj=%kobjdir} \ - $CONFIGURE_ARGS -make -j $RPM_BUILD_NCPUS -s + $CONFIGURE_ARGS --with-kmp-moddir=%{kmoddir} +make %{?_smp_mflags} -s %{?make_args} %install make install DESTDIR=$RPM_BUILD_ROOT -# hack to avoid changing the libsysio code for "make install" -rm -f $RPM_BUILD_ROOT%{_libdir}/libsysio.a -# Remove ldiskfs module(s) - they are packaged by the ldiskfs .spec. -rm -rf $RPM_BUILD_ROOT/lib/modules/%{kversion}/updates/kernel/fs/lustre-ldiskfs -# hack to include the llog_test module in lustre-tests -llog_base=$RPM_BUILD_DIR/lustre-%{version}/lustre/obdclass/llog_test -if [ -e ${llog_base}.ko ]; then - cp ${llog_base}.ko $RPM_BUILD_ROOT/lib/modules/%{kversion}/updates/kernel/fs/lustre -elif [ -e ${llog_base}.o ]; then - cp ${llog_base}.o $RPM_BUILD_ROOT/lib/modules/%{kversion}/updates/kernel/fs/lustre -fi +:> lustre.files +%if %{with servers} # The .ha_v2 extension identifies the heartbeat resource agent as using # legacy syntax. Install a compatibility symlink to avoid conflicts when # newer-style agents are added. -ln -s Lustre.ha_v2 $RPM_BUILD_ROOT/etc/ha.d/resource.d/Lustre +%if %{with lustre_utils} +ln -s Lustre.ha_v2 $RPM_BUILD_ROOT%{_sysconfdir}/ha.d/resource.d/Lustre +echo '%{_sysconfdir}/ha.d/resource.d/Lustre.ha_v2' >>lustre.files +echo '%{_sysconfdir}/ha.d/resource.d/Lustre' >>lustre.files +%endif + +if [ -f $RPM_BUILD_ROOT%{_sysconfdir}/init.d/lustre ]; then + echo '%{_sysconfdir}/sysconfig/lustre' >>lustre.files + echo '%{_sysconfdir}/init.d/lustre' >>lustre.files +fi +%endif + +if [ -f $RPM_BUILD_ROOT%{_sysconfdir}/init.d/lnet ]; then + echo '%{_sysconfdir}/init.d/lnet' >>lustre.files +fi # Create the pristine source directory. cd $RPM_BUILD_DIR/lustre-%{version} -mkdir -p $RPM_BUILD_ROOT/usr/src +mkdir -p $RPM_BUILD_ROOT%{_prefix}/src rm -f lustre-source -ln -s $RPM_BUILD_ROOT/usr/src lustre-source +ln -s $RPM_BUILD_ROOT%{_prefix}/src lustre-source make distdir distdir=lustre-source/lustre-%{version} chmod -R go-w lustre-source/lustre-%{version} +# fc18 needs 'x' permission for library files +find $RPM_BUILD_ROOT -name \*.so -type f -exec chmod +x {} \; -cat >lustre.files <>lustre.files +if [ -f $RPM_BUILD_ROOT%{_libdir}/liblnetconfig.a ] ; then + echo '%attr(-, root, root) %{_libdir}/liblnetconfig.a' >>lustre.files + echo '%attr(-, root, root) %{_libdir}/liblnetconfig.so' >>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 + echo '%{_libdir}/liblustre.a' >>lustre.files + echo '%{_libdir}/liblustre.so' >>lustre.files fi if [ -f $RPM_BUILD_ROOT%{_libdir}/libiam.a ] ; then - echo '%attr(-, root, root) %{_libdir}/libiam.a' >>lustre.files + echo '%{_libdir}/libiam.a' >>lustre.files fi if [ -d $RPM_BUILD_ROOT%{_libdir}/lustre/snmp ] ; then - echo '%attr(-, root, root) %{_libdir}/lustre/snmp' >>lustre.files - echo '%attr(-, root, root) %{_datadir}/lustre/snmp/mibs' >>lustre.files + echo '%{_libdir}/lustre/snmp' >>lustre.files + echo '%{_datadir}/lustre/snmp/mibs' >>lustre.files 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_user.h' >>lustre.files -else - echo '%attr(-, root, root) /usr/include/linux/lustre_idl.h' >>lustre.files -fi +find $RPM_BUILD_ROOT%{_libdir}/@PACKAGE@/ -name \*.la -type f -delete -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 +%if %{with lustre_tests} +echo '%{_libdir}/lustre/tests/*' >>lustre-tests.files +echo '%{_bindir}/mcreate' >>lustre-tests.files +echo '%{_bindir}/munlink' >>lustre-tests.files +echo '%{_bindir}/req_layout' >>lustre-tests.files +echo '%{_sbindir}/wirecheck' >>lustre-tests.files +echo '%{_sbindir}/wiretest' >>lustre-tests.files +%if %{with lustre_modules} +echo '%{?rootdir}/lib/modules/%{kversion}/%{kmoddir}/kernel/fs/@PACKAGE@/llog_test.ko' >>lustre-tests.files +%endif +%endif -%if %{build_lustre_tests} -echo '%attr(-, root, root) %{_libdir}/lustre/tests/*' >lustre-tests.files -echo '%attr(-, root, root) /lib/modules/%{kversion}/updates/kernel/fs/lustre/llog_test.*' >>lustre-tests.files -if [ -d $RPM_BUILD_ROOT%{_libdir}/lustre/liblustre/tests ] ; then - echo '%attr(-, root, root) %{_libdir}/lustre/liblustre/tests/*' >>lustre-tests.files +%if %{defined cross_path} +%if %{defined rpm_post_base} +POST_SCRIPT=$RPM_BUILD_DIR/lustre-%{version}/%{post_script} +if [ -f $POST_SCRIPT ]; then + cp -f $POST_SCRIPT $RPM_BUILD_ROOT/%{rpm_post_base}.sh + echo '%attr(0555, root, root) %{rpm_post_base}.sh' >>lustre.files + cp -f $POST_SCRIPT $RPM_BUILD_ROOT/%{rpm_post_base}-modules.sh +%if %{with ldiskfs} + cp -f $POST_SCRIPT $RPM_BUILD_ROOT/%{rpm_post_base}-osd-ldiskfs.sh +%if %{with lustre_utils} + cp -f $POST_SCRIPT $RPM_BUILD_ROOT/%{rpm_post_base}-mount-osd-ldiskfs.sh +%endif +%endif +%if %{with zfs} + cp -f $POST_SCRIPT $RPM_BUILD_ROOT/%{rpm_post_base}-osd-zfs.sh +%if %{with lustre_utils} + cp -f $POST_SCRIPT $RPM_BUILD_ROOT/%{rpm_post_base}-mount-osd-zfs.sh +%endif +%endif +%if %{with lustre_tests} + cp -f $POST_SCRIPT $RPM_BUILD_ROOT/%{rpm_post_base}-tests.sh + echo '%attr(0555, root, root) %{rpm_post_base}-tests.sh' >>lustre-tests.files +%endif fi %endif - +%else +%if %{with lustre_modules} # mark modules executable for find-debuginfo.sh -find $RPM_BUILD_ROOT/lib/modules/%{kversion}/updates -name "*.ko" -type f | \ - xargs --no-run-if-empty chmod u+x +find $RPM_BUILD_ROOT%{?rootdir}/lib/modules/%{kversion}/%{kmoddir} \ + -name \*.ko -type f -exec chmod u+x {} \; +%endif +%endif %files -f lustre.files +%defattr(-,root,root) +%{_sbindir}/* +%if %{with lustre_utils} +%if %{with servers} +%{_libexecdir}/lustre/lc_common +%{_libexecdir}/lustre/haconfig +%{_bindir}/lustre_req_history +%endif + +%{_bindir}/llobdstat +%{_bindir}/llstat +%{_bindir}/plot-llstat + +%{_bindir}/lfs +%{_bindir}/lfs_migrate +%{?rootdir}/sbin/mount.lustre +%{_libdir}/libptlctl.a +%{_libdir}/libcfsutil.a +%{_libdir}/liblustreapi.a +%{_libdir}/liblustreapi.so +%{_mandir}/man?/* +%{_includedir}/lustre +%{_includedir}/libcfs +%endif +%{_datadir}/lustre +%{_sysconfdir}/udev/rules.d/99-lustre.rules +%config(noreplace) %{_sysconfdir}/ldev.conf +%if %{with lustre_modules} %files modules -%attr(-, root, root) /lib/modules/%{kversion}/updates/* -%if %{build_lustre_tests} -%exclude /lib/modules/%{kversion}/updates/kernel/fs/lustre/llog_test.ko +%defattr(-,root,root) +%{?rootdir}/lib/modules/%{kversion}/%{kmoddir}/* +%if %{with lustre_tests} +%exclude %{?rootdir}/lib/modules/%{kversion}/%{kmoddir}/kernel/fs/@PACKAGE@/llog_test.ko +%endif +%if %{with ldiskfs} +%exclude %{?rootdir}/lib/modules/%{kversion}/%{kmoddir}/kernel/fs/@PACKAGE@/ldiskfs.ko +%exclude %{?rootdir}/lib/modules/%{kversion}/%{kmoddir}/kernel/fs/@PACKAGE@/osd_ldiskfs.ko %endif -%if %{build_lustre_osd_ldiskfs} -%exclude /lib/modules/%{kversion}/updates/kernel/fs/lustre/osd_ldiskfs.ko +%if %{with zfs} +%exclude %{?rootdir}/lib/modules/%{kversion}/%{kmoddir}/kernel/fs/@PACKAGE@/osd_zfs.ko %endif -%if %{build_lustre_osd_zfs} -%exclude /lib/modules/%{kversion}/updates/kernel/fs/lustre/osd_zfs.ko +%if %{defined rpm_post_base} +%attr(0555, root, root) %{rpm_post_base}-modules.sh %endif -%attr(-, root, root) %doc COPYING -%attr(-, root, root) %doc ChangeLog-lustre -%attr(-, root, root) %doc ChangeLog-lnet +%doc COPYING +%doc ChangeLog-lustre +%doc ChangeLog-lnet -%if %{build_lustre_osd_ldiskfs} +%if %{with ldiskfs} %files osd-ldiskfs -%attr(-, root, root) /lib/modules/%{kversion}/updates/kernel/fs/lustre/osd_ldiskfs.ko +%defattr(-,root,root) +%{?rootdir}/lib/modules/%{kversion}/%{kmoddir}/kernel/fs/@PACKAGE@/ldiskfs.ko +%{?rootdir}/lib/modules/%{kversion}/%{kmoddir}/kernel/fs/@PACKAGE@/osd_ldiskfs.ko +%if %{defined rpm_post_base} +%attr(0555, root, root) %{rpm_post_base}-osd-ldiskfs.sh +%endif +%if %{with lustre_utils} +%files osd-ldiskfs-mount +%defattr(-,root,root) +%{_libdir}/@PACKAGE@/mount_osd_ldiskfs.so +%if %{defined rpm_post_base} +%attr(0555, root, root) %{rpm_post_base}-mount-osd-ldiskfs.sh +%endif +%endif %endif -%if %{build_lustre_osd_zfs} +%if %{with zfs} %files osd-zfs -%attr(-, root, root) /lib/modules/%{kversion}/updates/kernel/fs/lustre/osd_zfs.ko +%defattr(-,root,root) +%{?rootdir}/lib/modules/%{kversion}/%{kmoddir}/kernel/fs/@PACKAGE@/osd_zfs.ko +%if %{defined rpm_post_base} +%attr(0555, root, root) %{rpm_post_base}-osd-zfs.sh +%endif +%if %{with lustre_utils} +%files osd-zfs-mount +%defattr(-,root,root) +%{_libdir}/@PACKAGE@/mount_osd_zfs.so +%if %{defined rpm_post_base} +%attr(0555, root, root) %{rpm_post_base}-mount-osd-zfs.sh %endif +%endif +%endif +%endif # with lustre_modules %files source -%attr(-, root, root) /usr/src/lustre-%{version} +%defattr(-,root,root) +%{_prefix}/src/lustre-%{version} # uncomment these lines to enable deps packages # %files deps-sles # %files deps-rhel -%if %{build_lustre_tests} +%if %{with lustre_tests} %files tests -f lustre-tests.files +%defattr(-,root,root) +%endif + +%if %{with lustre_iokit} +%files -n lustre-iokit +%defattr(-, root, root) +%{_bindir}/iokit-config +%{_bindir}/iokit-gather-stats +%{_bindir}/iokit-libecho +%{_bindir}/iokit-lstats +%{_bindir}/iokit-parse-ior +%{_bindir}/iokit-plot-obdfilter +%{_bindir}/iokit-plot-ost +%{_bindir}/iokit-plot-sgpdd +%{_bindir}/ior-survey +%{_bindir}/mds-survey +%{_bindir}/obdfilter-survey +%{_bindir}/ost-survey +%{_bindir}/sgpdd-survey +%doc lustre-iokit/ior-survey/README.ior-survey +%doc lustre-iokit/mds-survey/README.mds-survey +%doc lustre-iokit/obdfilter-survey/README.obdfilter-survey +%doc lustre-iokit/ost-survey/README.ost-survey +%doc lustre-iokit/sgpdd-survey/README.sgpdd-survey +%doc lustre-iokit/stats-collect/README.iokit-lstats %endif +%if %{defined rpm_post_base} +%post +if [ -x %{rpm_post_base}.sh ]; then + %{rpm_post_base}.sh %{cross_path} create +fi + +%preun +if [ -x %{rpm_post_base}.sh ]; then + %{rpm_post_base}.sh %{cross_path} remove +fi +%endif + +%if %{with lustre_modules} %post modules +%if %{defined rpm_post_base} +if [ -x %{rpm_post_base}-modules.sh ]; then + %{rpm_post_base}-modules.sh %{cross_path} create +fi +%else if [ -f /boot/System.map-%{kversion} ]; then depmod -ae -F /boot/System.map-%{kversion} %{kversion} || exit 0 else @@ -400,9 +644,15 @@ if sysctl kernel.unsupported >/dev/null 2>&1 && into /etc/modprobe.d/unsupported_modules" fi +%endif -%if %{build_lustre_osd_ldiskfs} +%if %{with ldiskfs} %post osd-ldiskfs +%if %{defined rpm_post_base} +if [ -x %{rpm_post_base}-osd-ldiskfs.sh ]; then + %{rpm_post_base}-osd-ldiskfs.sh %{cross_path} create +fi +%else if [ -f /boot/System.map-%{kversion} ]; then depmod -ae -F /boot/System.map-%{kversion} %{kversion} || exit 0 else @@ -437,9 +687,21 @@ if sysctl kernel.unsupported >/dev/null 2>&1 && into /etc/modprobe.d/unsupported_modules" fi %endif +%if %{with lustre_utils} && %{defined rpm_post_base} +%post osd-ldiskfs-mount +if [ -x %{rpm_post_base}-mount-osd-ldiskfs.sh ]; then + %{rpm_post_base}-mount-osd-ldiskfs.sh %{cross_path} create +fi +%endif +%endif -%if %{build_lustre_osd_zfs} +%if %{with zfs} %post osd-zfs +%if %{defined rpm_post_base} +if [ -x %{rpm_post_base}-osd-zfs.sh ]; then + %{rpm_post_base}-osd-zfs.sh %{cross_path} create +fi +%else if [ -f /boot/System.map-%{kversion} ]; then depmod -ae -F /boot/System.map-%{kversion} %{kversion} || exit 0 else @@ -474,23 +736,61 @@ if sysctl kernel.unsupported >/dev/null 2>&1 && into /etc/modprobe.d/unsupported_modules" fi %endif +%if %{with lustre_utils} && %{defined rpm_post_base} +%post osd-zfs-mount +if [ -x %{rpm_post_base}-mount-osd-zfs.sh ]; then + %{rpm_post_base}-mount-osd-zfs.sh %{cross_path} create +fi +%endif +%endif %preun modules +%if %{defined rpm_post_base} +if [ -x %{rpm_post_base}-modules.sh ]; then + %{rpm_post_base}-modules.sh %{cross_path} remove +fi +%else MODULES_RPM_NAME=$(rpm -q %{name}-modules | grep "%{version}-%{release}") rpm -ql $MODULES_RPM_NAME | grep '\.ko$' > /var/run/%{name}-modules || true +%endif -%if %{build_lustre_osd_ldiskfs} +%if %{with ldiskfs} %preun osd-ldiskfs +%if %{defined rpm_post_base} +if [ -x %{rpm_post_base}-osd-ldiskfs.sh ]; then + %{rpm_post_base}-osd-ldiskfs.sh %{cross_path} remove +fi +%else OSD_LDISKFS_RPM_NAME=$(rpm -q %{name}-osd-ldiskfs | grep "%{version}-%{release}") rpm -ql $OSD_LDISKFS_RPM_NAME | grep '\.ko$' > /var/run/%{name}-osd-ldiskfs || true %endif +%if %{with lustre_utils} && %{defined rpm_post_base} +%preun osd-ldiskfs-mount +if [ -x %{rpm_post_base}-mount-osd-ldiskfs.sh ]; then + %{rpm_post_base}-mount-osd-ldiskfs.sh %{cross_path} remove +fi +%endif +%endif -%if %{build_lustre_osd_zfs} +%if %{with zfs} %preun osd-zfs +%if %{defined rpm_post_base} +if [ -x %{rpm_post_base}-osd-zfs.sh ]; then + %{rpm_post_base}-osd-zfs.sh %{cross_path} remove +fi +%else OSD_ZFS_RPM_NAME=$(rpm -q %{name}-osd-zfs | grep "%{version}-%{release}") rpm -ql $OSD_ZFS_RPM_NAME | grep '\.ko$' > /var/run/%{name}-osd-zfs || true %endif +%if %{with lustre_utils} && %{defined rpm_post_base} +%preun osd-zfs-mount +if [ -x %{rpm_post_base}-mount-osd-zfs.sh ]; then + %{rpm_post_base}-mount-osd-zfs.sh %{cross_path} remove +fi +%endif +%endif +%if %{undefined cross_path} %postun modules if [ -f /boot/System.map-%{kversion} ]; then depmod -ae -F /boot/System.map-%{kversion} %{kversion} || exit 0 @@ -511,7 +811,7 @@ if [ -x /sbin/weak-modules ]; then fi rm /var/run/%{name}-modules -%if %{build_lustre_osd_ldiskfs} +%if %{with ldiskfs} %postun osd-ldiskfs if [ -f /boot/System.map-%{kversion} ]; then depmod -ae -F /boot/System.map-%{kversion} %{kversion} || exit 0 @@ -533,7 +833,7 @@ fi rm /var/run/%{name}-osd-ldiskfs %endif -%if %{build_lustre_osd_zfs} +%if %{with zfs} %postun osd-zfs if [ -f /boot/System.map-%{kversion} ]; then depmod -ae -F /boot/System.map-%{kversion} %{kversion} || exit 0 @@ -554,8 +854,22 @@ if [ -x /sbin/weak-modules ]; then fi rm /var/run/%{name}-osd-zfs %endif +%endif +%endif # with lustre_modules -%if %{build_lustre_tests} +%if %{with lustre_tests} +%if %{defined rpm_post_base} +%post tests +if [ -x %{rpm_post_base}-tests.sh ]; then + %{rpm_post_base}-tests.sh %{cross_path} create +fi + +%preun tests +if [ -x %{rpm_post_base}-tests.sh ]; then + %{rpm_post_base}-tests.sh %{cross_path} remove +fi +%else +%if %{with lustre_modules} %post tests if [ -f /boot/System.map-%{kversion} ]; then depmod -ae -F /boot/System.map-%{kversion} %{kversion} || exit 0 @@ -570,6 +884,8 @@ else depmod -ae %{kversion} || exit 0 fi %endif +%endif +%endif %clean rm -rf $RPM_BUILD_ROOT