On Thu, Apr 28, 2011 at 07:52:54PM +0530, Mohammed Shafi Shajakhan wrote: > From: Mohammed Shafi Shajakhan <mshajakhan@xxxxxxxxxxx> > > * enable LNA-diversity, fast-diversity based on the value read from > EEPROM content > * if antenna diversity/combining is supported set LNA1 for the main > antenna and LNA2 for the alternate antenna based on the new diversity > algorithm > > Signed-off-by: Mohammed Shafi Shajakhan <mshajakhan@xxxxxxxxxxx> > --- > drivers/net/wireless/ath/ath9k/ar9003_eeprom.c | 50 +++++++++++++++++++++--- > 1 files changed, 44 insertions(+), 6 deletions(-) > > diff --git a/drivers/net/wireless/ath/ath9k/ar9003_eeprom.c b/drivers/net/wireless/ath/ath9k/ar9003_eeprom.c > index fb892e5..d43e62c 100644 > --- a/drivers/net/wireless/ath/ath9k/ar9003_eeprom.c > +++ b/drivers/net/wireless/ath/ath9k/ar9003_eeprom.c > @@ -3500,6 +3500,8 @@ static u16 ar9003_hw_ant_ctrl_chain_get(struct ath_hw *ah, > static void ar9003_hw_ant_ctrl_apply(struct ath_hw *ah, bool is2ghz) > { > int chain; > + u32 regval; > + u32 ant_div_ctl1; > static const u32 switch_chain_reg[AR9300_MAX_CHAINS] = { > AR_PHY_SWITCH_CHAIN_0, > AR_PHY_SWITCH_CHAIN_1, > @@ -3525,13 +3527,49 @@ static void ar9003_hw_ant_ctrl_apply(struct ath_hw *ah, bool is2ghz) > > if (AR_SREV_9485(ah)) { > value = ath9k_hw_ar9300_get_eeprom(ah, EEP_ANT_DIV_CTL1); > - REG_RMW_FIELD(ah, AR_PHY_MC_GAIN_CTRL, AR_ANT_DIV_CTRL_ALL, > - value); > - REG_RMW_FIELD(ah, AR_PHY_MC_GAIN_CTRL, AR_ANT_DIV_ENABLE, > - value >> 6); > - REG_RMW_FIELD(ah, AR_PHY_CCK_DETECT, AR_FAST_DIV_ENABLE, > - value >> 7); > + /* > + * main_lnaconf, alt_lnaconf, main_tb, alt_tb > + * are the fields present > + */ > + regval = REG_READ(ah, AR_PHY_MC_GAIN_CTRL); > + regval &= (~AR_ANT_DIV_CTRL_ALL); > + regval |= (value & 0x3f) << AR_ANT_DIV_CTRL_ALL_S; > + /* enable_lnadiv */ > + regval &= (~AR_PHY_9485_ANT_DIV_LNADIV); > + regval |= ((value >> 6) & 0x1) << > + AR_PHY_9485_ANT_DIV_LNADIV_S; > + REG_WRITE(ah, AR_PHY_MC_GAIN_CTRL, regval); > + > + /*enable fast_div */ > + regval = REG_READ(ah, AR_PHY_CCK_DETECT); > + regval &= (~AR_BBB_SIG_DETECT_ANT_FAST_DIV); > + regval |= ((value >> 7) & 0x1) << > + AR_BBB_SIG_DETECT_ANT_FAST_DIV_S; > + REG_WRITE(ah, AR_PHY_CCK_DETECT, regval); Can these be simplified with REG_RMW()?. > + ant_div_ctl1 = > + ah->eep_ops->get_eeprom(ah, EEP_ANT_DIV_CTL1); > + /* check whether antenna diversity is enabled */ > + if ((ant_div_ctl1 >> 0x6) == 0x3) { > + regval = REG_READ(ah, AR_PHY_MC_GAIN_CTRL); > + /* > + * clear bits 25-30 main_lnaconf, alt_lnaconf, > + * main_tb, alt_tb > + */ > + regval &= (~(AR_PHY_9485_ANT_DIV_MAIN_LNACONF | > + AR_PHY_9485_ANT_DIV_ALT_LNACONF | > + AR_PHY_9485_ANT_DIV_ALT_GAINTB | > + AR_PHY_9485_ANT_DIV_MAIN_GAINTB)); > + /* by default use LNA1 for the main antenna */ > + regval |= (AR_PHY_9485_ANT_DIV_LNA1 << > + AR_PHY_9485_ANT_DIV_MAIN_LNACONF_S); > + regval |= (AR_PHY_9485_ANT_DIV_LNA2 << > + AR_PHY_9485_ANT_DIV_ALT_LNACONF_S); > + REG_WRITE(ah, AR_PHY_MC_GAIN_CTRL, regval); same here. Vasanth -- To unsubscribe from this list: send the line "unsubscribe linux-wireless" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html