From: David Schleef <ds@schleef.org>
Date: Wed, 2 Jun 2004 19:00:58 +0000 (+0000)
Subject: Upgrade as-linux.m4 and as-modtool.m4.  Fix build system to handle
X-Git-Tag: r0_7_69~39
X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=74eba3d47b03ac97e9bc759f2d4eee44cea9a9c6;p=comedi.git

Upgrade as-linux.m4 and as-modtool.m4.  Fix build system to handle
changes.
---

diff --git a/comedi/Makefile.am b/comedi/Makefile.am
index 32390fd2..9464b678 100644
--- a/comedi/Makefile.am
+++ b/comedi/Makefile.am
@@ -1,5 +1,5 @@
 
-SUBDIRS = kcomedilib drivers
+SUBDIRS = . kcomedilib drivers
 
 module_PROGRAMS = comedi.ko
 
diff --git a/comedi/drivers/Makefile.am b/comedi/drivers/Makefile.am
index 36fb402e..8fb45cc0 100644
--- a/comedi/drivers/Makefile.am
+++ b/comedi/drivers/Makefile.am
@@ -2,7 +2,36 @@
 #SUBDIRS = addi-data
 
 AM_CFLAGS = $(COMEDI_CFLAGS) $(LINUX_CFLAGS) $(RTAI_CFLAGS) $(RTLINUX_CFLAGS)
-LINK = $(top_builddir)/modtool --link -o $@
+LINK = $(top_builddir)/modtool --link -o $@ \
+	-i ../.mods/comedi.o.symvers \
+	-i .mods/8255.o.symvers \
+	-i .mods/amcc_s5933.o.symvers \
+	-i .mods/comedi_fc.o.symvers \
+	-i .mods/das08.o.symvers \
+	-i .mods/mite.o.symvers \
+	-i .mods/ni_labpc.o.symvers
+
+8255_ko_LINK = $(top_builddir)/modtool --link -o $@ \
+	-i ../.mods/comedi.o.symvers
+amcc_s5933_ko_LINK = $(top_builddir)/modtool --link -o $@ \
+	-i ../.mods/comedi.o.symvers
+comedi_fc_ko_LINK = $(top_builddir)/modtool --link -o $@ \
+	-i ../.mods/comedi.o.symvers
+das08_ko_CFLAGS = $(top_builddir)/modtool --link -o $@ \
+	-i ../.mods/comedi.o.symvers
+mite_ko_LINK = $(top_builddir)/modtool --link -o $@ \
+	-i ../.mods/comedi.o.symvers
+ni_labpc_ko_CFLAGS = $(top_builddir)/modtool --link -o $@ \
+	-i ../.mods/comedi.o.symvers
+
+8255_ko_CFLAGS = $(AM_CFLAGS) -DEXPORT_SYMTAB
+amcc_s5933_ko_CFLAGS = $(AM_CFLAGS) -DEXPORT_SYMTAB
+comedi_fc_ko_CFLAGS = $(AM_CFLAGS) -DEXPORT_SYMTAB
+das08_ko_CFLAGS = $(AM_CFLAGS) -DEXPORT_SYMTAB
+mite_ko_CFLAGS = $(AM_CFLAGS) -DEXPORT_SYMTAB
+ni_labpc_ko_CFLAGS = $(AM_CFLAGS) -DEXPORT_SYMTAB
+
+
 
 EXTRA_DIST = \
  8253.h \
@@ -48,11 +77,16 @@ else
 usb_modules=
 endif
 
-module_PROGRAMS = 8255.ko \
+module_PROGRAMS = \
+ 8255.ko \
+ amcc_s5933.ko \
+ comedi_fc.ko \
+ das08.ko \
+ mite.ko \
+ ni_labpc.ko \
  adl_pci9111.ko \
  adl_pci9118.ko \
  adv_pci1710.ko \
- amcc_s5933.ko \
  adv_pci_dio.ko \
  amplc_pci230.ko \
  amplc_pc236.ko \
@@ -62,10 +96,8 @@ module_PROGRAMS = 8255.ko \
  cb_pcidda.ko \
  cb_pcimdas.ko \
  cb_pcimdda.ko \
- comedi_fc.ko \
  contec_pci_dio.ko \
  daqboard2000.ko \
- das08.ko \
  das16.ko \
  das16m1.ko \
  das6402.ko \
@@ -85,7 +117,6 @@ module_PROGRAMS = 8255.ko \
  ke_counter.ko \
  me_daq.ko \
  me4000.ko \
- mite.ko \
  multiq3.ko \
  ni_660x.ko \
  ni_670x.ko \
@@ -95,7 +126,6 @@ module_PROGRAMS = 8255.ko \
  ni_6527.ko \
  ni_atmio16d.ko \
  ni_at_a2150.ko \
- ni_labpc.ko \
  ni_at_ao.ko \
  pcm3730.ko \
  pcmad.ko \
@@ -193,10 +223,3 @@ ssv_dnp_ko_SOURCES = ssv_dnp.c
 comedi_test_ko_SOURCES = comedi_test.c
 usbdux_ko_SOURCES = usbdux.c
 
-mite_ko_CFLAGS = $(AM_CFLAGS) -DEXPORT_SYMTAB
-8255_ko_CFLAGS = $(AM_CFLAGS) -DEXPORT_SYMTAB
-amcc_s5933_ko_CFLAGS = $(AM_CFLAGS) -DEXPORT_SYMTAB
-comedi_fc_ko_CFLAGS = $(AM_CFLAGS) -DEXPORT_SYMTAB
-ni_labpc_ko_CFLAGS = $(AM_CFLAGS) -DEXPORT_SYMTAB
-das08_ko_CFLAGS = $(AM_CFLAGS) -DEXPORT_SYMTAB
-
diff --git a/comedi/kcomedilib/Makefile.am b/comedi/kcomedilib/Makefile.am
index 7aeece01..108da7e2 100644
--- a/comedi/kcomedilib/Makefile.am
+++ b/comedi/kcomedilib/Makefile.am
@@ -3,7 +3,7 @@ module_PROGRAMS = kcomedilib.ko
 
 kcomedilib_ko_SOURCES = data.c ksyms.c dio.c kcomedilib_main.c get.c
 kcomedilib_ko_CFLAGS = $(COMEDI_CFLAGS) $(LINUX_CFLAGS) $(RTAI_CFLAGS) $(RTLINUX_CFLAGS)
-kcomedilib_ko_LINK = $(top_builddir)/modtool --link -o $@
+kcomedilib_ko_LINK = $(top_builddir)/modtool --link -o $@ -i ../.mods/comedi.o.symvers
 
 #ksyms.o: ksyms.c
 #	$(CC) -o $@ ksyms.c $(CFLAGS) $(COMEDI_CFLAGS) $(LINUX_CFLAGS) -DEXPORT_SYMTAB
diff --git a/m4/as-linux.m4 b/m4/as-linux.m4
index f1543bfb..1e4a1f92 100644
--- a/m4/as-linux.m4
+++ b/m4/as-linux.m4
@@ -1,14 +1,26 @@
-dnl as-linux.m4 0.0.1
+dnl as-linux.m4 0.2.0
+
 dnl autostars m4 macro for detecting a Linux source tree (or
 dnl equivalent) for compiling modules.
-dnl
+
 dnl David Schleef <ds@schleef.org>
 dnl Frank Mori Hess <fmhess@users.sourceforge.net>
-dnl thomas@apestaart.org
-dnl
+dnl Thomas Vander Stichele <thomas@apestaart.org>
+
+dnl $Id$
+
 dnl AS_LINUX()
 dnl
-dnl this macro adds the options --with-linuxdir and --with-linux-config.
+dnl this macro adds the options
+dnl --with-linuxdir        to specify a kernel build tree location
+dnl --with-linuxconfig     to specify a kernel .config file
+dnl --with-kernel-release  to specify an alternative uname -r
+dnl --with-machine         to specify an alternative uname -m
+dnl --with-rpm-target      to specify to match the given rpm --target option
+dnl --with-extraversion    to specify an EXTRAVERSION override
+dnl --with-modulesdir      to specify the base install location of modules
+dnl --with-modulesdeveldir to specify the base install location of build stuff
+
 dnl this macro defines:
 dnl LINUX_DIR
 dnl   The directory where the Linux source resides.
@@ -38,10 +50,58 @@ dnl LINUX_AS
 dnl   Assembler used by Linux.
 dnl LINUX_MODULE_EXT
 dnl   Module extension (.o or .ko)
-dnl
+dnl LINUX_MODPOST
+dnl   path to modpost script
+dnl modulesdir
+dnl   base install path for kernel modules
+dnl modulesdeveldir
+dnl   base install path for kernel module development files
 dnl 
 dnl End of search list.
 
+dnl main entry point
+dnl checks the version, and figures out all flags to use to make modules.
+AC_DEFUN([AS_LINUX],
+[
+	dnl check if user supplied a uname -r, and if not use the running one
+	AS_LINUX_KERNEL_RELEASE()
+	dnl check if user supplied a uname -m, and if not use the running one
+	AS_LINUX_MACHINE() 	 
+	dnl check if the user supplied an rpm target arch
+	dnl override the LINUX_MACHINE value if he did
+	AS_LINUX_RPM_TARGET($LINUX_KERNEL_RELEASE) 	 
+  	 
+	dnl find the kernel source tree for the given uname -r 	 
+	AS_LINUX_DIR($LINUX_KERNEL_RELEASE) 	 
+	dnl check if user supplied an EXTRAVERSION, and if not get from uname -r
+	AS_LINUX_EXTRAVERSION($LINUX_KERNEL_RELEASE) 	 
+	dnl check if user supplied a config file; if not, guess a good one
+	AS_LINUX_CONFIG($LINUX_DIR, $LINUX_KERNEL_RELEASE, $LINUX_MACHINE) 	 
+	dnl check if we're building on pre-FC2 Red Hat/Fedora,
+	dnl and add some flags if we are 	 
+	AS_CHECK_REDHAT_PRE_FC2() 	 
+	dnl check for where to install modules
+	AS_LINUX_MODULESDIR($LINUX_KERNEL_RELEASE)
+	dnl check for where to install module development files
+	AS_LINUX_MODULESDEVELDIR($LINUX_DIR)
+	dnl check for the MAJOR/MINOR version of Linux 	 
+	AS_LINUX_VERSION_MAJOR_MINOR($LINUX_DIR)
+
+	dnl now call the correct macro to get compiler flags
+	dnl the versioned AS_LINUX macros just use the global variables
+	dnl this could be cleaned up later on if we feel like it
+	case $LINUX_VERSION_MAJOR.$LINUX_VERSION_MINOR in
+		2.6)
+			AS_LINUX_2_6()
+			;;
+		2.[[01234]])
+			AS_LINUX_2_4()
+			;;
+		*)
+			AC_MSG_ERROR([Unknown Linux major.minor $LINUX_VERSION_MAJOR.$LINUX_VERSION_MINOR])
+			;;
+	esac
+])
 
 
 dnl check if we can find a source dir for the Linux kernel
@@ -93,76 +153,202 @@ AC_DEFUN([AS_TRY_LINUX_DIR],
 	AC_MSG_RESULT($result)
 ])
 
+dnl allow for specifying a kernel release (uname -r) to build for
+dnl use uname -r of running one if not specified
+dnl store result in LINUX_KERNEL_RELEASE
+AC_DEFUN([AS_LINUX_KERNEL_RELEASE],
+[
+	AC_ARG_WITH([kernel-release],
+		[AC_HELP_STRING([--with-kernel-release=RELEASE],
+			[specify the "uname -r"-value to build for])],
+		[LINUX_KERNEL_RELEASE="${withval}"],
+		[LINUX_KERNEL_RELEASE=`uname -r`])
+        if test "x$LINUX_KERNEL_RELEASE" = "xyes";
+        then
+		LINUX_KERNEL_RELEASE=`uname -r`
+        fi
+        AC_MSG_NOTICE([Using $LINUX_KERNEL_RELEASE as the uname -r value])
+])
+
+dnl allow for specifying a machine (uname -m) to build for
+dnl use uname -, of running one if not specified
+dnl store result in LINUX_MACHINE
+AC_DEFUN([AS_LINUX_MACHINE],
+[
+	AC_ARG_WITH([machine],
+		[AC_HELP_STRING([--with-machine=MACHINE],
+			[specify the "uname -m"-value to build for])],
+		[LINUX_MACHINE="${withval}"],
+		[LINUX_MACHINE=`uname -m`])
+        if test "x$LINUX_MACHINE" = "xyes";
+        then
+		LINUX_MACHINE=`uname -r`
+        fi
+        AC_MSG_NOTICE([Using $LINUX_MACHINE as the uname -m value])
+])
+dnl allow for specifying an rpm target arch
+dnl if none specified, try to guess one from running rpm querying for
+dnl the kernel with the uname -r
+dnl this is so configure without arguments works out of the box
+dnl FIXME: investigate if uname -p is a correct guess for this, and if
+dnl we should have a flag for specifying it instead
+
+dnl this macro possibly overrides LINUX_MACHINE
+
+dnl first argument is the kernel release building for
+AC_DEFUN([AS_LINUX_RPM_TARGET],
+[
+	RELEASE=$1
+	AC_ARG_WITH([rpm-target],
+		[AC_HELP_STRING([--with-rpm-target=TARGET],
+			[specify the target arch to build for])],
+		[LINUX_RPM_TARGET="${withval}"],
+		[LINUX_RPM_TARGET=])
+	if test "x$LINUX_RPM_TARGET" = "x"
+	then
+		dnl if we have rpm, try to guess the target of the kernel
+		dnl we want to build for using rpm
+		AC_PATH_PROG(RPM, rpm, yes, no)
+		if test "x$RPM" = "xyes"
+		then
+			if rpm -q kernel-$RELEASE > /dev/null
+			then
+				LINUX_RPM_TARGET=`rpm -q --queryformat %{arch} kernel-$RELEASE`
+			else
+				AC_MSG_NOTICE([Cannot guess target arch, consider setting it using --with-rpm-target])
+			fi
+		fi
+	fi
+
+	dnl now override LINUX_MACHINE if LINUX_RPM_TARGET is set
+	if test "x$LINUX_RPM_TARGET" != "x"
+	then
+		dnl override LINUX_MACHINE based on this
+		dnl FIXME: add other possible Red Hat/Fedora/rpm targets here
+		LINUX_MACHINE=
+		case "$LINUX_RPM_TARGET" in
+			i?86) LINUX_MACHINE=i386;;
+			athlon) LINUX_MACHINE=i386;;
+			x86_64) LINUX_MACHINE=x86_64;;
+		esac
+		if test "x$LINUX_MACHINE" = "x"
+		then
+		AC_MSG_ERROR(Could not guess uname -m value from target $LINUX_RPM_TARGET)
+		fi
+	fi
+])
+
+
+dnl allow for specifying an override for EXTRAVERSION
+dnl if none specified, make it from the passed-in KERNEL_RELEASE (uname -r)
+dnl resulting value is stored in LINUX_EXTRAVERSION
+dnl first argument is the uname -r string to use as a fallback
+AC_DEFUN([AS_LINUX_EXTRAVERSION],
+[
+	KERNEL_RELEASE=[$1]
+	dnl extract the default by getting everything after first -
+	LINUX_EXTRAVERSION="-`echo $KERNEL_RELEASE | cut -d- -f 2-`"
+	AC_ARG_WITH([extraversion],
+		[AC_HELP_STRING([--with-extraversion=FILE],
+			[specify override for kernel EXTRAVERSION])],
+		[LINUX_EXTRAVERSION="${withval}"],)
+])
+
+
 dnl check if we can find a config file for the Linux kernel
-dnl defines CONFIG_FILE to the absolute location of a usable kernel source tree
-dnl uses LINUX_DIR to find either .config or decent configs in configs/
-AC_DEFUN([AS_CONFIG_FILE],
+dnl defines LINUX_CONFIG to the absolute location of a usable
+dnl kernel source config file
+
+dnl for rpm distros, it can try and guess the correct config file by
+dnl checking the global LINUX_RPM_TARGET variable set somewhere else
+dnl (FIXME: move this to an argument instead ?)
+
+dnl first argument is LINUX_DIR to check for possible configs
+dnl second argument is kernel-release (uname -r)
+dnl third argument is machine (uname -m)
+
+AC_DEFUN([AS_LINUX_CONFIG],
 [
-	AC_ARG_WITH([linux-config],
-		[AC_HELP_STRING([--with-linux-config=FILE],
+	LINUX_DIR=[$1]
+	KERNEL_RELEASE=[$2]
+	MACHINE=[$3]
+	AC_ARG_WITH([linuxconfig],
+		[AC_HELP_STRING([--with-linuxconfig=FILE],
 			[specify path to Linux configuration file])],
-		[CONFIG_FILE="${withval}"],
-		[CONFIG_FILE=default])
+		[LINUX_CONFIG="${withval}"],
+		[LINUX_CONFIG=default])
 
-	if test "${CONFIG_FILE}" != "default" ; then
-		AS_TRY_CONFIG_FILE([${CONFIG_FILE}], , AC_MSG_ERROR([Linux config not found]) )
+	dnl if a file got specified, try it as a linux config file
+	if test "${LINUX_CONFIG}" != "default" ; then
+		AS_TRY_LINUX_CONFIG($LINUX_CONFIG, $MACHINE,
+                                    ,, AC_MSG_ERROR([Linux config not found]) )
 	fi
 
-        dnl if default specified, first check for the regular .config file
+        dnl if no file specified, first check for the regular .config file
         dnl in LINUX_DIR created by manual configuration
-	if test "${CONFIG_FILE}" = "default" ; then
+	if test "${LINUX_CONFIG}" = "default" ; then
 		file="$LINUX_DIR/.config";
-		AS_TRY_CONFIG_FILE([${file}], [CONFIG_FILE=${file}], )
+		AS_TRY_LINUX_CONFIG($file, $MACHINE,
+		                    [LINUX_CONFIG=${file}], )
 	fi
         dnl second, try to guess what config file to use for the current kernel
-	if test "${CONFIG_FILE}" = "default" ; then
+	dnl FIXME: the possible arch is from rpmbuild --target, and is
+	dnl different from the value of ARCH (Makefile) or MACHINE (uname -m)
+	dnl so we should have a redhat flag to specify the target to find
+	dnl the correct config file
+	if test "${LINUX_CONFIG}" = "default" && test "x$LINUX_RPM_TARGET" != "x"; then
 		dnl Red Hat stores configuration files for their built kernels
 		dnl named kernel-(version)-(arch)(extra).config
 		dnl where arch is athlon, i386, i586, i686, x86_64
 		dnl and (extra) is empty or -smp, -BOOT, -bigmem
 		dnl haven't seen combinations of extra yet as of FC1
-		version=`uname -r | cut -d- -f1`
-		machine=`uname -m`
+		KVERSION=`echo $KERNEL_RELEASE | cut -d- -f1`
 		extra=
-		uname -r | grep smp && extra="-smp"
-		uname -r | grep bigmem && extra="-bigmem"
-		uname -r | grep BOOT && extra="-BOOT"
-		file="$LINUX_DIR/configs/kernel-$version-$machine$extra.config"
-		AS_TRY_CONFIG_FILE([${file}], [CONFIG_FILE=${file}], )
+		echo $KERNEL_RELEASE | grep smp && EXTRA="-smp"
+		echo $KERNEL_RELEASE | grep bigmem && EXTRA="-bigmem"
+		echo $KERNEL_RELEASE | grep BOOT && EXTRA="-BOOT"
+		file="$LINUX_DIR/configs/kernel-$KVERSION-$LINUX_RPM_TARGET$EXTRA.config"
+		AS_TRY_LINUX_CONFIG($file, $MACHINE,
+		                    [LINUX_CONFIG=${file}], )
 	fi
-	if test "${CONFIG_FILE}" = "default" ; then
+	if test "${LINUX_CONFIG}" = "default" ; then
 		AC_MSG_ERROR([
 The kernel source tree at ${LINUX_DIR} is not configured,
 and no configuration files in config/ matching your kernel were found.
-Fix before continuing or specify a config file using --with-linux-config.])
+Fix before continuing or specify a config file using --with-configfile.])
 	fi
 
-	AC_SUBST(CONFIG_FILE)
+	AC_SUBST(LINUX_CONFIG)
 ])
 
 dnl check if the given candidate config file is usable
-AC_DEFUN([AS_TRY_CONFIG_FILE],
-	[AC_MSG_CHECKING(for configuration in $1)
+dnl FIXME: it would be nice if it could check if it matches the
+dnl given machine (uname -m)
+AC_DEFUN([AS_TRY_LINUX_CONFIG],
+[
+	CFG=[$1]
+	MACHINE=[$2]
+	AC_MSG_CHECKING($CFG)
 
-	if test -f "$1" ; then
+	if test -f "$CFG" ; then
 		result=yes
-		$2
+		ifelse([$3], , :, [$3])
 	else
 		result="not found"
-		$3
+		ifelse([$4], , :, [$4])
 	fi
-
 	AC_MSG_RESULT($result)
 ])
 
 dnl check if RED_HAT_LINUX_KERNEL is defined
-dnl RH/Fedora defines this in linux/rhconfig.h, included from linux/version.h
+dnl pre-FC2 RH/Fedora defines this in linux/rhconfig.h
+dnl included from linux/version.h
 dnl if this is present, a few extra defines need to be present to make sure
 dnl symbol versioning is correct
 dnl uses LINUX_DIR to find rhconfig.h
-AC_DEFUN([AS_CHECK_REDHAT],
+AC_DEFUN([AS_CHECK_REDHAT_PRE_FC2],
 [
-	AC_MSG_CHECKING(Red Hat/Fedora kernel)
+	AC_MSG_CHECKING(Pre-FC2 Red Hat/Fedora kernel)
         HAVE_REDHAT_KERNEL=false
         ac_save_CFLAGS="$CFLAGS"
         CFLAGS="$CFLAGS -I${LINUX_DIR}/include/linux"
@@ -185,7 +371,7 @@ int code = RED_HAT_LINUX_KERNEL;
 	HUGEMEM='0'
 
 	dnl get variables from the currently running kernel as default 
-	KERNEL_TYPE=`uname -r | sed 's_^.*\(smp\|enterprise\|bigmem\|hugemem\)$_-\1_;t;s_.*__;'`
+	KERNEL_TYPE=`uname -r | sed 's_^.*\(smp\|enterprise\|bigmem\|hugemem\)$_\1_;t;s_.*__;'`
 	KERNEL_RELEASE=`uname -r | sed 's|smp\|enterprise\|bigmem\|hugemem||g'`
 	KERNEL_ARCH=`uname -m`
 
@@ -198,18 +384,18 @@ int code = RED_HAT_LINUX_KERNEL;
         AS_CHECK_LINUX_CONFIG_OPTION(CONFIG_MK7, KERNEL_ARCH=athlon)
 
 	dnl check the config file and override KERNEL_TYPE
-        AS_CHECK_LINUX_CONFIG_OPTION(CONFIG_SMP, KERNEL_TYPE=-smp)
+        AS_CHECK_LINUX_CONFIG_OPTION(CONFIG_SMP, KERNEL_TYPE=smp)
 	dnl bigmem is also smp, so this check is done after smp to override
-        AS_CHECK_LINUX_CONFIG_OPTION(CONFIG_HIGHMEM64G, KERNEL_TYPE=-bigmem)
+        AS_CHECK_LINUX_CONFIG_OPTION(CONFIG_HIGHMEM64G, KERNEL_TYPE=bigmem)
 
 	dnl FIXME: need to check hugemem and enterprise config files, which
 	dnl aren't provided in Fedora Core 1 !
 
 	case "$KERNEL_TYPE" in
-		-smp) SMP='1';;
-		-enterprise) ENTERPRISE='1';;
-		-bigmem) BIGMEM='1';;
-		-hugemem) HUGEMEM='1';;
+		smp) SMP='1';;
+		enterprise) ENTERPRISE='1';;
+		bigmem) BIGMEM='1';;
+		hugemem) HUGEMEM='1';;
 		*) UP='1';;
 	esac
 	REDHAT_CFLAGS="-D__MODULE_KERNEL_$KERNEL_ARCH=1"
@@ -218,68 +404,48 @@ int code = RED_HAT_LINUX_KERNEL;
         REDHAT_CFLAGS="$REDHAT_CFLAGS -D__BOOT_KERNEL_SMP=$SMP"
         REDHAT_CFLAGS="$REDHAT_CFLAGS -D__BOOT_KERNEL_BIGMEM=$BIGMEM"
         REDHAT_CFLAGS="$REDHAT_CFLAGS -D__BOOT_KERNEL_HUGEMEM=$HUGEMEM"
-])
 
-dnl main entry point
-dnl checks the version, and figures out all flags to use to make modules.
-AC_DEFUN([AS_LINUX],
-[
-	AS_LINUX_DIR()
-        AS_CONFIG_FILE()
-	AS_CHECK_REDHAT()
+	LINUX_REDHAT_CFLAGS="$REDHAT_CFLAGS"
 
-	AC_MSG_CHECKING([Linux major/minor version])
+	AC_SUBST(LINUX_KERNEL_TYPE, "$KERNEL_TYPE")
+])
 
-	if [[ ! -f "${LINUX_DIR}/include/linux/version.h" ]];then
-		AC_MSG_ERROR([The header file include/linux/version.h does not exist.
-For 2.6 kernels, it can be generated by running 'make prepare' in
-the kernel source directory.])
+dnl add an argument to specify/override the module install path
+dnl if nothing specified, it will be /lib/modules/(kernelrel)
+AC_DEFUN([AS_LINUX_MODULESDIR],
+[
+	KERNEL_RELEASE=[$1]
+	AC_ARG_WITH([modulesdir],
+		[AC_HELP_STRING([--with-modulesdir=DIR],
+			[specify path to kernel-specific modules install directory])],
+		[MODULESDIR="${withval}"],
+		[MODULESDIR=default])
+
+	if test "${MODULESDIR}" = "default" ; then
+		MODULESDIR="/lib/modules/${KERNEL_RELEASE}"
 	fi
-        dnl the next set of tests is for figuring out version major/minor
-        dnl we make sure we have the right version.h by faking out CFLAGS
-        ac_save_CFLAGS="$CFLAGS"
-        CFLAGS="$CFLAGS -I${LINUX_DIR}/include/linux"
-        dnl make sure we find version.h and it contains LINUX_VERSION_CODE
-        AC_COMPILE_IFELSE(AC_LANG_PROGRAM([
-#include "version.h"
-int code = LINUX_VERSION_CODE;
-]),
- :, AC_MSG_ERROR([${LINUX_DIR}/include/linux/version.h does not contain LINUX_VERSION_CODE]))
-
-
-        dnl figure out the linux kernel version major and minor
-        dnl using the LINUX_VERSION_CODE defined in include/linux/version.h
-        AC_RUN_IFELSE(AC_LANG_PROGRAM([
-#include "version.h"
-#define KERNEL_VERSION_MAJOR(code) ((code) >> 16)
-],[
-  return KERNEL_VERSION_MAJOR(LINUX_VERSION_CODE);
-]),
-		LINUX_VERSION_MAJOR=0,
-		LINUX_VERSION_MAJOR=$?)
-        AC_RUN_IFELSE(AC_LANG_PROGRAM([
-#include "version.h"
-#define KERNEL_VERSION_MINOR(code) (((code) >> 8) & 0xff)
-],[
-  return KERNEL_VERSION_MINOR(LINUX_VERSION_CODE);
-]),
-		LINUX_VERSION_MINOR=0,
-		LINUX_VERSION_MINOR=$?)
-        AC_MSG_RESULT($LINUX_VERSION_MAJOR.$LINUX_VERSION_MINOR)
-	dnl restore CFLAGS
-        CFLAGS="$ac_save_CFLAGS"
+	dnl make it available to Makefiles so it can be used in ...dir
+	AC_SUBST(modulesdir, $MODULESDIR)
+	AC_MSG_NOTICE([Putting kernel modules under ${MODULESDIR}])
+])
 
-	case $LINUX_VERSION_MAJOR.$LINUX_VERSION_MINOR in
-		2.6)
-			AS_LINUX_2_6()
-			;;
-		2.[[01234]])
-			AS_LINUX_2_4()
-			;;
-		*)
-			AC_MSG_ERROR([Unknown Linux major.minor $LINUX_VERSION_MAJOR.$LINUX_VERSION_MINOR])
-			;;
-	esac
+dnl add an argument to specify/override the module devel install path
+dnl if nothing specified, it will be the passed in LINUXDIR)
+AC_DEFUN([AS_LINUX_MODULESDEVELDIR],
+[
+	LINUXDIR=[$1]
+	AC_ARG_WITH([modulesdeveldir],
+		[AC_HELP_STRING([--with-modulesdeveldir=DIR],
+			[specify path to kernel-specific module development install directory])],
+		[MODULESDEVELDIR="${withval}"],
+		[MODULESDEVELDIR=default])
+
+	if test "${MODULESDEVELDIR}" = "default" ; then
+		MODULESDEVELDIR="${LINUXDIR}"
+	fi
+	dnl make it available to Makefiles so it can be used in ...dir
+	AC_SUBST(modulesdeveldir, $MODULESDEVELDIR)
+	AC_MSG_NOTICE([Putting kernel module development files under ${MODULESDEVELDIR}])
 ])
 
 AC_DEFUN([AS_LINUX_2_6],
@@ -310,12 +476,12 @@ obj-m += fake.o
 .PHONY: flags
 flags:
 	echo LINUX_ARCH=\"\$(ARCH)\" >>\$(obj)/flags
-	echo LINUX_AFLAGS=\"\$(AFLAGS)\" | sed 's_Iinclude_I"\$(LINUXDIR)/include"_g'>>\$(obj)/flags
+	echo LINUX_AFLAGS=\"\$(AFLAGS)\" | sed 's,include,"\$(LINUXDIR)/include",g'>>\$(obj)/flags
 	echo LINUX_LDFLAGS=\"\" >>\$(obj)/flags
 	echo LINUX_ARFLAGS=\"\$(ARFLAGS)\" >>\$(obj)/flags
 	echo LINUX_CROSS_COMPILE=\"\$(CROSS_COMPILE)\" >>\$(obj)/flags
 	echo LINUX_KERNELRELEASE=\"\$(KERNELRELEASE)\" >>\$(obj)/flags
-	echo LINUX_CFLAGS=\"\$(CFLAGS)\" | sed 's_Iinclude_I"\$(LINUXDIR)/include"_g'>>\$(obj)/flags
+	echo LINUX_CFLAGS=\"\$(CFLAGS) \$(CPPFLAGS)\" | sed 's,Iinclude,I\$(LINUXDIR)/include,g' >>\$(obj)/flags
 	echo LINUX_CFLAGS_MODULE=\"\$(CFLAGS_MODULE)\" >>\$(obj)/flags
 	echo LINUX_CC=\"\$(CC)\" >>\$(obj)/flags
 	echo LINUX_LD=\"\$(LD) \$(LDFLAGS) \$(LDFLAGS_MODULE)\" >>\$(obj)/flags
@@ -330,6 +496,7 @@ EOF
 	LINUX_MODULE_EXT=".ko"
 
 	LINUX_CFLAGS="$LINUX_CFLAGS $LINUX_CFLAGS_MODULE"
+	LINUX_MODPOST="$LINUX_DIR/scripts/modpost"
 
 	AC_SUBST(LINUX_ARCH)
 	AC_SUBST(LINUX_AFLAGS)
@@ -342,8 +509,9 @@ EOF
 	AC_SUBST(LINUX_LD)
 	AC_SUBST(LINUX_AS)
 	AC_SUBST(LINUX_MODULE_EXT)
+	AC_SUBST(LINUX_MODPOST)
 
-	AC_MSG_RESULT([ok])
+	AC_MSG_RESULT([$LINUX_CFLAGS])
 ])
 
 
@@ -426,10 +594,10 @@ AC_DEFUN([AS_CHECK_LINUX_CONFIG_OPTION],
 [
 	AC_MSG_CHECKING([Linux config option $1])
 
-	if grep '^$1=y$' ${CONFIG_FILE} >/dev/null 2>/dev/null; then
+	if grep '^$1=y$' ${LINUX_CONFIG} >/dev/null 2>/dev/null; then
 		result=yes
 		$2
-	else if grep '^$1=m$' ${CONFIG_FILE} >/dev/null 2>/dev/null; then
+	else if grep '^$1=m$' ${LINUX_CONFIG} >/dev/null 2>/dev/null; then
 		result=module
 		$3
 	else
@@ -461,3 +629,56 @@ AC_DEFUN([AS_LINUX_CONFIG_OPTION_MODULE],
 	AM_CONDITIONAL([$1],[test "${$1}" = yes -o "${$1}" = module])
 ])
 
+dnl check for the major/minor version of the Linux source by checking
+dnl the headers
+dnl first argument is the linux directory
+dnl sets LINUX_VERSION_MAJOR and LINUX_VERSION_MINOR
+AC_DEFUN([AS_LINUX_VERSION_MAJOR_MINOR],
+[
+	LINUX_DIR=[$1]
+	AC_MSG_CHECKING([Linux major/minor version])
+
+	if [[ ! -f "${LINUX_DIR}/include/linux/version.h" ]];then
+		AC_MSG_ERROR([The header file include/linux/version.h does not exist.
+For 2.6 kernels, it can be generated by running 'make prepare' in
+the kernel source directory.])
+	fi
+        dnl the next set of tests is for figuring out version major/minor
+        dnl we make sure we have the right version.h by faking out CFLAGS
+	dnl since we want to avoid including linux/version.h and acidentally
+	dnl pick up /usr/include/linux
+	dnl we still add ${LINUX_DIR}/include so the Red Hat version can pick
+	dnl up linux/rhversion.h
+        ac_save_CFLAGS="$CFLAGS"
+        CFLAGS="$CFLAGS -I${LINUX_DIR}/include/linux -I${LINUX_DIR}/include"
+        dnl make sure we find version.h and it contains LINUX_VERSION_CODE
+        AC_COMPILE_IFELSE(AC_LANG_PROGRAM([
+#include "version.h"
+int code = LINUX_VERSION_CODE;
+]),
+ :, AC_MSG_ERROR([${LINUX_DIR}/include/linux/version.h does not contain LINUX_VERSION_CODE]))
+
+
+        dnl figure out the linux kernel version major and minor
+        dnl using the LINUX_VERSION_CODE defined in include/linux/version.h
+        AC_RUN_IFELSE(AC_LANG_PROGRAM([
+#include "version.h"
+#define KERNEL_VERSION_MAJOR(code) ((code) >> 16)
+],[
+  return KERNEL_VERSION_MAJOR(LINUX_VERSION_CODE);
+]),
+		LINUX_VERSION_MAJOR=0, 
+		LINUX_VERSION_MAJOR=$?)
+        AC_RUN_IFELSE(AC_LANG_PROGRAM([
+#include "version.h"
+#define KERNEL_VERSION_MINOR(code) (((code) >> 8) % (2 << 8))
+],[
+  return KERNEL_VERSION_MINOR(LINUX_VERSION_CODE);
+]),
+		LINUX_VERSION_MINOR=0, 
+		LINUX_VERSION_MINOR=$?)
+        AC_MSG_RESULT($LINUX_VERSION_MAJOR.$LINUX_VERSION_MINOR)
+	dnl restore CFLAGS
+        CFLAGS="$ac_save_CFLAGS"
+])
+
diff --git a/m4/as-modtool.m4 b/m4/as-modtool.m4
index 8ea64558..9c417b49 100644
--- a/m4/as-modtool.m4
+++ b/m4/as-modtool.m4
@@ -1,11 +1,13 @@
 dnl as-modtool.m4 0.0.1
 dnl autostars m4 macro for building modtool, a linker for Linux kernel
 dnl modules
-dnl
+
 dnl David Schleef <ds@schleef.org>
 dnl Frank Mori Hess <fmhess@users.sourceforge.net>
-dnl thomas@apestaart.org
-dnl
+dnl Thomas Vander Stichele <thomas@apestaart.org>
+
+dnl $Id$
+
 dnl AS_LINUX_MODTOOL()
 dnl
 dnl this macro defines:
@@ -21,11 +23,18 @@ dnl  How do you specify that the building of modtool should go to the
 dnl  end of the configure script?
 dnl
 
+dnl SYMVERS_INCLUDES can be used to add additional .symvers files to the
+dnl modpost step
+
 AC_DEFUN([AS_LINUX_MODTOOL],
 [
-	#AS_LINUX()
+	AC_PATH_PROG(STRIP, strip)
+	AC_PATH_PROG([DEPMOD], [depmod], [no], [$PATH:/sbin:/usr/sbin:/usr/local/sbin])
 
-	moduledir="\$(libdir)/modules/\$(LINUX_KERNELRELEASE)/comedi"
+	dnl this can be overridden in Makefile.am
+	dnl FIXME: it'd be nice if we could specify different target_PROGRAMS
+	dnl and different targetdir
+	moduledir="\$(modulesdir)/\$(PACKAGE)"
 	modulePROGRAMS_INSTALL="\$(top_builddir)/modtool --install"
 	modulePROGRAMS_UNINSTALL="\$(top_builddir)/modtool --uninstall"
 	AC_SUBST(moduledir)
@@ -35,19 +44,74 @@ AC_DEFUN([AS_LINUX_MODTOOL],
 	cat >modtool <<EOF
 #!/bin/sh
 
+set -e
+#set -x
+
 LINUX_LD="$LINUX_LD"
+LINUX_MODPOST="$LINUX_MODPOST"
 CC="$LINUX_CC"
 INSTALL="$INSTALL"
 LINUX_MODULE_EXT="$LINUX_MODULE_EXT"
 STRIP="$STRIP"
+CFLAGS="$CFLAGS $LINUX_CFLAGS"
+LINUX_DIR="$LINUX_DIR"
 
 mode=\$[1]
 shift
 
 case \$mode in
 --link)
-	echo \$LINUX_LD -r \$[*]
-	\$LINUX_LD -r \$[*]
+	# we accept -i (symvers) and -o (target) as options
+	# at least -o (target) needs to be specified
+	SYMVERS_INCLUDES=""
+	done=false
+	while test ! -z "\$[0]" -a "\$done" = "false"
+	do
+		case \$[1] in
+		-i)
+                        SYMVERS_INCLUDES="\$SYMVERS_INCLUDES \$[2]"
+                        shift 2
+                        ;;
+                -o)
+                        target=\$(echo \$[2] | sed s/.ko$//)
+                        shift 2
+                        ;;
+                *)
+                        done=true
+                        ;;
+                esac
+        done
+
+	if test "\$LINUX_MODULE_EXT" = .ko ; then
+		set -x
+		mkdir -p .mods
+
+		echo \$LINUX_LD -r -o .mods/\$target.o \$[*]
+		\$LINUX_LD -r -o .mods/\$target.o \$[*]
+
+		echo "cat \$LINUX_DIR/Module.symvers \$SYMVERS_INCLUDES >.mods/symvers.tmp"
+		cat \$LINUX_DIR/Module.symvers \$SYMVERS_INCLUDES >.mods/symvers.tmp
+
+		echo "\$LINUX_MODPOST -o .mods/\$target.o.symvers.tmp -i .mods/symvers.tmp \$target.o"
+		\$LINUX_MODPOST -o .mods/\$target.o.symvers.tmp -i .mods/symvers.tmp .mods/\$target.o
+
+		echo "grep .mods/\$target .mods/\$target.o.symvers.tmp >.mods/\$target.o.symvers || true"
+		grep .mods/\$target .mods/\$target.o.symvers.tmp >.mods/\$target.o.symvers || true
+
+		echo "rm -f .mods/\$target.o.symvers.tmp .mods/symvers.tmp"
+		rm -f .mods/\$target.o.symvers.tmp .mods/symvers.tmp
+		
+		echo \$CC \$CFLAGS -DKBUILD_MODNAME=\$target -c -o .mods/\$target.mod.o .mods/\$target.mod.c
+		\$CC \$CFLAGS -DKBUILD_MODNAME=\$target -c -o .mods/\$target.mod.o .mods/\$target.mod.c
+
+		echo \$LINUX_LD -r -o \$target.ko .mods/\$target.mod.o .mods/\$target.o
+		\$LINUX_LD -r -o \$target.ko .mods/\$target.mod.o .mods/\$target.o
+		set +x
+	else
+		echo \$LINUX_LD -r -o \$target.ko \$[*]
+		\$LINUX_LD -r -o \$target.ko \$[*]
+	fi
+
 	;;
 --install)
 	module_src=\$[1]
@@ -70,6 +134,7 @@ esac
 EOF
 	chmod +x modtool
 
+
 ])