X-Git-Url: https://git.whamcloud.com/?p=fs%2Flustre-release.git;a=blobdiff_plain;f=config%2Flustre-build-ldiskfs.m4;h=74fdbf3bf85d4185c73a9bf9fec1a72162c51493;hp=cdcd10b9f81cd2f0dff811cda1984adcde609f2c;hb=2cebaa2bc5cd0554ae2b0b625cf9b6da0b1a16c6;hpb=1ec95b2b5410286c46b95c624e1d382b1e86535a diff --git a/config/lustre-build-ldiskfs.m4 b/config/lustre-build-ldiskfs.m4 index cdcd10b..74fdbf3 100644 --- a/config/lustre-build-ldiskfs.m4 +++ b/config/lustre-build-ldiskfs.m4 @@ -1,332 +1,568 @@ # -# LB_PATH_LDISKFS +# LDISKFS_LINUX_SERIES # -# --without-ldiskfs - Disable ldiskfs support. -# --with-ldiskfs=no +AC_DEFUN([LDISKFS_LINUX_SERIES], [ +AC_MSG_CHECKING([which ldiskfs series to use]) +case x$LDISKFS_SERIES in + x) # not set + ;; + *.series) # set externally + ;; + *) LDISKFS_SERIES= +esac +AS_IF([test -z "$LDISKFS_SERIES"], [ +AS_IF([test x$RHEL_KERNEL = xyes], [ + case $RHEL_RELEASE_NO in + 83) LDISKFS_SERIES="4.18-rhel8.3.series" ;; + 82) LDISKFS_SERIES="4.18-rhel8.2.series" ;; + 81) LDISKFS_SERIES="4.18-rhel8.1.series" ;; + 80) LDISKFS_SERIES="4.18-rhel8.series" ;; + 79) LDISKFS_SERIES="3.10-rhel7.9.series" ;; + 78) LDISKFS_SERIES="3.10-rhel7.8.series" ;; + 77) LDISKFS_SERIES="3.10-rhel7.7.series" ;; + 76) LDISKFS_SERIES="3.10-rhel7.6.series" ;; + esac +], [test x$SUSE_KERNEL = xyes], [ + AS_VERSION_COMPARE([$LINUXRELEASE],[5.3.18],[ + AS_VERSION_COMPARE([$LINUXRELEASE],[4.12.14],[], [], [ + suse_conf=$LINUX_OBJ/include/generated/uapi/linux/suse_version.h + suse_vers=$(awk '[$]2 == "SUSE_VERSION" {print [$]3 }' $suse_conf) + suse_patchlevel=$(awk '[$]2 == "SUSE_PATCHLEVEL" {print [$]3 }' $suse_conf) + echo "$suse_conf $suse_vers $suse_patchlevel ${suse_vers}sp$suse_patchlevel" >> /tmp/log-nb + case ${suse_vers}sp$suse_patchlevel in # ( + 15sp0 ) LDISKFS_SERIES="4.12-sles15.series" + if test ! -f $LINUX/arch/x86/kernel/cpu/hygon.c ; then + # This file was added shortly after -150.22 so + # this must be 150.22 or earlier + LDISKFS_SERIES="4.12-sles15-22.series" + fi + ;; # ( + 15sp1 ) LDISKFS_SERIES="4.12-sles15sp1.series" + if test ! -f $LINUX/arch/x86/kernel/cpu/umwait.c ; then + # This file was added after -197.7 so + # this must be -197.7 or earlier + LDISKFS_SERIES="4.12-sles15sp1-7.series" + fi + ;; + esac + ] + )], [LDISKFS_SERIES="5.4.21-ml.series"], + [LDISKFS_SERIES="5.4.21-ml.series"]) +], [test x$UBUNTU_KERNEL = xyes], [ + AS_VERSION_COMPARE([$LINUXRELEASE],[5.4.0],[ + AS_VERSION_COMPARE([$LINUXRELEASE],[5.0.0],[ + AS_VERSION_COMPARE([$LINUXRELEASE],[4.15.0],[ + AS_VERSION_COMPARE([$LINUXRELEASE],[4.4.0], [], + [ + KPLEV=$(echo $LINUXRELEASE | sed -n 's/.*-\([0-9]\+\).*/\1/p') + AS_IF( + [test -z "$KPLEV"], [ + AC_MSG_WARN([Failed to determine Kernel patch level. Assume latest.]) + LDISKFS_SERIES="4.4.0-73-ubuntu14+16.series" + ], + [test $KPLEV -ge 73], [LDISKFS_SERIES="4.4.0-73-ubuntu14+16.series"], + [test $KPLEV -ge 62], [LDISKFS_SERIES="4.4.0-62-ubuntu14+16.series"], + [test $KPLEV -ge 49], [LDISKFS_SERIES="4.4.0-49-ubuntu14+16.series"], + [LDISKFS_SERIES="4.4.0-45-ubuntu14+16.series"] + ) + ], + [LDISKFS_SERIES="4.4.0-73-ubuntu14+16.series"])], + [ + KPLEV=$(echo $LINUXRELEASE | sed -n 's/.*-\([0-9]\+\).*/\1/p') + AS_IF( + [test -z "$KPLEV"], [ + AC_MSG_WARN([Failed to determine Kernel patch level. Assume latest.]) + LDISKFS_SERIES="4.15.0-24-ubuntu18.series" + ], + [test $KPLEV -ge 24], [LDISKFS_SERIES="4.15.0-24-ubuntu18.series"], + [test $KPLEV -ge 20], [LDISKFS_SERIES="4.15.0-20-ubuntu18.series"] + ) + ], + [LDISKFS_SERIES="4.15.0-24-ubuntu18.series"])], + [LDISKFS_SERIES="5.0.0-13-ubuntu19.series"], + [LDISKFS_SERIES="5.0.0-13-ubuntu19.series"])], + [LDISKFS_SERIES="5.4.0-42-ubuntu20.series"], + [LDISKFS_SERIES="5.4.0-42-ubuntu20.series"], + [LDISKFS_SERIES="5.4.0-ml.series"]) +]) +]) +# Not RHEL/SLES or Ubuntu .. probably mainline +AS_IF([test -z "$LDISKFS_SERIES"], + [ + AS_VERSION_COMPARE([$LINUXRELEASE],[5.4.0],[], + [LDISKFS_SERIES="5.4.0-ml.series"],[ + AS_VERSION_COMPARE([$LINUXRELEASE],[5.4.21], + [LDISKFS_SERIES="5.4.0-ml.series"], # lt + [LDISKFS_SERIES="5.4.21-ml.series"], # eq + [LDISKFS_SERIES="5.4.21-ml.series"] # gt + )]) + ], +[]) +AS_IF([test -z "$LDISKFS_SERIES"], + [AC_MSG_RESULT([failed to identify series])], + [AC_MSG_RESULT([$LDISKFS_SERIES for $LINUXRELEASE])]) +AC_SUBST(LDISKFS_SERIES) +]) # LDISKFS_LINUX_SERIES + # -# --with-ldiskfs - Enable ldiskfs support and attempt to autodetect the -# --with-ldiskfs=yes headers in one of the following places in this order: -# * ./ldiskfs -# * /usr/src/ldiskfs-*/$LINUXRELEASE -# * ../ldiskfs +# LB_EXT_FREE_BLOCKS_WITH_BUFFER_HEAD # -# --with-ldiskfs=path - Enable ldiskfs support and use the headers in the -# provided path. No autodetection is performed. +# 2.6.32-rc7 ext4_free_blocks requires struct buffer_head +# Note that RHEL6 is pre 2.6.32-rc7 so this check is still needed. # -# --with-ldiskfs-obj - When ldiskfs support is enabled the object directory -# will be based on the --with-ldiskfs directory. If -# this is detected incorrectly it can be explicitly -# specified using this option. +AC_DEFUN([LB_EXT_FREE_BLOCKS_WITH_BUFFER_HEAD], [ +LB_CHECK_COMPILE([if 'ext4_free_blocks' needs 'struct buffer_head'], +ext4_free_blocks_with_buffer_head, [ + #include + #include "$EXT4_SRC_DIR/ext4.h" +],[ + ext4_free_blocks(NULL, NULL, NULL, 0, 0, 0); +],[ + AC_DEFINE(HAVE_EXT_FREE_BLOCK_WITH_BUFFER_HEAD, 1, + [ext4_free_blocks do not require struct buffer_head]) +]) +]) # LB_EXT_FREE_BLOCKS_WITH_BUFFER_HEAD + # -# NOTE: As with all external packages ldiskfs is expected to already be -# configured and built. However, if the ldiskfs tree is located in-tree -# (./ldiskfs) then it will be configured and built recursively as part of -# the lustre build system. +# LB_EXT4_JOURNAL_START_3ARGS # -# NOTE: The lustre and in-tree ldiskfs build systems both make use these -# macros. This is undesirable and confusing at best, it is potentially -# danagerous at worst. The ldiskfs build system should be entirely stand -# alone without dependency on the lustre build system. +# 3.9 added a type argument to ext4_journal_start and friends # -AC_DEFUN([LB_PATH_LDISKFS], -[ -AC_ARG_WITH([ldiskfs], - AC_HELP_STRING([--with-ldiskfs=path], [set path to ldiskfs source]), - [],[ - if test x$enable_server = xyes && test x$enable_dist = xno; then - with_ldiskfs='yes' - else - with_ldiskfs='no' - fi - ]) - -case x$with_ldiskfs in - xno) - LDISKFS_DIR= - ;; - xyes) - LDISKFS_DIR= - - # Check ./ldiskfs - ldiskfs_src=$PWD/ldiskfs - if test -e "$ldiskfs_src"; then - LDISKFS_DIR=$(readlink -f $ldiskfs_src) - else - # Check /usr/src/ldiskfs-*/$LINUXRELEASE - ldiskfs_src=$(ls -1d \ - /usr/src/ldiskfs-*/$LINUXRELEASE \ - 2>/dev/null | tail -1) - if test -e "$ldiskfs_src"; then - LDISKFS_DIR=$(readlink -f $ldiskfs_src) - else - # Check ../ldiskfs - ldiskfs_src=$PWD/../ldiskfs - if test -e "$ldiskfs_src"; then - LDISKFS_DIR=$(readlink -f $ldiskfs_src) - else - # Disable ldiskfs failed to detect - with_ldiskfs='no' - fi - fi - fi +AC_DEFUN([LB_EXT4_JOURNAL_START_3ARGS], [ +LB_CHECK_COMPILE([if ext4_journal_start takes 3 arguments], +ext4_journal_start, [ + #include + #include "$EXT4_SRC_DIR/ext4_jbd2.h" +],[ + ext4_journal_start(NULL, 0, 0); +],[ + AC_DEFINE(JOURNAL_START_HAS_3ARGS, 1, [ext4_journal_start takes 3 arguments]) +]) +]) # LB_EXT4_JOURNAL_START_3ARGS - ;; - *) - LDISKFS_DIR=$(readlink -f $with_ldiskfs) - with_ldiskfs='yes' - ;; -esac +# +# LB_EXT4_BREAD_4ARGS +# +# 3.18 ext4_bread has 4 arguments +# NOTE: It may not be exported for modules, use a positive compiler test here. +# +AC_DEFUN([LB_EXT4_BREAD_4ARGS], [ +LB_CHECK_COMPILE([if ext4_bread takes 4 arguments], +ext4_bread, [ + #include + #include "$EXT4_SRC_DIR/ext4.h" + + struct buffer_head *ext4_bread(handle_t *handle, struct inode *inode, + ext4_lblk_t block, int map_flags) + { + struct buffer_head *bh = NULL; + (void)handle; + (void)inode; + (void)block; + (void)map_flags; + return bh; + } +],[ + ext4_bread(NULL, NULL, 0, 0); +],[ + AC_DEFINE(HAVE_EXT4_BREAD_4ARGS, 1, [ext4_bread takes 4 arguments]) +]) +]) # LB_EXT4_BREAD_4ARGS -AC_MSG_CHECKING([whether to enable ldiskfs]) -AC_MSG_RESULT([$with_ldiskfs]) +# +# LB_EXT4_HAVE_INFO_DQUOT +# +# in linux 4.4 i_dqout is in ext4_inode_info, not in struct inode +# +AC_DEFUN([LB_EXT4_HAVE_INFO_DQUOT], [ +LB_CHECK_COMPILE([if i_dquot is in ext4_inode_info], +ext4_info_dquot, [ + #include + #include + #include "$EXT4_SRC_DIR/ext4.h" +],[ + struct ext4_inode_info in; + struct dquot *dq; + + dq = in.i_dquot[0]; +],[ + AC_DEFINE(HAVE_EXT4_INFO_DQUOT, 1, [i_dquot is in ext4_inode_info]) +]) +]) # LB_EXT4_HAVE_INFO_DQUOT -AC_ARG_WITH([ldiskfs-obj], - AC_HELP_STRING([--with-ldiskfs-obj=path],[set path to ldiskfs objects]), - [ - if test x$with_ldiskfs = xyes; then - LDISKFS_OBJ="$withval" - fi - ],[ - if test x$with_ldiskfs = xyes; then - LDISKFS_OBJ=$LDISKFS_DIR - fi +# +# LB_EXT4_HAVE_I_CRYPT_INFO +# +# in linux 4.8 i_crypt_info moved from ext4_inode_info to struct inode +# +# Determine if we need to enable CONFIG_LDISKFS_FS_ENCRYPTION. +# If we have i_crypt_info in ext4_inode_info, the config option +# should be enabled to make the ldiskfs module compilation happy. +# Otherwise i_crypy_info is in struct inode, we need to check kernel +# config option to determine that. +# +AC_DEFUN([LB_EXT4_HAVE_I_CRYPT_INFO], [ +LB_CHECK_COMPILE([if i_crypt_info is in ext4_inode_info], +ext4_i_crypt_info, [ + #define CONFIG_EXT4_FS_ENCRYPTION 1 + #include + #include "$EXT4_SRC_DIR/ext4.h" +],[ + struct ext4_inode_info in; + + in.i_crypt_info = NULL; +],[ + AC_DEFINE( + CONFIG_LDISKFS_FS_ENCRYPTION, 1, + [enable encryption for ldiskfs] + ) +],[ + LB_CHECK_CONFIG([EXT4_FS_ENCRYPTION],[ + AC_DEFINE( + CONFIG_LDISKFS_FS_ENCRYPTION, 1, + [enable encryption for ldiskfs] + ) ]) +]) +]) # LB_EXT4_HAVE_I_CRYPT_INFO -if test x$with_ldiskfs = xyes; then - AC_MSG_CHECKING([ldiskfs source directory]) - AC_MSG_RESULT([$LDISKFS_DIR]) - AC_SUBST(LDISKFS_DIR) - - AC_MSG_CHECKING([ldiskfs object directory]) - AC_MSG_RESULT([$LDISKFS_OBJ]) - AC_SUBST(LDISKFS_OBJ) +# +# LB_LDISKFS_JOURNAL_ENSURE_CREDITS +# +# kernel 4.18.0-240.1.1.el8 and +# kernel 5.4 commit a413036791d040e33badcc634453a4d0c0705499 +# +# ext4_journal_ensure_credits was introduced to ensure given handle +# has at least requested amount of credits available, and possibly +# restarting transaction if needed. +# +AC_DEFUN([LB_LDISKFS_JOURNAL_ENSURE_CREDITS], [ +tmp_flags="$EXTRA_KCFLAGS" +EXTRA_KCFLAGS="-Werror" +LB_CHECK_COMPILE([if 'ext4_journal_ensure_credits' exists], +ext4_journal_ensure_credits, [ + #include "$EXT4_SRC_DIR/ext4_jbd2.h" + int __ext4_journal_ensure_credits(handle_t *handle, int check_cred, + int extend_cred, int revoke_cred) { return 0; } +],[ + ext4_journal_ensure_credits(NULL, 0, 0); +],[ + AC_DEFINE(HAVE_LDISKFS_JOURNAL_ENSURE_CREDITS, 1, + ['ext4_journal_ensure_credits' exists]) +]) +EXTRA_KCFLAGS="$tmp_flags" +]) # LB_LDISKFS_JOURNAL_ENSURE_CREDITS - LB_LDISKFS_SYMVERS - LB_LDISKFS_RELEASE - LB_LDISKFS_EXT_DIR - LB_LDISKFS_BUILD - AC_DEFINE(HAVE_LDISKFS_OSD, 1, Enable ldiskfs osd) -fi +# +# LB_LDISKFS_IGET_HAS_FLAGS_ARG +# +# kernel 4.19 commit 8a363970d1dc38c4ec4ad575c862f776f468d057 +# ext4_iget changed to a macro with 3 args was function with 2 args +# +AC_DEFUN([LB_LDISKFS_IGET_HAS_FLAGS_ARG], [ +tmp_flags="$EXTRA_KCFLAGS" +EXTRA_KCFLAGS="-Werror" +LB_CHECK_COMPILE([if ldiskfs_iget takes a flags argument], +ext4_iget_3args, [ + #include + #include "$EXT4_SRC_DIR/ext4.h" +],[ + int f = EXT4_IGET_SPECIAL; + (void)f; +],[ + AC_DEFINE(HAVE_LDISKFS_IGET_WITH_FLAGS, 1, + [if ldiskfs_iget takes a flags argument]) +]) +EXTRA_KCFLAGS="$tmp_flags" +]) # LB_LDISKFS_IGET_HAS_FLAGS_ARG # -# LDISKFS_DEVEL is required because when using the ldiskfs-devel package the -# ext4 source will be fully patched to ldiskfs. When building with the -# in-tree ldiskfs this patching this will occur after the configure step. -# We needed a way to determine if we should check the patched or unpatched -# source files. +# LDISKFS_AC_PATCH_PROGRAM # -# Longer term this could be removed by moving the ldiskfs patching in to -# the configure phase. Or better yet ldiskfs could be updated to generate -# a ldiskfs_config.h which clearly defines how it was built. This can -# then be directly included by Lustre to avoid all the autoconf guess work. -# For an example of this behavior consult the lustre/zfs build integration. +# Determine which program should be used to apply the patches to +# the ext4 source code to produce the ldiskfs source code. # -AM_CONDITIONAL(LDISKFS_DEVEL, \ - test x$LDISKFS_DIR = x$(readlink -f $PWD/ldiskfs) || \ - test x$LDISKFS_DIR = x$(readlink -f $PWD/../ldiskfs)) +AC_DEFUN([LDISKFS_AC_PATCH_PROGRAM], [ + AC_ARG_ENABLE([quilt], + [AC_HELP_STRING([--disable-quilt], + [disable use of quilt for ldiskfs])], + [AS_IF([test "x$enableval" = xno], + [use_quilt=no], + [use_quilt=maybe])], + [use_quilt=maybe] + ) + + AS_IF([test x$use_quilt = xmaybe], [ + AC_PATH_PROG([quilt_avail], [quilt], [no]) + AS_IF([test x$quilt_avail = xno], [ + use_quilt=no + ], [ + use_quilt=yes + ]) + ]) -AM_CONDITIONAL(LDISKFS_BUILD, test x$enable_ldiskfs_build = xyes) -AM_CONDITIONAL(LDISKFS_ENABLED, test x$with_ldiskfs = xyes) + AS_IF([test x$use_quilt = xno], [ + AC_PATH_PROG([patch_avail], [patch], [no]) + AS_IF([test x$patch_avail = xno], [ + AC_MSG_ERROR([*** Need "quilt" or "patch" command]) + ]) + ]) +]) # LDISKFS_AC_PATCH_PROGRAM -if test -e "$PWD/ldiskfs"; then - LDISKFS_DIST_SUBDIR="ldiskfs" - AC_SUBST(LDISKFS_DIST_SUBDIR) - AC_CONFIG_SUBDIRS("ldiskfs") -fi +# +# LB_LDISKFS_FIND_ENTRY_LOCKED_EXISTS +# +# kernel 5.2 commit 8a363970d1dc38c4ec4ad575c862f776f468d057 +# ext4: avoid declaring fs inconsistent due to invalid file handles +# __ext4_find_entry became a helper function for ext4_find_entry +# conflicting with previous ldiskfs patches. +# ldiskfs patches map ext4_find_entry to ldiskfs_find_entry_locked to +# avoid conflicting with __ext4_find_entry +# +# When the following check succeeds __ext4_find_entry helper is not +# used. +# +AC_DEFUN([LB_LDISKFS_FIND_ENTRY_LOCKED_EXISTS], [ +tmp_flags="$EXTRA_KCFLAGS" +EXTRA_KCFLAGS="-Werror" +LB_CHECK_COMPILE([if __ldiskfs_find_entry is available], +ldiskfs_find_entry_locked, [ + #include + #include "$EXT4_SRC_DIR/ext4.h" + #include "$EXT4_SRC_DIR/namei.c" + + static int __ext4_find_entry(void) { return 0; } +],[ + int x = __ext4_find_entry(); + (void)x; +],[ + AC_DEFINE(HAVE___LDISKFS_FIND_ENTRY, 1, + [if __ldiskfs_find_entry is available]) ]) +EXTRA_KCFLAGS="$tmp_flags" +]) # LB_LDISKFS_FIND_ENTRY_LOCKED_EXISTS # -# LB_LDISKFS_EXT_DIR +# LB_LDISKFSFS_DIRHASH_WANTS_DIR # -# Determine the location of the ext4 source code. It it required -# for several configure tests and to build ldiskfs. +# kernel 5.2 commit 8a363970d1dc38c4ec4ad575c862f776f468d057 +# ext4fs_dirhash UNICODE support # -AC_DEFUN([LB_LDISKFS_EXT_DIR], -[ -# Kernel ext source located with devel headers -linux_src=$LINUX -if test -e "$linux_src/fs/ext4/super.c"; then - EXT_DIR=$linux_src/fs/ext4 -else - # Kernel ext source provided by kernel-debuginfo-common package - linux_src=$(ls -1d /usr/src/debug/*/linux-$LINUXRELEASE \ - 2>/dev/null | tail -1) - if test -e "$linux_src/fs/ext4/super.c"; then - EXT_DIR=$linux_src/fs/ext4 - else - EXT_DIR= - fi -fi +AC_DEFUN([LB_LDISKFSFS_DIRHASH_WANTS_DIR], [ +tmp_flags="$EXTRA_KCFLAGS" +EXTRA_KCFLAGS="-Werror" +LB_CHECK_COMPILE([if ldiskfsfs_dirhash takes an inode argument], +ext4fs_dirhash, [ + #include + #include "$EXT4_SRC_DIR/ext4.h" + + int ext4fs_dirhash(const struct inode *dir, const char *name, int len, + struct dx_hash_info *hinfo) + { + (void)dir; + (void)name; + (void)len; + (void)hinfo; + return 0; + } +],[ + int f = ext4fs_dirhash(NULL, NULL, 0, NULL); + (void)f; +],[ + AC_DEFINE(HAVE_LDISKFSFS_GETHASH_INODE_ARG, 1, + [ldiskfsfs_dirhash takes an inode argument]) +]) +EXTRA_KCFLAGS="$tmp_flags" +]) # LB_LDISKFSFS_DIRHASH_WANTS_DIR -AC_MSG_CHECKING([ext4 source directory]) -AC_MSG_RESULT([$EXT_DIR]) -AC_SUBST(EXT_DIR) +# +# LB_JBD2_H_TOTAL_CREDITS +# +# kernel 5.5 commit 933f1c1e0b75bbc29730eef07c9e196c6dfd37e5 +# jbd2: Reserve space for revoke descriptor blocks +# +AC_DEFUN([LB_JBD2_H_TOTAL_CREDITS], [ +tmp_flags="$EXTRA_KCFLAGS" +EXTRA_KCFLAGS="-Werror" +LB_CHECK_COMPILE([if struct jbd2_journal_handle has h_total_credits member], +handle_t_h_revoke_credits, [ + #include +],[ + int x = offsetof(struct jbd2_journal_handle, h_total_credits); + (void)x; +],[ + AC_DEFINE(HAVE_JOURNAL_TOTAL_CREDITS, 1, + [struct jbd2_journal_handle has h_total_credits member]) +]) +EXTRA_KCFLAGS="$tmp_flags" +]) # LB_JBD2_H_TOTAL_CREDITS + +# +# LB_CONFIG_LDISKFS +# +AC_DEFUN([LB_CONFIG_LDISKFS], [ +# --with-ldiskfs is deprecated now that ldiskfs is fully merged with lustre. +# However we continue to support this option through Lustre 2.5. +AC_ARG_WITH([ldiskfs], + [], + [AC_MSG_WARN([--with-ldiskfs is deprecated, please use --enable-ldiskfs]) + AS_IF([test x$withval != xyes -a x$withval != xno], + [AC_MSG_ERROR([ + +The ldiskfs option is deprecated, +and no longer supports paths to external ldiskfs source +])]) ]) +AC_ARG_ENABLE([ldiskfs], + [AS_HELP_STRING([--disable-ldiskfs], + [disable ldiskfs osd (default is enable)])], + [AS_IF([test x$enable_ldiskfs != xyes -a x$enable_ldiskfs != xno], + [AC_MSG_ERROR([ldiskfs valid options are "yes" or "no"])])], + [AS_IF([test "${with_ldiskfs+set}" = set], + [enable_ldiskfs=$with_ldiskfs], + [enable_ldiskfs=maybe]) +]) + +AS_IF([test x$enable_server = xno], + [AS_CASE([$enable_ldiskfs], + [maybe], [enable_ldiskfs=no], + [yes], [AC_MSG_ERROR([cannot build ldiskfs when servers are disabled])] + )]) + +AS_IF([test x$enable_ldiskfs != xno],[ + # In the future, we chould change enable_ldiskfs from maybe to + # either yes or no based on additional tests, e.g. whether a patch + # set is available for the detected kernel. For now, we just always + # set it to "yes". + AS_IF([test x$enable_ldiskfs = xmaybe], [enable_ldiskfs=yes]) + AC_SUBST(ENABLE_LDISKFS, yes) + + LDISKFS_LINUX_SERIES + LDISKFS_AC_PATCH_PROGRAM + LB_EXT_FREE_BLOCKS_WITH_BUFFER_HEAD + LB_EXT4_JOURNAL_START_3ARGS + LB_EXT4_BREAD_4ARGS + LB_EXT4_HAVE_INFO_DQUOT + LB_EXT4_HAVE_I_CRYPT_INFO + LB_LDISKFS_JOURNAL_ENSURE_CREDITS + LB_LDISKFS_IGET_HAS_FLAGS_ARG + LB_LDISKFS_FIND_ENTRY_LOCKED_EXISTS + LB_LDISKFSFS_DIRHASH_WANTS_DIR + LB_JBD2_H_TOTAL_CREDITS + AC_DEFINE(CONFIG_LDISKFS_FS_POSIX_ACL, 1, [posix acls for ldiskfs]) + AC_DEFINE(CONFIG_LDISKFS_FS_SECURITY, 1, [fs security for ldiskfs]) + AC_DEFINE(CONFIG_LDISKFS_FS_XATTR, 1, [extened attributes for ldiskfs]) + AC_DEFINE(CONFIG_LDISKFS_FS_RW, 1, [enable rw access for ldiskfs]) + AC_SUBST(LDISKFS_SUBDIR, ldiskfs) + AC_DEFINE(HAVE_LDISKFS_OSD, 1, Enable ldiskfs osd) +], [ + AC_SUBST(ENABLE_LDISKFS, no) +]) + +AC_MSG_CHECKING([whether to build ldiskfs]) +AC_MSG_RESULT([$enable_ldiskfs]) + +AM_CONDITIONAL([LDISKFS_ENABLED], [test x$enable_ldiskfs = xyes]) +]) # LB_CONFIG_LDISKFS + + +AC_DEFUN([LB_EXT4_SRC_DIR_SRC], []) +AC_DEFUN([LB_EXT4_SRC_DIR_RESULTS], []) + # -# LB_LDISKFS_EXT_SOURCE +# LB_VALIDATE_EXT4_SRC_DIR # -# Spot check the existance of several source files common to ext4. +# Spot check the existence of several source files common to ext4. # Detecting this at configure time allows us to avoid a potential build # failure and provide a useful error message to explain what is wrong. # -AC_DEFUN([LB_LDISKFS_EXT_SOURCE], -[ -if test x$EXT_DIR = x; then - enable_ldiskfs_build='no' -else - LB_CHECK_FILE([$EXT_DIR/dir.c], [], [ - enable_ldiskfs_build='no' - AC_MSG_WARN([ext4 must exist for ldiskfs build])]) - LB_CHECK_FILE([$EXT_DIR/file.c], [], [ - enable_ldiskfs_build='no' - AC_MSG_WARN([ext4 must exist for ldiskfs build])]) - LB_CHECK_FILE([$EXT_DIR/inode.c], [], [ - enable_ldiskfs_build='no' - AC_MSG_WARN([ext4 must exist for ldiskfs build])]) - LB_CHECK_FILE([$EXT_DIR/super.c], [], [ - enable_ldiskfs_build='no' - AC_MSG_WARN([ext4 must exist for ldiskfs build])]) -fi - -if test x$enable_ldiskfs_build = xno; then - enable_server='no' - enable_ldiskfs_build='no' - with_ldiskfs='no' - LDISKFS_SUBDIR= +AC_DEFUN([LB_VALIDATE_EXT4_SRC_DIR], [ +enable_ldiskfs_build="no" +AS_IF([test -n "$EXT4_SRC_DIR"], [ + enable_ldiskfs_build="yes" + LB_CHECK_FILE([$EXT4_SRC_DIR/dir.c], [], [ + enable_ldiskfs_build="no" + AC_MSG_WARN([ext4 must exist for ldiskfs build]) + ]) + LB_CHECK_FILE([$EXT4_SRC_DIR/file.c], [], [ + enable_ldiskfs_build="no" + AC_MSG_WARN([ext4 must exist for ldiskfs build]) + ]) + LB_CHECK_FILE([$EXT4_SRC_DIR/inode.c], [], [ + enable_ldiskfs_build="no" + AC_MSG_WARN([ext4 must exist for ldiskfs build]) + ]) + LB_CHECK_FILE([$EXT4_SRC_DIR/super.c], [], [ + enable_ldiskfs_build="no" + AC_MSG_WARN([ext4 must exist for ldiskfs build]) + ]) +]) + +AS_IF([test "x$enable_ldiskfs_build" = xno], [ + enable_ldiskfs="no" AC_MSG_WARN([ -Disabling server because complete ext4 source does not exist. +Disabling ldiskfs support because complete ext4 source does not exist. If you are building using kernel-devel packages and require ldiskfs server support then ensure that the matching kernel-debuginfo-common and kernel-debuginfo-common- packages are installed. - ]) - -fi ]) +]) # LB_VALIDATE_EXT4_SRC_DIR # -# Optionally configure/make the ldiskfs sources. If the sources are -# determined to reside in-tree this feature will automatically be -# enabled. If the sources are not in-tree it will be disabled. -# Use --enable-ldiskfs-build or --disable-ldiskfs-build if you need -# to override this behavior. -# -AC_DEFUN([LB_LDISKFS_BUILD], -[ -AC_ARG_ENABLE([ldiskfs-build], - AC_HELP_STRING([--enable-ldiskfs-build], - [enable ldiskfs configure/make]), - [], [ - LDISKFS_DIR_INTREE=$(readlink -f $PWD/ldiskfs) - if test x$LDISKFS_DIR = x$LDISKFS_DIR_INTREE; then - enable_ldiskfs_build='yes' - else - enable_ldiskfs_build='no' - fi +# LB_EXT4_SRC_DIR +# +# Determine the location of the ext4 source code. It it required +# for several configure tests and to build ldiskfs. +# +AC_DEFUN([LB_EXT4_SRC_DIR], [ +AC_MSG_CHECKING([ext4 source directory]) +# Kernel ext source located with devel headers +linux_src=$LINUX +AS_IF([test -e "$linux_src/fs/ext4/super.c"], [ + EXT4_SRC_DIR="$linux_src/fs/ext4" +], [ + # Kernel ext source provided by kernel-debuginfo-common package + # that extracted to $LINUX + linux_src=$(ls -1d $linux_src/../../debug/*/linux-${LINUXRELEASE%.*}* \ + 2>/dev/null | tail -1) + AS_IF([test -e "$linux_src/fs/ext4/super.c"], [ + EXT4_SRC_DIR="$linux_src/fs/ext4" + ], [ + # Kernel ext source provided by kernel-debuginfo-common package + linux_src=$(ls -1d /usr/src/debug/*/linux-${LINUXRELEASE%.*}* \ + 2>/dev/null | tail -1) + AS_IF([test -e "$linux_src/fs/ext4/super.c"], [ + EXT4_SRC_DIR="$linux_src/fs/ext4" + ], [ + EXT4_SRC_DIR="" + ]) ]) - -AC_MSG_CHECKING([whether to build ldiskfs]) -if test x$enable_ldiskfs_build = xyes; then - AC_MSG_RESULT([$enable_ldiskfs_build]) - LDISKFS_SUBDIR="ldiskfs" - - LB_CHECK_FILE([$LDISKFS_DIR/configure], [], [ - AC_MSG_ERROR([Complete ldiskfs build system must exist])]) - LB_LDISKFS_EXT_SOURCE - - AC_SUBST(LDISKFS_SUBDIR) -else - enable_ldiskfs_build='no' - AC_MSG_RESULT([$enable_ldiskfs_build]) -fi ]) +AC_MSG_RESULT([$EXT4_SRC_DIR]) +AC_SUBST(EXT4_SRC_DIR) -AC_DEFUN([LB_LDISKFS_SYMVERS], -[ -AC_MSG_CHECKING([ldiskfs module symbols]) -if test -r $LDISKFS_OBJ/Module.symvers; then - LDISKFS_SYMBOLS=Module.symvers -elif test -r $LDISKFS_OBJ/Modules.symvers; then - LDISKFS_SYMBOLS=Modules.symvers -elif test -r $LDISKFS_OBJ/ldiskfs/Module.symvers; then - LDISKFS_SYMBOLS=Module.symvers -elif test -r $LDISKFS_OBJ/ldiskfs/Modules.symvers; then - LDISKFS_SYMBOLS=Modules.symvers -else - LDISKFS_SYMBOLS=$SYMVERFILE -fi - -AC_MSG_RESULT([$LDISKFS_SYMBOLS]) -AC_SUBST(LDISKFS_SYMBOLS) -]) - -AC_DEFUN([LB_LDISKFS_RELEASE], -[ -AC_MSG_CHECKING([ldiskfs source release]) -if test -r $LDISKFS_OBJ/config.h; then - tmp_flags="$EXTRA_KCFLAGS" - EXTRA_KCFLAGS="-I$LDISKFS_DIR $EXTRA_KCFLAGS" - LB_LINUX_TRY_MAKE([ - #undef PACKAGE_NAME - #undef PACKAGE_TARNAME - #undef PACKAGE_VERSION - #undef PACKAGE_STRING - #undef PACKAGE_BUGREPORT - #undef PACKAGE - #undef VERSION - #undef STDC_HEADERS - - #include <$LDISKFS_OBJ/config.h> - ],[ - char *LDISKFS_RELEASE; - LDISKFS_RELEASE=VERSION; - ],[ - $makerule LUSTRE_KERNEL_TEST=conftest.i - ],[ - test -s build/conftest.i - ],[ - eval $(grep "LDISKFS_RELEASE=" build/conftest.i) - ],[ - AC_MSG_RESULT([unknown]) - AC_MSG_ERROR([Could not preprocess test program.]) - ]) - EXTRA_KCFLAGS="$tmp_flags" - rm build/conftest.i -elif test -r $LDISKFS_DIR/configure.ac; then - LDISKFS_RELEASE=$(awk '/AC\_INIT/ { print [$]3 }' \ - $LDISKFS_DIR/configure.ac | tr ',' '\n') -else - AC_MSG_RESULT([unknown]) - AC_MSG_ERROR([Could not locate config.h, META, or configure.ac to check release.]) -fi - -if test x$LDISKFS_RELEASE = x; then - AC_MSG_RESULT([unknown]) - AC_MSG_ERROR([Could not determine ldiskfs release.]) -fi - -AC_MSG_RESULT([$LDISKFS_RELEASE]) -AC_SUBST(LDISKFS_RELEASE) -]) +LB_VALIDATE_EXT4_SRC_DIR +]) # LB_EXT4_SRC_DIR # # LB_DEFINE_E2FSPROGS_NAMES # # Enable the use of alternate naming of ldiskfs-enabled e2fsprogs package. # -AC_DEFUN([LB_DEFINE_E2FSPROGS_NAMES], -[ +AC_DEFUN([LB_DEFINE_E2FSPROGS_NAMES], [ +AC_MSG_CHECKING([whether to use alternate names for e2fsprogs]) AC_ARG_WITH([ldiskfsprogs], - AC_HELP_STRING([--with-ldiskfsprogs], - [use alternate names for ldiskfs-enabled e2fsprogs]), - [],[withval='no']) + AC_HELP_STRING([--with-ldiskfsprogs], + [use alternate names for ldiskfs-enabled e2fsprogs]), + [], [withval="no"]) -AC_MSG_CHECKING([whether to use alternate names for e2fsprogs]) -if test x$withval = xyes ; then +AS_IF([test "x$withval" = xyes], [ + AC_MSG_RESULT([enabled]) AC_DEFINE(HAVE_LDISKFSPROGS, 1, [enable use of ldiskfsprogs package]) E2FSPROGS="ldiskfsprogs" MKE2FS="mkfs.ldiskfs" @@ -336,8 +572,8 @@ if test x$withval = xyes ; then DUMPE2FS="dumpfs.ldiskfs" E2FSCK="fsck.ldiskfs" PFSCK="pfsck.ldiskfs" - AC_MSG_RESULT([enabled]) -else +], [ + AC_MSG_RESULT([disabled]) E2FSPROGS="e2fsprogs" MKE2FS="mke2fs" DEBUGFS="debugfs" @@ -346,8 +582,7 @@ else DUMPE2FS="dumpe2fs" E2FSCK="e2fsck" PFSCK="fsck" - AC_MSG_RESULT([disabled]) -fi +]) AC_DEFINE_UNQUOTED(E2FSPROGS, "$E2FSPROGS", [name of ldiskfs e2fsprogs package]) AC_DEFINE_UNQUOTED(MKE2FS, "$MKE2FS", [name of ldiskfs mkfs program]) @@ -366,4 +601,4 @@ AC_SUBST([E2LABEL], [$E2LABEL]) AC_SUBST([DUMPE2FS], [$DUMPE2FS]) AC_SUBST([E2FSCK], [$E2FSCK]) AC_SUBST([PFSCK], [$PFSCK]) -]) +]) # LB_DEFINE_E2FSPROGS_NAMES