libertas: remove tx_timeout handler
authorDaniel Drake <dsd@laptop.org>
Mon, 2 May 2011 20:38:16 +0000 (21:38 +0100)
committerJohn W. Linville <linville@tuxdriver.com>
Thu, 5 May 2011 18:59:05 +0000 (14:59 -0400)
As described at http://marc.info/?l=linux-netdev&m=130428493104730&w=2
libertas frequently generates spurious tx timeouts, because the tx
queue is brought down for extended periods during scanning. The net
layer takes a look and incorrectly assumes the queue has been down for
several seconds, and generates a tx_timeout.

One way to fix this is to bump the trans_start counter while scanning
so that the network layer knows that the device is still alive, but
I think the tx_timeout handler is implemented wrongly here and not of
any real use, so I vote to remove it.

As explained at http://marc.info/?l=linux-wireless&m=130430311115755&w=2
the watchdog is primarily meant to deal with lockup on the hardware TX
path (detected by the tx queue being stopped for an extended period of
time), but this is unlikely to happen with libertas. In this case, the tx
queue is stopped only while waiting for lbs_thread to send the queued frame
to the driver, and lbs_thread wakes up the queue immediately after, even
if the frame could not be sent correctly.

So, the only hardware-related possibility that this catches is if
hw_host_to_card hangs - this is something I have never seen. And if it
were to happen, nothing done by lbs_tx_timeout would actually wake up
lbs_thread any quicker than otherwise.

Removing this oddly-behaving spuriously-firing tx_timeout handler should
fix an occasional kernel crash during resume
(http://dev.laptop.org/ticket/10748)

Signed-off-by: Daniel Drake <dsd@laptop.org>
Acked-by: Dan Williams <dcbw@redhat.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
drivers/net/wireless/libertas/main.c

index ed57cf863b6981230b372810cfc8ef948acac738..ae02e6b7bc41d6c4aec357b0c05549e1673d875c 100644 (file)
@@ -149,28 +149,6 @@ static int lbs_eth_stop(struct net_device *dev)
        return 0;
 }
 
-static void lbs_tx_timeout(struct net_device *dev)
-{
-       struct lbs_private *priv = dev->ml_priv;
-
-       lbs_deb_enter(LBS_DEB_TX);
-
-       lbs_pr_err("tx watch dog timeout\n");
-
-       dev->trans_start = jiffies; /* prevent tx timeout */
-
-       if (priv->currenttxskb)
-               lbs_send_tx_feedback(priv, 0);
-
-       /* XX: Shouldn't we also call into the hw-specific driver
-          to kick it somehow? */
-       lbs_host_to_card_done(priv);
-
-       /* FIXME: reset the card */
-
-       lbs_deb_leave(LBS_DEB_TX);
-}
-
 void lbs_host_to_card_done(struct lbs_private *priv)
 {
        unsigned long flags;
@@ -791,7 +769,6 @@ static const struct net_device_ops lbs_netdev_ops = {
        .ndo_stop               = lbs_eth_stop,
        .ndo_start_xmit         = lbs_hard_start_xmit,
        .ndo_set_mac_address    = lbs_set_mac_address,
-       .ndo_tx_timeout         = lbs_tx_timeout,
        .ndo_set_multicast_list = lbs_set_multicast_list,
        .ndo_change_mtu         = eth_change_mtu,
        .ndo_validate_addr      = eth_validate_addr,