8bac78f826
When INTx is used, the interrupt handler needs to explicitly re-enable
interrupt in order to receive another one in future. The LSC interrupt
handler currently does not, and the link state never gets updated when
INTx is used (e.g. uio_pci_generic). Call rte_intr_ack() at the end of
the handler, to re-enable INTx.
Fixes: fefed3d1e6
("enic: new driver")
Cc: stable@dpdk.org
Signed-off-by: Hyong Youb Kim <hyonkim@cisco.com>
Reviewed-by: John Daley <johndale@cisco.com>
38 lines
1.2 KiB
Meson
38 lines
1.2 KiB
Meson
# SPDX-License-Identifier: BSD-3-Clause
|
|
# Copyright(c) 2018 Cisco Systems, Inc.
|
|
|
|
# Experimental APIs used: rte_intr_ack
|
|
cflags += ['-DALLOW_EXPERIMENTAL_API']
|
|
sources = files(
|
|
'base/vnic_cq.c',
|
|
'base/vnic_dev.c',
|
|
'base/vnic_intr.c',
|
|
'base/vnic_rq.c',
|
|
'base/vnic_wq.c',
|
|
'enic_clsf.c',
|
|
'enic_ethdev.c',
|
|
'enic_flow.c',
|
|
'enic_fm_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 dpdk_conf.get('RTE_ARCH_64')
|
|
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 dpdk_conf.get('RTE_ARCH_64')
|
|
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
|