diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2008-10-16 14:26:26 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2008-10-16 14:26:26 -0400 |
commit | cb23832e3987a02428a274c8f259336f706b17e9 (patch) | |
tree | 0ab4c8aeafacaed9a4261f4ad46fdbe04121df8c /drivers/net/wireless/spectrum_cs.c | |
parent | 8ef50901d3c619127858b7d7f614fcab45e09d6b (diff) | |
parent | 8fa0b315fc0c1a414da1371f1fc39523a657c192 (diff) |
Merge git://git.kernel.org/pub/scm/linux/kernel/git/davem/net-2.6
* git://git.kernel.org/pub/scm/linux/kernel/git/davem/net-2.6: (26 commits)
decnet: Fix compiler warning in dn_dev.c
IPV6: Fix default gateway criteria wrt. HIGH/LOW preference radv option
net/802/fc.c: Fix compilation warnings
netns: correct mib stats in ip6_route_me_harder()
netns: fix net_generic array leak
rt2x00: fix regression introduced by "mac80211: free up 2 bytes in skb->cb"
rtl8187: Add USB ID for Belkin F5D7050 with RTL8187B chip
p54usb: Device ID updates
mac80211: fixme for kernel-doc
ath9k/mac80211: disallow fragmentation in ath9k, report to userspace
libertas : Remove unused variable warning for "old_channel" from cmd.c
mac80211: Fix scan RX processing oops
orinoco: fix unsafe locking in spectrum_cs_suspend
orinoco: fix unsafe locking in orinoco_cs_resume
cfg80211: fix debugfs error handling
mac80211: fix debugfs netdev rename
iwlwifi: fix ct kill configuration for 5350
mac80211: fix HT information element parsing
p54: Fix compilation problem on PPC
mac80211: fix debugfs lockup
...
Diffstat (limited to 'drivers/net/wireless/spectrum_cs.c')
-rw-r--r-- | drivers/net/wireless/spectrum_cs.c | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/drivers/net/wireless/spectrum_cs.c b/drivers/net/wireless/spectrum_cs.c index b0c71c3be467..852789ad34b3 100644 --- a/drivers/net/wireless/spectrum_cs.c +++ b/drivers/net/wireless/spectrum_cs.c | |||
@@ -426,10 +426,11 @@ spectrum_cs_suspend(struct pcmcia_device *link) | |||
426 | { | 426 | { |
427 | struct net_device *dev = link->priv; | 427 | struct net_device *dev = link->priv; |
428 | struct orinoco_private *priv = netdev_priv(dev); | 428 | struct orinoco_private *priv = netdev_priv(dev); |
429 | unsigned long flags; | ||
429 | int err = 0; | 430 | int err = 0; |
430 | 431 | ||
431 | /* Mark the device as stopped, to block IO until later */ | 432 | /* Mark the device as stopped, to block IO until later */ |
432 | spin_lock(&priv->lock); | 433 | spin_lock_irqsave(&priv->lock, flags); |
433 | 434 | ||
434 | err = __orinoco_down(dev); | 435 | err = __orinoco_down(dev); |
435 | if (err) | 436 | if (err) |
@@ -439,7 +440,7 @@ spectrum_cs_suspend(struct pcmcia_device *link) | |||
439 | netif_device_detach(dev); | 440 | netif_device_detach(dev); |
440 | priv->hw_unavailable++; | 441 | priv->hw_unavailable++; |
441 | 442 | ||
442 | spin_unlock(&priv->lock); | 443 | spin_unlock_irqrestore(&priv->lock, flags); |
443 | 444 | ||
444 | return err; | 445 | return err; |
445 | } | 446 | } |