]> git.proxmox.com Git - mirror_iproute2.git/commitdiff
config: put CFLAGS/LDLIBS in config.mk
authorStephen Hemminger <stephen@networkplumber.org>
Fri, 11 Aug 2017 00:05:03 +0000 (17:05 -0700)
committerStephen Hemminger <stephen@networkplumber.org>
Wed, 23 Aug 2017 17:03:09 +0000 (10:03 -0700)
This renames Config to config.mk and includes more Make input.
Now configure generates all the required CFLAGS and LDLIBS for
the optional libraries.

Also, use pkg-config to test for libelf, rather than using a test
program. This makes it consistent with other libraries.

Signed-off-by: Stephen Hemminger <stephen@networkplumber.org>
14 files changed:
.gitignore
Makefile
README
bridge/Makefile
configure
devlink/Makefile
genl/Makefile
ip/Makefile
lib/Makefile
misc/Makefile
netem/Makefile
rdma/Makefile
tc/Makefile
tipc/Makefile

index c3b8d386450bfd28de0b736ab1b37d3f3f843c33..308aec6ba80bdc54de71ecaeea17d12c88d37861 100644 (file)
@@ -1,6 +1,5 @@
 static-syms.h
 config.*
-Config
 *.o
 *.a
 *.so
index dbb4a4afd608baebeb34cc32c8c836cebffaebe0..7a691dea2441771e848c7a67d060c0cc0f535876 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -54,12 +54,12 @@ SUBDIRS=lib ip tc bridge misc netem genl tipc devlink rdma man
 LIBNETLINK=../lib/libnetlink.a ../lib/libutil.a
 LDLIBS += $(LIBNETLINK)
 
-all: Config
+all: config.mk
        @set -e; \
        for i in $(SUBDIRS); \
        do echo; echo $$i; $(MAKE) $(MFLAGS) -C $$i; done
 
-Config:
+config.mk:
        sh configure $(KERNEL_INCLUDE)
 
 install: all
@@ -88,9 +88,9 @@ clean:
        do $(MAKE) $(MFLAGS) -C $$i clean; done
 
 clobber:
-       touch Config
+       touch config.mk
        $(MAKE) $(MFLAGS) clean
-       rm -f Config cscope.*
+       rm -f config.mk cscope.*
 
 distclean: clobber
 
diff --git a/README b/README
index c7a5118dd6d0704ef9aa405641aa5e4bf9c43d7a..386fbaf6cf7da63f53c2ebb9fa7c4312f246a80c 100644 (file)
--- a/README
+++ b/README
@@ -21,8 +21,9 @@ database routines.  Often this is in the db-devel package.
 
 2. make
 
-The makefile will automatically build a Config file which
-contains whether or not ATM is available, etc.
+The makefile will automatically build a config.mk file which
+contains definitions of libraries that may or may not be available
+on the system such as: ATM, ELF, MNL, and SELINUX.
 
 3. To make documentation, cd to doc/ directory , then
    look at start of Makefile and set correct values for
index fa448ea2e4fa83c268d84e1ee80adc9460ac6d08..b2ae0a4ed04d1380aff281b7e9b372d1092d6c04 100644 (file)
@@ -1,15 +1,6 @@
 BROBJ = bridge.o fdb.o monitor.o link.o mdb.o vlan.o
 
-include ../Config
-
-ifeq ($(IP_CONFIG_SETNS),y)
-       CFLAGS += -DHAVE_SETNS
-endif
-
-ifeq ($(HAVE_MNL),y)
-       CFLAGS += -DHAVE_LIBMNL $(shell $(PKG_CONFIG) libmnl --cflags)
-       LDLIBS += $(shell $(PKG_CONFIG) libmnl --libs)
-endif
+include ../config.mk
 
 all: bridge
 
index 88cbdb825689c1e257a656141ff89caf792215df..7be8fb113cc98cb8e006393f1c61be00875e6cb2 100755 (executable)
--- a/configure
+++ b/configure
@@ -3,6 +3,9 @@
 #
 INCLUDE=${1:-"$PWD/include"}
 
+# Output file which is input to Makefile
+CONFIG=config.mk
+
 # Make a temp directory in build tree.
 TMPDIR=$(mktemp -d config.XXXXXX)
 trap 'status=$?; rm -rf $TMPDIR; exit $status' EXIT HUP INT QUIT TERM
@@ -10,7 +13,7 @@ trap 'status=$?; rm -rf $TMPDIR; exit $status' EXIT HUP INT QUIT TERM
 check_prog()
 {
     echo -n "$2"
-    command -v $1 >/dev/null 2>&1 && (echo "$3:=y" >> Config; echo "yes") || (echo "no"; return 1)
+    command -v $1 >/dev/null 2>&1 && (echo "$3:=y" >> $CONFIG; echo "yes") || (echo "no"; return 1)
 }
 
 check_docs()
@@ -30,9 +33,9 @@ check_toolchain()
     : ${PKG_CONFIG:=pkg-config}
     : ${AR=ar}
     : ${CC=gcc}
-    echo "PKG_CONFIG:=${PKG_CONFIG}" >>Config
-    echo "AR:=${AR}" >>Config
-    echo "CC:=${CC}" >>Config
+    echo "PKG_CONFIG:=${PKG_CONFIG}" >>$CONFIG
+    echo "AR:=${AR}" >>$CONFIG
+    echo "CC:=${CC}" >>$CONFIG
 }
 
 check_atm()
@@ -49,7 +52,7 @@ EOF
     $CC -I$INCLUDE -o $TMPDIR/atmtest $TMPDIR/atmtest.c -latm >/dev/null 2>&1
     if [ $? -eq 0 ]
     then
-       echo "TC_CONFIG_ATM:=y" >>Config
+       echo "TC_CONFIG_ATM:=y" >>$CONFIG
        echo yes
     else
        echo no
@@ -61,7 +64,7 @@ check_xtables()
 {
        if ! ${PKG_CONFIG} xtables --exists
        then
-               echo "TC_CONFIG_NO_XT:=y" >>Config
+               echo "TC_CONFIG_NO_XT:=y" >>$CONFIG
        fi
 }
 
@@ -90,7 +93,7 @@ EOF
     if $CC -I$INCLUDE $IPTC -o $TMPDIR/ipttest $TMPDIR/ipttest.c $IPTL \
        $(${PKG_CONFIG} xtables --cflags --libs) -ldl >/dev/null 2>&1
     then
-       echo "TC_CONFIG_XT:=y" >>Config
+       echo "TC_CONFIG_XT:=y" >>$CONFIG
        echo "using xtables"
     fi
     rm -f $TMPDIR/ipttest.c $TMPDIR/ipttest
@@ -99,7 +102,7 @@ EOF
 check_xt_old()
 {
     # bail if previous XT checks has already succeded.
-    if grep -q TC_CONFIG_XT Config
+    if grep -q TC_CONFIG_XT $CONFIG
     then
        return
     fi
@@ -129,7 +132,7 @@ EOF
     $CC -I$INCLUDE $IPTC -o $TMPDIR/ipttest $TMPDIR/ipttest.c $IPTL -ldl >/dev/null 2>&1
     if [ $? -eq 0 ]
     then
-       echo "TC_CONFIG_XT_OLD:=y" >>Config
+       echo "TC_CONFIG_XT_OLD:=y" >>$CONFIG
        echo "using old xtables (no need for xt-internal.h)"
     fi
     rm -f $TMPDIR/ipttest.c $TMPDIR/ipttest
@@ -138,7 +141,7 @@ EOF
 check_xt_old_internal_h()
 {
     # bail if previous XT checks has already succeded.
-    if grep -q TC_CONFIG_XT Config
+    if grep -q TC_CONFIG_XT $CONFIG
     then
        return
     fi
@@ -170,14 +173,14 @@ EOF
        if [ $? -eq 0 ]
        then
            echo "using old xtables with xt-internal.h"
-           echo "TC_CONFIG_XT_OLD_H:=y" >>Config
+           echo "TC_CONFIG_XT_OLD_H:=y" >>$CONFIG
        fi
        rm -f $TMPDIR/ipttest.c $TMPDIR/ipttest
 }
 
 check_ipt()
 {
-       if ! grep TC_CONFIG_XT Config > /dev/null
+       if ! grep TC_CONFIG_XT $CONFIG > /dev/null
        then
                echo "using iptables"
        fi
@@ -188,7 +191,7 @@ check_ipt_lib_dir()
        IPT_LIB_DIR=$(${PKG_CONFIG} --variable=xtlibdir xtables)
        if [ -n "$IPT_LIB_DIR" ]; then
                echo $IPT_LIB_DIR
-               echo "IPT_LIB_DIR:=$IPT_LIB_DIR" >> Config
+               echo "IPT_LIB_DIR:=$IPT_LIB_DIR" >> $CONFIG
                return
        fi
 
@@ -197,7 +200,7 @@ check_ipt_lib_dir()
                for file in $dir/{xtables,iptables}/lib*t_*so ; do
                        if [ -f $file ]; then
                                echo ${file%/*}
-                               echo "IPT_LIB_DIR:=${file%/*}" >> Config
+                               echo "IPT_LIB_DIR:=${file%/*}" >> $CONFIG
                                return
                        fi
                done
@@ -218,8 +221,9 @@ EOF
     $CC -I$INCLUDE -o $TMPDIR/setnstest $TMPDIR/setnstest.c >/dev/null 2>&1
     if [ $? -eq 0 ]
     then
-       echo "IP_CONFIG_SETNS:=y" >>Config
+       echo "IP_CONFIG_SETNS:=y" >>$CONFIG
        echo "yes"
+       echo "CFLAGS += -DHAVE_SETNS" >>$CONFIG
     else
        echo "no"
     fi
@@ -249,7 +253,7 @@ EOF
 
     if $CC -I$INCLUDE -o $TMPDIR/ipsettest $TMPDIR/ipsettest.c >/dev/null 2>&1
     then
-       echo "TC_CONFIG_IPSET:=y" >>Config
+       echo "TC_CONFIG_IPSET:=y" >>$CONFIG
        echo "yes"
     else
        echo "no"
@@ -259,25 +263,16 @@ EOF
 
 check_elf()
 {
-    cat >$TMPDIR/elftest.c <<EOF
-#include <libelf.h>
-#include <gelf.h>
-int main(void)
-{
-       Elf_Scn *scn __attribute__((__unused__));
-       GElf_Shdr shdr  __attribute__((__unused__));;
-       return elf_version(EV_CURRENT);
-}
-EOF
-
-    if $CC -I$INCLUDE -o $TMPDIR/elftest $TMPDIR/elftest.c -lelf >/dev/null 2>&1
+    if ${PKG_CONFIG} libelf --exists
     then
-       echo "HAVE_ELF:=y" >>Config
+       echo "HAVE_ELF:=y" >>$CONFIG
        echo "yes"
+
+       echo 'CFLAGS += -DHAVE_ELF' `${PKG_CONFIG} libelf --cflags` >> $CONFIG
+       echo 'LDLIBS += ' `${PKG_CONFIG} libelf --libs` >>$CONFIG
     else
        echo "no"
     fi
-    rm -f $TMPDIR/elftest.c $TMPDIR/elftest
 }
 
 check_selinux()
@@ -285,8 +280,11 @@ check_selinux()
 {
        if ${PKG_CONFIG} libselinux --exists
        then
-               echo "HAVE_SELINUX:=y" >>Config
+               echo "HAVE_SELINUX:=y" >>$CONFIG
                echo "yes"
+
+               echo 'LDLIBS +=' `${PKG_CONFIG} --libs libselinux` >>$CONFIG
+               echo 'CFLAGS += -DHAVE_SELINUX' `${PKG_CONFIG} --cflags libselinux` >>$CONFIG
        else
                echo "no"
        fi
@@ -296,8 +294,11 @@ check_mnl()
 {
        if ${PKG_CONFIG} libmnl --exists
        then
-               echo "HAVE_MNL:=y" >>Config
+               echo "HAVE_MNL:=y" >>$CONFIG
                echo "yes"
+
+               echo 'CFLAGS += -DHAVE_LIBMNL' `${PKG_CONFIG} libmnl --cflags` >>$CONFIG
+               echo 'LDLIBS +=' `${PKG_CONFIG} libmnl --libs` >> $CONFIG
        else
                echo "no"
        fi
@@ -317,7 +318,7 @@ EOF
     $CC -I$INCLUDE -o $TMPDIR/dbtest $TMPDIR/dbtest.c -ldb >/dev/null 2>&1
     if [ $? -eq 0 ]
     then
-       echo "HAVE_BERKELEY_DB:=y" >>Config
+       echo "HAVE_BERKELEY_DB:=y" >>$CONFIG
        echo "yes"
     else
        echo "no"
@@ -351,8 +352,8 @@ endif
 EOF
 }
 
-echo "# Generated config based on" $INCLUDE >Config
-quiet_config >> Config
+echo "# Generated config based on" $INCLUDE >$CONFIG
+quiet_config >> $CONFIG
 
 check_toolchain
 
@@ -362,7 +363,7 @@ echo -n " ATM       "
 check_atm
 
 check_xtables
-if ! grep -q TC_CONFIG_NO_XT Config
+if ! grep -q TC_CONFIG_NO_XT $CONFIG
 then
        echo -n " IPT   "
        check_xt
@@ -375,7 +376,7 @@ then
 fi
 
 echo
-if ! grep -q TC_CONFIG_NO_XT Config
+if ! grep -q TC_CONFIG_NO_XT $CONFIG
 then
        echo -n "iptables modules directory: "
        check_ipt_lib_dir
@@ -401,6 +402,6 @@ echo -n "docs:"
 check_docs
 echo
 
-echo >> Config
-echo "%.o: %.c" >> Config
-echo ' $(QUIET_CC)$(CC) $(CFLAGS) $(EXTRA_CFLAGS) -c -o $@ $<' >> Config
+echo >> $CONFIG
+echo "%.o: %.c" >> $CONFIG
+echo ' $(QUIET_CC)$(CC) $(CFLAGS) $(EXTRA_CFLAGS) -c -o $@ $<' >> $CONFIG
index 7256c28708eb2dac2278ce5181c96074618ea958..3b2067d6658ccadbce09b031bac970c40c241c5d 100644 (file)
@@ -1,4 +1,5 @@
-include ../Config
+include ../config.mk
+
 ifeq ($(HAVE_MNL),y)
 
 DEVLINKOBJ = devlink.o mnlg.o
index f0efe1ac66473a9f501c1e1a9fc97e3992dd405f..de1635e498ad1160bae56b9e760946122ab1c514 100644 (file)
@@ -1,6 +1,6 @@
 GENLOBJ=genl.o
 
-include ../Config
+include ../config.mk
 SHARED_LIBS ?= y
 
 CFLAGS += -fno-strict-aliasing
@@ -17,11 +17,6 @@ LDFLAGS += -Wl,-export-dynamic
 LDLIBS  += -lm -ldl
 endif
 
-ifeq ($(HAVE_MNL),y)
-       CFLAGS += -DHAVE_LIBMNL $(shell $(PKG_CONFIG) libmnl --cflags)
-       LDLIBS += $(shell $(PKG_CONFIG) libmnl --libs)
-endif
-
 all: genl
 
 genl: $(GENLOBJ) $(LIBNETLINK) $(LIBUTIL) $(GENLLIB)
index 8ed2686c63d1d649202bd07683922d798855256d..52c9a2e53c5640f2d4459bb35147105cdf34a508 100644 (file)
@@ -13,20 +13,7 @@ IPOBJ=ip.o ipaddress.o ipaddrlabel.o iproute.o iprule.o ipnetns.o \
 
 RTMONOBJ=rtmon.o
 
-include ../Config
-
-ifeq ($(IP_CONFIG_SETNS),y)
-       CFLAGS += -DHAVE_SETNS
-endif
-
-ifeq ($(HAVE_ELF),y)
-       CFLAGS += -DHAVE_ELF
-       LDLIBS += -lelf
-endif
-ifeq ($(HAVE_MNL),y)
-       CFLAGS += -DHAVE_LIBMNL $(shell $(PKG_CONFIG) libmnl --cflags)
-       LDLIBS += $(shell $(PKG_CONFIG) libmnl --libs)
-endif
+include ../config.mk
 
 ALLOBJ=$(IPOBJ) $(RTMONOBJ)
 SCRIPTS=ifcfg rtpr routel routef
index b7b1d5685b943051ba1e46027d9c5e7d43c0de23..5e9f72facd36f4ba50d5717b57bc2c002da9873a 100644 (file)
@@ -1,16 +1,4 @@
-include ../Config
-
-ifeq ($(IP_CONFIG_SETNS),y)
-       CFLAGS += -DHAVE_SETNS
-endif
-
-ifeq ($(HAVE_ELF),y)
-       CFLAGS += -DHAVE_ELF
-endif
-
-ifeq ($(HAVE_MNL),y)
-       CFLAGS += -DHAVE_LIBMNL $(shell $(PKG_CONFIG) libmnl --cflags)
-endif
+include ../config.mk
 
 CFLAGS += -fPIC
 
index fa90308e4848ed3e2f57713376b3da759e6b6e57..d02616e3482af3dba9bd8bcd07958604364d0b7c 100644 (file)
@@ -3,26 +3,12 @@ LNSTATOBJ=lnstat.o lnstat_util.o
 
 TARGETS=ss nstat ifstat rtacct lnstat
 
-include ../Config
+include ../config.mk
 
 ifeq ($(HAVE_BERKELEY_DB),y)
        TARGETS += arpd
 endif
 
-ifeq ($(HAVE_SELINUX),y)
-       LDLIBS += $(shell $(PKG_CONFIG) --libs libselinux)
-       CFLAGS += $(shell $(PKG_CONFIG) --cflags libselinux) -DHAVE_SELINUX
-endif
-
-ifeq ($(IP_CONFIG_SETNS),y)
-       CFLAGS += -DHAVE_SETNS
-endif
-
-ifeq ($(HAVE_MNL),y)
-       CFLAGS += -DHAVE_LIBMNL $(shell $(PKG_CONFIG) libmnl --cflags)
-       LDLIBS += $(shell $(PKG_CONFIG) libmnl --libs)
-endif
-
 all: $(TARGETS)
 
 ss: $(SSOBJ)
index 2499f086f24d524746044053eee61ca34000c6d3..434185273f64ca29e4ee7e68fb2f8509e5ce7ec9 100644 (file)
@@ -1,4 +1,4 @@
-include ../Config
+include ../config.mk
 
 DISTGEN = maketable normal pareto paretonormal
 DISTDATA = normal.dist pareto.dist paretonormal.dist experimental.dist
@@ -7,11 +7,6 @@ HOSTCC ?= $(CC)
 CCOPTS  = $(CBUILD_CFLAGS)
 LDLIBS += -lm
 
-ifeq ($(HAVE_MNL),y)
-       CFLAGS += -DHAVE_LIBMNL $(shell $(PKG_CONFIG) libmnl --cflags)
-       LDLIBS += $(shell $(PKG_CONFIG) libmnl --libs)
-endif
-
 all: $(DISTGEN) $(DISTDATA)
 
 $(DISTGEN):
index 1a9e4b1a93011b739a6ce0263899916f5fb45357..1b5aa50b2cb8e9b78153d54c3021466879a77cf4 100644 (file)
@@ -1,13 +1,10 @@
-include ../Config
+include ../config.mk
 
 ifeq ($(HAVE_MNL),y)
 
 RDMA_OBJ = rdma.o utils.o dev.o link.o
 
 TARGETS=rdma
-CFLAGS += $(shell $(PKG_CONFIG) libmnl --cflags)
-LDLIBS += $(shell $(PKG_CONFIG) libmnl --libs)
-
 endif
 
 all:   $(TARGETS) $(LIBS)
index a9b4b8e60dacbc27b85dc74eeb54ceab8cf2c368..777de5e6da76652c4dfd80d4c18f772f36db2574 100644 (file)
@@ -2,11 +2,7 @@ TCOBJ= tc.o tc_qdisc.o tc_class.o tc_filter.o tc_util.o tc_monitor.o \
        tc_exec.o m_police.o m_estimator.o m_action.o m_ematch.o \
        emp_ematch.yacc.o emp_ematch.lex.o
 
-include ../Config
-
-ifeq ($(IP_CONFIG_SETNS),y)
-       CFLAGS += -DHAVE_SETNS
-endif
+include ../config.mk
 
 SHARED_LIBS ?= y
 
@@ -102,15 +98,6 @@ endif
 TCOBJ += $(TCMODULES)
 LDLIBS += -L. -lm
 
-ifeq ($(HAVE_ELF),y)
-       CFLAGS += -DHAVE_ELF
-       LDLIBS += -lelf
-endif
-ifeq ($(HAVE_MNL),y)
-       CFLAGS += -DHAVE_LIBMNL $(shell $(PKG_CONFIG) libmnl --cflags)
-       LDLIBS += $(shell $(PKG_CONFIG) libmnl --libs)
-endif
-
 ifeq ($(SHARED_LIBS),y)
 LDLIBS += -ldl
 LDFLAGS += -Wl,-export-dynamic
index 87e3cac3756f2c92c32e8138db06d972cafb3a9f..2212beb06534ac77373549d18e247bc0a6629ffa 100644 (file)
@@ -1,4 +1,5 @@
-include ../Config
+include ../config.mk
+
 ifeq ($(HAVE_MNL),y)
 
 TIPCOBJ=bearer.o \
@@ -8,8 +9,6 @@ TIPCOBJ=bearer.o \
     node.o socket.o \
     peer.o tipc.o
 
-include ../Config
-
 TARGETS=tipc
 CFLAGS += $(shell $(PKG_CONFIG) libmnl --cflags)
 LDLIBS += $(shell $(PKG_CONFIG) libmnl --libs)