f88b0b8922
The rule for indentation in Meson in DPDK is 4 spaces. Any tab should be flagged as an issue, let's extend the check and fix existing offenders. Fixes:4ad4b20a79
("drivers: change indentation in build files") Fixes:2457705e64
("crypto/cnxk: add driver skeleton") Fixes:634b731044
("app/testpmd: build on Windows") Fixes:3a6bfc37ea
("net/ice: support QoS config VF bandwidth in DCF") Fixes:8ef09fdc50
("build: add optional NUMA and CPU counts detection") Fixes:e1369718f5
("common/octeontx: enable build only on 64-bit Linux") Fixes:2b504721bf
("app/bbdev: enable la12xx") Fixes:6cc51b1293
("mem: instrument allocator for ASan") Fixes:c75542ae42
("crypto/ipsec_mb: introduce IPsec_mb framework") Fixes:918fd2f146
("crypto/ipsec_mb: move aesni_mb PMD") Fixes:746825e5c0
("crypto/ipsec_mb: move aesni_gcm PMD") Fixes:bc9ef81c42
("crypto/ipsec_mb: move kasumi PMD") Fixes:4f1cfda59a
("crypto/ipsec_mb: move snow3g PMD") Fixes:cde8df1bda
("crypto/ipsec_mb: move zuc PMD") Fixes:f166628854
("crypto/ipsec_mb: add chacha_poly PMD") Signed-off-by: David Marchand <david.marchand@redhat.com> Acked-by: Bruce Richardson <bruce.richardson@intel.com> Acked-by: Stephen Hemminger <stephen@networkplumber.org>
79 lines
2.5 KiB
Meson
79 lines
2.5 KiB
Meson
# SPDX-License-Identifier: BSD-3-Clause
|
|
# Copyright(c) 2018 Intel Corporation
|
|
|
|
subdir('base')
|
|
objs = [base_objs]
|
|
|
|
sources = files(
|
|
'ice_acl_filter.c',
|
|
'ice_ethdev.c',
|
|
'ice_fdir_filter.c',
|
|
'ice_generic_flow.c',
|
|
'ice_hash.c',
|
|
'ice_rxtx.c',
|
|
'ice_switch_filter.c',
|
|
)
|
|
|
|
deps += ['hash', 'net', 'common_iavf']
|
|
includes += include_directories('base', '../../common/iavf')
|
|
|
|
if arch_subdir == 'x86'
|
|
sources += files('ice_rxtx_vec_sse.c')
|
|
|
|
if is_windows and cc.get_id() != 'clang'
|
|
cflags += ['-fno-asynchronous-unwind-tables']
|
|
endif
|
|
|
|
# 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('ice_rxtx_vec_avx2.c')
|
|
elif cc.has_argument('-mavx2')
|
|
cflags += ['-DCC_AVX2_SUPPORT']
|
|
ice_avx2_lib = static_library('ice_avx2_lib',
|
|
'ice_rxtx_vec_avx2.c',
|
|
dependencies: [static_rte_ethdev, static_rte_kvargs, static_rte_hash],
|
|
include_directories: includes,
|
|
c_args: [cflags, '-mavx2'])
|
|
objs += ice_avx2_lib.extract_objects('ice_rxtx_vec_avx2.c')
|
|
endif
|
|
|
|
ice_avx512_cpu_support = (
|
|
cc.get_define('__AVX512F__', args: machine_args) != '' and
|
|
cc.get_define('__AVX512BW__', args: machine_args) != ''
|
|
)
|
|
|
|
ice_avx512_cc_support = (
|
|
not machine_args.contains('-mno-avx512f') and
|
|
cc.has_argument('-mavx512f') and
|
|
cc.has_argument('-mavx512bw')
|
|
)
|
|
|
|
if ice_avx512_cpu_support == true or ice_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
|
|
ice_avx512_lib = static_library('ice_avx512_lib',
|
|
'ice_rxtx_vec_avx512.c',
|
|
dependencies: [static_rte_ethdev,
|
|
static_rte_kvargs, static_rte_hash],
|
|
include_directories: includes,
|
|
c_args: avx512_args)
|
|
objs += ice_avx512_lib.extract_objects('ice_rxtx_vec_avx512.c')
|
|
endif
|
|
endif
|
|
|
|
sources += files(
|
|
'ice_dcf.c',
|
|
'ice_dcf_vf_representor.c',
|
|
'ice_dcf_ethdev.c',
|
|
'ice_dcf_parent.c',
|
|
'ice_dcf_sched.c',
|
|
)
|
|
|
|
headers = files('rte_pmd_ice.h')
|