* [PATCH] wimax/i2400m: fix erroneous NETDEV_TX_BUSY use
@ 2012-03-14 19:21 Eric Dumazet
2012-03-16 9:02 ` David Miller
0 siblings, 1 reply; 3+ messages in thread
From: Eric Dumazet @ 2012-03-14 19:21 UTC (permalink / raw)
To: David Miller; +Cc: netdev, Inaky Perez-Gonzalez
A driver start_xmit() method cannot free skb and return NETDEV_TX_BUSY,
since caller is going to reuse freed skb.
In fact netif_tx_stop_queue() / netif_stop_queue() is needed before
returning NETDEV_TX_BUSY or you can trigger a ksoftirqd fatal loop.
In case of memory allocation error, only safe way is to drop the packet
and return NETDEV_TX_OK
Also increments tx_dropped counter
Signed-off-by: Eric Dumazet <eric.dumazet@gmail.com>
Cc: Inaky Perez-Gonzalez <inaky.perez-gonzalez@intel.com>
---
drivers/net/wimax/i2400m/netdev.c | 30 +++++++++-------------------
1 file changed, 10 insertions(+), 20 deletions(-)
diff --git a/drivers/net/wimax/i2400m/netdev.c
b/drivers/net/wimax/i2400m/netdev.c
index 64a1106..63e4b70 100644
--- a/drivers/net/wimax/i2400m/netdev.c
+++ b/drivers/net/wimax/i2400m/netdev.c
@@ -367,38 +367,28 @@ netdev_tx_t i2400m_hard_start_xmit(struct sk_buff
*skb,
{
struct i2400m *i2400m = net_dev_to_i2400m(net_dev);
struct device *dev = i2400m_dev(i2400m);
- int result;
+ int result = -1;
d_fnstart(3, dev, "(skb %p net_dev %p)\n", skb, net_dev);
- if (skb_header_cloned(skb)) {
- /*
- * Make tcpdump/wireshark happy -- if they are
- * running, the skb is cloned and we will overwrite
- * the mac fields in i2400m_tx_prep_header. Expand
- * seems to fix this...
- */
- result = pskb_expand_head(skb, 0, 0, GFP_ATOMIC);
- if (result) {
- result = NETDEV_TX_BUSY;
- goto error_expand;
- }
- }
+
+ if (skb_header_cloned(skb) &&
+ pskb_expand_head(skb, 0, 0, GFP_ATOMIC))
+ goto drop;
if (i2400m->state == I2400M_SS_IDLE)
result = i2400m_net_wake_tx(i2400m, net_dev, skb);
else
result = i2400m_net_tx(i2400m, net_dev, skb);
- if (result < 0)
+ if (result < 0) {
+drop:
net_dev->stats.tx_dropped++;
- else {
+ } else {
net_dev->stats.tx_packets++;
net_dev->stats.tx_bytes += skb->len;
}
- result = NETDEV_TX_OK;
-error_expand:
- kfree_skb(skb);
+ dev_kfree_skb(skb);
d_fnend(3, dev, "(skb %p net_dev %p) = %d\n", skb, net_dev, result);
- return result;
+ return NETDEV_TX_OK;
}
^ permalink raw reply related [flat|nested] 3+ messages in thread
* Re: [PATCH] wimax/i2400m: fix erroneous NETDEV_TX_BUSY use
2012-03-14 19:21 [PATCH] wimax/i2400m: fix erroneous NETDEV_TX_BUSY use Eric Dumazet
@ 2012-03-16 9:02 ` David Miller
2012-03-16 14:17 ` Eric Dumazet
0 siblings, 1 reply; 3+ messages in thread
From: David Miller @ 2012-03-16 9:02 UTC (permalink / raw)
To: eric.dumazet; +Cc: netdev, inaky.perez-gonzalez
From: Eric Dumazet <eric.dumazet@gmail.com>
Date: Wed, 14 Mar 2012 12:21:44 -0700
> A driver start_xmit() method cannot free skb and return NETDEV_TX_BUSY,
> since caller is going to reuse freed skb.
>
> In fact netif_tx_stop_queue() / netif_stop_queue() is needed before
> returning NETDEV_TX_BUSY or you can trigger a ksoftirqd fatal loop.
>
> In case of memory allocation error, only safe way is to drop the packet
> and return NETDEV_TX_OK
>
> Also increments tx_dropped counter
>
> Signed-off-by: Eric Dumazet <eric.dumazet@gmail.com>
> Cc: Inaky Perez-Gonzalez <inaky.perez-gonzalez@intel.com>
Applied, but Eric:
> @@ -367,38 +367,28 @@ netdev_tx_t i2400m_hard_start_xmit(struct sk_buff
> *skb,
Your mailer chopped up that line and I had to fix it up.
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [PATCH] wimax/i2400m: fix erroneous NETDEV_TX_BUSY use
2012-03-16 9:02 ` David Miller
@ 2012-03-16 14:17 ` Eric Dumazet
0 siblings, 0 replies; 3+ messages in thread
From: Eric Dumazet @ 2012-03-16 14:17 UTC (permalink / raw)
To: David Miller; +Cc: netdev, inaky.perez-gonzalez
Le vendredi 16 mars 2012 à 02:02 -0700, David Miller a écrit :
> From: Eric Dumazet <eric.dumazet@gmail.com>
> Applied, but Eric:
>
> > @@ -367,38 +367,28 @@ netdev_tx_t i2400m_hard_start_xmit(struct sk_buff
> > *skb,
>
> Your mailer chopped up that line and I had to fix it up.
Oh sorry, thanks for taking care of this David.
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2012-03-16 14:17 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2012-03-14 19:21 [PATCH] wimax/i2400m: fix erroneous NETDEV_TX_BUSY use Eric Dumazet
2012-03-16 9:02 ` David Miller
2012-03-16 14:17 ` Eric Dumazet
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox