diff options
author | Luis R. Rodriguez <lrodriguez@atheros.com> | 2009-09-13 03:03:27 -0400 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2009-10-07 16:39:28 -0400 |
commit | b002a4a950e41326310795cf4a0c74d0e90fa70a (patch) | |
tree | 57057bf14397542cab1c5c558727e9cec6e379eb | |
parent | 13b81559200b8e54473e5b140323cbb5f2bb21c0 (diff) |
atheros: add ieee80211_hw to ath_common
Make use of it on hw code in ath9k to avoid
using the ath9k ath_softc.
Signed-off-by: Luis R. Rodriguez <lrodriguez@atheros.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
-rw-r--r-- | drivers/net/wireless/ath/ath.h | 2 | ||||
-rw-r--r-- | drivers/net/wireless/ath/ath5k/base.c | 1 | ||||
-rw-r--r-- | drivers/net/wireless/ath/ath9k/ani.c | 4 | ||||
-rw-r--r-- | drivers/net/wireless/ath/ath9k/calib.c | 4 | ||||
-rw-r--r-- | drivers/net/wireless/ath/ath9k/hw.c | 8 | ||||
-rw-r--r-- | drivers/net/wireless/ath/ath9k/hw.h | 1 | ||||
-rw-r--r-- | drivers/net/wireless/ath/ath9k/main.c | 1 |
7 files changed, 13 insertions, 8 deletions
diff --git a/drivers/net/wireless/ath/ath.h b/drivers/net/wireless/ath/ath.h index 0582ee4a493e..88654138f999 100644 --- a/drivers/net/wireless/ath/ath.h +++ b/drivers/net/wireless/ath/ath.h | |||
@@ -19,6 +19,7 @@ | |||
19 | 19 | ||
20 | #include <linux/skbuff.h> | 20 | #include <linux/skbuff.h> |
21 | #include <linux/if_ether.h> | 21 | #include <linux/if_ether.h> |
22 | #include <net/mac80211.h> | ||
22 | 23 | ||
23 | static const u8 ath_bcast_mac[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff}; | 24 | static const u8 ath_bcast_mac[ETH_ALEN] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff}; |
24 | 25 | ||
@@ -46,6 +47,7 @@ struct ath_ops { | |||
46 | 47 | ||
47 | struct ath_common { | 48 | struct ath_common { |
48 | void *ah; | 49 | void *ah; |
50 | struct ieee80211_hw *hw; | ||
49 | u16 cachelsz; | 51 | u16 cachelsz; |
50 | u16 curaid; | 52 | u16 curaid; |
51 | u8 macaddr[ETH_ALEN]; | 53 | u8 macaddr[ETH_ALEN]; |
diff --git a/drivers/net/wireless/ath/ath5k/base.c b/drivers/net/wireless/ath/ath5k/base.c index 1abbebc2bd26..70831f1bcf04 100644 --- a/drivers/net/wireless/ath/ath5k/base.c +++ b/drivers/net/wireless/ath/ath5k/base.c | |||
@@ -594,6 +594,7 @@ ath5k_pci_probe(struct pci_dev *pdev, | |||
594 | common = ath5k_hw_common(sc->ah); | 594 | common = ath5k_hw_common(sc->ah); |
595 | common->ops = &ath5k_common_ops; | 595 | common->ops = &ath5k_common_ops; |
596 | common->ah = sc->ah; | 596 | common->ah = sc->ah; |
597 | common->hw = hw; | ||
597 | common->cachelsz = csz << 2; /* convert to bytes */ | 598 | common->cachelsz = csz << 2; /* convert to bytes */ |
598 | 599 | ||
599 | /* Initialize device */ | 600 | /* Initialize device */ |
diff --git a/drivers/net/wireless/ath/ath9k/ani.c b/drivers/net/wireless/ath/ath9k/ani.c index e4f9559d25b6..9682c49ab454 100644 --- a/drivers/net/wireless/ath/ath9k/ani.c +++ b/drivers/net/wireless/ath/ath9k/ani.c | |||
@@ -271,7 +271,7 @@ static void ath9k_ani_restart(struct ath_hw *ah) | |||
271 | 271 | ||
272 | static void ath9k_hw_ani_ofdm_err_trigger(struct ath_hw *ah) | 272 | static void ath9k_hw_ani_ofdm_err_trigger(struct ath_hw *ah) |
273 | { | 273 | { |
274 | struct ieee80211_conf *conf = &ah->ah_sc->hw->conf; | 274 | struct ieee80211_conf *conf = &ath9k_hw_common(ah)->hw->conf; |
275 | struct ar5416AniState *aniState; | 275 | struct ar5416AniState *aniState; |
276 | int32_t rssi; | 276 | int32_t rssi; |
277 | 277 | ||
@@ -343,7 +343,7 @@ static void ath9k_hw_ani_ofdm_err_trigger(struct ath_hw *ah) | |||
343 | 343 | ||
344 | static void ath9k_hw_ani_cck_err_trigger(struct ath_hw *ah) | 344 | static void ath9k_hw_ani_cck_err_trigger(struct ath_hw *ah) |
345 | { | 345 | { |
346 | struct ieee80211_conf *conf = &ah->ah_sc->hw->conf; | 346 | struct ieee80211_conf *conf = &ath9k_hw_common(ah)->hw->conf; |
347 | struct ar5416AniState *aniState; | 347 | struct ar5416AniState *aniState; |
348 | int32_t rssi; | 348 | int32_t rssi; |
349 | 349 | ||
diff --git a/drivers/net/wireless/ath/ath9k/calib.c b/drivers/net/wireless/ath/ath9k/calib.c index 30106f49322a..bdd4a19f32be 100644 --- a/drivers/net/wireless/ath/ath9k/calib.c +++ b/drivers/net/wireless/ath/ath9k/calib.c | |||
@@ -278,7 +278,7 @@ static bool ath9k_hw_per_calibration(struct ath_hw *ah, | |||
278 | static bool ath9k_hw_iscal_supported(struct ath_hw *ah, | 278 | static bool ath9k_hw_iscal_supported(struct ath_hw *ah, |
279 | enum ath9k_cal_types calType) | 279 | enum ath9k_cal_types calType) |
280 | { | 280 | { |
281 | struct ieee80211_conf *conf = &ah->ah_sc->hw->conf; | 281 | struct ieee80211_conf *conf = &ath9k_hw_common(ah)->hw->conf; |
282 | 282 | ||
283 | switch (calType & ah->supp_cals) { | 283 | switch (calType & ah->supp_cals) { |
284 | case IQ_MISMATCH_CAL: /* Both 2 GHz and 5 GHz support OFDM */ | 284 | case IQ_MISMATCH_CAL: /* Both 2 GHz and 5 GHz support OFDM */ |
@@ -555,7 +555,7 @@ static void ath9k_hw_adc_dccal_calibrate(struct ath_hw *ah, u8 numChains) | |||
555 | /* This is done for the currently configured channel */ | 555 | /* This is done for the currently configured channel */ |
556 | bool ath9k_hw_reset_calvalid(struct ath_hw *ah) | 556 | bool ath9k_hw_reset_calvalid(struct ath_hw *ah) |
557 | { | 557 | { |
558 | struct ieee80211_conf *conf = &ah->ah_sc->hw->conf; | 558 | struct ieee80211_conf *conf = &ath9k_hw_common(ah)->hw->conf; |
559 | struct ath9k_cal_list *currCal = ah->cal_list_curr; | 559 | struct ath9k_cal_list *currCal = ah->cal_list_curr; |
560 | 560 | ||
561 | if (!ah->curchan) | 561 | if (!ah->curchan) |
diff --git a/drivers/net/wireless/ath/ath9k/hw.c b/drivers/net/wireless/ath/ath9k/hw.c index 5fb94fa45ff9..177244b2b6b9 100644 --- a/drivers/net/wireless/ath/ath9k/hw.c +++ b/drivers/net/wireless/ath/ath9k/hw.c | |||
@@ -40,7 +40,7 @@ static void ath9k_hw_spur_mitigate(struct ath_hw *ah, struct ath9k_channel *chan | |||
40 | 40 | ||
41 | static u32 ath9k_hw_mac_usec(struct ath_hw *ah, u32 clks) | 41 | static u32 ath9k_hw_mac_usec(struct ath_hw *ah, u32 clks) |
42 | { | 42 | { |
43 | struct ieee80211_conf *conf = &ah->ah_sc->hw->conf; | 43 | struct ieee80211_conf *conf = &ath9k_hw_common(ah)->hw->conf; |
44 | 44 | ||
45 | if (!ah->curchan) /* should really check for CCK instead */ | 45 | if (!ah->curchan) /* should really check for CCK instead */ |
46 | return clks / ATH9K_CLOCK_RATE_CCK; | 46 | return clks / ATH9K_CLOCK_RATE_CCK; |
@@ -52,7 +52,7 @@ static u32 ath9k_hw_mac_usec(struct ath_hw *ah, u32 clks) | |||
52 | 52 | ||
53 | static u32 ath9k_hw_mac_to_usec(struct ath_hw *ah, u32 clks) | 53 | static u32 ath9k_hw_mac_to_usec(struct ath_hw *ah, u32 clks) |
54 | { | 54 | { |
55 | struct ieee80211_conf *conf = &ah->ah_sc->hw->conf; | 55 | struct ieee80211_conf *conf = &ath9k_hw_common(ah)->hw->conf; |
56 | 56 | ||
57 | if (conf_is_ht40(conf)) | 57 | if (conf_is_ht40(conf)) |
58 | return ath9k_hw_mac_usec(ah, clks) / 2; | 58 | return ath9k_hw_mac_usec(ah, clks) / 2; |
@@ -62,7 +62,7 @@ static u32 ath9k_hw_mac_to_usec(struct ath_hw *ah, u32 clks) | |||
62 | 62 | ||
63 | static u32 ath9k_hw_mac_clks(struct ath_hw *ah, u32 usecs) | 63 | static u32 ath9k_hw_mac_clks(struct ath_hw *ah, u32 usecs) |
64 | { | 64 | { |
65 | struct ieee80211_conf *conf = &ah->ah_sc->hw->conf; | 65 | struct ieee80211_conf *conf = &ath9k_hw_common(ah)->hw->conf; |
66 | 66 | ||
67 | if (!ah->curchan) /* should really check for CCK instead */ | 67 | if (!ah->curchan) /* should really check for CCK instead */ |
68 | return usecs *ATH9K_CLOCK_RATE_CCK; | 68 | return usecs *ATH9K_CLOCK_RATE_CCK; |
@@ -73,7 +73,7 @@ static u32 ath9k_hw_mac_clks(struct ath_hw *ah, u32 usecs) | |||
73 | 73 | ||
74 | static u32 ath9k_hw_mac_to_clks(struct ath_hw *ah, u32 usecs) | 74 | static u32 ath9k_hw_mac_to_clks(struct ath_hw *ah, u32 usecs) |
75 | { | 75 | { |
76 | struct ieee80211_conf *conf = &ah->ah_sc->hw->conf; | 76 | struct ieee80211_conf *conf = &ath9k_hw_common(ah)->hw->conf; |
77 | 77 | ||
78 | if (conf_is_ht40(conf)) | 78 | if (conf_is_ht40(conf)) |
79 | return ath9k_hw_mac_clks(ah, usecs) * 2; | 79 | return ath9k_hw_mac_clks(ah, usecs) * 2; |
diff --git a/drivers/net/wireless/ath/ath9k/hw.h b/drivers/net/wireless/ath/ath9k/hw.h index ae351a183416..1f6dece9b007 100644 --- a/drivers/net/wireless/ath/ath9k/hw.h +++ b/drivers/net/wireless/ath/ath9k/hw.h | |||
@@ -437,6 +437,7 @@ struct ath_gen_timer_table { | |||
437 | }; | 437 | }; |
438 | 438 | ||
439 | struct ath_hw { | 439 | struct ath_hw { |
440 | struct ieee80211_hw *hw; | ||
440 | struct ath_softc *ah_sc; | 441 | struct ath_softc *ah_sc; |
441 | struct ath_common common; | 442 | struct ath_common common; |
442 | struct ath9k_hw_version hw_version; | 443 | struct ath9k_hw_version hw_version; |
diff --git a/drivers/net/wireless/ath/ath9k/main.c b/drivers/net/wireless/ath/ath9k/main.c index d752b167f5ad..693555728eab 100644 --- a/drivers/net/wireless/ath/ath9k/main.c +++ b/drivers/net/wireless/ath/ath9k/main.c | |||
@@ -1571,6 +1571,7 @@ static int ath_init_softc(u16 devid, struct ath_softc *sc, u16 subsysid) | |||
1571 | common = ath9k_hw_common(ah); | 1571 | common = ath9k_hw_common(ah); |
1572 | common->ops = &ath9k_common_ops; | 1572 | common->ops = &ath9k_common_ops; |
1573 | common->ah = ah; | 1573 | common->ah = ah; |
1574 | common->hw = sc->hw; | ||
1574 | 1575 | ||
1575 | /* | 1576 | /* |
1576 | * Cache line size is used to size and align various | 1577 | * Cache line size is used to size and align various |