Merge branch 'dev_kfree_skb_any'

Eric W. Biederman says:

====================
Using dev_kfree_skb_any for functions called in multiple contexts

This patchset should be an uncontroversial set of changes to change
dev_kfree_skb to dev_kfree_skb_any for code paths that are called in
hard irq contexts in addition to other contexts.  netpoll is the reason
this code gets called in multiple contexts.

There is more coming but these changes are a good starting place, and
stand on their own.

Since the last round changes to the rx path have been removed netpoll
will changed to avoid that.
====================

Signed-off-by: David S. Miller <davem@davemloft.net>
Acked-by: Eric Dumazet <edumazet@google.com>
This commit is contained in:
David S. Miller 2014-03-12 16:22:20 -04:00
commit 8a83d9396a
12 changed files with 30 additions and 30 deletions

View File

@ -2479,7 +2479,7 @@ int bond_3ad_xmit_xor(struct sk_buff *skb, struct net_device *dev)
return NETDEV_TX_OK; return NETDEV_TX_OK;
err_free: err_free:
/* no suitable interface, frame not sent */ /* no suitable interface, frame not sent */
kfree_skb(skb); dev_kfree_skb_any(skb);
goto out; goto out;
} }

View File

@ -1464,7 +1464,7 @@ int bond_alb_xmit(struct sk_buff *skb, struct net_device *bond_dev)
} }
/* no suitable interface, frame not sent */ /* no suitable interface, frame not sent */
kfree_skb(skb); dev_kfree_skb_any(skb);
out: out:
return NETDEV_TX_OK; return NETDEV_TX_OK;
} }

View File

@ -3548,7 +3548,7 @@ static void bond_xmit_slave_id(struct bonding *bond, struct sk_buff *skb, int sl
} }
} }
/* no slave that can tx has been found */ /* no slave that can tx has been found */
kfree_skb(skb); dev_kfree_skb_any(skb);
} }
/** /**
@ -3624,7 +3624,7 @@ static int bond_xmit_activebackup(struct sk_buff *skb, struct net_device *bond_d
if (slave) if (slave)
bond_dev_queue_xmit(bond, skb, slave->dev); bond_dev_queue_xmit(bond, skb, slave->dev);
else else
kfree_skb(skb); dev_kfree_skb_any(skb);
return NETDEV_TX_OK; return NETDEV_TX_OK;
} }
@ -3667,7 +3667,7 @@ static int bond_xmit_broadcast(struct sk_buff *skb, struct net_device *bond_dev)
if (slave && IS_UP(slave->dev) && slave->link == BOND_LINK_UP) if (slave && IS_UP(slave->dev) && slave->link == BOND_LINK_UP)
bond_dev_queue_xmit(bond, skb, slave->dev); bond_dev_queue_xmit(bond, skb, slave->dev);
else else
kfree_skb(skb); dev_kfree_skb_any(skb);
return NETDEV_TX_OK; return NETDEV_TX_OK;
} }
@ -3754,7 +3754,7 @@ static netdev_tx_t __bond_start_xmit(struct sk_buff *skb, struct net_device *dev
pr_err("%s: Error: Unknown bonding mode %d\n", pr_err("%s: Error: Unknown bonding mode %d\n",
dev->name, bond->params.mode); dev->name, bond->params.mode);
WARN_ON_ONCE(1); WARN_ON_ONCE(1);
kfree_skb(skb); dev_kfree_skb_any(skb);
return NETDEV_TX_OK; return NETDEV_TX_OK;
} }
} }
@ -3775,7 +3775,7 @@ static netdev_tx_t bond_start_xmit(struct sk_buff *skb, struct net_device *dev)
if (bond_has_slaves(bond)) if (bond_has_slaves(bond))
ret = __bond_start_xmit(skb, dev); ret = __bond_start_xmit(skb, dev);
else else
kfree_skb(skb); dev_kfree_skb_any(skb);
rcu_read_unlock(); rcu_read_unlock();
return ret; return ret;

View File

@ -2885,7 +2885,7 @@ bnx2_tx_int(struct bnx2 *bp, struct bnx2_napi *bnapi, int budget)
sw_cons = BNX2_NEXT_TX_BD(sw_cons); sw_cons = BNX2_NEXT_TX_BD(sw_cons);
tx_bytes += skb->len; tx_bytes += skb->len;
dev_kfree_skb(skb); dev_kfree_skb_any(skb);
tx_pkt++; tx_pkt++;
if (tx_pkt == budget) if (tx_pkt == budget)
break; break;
@ -6604,7 +6604,7 @@ bnx2_start_xmit(struct sk_buff *skb, struct net_device *dev)
mapping = dma_map_single(&bp->pdev->dev, skb->data, len, PCI_DMA_TODEVICE); mapping = dma_map_single(&bp->pdev->dev, skb->data, len, PCI_DMA_TODEVICE);
if (dma_mapping_error(&bp->pdev->dev, mapping)) { if (dma_mapping_error(&bp->pdev->dev, mapping)) {
dev_kfree_skb(skb); dev_kfree_skb_any(skb);
return NETDEV_TX_OK; return NETDEV_TX_OK;
} }
@ -6697,7 +6697,7 @@ bnx2_start_xmit(struct sk_buff *skb, struct net_device *dev)
PCI_DMA_TODEVICE); PCI_DMA_TODEVICE);
} }
dev_kfree_skb(skb); dev_kfree_skb_any(skb);
return NETDEV_TX_OK; return NETDEV_TX_OK;
} }

View File

@ -6593,7 +6593,7 @@ static void tg3_tx(struct tg3_napi *tnapi)
pkts_compl++; pkts_compl++;
bytes_compl += skb->len; bytes_compl += skb->len;
dev_kfree_skb(skb); dev_kfree_skb_any(skb);
if (unlikely(tx_bug)) { if (unlikely(tx_bug)) {
tg3_tx_recover(tp); tg3_tx_recover(tp);
@ -6924,7 +6924,7 @@ static int tg3_rx(struct tg3_napi *tnapi, int budget)
if (len > (tp->dev->mtu + ETH_HLEN) && if (len > (tp->dev->mtu + ETH_HLEN) &&
skb->protocol != htons(ETH_P_8021Q)) { skb->protocol != htons(ETH_P_8021Q)) {
dev_kfree_skb(skb); dev_kfree_skb_any(skb);
goto drop_it_no_recycle; goto drop_it_no_recycle;
} }
@ -7807,7 +7807,7 @@ static int tigon3_dma_hwbug_workaround(struct tg3_napi *tnapi,
PCI_DMA_TODEVICE); PCI_DMA_TODEVICE);
/* Make sure the mapping succeeded */ /* Make sure the mapping succeeded */
if (pci_dma_mapping_error(tp->pdev, new_addr)) { if (pci_dma_mapping_error(tp->pdev, new_addr)) {
dev_kfree_skb(new_skb); dev_kfree_skb_any(new_skb);
ret = -1; ret = -1;
} else { } else {
u32 save_entry = *entry; u32 save_entry = *entry;
@ -7822,13 +7822,13 @@ static int tigon3_dma_hwbug_workaround(struct tg3_napi *tnapi,
new_skb->len, base_flags, new_skb->len, base_flags,
mss, vlan)) { mss, vlan)) {
tg3_tx_skb_unmap(tnapi, save_entry, -1); tg3_tx_skb_unmap(tnapi, save_entry, -1);
dev_kfree_skb(new_skb); dev_kfree_skb_any(new_skb);
ret = -1; ret = -1;
} }
} }
} }
dev_kfree_skb(skb); dev_kfree_skb_any(skb);
*pskb = new_skb; *pskb = new_skb;
return ret; return ret;
} }
@ -7871,7 +7871,7 @@ static int tg3_tso_bug(struct tg3 *tp, struct sk_buff *skb)
} while (segs); } while (segs);
tg3_tso_bug_end: tg3_tso_bug_end:
dev_kfree_skb(skb); dev_kfree_skb_any(skb);
return NETDEV_TX_OK; return NETDEV_TX_OK;
} }
@ -8093,7 +8093,7 @@ static netdev_tx_t tg3_start_xmit(struct sk_buff *skb, struct net_device *dev)
tg3_tx_skb_unmap(tnapi, tnapi->tx_prod, --i); tg3_tx_skb_unmap(tnapi, tnapi->tx_prod, --i);
tnapi->tx_buffers[tnapi->tx_prod].skb = NULL; tnapi->tx_buffers[tnapi->tx_prod].skb = NULL;
drop: drop:
dev_kfree_skb(skb); dev_kfree_skb_any(skb);
drop_nofree: drop_nofree:
tp->tx_dropped++; tp->tx_dropped++;
return NETDEV_TX_OK; return NETDEV_TX_OK;

View File

@ -1919,7 +1919,7 @@ static u16 be_tx_compl_process(struct be_adapter *adapter,
queue_tail_inc(txq); queue_tail_inc(txq);
} while (cur_index != last_index); } while (cur_index != last_index);
kfree_skb(sent_skb); dev_kfree_skb_any(sent_skb);
return num_wrbs; return num_wrbs;
} }

View File

@ -2192,13 +2192,13 @@ static int gfar_start_xmit(struct sk_buff *skb, struct net_device *dev)
skb_new = skb_realloc_headroom(skb, fcb_len); skb_new = skb_realloc_headroom(skb, fcb_len);
if (!skb_new) { if (!skb_new) {
dev->stats.tx_errors++; dev->stats.tx_errors++;
kfree_skb(skb); dev_kfree_skb_any(skb);
return NETDEV_TX_OK; return NETDEV_TX_OK;
} }
if (skb->sk) if (skb->sk)
skb_set_owner_w(skb_new, skb->sk); skb_set_owner_w(skb_new, skb->sk);
consume_skb(skb); dev_consume_skb_any(skb);
skb = skb_new; skb = skb_new;
} }

View File

@ -1521,12 +1521,12 @@ ixgb_xmit_frame(struct sk_buff *skb, struct net_device *netdev)
int tso; int tso;
if (test_bit(__IXGB_DOWN, &adapter->flags)) { if (test_bit(__IXGB_DOWN, &adapter->flags)) {
dev_kfree_skb(skb); dev_kfree_skb_any(skb);
return NETDEV_TX_OK; return NETDEV_TX_OK;
} }
if (skb->len <= 0) { if (skb->len <= 0) {
dev_kfree_skb(skb); dev_kfree_skb_any(skb);
return NETDEV_TX_OK; return NETDEV_TX_OK;
} }
@ -1543,7 +1543,7 @@ ixgb_xmit_frame(struct sk_buff *skb, struct net_device *netdev)
tso = ixgb_tso(adapter, skb); tso = ixgb_tso(adapter, skb);
if (tso < 0) { if (tso < 0) {
dev_kfree_skb(skb); dev_kfree_skb_any(skb);
return NETDEV_TX_OK; return NETDEV_TX_OK;
} }

View File

@ -314,7 +314,7 @@ static u32 mlx4_en_free_tx_desc(struct mlx4_en_priv *priv,
} }
} }
} }
dev_kfree_skb(skb); dev_kfree_skb_any(skb);
return tx_info->nr_txbb; return tx_info->nr_txbb;
} }

View File

@ -899,7 +899,7 @@ static netdev_tx_t cp_start_xmit (struct sk_buff *skb,
return NETDEV_TX_OK; return NETDEV_TX_OK;
out_dma_error: out_dma_error:
kfree_skb(skb); dev_kfree_skb_any(skb);
cp->dev->stats.tx_dropped++; cp->dev->stats.tx_dropped++;
goto out_unlock; goto out_unlock;
} }

View File

@ -1717,9 +1717,9 @@ static netdev_tx_t rtl8139_start_xmit (struct sk_buff *skb,
if (len < ETH_ZLEN) if (len < ETH_ZLEN)
memset(tp->tx_buf[entry], 0, ETH_ZLEN); memset(tp->tx_buf[entry], 0, ETH_ZLEN);
skb_copy_and_csum_dev(skb, tp->tx_buf[entry]); skb_copy_and_csum_dev(skb, tp->tx_buf[entry]);
dev_kfree_skb(skb); dev_kfree_skb_any(skb);
} else { } else {
dev_kfree_skb(skb); dev_kfree_skb_any(skb);
dev->stats.tx_dropped++; dev->stats.tx_dropped++;
return NETDEV_TX_OK; return NETDEV_TX_OK;
} }

View File

@ -5834,7 +5834,7 @@ static void rtl8169_tx_clear_range(struct rtl8169_private *tp, u32 start,
tp->TxDescArray + entry); tp->TxDescArray + entry);
if (skb) { if (skb) {
tp->dev->stats.tx_dropped++; tp->dev->stats.tx_dropped++;
dev_kfree_skb(skb); dev_kfree_skb_any(skb);
tx_skb->skb = NULL; tx_skb->skb = NULL;
} }
} }
@ -6059,7 +6059,7 @@ static netdev_tx_t rtl8169_start_xmit(struct sk_buff *skb,
err_dma_1: err_dma_1:
rtl8169_unmap_tx_skb(d, tp->tx_skb + entry, txd); rtl8169_unmap_tx_skb(d, tp->tx_skb + entry, txd);
err_dma_0: err_dma_0:
dev_kfree_skb(skb); dev_kfree_skb_any(skb);
err_update_stats: err_update_stats:
dev->stats.tx_dropped++; dev->stats.tx_dropped++;
return NETDEV_TX_OK; return NETDEV_TX_OK;
@ -6142,7 +6142,7 @@ static void rtl_tx(struct net_device *dev, struct rtl8169_private *tp)
tp->tx_stats.packets++; tp->tx_stats.packets++;
tp->tx_stats.bytes += tx_skb->skb->len; tp->tx_stats.bytes += tx_skb->skb->len;
u64_stats_update_end(&tp->tx_stats.syncp); u64_stats_update_end(&tp->tx_stats.syncp);
dev_kfree_skb(tx_skb->skb); dev_kfree_skb_any(tx_skb->skb);
tx_skb->skb = NULL; tx_skb->skb = NULL;
} }
dirty_tx++; dirty_tx++;