2017-12-18 15:56:25 +00:00
|
|
|
# SPDX-License-Identifier: BSD-3-Clause
|
2019-04-02 03:54:58 +00:00
|
|
|
# Copyright(c) 2017-2019 Intel Corporation
|
|
|
|
|
2019-04-09 10:55:36 +00:00
|
|
|
if is_windows
|
2019-04-02 03:54:58 +00:00
|
|
|
subdir_done()
|
|
|
|
endif
|
2017-08-29 13:49:45 +00:00
|
|
|
|
2018-01-19 18:15:20 +00:00
|
|
|
# Defines the order in which the drivers are buit.
|
2019-03-25 10:34:59 +00:00
|
|
|
dpdk_driver_classes = ['common',
|
2018-04-04 14:30:24 +00:00
|
|
|
'bus',
|
|
|
|
'mempool', # depends on common and bus.
|
raw/ifpga/base: support device tree
In PAC N3000 card, this is a BMC chip which using MAX10 FPGA
to manage the board configuration, like sensors, flash controller,
QSFP, powers. And this is a SPI bus connected between A10 FPGA and
MAX10, we can access the MAX10 registers over this SPI bus.
In BMC, there are about 19 sensors in MAX10 chip, including the FPGA
core temperature, Board temperature, board current, voltage and so on.
We use DTB (Device tree table) to describe it. This DTB file is store
in nor flash partition, which will flashed in Factory when the boards
delivery to customers. And the same time, the customers can easy to
customize the BMC configuration like change the sensors.
Add device tree support by using libfdt library in Linux distribution.
The end-user should pre-install the libfdt and libfdt-devel package
before use DPDK on PAC N3000 Card.
For Centos 7.x: sudo yum install libfdt libfdt-devel
For Ubuntu 18.04: sudo apt install libfdt-dev libfdt1
To eliminate build error, we currently do not compile raw/ifpga
and net/ipn3ke. User should install libfdt and libfdt-devel first,
modify config/common_linux, CONFIG_RTE_LIBRTE_PMD_IFPGA_RAWDEV=n
to CONFIG_RTE_LIBRTE_PMD_IFPGA_RAWDEV=y, modify config/common_base,
CONFIG_RTE_LIBRTE_IPN3KE_PMD=n to CONFIG_RTE_LIBRTE_IPN3KE_PMD=y.
Then this function can work.
Signed-off-by: Tianfei Zhang <tianfei.zhang@intel.com>
Signed-off-by: Andy Pei <andy.pei@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2019-11-14 09:02:53 +00:00
|
|
|
'raw', # depends on common and bus.
|
|
|
|
'net', # depends on common, bus, mempool and raw.
|
2018-04-04 14:30:24 +00:00
|
|
|
'crypto', # depends on common, bus and mempool (net in future).
|
2018-05-09 16:14:26 +00:00
|
|
|
'compress', # depends on common, bus, mempool.
|
2018-05-03 16:06:03 +00:00
|
|
|
'event', # depends on common, bus, mempool and net.
|
raw/ifpga/base: support device tree
In PAC N3000 card, this is a BMC chip which using MAX10 FPGA
to manage the board configuration, like sensors, flash controller,
QSFP, powers. And this is a SPI bus connected between A10 FPGA and
MAX10, we can access the MAX10 registers over this SPI bus.
In BMC, there are about 19 sensors in MAX10 chip, including the FPGA
core temperature, Board temperature, board current, voltage and so on.
We use DTB (Device tree table) to describe it. This DTB file is store
in nor flash partition, which will flashed in Factory when the boards
delivery to customers. And the same time, the customers can easy to
customize the BMC configuration like change the sensors.
Add device tree support by using libfdt library in Linux distribution.
The end-user should pre-install the libfdt and libfdt-devel package
before use DPDK on PAC N3000 Card.
For Centos 7.x: sudo yum install libfdt libfdt-devel
For Ubuntu 18.04: sudo apt install libfdt-dev libfdt1
To eliminate build error, we currently do not compile raw/ifpga
and net/ipn3ke. User should install libfdt and libfdt-devel first,
modify config/common_linux, CONFIG_RTE_LIBRTE_PMD_IFPGA_RAWDEV=n
to CONFIG_RTE_LIBRTE_PMD_IFPGA_RAWDEV=y, modify config/common_base,
CONFIG_RTE_LIBRTE_IPN3KE_PMD=n to CONFIG_RTE_LIBRTE_IPN3KE_PMD=y.
Then this function can work.
Signed-off-by: Tianfei Zhang <tianfei.zhang@intel.com>
Signed-off-by: Andy Pei <andy.pei@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
2019-11-14 09:02:53 +00:00
|
|
|
'baseband'] # depends on common and bus.
|
2017-08-29 13:49:45 +00:00
|
|
|
|
2019-09-25 14:55:31 +00:00
|
|
|
disabled_drivers = get_option('disable_drivers').split(',')
|
|
|
|
|
2018-07-19 14:22:06 +00:00
|
|
|
default_cflags = machine_args
|
|
|
|
if cc.has_argument('-Wno-format-truncation')
|
|
|
|
default_cflags += '-Wno-format-truncation'
|
|
|
|
endif
|
2018-10-04 10:20:33 +00:00
|
|
|
|
2019-03-25 10:34:59 +00:00
|
|
|
foreach class:dpdk_driver_classes
|
2017-08-29 13:49:45 +00:00
|
|
|
drivers = []
|
|
|
|
std_deps = []
|
|
|
|
config_flag_fmt = '' # format string used to set the value in dpdk_conf
|
|
|
|
driver_name_fmt = '' # format string for driver name, used to name
|
|
|
|
# the library, the dependency and to find the
|
|
|
|
# version file for linking
|
|
|
|
|
|
|
|
subdir(class)
|
2018-08-29 16:19:20 +00:00
|
|
|
class_drivers = []
|
2017-08-29 13:49:45 +00:00
|
|
|
|
|
|
|
foreach drv:drivers
|
|
|
|
drv_path = join_paths(class, drv)
|
|
|
|
|
|
|
|
# set up empty variables used for build
|
|
|
|
build = true # set to false to disable, e.g. missing deps
|
2019-06-05 20:22:39 +00:00
|
|
|
reason = '<unknown reason>' # set if build == false to explain
|
2017-08-29 16:20:14 +00:00
|
|
|
name = drv
|
2017-08-29 13:49:45 +00:00
|
|
|
allow_experimental_apis = false
|
|
|
|
sources = []
|
|
|
|
objs = []
|
2018-07-19 14:22:06 +00:00
|
|
|
cflags = default_cflags
|
2017-08-29 13:49:45 +00:00
|
|
|
includes = [include_directories(drv_path)]
|
|
|
|
# set up internal deps. Drivers can append/override as necessary
|
|
|
|
deps = std_deps
|
|
|
|
# ext_deps: Stores external library dependency got
|
2019-02-26 17:46:33 +00:00
|
|
|
# using dependency() (preferred) or find_library().
|
|
|
|
# For the find_library() case (but not with dependency()) we also
|
|
|
|
# need to specify the "-l" flags in pkgconfig_extra_libs variable
|
|
|
|
# too, so that it can be reflected in the pkgconfig output for
|
|
|
|
# static builds.
|
2017-08-29 13:49:45 +00:00
|
|
|
ext_deps = []
|
|
|
|
pkgconfig_extra_libs = []
|
|
|
|
|
|
|
|
# pull in driver directory which should assign to each of the above
|
|
|
|
subdir(drv_path)
|
|
|
|
|
2019-10-24 10:41:08 +00:00
|
|
|
# skip disabled drivers. For meson 0.49 change this to use
|
|
|
|
# "in" keyword
|
|
|
|
foreach disable_path: disabled_drivers
|
|
|
|
if drv_path == disable_path
|
|
|
|
build = false
|
|
|
|
reason = 'Explicitly disabled via build config'
|
|
|
|
endif
|
|
|
|
endforeach
|
|
|
|
if build
|
2019-09-25 14:55:30 +00:00
|
|
|
# get dependency objs from strings
|
|
|
|
shared_deps = ext_deps
|
|
|
|
static_deps = ext_deps
|
|
|
|
foreach d:deps
|
|
|
|
if not is_variable('shared_rte_' + d)
|
2019-09-25 14:55:31 +00:00
|
|
|
build = false
|
|
|
|
reason = 'Missing internal dependency, "@0@"'.format(d)
|
|
|
|
message('Disabling @1@ [@2@]: missing internal dependency "@0@"'
|
2019-09-25 14:55:30 +00:00
|
|
|
.format(d, name, 'drivers/' + drv_path))
|
2019-09-25 14:55:31 +00:00
|
|
|
else
|
|
|
|
shared_deps += [get_variable('shared_rte_' + d)]
|
|
|
|
static_deps += [get_variable('static_rte_' + d)]
|
2019-09-25 14:55:30 +00:00
|
|
|
endif
|
|
|
|
endforeach
|
|
|
|
endif
|
|
|
|
|
2019-06-05 20:22:39 +00:00
|
|
|
if not build
|
|
|
|
# some driver directories are placeholders which
|
|
|
|
# are never built, so we allow suppression of the
|
|
|
|
# component disable printout in those cases
|
|
|
|
if reason != ''
|
|
|
|
dpdk_drvs_disabled += drv_path
|
|
|
|
set_variable(drv_path.underscorify() +
|
|
|
|
'_disable_reason', reason)
|
|
|
|
endif
|
|
|
|
else
|
2018-08-29 16:19:20 +00:00
|
|
|
class_drivers += name
|
|
|
|
|
2017-08-29 16:20:14 +00:00
|
|
|
dpdk_conf.set(config_flag_fmt.format(name.to_upper()),1)
|
drivers: improve pmdinfo generation with meson
Since meson 0.44, changing any file inside a PMD directory (quite
correctly) triggers a full re-run of meson on build, rather than an
incremental build as with earlier versions. This rerun is needed because
we use "grep" in meson to search for files on which to run pmdinfogen, and
changing any of those files means that grep and, therefore meson, needs to
be rerun. [Previous versions of meson did not track this dependency on the
grep command, and so did incremental builds only.]
If, however, we take advantage of pmdinfogen's ability to use stdin and
stdout instead of files, we can instead use a shell script to process an
entire static archive and generate a single .c file from it. This
eliminates the need for grep, and means that changes to a PMD file only
need an incremental build - a significant time saving.
Signed-off-by: Bruce Richardson <bruce.richardson@intel.com>
2018-01-25 11:14:43 +00:00
|
|
|
lib_name = driver_name_fmt.format(name)
|
2017-08-29 13:49:45 +00:00
|
|
|
|
|
|
|
if allow_experimental_apis
|
|
|
|
cflags += '-DALLOW_EXPERIMENTAL_API'
|
|
|
|
endif
|
|
|
|
|
|
|
|
dpdk_extra_ldflags += pkgconfig_extra_libs
|
|
|
|
|
drivers: improve pmdinfo generation with meson
Since meson 0.44, changing any file inside a PMD directory (quite
correctly) triggers a full re-run of meson on build, rather than an
incremental build as with earlier versions. This rerun is needed because
we use "grep" in meson to search for files on which to run pmdinfogen, and
changing any of those files means that grep and, therefore meson, needs to
be rerun. [Previous versions of meson did not track this dependency on the
grep command, and so did incremental builds only.]
If, however, we take advantage of pmdinfogen's ability to use stdin and
stdout instead of files, we can instead use a shell script to process an
entire static archive and generate a single .c file from it. This
eliminates the need for grep, and means that changes to a PMD file only
need an incremental build - a significant time saving.
Signed-off-by: Bruce Richardson <bruce.richardson@intel.com>
2018-01-25 11:14:43 +00:00
|
|
|
# generate pmdinfo sources by building a temporary
|
|
|
|
# lib and then running pmdinfogen on the contents of
|
|
|
|
# that lib. The final lib reuses the object files and
|
|
|
|
# adds in the new source file.
|
|
|
|
out_filename = lib_name + '.pmd.c'
|
|
|
|
tmp_lib = static_library('tmp_' + lib_name,
|
|
|
|
sources,
|
|
|
|
include_directories: includes,
|
2019-09-25 14:55:29 +00:00
|
|
|
dependencies: static_deps,
|
2017-08-29 13:49:45 +00:00
|
|
|
c_args: cflags)
|
drivers: improve pmdinfo generation with meson
Since meson 0.44, changing any file inside a PMD directory (quite
correctly) triggers a full re-run of meson on build, rather than an
incremental build as with earlier versions. This rerun is needed because
we use "grep" in meson to search for files on which to run pmdinfogen, and
changing any of those files means that grep and, therefore meson, needs to
be rerun. [Previous versions of meson did not track this dependency on the
grep command, and so did incremental builds only.]
If, however, we take advantage of pmdinfogen's ability to use stdin and
stdout instead of files, we can instead use a shell script to process an
entire static archive and generate a single .c file from it. This
eliminates the need for grep, and means that changes to a PMD file only
need an incremental build - a significant time saving.
Signed-off-by: Bruce Richardson <bruce.richardson@intel.com>
2018-01-25 11:14:43 +00:00
|
|
|
objs += tmp_lib.extract_all_objects()
|
|
|
|
sources = custom_target(out_filename,
|
|
|
|
command: [pmdinfo, tmp_lib.full_path(),
|
|
|
|
'@OUTPUT@', pmdinfogen],
|
|
|
|
output: out_filename,
|
|
|
|
depends: [pmdinfogen, tmp_lib])
|
2017-08-29 13:49:45 +00:00
|
|
|
|
2019-11-20 17:23:28 +00:00
|
|
|
version_map = '@0@/@1@/@2@_version.map'.format(
|
|
|
|
meson.current_source_dir(),
|
|
|
|
drv_path, lib_name)
|
|
|
|
|
|
|
|
is_experimental = run_command(is_experimental_cmd,
|
|
|
|
files(version_map)).returncode()
|
|
|
|
|
|
|
|
if is_experimental != 0
|
|
|
|
lib_version = experimental_abi_version
|
|
|
|
so_version = experimental_abi_version
|
2017-08-31 10:36:43 +00:00
|
|
|
else
|
2019-11-20 17:23:28 +00:00
|
|
|
lib_version = abi_version
|
|
|
|
so_version = abi_version
|
2017-08-31 10:36:43 +00:00
|
|
|
endif
|
|
|
|
|
2017-11-03 17:27:32 +00:00
|
|
|
# now build the static driver
|
|
|
|
static_lib = static_library(lib_name,
|
|
|
|
sources,
|
|
|
|
objects: objs,
|
|
|
|
include_directories: includes,
|
2019-09-25 14:55:29 +00:00
|
|
|
dependencies: static_deps,
|
2017-11-03 17:27:32 +00:00
|
|
|
c_args: cflags,
|
|
|
|
install: true)
|
|
|
|
|
|
|
|
# now build the shared driver
|
2017-08-29 13:49:45 +00:00
|
|
|
version_map = '@0@/@1@/@2@_version.map'.format(
|
|
|
|
meson.current_source_dir(),
|
2017-08-29 16:20:14 +00:00
|
|
|
drv_path, lib_name)
|
2019-10-08 14:36:28 +00:00
|
|
|
implib = dir_name + '.dll.a'
|
|
|
|
|
|
|
|
def_file = custom_target(lib_name + '_def',
|
|
|
|
command: [map_to_def_cmd, '@INPUT@', '@OUTPUT@'],
|
|
|
|
input: version_map,
|
|
|
|
output: '@0@_exports.def'.format(lib_name))
|
|
|
|
lk_deps = [version_map, def_file]
|
|
|
|
if is_windows
|
|
|
|
lk_args = ['-Wl,/def:' + def_file.full_path(),
|
|
|
|
'-Wl,/implib:lib\\' + implib]
|
|
|
|
else
|
|
|
|
lk_args = ['-Wl,--version-script=' + version_map]
|
|
|
|
# on unix systems check the output of the
|
|
|
|
# experimental syms script, using it as a
|
|
|
|
# dependency of the .so build
|
|
|
|
lk_deps += custom_target(lib_name + '.exp_chk',
|
|
|
|
command: [check_experimental_syms,
|
|
|
|
version_map, '@INPUT@'],
|
|
|
|
capture: true,
|
|
|
|
input: static_lib,
|
|
|
|
output: lib_name + '.exp_chk')
|
|
|
|
endif
|
|
|
|
|
2017-11-03 17:27:32 +00:00
|
|
|
shared_lib = shared_library(lib_name,
|
2017-08-29 13:49:45 +00:00
|
|
|
sources,
|
|
|
|
objects: objs,
|
|
|
|
include_directories: includes,
|
2019-09-25 14:55:29 +00:00
|
|
|
dependencies: shared_deps,
|
2017-08-29 13:49:45 +00:00
|
|
|
c_args: cflags,
|
2019-10-08 14:36:28 +00:00
|
|
|
link_args: lk_args,
|
|
|
|
link_depends: lk_deps,
|
2017-08-31 10:36:43 +00:00
|
|
|
version: lib_version,
|
|
|
|
soversion: so_version,
|
2017-08-29 13:49:45 +00:00
|
|
|
install: true,
|
|
|
|
install_dir: driver_install_path)
|
|
|
|
|
|
|
|
# create a dependency object and add it to the global dictionary so
|
|
|
|
# testpmd or other built-in apps can find it if necessary
|
2017-11-03 17:27:32 +00:00
|
|
|
shared_dep = declare_dependency(link_with: shared_lib,
|
|
|
|
include_directories: includes,
|
2019-09-25 14:55:29 +00:00
|
|
|
dependencies: shared_deps)
|
2017-11-03 17:27:32 +00:00
|
|
|
static_dep = declare_dependency(link_with: static_lib,
|
2017-08-29 13:49:45 +00:00
|
|
|
include_directories: includes,
|
2019-09-25 14:55:29 +00:00
|
|
|
dependencies: static_deps)
|
2017-11-03 17:27:32 +00:00
|
|
|
|
|
|
|
dpdk_drivers += static_lib
|
|
|
|
|
|
|
|
set_variable('shared_@0@'.format(lib_name), shared_dep)
|
|
|
|
set_variable('static_@0@'.format(lib_name), static_dep)
|
2019-09-19 15:07:55 +00:00
|
|
|
dependency_name = ''.join(lib_name.split('rte_'))
|
|
|
|
message('drivers/@0@: Defining dependency "@1@"'.format(
|
|
|
|
drv_path, dependency_name))
|
2017-08-29 13:49:45 +00:00
|
|
|
endif # build
|
|
|
|
endforeach
|
2018-08-29 16:19:20 +00:00
|
|
|
|
2019-02-26 17:46:32 +00:00
|
|
|
set_variable(class + '_drivers', class_drivers)
|
2017-08-29 13:49:45 +00:00
|
|
|
endforeach
|