From e96be1888ae8b82905d5b554df7cad496b369cf3 Mon Sep 17 00:00:00 2001 From: Brian Behlendorf Date: Mon, 22 Mar 2010 16:42:18 -0700 Subject: [PATCH 1/3] Allow zfs_config.h to be included by dependant packages (updated) We need dependent packages to be able to include zfs_config.h to build properly. This was partially solved previously be using AH_BOTTOM to #undef common #defines (PACKAGE, VERSION, etc) which autoconf always adds and cannot be easily removed. This solution works as long as the zfs_config.h is included before your projects config.h. That turns out to be easier said than done. In particular, this is a problem when your package includes its config.h using the -include gcc option which ensures the first thing included is your config.h. To handle all cases cleanly I have removed the AH_BOTTOM hack and replaced it with an AC_CONFIG_HEADERS command. This command runs immediately after zfs_config.h is written and with a little awk-foo it strips the offending #defines from the file. This eliminates the problem entirely and makes header safe for inclusion. --- Makefile.am | 5 +++-- config/Rules.am | 2 +- config/config.awk | 15 +++++++++++++++ config/kernel.m4 | 8 +++----- configure.ac | 8 +++++--- zfs_unconfig.h | 12 ------------ 6 files changed, 27 insertions(+), 23 deletions(-) create mode 100644 config/config.awk delete mode 100644 zfs_unconfig.h diff --git a/Makefile.am b/Makefile.am index c174e98d1c..d0a70b06cd 100644 --- a/Makefile.am +++ b/Makefile.am @@ -9,10 +9,11 @@ endif SUBDIRS = $(USER_DIR) $(KERNEL_DIR) AUTOMAKE_OPTIONS = foreign dist-zip -EXTRA_DIST = autogen.sh zfs.spec.in zfs-modules.spec.in +EXTRA_DIST = autogen.sh config/config.awk +EXTRA_DIST += zfs.spec.in zfs-modules.spec.in EXTRA_DIST += META DISCLAIMER GIT EXTRA_DIST += OPENSOLARIS.LICENSE ZFS.RELEASE -noinst_HEADERS = zfs_config.h zfs_unconfig.h +noinst_HEADERS = zfs_config.h distclean-local:: -$(RM) -R autom4te*.cache diff --git a/config/Rules.am b/config/Rules.am index e36860ee68..115fa348f4 100644 --- a/config/Rules.am +++ b/config/Rules.am @@ -1,4 +1,4 @@ -DEFAULT_INCLUDES = -I${top_srcdir} +DEFAULT_INCLUDES = -include ${top_srcdir}/zfs_config.h # FIXME: Add -Wshadow once everything is working AM_CFLAGS = -Wall -Wstrict-prototypes -fno-strict-aliasing -Werror diff --git a/config/config.awk b/config/config.awk new file mode 100644 index 0000000000..cc4b7cc265 --- /dev/null +++ b/config/config.awk @@ -0,0 +1,15 @@ +# Remove default preprocessor define's from config.h +# PACKAGE +# PACKAGE_BUGREPORT +# PACKAGE_NAME +# PACKAGE_STRING +# PACKAGE_TARNAME +# PACKAGE_VERSION +# STDC_HEADERS +# VERSION + +BEGIN { RS = "" ; FS = "\n" } \ + !/.#define PACKAGE./ && \ + !/.#define VERSION./ && \ + !/.#define STDC_HEADERS./ \ + { print $0"\n" } diff --git a/config/kernel.m4 b/config/kernel.m4 index 95c5942540..952eb3f3e3 100644 --- a/config/kernel.m4 +++ b/config/kernel.m4 @@ -23,15 +23,13 @@ AC_DEFUN([ZFS_AC_CONFIG_KERNEL], [ ZFS_AC_KERNEL_RQ_IS_SYNC ZFS_AC_KERNEL_RQ_FOR_EACH_SEGMENT - dnl # Kernel build make options - dnl # KERNELMAKE_PARAMS="V=1" # Enable verbose module build - KERNELMAKE_PARAMS= - dnl # -Wall -fno-strict-aliasing -Wstrict-prototypes and other dnl # compiler options are added by the kernel build system. KERNELCPPFLAGS="$KERNELCPPFLAGS -Werror -DHAVE_SPL -D_KERNEL" KERNELCPPFLAGS="$KERNELCPPFLAGS -DTEXT_DOMAIN=\\\"zfs-linux-kernel\\\"" - KERNELCPPFLAGS="$KERNELCPPFLAGS -I$TOPDIR -I$SPL -I$SPL/include" + KERNELCPPFLAGS="$KERNELCPPFLAGS -I$SPL/include" + KERNELCPPFLAGS="$KERNELCPPFLAGS -include $SPL/spl_config.h" + KERNELCPPFLAGS="$KERNELCPPFLAGS -include $TOPDIR/zfs_config.h" if test "$LINUX_OBJ" != "$LINUX"; then KERNELMAKE_PARAMS="$KERNELMAKE_PARAMS O=$LINUX_OBJ" diff --git a/configure.ac b/configure.ac index f49b09b764..1ef7003f97 100644 --- a/configure.ac +++ b/configure.ac @@ -35,10 +35,12 @@ AC_LANG(C) ZFS_AC_META AC_CONFIG_AUX_DIR([config]) AC_CANONICAL_SYSTEM -AM_INIT_AUTOMAKE([$ZFS_META_NAME], [$ZFS_META_VERSION]) -AC_CONFIG_HEADERS([zfs_config.h]) -AH_BOTTOM([#include ]) AM_MAINTAINER_MODE +AM_INIT_AUTOMAKE([$ZFS_META_NAME], [$ZFS_META_VERSION]) +AC_CONFIG_HEADERS([zfs_config.h], [ + (mv zfs_config.h zfs_config.h.tmp && + awk -f config/config.awk zfs_config.h.tmp >zfs_config.h && + rm zfs_config.h.tmp) || exit 1]) AC_PROG_INSTALL AC_PROG_CC diff --git a/zfs_unconfig.h b/zfs_unconfig.h deleted file mode 100644 index eee3b87adc..0000000000 --- a/zfs_unconfig.h +++ /dev/null @@ -1,12 +0,0 @@ -/* - * Undefine these symbols to allow other autoheader enabled packages - * to leverage the ZFS configure checks without a header conflict. - */ -#undef PACKAGE -#undef PACKAGE_BUGREPORT -#undef PACKAGE_NAME -#undef PACKAGE_STRING -#undef PACKAGE_TARNAME -#undef PACKAGE_VERSION -#undef VERSION -#undef STDC_HEADERS From c9aaaff23b07a7bb3f03cff8e667ea1241eeeafe Mon Sep 17 00:00:00 2001 From: Brian Behlendorf Date: Mon, 22 Mar 2010 16:48:16 -0700 Subject: [PATCH 2/3] Move zfs_config.h include to command line -include Remove the few places in the code where zfs_config.h is included. It is now added to the gcc compile line to ensure the config results are always available. --- module/avl/avl.c | 1 - module/nvpair/nvpair.c | 1 - module/unicode/u8_textprep.c | 1 - module/zcommon/zfs_prop.c | 1 - 4 files changed, 4 deletions(-) diff --git a/module/avl/avl.c b/module/avl/avl.c index eb8bfcd052..cdcf2afa61 100644 --- a/module/avl/avl.c +++ b/module/avl/avl.c @@ -1033,7 +1033,6 @@ done: } #if defined(_KERNEL) && defined(HAVE_SPL) -#include "zfs_config.h" static int avl_init(void) { return 0; } static int avl_fini(void) { return 0; } diff --git a/module/nvpair/nvpair.c b/module/nvpair/nvpair.c index 02abfdbefb..3492f23518 100644 --- a/module/nvpair/nvpair.c +++ b/module/nvpair/nvpair.c @@ -3246,7 +3246,6 @@ nvs_xdr(nvstream_t *nvs, nvlist_t *nvl, char *buf, size_t *buflen) } #if defined(_KERNEL) && defined(HAVE_SPL) -#include "zfs_config.h" static int nvpair_init(void) { return 0; } static int nvpair_fini(void) { return 0; } diff --git a/module/unicode/u8_textprep.c b/module/unicode/u8_textprep.c index 9f90e5056d..df6dcf552b 100644 --- a/module/unicode/u8_textprep.c +++ b/module/unicode/u8_textprep.c @@ -2133,7 +2133,6 @@ u8_textprep_str(char *inarray, size_t *inlen, char *outarray, size_t *outlen, } #if defined(_KERNEL) && defined(HAVE_SPL) -#include "zfs_config.h" static int unicode_init(void) { return 0; } static int unicode_fini(void) { return 0; } diff --git a/module/zcommon/zfs_prop.c b/module/zcommon/zfs_prop.c index ec93ae4c99..bb73e7ee35 100644 --- a/module/zcommon/zfs_prop.c +++ b/module/zcommon/zfs_prop.c @@ -534,7 +534,6 @@ zfs_prop_align_right(zfs_prop_t prop) #endif #if defined(_KERNEL) && defined(HAVE_SPL) -#include "zfs_config.h" static int zcommon_init(void) { return 0; } static int zcommon_fini(void) { return 0; } From 5b14d2ab2f4b764f43d291f22e67db04691e2a3a Mon Sep 17 00:00:00 2001 From: Brian Behlendorf Date: Mon, 22 Mar 2010 16:50:58 -0700 Subject: [PATCH 3/3] Move zfs_config.h include to command line -include Remove the few places in the code where zfs_config.h is included. It is now added to the gcc compile line to ensure the config results --- module/zfs/include/sys/blkdev.h | 1 - module/zfs/include/sys/vdev_disk.h | 1 - module/zfs/zfs_ioctl.c | 1 - 3 files changed, 3 deletions(-) diff --git a/module/zfs/include/sys/blkdev.h b/module/zfs/include/sys/blkdev.h index 9ad184b3ea..389b2237aa 100644 --- a/module/zfs/include/sys/blkdev.h +++ b/module/zfs/include/sys/blkdev.h @@ -5,7 +5,6 @@ #include #include -#include "zfs_config.h" #ifndef HAVE_FMODE_T typedef unsigned __bitwise__ fmode_t; diff --git a/module/zfs/include/sys/vdev_disk.h b/module/zfs/include/sys/vdev_disk.h index 544036bbc0..6f6ed2ed8d 100644 --- a/module/zfs/include/sys/vdev_disk.h +++ b/module/zfs/include/sys/vdev_disk.h @@ -10,7 +10,6 @@ extern "C" { #include #include #include -#include typedef struct vdev_disk { ddi_devid_t vd_devid; diff --git a/module/zfs/zfs_ioctl.c b/module/zfs/zfs_ioctl.c index 8511d408a0..eb3f80d16c 100644 --- a/module/zfs/zfs_ioctl.c +++ b/module/zfs/zfs_ioctl.c @@ -69,7 +69,6 @@ #include "zfs_namecheck.h" #include "zfs_prop.h" #include "zfs_deleg.h" -#include "zfs_config.h" extern void zfs_init(void); extern void zfs_fini(void);