diff options
-rw-r--r-- | drivers/net/wireless/ath/ath9k/ath9k.h | 33 | ||||
-rw-r--r-- | drivers/net/wireless/ath/ath9k/hw.c | 32 |
2 files changed, 34 insertions, 31 deletions
diff --git a/drivers/net/wireless/ath/ath9k/ath9k.h b/drivers/net/wireless/ath/ath9k/ath9k.h index d5084ddf44ff..90b6314a8169 100644 --- a/drivers/net/wireless/ath/ath9k/ath9k.h +++ b/drivers/net/wireless/ath/ath9k/ath9k.h | |||
@@ -697,36 +697,7 @@ void ath9k_wiphy_pause_all_forced(struct ath_softc *sc, | |||
697 | bool ath9k_wiphy_scanning(struct ath_softc *sc); | 697 | bool ath9k_wiphy_scanning(struct ath_softc *sc); |
698 | void ath9k_wiphy_work(struct work_struct *work); | 698 | void ath9k_wiphy_work(struct work_struct *work); |
699 | 699 | ||
700 | /* | 700 | void ath9k_iowrite32(struct ath_hw *ah, u32 reg_offset, u32 val); |
701 | * Read and write, they both share the same lock. We do this to serialize | 701 | unsigned int ath9k_ioread32(struct ath_hw *ah, u32 reg_offset); |
702 | * reads and writes on Atheros 802.11n PCI devices only. This is required | ||
703 | * as the FIFO on these devices can only accept sanely 2 requests. After | ||
704 | * that the device goes bananas. Serializing the reads/writes prevents this | ||
705 | * from happening. | ||
706 | */ | ||
707 | |||
708 | static inline void ath9k_iowrite32(struct ath_hw *ah, u32 reg_offset, u32 val) | ||
709 | { | ||
710 | if (ah->config.serialize_regmode == SER_REG_MODE_ON) { | ||
711 | unsigned long flags; | ||
712 | spin_lock_irqsave(&ah->ah_sc->sc_serial_rw, flags); | ||
713 | iowrite32(val, ah->ah_sc->mem + reg_offset); | ||
714 | spin_unlock_irqrestore(&ah->ah_sc->sc_serial_rw, flags); | ||
715 | } else | ||
716 | iowrite32(val, ah->ah_sc->mem + reg_offset); | ||
717 | } | ||
718 | |||
719 | static inline unsigned int ath9k_ioread32(struct ath_hw *ah, u32 reg_offset) | ||
720 | { | ||
721 | u32 val; | ||
722 | if (ah->config.serialize_regmode == SER_REG_MODE_ON) { | ||
723 | unsigned long flags; | ||
724 | spin_lock_irqsave(&ah->ah_sc->sc_serial_rw, flags); | ||
725 | val = ioread32(ah->ah_sc->mem + reg_offset); | ||
726 | spin_unlock_irqrestore(&ah->ah_sc->sc_serial_rw, flags); | ||
727 | } else | ||
728 | val = ioread32(ah->ah_sc->mem + reg_offset); | ||
729 | return val; | ||
730 | } | ||
731 | 702 | ||
732 | #endif /* ATH9K_H */ | 703 | #endif /* ATH9K_H */ |
diff --git a/drivers/net/wireless/ath/ath9k/hw.c b/drivers/net/wireless/ath/ath9k/hw.c index ec2a7a40b00d..02f40154e831 100644 --- a/drivers/net/wireless/ath/ath9k/hw.c +++ b/drivers/net/wireless/ath/ath9k/hw.c | |||
@@ -84,6 +84,38 @@ static u32 ath9k_hw_mac_to_clks(struct ath_hw *ah, u32 usecs) | |||
84 | return ath9k_hw_mac_clks(ah, usecs); | 84 | return ath9k_hw_mac_clks(ah, usecs); |
85 | } | 85 | } |
86 | 86 | ||
87 | /* | ||
88 | * Read and write, they both share the same lock. We do this to serialize | ||
89 | * reads and writes on Atheros 802.11n PCI devices only. This is required | ||
90 | * as the FIFO on these devices can only accept sanely 2 requests. After | ||
91 | * that the device goes bananas. Serializing the reads/writes prevents this | ||
92 | * from happening. | ||
93 | */ | ||
94 | |||
95 | void ath9k_iowrite32(struct ath_hw *ah, u32 reg_offset, u32 val) | ||
96 | { | ||
97 | if (ah->config.serialize_regmode == SER_REG_MODE_ON) { | ||
98 | unsigned long flags; | ||
99 | spin_lock_irqsave(&ah->ah_sc->sc_serial_rw, flags); | ||
100 | iowrite32(val, ah->ah_sc->mem + reg_offset); | ||
101 | spin_unlock_irqrestore(&ah->ah_sc->sc_serial_rw, flags); | ||
102 | } else | ||
103 | iowrite32(val, ah->ah_sc->mem + reg_offset); | ||
104 | } | ||
105 | |||
106 | unsigned int ath9k_ioread32(struct ath_hw *ah, u32 reg_offset) | ||
107 | { | ||
108 | u32 val; | ||
109 | if (ah->config.serialize_regmode == SER_REG_MODE_ON) { | ||
110 | unsigned long flags; | ||
111 | spin_lock_irqsave(&ah->ah_sc->sc_serial_rw, flags); | ||
112 | val = ioread32(ah->ah_sc->mem + reg_offset); | ||
113 | spin_unlock_irqrestore(&ah->ah_sc->sc_serial_rw, flags); | ||
114 | } else | ||
115 | val = ioread32(ah->ah_sc->mem + reg_offset); | ||
116 | return val; | ||
117 | } | ||
118 | |||
87 | bool ath9k_hw_wait(struct ath_hw *ah, u32 reg, u32 mask, u32 val, u32 timeout) | 119 | bool ath9k_hw_wait(struct ath_hw *ah, u32 reg, u32 mask, u32 val, u32 timeout) |
88 | { | 120 | { |
89 | int i; | 121 | int i; |