| Submitter | Eric Dumazet |
|---|---|
| Date | Jan. 24, 2010, 7:43 p.m. |
| Message ID | <4B5CA2CA.4040307@gmail.com> |
| Download | mbox | patch |
| Permalink | /patch/43601/ |
| State | Accepted |
| Delegated to: | David Miller |
| Headers | show |
Comments
From: Eric Dumazet <eric.dumazet@gmail.com> Date: Sun, 24 Jan 2010 20:43:06 +0100 > [PATCH] vlan: fix vlan_skb_recv() > > Bruno Prémont found commit 9793241fe92f7d930 > (vlan: Precise RX stats accounting) added a regression for non > hw accelerated vlans. > > [ 26.390576] BUG: unable to handle kernel NULL pointer dereference at (null) > [ 26.396369] IP: [<df856b89>] vlan_skb_recv+0x89/0x280 [8021q] > > vlan_dev_info() was used with original device, instead of > skb->dev. Also spotted by Américo Wang. > > Reported-By: Bruno Prémont <bonbons@linux-vserver.org> > Tested-By: Bruno Prémont <bonbons@linux-vserver.org> > Signed-off-by: Eric Dumazet <eric.dumazet@gmail.com> Applied, thanks everyone. -- To unsubscribe from this list: send the line "unsubscribe netdev" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
Patch
diff --git a/net/8021q/vlan_dev.c b/net/8021q/vlan_dev.c index b788978..c1b92ca 100644 --- a/net/8021q/vlan_dev.c +++ b/net/8021q/vlan_dev.c @@ -163,7 +163,7 @@ int vlan_skb_recv(struct sk_buff *skb, struct net_device *dev, goto err_unlock; } - rx_stats = per_cpu_ptr(vlan_dev_info(dev)->vlan_rx_stats, + rx_stats = per_cpu_ptr(vlan_dev_info(skb->dev)->vlan_rx_stats, smp_processor_id()); rx_stats->rx_packets++; rx_stats->rx_bytes += skb->len;