aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLuis R. Rodriguez <lrodriguez@atheros.com>2009-09-10 14:20:57 -0400
committerJohn W. Linville <linville@tuxdriver.com>2009-10-07 16:39:27 -0400
commitdb7197184802578314d974e4b2bc961bdcec8f8c (patch)
tree80b4436d96b2a0ef46ecba806592e7f6d6c71b8b
parent27c51f1a349f3e4eb9c1d6d3a548eafe1828cc7a (diff)
ath5k: move ath_common to ath5k_hw
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/ath5k/ath5k.h2
-rw-r--r--drivers/net/wireless/ath/ath5k/base.c21
-rw-r--r--drivers/net/wireless/ath/ath5k/base.h3
3 files changed, 16 insertions, 10 deletions
diff --git a/drivers/net/wireless/ath/ath5k/ath5k.h b/drivers/net/wireless/ath/ath5k/ath5k.h
index f46a92e78b32..fee16fdd9c5a 100644
--- a/drivers/net/wireless/ath/ath5k/ath5k.h
+++ b/drivers/net/wireless/ath/ath5k/ath5k.h
@@ -35,6 +35,7 @@
35 * TODO: Make a more generic struct (eg. add more stuff to ath5k_capabilities) 35 * TODO: Make a more generic struct (eg. add more stuff to ath5k_capabilities)
36 * and clean up common bits, then introduce set/get functions in eeprom.c */ 36 * and clean up common bits, then introduce set/get functions in eeprom.c */
37#include "eeprom.h" 37#include "eeprom.h"
38#include "../ath.h"
38 39
39/* PCI IDs */ 40/* PCI IDs */
40#define PCI_DEVICE_ID_ATHEROS_AR5210 0x0007 /* AR5210 */ 41#define PCI_DEVICE_ID_ATHEROS_AR5210 0x0007 /* AR5210 */
@@ -1020,6 +1021,7 @@ struct ath5k_capabilities {
1020/* TODO: Clean up and merge with ath5k_softc */ 1021/* TODO: Clean up and merge with ath5k_softc */
1021struct ath5k_hw { 1022struct ath5k_hw {
1022 u32 ah_magic; 1023 u32 ah_magic;
1024 struct ath_common common;
1023 1025
1024 struct ath5k_softc *ah_sc; 1026 struct ath5k_softc *ah_sc;
1025 void __iomem *ah_iobase; 1027 void __iomem *ah_iobase;
diff --git a/drivers/net/wireless/ath/ath5k/base.c b/drivers/net/wireless/ath/ath5k/base.c
index efee68c8b1ab..06fc893723fa 100644
--- a/drivers/net/wireless/ath/ath5k/base.c
+++ b/drivers/net/wireless/ath/ath5k/base.c
@@ -444,6 +444,7 @@ ath5k_pci_probe(struct pci_dev *pdev,
444{ 444{
445 void __iomem *mem; 445 void __iomem *mem;
446 struct ath5k_softc *sc; 446 struct ath5k_softc *sc;
447 struct ath_common *common;
447 struct ieee80211_hw *hw; 448 struct ieee80211_hw *hw;
448 int ret; 449 int ret;
449 u8 csz; 450 u8 csz;
@@ -547,7 +548,6 @@ ath5k_pci_probe(struct pci_dev *pdev,
547 __set_bit(ATH_STAT_INVALID, sc->status); 548 __set_bit(ATH_STAT_INVALID, sc->status);
548 549
549 sc->iobase = mem; /* So we can unmap it on detach */ 550 sc->iobase = mem; /* So we can unmap it on detach */
550 sc->common.cachelsz = csz << 2; /* convert to bytes */
551 sc->opmode = NL80211_IFTYPE_STATION; 551 sc->opmode = NL80211_IFTYPE_STATION;
552 sc->bintval = 1000; 552 sc->bintval = 1000;
553 mutex_init(&sc->lock); 553 mutex_init(&sc->lock);
@@ -572,6 +572,9 @@ ath5k_pci_probe(struct pci_dev *pdev,
572 goto err_irq; 572 goto err_irq;
573 } 573 }
574 574
575 common = ath5k_hw_common(sc->ah);
576 common->cachelsz = csz << 2; /* convert to bytes */
577
575 /* set up multi-rate retry capabilities */ 578 /* set up multi-rate retry capabilities */
576 if (sc->ah->ah_version == AR5K_AR5212) { 579 if (sc->ah->ah_version == AR5K_AR5212) {
577 hw->max_rates = 4; 580 hw->max_rates = 4;
@@ -718,7 +721,7 @@ static int ath5k_reg_notifier(struct wiphy *wiphy, struct regulatory_request *re
718{ 721{
719 struct ieee80211_hw *hw = wiphy_to_ieee80211_hw(wiphy); 722 struct ieee80211_hw *hw = wiphy_to_ieee80211_hw(wiphy);
720 struct ath5k_softc *sc = hw->priv; 723 struct ath5k_softc *sc = hw->priv;
721 struct ath_regulatory *regulatory = &sc->common.regulatory; 724 struct ath_regulatory *regulatory = ath5k_hw_regulatory(sc->ah);
722 725
723 return ath_reg_notifier_apply(wiphy, request, regulatory); 726 return ath_reg_notifier_apply(wiphy, request, regulatory);
724} 727}
@@ -728,7 +731,7 @@ ath5k_attach(struct pci_dev *pdev, struct ieee80211_hw *hw)
728{ 731{
729 struct ath5k_softc *sc = hw->priv; 732 struct ath5k_softc *sc = hw->priv;
730 struct ath5k_hw *ah = sc->ah; 733 struct ath5k_hw *ah = sc->ah;
731 struct ath_regulatory *regulatory = &sc->common.regulatory; 734 struct ath_regulatory *regulatory = ath5k_hw_regulatory(ah);
732 u8 mac[ETH_ALEN] = {}; 735 u8 mac[ETH_ALEN] = {};
733 int ret; 736 int ret;
734 737
@@ -1153,19 +1156,20 @@ ath5k_hw_to_driver_rix(struct ath5k_softc *sc, int hw_rix)
1153static 1156static
1154struct sk_buff *ath5k_rx_skb_alloc(struct ath5k_softc *sc, dma_addr_t *skb_addr) 1157struct sk_buff *ath5k_rx_skb_alloc(struct ath5k_softc *sc, dma_addr_t *skb_addr)
1155{ 1158{
1159 struct ath_common *common = ath5k_hw_common(sc->ah);
1156 struct sk_buff *skb; 1160 struct sk_buff *skb;
1157 1161
1158 /* 1162 /*
1159 * Allocate buffer with headroom_needed space for the 1163 * Allocate buffer with headroom_needed space for the
1160 * fake physical layer header at the start. 1164 * fake physical layer header at the start.
1161 */ 1165 */
1162 skb = ath_rxbuf_alloc(&sc->common, 1166 skb = ath_rxbuf_alloc(common,
1163 sc->rxbufsize + sc->common.cachelsz - 1, 1167 sc->rxbufsize + common->cachelsz - 1,
1164 GFP_ATOMIC); 1168 GFP_ATOMIC);
1165 1169
1166 if (!skb) { 1170 if (!skb) {
1167 ATH5K_ERR(sc, "can't alloc skbuff of size %u\n", 1171 ATH5K_ERR(sc, "can't alloc skbuff of size %u\n",
1168 sc->rxbufsize + sc->common.cachelsz - 1); 1172 sc->rxbufsize + common->cachelsz - 1);
1169 return NULL; 1173 return NULL;
1170 } 1174 }
1171 1175
@@ -1606,13 +1610,14 @@ static int
1606ath5k_rx_start(struct ath5k_softc *sc) 1610ath5k_rx_start(struct ath5k_softc *sc)
1607{ 1611{
1608 struct ath5k_hw *ah = sc->ah; 1612 struct ath5k_hw *ah = sc->ah;
1613 struct ath_common *common = ath5k_hw_common(ah);
1609 struct ath5k_buf *bf; 1614 struct ath5k_buf *bf;
1610 int ret; 1615 int ret;
1611 1616
1612 sc->rxbufsize = roundup(IEEE80211_MAX_LEN, sc->common.cachelsz); 1617 sc->rxbufsize = roundup(IEEE80211_MAX_LEN, common->cachelsz);
1613 1618
1614 ATH5K_DBG(sc, ATH5K_DEBUG_RESET, "cachelsz %u rxbufsize %u\n", 1619 ATH5K_DBG(sc, ATH5K_DEBUG_RESET, "cachelsz %u rxbufsize %u\n",
1615 sc->common.cachelsz, sc->rxbufsize); 1620 common->cachelsz, sc->rxbufsize);
1616 1621
1617 spin_lock_bh(&sc->rxbuflock); 1622 spin_lock_bh(&sc->rxbuflock);
1618 sc->rxlink = NULL; 1623 sc->rxlink = NULL;
diff --git a/drivers/net/wireless/ath/ath5k/base.h b/drivers/net/wireless/ath/ath5k/base.h
index a28c42f32c9d..005d25f2e130 100644
--- a/drivers/net/wireless/ath/ath5k/base.h
+++ b/drivers/net/wireless/ath/ath5k/base.h
@@ -115,7 +115,6 @@ struct ath5k_rfkill {
115 * associated with an instance of a device */ 115 * associated with an instance of a device */
116struct ath5k_softc { 116struct ath5k_softc {
117 struct pci_dev *pdev; /* for dma mapping */ 117 struct pci_dev *pdev; /* for dma mapping */
118 struct ath_common common;
119 void __iomem *iobase; /* address of the device */ 118 void __iomem *iobase; /* address of the device */
120 struct mutex lock; /* dev-level lock */ 119 struct mutex lock; /* dev-level lock */
121 struct ieee80211_tx_queue_stats tx_stats[AR5K_NUM_TX_QUEUES]; 120 struct ieee80211_tx_queue_stats tx_stats[AR5K_NUM_TX_QUEUES];
@@ -204,7 +203,7 @@ struct ath5k_softc {
204 203
205static inline struct ath_common *ath5k_hw_common(struct ath5k_hw *ah) 204static inline struct ath_common *ath5k_hw_common(struct ath5k_hw *ah)
206{ 205{
207 return &ah->ah_sc->common; 206 return &ah->common;
208} 207}
209 208
210static inline struct ath_regulatory *ath5k_hw_regulatory(struct ath5k_hw *ah) 209static inline struct ath_regulatory *ath5k_hw_regulatory(struct ath5k_hw *ah)