|
@@ -328,7 +328,61 @@ static void ar9003_hw_init_mode_regs(struct ath_hw *ah)
|
|
|
|
|
|
INIT_INI_ARRAY(&ah->ini_japan2484, AR9462_BBC_TXIFR_COEFFJ,
|
|
|
ARRAY_SIZE(AR9462_BBC_TXIFR_COEFFJ), 2);
|
|
|
+ } else if (AR_SREV_9550(ah)) {
|
|
|
+ /* mac */
|
|
|
+ INIT_INI_ARRAY(&ah->iniMac[ATH_INI_PRE], NULL, 0, 0);
|
|
|
+ INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE],
|
|
|
+ ar955x_1p0_mac_core,
|
|
|
+ ARRAY_SIZE(ar955x_1p0_mac_core), 2);
|
|
|
+ INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST],
|
|
|
+ ar955x_1p0_mac_postamble,
|
|
|
+ ARRAY_SIZE(ar955x_1p0_mac_postamble), 5);
|
|
|
+
|
|
|
+ /* bb */
|
|
|
+ INIT_INI_ARRAY(&ah->iniBB[ATH_INI_PRE], NULL, 0, 0);
|
|
|
+ INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE],
|
|
|
+ ar955x_1p0_baseband_core,
|
|
|
+ ARRAY_SIZE(ar955x_1p0_baseband_core), 2);
|
|
|
+ INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST],
|
|
|
+ ar955x_1p0_baseband_postamble,
|
|
|
+ ARRAY_SIZE(ar955x_1p0_baseband_postamble), 5);
|
|
|
+
|
|
|
+ /* radio */
|
|
|
+ INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_PRE], NULL, 0, 0);
|
|
|
+ INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE],
|
|
|
+ ar955x_1p0_radio_core,
|
|
|
+ ARRAY_SIZE(ar955x_1p0_radio_core), 2);
|
|
|
+ INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_POST],
|
|
|
+ ar955x_1p0_radio_postamble,
|
|
|
+ ARRAY_SIZE(ar955x_1p0_radio_postamble), 5);
|
|
|
+
|
|
|
+ /* soc */
|
|
|
+ INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE],
|
|
|
+ ar955x_1p0_soc_preamble,
|
|
|
+ ARRAY_SIZE(ar955x_1p0_soc_preamble), 2);
|
|
|
+ INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_CORE], NULL, 0, 0);
|
|
|
+ INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_POST],
|
|
|
+ ar955x_1p0_soc_postamble,
|
|
|
+ ARRAY_SIZE(ar955x_1p0_soc_postamble), 5);
|
|
|
|
|
|
+ /* rx/tx gain */
|
|
|
+ INIT_INI_ARRAY(&ah->iniModesRxGain,
|
|
|
+ ar955x_1p0_common_wo_xlna_rx_gain_table,
|
|
|
+ ARRAY_SIZE(ar955x_1p0_common_wo_xlna_rx_gain_table),
|
|
|
+ 2);
|
|
|
+ INIT_INI_ARRAY(&ah->ini_modes_rx_gain_bounds,
|
|
|
+ ar955x_1p0_common_wo_xlna_rx_gain_bounds,
|
|
|
+ ARRAY_SIZE(ar955x_1p0_common_wo_xlna_rx_gain_bounds),
|
|
|
+ 5);
|
|
|
+ INIT_INI_ARRAY(&ah->iniModesTxGain,
|
|
|
+ ar955x_1p0_modes_xpa_tx_gain_table,
|
|
|
+ ARRAY_SIZE(ar955x_1p0_modes_xpa_tx_gain_table),
|
|
|
+ 9);
|
|
|
+
|
|
|
+ /* Fast clock modal settings */
|
|
|
+ INIT_INI_ARRAY(&ah->iniModesFastClock,
|
|
|
+ ar955x_1p0_modes_fast_clock,
|
|
|
+ ARRAY_SIZE(ar955x_1p0_modes_fast_clock), 3);
|
|
|
} else if (AR_SREV_9580(ah)) {
|
|
|
/* mac */
|
|
|
INIT_INI_ARRAY(&ah->iniMac[ATH_INI_PRE], NULL, 0, 0);
|
|
@@ -471,6 +525,11 @@ static void ar9003_tx_gain_table_mode0(struct ath_hw *ah)
|
|
|
ar9485_modes_lowest_ob_db_tx_gain_1_1,
|
|
|
ARRAY_SIZE(ar9485_modes_lowest_ob_db_tx_gain_1_1),
|
|
|
5);
|
|
|
+ else if (AR_SREV_9550(ah))
|
|
|
+ INIT_INI_ARRAY(&ah->iniModesTxGain,
|
|
|
+ ar955x_1p0_modes_xpa_tx_gain_table,
|
|
|
+ ARRAY_SIZE(ar955x_1p0_modes_xpa_tx_gain_table),
|
|
|
+ 9);
|
|
|
else if (AR_SREV_9580(ah))
|
|
|
INIT_INI_ARRAY(&ah->iniModesTxGain,
|
|
|
ar9580_1p0_lowest_ob_db_tx_gain_table,
|
|
@@ -515,6 +574,11 @@ static void ar9003_tx_gain_table_mode1(struct ath_hw *ah)
|
|
|
ar9580_1p0_high_ob_db_tx_gain_table,
|
|
|
ARRAY_SIZE(ar9580_1p0_high_ob_db_tx_gain_table),
|
|
|
5);
|
|
|
+ else if (AR_SREV_9550(ah))
|
|
|
+ INIT_INI_ARRAY(&ah->iniModesTxGain,
|
|
|
+ ar955x_1p0_modes_no_xpa_tx_gain_table,
|
|
|
+ ARRAY_SIZE(ar955x_1p0_modes_no_xpa_tx_gain_table),
|
|
|
+ 9);
|
|
|
else if (AR_SREV_9462_20(ah))
|
|
|
INIT_INI_ARRAY(&ah->iniModesTxGain,
|
|
|
ar9462_modes_high_ob_db_tx_gain_table_2p0,
|
|
@@ -636,7 +700,16 @@ static void ar9003_rx_gain_table_mode0(struct ath_hw *ah)
|
|
|
ar9485Common_wo_xlna_rx_gain_1_1,
|
|
|
ARRAY_SIZE(ar9485Common_wo_xlna_rx_gain_1_1),
|
|
|
2);
|
|
|
- else if (AR_SREV_9580(ah))
|
|
|
+ else if (AR_SREV_9550(ah)) {
|
|
|
+ INIT_INI_ARRAY(&ah->iniModesRxGain,
|
|
|
+ ar955x_1p0_common_rx_gain_table,
|
|
|
+ ARRAY_SIZE(ar955x_1p0_common_rx_gain_table),
|
|
|
+ 2);
|
|
|
+ INIT_INI_ARRAY(&ah->ini_modes_rx_gain_bounds,
|
|
|
+ ar955x_1p0_common_rx_gain_bounds,
|
|
|
+ ARRAY_SIZE(ar955x_1p0_common_rx_gain_bounds),
|
|
|
+ 5);
|
|
|
+ } else if (AR_SREV_9580(ah))
|
|
|
INIT_INI_ARRAY(&ah->iniModesRxGain,
|
|
|
ar9580_1p0_rx_gain_table,
|
|
|
ARRAY_SIZE(ar9580_1p0_rx_gain_table),
|
|
@@ -680,7 +753,16 @@ static void ar9003_rx_gain_table_mode1(struct ath_hw *ah)
|
|
|
ar9462_common_wo_xlna_rx_gain_table_2p0,
|
|
|
ARRAY_SIZE(ar9462_common_wo_xlna_rx_gain_table_2p0),
|
|
|
2);
|
|
|
- else if (AR_SREV_9580(ah))
|
|
|
+ else if (AR_SREV_9550(ah)) {
|
|
|
+ INIT_INI_ARRAY(&ah->iniModesRxGain,
|
|
|
+ ar955x_1p0_common_wo_xlna_rx_gain_table,
|
|
|
+ ARRAY_SIZE(ar955x_1p0_common_wo_xlna_rx_gain_table),
|
|
|
+ 2);
|
|
|
+ INIT_INI_ARRAY(&ah->ini_modes_rx_gain_bounds,
|
|
|
+ ar955x_1p0_common_wo_xlna_rx_gain_bounds,
|
|
|
+ ARRAY_SIZE(ar955x_1p0_common_wo_xlna_rx_gain_bounds),
|
|
|
+ 5);
|
|
|
+ } else if (AR_SREV_9580(ah))
|
|
|
INIT_INI_ARRAY(&ah->iniModesRxGain,
|
|
|
ar9580_1p0_wo_xlna_rx_gain_table,
|
|
|
ARRAY_SIZE(ar9580_1p0_wo_xlna_rx_gain_table),
|