From 65ea3cc37ea933ac9d3586ea3e9cf48248a20ef8 Mon Sep 17 00:00:00 2001 From: Florian Pose <fp@igh-essen.com> Date: Fri, 3 Nov 2006 14:18:05 +0000 Subject: [PATCH] Improved installation, added quick modules_install target. --- Makefile.am | 4 ++++ configure.ac | 27 +++++++++++++++++++++++---- devices/Makefile.am | 8 ++++---- examples/mini/Makefile.am | 8 ++++---- examples/msr/Makefile.am | 8 ++++---- examples/rtai/Makefile.am | 8 ++++---- master/Makefile.am | 8 ++++---- 7 files changed, 47 insertions(+), 24 deletions(-) diff --git a/Makefile.am b/Makefile.am index 08bbcb13..845ccfd6 100644 --- a/Makefile.am +++ b/Makefile.am @@ -43,6 +43,10 @@ EXTRA_DIST = \ globals.h \ LICENSE +modules_install: + $(MAKE) -C master modules_install + $(MAKE) -C devices modules_install + mydist: @SVNREV=`svnversion $(srcdir)` && \ $(MAKE) dist-bzip2 \ diff --git a/configure.ac b/configure.ac index a8f44673..b91f4fe8 100644 --- a/configure.ac +++ b/configure.ac @@ -36,7 +36,7 @@ AC_ARG_WITH([linux-dir], modulesdir=/lib/modules/${version} if test \! -d ${modulesdir} || test \! -d ${modulesdir}/build; then echo - AC_MSG_ERROR([Invalid modules directory ${modulesdir}]) + AC_MSG_ERROR([Failed to find Linux sources. Use --with-linux-dir!]) fi sourcedir=`cd ${modulesdir}/build && pwd -P` ] @@ -45,12 +45,31 @@ AC_ARG_WITH([linux-dir], AC_MSG_CHECKING([for Linux kernel sources]) if test \! -r ${sourcedir}/.config; then - echo - AC_MSG_ERROR([No configured Linux kernel sources in $sourcedir]) + echo + AC_MSG_ERROR([No configured Linux kernel sources in $sourcedir]) fi +# Try to get kernel release string +if test -r ${sourcedir}/.kernelrelease; then + kernelrelease=`cat $sourcedir/.kernelrelease` +elif test -r ${sourcedir}/include/linux/version.h; then + hdr=$sourcedir/include/linux/version.h + kernelrelease=`grep UTS_RELEASE $hdr | cut -d " " -f 3- | tr -d \"` +fi + +if test -z "$kernelrelease"; then + echo + AC_MSG_ERROR([Failed to extract Linux kernel version!]) +fi + +# Extract three numbers from kernel release string +linuxversion=`echo $kernelrelease | grep -oE [[0-9]]+\.[[0-9]]+\.[[0-9]]+` + AC_SUBST(LINUX_SOURCE_DIR,[$sourcedir]) -AC_MSG_RESULT($LINUX_SOURCE_DIR) +AC_SUBST(LINUX_KERNEL_RELEASE,[$kernelrelease]) +AC_SUBST(LINUX_KERNEL_VERSION,[$linuxversion]) +AC_SUBST(LINUX_MOD_PATH,[/lib/modules/$kernelrelease/ethercat]) +AC_MSG_RESULT([$LINUX_SOURCE_DIR (Kernel $LINUX_KERNEL_RELEASE)]) #------------------------------------------------------------------------------ # Debug interface diff --git a/devices/Makefile.am b/devices/Makefile.am index ecf7c497..23092016 100644 --- a/devices/Makefile.am +++ b/devices/Makefile.am @@ -45,9 +45,9 @@ all-local: clean-local: $(MAKE) -C "$(LINUX_SOURCE_DIR)" M="@abs_srcdir@" clean -install-data-local: - $(MAKE) -C "$(LINUX_SOURCE_DIR)" M="@abs_srcdir@" \ - INSTALL_MOD_PATH="$(DESTDIR)" \ - INSTALL_MOD_DIR="ethercat" modules_install +install-data-local: modules_install + +modules_install: + cp $(srcdir)/ec_8139too.ko $(DESTDIR)$(LINUX_MOD_PATH) #------------------------------------------------------------------------------ diff --git a/examples/mini/Makefile.am b/examples/mini/Makefile.am index 00c4a21d..3a6cec88 100644 --- a/examples/mini/Makefile.am +++ b/examples/mini/Makefile.am @@ -43,9 +43,9 @@ all: clean-local: $(MAKE) -C "$(LINUX_SOURCE_DIR)" M="@abs_srcdir@" clean -install-data-local: - $(MAKE) -C "$(LINUX_SOURCE_DIR)" M="@abs_srcdir@" \ - INSTALL_MOD_PATH="$(DESTDIR)" \ - INSTALL_MOD_DIR="ethercat" modules_install +install-data-local: modules_install + +modules_install: + cp $(srcdir)/ec_mini.ko $(DESTDIR)$(LINUX_MOD_PATH) #------------------------------------------------------------------------------ diff --git a/examples/msr/Makefile.am b/examples/msr/Makefile.am index 2e908a5d..2364dede 100644 --- a/examples/msr/Makefile.am +++ b/examples/msr/Makefile.am @@ -44,9 +44,9 @@ all: clean-local: $(MAKE) -C "$(LINUX_SOURCE_DIR)" M="@abs_srcdir@" clean -install-data-local: - $(MAKE) -C "$(LINUX_SOURCE_DIR)" M="@abs_srcdir@" \ - INSTALL_MOD_PATH="$(DESTDIR)" \ - INSTALL_MOD_DIR="ethercat" modules_install +install-data-local: modules_install + +modules_install: + cp $(srcdir)/ec_msr_sample.ko $(DESTDIR)$(LINUX_MOD_PATH) #------------------------------------------------------------------------------ diff --git a/examples/rtai/Makefile.am b/examples/rtai/Makefile.am index 93abbea1..6eb160e3 100644 --- a/examples/rtai/Makefile.am +++ b/examples/rtai/Makefile.am @@ -43,9 +43,9 @@ all: clean-local: $(MAKE) -C "$(LINUX_SOURCE_DIR)" M="@abs_srcdir@" clean -install-data-local: - $(MAKE) -C "$(LINUX_SOURCE_DIR)" M="@abs_srcdir@" \ - INSTALL_MOD_PATH="$(DESTDIR)" \ - INSTALL_MOD_DIR="ethercat" modules_install +install-data-local: modules_install + +modules_install: + cp $(srcdir)/ec_rtai_sample.ko $(DESTDIR)$(LINUX_MOD_PATH) #------------------------------------------------------------------------------ diff --git a/master/Makefile.am b/master/Makefile.am index ade86b55..b108a547 100644 --- a/master/Makefile.am +++ b/master/Makefile.am @@ -58,9 +58,9 @@ all-local: clean-local: $(MAKE) -C "$(LINUX_SOURCE_DIR)" M="@abs_srcdir@" clean -install-data-local: - $(MAKE) -C "$(LINUX_SOURCE_DIR)" M="@abs_srcdir@" \ - INSTALL_MOD_PATH="$(DESTDIR)" \ - INSTALL_MOD_DIR="ethercat" modules_install +install-data-local: modules_install + +modules_install: + cp $(srcdir)/ec_master.ko $(DESTDIR)$(LINUX_MOD_PATH) #------------------------------------------------------------------------------ -- GitLab