X-Git-Url: http://git.droids-corp.org/?a=blobdiff_plain;f=meson.build;h=d1e8e5239aa1a0365e50e4e6c87414ed32b3b519;hb=e09848337cac0f18833557034b181a48af517193;hp=7332e75b5487513dce495a912f66930e9e71cb9f;hpb=806c45dd483dfec319028758210d9faee731ca8e;p=dpdk.git diff --git a/meson.build b/meson.build index 7332e75b54..d1e8e5239a 100644 --- a/meson.build +++ b/meson.build @@ -1,27 +1,33 @@ # SPDX-License-Identifier: BSD-3-Clause -# Copyright(c) 2017 Intel Corporation +# Copyright(c) 2017-2019 Intel Corporation project('DPDK', 'C', - version: '18.11-rc0', + # Get version number from file. + # Fallback to "more" for Windows compatibility. + version: run_command(find_program('cat', 'more'), + files('VERSION')).stdout().strip(), license: 'BSD', default_options: ['buildtype=release', 'default_library=static'], - meson_version: '>= 0.41' + meson_version: '>= 0.47.1' ) # set up some global vars for compiler, platform, configuration, etc. cc = meson.get_compiler('c') dpdk_conf = configuration_data() dpdk_libraries = [] +dpdk_static_libraries = [] +dpdk_driver_classes = [] dpdk_drivers = [] dpdk_extra_ldflags = [] - -driver_install_path = join_paths(get_option('libdir'), 'dpdk/drivers') -eal_pmd_path = join_paths(get_option('prefix'), driver_install_path) +dpdk_app_link_libraries = [] # configure the build, and make sure configs here and in config folder are # able to be included in any file. We also store a global array of include dirs # for passing to pmdinfogen scripts -global_inc = include_directories('.', 'config') +global_inc = include_directories('.', 'config', + 'lib/librte_eal/common/include', + 'lib/librte_eal/@0@/eal/include'.format(host_machine.system()), +) subdir('config') # build libs and drivers @@ -32,7 +38,9 @@ subdir('drivers') # build binaries and installable tools subdir('usertools') subdir('app') -subdir('test') + +# build docs +subdir('doc') # build any examples explicitly requested - useful for developers if get_option('examples') != '' @@ -55,21 +63,16 @@ configure_file(output: build_cfg, # them. dpdk_drivers = ['-Wl,--whole-archive'] + dpdk_drivers + ['-Wl,--no-whole-archive'] -# driver .so files often depend upon the bus drivers for their connect bus, -# e.g. ixgbe depends on librte_bus_pci. This means that the bus drivers need -# to be in the library path, so symlink the drivers from the main lib directory. -meson.add_install_script('buildtools/symlink-drivers-solibs.sh', - driver_install_path, - get_option('libdir')) - pkg = import('pkgconfig') pkg.generate(name: meson.project_name(), filebase: 'lib' + meson.project_name().to_lower(), version: meson.project_version(), libraries: dpdk_libraries, - libraries_private: dpdk_drivers + dpdk_libraries + + libraries_private: dpdk_drivers + dpdk_static_libraries + ['-Wl,-Bdynamic'] + dpdk_extra_ldflags, - description: 'The Data Plane Development Kit (DPDK)', + description: '''The Data Plane Development Kit (DPDK). +Note that CFLAGS might contain an -march flag higher than typical baseline. +This is required for a number of static inline functions in the public headers.''', subdirs: [get_option('include_subdir_arch'), '.'], extra_cflags: ['-include', 'rte_config.h'] + machine_args ) @@ -90,7 +93,7 @@ endforeach message(output_message + '\n') output_message = '\n===============\nDrivers Enabled\n===============\n' -foreach class:driver_classes +foreach class:dpdk_driver_classes class_drivers = get_variable(class + '_drivers') output_message += '\n' + class + ':\n\t' output_count = 0