diff options
author | Benjamin Herrenschmidt <benh@kernel.crashing.org> | 2009-12-09 01:14:38 -0500 |
---|---|---|
committer | Benjamin Herrenschmidt <benh@kernel.crashing.org> | 2009-12-09 01:14:38 -0500 |
commit | bcd6acd51f3d4d1ada201e9bc5c40a31d6d80c71 (patch) | |
tree | 2f6dffd2d3e4dd67355a224de7e7a960335a92fd /drivers/net/ifb.c | |
parent | 11c34c7deaeeebcee342cbc35e1bb2a6711b2431 (diff) | |
parent | 3ff6a468b45b5dfeb0e903e56f4eb27d34b2437c (diff) |
Merge commit 'origin/master' into next
Conflicts:
include/linux/kvm.h
Diffstat (limited to 'drivers/net/ifb.c')
-rw-r--r-- | drivers/net/ifb.c | 10 |
1 files changed, 6 insertions, 4 deletions
diff --git a/drivers/net/ifb.c b/drivers/net/ifb.c index 030913f8bd26..f4081c0a2d9c 100644 --- a/drivers/net/ifb.c +++ b/drivers/net/ifb.c | |||
@@ -98,14 +98,16 @@ static void ri_tasklet(unsigned long dev) | |||
98 | stats->tx_packets++; | 98 | stats->tx_packets++; |
99 | stats->tx_bytes +=skb->len; | 99 | stats->tx_bytes +=skb->len; |
100 | 100 | ||
101 | skb->dev = dev_get_by_index(&init_net, skb->iif); | 101 | rcu_read_lock(); |
102 | skb->dev = dev_get_by_index_rcu(&init_net, skb->skb_iif); | ||
102 | if (!skb->dev) { | 103 | if (!skb->dev) { |
104 | rcu_read_unlock(); | ||
103 | dev_kfree_skb(skb); | 105 | dev_kfree_skb(skb); |
104 | stats->tx_dropped++; | 106 | stats->tx_dropped++; |
105 | break; | 107 | break; |
106 | } | 108 | } |
107 | dev_put(skb->dev); | 109 | rcu_read_unlock(); |
108 | skb->iif = _dev->ifindex; | 110 | skb->skb_iif = _dev->ifindex; |
109 | 111 | ||
110 | if (from & AT_EGRESS) { | 112 | if (from & AT_EGRESS) { |
111 | dp->st_rx_frm_egr++; | 113 | dp->st_rx_frm_egr++; |
@@ -170,7 +172,7 @@ static netdev_tx_t ifb_xmit(struct sk_buff *skb, struct net_device *dev) | |||
170 | stats->rx_packets++; | 172 | stats->rx_packets++; |
171 | stats->rx_bytes+=skb->len; | 173 | stats->rx_bytes+=skb->len; |
172 | 174 | ||
173 | if (!(from & (AT_INGRESS|AT_EGRESS)) || !skb->iif) { | 175 | if (!(from & (AT_INGRESS|AT_EGRESS)) || !skb->skb_iif) { |
174 | dev_kfree_skb(skb); | 176 | dev_kfree_skb(skb); |
175 | stats->rx_dropped++; | 177 | stats->rx_dropped++; |
176 | return NETDEV_TX_OK; | 178 | return NETDEV_TX_OK; |