netpoll: Add drop checks to all entry points
The netpoll entry checks are required to ensure that we don't receive normal packets when invoked via netpoll. Unfortunately it only ever worked for the netif_receive_skb/netif_rx entry points. The VLAN (and subsequently GRO) entry point didn't have the check and therefore can trigger all sorts of weird problems. This patch adds the netpoll check to all entry points. I'm still uneasy with receiving at all under netpoll (which apparently is only used by the out-of-tree kdump code). The reason is it is perfectly legal to receive all data including headers into highmem if netpoll is off, but if you try to do that with netpoll on and someone gets a printk in an IRQ handler you're going to get a nice BUG_ON. Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
18963caaf5
commit
4ead443163
|
@ -1,12 +1,16 @@
|
|||
#include <linux/skbuff.h>
|
||||
#include <linux/netdevice.h>
|
||||
#include <linux/if_vlan.h>
|
||||
#include <linux/netpoll.h>
|
||||
#include "vlan.h"
|
||||
|
||||
/* VLAN rx hw acceleration helper. This acts like netif_{rx,receive_skb}(). */
|
||||
int __vlan_hwaccel_rx(struct sk_buff *skb, struct vlan_group *grp,
|
||||
u16 vlan_tci, int polling)
|
||||
{
|
||||
if (netpoll_rx(skb))
|
||||
return NET_RX_DROP;
|
||||
|
||||
if (skb_bond_should_drop(skb))
|
||||
goto drop;
|
||||
|
||||
|
@ -100,6 +104,9 @@ int vlan_gro_receive(struct napi_struct *napi, struct vlan_group *grp,
|
|||
{
|
||||
int err = NET_RX_SUCCESS;
|
||||
|
||||
if (netpoll_receive_skb(skb))
|
||||
return NET_RX_DROP;
|
||||
|
||||
switch (vlan_gro_common(napi, grp, vlan_tci, skb)) {
|
||||
case -1:
|
||||
return netif_receive_skb(skb);
|
||||
|
@ -126,6 +133,9 @@ int vlan_gro_frags(struct napi_struct *napi, struct vlan_group *grp,
|
|||
if (!skb)
|
||||
goto out;
|
||||
|
||||
if (netpoll_receive_skb(skb))
|
||||
goto out;
|
||||
|
||||
err = NET_RX_SUCCESS;
|
||||
|
||||
switch (vlan_gro_common(napi, grp, vlan_tci, skb)) {
|
||||
|
|
|
@ -2488,6 +2488,9 @@ static int __napi_gro_receive(struct napi_struct *napi, struct sk_buff *skb)
|
|||
|
||||
int napi_gro_receive(struct napi_struct *napi, struct sk_buff *skb)
|
||||
{
|
||||
if (netpoll_receive_skb(skb))
|
||||
return NET_RX_DROP;
|
||||
|
||||
switch (__napi_gro_receive(napi, skb)) {
|
||||
case -1:
|
||||
return netif_receive_skb(skb);
|
||||
|
@ -2558,6 +2561,9 @@ int napi_gro_frags(struct napi_struct *napi, struct napi_gro_fraginfo *info)
|
|||
if (!skb)
|
||||
goto out;
|
||||
|
||||
if (netpoll_receive_skb(skb))
|
||||
goto out;
|
||||
|
||||
err = NET_RX_SUCCESS;
|
||||
|
||||
switch (__napi_gro_receive(napi, skb)) {
|
||||
|
|
Loading…
Reference in New Issue