1 1.1 alc /* 2 1.1 alc * Copyright (c) 2002-2008 Sam Leffler, Errno Consulting 3 1.1 alc * Copyright (c) 2002-2008 Atheros Communications, Inc. 4 1.1 alc * 5 1.1 alc * Permission to use, copy, modify, and/or distribute this software for any 6 1.1 alc * purpose with or without fee is hereby granted, provided that the above 7 1.1 alc * copyright notice and this permission notice appear in all copies. 8 1.1 alc * 9 1.1 alc * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES 10 1.1 alc * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF 11 1.1 alc * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR 12 1.1 alc * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES 13 1.1 alc * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN 14 1.1 alc * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF 15 1.1 alc * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. 16 1.1 alc * 17 1.1 alc * $Id: ar5312_misc.c,v 1.1.1.1 2008/12/11 04:46:45 alc Exp $ 18 1.1 alc */ 19 1.1 alc #include "opt_ah.h" 20 1.1 alc 21 1.1 alc #ifdef AH_SUPPORT_AR5312 22 1.1 alc 23 1.1 alc #include "ah.h" 24 1.1 alc #include "ah_internal.h" 25 1.1 alc #include "ah_devid.h" 26 1.1 alc 27 1.1 alc #include "ar5312/ar5312.h" 28 1.1 alc #include "ar5312/ar5312reg.h" 29 1.1 alc #include "ar5312/ar5312phy.h" 30 1.1 alc 31 1.1 alc #define AR_NUM_GPIO 6 /* 6 GPIO pins */ 32 1.1 alc #define AR_GPIOD_MASK 0x0000002F /* GPIO data reg r/w mask */ 33 1.1 alc 34 1.1 alc /* 35 1.1 alc * Change the LED blinking pattern to correspond to the connectivity 36 1.1 alc */ 37 1.1 alc void 38 1.1 alc ar5312SetLedState(struct ath_hal *ah, HAL_LED_STATE state) 39 1.1 alc { 40 1.1 alc uint32_t val; 41 1.1 alc uint32_t resOffset = (AR5312_RSTIMER_BASE - ((uint32_t) ah->ah_sh)); 42 1.1 alc if(IS_2316(ah)) return; /* not yet */ 43 1.1 alc val = SM(AR5312_PCICFG_LEDSEL0, AR5312_PCICFG_LEDSEL) | 44 1.1 alc SM(AR5312_PCICFG_LEDMOD0, AR5312_PCICFG_LEDMODE) | 45 1.1 alc 2; 46 1.1 alc OS_REG_WRITE(ah, resOffset+AR5312_PCICFG, 47 1.1 alc (OS_REG_READ(ah, AR5312_PCICFG) &~ 48 1.1 alc (AR5312_PCICFG_LEDSEL | AR5312_PCICFG_LEDMODE | 49 1.1 alc AR5312_PCICFG_LEDSBR)) 50 1.1 alc | val); 51 1.1 alc } 52 1.1 alc 53 1.1 alc /* 54 1.1 alc * Detect if our wireless mac is present. 55 1.1 alc */ 56 1.1 alc HAL_BOOL 57 1.1 alc ar5312DetectCardPresent(struct ath_hal *ah) 58 1.1 alc { 59 1.1 alc uint16_t macVersion, macRev; 60 1.1 alc uint32_t v; 61 1.1 alc 62 1.1 alc /* 63 1.1 alc * Read the Silicon Revision register and compare that 64 1.1 alc * to what we read at attach time. If the same, we say 65 1.1 alc * a card/device is present. 66 1.1 alc */ 67 1.1 alc #if (AH_SUPPORT_2316 || AH_SUPPORT_2317) 68 1.1 alc if(IS_5315(ah)) 69 1.1 alc { 70 1.1 alc v = (OS_REG_READ(ah, 71 1.1 alc (AR5315_RSTIMER_BASE-((uint32_t) ah->ah_sh)) + AR5315_WREV)) 72 1.1 alc & AR_SREV_ID; 73 1.1 alc macVersion = v >> AR_SREV_ID_S; 74 1.1 alc macRev = v & AR_SREV_REVISION; 75 1.1 alc return (AH_PRIVATE(ah)->ah_macVersion == macVersion && 76 1.1 alc AH_PRIVATE(ah)->ah_macRev == macRev); 77 1.1 alc } 78 1.1 alc else 79 1.1 alc #endif 80 1.1 alc { 81 1.1 alc v = (OS_REG_READ(ah, 82 1.1 alc (AR5312_RSTIMER_BASE-((uint32_t) ah->ah_sh)) + AR5312_WREV)) 83 1.1 alc & AR_SREV_ID; 84 1.1 alc macVersion = v >> AR_SREV_ID_S; 85 1.1 alc macRev = v & AR_SREV_REVISION; 86 1.1 alc return (AH_PRIVATE(ah)->ah_macVersion == macVersion && 87 1.1 alc AH_PRIVATE(ah)->ah_macRev == macRev); 88 1.1 alc } 89 1.1 alc } 90 1.1 alc 91 1.1 alc /* 92 1.1 alc * If 32KHz clock exists, use it to lower power consumption during sleep 93 1.1 alc * 94 1.1 alc * Note: If clock is set to 32 KHz, delays on accessing certain 95 1.1 alc * baseband registers (27-31, 124-127) are required. 96 1.1 alc */ 97 1.1 alc void 98 1.1 alc ar5312SetupClock(struct ath_hal *ah, HAL_OPMODE opmode) 99 1.1 alc { 100 1.1 alc if (ar5212Use32KHzclock(ah, opmode)) { 101 1.1 alc /* 102 1.1 alc * Enable clocks to be turned OFF in BB during sleep 103 1.1 alc * and also enable turning OFF 32MHz/40MHz Refclk 104 1.1 alc * from A2. 105 1.1 alc */ 106 1.1 alc OS_REG_WRITE(ah, AR_PHY_SLEEP_CTR_CONTROL, 0x1f); 107 1.1 alc OS_REG_WRITE(ah, AR_PHY_SLEEP_CTR_LIMIT, 0x0d); 108 1.1 alc OS_REG_WRITE(ah, AR_PHY_SLEEP_SCAL, 0x0c); 109 1.1 alc OS_REG_WRITE(ah, AR_PHY_M_SLEEP, 0x03); 110 1.1 alc OS_REG_WRITE(ah, AR_PHY_REFCLKDLY, 0x05); 111 1.1 alc OS_REG_WRITE(ah, AR_PHY_REFCLKPD, 112 1.1 alc IS_RAD5112_ANY(ah) ? 0x14 : 0x18); 113 1.1 alc 114 1.1 alc OS_REG_RMW_FIELD(ah, AR_USEC, AR_USEC_USEC32, 1); 115 1.1 alc OS_REG_WRITE(ah, AR_TSF_PARM, 61); /* 32 KHz TSF incr */ 116 1.1 alc 117 1.1 alc } else { 118 1.1 alc OS_REG_WRITE(ah, AR_TSF_PARM, 1); /* 32 MHz TSF incr */ 119 1.1 alc OS_REG_RMW_FIELD(ah, AR_USEC, AR_USEC_USEC32, 120 1.1 alc IS_RAD5112_ANY(ah) ? 39 : 31); 121 1.1 alc 122 1.1 alc OS_REG_WRITE(ah, AR_PHY_SLEEP_CTR_CONTROL, 0x1f); 123 1.1 alc OS_REG_WRITE(ah, AR_PHY_SLEEP_CTR_LIMIT, 0x7f); 124 1.1 alc 125 1.1 alc if (IS_5312_2_X(ah)) { 126 1.1 alc /* Set ADC/DAC select values */ 127 1.1 alc OS_REG_WRITE(ah, AR_PHY_SLEEP_SCAL, 0x04); 128 1.1 alc } else { 129 1.1 alc OS_REG_WRITE(ah, AR_PHY_SLEEP_SCAL, 0x0e); 130 1.1 alc OS_REG_WRITE(ah, AR_PHY_M_SLEEP, 0x0c); 131 1.1 alc OS_REG_WRITE(ah, AR_PHY_REFCLKDLY, 0xff); 132 1.1 alc OS_REG_WRITE(ah, AR_PHY_REFCLKPD, 133 1.1 alc IS_RAD5112_ANY(ah) ? 0x14 : 0x18); 134 1.1 alc } 135 1.1 alc } 136 1.1 alc } 137 1.1 alc 138 1.1 alc /* 139 1.1 alc * If 32KHz clock exists, turn it off and turn back on the 32Mhz 140 1.1 alc */ 141 1.1 alc void 142 1.1 alc ar5312RestoreClock(struct ath_hal *ah, HAL_OPMODE opmode) 143 1.1 alc { 144 1.1 alc if (ar5212Use32KHzclock(ah, opmode)) { 145 1.1 alc /* # Set sleep clock rate back to 32 MHz. */ 146 1.1 alc OS_REG_WRITE(ah, AR_TSF_PARM, 1); /* 32 MHz TSF incr */ 147 1.1 alc OS_REG_RMW_FIELD(ah, AR_USEC, AR_USEC_USEC32, 148 1.1 alc IS_RAD5112_ANY(ah) ? 39 : 31); 149 1.1 alc 150 1.1 alc /* 151 1.1 alc * Restore BB registers to power-on defaults 152 1.1 alc */ 153 1.1 alc OS_REG_WRITE(ah, AR_PHY_SLEEP_CTR_CONTROL, 0x1f); 154 1.1 alc OS_REG_WRITE(ah, AR_PHY_SLEEP_CTR_LIMIT, 0x7f); 155 1.1 alc if (IS_5312_2_X(ah)) { 156 1.1 alc /* Set ADC/DAC select values */ 157 1.1 alc OS_REG_WRITE(ah, AR_PHY_SLEEP_SCAL, 0x04); 158 1.1 alc } else { 159 1.1 alc OS_REG_WRITE(ah, AR_PHY_SLEEP_SCAL, 0x0e); 160 1.1 alc OS_REG_WRITE(ah, AR_PHY_M_SLEEP, 0x0c); 161 1.1 alc OS_REG_WRITE(ah, AR_PHY_REFCLKDLY, 0xff); 162 1.1 alc OS_REG_WRITE(ah, AR_PHY_REFCLKPD, 163 1.1 alc IS_RAD5112_ANY(ah) ? 0x14 : 0x18); 164 1.1 alc } 165 1.1 alc } 166 1.1 alc } 167 1.1 alc 168 1.1 alc #endif /* AH_SUPPORT_AR5312 */ 169