diff options
-rw-r--r-- | drivers/net/wireless/ath/ath5k/Kconfig | 8 | ||||
-rw-r--r-- | drivers/net/wireless/ath/ath5k/Makefile | 2 | ||||
-rw-r--r-- | drivers/net/wireless/ath/ath5k/ath5k.h | 5 | ||||
-rw-r--r-- | drivers/net/wireless/ath/ath5k/base.c | 5 | ||||
-rw-r--r-- | drivers/net/wireless/ath/ath5k/base.h | 2 | ||||
-rw-r--r-- | drivers/net/wireless/ath/ath5k/rfkill.c | 12 |
6 files changed, 8 insertions, 26 deletions
diff --git a/drivers/net/wireless/ath/ath5k/Kconfig b/drivers/net/wireless/ath/ath5k/Kconfig index 4863f4bbf768..509b6f94f73b 100644 --- a/drivers/net/wireless/ath/ath5k/Kconfig +++ b/drivers/net/wireless/ath/ath5k/Kconfig | |||
@@ -39,11 +39,3 @@ config ATH5K_DEBUG | |||
39 | 39 | ||
40 | modprobe ath5k debug=0x00000400 | 40 | modprobe ath5k debug=0x00000400 |
41 | 41 | ||
42 | config ATH5K_RFKILL | ||
43 | bool "Atheros 5xxx rfkill support" | ||
44 | depends on ATH5K | ||
45 | default y | ||
46 | ---help--- | ||
47 | Include support for enabling/disabling WiFi via rfkill switch | ||
48 | with Atheros 5xxx cards | ||
49 | |||
diff --git a/drivers/net/wireless/ath/ath5k/Makefile b/drivers/net/wireless/ath/ath5k/Makefile index f1e281c5a213..090dc6d268a3 100644 --- a/drivers/net/wireless/ath/ath5k/Makefile +++ b/drivers/net/wireless/ath/ath5k/Makefile | |||
@@ -11,6 +11,6 @@ ath5k-y += reset.o | |||
11 | ath5k-y += attach.o | 11 | ath5k-y += attach.o |
12 | ath5k-y += base.o | 12 | ath5k-y += base.o |
13 | ath5k-y += led.o | 13 | ath5k-y += led.o |
14 | ath5k-y += rfkill.o | ||
14 | ath5k-$(CONFIG_ATH5K_DEBUG) += debug.o | 15 | ath5k-$(CONFIG_ATH5K_DEBUG) += debug.o |
15 | ath5k-$(CONFIG_ATH5K_RFKILL) += rfkill.o | ||
16 | obj-$(CONFIG_ATH5K) += ath5k.o | 16 | obj-$(CONFIG_ATH5K) += ath5k.o |
diff --git a/drivers/net/wireless/ath/ath5k/ath5k.h b/drivers/net/wireless/ath/ath5k/ath5k.h index 4c84e308763c..6358233bac99 100644 --- a/drivers/net/wireless/ath/ath5k/ath5k.h +++ b/drivers/net/wireless/ath/ath5k/ath5k.h | |||
@@ -1257,13 +1257,8 @@ extern int ath5k_hw_set_gpio(struct ath5k_hw *ah, u32 gpio, u32 val); | |||
1257 | extern void ath5k_hw_set_gpio_intr(struct ath5k_hw *ah, unsigned int gpio, u32 interrupt_level); | 1257 | extern void ath5k_hw_set_gpio_intr(struct ath5k_hw *ah, unsigned int gpio, u32 interrupt_level); |
1258 | 1258 | ||
1259 | /* rfkill Functions */ | 1259 | /* rfkill Functions */ |
1260 | #ifdef CONFIG_ATH5K_RFKILL | ||
1261 | extern void ath5k_rfkill_hw_start(struct ath5k_hw *ah); | 1260 | extern void ath5k_rfkill_hw_start(struct ath5k_hw *ah); |
1262 | extern void ath5k_rfkill_hw_stop(struct ath5k_hw *ah); | 1261 | extern void ath5k_rfkill_hw_stop(struct ath5k_hw *ah); |
1263 | #else | ||
1264 | static inline void ath5k_rfkill_hw_start(struct ath5k_hw *ah) {} | ||
1265 | static inline void ath5k_rfkill_hw_stop(struct ath5k_hw *ah) {} | ||
1266 | #endif | ||
1267 | 1262 | ||
1268 | /* Misc functions */ | 1263 | /* Misc functions */ |
1269 | int ath5k_hw_set_capabilities(struct ath5k_hw *ah); | 1264 | int ath5k_hw_set_capabilities(struct ath5k_hw *ah); |
diff --git a/drivers/net/wireless/ath/ath5k/base.c b/drivers/net/wireless/ath/ath5k/base.c index f55675c23f2e..55f7de09d134 100644 --- a/drivers/net/wireless/ath/ath5k/base.c +++ b/drivers/net/wireless/ath/ath5k/base.c | |||
@@ -2530,12 +2530,9 @@ ath5k_intr(int irq, void *dev_id) | |||
2530 | */ | 2530 | */ |
2531 | ath5k_hw_update_mib_counters(ah, &sc->ll_stats); | 2531 | ath5k_hw_update_mib_counters(ah, &sc->ll_stats); |
2532 | } | 2532 | } |
2533 | #ifdef CONFIG_ATH5K_RFKILL | ||
2534 | if (status & AR5K_INT_GPIO) | 2533 | if (status & AR5K_INT_GPIO) |
2535 | { | ||
2536 | tasklet_schedule(&sc->rf_kill.toggleq); | 2534 | tasklet_schedule(&sc->rf_kill.toggleq); |
2537 | } | 2535 | |
2538 | #endif | ||
2539 | } | 2536 | } |
2540 | } while (ath5k_hw_is_intr_pending(ah) && --counter > 0); | 2537 | } while (ath5k_hw_is_intr_pending(ah) && --counter > 0); |
2541 | 2538 | ||
diff --git a/drivers/net/wireless/ath/ath5k/base.h b/drivers/net/wireless/ath/ath5k/base.h index 7a0ecdd9c258..f9b7f2f819b7 100644 --- a/drivers/net/wireless/ath/ath5k/base.h +++ b/drivers/net/wireless/ath/ath5k/base.h | |||
@@ -177,9 +177,7 @@ struct ath5k_softc { | |||
177 | struct tasklet_struct txtq; /* tx intr tasklet */ | 177 | struct tasklet_struct txtq; /* tx intr tasklet */ |
178 | struct ath5k_led tx_led; /* tx led */ | 178 | struct ath5k_led tx_led; /* tx led */ |
179 | 179 | ||
180 | #ifdef CONFIG_ATH5K_RFKILL | ||
181 | struct ath5k_rfkill rf_kill; | 180 | struct ath5k_rfkill rf_kill; |
182 | #endif | ||
183 | 181 | ||
184 | spinlock_t block; /* protects beacon */ | 182 | spinlock_t block; /* protects beacon */ |
185 | struct tasklet_struct beacontq; /* beacon intr tasklet */ | 183 | struct tasklet_struct beacontq; /* beacon intr tasklet */ |
diff --git a/drivers/net/wireless/ath/ath5k/rfkill.c b/drivers/net/wireless/ath/ath5k/rfkill.c index 492ada92db56..41a877b73fce 100644 --- a/drivers/net/wireless/ath/ath5k/rfkill.c +++ b/drivers/net/wireless/ath/ath5k/rfkill.c | |||
@@ -56,10 +56,12 @@ static inline void ath5k_rfkill_enable(struct ath5k_softc *sc) | |||
56 | static inline void ath5k_rfkill_set_intr(struct ath5k_softc *sc, bool enable) | 56 | static inline void ath5k_rfkill_set_intr(struct ath5k_softc *sc, bool enable) |
57 | { | 57 | { |
58 | struct ath5k_hw *ah = sc->ah; | 58 | struct ath5k_hw *ah = sc->ah; |
59 | u32 curval; | ||
60 | |||
59 | ath5k_hw_set_gpio_input(ah, sc->rf_kill.gpio); | 61 | ath5k_hw_set_gpio_input(ah, sc->rf_kill.gpio); |
60 | ah->ah_gpio[0] = ath5k_hw_get_gpio(ah, sc->rf_kill.gpio); | 62 | curval = ath5k_hw_get_gpio(ah, sc->rf_kill.gpio); |
61 | ath5k_hw_set_gpio_intr(ah, sc->rf_kill.gpio, enable ? | 63 | ath5k_hw_set_gpio_intr(ah, sc->rf_kill.gpio, enable ? |
62 | !!ah->ah_gpio[0] : !ah->ah_gpio[0]); | 64 | !!curval : !curval); |
63 | } | 65 | } |
64 | 66 | ||
65 | static bool | 67 | static bool |
@@ -97,9 +99,8 @@ ath5k_rfkill_hw_start(struct ath5k_hw *ah) | |||
97 | ath5k_rfkill_disable(sc); | 99 | ath5k_rfkill_disable(sc); |
98 | 100 | ||
99 | /* enable interrupt for rfkill switch */ | 101 | /* enable interrupt for rfkill switch */ |
100 | if (AR5K_EEPROM_HDR_RFKILL(ah->ah_capabilities.cap_eeprom.ee_header)) { | 102 | if (AR5K_EEPROM_HDR_RFKILL(ah->ah_capabilities.cap_eeprom.ee_header)) |
101 | ath5k_rfkill_set_intr(sc, true); | 103 | ath5k_rfkill_set_intr(sc, true); |
102 | } | ||
103 | } | 104 | } |
104 | 105 | ||
105 | 106 | ||
@@ -109,9 +110,8 @@ ath5k_rfkill_hw_stop(struct ath5k_hw *ah) | |||
109 | struct ath5k_softc *sc = ah->ah_sc; | 110 | struct ath5k_softc *sc = ah->ah_sc; |
110 | 111 | ||
111 | /* disable interrupt for rfkill switch */ | 112 | /* disable interrupt for rfkill switch */ |
112 | if (AR5K_EEPROM_HDR_RFKILL(ah->ah_capabilities.cap_eeprom.ee_header)) { | 113 | if (AR5K_EEPROM_HDR_RFKILL(ah->ah_capabilities.cap_eeprom.ee_header)) |
113 | ath5k_rfkill_set_intr(sc, false); | 114 | ath5k_rfkill_set_intr(sc, false); |
114 | } | ||
115 | 115 | ||
116 | tasklet_kill(&sc->rf_kill.toggleq); | 116 | tasklet_kill(&sc->rf_kill.toggleq); |
117 | 117 | ||