]> git.droids-corp.org - dpdk.git/commitdiff
build: support building ABI versioned files twice
authorBruce Richardson <bruce.richardson@intel.com>
Mon, 7 Oct 2019 15:45:50 +0000 (16:45 +0100)
committerThomas Monjalon <thomas@monjalon.net>
Sun, 27 Oct 2019 11:49:28 +0000 (12:49 +0100)
Any file with ABI versioned functions needs different macros for shared and
static builds, so we need to accommodate that. Rather than building
everything twice, we just flag to the build system which libraries need
that handling, by setting use_function_versioning in the meson.build files.

To ensure we don't get silent errors at build time due to this meson flag
being missed, we add an explicit error to the function versioning header
file if a known C macro is not defined. Since "make" builds always only
build one of shared or static libraries, this define can be always set, and
so is added to the global CFLAGS. For meson, the build flag - and therefore
the C define - is set for the three libraries that need the function
versioning: "distributor", "lpm" and "timer".

Signed-off-by: Bruce Richardson <bruce.richardson@intel.com>
Acked-by: Stephen Hemminger <stephen@networkplumber.org>
Tested-by: Andrzej Ostruszka <amo@semihalf.com>
Reviewed-by: Andrzej Ostruszka <amo@semihalf.com>
config/rte_config.h
doc/guides/contributing/coding_style.rst
lib/librte_distributor/meson.build
lib/librte_eal/common/include/rte_function_versioning.h
lib/librte_lpm/meson.build
lib/librte_timer/meson.build
lib/meson.build
mk/target/generic/rte.vars.mk

index 895475a44da02919dfe60afa40f8f8a6d5bb69a7..d30786bc08e8baedcd6715ea9fb911c5a5b0f650 100644 (file)
@@ -31,9 +31,6 @@
 
 /****** library defines ********/
 
-/* compat defines */
-#define RTE_BUILD_SHARED_LIB
-
 /* EAL defines */
 #define RTE_MAX_HEAPS 32
 #define RTE_MAX_MEMSEG_LISTS 128
index 449b33494bb464543308e72cd8f994a451376eb4..e95a1a2be249d8f45e188263cc28b592d9b07535 100644 (file)
@@ -948,6 +948,13 @@ reason
        built. For missing dependencies this should be of the form
        ``'missing dependency, "libname"'``.
 
+use_function_versioning
+       **Default Value = false**.
+       Specifies if the library in question has ABI versioned functions. If it
+       has, this value should be set to ensure that the C files are compiled
+       twice with suitable parameters for each of shared or static library
+       builds.
+
 version
        **Default Value = 1**.
        Specifies the ABI version of the library, and is used as the major
index 26577dbc19776aa068791f49280cf410e75027bc..c9617d7b140215436ea263fc798001ed40916cc3 100644 (file)
@@ -9,6 +9,7 @@ else
 endif
 headers = files('rte_distributor.h')
 deps += ['mbuf']
+use_function_versioning = true
 
 # for clang 32-bit compiles we need libatomic for 64-bit atomic ops
 if cc.get_id() == 'clang' and dpdk_conf.get('RTE_ARCH_64') == false
index ce963d4b128e141575b8ba4812cd25ad939ab05c..55e88ffae66547f36cc79af7b33b301db44b77b6 100644 (file)
@@ -7,6 +7,10 @@
 #define _RTE_FUNCTION_VERSIONING_H_
 #include <rte_common.h>
 
+#ifndef RTE_USE_FUNCTION_VERSIONING
+#error Use of function versioning disabled, is "use_function_versioning=true" in meson.build?
+#endif
+
 #ifdef RTE_BUILD_SHARED_LIB
 
 /*
index a5176d8aefb6dea3ede3293644203616ce70dd89..4e3920660b9c00aee2972a4f002d4b04871bfe59 100644 (file)
@@ -8,3 +8,4 @@ headers = files('rte_lpm.h', 'rte_lpm6.h')
 # without worrying about which architecture we actually need
 headers += files('rte_lpm_altivec.h', 'rte_lpm_neon.h', 'rte_lpm_sse.h')
 deps += ['hash']
+use_function_versioning = true
index d3b828ce9d53499af8524190cf47e8d9729ecf5c..b7edfe2e7d3052db9b61b0f2c74a7f1b132b9041 100644 (file)
@@ -4,3 +4,4 @@
 sources = files('rte_timer.c')
 headers = files('rte_timer.h')
 allow_experimental_apis = true
+use_function_versioning = true
index 8ea3671c049b722637c56482d0dfe70b77f27a23..f29eb415ee46cdd11d2140aaea40f59db248b4b9 100644 (file)
@@ -47,6 +47,7 @@ foreach l:libraries
        name = l
        version = 1
        allow_experimental_apis = false
+       use_function_versioning = false
        sources = []
        headers = []
        includes = []
@@ -99,6 +100,9 @@ foreach l:libraries
                        if allow_experimental_apis
                                cflags += '-DALLOW_EXPERIMENTAL_API'
                        endif
+                       if use_function_versioning
+                               cflags += '-DRTE_USE_FUNCTION_VERSIONING'
+                       endif
 
                        if get_option('per_library_versions')
                                lib_version = '@0@.1'.format(version)
@@ -120,9 +124,15 @@ foreach l:libraries
                                        include_directories: includes,
                                        dependencies: static_deps)
 
-                       # then use pre-build objects to build shared lib
-                       sources = []
-                       objs += static_lib.extract_all_objects(recursive: false)
+                       if not use_function_versioning
+                               # use pre-build objects to build shared lib
+                               sources = []
+                               objs += static_lib.extract_all_objects(recursive: false)
+                       else
+                               # for compat we need to rebuild with
+                               # RTE_BUILD_SHARED_LIB defined
+                               cflags += '-DRTE_BUILD_SHARED_LIB'
+                       endif
                        version_map = '@0@/@1@/rte_@2@_version.map'.format(
                                        meson.current_source_dir(), dir_name, name)
                        implib = dir_name + '.dll.a'
index 5f00a0bfaf9eee178e6f208d37b8370fea3cf9bc..374722173d162dd02736a64f48ed73c81abbf5db 100644 (file)
@@ -90,6 +90,14 @@ ASFLAGS += $(TARGET_ASFLAGS)
 CFLAGS += -I$(RTE_OUTPUT)/include
 LDFLAGS += -L$(RTE_OUTPUT)/lib
 
+# add in flag for supporting function versioning. The define is used in meson
+# builds to ensure that the user has properly flagged the unit in question as
+# using function versioning so it can be built twice - once for static lib and
+# then a second time for the shared lib. Since make only builds one library
+# type at a time, such precautions aren't necessary, so we can globally define
+# the flag
+CFLAGS += -DRTE_USE_FUNCTION_VERSIONING
+
 # always include rte_config.h: the one in $(RTE_OUTPUT)/include is
 # the configuration of SDK when $(BUILDING_RTE_SDK) is true, or the
 # configuration of the application if $(BUILDING_RTE_SDK) is not