]> git.droids-corp.org - dpdk.git/commitdiff
mk: generate internal library dependencies
authorPanu Matilainen <pmatilai@redhat.com>
Tue, 7 Jun 2016 10:01:54 +0000 (13:01 +0300)
committerThomas Monjalon <thomas.monjalon@6wind.com>
Thu, 9 Jun 2016 09:30:46 +0000 (11:30 +0200)
Up to now dependencies between DPDK internal libraries have been
untracked at shared library level, requiring applications to know
about library internal dependencies and often consequently overlinking.

Since the dependencies are already recorded for build ordering in the
makefiles with DEPDIRS-y we can use that information to generate LDLIBS
entries for internal libraries automatically.

Also revert commit 8180554d82b3 ("vhost: fix linkage of driver with
library") which is made redundant by this change.

Signed-off-by: Panu Matilainen <pmatilai@redhat.com>
Acked-by: Christian Ehrhardt <christian.ehrhardt@canonical.com>
drivers/net/vhost/Makefile
mk/rte.lib.mk

index 30b91a066e18ad0b69cf46fcbdad7f6c825dd597..f49a69b3bdecbb254803e4d13497d0a9312206b3 100644 (file)
@@ -38,7 +38,6 @@ LIB = librte_pmd_vhost.a
 
 CFLAGS += -O3
 CFLAGS += $(WERROR_FLAGS)
-LDLIBS += -lrte_vhost
 
 EXPORT_MAP := rte_pmd_vhost_version.map
 
index b420280d9e5676ba57d89d64a863d0a8190c2ebb..1ff403f5ef3aed2cf4f70b18fe87806600428399 100644 (file)
@@ -77,6 +77,13 @@ else
 _CPU_LDFLAGS := $(CPU_LDFLAGS)
 endif
 
+# Translate DEPDIRS-y into LDLIBS
+# Ignore (sub)directory dependencies which do not provide an actual library
+_IGNORE_DIRS = lib/librte_eal/% lib/librte_net lib/librte_compat
+_DEPDIRS = $(filter-out $(_IGNORE_DIRS),$(DEPDIRS-y))
+_LDDIRS = $(subst librte_ether,libethdev,$(_DEPDIRS))
+LDLIBS += $(subst lib/lib,-l,$(_LDDIRS))
+
 O_TO_A = $(AR) crDs $(LIB) $(OBJS-y)
 O_TO_A_STR = $(subst ','\'',$(O_TO_A)) #'# fix syntax highlight
 O_TO_A_DISP = $(if $(V),"$(O_TO_A_STR)","  AR $(@)")