X-Git-Url: https://git.whamcloud.com/?p=fs%2Flustre-release.git;a=blobdiff_plain;f=build%2Fautoconf%2Flustre-build-linux.m4;h=c71b9ac46c31bfac128cd92a7921aa0b606febcc;hp=840dc225655a5397e4d1ae57ea1ec3555d4896f9;hb=fd0bd149e66cbc06a17c372e159f9bfba024cc97;hpb=fea8d73ca26e491d311e0644b0f14fc31573d835 diff --git a/build/autoconf/lustre-build-linux.m4 b/build/autoconf/lustre-build-linux.m4 index 840dc22..c71b9ac 100644 --- a/build/autoconf/lustre-build-linux.m4 +++ b/build/autoconf/lustre-build-linux.m4 @@ -84,7 +84,7 @@ fi AC_MSG_RESULT([$LINUXRELEASE]) AC_SUBST(LINUXRELEASE) -moduledir='/lib/modules/'$LINUXRELEASE/kernel +moduledir='/lib/modules/'$LINUXRELEASE/updates/kernel AC_SUBST(moduledir) modulefsdir='$(moduledir)/fs/$(PACKAGE)' @@ -95,7 +95,15 @@ AC_SUBST(modulenetdir) # ------------ RELEASE -------------------------------- AC_MSG_CHECKING([for Lustre release]) -RELEASE="`echo ${LINUXRELEASE} | tr '-' '_'`_`date +%Y%m%d%H%M`" +AC_ARG_WITH([release], + AC_HELP_STRING([--with-release=string], + [set the release string (default=$kvers_YYYYMMDDhhmm)]), + [RELEASE=$withval], + RELEASE="" + if test -n "$DOWNSTREAM_RELEASE"; then + RELEASE="${DOWNSTREAM_RELEASE}_" + fi + RELEASE="$RELEASE`echo ${LINUXRELEASE} | tr '-' '_'`_$BUILDID") AC_MSG_RESULT($RELEASE) AC_SUBST(RELEASE) @@ -119,6 +127,39 @@ LB_LINUX_CONFIG([SUSE_KERNEL],[SUSE_KERNEL="yes"],[]) ]) +# LB_ARG_REPLACE_PATH(PACKAGE, PATH) +AC_DEFUN([LB_ARG_REPLACE_PATH],[ + new_configure_args= + eval "set x $ac_configure_args" + shift + for arg; do + case $arg in + --with-[$1]=*) + arg=--with-[$1]=[$2] + ;; + *\'*) + arg=$(printf %s\n ["$arg"] | \ + sed "s/'/'\\\\\\\\''/g") + ;; + esac + dnl AS_VAR_APPEND([new_configure_args], [" '$arg'"]) + new_configure_args="$new_configure_args \"$arg\"" + done + ac_configure_args=$new_configure_args +]) + +# this is the work-horse of the next function +AC_DEFUN([__LB_ARG_CANON_PATH], [ + [$3]=$(readlink -f $with_$2) + LB_ARG_REPLACE_PATH([$1], $[$3]) +]) + +# a front-end for the above function that transforms - and . in the +# PACKAGE portion of --with-PACKAGE into _ suitable for variable names +AC_DEFUN([LB_ARG_CANON_PATH], [ + __LB_ARG_CANON_PATH([$1], m4_translit([$1], [-.], [__]), [$2]) +]) + # # # LB_LINUX_PATH @@ -126,18 +167,28 @@ LB_LINUX_CONFIG([SUSE_KERNEL],[SUSE_KERNEL="yes"],[]) # Find paths for linux, handling kernel-source rpms # AC_DEFUN([LB_LINUX_PATH], -[AC_MSG_CHECKING([for Linux sources]) +[# prep some default values +for DEFAULT_LINUX in /lib/modules/$(uname -r)/{source,build} /usr/src/linux; do + if readlink -q -e $DEFAULT_LINUX; then + break + fi +done +if test "$DEFAULT_LINUX" = "/lib/modules/$(uname -r)/source"; then + PATHS="/lib/modules/$(uname -r)/build" +fi +PATHS+="$DEFAULT_LINUX" +for DEFAULT_LINUX_OBJ in $PATHS; do + if readlink -q -e $DEFAULT_LINUX_OBJ; then + break + fi +done +AC_MSG_CHECKING([for Linux sources]) AC_ARG_WITH([linux], AC_HELP_STRING([--with-linux=path], - [set path to Linux source (default=/usr/src/linux)]), - [ - if ! [[[ $with_linux = /* ]]]; then - AC_MSG_ERROR([You must provide an absolute pathname to the --with-linux= option.]) - else - LINUX=$with_linux - fi - ], - [LINUX=/usr/src/linux]) + [set path to Linux source (default=/lib/modules/$(uname -r)/{source,build},/usr/src/linux)]), + [LB_ARG_CANON_PATH([linux], [LINUX]) + DEFAULT_LINUX_OBJ=$LINUX], + [LINUX=$DEFAULT_LINUX]) AC_MSG_RESULT([$LINUX]) AC_SUBST(LINUX) @@ -149,9 +200,10 @@ LB_CHECK_FILE([$LINUX],[], AC_MSG_CHECKING([for Linux objects dir]) AC_ARG_WITH([linux-obj], AC_HELP_STRING([--with-linux-obj=path], - [set path to Linux objects dir (default=$LINUX)]), - [LINUX_OBJ=$with_linux_obj], - [LINUX_OBJ=$LINUX]) + [set path to Linux objects dir (default=/lib/modules/$(uname -r)/build,/usr/src/linux)]), + [LB_ARG_CANON_PATH([linux-obj], [LINUX_OBJ])], + [LINUX_OBJ=$DEFAULT_LINUX_OBJ]) + AC_MSG_RESULT([$LINUX_OBJ]) AC_SUBST(LINUX_OBJ) @@ -159,7 +211,7 @@ AC_SUBST(LINUX_OBJ) AC_ARG_WITH([linux-config], [AC_HELP_STRING([--with-linux-config=path], [set path to Linux .conf (default=$LINUX_OBJ/.config)])], - [LINUX_CONFIG=$with_linux_config], + [LB_ARG_CANON_PATH([linux-config], [LINUX_CONFIG])], [LINUX_CONFIG=$LINUX_OBJ/.config]) AC_SUBST(LINUX_CONFIG) @@ -171,7 +223,7 @@ LB_CHECK_FILE([/boot/kernel.h], AC_ARG_WITH([kernel-source-header], AC_HELP_STRING([--with-kernel-source-header=path], [Use a different kernel version header. Consult build/README.kernel-source for details.]), - [KERNEL_SOURCE_HEADER=$with_kernel_source_header]) + [LB_ARG_CANON_PATH([kernel-source-header], [KERNEL_SOURCE_HEADER])]) # ------------ .config exists ---------------- LB_CHECK_FILE([$LINUX_CONFIG],[], @@ -306,18 +358,6 @@ AC_SUBST(UML_CFLAGS) # these are like AC_TRY_COMPILE, but try to build modules against the # kernel, inside the build directory -# -# LB_LINUX_CONFTEST -# -# create a conftest.c file -# -AC_DEFUN([LB_LINUX_CONFTEST], -[cat >conftest.c <<_ACEOF -$1 -_ACEOF -]) - - # LB_LANG_PROGRAM(C)([PROLOGUE], [BODY]) # -------------------------------------- m4_define([LB_LANG_PROGRAM], @@ -338,7 +378,7 @@ $2 # like AC_COMPILE_IFELSE # AC_DEFUN([LB_LINUX_COMPILE_IFELSE], -[m4_ifvaln([$1], [LB_LINUX_CONFTEST([$1])])dnl +[m4_ifvaln([$1], [AC_LANG_CONFTEST([$1])])dnl rm -f build/conftest.o build/conftest.mod.c build/conftest.ko AS_IF([AC_TRY_COMMAND(cp conftest.c build && make -d [$2] ${LD:+"LD=$LD"} CC="$CC" -f $PWD/build/Makefile LUSTRE_LINUX_CONFIG=$LINUX_CONFIG LINUXINCLUDE="$EXTRA_LNET_INCLUDE -I$LINUX/arch/`uname -m|sed -e 's/ppc.*/powerpc/' -e 's/x86_64/x86/' -e 's/i.86/x86/'`/include -I$LINUX/include -I$LINUX_OBJ/include -I$LINUX_OBJ/include2 -include include/linux/autoconf.h" -o tmp_include_depends -o scripts -o include/config/MARKER -C $LINUX_OBJ EXTRA_CFLAGS="-Werror-implicit-function-declaration $EXTRA_KCFLAGS" $ARCH_UM $MODULE_TARGET=$PWD/build) >/dev/null && AC_TRY_COMMAND([$3])], [$4], @@ -502,7 +542,7 @@ else . $O2IBPATH/ofed_patch.mk fi if test -n "$BACKPORT_INCLUDES"; then - OFED_BACKPORT_PATH=`echo $BACKPORT_INCLUDES | sed "s#.*/src/ofa_kernel/#$O2IBPATH/#"` + OFED_BACKPORT_PATH="$O2IBPATH/${BACKPORT_INCLUDES/*\/kernel_addons/kernel_addons}/" EXTRA_LNET_INCLUDE="-I$OFED_BACKPORT_PATH $EXTRA_LNET_INCLUDE" AC_MSG_RESULT([yes]) else