git.droids-corp.org
/
dpdk.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
regexdev: introduce API
[dpdk.git]
/
lib
/
meson.build
diff --git
a/lib/meson.build
b/lib/meson.build
index
bc8eb1d
..
80c37af
100644
(file)
--- a/
lib/meson.build
+++ b/
lib/meson.build
@@
-10,8
+10,11
@@
# core libs which are widely reused, so their deps are kept to a minimum.
libraries = [
'kvargs', # eal depends on kvargs
# core libs which are widely reused, so their deps are kept to a minimum.
libraries = [
'kvargs', # eal depends on kvargs
+ 'telemetry', # basic info querying
'eal', # everything depends on eal
'eal', # everything depends on eal
- 'ring', 'mempool', 'mbuf', 'net', 'meter', 'ethdev', 'pci', # core
+ 'ring',
+ 'rcu', # rcu depends on ring
+ 'mempool', 'mbuf', 'net', 'meter', 'ethdev', 'pci', # core
'cmdline',
'metrics', # bitrate/latency stats depends on this
'hash', # efd depends on this
'cmdline',
'metrics', # bitrate/latency stats depends on this
'hash', # efd depends on this
@@
-21,8
+24,8
@@
libraries = [
'distributor', 'efd', 'eventdev',
'gro', 'gso', 'ip_frag', 'jobstats',
'kni', 'latencystats', 'lpm', 'member',
'distributor', 'efd', 'eventdev',
'gro', 'gso', 'ip_frag', 'jobstats',
'kni', 'latencystats', 'lpm', 'member',
- 'power', 'pdump', 'rawdev',
- 'r
cu', 'r
ib', 'reorder', 'sched', 'security', 'stack', 'vhost',
+ 'power', 'pdump', 'rawdev',
'regexdev',
+ 'rib', 'reorder', 'sched', 'security', 'stack', 'vhost',
# ipsec lib depends on net, crypto and security
'ipsec',
#fib lib depends on rib
# ipsec lib depends on net, crypto and security
'ipsec',
#fib lib depends on rib
@@
-30,13
+33,21
@@
libraries = [
# add pkt framework libs which use other libs from above
'port', 'table', 'pipeline',
# flow_classify lib depends on pkt framework table lib
# add pkt framework libs which use other libs from above
'port', 'table', 'pipeline',
# flow_classify lib depends on pkt framework table lib
- 'flow_classify', 'bpf', '
telemetry
']
+ 'flow_classify', 'bpf', '
graph', 'node
']
if is_windows
if is_windows
- libraries = ['kvargs','eal'] # only supported libraries for windows
+ libraries = [
+ 'kvargs',
+ 'eal',
+ 'ring',
+ 'pci',
+ ] # only supported libraries for windows
endif
default_cflags = machine_args
endif
default_cflags = machine_args
+default_cflags += ['-DALLOW_EXPERIMENTAL_API']
+default_cflags += ['-DALLOW_INTERNAL_API']
+
if cc.has_argument('-Wno-format-truncation')
default_cflags += '-Wno-format-truncation'
endif
if cc.has_argument('-Wno-format-truncation')
default_cflags += '-Wno-format-truncation'
endif
@@
-47,8
+58,6
@@
foreach l:libraries
build = true
reason = '<unknown reason>' # set if build == false to explain why
name = l
build = true
reason = '<unknown reason>' # set if build == false to explain why
name = l
- version = 1
- allow_experimental_apis = false
use_function_versioning = false
sources = []
headers = []
use_function_versioning = false
sources = []
headers = []
@@
-99,19
+108,22
@@
foreach l:libraries
static_dep = shared_dep
else
static_dep = shared_dep
else
- if allow_experimental_apis
- cflags += '-DALLOW_EXPERIMENTAL_API'
- endif
if use_function_versioning
cflags += '-DRTE_USE_FUNCTION_VERSIONING'
endif
if use_function_versioning
cflags += '-DRTE_USE_FUNCTION_VERSIONING'
endif
- if get_option('per_library_versions')
- lib_version = '@0@.1'.format(version)
- so_version = '@0@'.format(version)
+ version_map = '@0@/@1@/rte_@2@_version.map'.format(
+ meson.current_source_dir(), dir_name, name)
+
+ is_stable = run_command(is_stable_cmd,
+ files(version_map)).returncode() == 0
+
+ if is_stable
+ lib_version = abi_version
+ so_version = stable_so_version
else
else
- lib_version =
major
_version
- so_version =
major
_version
+ lib_version =
experimental_abi
_version
+ so_version =
experimental_so
_version
endif
# first build static lib
endif
# first build static lib
@@
-122,7
+134,7
@@
foreach l:libraries
dependencies: static_deps,
include_directories: includes,
install: true)
dependencies: static_deps,
include_directories: includes,
install: true)
- static_dep = declare_dependency(
link_with: static_lib,
+ static_dep = declare_dependency(
include_directories: includes,
dependencies: static_deps)
include_directories: includes,
dependencies: static_deps)
@@
-139,25
+151,38
@@
foreach l:libraries
meson.current_source_dir(), dir_name, name)
implib = dir_name + '.dll.a'
meson.current_source_dir(), dir_name, name)
implib = dir_name + '.dll.a'
- def_file = custom_target(name + '_def',
- command: [map_to_
def
_cmd, '@INPUT@', '@OUTPUT@'],
+ def_file = custom_target(
lib
name + '_def',
+ command: [map_to_
win
_cmd, '@INPUT@', '@OUTPUT@'],
input: version_map,
input: version_map,
- output: 'rte_@0@_exports.def'.format(name))
- lk_deps = [version_map, def_file]
- if is_windows
+ output: '@0@_exports.def'.format(libname))
+
+ mingw_map = custom_target(libname + '_mingw',
+ command: [map_to_win_cmd, '@INPUT@', '@OUTPUT@'],
+ input: version_map,
+ output: '@0@_mingw.map'.format(libname))
+
+ if is_ms_linker
lk_args = ['-Wl,/def:' + def_file.full_path(),
'-Wl,/implib:lib\\' + implib]
else
lk_args = ['-Wl,/def:' + def_file.full_path(),
'-Wl,/implib:lib\\' + implib]
else
- lk_args = ['-Wl,--version-script=' + version_map]
+ if is_windows
+ lk_args = ['-Wl,--version-script=' + mingw_map.full_path()]
+ else
+ lk_args = ['-Wl,--version-script=' + version_map]
+ endif
+ endif
+
+ lk_deps = [version_map, def_file, mingw_map]
+ if not is_windows
# on unix systems check the output of the
# on unix systems check the output of the
- #
experimental syms
script, using it as a
+ #
check-symbols.sh
script, using it as a
# dependency of the .so build
# dependency of the .so build
- lk_deps += custom_target(name + '.
exp
_chk',
- command: [check_
experimental_sym
s,
+ lk_deps += custom_target(name + '.
sym
_chk',
+ command: [check_
symbol
s,
version_map, '@INPUT@'],
capture: true,
input: static_lib,
version_map, '@INPUT@'],
capture: true,
input: static_lib,
- output: name + '.
exp
_chk')
+ output: name + '.
sym
_chk')
endif
shared_lib = shared_library(libname,
endif
shared_lib = shared_library(libname,