Whamcloud - gitweb
Branch b_hd_kdmu
[fs/lustre-release.git] / build / autoconf / lustre-build.m4
index dd9fc53..73707bb 100644 (file)
@@ -305,7 +305,7 @@ AC_ARG_ENABLE([bgl],
        [enable_bgl='yes'],[enable_bgl='no'])
 AC_MSG_RESULT([$enable_bgl])
 if test x$enable_bgl != xno; then
-        AC_DEFINE(BGL_SUPPORT, 1, Enable BGL Features)
+        AC_DEFINE(HAVE_BGL_SUPPORT, 1, Enable BGL Features)
         enable_doc='no'
         enable_tests='no'
         enable_server='no'
@@ -357,32 +357,72 @@ AM_CONDITIONAL(POSIX_OSD_ENABLED, test x$posix_osd = xyes)
 
 #
 # LB_PATH_DMU
-# Support for --with-dmu
 #
 AC_DEFUN([LB_PATH_DMU],
-[AC_MSG_CHECKING([whether to enable DMU])
-AC_ARG_WITH([dmu],
-       AC_HELP_STRING([--with-dmu=path],
-                      [set path to a DMU tree (default is included zfs-lustre)]),
-       [
-               DMU_SRC=$with_dmu
-       ],
-       [
-               DMU_SRC="$PWD/zfs-lustre"
-       ])
-if test x$enable_uoss = xyes -a x$enable_posix_osd != xyes; then
+[AC_ARG_ENABLE([dmu],
+       AC_HELP_STRING([--enable-dmu],
+                      [enable the DMU backend]),
+       [],[with_dmu='default'])
+AC_MSG_CHECKING([whether to enable DMU])
+case x$with_dmu in
+       xyes)
+               dmu_osd='yes'
+               ;;
+       xno)
+               dmu_osd='no'
+               ;;
+       xdefault)
+               if test x$enable_uoss = xyes -a x$posix_osd != xyes; then
+                       # Enable the DMU if we're configuring a userspace server
+                       dmu_osd='yes'
+               else
+                       # Enable the DMU by default on the b_hd_kdmu branch
+                       if test -d $PWD/zfs -a x$linux25$enable_server = xyesyes; then
+                               dmu_osd='yes'
+                       else
+                               dmu_osd='no'
+                       fi
+               fi
+               ;;
+       *)
+               dmu_osd='yes'
+               ;;
+esac
+AC_MSG_RESULT([$dmu_osd])
+if test x$dmu_osd = xyes; then
        AC_DEFINE(DMU_OSD, 1, Enable DMU OSD)
-       AC_MSG_RESULT([yes])
-       LB_CHECK_FILE([$DMU_SRC/src/.patched],[],[
-               AC_MSG_ERROR([A complete (patched) DMU tree was not found.])
-       ])
-       AC_CONFIG_SUBDIRS(zfs-lustre)
-       dmu_osd='yes'
-else
-       AC_MSG_RESULT([no])
+       if test x$enable_uoss = xyes; then
+               # Userspace DMU
+               DMU_SRC="$PWD/lustre/zfs-lustre"
+               AC_SUBST(DMU_SRC)
+               LB_CHECK_FILE([$DMU_SRC/src/.patched],[],[
+                       AC_MSG_ERROR([A complete (patched) DMU tree was not found.])
+               ])
+               AC_CONFIG_SUBDIRS(lustre/zfs-lustre)
+       else
+               # Kernel DMU
+               SPL_DIR="$PWD/spl"
+               ZFS_DIR="$PWD/zfs"
+               AC_SUBST(SPL_DIR)
+               AC_SUBST(ZFS_DIR)
+
+               AC_SUBST(spl_src)
+
+               LB_CHECK_FILE([$SPL_DIR/modules/spl/spl-generic.c],[],[
+                       AC_MSG_ERROR([A complete SPL tree was not found in $SPL_DIR.])
+               ])
+
+               LB_CHECK_FILE([$ZFS_DIR/zfs/lib/libzpool/dmu.c],[],[
+                       AC_MSG_ERROR([A complete kernel DMU tree was not found in $ZFS_DIR.])
+               ])
+
+               AC_CONFIG_SUBDIRS(spl)
+               ac_configure_args="$ac_configure_args --with-spl=$SPL_DIR"
+               AC_CONFIG_SUBDIRS(zfs)
+       fi
 fi
-AC_SUBST(DMU_SRC)
 AM_CONDITIONAL(DMU_OSD_ENABLED, test x$dmu_osd = xyes)
+AM_CONDITIONAL(KDMU, test x$dmu_osd$enable_uoss = xyesno)
 ])
 
 #
@@ -602,12 +642,19 @@ if test $ac_cv_sizeof_unsigned_long_long != 8 ; then
         AC_MSG_ERROR([** we assume that sizeof(long long) == 8.  Tell phil@clusterfs.com])
 fi
 
+if test $target_cpu == "powerpc64"; then
+       AC_MSG_WARN([set compiler with -m64])
+       CFLAGS="$CFLAGS -m64"
+       CC="$CC -m64"
+fi
+
 CPPFLAGS="-I\$(top_builddir)/$LIBCFS_INCLUDE_DIR -I\$(top_srcdir)/$LIBCFS_INCLUDE_DIR-I\$(top_builddir)/lnet/include -I\$(top_srcdir)/lnet/include -I\$(top_builddir)/lustre/include -I\$(top_srcdir)/lustre/include $CPPFLAGS"
 
 LLCPPFLAGS="-D__arch_lib__ -D_LARGEFILE64_SOURCE=1"
 AC_SUBST(LLCPPFLAGS)
 
-LLCFLAGS="-g -Wall -fPIC"
+# Add _GNU_SOURCE for strnlen on linux
+LLCFLAGS="-g -Wall -fPIC -D_GNU_SOURCE"
 AC_SUBST(LLCFLAGS)
 
 # everyone builds against lnet and lustre
@@ -686,20 +733,20 @@ LB_PROG_CC
 
 LB_UOSS
 LB_POSIX_OSD
-LB_PATH_DMU
 
 LB_CONFIG_DOCS
 LB_CONFIG_UTILS
 LB_CONFIG_TESTS
 LC_CONFIG_CLIENT_SERVER
 
-# three macros for cmd3 
-LC_CONFIG_SPLIT
-LC_CONFIG_LDISKFS
+# two macros for cmd3 
+m4_ifdef([LC_CONFIG_SPLIT], [LC_CONFIG_SPLIT])
 LN_CONFIG_CDEBUG
+LC_QUOTA
 
 LB_CONFIG_MODULES
 
+LB_PATH_DMU
 LB_PATH_LIBSYSIO
 LB_PATH_SNMP
 LB_PATH_LDISKFS