linux/drivers/net/ethernet/intel/i40e
Magnus Karlsson 705639572e i40e: need_wakeup flag might not be set for Tx
The need_wakeup flag for Tx might not be set for AF_XDP sockets that
are only used to send packets. This happens if there is at least one
outstanding packet that has not been completed by the hardware and we
get that corresponding completion (which will not generate an
interrupt since interrupts are disabled in the napi poll loop) between
the time we stopped processing the Tx completions and interrupts are
enabled again. In this case, the need_wakeup flag will have been
cleared at the end of the Tx completion processing as we believe we
will get an interrupt from the outstanding completion at a later point
in time. But if this completion interrupt occurs before interrupts
are enable, we lose it and should at that point really have set the
need_wakeup flag since there are no more outstanding completions that
can generate an interrupt to continue the processing. When this
happens, user space will see a Tx queue need_wakeup of 0 and skip
issuing a syscall, which means will never get into the Tx processing
again and we have a deadlock.

This patch introduces a quick fix for this issue by just setting the
need_wakeup flag for Tx to 1 all the time. I am working on a proper
fix for this that will toggle the flag appropriately, but it is more
challenging than I anticipated and I am afraid that this patch will
not be completed before the merge window closes, therefore this easier
fix for now. This fix has a negative performance impact in the range
of 0% to 4%. Towards the higher end of the scale if you have driver
and application on the same core and issue a lot of packets, and
towards no negative impact if you use two cores, lower transmission
speeds and/or a workload that also receives packets.

Signed-off-by: Magnus Karlsson <magnus.karlsson@intel.com>
Tested-by: Andrew Bowers <andrewx.bowers@intel.com>
Signed-off-by: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
2019-11-08 16:11:48 -08:00
..
i40e.h i40e: use BIT macro to specify the cloud filter field flags 2019-09-11 09:10:46 -07:00
i40e_adminq.c i40e: Add drop mode parameter to set mac config 2019-08-22 13:24:13 -07:00
i40e_adminq.h
i40e_adminq_cmd.h igb/igc: use ktime accessors for skb->tstamp 2019-11-08 16:10:51 -08:00
i40e_alloc.h
i40e_client.c i40e: Use struct_size() in kzalloc() 2019-05-04 17:34:43 -07:00
i40e_client.h
i40e_common.c i40e: Fix for ethtool -m issue on X722 NIC 2019-11-08 16:10:51 -08:00
i40e_dcb.c i40e: Persistent LLDP support 2019-08-22 13:24:14 -07:00
i40e_dcb.h i40e: Persistent LLDP support 2019-08-22 13:24:14 -07:00
i40e_dcb_nl.c
i40e_ddp.c i40e: Implement DDP support in i40e driver 2019-04-16 15:10:21 -07:00
i40e_debugfs.c i40e: Remove EMPR traces from debugfs facility 2019-09-09 11:36:43 -07:00
i40e_devids.h i40e: Add support for X710 B/P & SFP+ cards 2019-05-04 17:24:48 -07:00
i40e_diag.c
i40e_diag.h
i40e_ethtool.c i40e: Check if transceiver implements DDM before access 2019-08-22 13:24:13 -07:00
i40e_hmc.c i40e: Implement debug macro hw_dbg using dev_dbg 2019-09-09 11:22:20 -07:00
i40e_hmc.h
i40e_lan_hmc.c i40e: fix hw_dbg usage in i40e_hmc_get_object_va 2019-09-09 10:18:18 -07:00
i40e_lan_hmc.h
i40e_main.c i40e: Fix message for other card without FEC. 2019-09-11 09:10:46 -07:00
i40e_nvm.c i40e: Persistent LLDP support 2019-08-22 13:24:14 -07:00
i40e_osdep.h i40e: Implement debug macro hw_dbg using dev_dbg 2019-09-09 11:22:20 -07:00
i40e_prototype.h i40e: Persistent LLDP support 2019-08-22 13:24:14 -07:00
i40e_ptp.c i40e: use ktime_get_real_ts64 instead of ktime_to_timespec64 2019-09-11 09:10:45 -07:00
i40e_register.h i40e: check_recovery_mode had wrong if statement 2019-08-22 13:24:13 -07:00
i40e_status.h
i40e_trace.h
i40e_txrx.c net: Use skb_frag_off accessors 2019-07-30 14:21:32 -07:00
i40e_txrx.h net: Use skb accessors in network drivers 2019-07-22 20:47:56 -07:00
i40e_txrx_common.h
i40e_type.h i40e: Persistent LLDP support 2019-08-22 13:24:14 -07:00
i40e_virtchnl_pf.c i40e: clear __I40E_VIRTCHNL_OP_PENDING on invalid min Tx rate 2019-09-11 09:10:46 -07:00
i40e_virtchnl_pf.h i40e: don't report link up for a VF who hasn't enabled queues 2019-08-05 11:42:05 -07:00
i40e_xsk.c i40e: need_wakeup flag might not be set for Tx 2019-11-08 16:11:48 -08:00
i40e_xsk.h xsk: replace ndo_xsk_async_xmit with ndo_xsk_wakeup 2019-08-17 23:07:31 +02:00
Makefile i40e: Implement DDP support in i40e driver 2019-04-16 15:10:21 -07:00