[dpdk-dev] [PATCH v9 4/8] fib: introduce AVX512 lookup
Bruce Richardson
bruce.richardson at intel.com
Tue Oct 13 12:27:26 CEST 2020
On Wed, Oct 07, 2020 at 05:10:38PM +0100, Vladimir Medvedkin wrote:
> Add new lookup implementation for DIR24_8 algorithm using
> AVX512 instruction set
>
> Signed-off-by: Vladimir Medvedkin <vladimir.medvedkin at intel.com>
> Acked-by: Konstantin Ananyev <konstantin.ananyev at intel.com>
> ---
> doc/guides/rel_notes/release_20_11.rst | 3 +
> lib/librte_fib/dir24_8.c | 36 +++++++
> lib/librte_fib/dir24_8_avx512.c | 165 +++++++++++++++++++++++++++++++++
> lib/librte_fib/dir24_8_avx512.h | 24 +++++
> lib/librte_fib/meson.build | 34 +++++++
> lib/librte_fib/rte_fib.c | 2 +-
> lib/librte_fib/rte_fib.h | 4 +-
> 7 files changed, 266 insertions(+), 2 deletions(-)
> create mode 100644 lib/librte_fib/dir24_8_avx512.c
> create mode 100644 lib/librte_fib/dir24_8_avx512.h
>
<snip>
> diff --git a/lib/librte_fib/meson.build b/lib/librte_fib/meson.build
> index 771828f..0a8adef 100644
> --- a/lib/librte_fib/meson.build
> +++ b/lib/librte_fib/meson.build
> @@ -5,3 +5,37 @@
> sources = files('rte_fib.c', 'rte_fib6.c', 'dir24_8.c', 'trie.c')
> headers = files('rte_fib.h', 'rte_fib6.h')
> deps += ['rib']
> +
> +# compile AVX512 version if:
> +# we are building 64-bit binary AND binutils can generate proper code
> +if dpdk_conf.has('RTE_ARCH_X86_64') and binutils_ok.returncode() == 0
> + # compile AVX512 version if either:
> + # a. we have AVX512F supported in minimum instruction set baseline
> + # b. it's not minimum instruction set, but supported by compiler
> + #
> + # in former case, just add avx512 C file to files list
> + # in latter case, compile c file to static lib, using correct
> + # compiler flags, and then have the .o file from static lib
> + # linked into main lib.
> +
> + # check if all required flags already enabled (variant a).
> + acl_avx512_flags = ['__AVX512F__','__AVX512DQ__']
> + acl_avx512_on = true
> + foreach f:acl_avx512_flags
> + if cc.get_define(f, args: machine_args) == ''
> + acl_avx512_on = false
> + endif
> + endforeach
> +
> + if acl_avx512_on == true
> + cflags += ['-DCC_DIR24_8_AVX512_SUPPORT']
> + sources += files('dir24_8_avx512.c')
> + elif cc.has_multi_arguments('-mavx512f', '-mavx512dq')
> + dir24_8_avx512_tmp = static_library('dir24_8_avx512_tmp',
> + 'dir24_8_avx512.c',
> + dependencies: static_rte_eal,
> + c_args: cflags + ['-mavx512f', '-mavx512dq'])
> + objs += dir24_8_avx512_tmp.extract_objects('dir24_8_avx512.c')
> + cflags += '-DCC_DIR24_8_AVX512_SUPPORT'
> + endif
> +endif
This meson change looks ok to me. For the build-system part:
Acked-by: Bruce Richardson <bruce.richardson at intel.com>
More information about the dev
mailing list