8a6ff33d6d
Add the vectorized version of the no-scatter Rx handler. It aims to process 8 descriptors per loop using AVX2 SIMD instructions. This handler is in its own file enic_rxtx_vec_avx2.c, and makefile and meson.build are modified to compile it when the compiler supports AVX2. Under ideal conditions, the vectorized handler reduces cycles/packet by more than 30%, when compared against the no-scatter Rx handler. Most implementation ideas come from i40e's AVX2 based handler, so credit goes to its authors. At this point, the new handler is meant for field trials, and is not selected by default. So add a new devarg enable-avx2-rx to allow the user to request the use of the new handler. When enable-avx2-rx=1, the driver will consider using the new handler. Also update the guide doc and introduce the vectorized handler. Signed-off-by: Hyong Youb Kim <hyonkim@cisco.com> Reviewed-by: John Daley <johndale@cisco.com>
36 lines
1.1 KiB
Meson
36 lines
1.1 KiB
Meson
# SPDX-License-Identifier: BSD-3-Clause
|
|
# Copyright(c) 2018 Cisco Systems, Inc.
|
|
|
|
sources = files(
|
|
'base/vnic_cq.c',
|
|
'base/vnic_dev.c',
|
|
'base/vnic_intr.c',
|
|
'base/vnic_rq.c',
|
|
'base/vnic_rss.c',
|
|
'base/vnic_wq.c',
|
|
'enic_clsf.c',
|
|
'enic_ethdev.c',
|
|
'enic_flow.c',
|
|
'enic_main.c',
|
|
'enic_res.c',
|
|
'enic_rxtx.c',
|
|
)
|
|
deps += ['hash']
|
|
includes += include_directories('base')
|
|
|
|
# The current implementation assumes 64-bit pointers
|
|
if dpdk_conf.has('RTE_MACHINE_CPUFLAG_AVX2') and cc.sizeof('void *') == 8
|
|
sources += files('enic_rxtx_vec_avx2.c')
|
|
# Build the avx2 handler if the compiler supports it, even though 'machine'
|
|
# does not. This is to support users who build for the min supported machine
|
|
# and need to run the binary on newer CPUs too.
|
|
# This part is from i40e meson.build
|
|
elif cc.has_argument('-mavx2') and cc.sizeof('void *') == 8
|
|
enic_avx2_lib = static_library('enic_avx2_lib',
|
|
'enic_rxtx_vec_avx2.c',
|
|
dependencies: [static_rte_ethdev, static_rte_bus_pci],
|
|
include_directories: includes,
|
|
c_args: [cflags, '-mavx2'])
|
|
objs += enic_avx2_lib.extract_objects('enic_rxtx_vec_avx2.c')
|
|
endif
|