orinoco: Resume spectrum_cs in the same way as orinoco_cs
authorDavid Kilroy <kilroyd@googlemail.com>
Sat, 22 Nov 2008 10:37:27 +0000 (10:37 +0000)
committerJohn W. Linville <linville@tuxdriver.com>
Wed, 26 Nov 2008 14:47:46 +0000 (09:47 -0500)
Retrieval of external firmware has been resolved, and should work with
the standard orinoco resume algorithm.

This fixes an issue where priv->hw_unavailable indicates the card is
ready when firmware has not been loaded.

Signed-off by: David Kilroy <kilroyd@googlemail.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
drivers/net/wireless/orinoco/spectrum_cs.c

index 0bae3dcf9d5055b55205433a356720596704926d..a2764764c1c0112f6692b96e82765c2e311e462c 100644 (file)
@@ -450,10 +450,29 @@ spectrum_cs_resume(struct pcmcia_device *link)
 {
        struct net_device *dev = link->priv;
        struct orinoco_private *priv = netdev_priv(dev);
+       unsigned long flags;
+       int err;
+
+       err = orinoco_reinit_firmware(dev);
+       if (err) {
+               printk(KERN_ERR "%s: Error %d re-initializing firmware\n",
+                      dev->name, err);
+               return -EIO;
+       }
+
+       spin_lock_irqsave(&priv->lock, flags);
 
        netif_device_attach(dev);
        priv->hw_unavailable--;
-       schedule_work(&priv->reset_work);
+
+       if (priv->open && !priv->hw_unavailable) {
+               err = __orinoco_up(dev);
+               if (err)
+                       printk(KERN_ERR "%s: Error %d restarting card\n",
+                              dev->name, err);
+       }
+
+       spin_unlock_irqrestore(&priv->lock, flags);
 
        return 0;
 }