2018-09-19 10:04:17 +00:00
|
|
|
# SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
# Copyright(c) 2018 Luca Boccassi <bluca@debian.org>
|
|
|
|
|
2020-12-22 00:45:11 +00:00
|
|
|
if is_windows
|
2021-04-20 10:22:25 +00:00
|
|
|
build = false
|
|
|
|
reason = 'not supported on Windows'
|
|
|
|
subdir_done()
|
2020-12-22 00:45:11 +00:00
|
|
|
endif
|
|
|
|
|
2018-09-19 10:04:17 +00:00
|
|
|
cflags += ['-Wno-strict-aliasing']
|
|
|
|
|
2020-01-10 01:37:49 +00:00
|
|
|
includes += include_directories('../../common/iavf')
|
|
|
|
deps += ['common_iavf']
|
2018-09-19 10:04:17 +00:00
|
|
|
|
|
|
|
sources = files(
|
2021-04-20 10:22:25 +00:00
|
|
|
'iavf_ethdev.c',
|
|
|
|
'iavf_rxtx.c',
|
|
|
|
'iavf_vchnl.c',
|
|
|
|
'iavf_generic_flow.c',
|
|
|
|
'iavf_fdir.c',
|
|
|
|
'iavf_hash.c',
|
2021-07-01 11:41:22 +00:00
|
|
|
'iavf_tm.c',
|
2018-09-19 10:04:17 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
if arch_subdir == 'x86'
|
2021-04-20 10:22:25 +00:00
|
|
|
sources += files('iavf_rxtx_vec_sse.c')
|
2019-10-16 08:14:09 +00:00
|
|
|
|
2021-04-20 10:22:25 +00:00
|
|
|
# compile AVX2 version if either:
|
|
|
|
# a. we have AVX supported in minimum instruction set baseline
|
|
|
|
# b. it's not minimum instruction set, but supported by compiler
|
|
|
|
if cc.get_define('__AVX2__', args: machine_args) != ''
|
|
|
|
cflags += ['-DCC_AVX2_SUPPORT']
|
|
|
|
sources += files('iavf_rxtx_vec_avx2.c')
|
|
|
|
elif cc.has_argument('-mavx2')
|
|
|
|
cflags += ['-DCC_AVX2_SUPPORT']
|
|
|
|
iavf_avx2_lib = static_library('iavf_avx2_lib',
|
|
|
|
'iavf_rxtx_vec_avx2.c',
|
|
|
|
dependencies: [static_rte_ethdev,
|
|
|
|
static_rte_kvargs, static_rte_hash],
|
|
|
|
include_directories: includes,
|
|
|
|
c_args: [cflags, '-mavx2'])
|
|
|
|
objs += iavf_avx2_lib.extract_objects('iavf_rxtx_vec_avx2.c')
|
|
|
|
endif
|
2020-10-29 01:24:02 +00:00
|
|
|
|
2021-04-20 10:22:25 +00:00
|
|
|
iavf_avx512_cpu_support = (
|
|
|
|
cc.get_define('__AVX512F__', args: machine_args) != '' and
|
|
|
|
cc.get_define('__AVX512BW__', args: machine_args) != '')
|
2020-10-29 01:24:02 +00:00
|
|
|
|
2021-04-20 10:22:25 +00:00
|
|
|
iavf_avx512_cc_support = (
|
|
|
|
not machine_args.contains('-mno-avx512f') and
|
|
|
|
cc.has_argument('-mavx512f') and
|
|
|
|
cc.has_argument('-mavx512bw'))
|
2020-10-29 01:24:02 +00:00
|
|
|
|
2021-04-20 10:22:25 +00:00
|
|
|
if iavf_avx512_cpu_support == true or iavf_avx512_cc_support == true
|
|
|
|
cflags += ['-DCC_AVX512_SUPPORT']
|
|
|
|
avx512_args = [cflags, '-mavx512f', '-mavx512bw']
|
|
|
|
if cc.has_argument('-march=skylake-avx512')
|
|
|
|
avx512_args += '-march=skylake-avx512'
|
|
|
|
endif
|
|
|
|
iavf_avx512_lib = static_library('iavf_avx512_lib',
|
|
|
|
'iavf_rxtx_vec_avx512.c',
|
|
|
|
dependencies: [static_rte_ethdev,
|
|
|
|
static_rte_kvargs, static_rte_hash],
|
|
|
|
include_directories: includes,
|
|
|
|
c_args: avx512_args)
|
|
|
|
objs += iavf_avx512_lib.extract_objects('iavf_rxtx_vec_avx512.c')
|
|
|
|
endif
|
2018-09-19 10:04:17 +00:00
|
|
|
endif
|
2020-10-30 08:40:30 +00:00
|
|
|
|
|
|
|
headers = files('rte_pmd_iavf.h')
|