diff options
author | David S. Miller <davem@davemloft.net> | 2011-09-22 03:23:13 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2011-09-22 03:23:13 -0400 |
commit | 8decf868790b48a727d7e7ca164f2bcd3c1389c0 (patch) | |
tree | b759a5f861f842af7ea76f9011b579d06e9d5508 /net/core/neighbour.c | |
parent | 3fc72370186be2f9d4d6ef06d99e1caa5d92c564 (diff) | |
parent | d93dc5c4478c1fd5de85a3e8aece9aad7bbae044 (diff) |
Merge branch 'master' of github.com:davem330/net
Conflicts:
MAINTAINERS
drivers/net/Kconfig
drivers/net/ethernet/broadcom/bnx2x/bnx2x_link.c
drivers/net/ethernet/broadcom/tg3.c
drivers/net/wireless/iwlwifi/iwl-pci.c
drivers/net/wireless/iwlwifi/iwl-trans-tx-pcie.c
drivers/net/wireless/rt2x00/rt2800usb.c
drivers/net/wireless/wl12xx/main.c
Diffstat (limited to 'net/core/neighbour.c')
-rw-r--r-- | net/core/neighbour.c | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/net/core/neighbour.c b/net/core/neighbour.c index 4002261f20d1..43449649cf73 100644 --- a/net/core/neighbour.c +++ b/net/core/neighbour.c | |||
@@ -1331,11 +1331,15 @@ static void neigh_proxy_process(unsigned long arg) | |||
1331 | 1331 | ||
1332 | if (tdif <= 0) { | 1332 | if (tdif <= 0) { |
1333 | struct net_device *dev = skb->dev; | 1333 | struct net_device *dev = skb->dev; |
1334 | |||
1334 | __skb_unlink(skb, &tbl->proxy_queue); | 1335 | __skb_unlink(skb, &tbl->proxy_queue); |
1335 | if (tbl->proxy_redo && netif_running(dev)) | 1336 | if (tbl->proxy_redo && netif_running(dev)) { |
1337 | rcu_read_lock(); | ||
1336 | tbl->proxy_redo(skb); | 1338 | tbl->proxy_redo(skb); |
1337 | else | 1339 | rcu_read_unlock(); |
1340 | } else { | ||
1338 | kfree_skb(skb); | 1341 | kfree_skb(skb); |
1342 | } | ||
1339 | 1343 | ||
1340 | dev_put(dev); | 1344 | dev_put(dev); |
1341 | } else if (!sched_next || tdif < sched_next) | 1345 | } else if (!sched_next || tdif < sched_next) |