aboutsummaryrefslogtreecommitdiff
path: root/drivers/platform/surface/aggregator/ssh_parser.c
diff options
context:
space:
mode:
authorTobias Waldekranz <[email protected]>2020-07-03 16:10:58 +0200
committerDavid S. Miller <[email protected]>2020-07-07 15:25:05 -0700
commit7cdaa4cc4bdfa252d515b307863f5a1972246dd6 (patch)
tree32cec9b7733825cc0f160c9964adb6ad651edbab /drivers/platform/surface/aggregator/ssh_parser.c
parent28b18e4eb515af7c6661c3995c6e3c34412c2874 (diff)
net: ethernet: fec: prevent tx starvation under high rx load
In the ISR, we poll the event register for the queues in need of service and then enter polled mode. After this point, the event register will never be read again until we exit polled mode. In a scenario where a UDP flow is routed back out through the same interface, i.e. "router-on-a-stick" we'll typically only see an rx queue event initially. Once we start to process the incoming flow we'll be locked polled mode, but we'll never clean the tx rings since that event is never caught. Eventually the netdev watchdog will trip, causing all buffers to be dropped and then the process starts over again. Rework the NAPI poll to keep trying to consome the entire budget as long as new events are coming in, making sure to service all rx/tx queues, in priority order, on each pass. Fixes: 4d494cdc92b3 ("net: fec: change data structure to support multiqueue") Signed-off-by: Tobias Waldekranz <[email protected]> Tested-by: Fugang Duan <[email protected]> Reviewed-by: Fugang Duan <[email protected]> Signed-off-by: David S. Miller <[email protected]>
Diffstat (limited to 'drivers/platform/surface/aggregator/ssh_parser.c')
0 files changed, 0 insertions, 0 deletions