net: Avoid overwriting valid skb->napi_id
authorAmritha Nambiar <amritha.nambiar@intel.com>
Thu, 18 Jun 2020 21:22:15 +0000 (14:22 -0700)
committerDavid S. Miller <davem@davemloft.net>
Sun, 21 Jun 2020 00:30:59 +0000 (17:30 -0700)
commit78e57f152c001eed0321ba4413a07c9e33e753e6
treef60573a1f94c76ae442d12a3ca27130ac79a3f07
parent8eaf8d99409009b7ab7853f3ac603928458c2022
net: Avoid overwriting valid skb->napi_id

This will be useful to allow busy poll for tunneled traffic. In case of
busy poll for sessions over tunnels, the underlying physical device's
queues need to be polled.

Tunnels schedule NAPI either via netif_rx() for backlog queue or
schedule the gro_cell_poll(). netif_rx() propagates the valid skb->napi_id
to the socket. OTOH, gro_cell_poll() stamps the skb->napi_id again by
calling skb_mark_napi_id() with the tunnel NAPI which is not a busy poll
candidate. This was preventing tunneled traffic to use busy poll. A valid
NAPI ID in the skb indicates it was already marked for busy poll by a
NAPI driver and hence needs to be copied into the socket.

Signed-off-by: Amritha Nambiar <amritha.nambiar@intel.com>
Reviewed-by: Eric Dumazet <edumazet@google.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
include/net/busy_poll.h