X-Git-Url: https://git.whamcloud.com/?a=blobdiff_plain;f=lustre.spec.in;h=dd5e81f725d6c8bdb77b321ab0f5e061352b9ccd;hb=d1cf226d04884a102e17a7d4109764c24572983f;hp=8d2ccd09aa2d093d36d9cc983d63660d34f2dd46;hpb=a0a1066d30054540d853a067449b90f991b7554a;p=fs%2Flustre-release.git diff --git a/lustre.spec.in b/lustre.spec.in index 8d2ccd0..dd5e81f 100644 --- a/lustre.spec.in +++ b/lustre.spec.in @@ -5,7 +5,10 @@ %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} @@ -56,12 +59,6 @@ # 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") - -%if %sles10 -%define flavor %(bash -c "echo %{kversion} | sed -e 's/^.*-//'") -%endif - # Set the package name prefix %if %{undefined lustre_name} %if %{with servers} @@ -71,10 +68,30 @@ %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 %{defined cross_path} && %{defined post_script} %define rpm_post_base %(echo $(dirname %{cross_path})/%{lustre_name}) %endif +# 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 Name: %{lustre_name} Version: %{version} @@ -82,11 +99,12 @@ 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 %endif @@ -105,6 +123,7 @@ Requires: libselinux %description Userspace tools and files for the Lustre file system. +%if %{with lustre_modules} %package modules Summary: Kernel Lustre modules for Linux %{kversion} %if %{defined cross_requires} @@ -112,14 +131,13 @@ Requires: %{cross_requires} AutoReqProv: no %else # for SLES11, we need nothing here -# for SLES10, we need (where %{flavor} is, i.e. smp): -%if %sles10 -Requires: kernel-%{flavor} -%else %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 %endif @@ -132,7 +150,7 @@ Lustre file system, server and network drivers for Linux %{kversion}. %package osd-ldiskfs Summary: osd-ldiskfs contains both ldiskfs and its osd interface in Lustre. Requires: lustre-modules = %{version} -Requires: modutils >= 2.4.10 +Requires: module-init-tools >= 3.9 Requires: ldiskfsprogs >= 1.42.7.wc1 Provides: lustre-osd Obsoletes: lustre-ldiskfs @@ -160,6 +178,7 @@ 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. %endif +%endif # with lustre_modules %package source Summary: Object-Based Disk storage driver source @@ -208,6 +227,7 @@ Summary: Lustre testing framework Group: Development/Kernel Provides: %{name}-tests = %{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 @@ -258,18 +278,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} @@ -277,15 +285,41 @@ cd $RPM_BUILD_DIR/lustre-%{version} # build failures %define optflags -g -O2 -Werror CONFIGURE_ARGS="%{?configure_args} --with-release=%release" + %if %{with lustre_tests} -CONFIGURE_ARGS="$CONFIGURE_ARGS --enable-tests --enable-liblustre-tests" +CONFIGURE_ARGS="$CONFIGURE_ARGS --enable-tests" %else -CONFIGURE_ARGS="$CONFIGURE_ARGS --disable-tests --disable-liblustre-tests" +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-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 if [ -n "%kdir" ]; then CONFIGURE_ARGS=$(echo $CONFIGURE_ARGS | sed -e 's/"\?--with-linux=[^ ][^ ]* \?//') @@ -294,6 +328,9 @@ 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 @@ -303,26 +340,33 @@ fi %eval_configure \ %{?kdir: --with-linux=%kdir} %{?kobjdir: --with-linux-obj=%kobjdir} \ - $CONFIGURE_ARGS -make -j $RPM_BUILD_NCPUS -s %{?make_args} + $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 -# 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%{?rootdir}/lib/modules/%{kversion}/updates/kernel/fs/lustre -elif [ -e ${llog_base}.o ]; then - cp ${llog_base}.o $RPM_BUILD_ROOT%{?rootdir}/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. +%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} @@ -332,74 +376,39 @@ 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' | xargs chmod +x - -cat >lustre.files <>lustre.files +find $RPM_BUILD_ROOT -name \*.so -type f -exec chmod +x {} \; + +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) %{_includedir}/linux/lustre_user.h' >>lustre.files -else - echo '%attr(-, root, root) %{_includedir}/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) %{_includedir}/linux/lustre_types.h' >>lustre.files -fi +find $RPM_BUILD_ROOT%{_libdir}/@PACKAGE@/ -name \*.la -type f -delete %if %{with lustre_tests} -echo '%attr(-, root, root) %{_libdir}/lustre/tests/*' >lustre-tests.files -echo '%attr(-, root, root) %{?rootdir}/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 -fi +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 %{defined cross_path} @@ -422,38 +431,72 @@ if [ -f $POST_SCRIPT ]; then fi %endif %else +%if %{with lustre_modules} # mark modules executable for find-debuginfo.sh -find $RPM_BUILD_ROOT%{?rootdir}/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 +%{_includedir}/linux/lustre_user.h +%endif +%{_datadir}/lustre +%{_sysconfdir}/udev/rules.d/99-lustre.rules +%config(noreplace) %{_sysconfdir}/ldev.conf + +%if %{with lustre_modules} %files modules -%attr(-, root, root) %{?rootdir}/lib/modules/%{kversion}/updates/* +%defattr(-,root,root) +%{?rootdir}/lib/modules/%{kversion}/%{kmoddir}/* %if %{with lustre_tests} -%exclude %{?rootdir}/lib/modules/%{kversion}/updates/kernel/fs/lustre/llog_test.ko +%exclude %{?rootdir}/lib/modules/%{kversion}/%{kmoddir}/kernel/fs/@PACKAGE@/llog_test.ko %endif %if %{with ldiskfs} -%exclude %{?rootdir}/lib/modules/%{kversion}/updates/kernel/fs/lustre/ldiskfs.ko -%exclude %{?rootdir}/lib/modules/%{kversion}/updates/kernel/fs/lustre/fsfilt_ldiskfs.ko -%exclude %{?rootdir}/lib/modules/%{kversion}/updates/kernel/fs/lustre/osd_ldiskfs.ko +%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 %{with zfs} -%exclude %{?rootdir}/lib/modules/%{kversion}/updates/kernel/fs/lustre/osd_zfs.ko +%exclude %{?rootdir}/lib/modules/%{kversion}/%{kmoddir}/kernel/fs/@PACKAGE@/osd_zfs.ko %endif %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 %{with ldiskfs} %files osd-ldiskfs -%attr(-, root, root) %{?rootdir}/lib/modules/%{kversion}/updates/kernel/fs/lustre/ldiskfs.ko -%attr(-, root, root) %{?rootdir}/lib/modules/%{kversion}/updates/kernel/fs/lustre/fsfilt_ldiskfs.ko -%attr(-, root, root) %{?rootdir}/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 %{with lustre_utils} +%{_libdir}/@PACKAGE@/mount_osd_ldiskfs.so +%endif %if %{defined rpm_post_base} %attr(0555, root, root) %{rpm_post_base}-osd-ldiskfs.sh %endif @@ -461,14 +504,20 @@ find $RPM_BUILD_ROOT%{?rootdir}/lib/modules/%{kversion}/updates -name "*.ko" -ty %if %{with zfs} %files osd-zfs -%attr(-, root, root) %{?rootdir}/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 %{with lustre_utils} +%{_libdir}/@PACKAGE@/mount_osd_zfs.so +%endif %if %{defined rpm_post_base} %attr(0555, root, root) %{rpm_post_base}-osd-zfs.sh %endif %endif +%endif # with lustre_modules %files source -%attr(-, root, root) %{_prefix}/src/lustre-%{version} +%defattr(-,root,root) +%{_prefix}/src/lustre-%{version} # uncomment these lines to enable deps packages # %files deps-sles @@ -476,29 +525,31 @@ find $RPM_BUILD_ROOT%{?rootdir}/lib/modules/%{kversion}/updates -name "*.ko" -ty %if %{with lustre_tests} %files tests -f lustre-tests.files +%defattr(-,root,root) %endif %if %{with lustre_iokit} %files -n lustre-iokit -%attr(-, root, root) %{_bindir}/ior-survey -%attr(-, root, root) %{_bindir}/parse-ior -%attr(-, root, root) %{_bindir}/libecho -%attr(-, root, root) %{_bindir}/obdfilter-survey -%attr(-, root, root) %{_bindir}/plot-obdfilter -%attr(-, root, root) %{_bindir}/plot-ost -%attr(-, root, root) %{_bindir}/ost-survey -%attr(-, root, root) %{_bindir}/sgpdd-survey -%attr(-, root, root) %{_bindir}/plot-sgpdd -%attr(-, root, root) %{_bindir}/lstats.sh -%attr(-, root, root) %{_bindir}/gather_stats_everywhere.sh -%attr(-, root, root) %{_bindir}/config.sh -%attr(-, root, root) %{_bindir}/mds-survey -%doc lustre-iokit/obdfilter-survey/README.obdfilter-survey +%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/ost-survey/README.ost-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.lstats.sh +%doc lustre-iokit/stats-collect/README.iokit-lstats %endif %if %{defined rpm_post_base} @@ -513,6 +564,7 @@ if [ -x %{rpm_post_base}.sh ]; then fi %endif +%if %{with lustre_modules} %post modules %if %{defined rpm_post_base} if [ -x %{rpm_post_base}-modules.sh ]; then @@ -739,10 +791,11 @@ fi rm /var/run/%{name}-osd-zfs %endif %endif +%endif # with lustre_modules %if %{with lustre_tests} -%post 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 @@ -752,6 +805,8 @@ 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 else @@ -766,6 +821,7 @@ else fi %endif %endif +%endif %clean rm -rf $RPM_BUILD_ROOT