X-Git-Url: https://git.whamcloud.com/?p=fs%2Flustre-release.git;a=blobdiff_plain;f=config%2Flustre-build.m4;h=4cea28b87112785be0dce76494520896ad635538;hp=69648a68a924c53fe21aaba40756077f2be8f972;hb=84bcd1360516a4684a686d8e5f0b59b3ab231c6e;hpb=4dd31baae9a73502c5c7bb5c0962fd703e231fd5 diff --git a/config/lustre-build.m4 b/config/lustre-build.m4 index 69648a6..4cea28b 100644 --- a/config/lustre-build.m4 +++ b/config/lustre-build.m4 @@ -106,7 +106,12 @@ elif test -f META; then msg="$BUILDID (from META file)" AC_MSG_RESULT([$msg]) else - AC_MSG_WARN([FIXME: I don't know how to deal with source trees outside of git that don't have a META file. Not setting a buildid.]) + AC_MSG_RESULT([none]) + AC_MSG_WARN([ + +FIXME: I don't know how to deal with source trees outside of git that +don't have a META file. Not setting a buildid. +]) fi AC_SUBST(BUILDID) ]) @@ -226,47 +231,26 @@ case x$with_sysio in esac # We have to configure even if we don't build here for make dist to work -AC_CONFIG_SUBDIRS(libsysio) +AC_CONFIG_SUBDIRS([libsysio]) ]) # # LB_PATH_LUSTREIOKIT # -# Handle internal/external lustre-iokit +# We no longer handle external lustre-iokit # AC_DEFUN([LB_PATH_LUSTREIOKIT], -[AC_ARG_WITH([lustre-iokit], - AC_HELP_STRING([--with-lustre-iokit=path], - [set path to lustre-iokit source (default is included lustre-iokit)]), +[AC_ARG_ENABLE([iokit], + AC_HELP_STRING([--disable-iokit], + [disable iokit (default is enable)]), [],[ - with_lustre_iokit='yes' + enable_iokit='yes' ]) -AC_MSG_CHECKING([location of lustre-iokit]) -enable_lustre_iokit="$with_lustre_iokit" -case x$with_lustre_iokit in - xyes) - AC_MSG_RESULT([internal]) - LB_CHECK_FILE([$srcdir/lustre-iokit/ior-survey/ior-survey],[],[ - AC_MSG_ERROR([A complete internal lustre-iokit was not found.]) - ]) - LUSTREIOKIT_SUBDIR="lustre-iokit" - LUSTREIOKIT="$PWD/lustre-iokit" - ;; - xno) - AC_MSG_RESULT([disabled]) - ;; - *) - AC_MSG_RESULT([$with_lustre_iokit]) - LB_CHECK_FILE([$with_lustre_iokit/ior-survey/ior_survey],[],[ - AC_MSG_ERROR([A complete (built) external lustre-iokit was not found.]) - ]) - LUSTREIOKIT="$with_lustre_iokit" - ;; -esac +AC_MSG_CHECKING([whether to build iokit]) +AC_MSG_RESULT([$enable_iokit]) +AS_IF([test "x$enable_iokit" = xyes], [LUSTREIOKIT_SUBDIR="lustre-iokit"], [LUSTREIOKIT_SUBDIR=""])[]dnl AC_SUBST(LUSTREIOKIT_SUBDIR) -# We have to configure even if we don't build here for make dist to work -AC_CONFIG_SUBDIRS(lustre-iokit) -AM_CONDITIONAL(BUILD_LUSTREIOKIT, [test "x$with_lustre_iokit" != xno]) +AM_CONDITIONAL(BUILD_LUSTREIOKIT, [test "x$enable_iokit" = xyes]) ]) # Define no libcfs by default. @@ -322,6 +306,9 @@ if test x$enable_modules = xyes ; then LB_PROG_LINUX LIBCFS_PROG_LINUX LN_PROG_LINUX + if test x$enable_server != xno; then + LB_EXT4_SRC_DIR + fi LC_PROG_LINUX ;; darwin*) @@ -539,11 +526,8 @@ AM_CONDITIONAL(LINUX, test x$lb_target_os = "xlinux") AM_CONDITIONAL(DARWIN, test x$lb_target_os = "xdarwin") AM_CONDITIONAL(SUNOS, test x$lb_target_os = "xSunOS") AM_CONDITIONAL(USES_DPKG, test x$uses_dpkg = "xyes") -AM_CONDITIONAL(ARCH_x86, test x$target_cpu = "xx86_64" -o x$target_cpu = "xi686") -AM_CONDITIONAL(ARCH_MIC, test x$target_cpu = "xx86_64" -a x$target_vendor = "xk1om") AM_CONDITIONAL([USE_QUILT], [test x$use_quilt = xyes]) - # Sanity check for PCLMULQDQ instruction availability # PCLMULQDQ instruction is a new instruction available beginning with # the all new Core processor family based on the 32nm microarchitecture @@ -585,11 +569,19 @@ AC_DEFUN([LB_CONFIG_FILES], config/Makefile [Rules:build/Rules.in] AC_PACKAGE_TARNAME[.spec] + AC_PACKAGE_TARNAME[-dkms.spec] contrib/Makefile contrib/lbuild/Makefile contrib/scripts/Makefile ldiskfs/Makefile ldiskfs/autoMakefile + lustre-iokit/Makefile + lustre-iokit/obdfilter-survey/Makefile + lustre-iokit/ost-survey/Makefile + lustre-iokit/sgpdd-survey/Makefile + lustre-iokit/mds-survey/Makefile + lustre-iokit/ior-survey/Makefile + lustre-iokit/stats-collect/Makefile ) ]) @@ -642,6 +634,89 @@ AS_IF([test x$enable_server = xyes], ) ]) + +# +# LB_CONFIG_RPMBUILD_OPTIONS +# +# The purpose of this function is to assemble command line options +# for the rpmbuild command based on the options passed to the configure +# script, and also upon the descisions that configure makes based on +# the tests that it runs. +# These strings can be passed to rpmbuild on the command line +# in the Make targets named "rpms" and "srpm". +# +AC_DEFUN([LB_CONFIG_RPMBUILD_OPTIONS],[ + RPMBINARGS= + RPMSRCARGS= + CONFIGURE_ARGS= + eval set -- $ac_configure_args + for arg; do + case $arg in + --with-release=* ) ;; + --with-kmp-moddir=* ) ;; + --enable-tests | --disable-tests ) ;; + --with-linux=* | --with-linux-obj=* ) ;; + * ) CONFIGURE_ARGS="$CONFIGURE_ARGS '$arg'" ;; + esac + done + if test -n "$CONFIGURE_ARGS" ; then + RPMBINARGS="$RPMBINARGS --define \"configure_args $CONFIGURE_ARGS\"" + fi + if test -n "$LINUX" ; then + RPMBINARGS="$RPMBINARGS --define \"kdir $LINUX\"" + if test -n "$LINUX_OBJ" -a "$LINUX_OBJ" != x"$LINUX" ; then + RPMBINARGS="$RPMBINARGS --define \"kobjdir $LINUX_OBJ\"" + fi + fi + if test -n "$KMP_MODDIR" ; then + RPMBINARGS="$RPMBINARGS --define \"kmoddir $KMP_MODDIR\"" + fi + if test -n "$CROSS_PATH" ; then + if test x$enable_server = xyes ; then + echo -e "\n" + "*** Don't support cross compilation for the Intel(R) Xeon Phi(TM) card.\n" + exit 1 + fi + CROSS_SUFFIX="-mic" + RPMBINARGS="$RPMBINARGS --define \"post_script build/gen_filelist.sh\"" + RPMBINARGS="$RPMBINARGS --define \"cross_path $CROSS_PATH\"" + RPMBINARGS="$RPMBINARGS --define \"rootdir %{cross_path}\"" + RPMBINARGS="$RPMBINARGS --define \"_prefix %{cross_path}/usr\"" + RPMBINARGS="$RPMBINARGS --define \"_mandir %{_prefix}/share/man\"" + RPMBINARGS="$RPMBINARGS --define \"_sysconfdir %{cross_path}/etc\"" + RPMBINARGS="$RPMBINARGS --define \"make_args $CROSS_VARS\"" + if test x$CC_TARGET_ARCH = x"x86_64-k1om-linux" ; then + RPMBINARGS="$RPMBINARGS --define \"cross_requires intel-mic-gpl\"" + fi + fi + if test x$enable_tests != xyes ; then + RPMBINARGS="$RPMBINARGS --without lustre_tests" + RPMSRCARGS="$RPMSRCARGS --without lustre_tests"; + fi + if test x$enable_server != xyes ; then + RPMBINARGS="$RPMBINARGS --without servers" + if test -n "$CROSS_SUFFIX" ; then + RPMBINARGS="$RPMBINARGS --define \"lustre_name lustre-client$CROSS_SUFFIX\"" + fi + fi + if test x$enable_ldiskfs != xyes ; then + RPMBINARGS="$RPMBINARGS --without ldiskfs" + fi + if test x$enable_zfs = xyes ; then + RPMBINARGS="$RPMBINARGS --with zfs" + fi + if test x$enable_iokit != xyes ; then + RPMBINARGS="$RPMBINARGS --without lustre_iokit" + RPMSRCARGS="$RPMSRCARGS --without lustre_iokit" + fi + + RPMBUILD_BINARY_ARGS=$RPMBINARGS + RPMBUILD_SOURCE_ARGS=$RPMSRCARGS + + AC_SUBST(RPMBUILD_BINARY_ARGS) + AC_SUBST(RPMBUILD_SOURCE_ARGS) +]) + # # LB_CONFIGURE # @@ -674,6 +749,7 @@ LB_CONFIG_SERVERS # two macros for cmd3 m4_ifdef([LC_CONFIG_SPLIT], [LC_CONFIG_SPLIT]) +m4_ifdef([LC_NODEMAP_PROC_DEBUG], [LC_NODEMAP_PROC_DEBUG]) LN_CONFIG_CDEBUG LC_QUOTA @@ -712,6 +788,8 @@ AC_SUBST(ac_configure_args) MOSTLYCLEANFILES='.*.cmd .*.flags *.o *.ko *.mod.c .depend .*.1.* Modules.symvers Module.symvers' AC_SUBST(MOSTLYCLEANFILES) +LB_CONFIG_RPMBUILD_OPTIONS + AC_OUTPUT cat <<_ACEOF