build: add dependency on telemetry to apps with meson
authorKevin Laatz <kevin.laatz@intel.com>
Sat, 27 Oct 2018 09:17:50 +0000 (10:17 +0100)
committerThomas Monjalon <thomas@monjalon.net>
Sat, 27 Oct 2018 13:21:33 +0000 (15:21 +0200)
This patch adds telemetry as a dependecy to all applications. Without these
changes, the --telemetry flag will not be recognised and applications will
fail to run if they want to enable telemetry.

Signed-off-by: Bruce Richardson <bruce.richardson@intel.com>
Signed-off-by: Kevin Laatz <kevin.laatz@intel.com>
Signed-off-by: Radu Nicolau <radu.nicolau@intel.com>
Acked-by: Harry van Haaren <harry.van.haaren@intel.com>
app/meson.build
app/pdump/meson.build
app/proc-info/meson.build
app/test-bbdev/meson.build
app/test-crypto-perf/meson.build
app/test-pmd/meson.build
config/meson.build
lib/librte_telemetry/meson.build
lib/meson.build
meson.build

index e68d949..a9a026b 100644 (file)
@@ -29,7 +29,7 @@ foreach app:apps
        # use "deps" for internal DPDK dependencies, and "ext_deps" for
        # external package/library requirements
        ext_deps = []
-       deps = []
+       deps = dpdk_app_link_libraries
 
        subdir(name)
 
@@ -43,7 +43,7 @@ foreach app:apps
 
                link_libs = []
                if get_option('default_library') == 'static'
-                       link_libs = dpdk_drivers
+                       link_libs = dpdk_static_libraries + dpdk_drivers
                endif
 
                if allow_experimental_apis
index 988cb4e..116c27f 100644 (file)
@@ -3,4 +3,4 @@
 
 sources = files('main.c')
 allow_experimental_apis = true
-deps = ['ethdev', 'kvargs', 'pdump']
+deps += ['ethdev', 'kvargs', 'pdump']
index 9c148e3..a52b2ee 100644 (file)
@@ -3,4 +3,4 @@
 
 sources = files('main.c')
 allow_experimental_apis = true
-deps = ['ethdev', 'metrics']
+deps += ['ethdev', 'metrics']
index 653907d..eb8cc04 100644 (file)
@@ -6,4 +6,4 @@ sources = files('main.c',
                'test_bbdev_perf.c',
                'test_bbdev_vector.c')
 allow_experimental_apis = true
-deps = ['bbdev', 'bus_vdev']
+deps += ['bbdev', 'bus_vdev']
index eacd7a0..d735b18 100644 (file)
@@ -12,4 +12,4 @@ sources = files('cperf_ops.c',
                'cperf_test_vectors.c',
                'cperf_test_verify.c',
                'main.c')
-deps = ['cryptodev']
+deps += ['cryptodev']
index cd66618..6006c60 100644 (file)
@@ -24,7 +24,7 @@ sources = files('cmdline.c',
        'txonly.c',
        'util.c')
 
-deps = ['ethdev', 'gro', 'gso', 'cmdline', 'metrics', 'meter', 'bus_pci']
+deps += ['ethdev', 'gro', 'gso', 'cmdline', 'metrics', 'meter', 'bus_pci']
 if dpdk_conf.has('RTE_LIBRTE_PDUMP')
        deps += 'pdump'
 endif
index 6f9228c..275f00b 100644 (file)
@@ -21,6 +21,9 @@ toolchain = cc.get_id()
 dpdk_conf.set_quoted('RTE_TOOLCHAIN', toolchain)
 dpdk_conf.set('RTE_TOOLCHAIN_' + toolchain.to_upper(), 1)
 
+add_project_link_arguments('-Wl,--no-as-needed', language: 'c')
+dpdk_extra_ldflags += '-Wl,--no-as-needed'
+
 # use pthreads
 add_project_link_arguments('-pthread', language: 'c')
 dpdk_extra_ldflags += '-pthread'
index b3bbf5b..9492f54 100644 (file)
@@ -9,6 +9,7 @@ cflags += '-DALLOW_EXPERIMENTAL_API'
 jansson = cc.find_library('jansson', required: false)
 if jansson.found()
        ext_deps += jansson
+       dpdk_app_link_libraries += ['telemetry']
 else
        build = false
 endif
index 9d1f353..c0cc2d8 100644 (file)
@@ -132,6 +132,7 @@ foreach l:libraries
                                        dependencies: shared_deps)
 
                        dpdk_libraries = [shared_lib] + dpdk_libraries
+                       dpdk_static_libraries = [static_lib] + dpdk_static_libraries
                endif # sources.length() > 0
 
                set_variable('shared_' + libname, shared_dep)
index c9af335..b1e6eab 100644 (file)
@@ -12,8 +12,10 @@ project('DPDK', 'C',
 cc = meson.get_compiler('c')
 dpdk_conf = configuration_data()
 dpdk_libraries = []
+dpdk_static_libraries = []
 dpdk_drivers = []
 dpdk_extra_ldflags = []
+dpdk_app_link_libraries = []
 
 driver_install_path = join_paths(get_option('libdir'), 'dpdk/drivers')
 eal_pmd_path = join_paths(get_option('prefix'), driver_install_path)