summaryrefslogtreecommitdiff
path: root/drivers/net/wireless/ath/ath9k/ar9003_phy.c
diff options
context:
space:
mode:
authorFelix Fietkau <nbd@openwrt.org>2010-04-15 21:38:34 (GMT)
committerJohn W. Linville <linville@tuxdriver.com>2010-04-16 19:43:23 (GMT)
commit317d33280c63f32bd84c49aacaaae047e981b441 (patch)
tree7a473c49289a5b26a189ecbfb2546d6ad1500283 /drivers/net/wireless/ath/ath9k/ar9003_phy.c
parentf7abf0c1958ab363874cad0d799a1bb43880145a (diff)
downloadlinux-fsl-qoriq-317d33280c63f32bd84c49aacaaae047e981b441.tar.xz
ath9k_hw: Implement PLL control on AR9003
Signed-off-by: Felix Fietkau <nbd@openwrt.org> Signed-off-by: Luis R. Rodriguez <lrodriguez@atheros.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net/wireless/ath/ath9k/ar9003_phy.c')
-rw-r--r--drivers/net/wireless/ath/ath9k/ar9003_phy.c23
1 files changed, 21 insertions, 2 deletions
diff --git a/drivers/net/wireless/ath/ath9k/ar9003_phy.c b/drivers/net/wireless/ath/ath9k/ar9003_phy.c
index f1632ab..9767265 100644
--- a/drivers/net/wireless/ath/ath9k/ar9003_phy.c
+++ b/drivers/net/wireless/ath/ath9k/ar9003_phy.c
@@ -112,8 +112,27 @@ static void ar9003_hw_spur_mitigate(struct ath_hw *ah,
static u32 ar9003_hw_compute_pll_control(struct ath_hw *ah,
struct ath9k_channel *chan)
{
- /* TODO */
- return 0;
+ u32 pll;
+
+ pll = SM(0x5, AR_RTC_9300_PLL_REFDIV);
+
+ if (chan && IS_CHAN_HALF_RATE(chan))
+ pll |= SM(0x1, AR_RTC_9300_PLL_CLKSEL);
+ else if (chan && IS_CHAN_QUARTER_RATE(chan))
+ pll |= SM(0x2, AR_RTC_9300_PLL_CLKSEL);
+
+ if (chan && IS_CHAN_5GHZ(chan)) {
+ pll |= SM(0x28, AR_RTC_9300_PLL_DIV);
+
+ /*
+ * When doing fast clock, set PLL to 0x142c
+ */
+ if (IS_CHAN_A_5MHZ_SPACED(chan))
+ pll = 0x142c;
+ } else
+ pll |= SM(0x2c, AR_RTC_9300_PLL_DIV);
+
+ return pll;
}
static void ar9003_hw_set_channel_regs(struct ath_hw *ah,