| 
									
										
										
										
											2010-04-15 17:39:03 -04:00
										 |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2011-05-17 13:36:18 +05:30
										 |  |  |  * Copyright (c) 2008-2011 Atheros Communications Inc. | 
					
						
							| 
									
										
										
										
											2010-04-15 17:39:03 -04:00
										 |  |  |  * | 
					
						
							|  |  |  |  * Permission to use, copy, modify, and/or distribute this software for any | 
					
						
							|  |  |  |  * purpose with or without fee is hereby granted, provided that the above | 
					
						
							|  |  |  |  * copyright notice and this permission notice appear in all copies. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES | 
					
						
							|  |  |  |  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF | 
					
						
							|  |  |  |  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR | 
					
						
							|  |  |  |  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES | 
					
						
							|  |  |  |  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN | 
					
						
							|  |  |  |  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF | 
					
						
							|  |  |  |  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "hw.h"
 | 
					
						
							| 
									
										
										
										
											2010-04-15 17:39:28 -04:00
										 |  |  | #include "ar9003_mac.h"
 | 
					
						
							| 
									
										
										
										
											2010-05-12 21:15:05 -04:00
										 |  |  | #include "ar9003_2p2_initvals.h"
 | 
					
						
							| 
									
										
										
										
											2010-12-06 04:27:37 -08:00
										 |  |  | #include "ar9485_initvals.h"
 | 
					
						
							| 
									
										
										
										
											2011-04-19 19:29:04 +05:30
										 |  |  | #include "ar9340_initvals.h"
 | 
					
						
							| 
									
										
										
										
											2011-06-21 11:23:26 +02:00
										 |  |  | #include "ar9330_1p1_initvals.h"
 | 
					
						
							|  |  |  | #include "ar9330_1p2_initvals.h"
 | 
					
						
							| 
									
										
										
										
											2012-07-03 19:13:22 +02:00
										 |  |  | #include "ar955x_1p0_initvals.h"
 | 
					
						
							| 
									
										
										
										
											2011-08-24 15:36:08 -07:00
										 |  |  | #include "ar9580_1p0_initvals.h"
 | 
					
						
							| 
									
										
										
										
											2011-10-13 11:00:43 +05:30
										 |  |  | #include "ar9462_2p0_initvals.h"
 | 
					
						
							| 
									
										
										
										
											2012-09-10 09:19:54 +05:30
										 |  |  | #include "ar9565_1p0_initvals.h"
 | 
					
						
							| 
									
										
										
										
											2010-04-15 17:39:03 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* General hardware code for the AR9003 hadware family */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-14 11:44:27 -07:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * The AR9003 family uses a new INI format (pre, core, post | 
					
						
							|  |  |  |  * arrays per subsystem). This provides support for the | 
					
						
							|  |  |  |  * AR9003 2.2 chipsets. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | static void ar9003_hw_init_mode_regs(struct ath_hw *ah) | 
					
						
							| 
									
										
										
										
											2010-05-12 21:15:05 -04:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-06-21 11:23:26 +02:00
										 |  |  | 	if (AR_SREV_9330_11(ah)) { | 
					
						
							|  |  |  | 		/* mac */ | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9331_1p1_mac_core); | 
					
						
							| 
									
										
										
										
											2011-06-21 11:23:26 +02:00
										 |  |  | 		INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9331_1p1_mac_postamble); | 
					
						
							| 
									
										
										
										
											2011-06-21 11:23:26 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* bb */ | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9331_1p1_baseband_core); | 
					
						
							| 
									
										
										
										
											2011-06-21 11:23:26 +02:00
										 |  |  | 		INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9331_1p1_baseband_postamble); | 
					
						
							| 
									
										
										
										
											2011-06-21 11:23:26 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* radio */ | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9331_1p1_radio_core); | 
					
						
							| 
									
										
										
										
											2011-06-21 11:23:26 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* soc */ | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9331_1p1_soc_preamble); | 
					
						
							| 
									
										
										
										
											2011-06-21 11:23:26 +02:00
										 |  |  | 		INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_POST], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9331_1p1_soc_postamble); | 
					
						
							| 
									
										
										
										
											2011-06-21 11:23:26 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* rx/tx gain */ | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesRxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9331_common_rx_gain_1p1); | 
					
						
							| 
									
										
										
										
											2011-06-21 11:23:26 +02:00
										 |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9331_modes_lowest_ob_db_tx_gain_1p1); | 
					
						
							| 
									
										
										
										
											2011-06-21 11:23:26 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-11-13 11:33:53 +05:30
										 |  |  | 		/* Japan 2484 Mhz CCK */ | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniCckfirJapan2484, | 
					
						
							|  |  |  | 			       ar9331_1p1_baseband_core_txfir_coeff_japan_2484); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-06-21 11:23:26 +02:00
										 |  |  | 		/* additional clock settings */ | 
					
						
							|  |  |  | 		if (ah->is_clk_25mhz) | 
					
						
							| 
									
										
										
										
											2012-03-14 16:40:31 +01:00
										 |  |  | 			INIT_INI_ARRAY(&ah->iniAdditional, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 					ar9331_1p1_xtal_25M); | 
					
						
							| 
									
										
										
										
											2011-06-21 11:23:26 +02:00
										 |  |  | 		else | 
					
						
							| 
									
										
										
										
											2012-03-14 16:40:31 +01:00
										 |  |  | 			INIT_INI_ARRAY(&ah->iniAdditional, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 					ar9331_1p1_xtal_40M); | 
					
						
							| 
									
										
										
										
											2011-06-21 11:23:26 +02:00
										 |  |  | 	} else if (AR_SREV_9330_12(ah)) { | 
					
						
							|  |  |  | 		/* mac */ | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9331_1p2_mac_core); | 
					
						
							| 
									
										
										
										
											2011-06-21 11:23:26 +02:00
										 |  |  | 		INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9331_1p2_mac_postamble); | 
					
						
							| 
									
										
										
										
											2011-06-21 11:23:26 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* bb */ | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9331_1p2_baseband_core); | 
					
						
							| 
									
										
										
										
											2011-06-21 11:23:26 +02:00
										 |  |  | 		INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9331_1p2_baseband_postamble); | 
					
						
							| 
									
										
										
										
											2011-06-21 11:23:26 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* radio */ | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9331_1p2_radio_core); | 
					
						
							| 
									
										
										
										
											2011-06-21 11:23:26 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* soc */ | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9331_1p2_soc_preamble); | 
					
						
							| 
									
										
										
										
											2011-06-21 11:23:26 +02:00
										 |  |  | 		INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_POST], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9331_1p2_soc_postamble); | 
					
						
							| 
									
										
										
										
											2011-06-21 11:23:26 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* rx/tx gain */ | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesRxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9331_common_rx_gain_1p2); | 
					
						
							| 
									
										
										
										
											2011-06-21 11:23:26 +02:00
										 |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9331_modes_lowest_ob_db_tx_gain_1p2); | 
					
						
							| 
									
										
										
										
											2011-06-21 11:23:26 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-11-13 11:33:53 +05:30
										 |  |  | 		/* Japan 2484 Mhz CCK */ | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniCckfirJapan2484, | 
					
						
							|  |  |  | 			       ar9331_1p2_baseband_core_txfir_coeff_japan_2484); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-06-21 11:23:26 +02:00
										 |  |  | 		/* additional clock settings */ | 
					
						
							|  |  |  | 		if (ah->is_clk_25mhz) | 
					
						
							| 
									
										
										
										
											2012-03-14 16:40:31 +01:00
										 |  |  | 			INIT_INI_ARRAY(&ah->iniAdditional, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 					ar9331_1p2_xtal_25M); | 
					
						
							| 
									
										
										
										
											2011-06-21 11:23:26 +02:00
										 |  |  | 		else | 
					
						
							| 
									
										
										
										
											2012-03-14 16:40:31 +01:00
										 |  |  | 			INIT_INI_ARRAY(&ah->iniAdditional, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 					ar9331_1p2_xtal_40M); | 
					
						
							| 
									
										
										
										
											2011-06-21 11:23:26 +02:00
										 |  |  | 	} else if (AR_SREV_9340(ah)) { | 
					
						
							| 
									
										
										
										
											2011-04-19 19:29:04 +05:30
										 |  |  | 		/* mac */ | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9340_1p0_mac_core); | 
					
						
							| 
									
										
										
										
											2011-04-19 19:29:04 +05:30
										 |  |  | 		INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9340_1p0_mac_postamble); | 
					
						
							| 
									
										
										
										
											2011-04-19 19:29:04 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* bb */ | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9340_1p0_baseband_core); | 
					
						
							| 
									
										
										
										
											2011-04-19 19:29:04 +05:30
										 |  |  | 		INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9340_1p0_baseband_postamble); | 
					
						
							| 
									
										
										
										
											2011-04-19 19:29:04 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* radio */ | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9340_1p0_radio_core); | 
					
						
							| 
									
										
										
										
											2011-04-19 19:29:04 +05:30
										 |  |  | 		INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_POST], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9340_1p0_radio_postamble); | 
					
						
							| 
									
										
										
										
											2011-04-19 19:29:04 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* soc */ | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9340_1p0_soc_preamble); | 
					
						
							| 
									
										
										
										
											2011-04-19 19:29:04 +05:30
										 |  |  | 		INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_POST], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9340_1p0_soc_postamble); | 
					
						
							| 
									
										
										
										
											2011-04-19 19:29:04 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* rx/tx gain */ | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesRxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9340Common_wo_xlna_rx_gain_table_1p0); | 
					
						
							| 
									
										
										
										
											2011-04-19 19:29:04 +05:30
										 |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9340Modes_high_ob_db_tx_gain_table_1p0); | 
					
						
							| 
									
										
										
										
											2011-04-19 19:29:04 +05:30
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-14 16:40:31 +01:00
										 |  |  | 		INIT_INI_ARRAY(&ah->iniModesFastClock, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9340Modes_fast_clock_1p0); | 
					
						
							| 
									
										
										
										
											2011-04-19 19:29:04 +05:30
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-14 16:40:31 +01:00
										 |  |  | 		if (!ah->is_clk_25mhz) | 
					
						
							|  |  |  | 			INIT_INI_ARRAY(&ah->iniAdditional, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				       ar9340_1p0_radio_core_40M); | 
					
						
							| 
									
										
										
										
											2011-04-19 19:29:04 +05:30
										 |  |  | 	} else if (AR_SREV_9485_11(ah)) { | 
					
						
							| 
									
										
										
										
											2011-02-18 16:49:47 +05:30
										 |  |  | 		/* mac */ | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9485_1_1_mac_core); | 
					
						
							| 
									
										
										
										
											2011-02-18 16:49:47 +05:30
										 |  |  | 		INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9485_1_1_mac_postamble); | 
					
						
							| 
									
										
										
										
											2011-02-18 16:49:47 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* bb */ | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 		INIT_INI_ARRAY(&ah->iniBB[ATH_INI_PRE], ar9485_1_1); | 
					
						
							| 
									
										
										
										
											2011-02-18 16:49:47 +05:30
										 |  |  | 		INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9485_1_1_baseband_core); | 
					
						
							| 
									
										
										
										
											2011-02-18 16:49:47 +05:30
										 |  |  | 		INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9485_1_1_baseband_postamble); | 
					
						
							| 
									
										
										
										
											2011-02-18 16:49:47 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* radio */ | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9485_1_1_radio_core); | 
					
						
							| 
									
										
										
										
											2011-02-18 16:49:47 +05:30
										 |  |  | 		INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_POST], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9485_1_1_radio_postamble); | 
					
						
							| 
									
										
										
										
											2011-02-18 16:49:47 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* soc */ | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9485_1_1_soc_preamble); | 
					
						
							| 
									
										
										
										
											2011-02-18 16:49:47 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* rx/tx gain */ | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesRxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9485Common_wo_xlna_rx_gain_1_1); | 
					
						
							| 
									
										
										
										
											2011-02-18 16:49:47 +05:30
										 |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9485_modes_lowest_ob_db_tx_gain_1_1); | 
					
						
							| 
									
										
										
										
											2011-02-18 16:49:47 +05:30
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-11-13 11:33:53 +05:30
										 |  |  | 		/* Japan 2484 Mhz CCK */ | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniCckfirJapan2484, | 
					
						
							|  |  |  | 			       ar9485_1_1_baseband_core_txfir_coeff_japan_2484); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-18 16:49:47 +05:30
										 |  |  | 		/* Load PCIE SERDES settings from INI */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/* Awake Setting */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniPcieSerdes, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9485_1_1_pcie_phy_clkreq_disable_L1); | 
					
						
							| 
									
										
										
										
											2011-02-18 16:49:47 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* Sleep Setting */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniPcieSerdesLowPower, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9485_1_1_pcie_phy_clkreq_disable_L1); | 
					
						
							| 
									
										
										
										
											2011-10-13 11:00:44 +05:30
										 |  |  | 	} else if (AR_SREV_9462_20(ah)) { | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:18 +05:30
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 		INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE], ar9462_2p0_mac_core); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:18 +05:30
										 |  |  | 		INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9462_2p0_mac_postamble); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:18 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9462_2p0_baseband_core); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:18 +05:30
										 |  |  | 		INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9462_2p0_baseband_postamble); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:18 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9462_2p0_radio_core); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:18 +05:30
										 |  |  | 		INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_POST], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9462_2p0_radio_postamble); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:18 +05:30
										 |  |  | 		INIT_INI_ARRAY(&ah->ini_radio_post_sys2ant, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9462_2p0_radio_postamble_sys2ant); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:18 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9462_2p0_soc_preamble); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:18 +05:30
										 |  |  | 		INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_POST], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9462_2p0_soc_postamble); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:18 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesRxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9462_common_rx_gain_table_2p0); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:18 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* Awake -> Sleep Setting */ | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniPcieSerdes, | 
					
						
							| 
									
										
										
										
											2012-10-25 17:11:31 +05:30
										 |  |  | 			       ar9462_pciephy_clkreq_disable_L1_2p0); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:18 +05:30
										 |  |  | 		/* Sleep -> Awake Setting */ | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniPcieSerdesLowPower, | 
					
						
							| 
									
										
										
										
											2012-10-25 17:11:31 +05:30
										 |  |  | 			       ar9462_pciephy_clkreq_disable_L1_2p0); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:18 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* Fast clock modal settings */ | 
					
						
							| 
									
										
										
										
											2012-03-14 16:40:31 +01:00
										 |  |  | 		INIT_INI_ARRAY(&ah->iniModesFastClock, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9462_modes_fast_clock_2p0); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:18 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniCckfirJapan2484, | 
					
						
							| 
									
										
										
										
											2012-11-13 11:33:53 +05:30
										 |  |  | 			       ar9462_2p0_baseband_core_txfir_coeff_japan_2484); | 
					
						
							| 
									
										
										
										
											2012-07-03 19:13:23 +02:00
										 |  |  | 	} else if (AR_SREV_9550(ah)) { | 
					
						
							|  |  |  | 		/* mac */ | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar955x_1p0_mac_core); | 
					
						
							| 
									
										
										
										
											2012-07-03 19:13:23 +02:00
										 |  |  | 		INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar955x_1p0_mac_postamble); | 
					
						
							| 
									
										
										
										
											2012-07-03 19:13:23 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* bb */ | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar955x_1p0_baseband_core); | 
					
						
							| 
									
										
										
										
											2012-07-03 19:13:23 +02:00
										 |  |  | 		INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar955x_1p0_baseband_postamble); | 
					
						
							| 
									
										
										
										
											2012-07-03 19:13:23 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* radio */ | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar955x_1p0_radio_core); | 
					
						
							| 
									
										
										
										
											2012-07-03 19:13:23 +02:00
										 |  |  | 		INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_POST], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar955x_1p0_radio_postamble); | 
					
						
							| 
									
										
										
										
											2012-07-03 19:13:23 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* soc */ | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar955x_1p0_soc_preamble); | 
					
						
							| 
									
										
										
										
											2012-07-03 19:13:23 +02:00
										 |  |  | 		INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_POST], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar955x_1p0_soc_postamble); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:18 +05:30
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-07-03 19:13:23 +02:00
										 |  |  | 		/* rx/tx gain */ | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesRxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			ar955x_1p0_common_wo_xlna_rx_gain_table); | 
					
						
							| 
									
										
										
										
											2012-07-03 19:13:23 +02:00
										 |  |  | 		INIT_INI_ARRAY(&ah->ini_modes_rx_gain_bounds, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			ar955x_1p0_common_wo_xlna_rx_gain_bounds); | 
					
						
							| 
									
										
										
										
											2012-07-03 19:13:23 +02:00
										 |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar955x_1p0_modes_xpa_tx_gain_table); | 
					
						
							| 
									
										
										
										
											2012-07-03 19:13:23 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* Fast clock modal settings */ | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesFastClock, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar955x_1p0_modes_fast_clock); | 
					
						
							| 
									
										
										
										
											2011-08-24 15:36:08 -07:00
										 |  |  | 	} else if (AR_SREV_9580(ah)) { | 
					
						
							|  |  |  | 		/* mac */ | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9580_1p0_mac_core); | 
					
						
							| 
									
										
										
										
											2011-08-24 15:36:08 -07:00
										 |  |  | 		INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9580_1p0_mac_postamble); | 
					
						
							| 
									
										
										
										
											2011-08-24 15:36:08 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* bb */ | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9580_1p0_baseband_core); | 
					
						
							| 
									
										
										
										
											2011-08-24 15:36:08 -07:00
										 |  |  | 		INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9580_1p0_baseband_postamble); | 
					
						
							| 
									
										
										
										
											2011-08-24 15:36:08 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* radio */ | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9580_1p0_radio_core); | 
					
						
							| 
									
										
										
										
											2011-08-24 15:36:08 -07:00
										 |  |  | 		INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_POST], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9580_1p0_radio_postamble); | 
					
						
							| 
									
										
										
										
											2011-08-24 15:36:08 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* soc */ | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9580_1p0_soc_preamble); | 
					
						
							| 
									
										
										
										
											2011-08-24 15:36:08 -07:00
										 |  |  | 		INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_POST], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9580_1p0_soc_postamble); | 
					
						
							| 
									
										
										
										
											2011-08-24 15:36:08 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* rx/tx gain */ | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesRxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9580_1p0_rx_gain_table); | 
					
						
							| 
									
										
										
										
											2011-08-24 15:36:08 -07:00
										 |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9580_1p0_low_ob_db_tx_gain_table); | 
					
						
							| 
									
										
										
										
											2011-08-24 15:36:08 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-14 16:40:31 +01:00
										 |  |  | 		INIT_INI_ARRAY(&ah->iniModesFastClock, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9580_1p0_modes_fast_clock); | 
					
						
							| 
									
										
										
										
											2012-09-10 09:19:54 +05:30
										 |  |  | 	} else if (AR_SREV_9565(ah)) { | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE], | 
					
						
							|  |  |  | 			       ar9565_1p0_mac_core); | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST], | 
					
						
							|  |  |  | 			       ar9565_1p0_mac_postamble); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE], | 
					
						
							|  |  |  | 			       ar9565_1p0_baseband_core); | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST], | 
					
						
							|  |  |  | 			       ar9565_1p0_baseband_postamble); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE], | 
					
						
							|  |  |  | 			       ar9565_1p0_radio_core); | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_POST], | 
					
						
							|  |  |  | 			       ar9565_1p0_radio_postamble); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE], | 
					
						
							|  |  |  | 			       ar9565_1p0_soc_preamble); | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_POST], | 
					
						
							|  |  |  | 			       ar9565_1p0_soc_postamble); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesRxGain, | 
					
						
							|  |  |  | 			       ar9565_1p0_Common_rx_gain_table); | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							|  |  |  | 			       ar9565_1p0_Modes_lowest_ob_db_tx_gain_table); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniPcieSerdes, | 
					
						
							| 
									
										
										
										
											2012-10-25 17:16:51 +05:30
										 |  |  | 			       ar9565_1p0_pciephy_clkreq_disable_L1); | 
					
						
							| 
									
										
										
										
											2012-09-10 09:19:54 +05:30
										 |  |  | 		INIT_INI_ARRAY(&ah->iniPcieSerdesLowPower, | 
					
						
							| 
									
										
										
										
											2012-10-25 17:16:51 +05:30
										 |  |  | 			       ar9565_1p0_pciephy_clkreq_disable_L1); | 
					
						
							| 
									
										
										
										
											2012-09-10 09:19:54 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesFastClock, | 
					
						
							|  |  |  | 				ar9565_1p0_modes_fast_clock); | 
					
						
							| 
									
										
										
										
											2010-12-06 04:27:37 -08:00
										 |  |  | 	} else { | 
					
						
							|  |  |  | 		/* mac */ | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniMac[ATH_INI_CORE], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9300_2p2_mac_core); | 
					
						
							| 
									
										
										
										
											2010-12-06 04:27:37 -08:00
										 |  |  | 		INIT_INI_ARRAY(&ah->iniMac[ATH_INI_POST], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9300_2p2_mac_postamble); | 
					
						
							| 
									
										
										
										
											2010-12-06 04:27:37 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* bb */ | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniBB[ATH_INI_CORE], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9300_2p2_baseband_core); | 
					
						
							| 
									
										
										
										
											2010-12-06 04:27:37 -08:00
										 |  |  | 		INIT_INI_ARRAY(&ah->iniBB[ATH_INI_POST], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9300_2p2_baseband_postamble); | 
					
						
							| 
									
										
										
										
											2010-12-06 04:27:37 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* radio */ | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_CORE], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9300_2p2_radio_core); | 
					
						
							| 
									
										
										
										
											2010-12-06 04:27:37 -08:00
										 |  |  | 		INIT_INI_ARRAY(&ah->iniRadio[ATH_INI_POST], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9300_2p2_radio_postamble); | 
					
						
							| 
									
										
										
										
											2010-12-06 04:27:37 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* soc */ | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_PRE], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9300_2p2_soc_preamble); | 
					
						
							| 
									
										
										
										
											2010-12-06 04:27:37 -08:00
										 |  |  | 		INIT_INI_ARRAY(&ah->iniSOC[ATH_INI_POST], | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9300_2p2_soc_postamble); | 
					
						
							| 
									
										
										
										
											2010-12-06 04:27:37 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* rx/tx gain */ | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesRxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9300Common_rx_gain_table_2p2); | 
					
						
							| 
									
										
										
										
											2010-12-06 04:27:37 -08:00
										 |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9300Modes_lowest_ob_db_tx_gain_table_2p2); | 
					
						
							| 
									
										
										
										
											2010-12-06 04:27:37 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* Load PCIE SERDES settings from INI */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/* Awake Setting */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniPcieSerdes, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9300PciePhy_pll_on_clkreq_disable_L1_2p2); | 
					
						
							| 
									
										
										
										
											2010-12-06 04:27:37 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* Sleep Setting */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniPcieSerdesLowPower, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9300PciePhy_pll_on_clkreq_disable_L1_2p2); | 
					
						
							| 
									
										
										
										
											2010-12-06 04:27:37 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* Fast clock modal settings */ | 
					
						
							| 
									
										
										
										
											2012-03-14 16:40:31 +01:00
										 |  |  | 		INIT_INI_ARRAY(&ah->iniModesFastClock, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9300Modes_fast_clock_2p2); | 
					
						
							| 
									
										
										
										
											2010-12-06 04:27:37 -08:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-05-12 21:15:05 -04:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:17 +05:30
										 |  |  | static void ar9003_tx_gain_table_mode0(struct ath_hw *ah) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if (AR_SREV_9330_12(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			ar9331_modes_lowest_ob_db_tx_gain_1p2); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:17 +05:30
										 |  |  | 	else if (AR_SREV_9330_11(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			ar9331_modes_lowest_ob_db_tx_gain_1p1); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:17 +05:30
										 |  |  | 	else if (AR_SREV_9340(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			ar9340Modes_lowest_ob_db_tx_gain_table_1p0); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:17 +05:30
										 |  |  | 	else if (AR_SREV_9485_11(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			ar9485_modes_lowest_ob_db_tx_gain_1_1); | 
					
						
							| 
									
										
										
										
											2012-07-03 19:13:23 +02:00
										 |  |  | 	else if (AR_SREV_9550(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			ar955x_1p0_modes_xpa_tx_gain_table); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:17 +05:30
										 |  |  | 	else if (AR_SREV_9580(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			ar9580_1p0_lowest_ob_db_tx_gain_table); | 
					
						
							| 
									
										
										
										
											2011-10-13 11:00:44 +05:30
										 |  |  | 	else if (AR_SREV_9462_20(ah)) | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:18 +05:30
										 |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			ar9462_modes_low_ob_db_tx_gain_table_2p0); | 
					
						
							| 
									
										
										
										
											2012-09-10 09:19:54 +05:30
										 |  |  | 	else if (AR_SREV_9565(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							|  |  |  | 			       ar9565_1p0_modes_low_ob_db_tx_gain_table); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:17 +05:30
										 |  |  | 	else | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			ar9300Modes_lowest_ob_db_tx_gain_table_2p2); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:17 +05:30
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void ar9003_tx_gain_table_mode1(struct ath_hw *ah) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if (AR_SREV_9330_12(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			ar9331_modes_high_ob_db_tx_gain_1p2); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:17 +05:30
										 |  |  | 	else if (AR_SREV_9330_11(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			ar9331_modes_high_ob_db_tx_gain_1p1); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:17 +05:30
										 |  |  | 	else if (AR_SREV_9340(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			ar9340Modes_high_ob_db_tx_gain_table_1p0); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:17 +05:30
										 |  |  | 	else if (AR_SREV_9485_11(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			ar9485Modes_high_ob_db_tx_gain_1_1); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:17 +05:30
										 |  |  | 	else if (AR_SREV_9580(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			ar9580_1p0_high_ob_db_tx_gain_table); | 
					
						
							| 
									
										
										
										
											2012-07-03 19:13:23 +02:00
										 |  |  | 	else if (AR_SREV_9550(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			ar955x_1p0_modes_no_xpa_tx_gain_table); | 
					
						
							| 
									
										
										
										
											2011-10-13 11:00:44 +05:30
										 |  |  | 	else if (AR_SREV_9462_20(ah)) | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:18 +05:30
										 |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			ar9462_modes_high_ob_db_tx_gain_table_2p0); | 
					
						
							| 
									
										
										
										
											2012-09-10 09:19:54 +05:30
										 |  |  | 	else if (AR_SREV_9565(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							|  |  |  | 			       ar9565_1p0_modes_high_ob_db_tx_gain_table); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:17 +05:30
										 |  |  | 	else | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			ar9300Modes_high_ob_db_tx_gain_table_2p2); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:17 +05:30
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void ar9003_tx_gain_table_mode2(struct ath_hw *ah) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if (AR_SREV_9330_12(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			ar9331_modes_low_ob_db_tx_gain_1p2); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:17 +05:30
										 |  |  | 	else if (AR_SREV_9330_11(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			ar9331_modes_low_ob_db_tx_gain_1p1); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:17 +05:30
										 |  |  | 	else if (AR_SREV_9340(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			ar9340Modes_low_ob_db_tx_gain_table_1p0); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:17 +05:30
										 |  |  | 	else if (AR_SREV_9485_11(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			ar9485Modes_low_ob_db_tx_gain_1_1); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:17 +05:30
										 |  |  | 	else if (AR_SREV_9580(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			ar9580_1p0_low_ob_db_tx_gain_table); | 
					
						
							| 
									
										
										
										
											2012-09-10 09:19:54 +05:30
										 |  |  | 	else if (AR_SREV_9565(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							|  |  |  | 			       ar9565_1p0_modes_low_ob_db_tx_gain_table); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:17 +05:30
										 |  |  | 	else | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			ar9300Modes_low_ob_db_tx_gain_table_2p2); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:17 +05:30
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void ar9003_tx_gain_table_mode3(struct ath_hw *ah) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if (AR_SREV_9330_12(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			ar9331_modes_high_power_tx_gain_1p2); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:17 +05:30
										 |  |  | 	else if (AR_SREV_9330_11(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			ar9331_modes_high_power_tx_gain_1p1); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:17 +05:30
										 |  |  | 	else if (AR_SREV_9340(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			ar9340Modes_high_power_tx_gain_table_1p0); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:17 +05:30
										 |  |  | 	else if (AR_SREV_9485_11(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			ar9485Modes_high_power_tx_gain_1_1); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:17 +05:30
										 |  |  | 	else if (AR_SREV_9580(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			ar9580_1p0_high_power_tx_gain_table); | 
					
						
							| 
									
										
										
										
											2012-09-10 09:19:54 +05:30
										 |  |  | 	else if (AR_SREV_9565(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							|  |  |  | 			       ar9565_1p0_modes_high_power_tx_gain_table); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:17 +05:30
										 |  |  | 	else | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			ar9300Modes_high_power_tx_gain_table_2p2); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:17 +05:30
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:32 +02:00
										 |  |  | static void ar9003_tx_gain_table_mode4(struct ath_hw *ah) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if (AR_SREV_9340(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			ar9340Modes_mixed_ob_db_tx_gain_table_1p0); | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:32 +02:00
										 |  |  | 	else if (AR_SREV_9580(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			ar9580_1p0_mixed_ob_db_tx_gain_table); | 
					
						
							| 
									
										
										
										
											2013-01-10 19:41:52 +01:00
										 |  |  | 	else | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							|  |  |  | 			ar9300Modes_mixed_ob_db_tx_gain_table_2p2); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void ar9003_tx_gain_table_mode5(struct ath_hw *ah) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if (AR_SREV_9485_11(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							|  |  |  | 			ar9485Modes_green_ob_db_tx_gain_1_1); | 
					
						
							|  |  |  | 	else if (AR_SREV_9340(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							|  |  |  | 			ar9340Modes_ub124_tx_gain_table_1p0); | 
					
						
							|  |  |  | 	else if (AR_SREV_9580(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							|  |  |  | 			ar9580_1p0_type5_tx_gain_table); | 
					
						
							|  |  |  | 	else if (AR_SREV_9300_22(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							|  |  |  | 			ar9300Modes_type5_tx_gain_table_2p2); | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:32 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-10 19:41:52 +01:00
										 |  |  | static void ar9003_tx_gain_table_mode6(struct ath_hw *ah) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if (AR_SREV_9340(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							|  |  |  | 			ar9340Modes_low_ob_db_and_spur_tx_gain_table_1p0); | 
					
						
							|  |  |  | 	else if (AR_SREV_9485_11(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							|  |  |  | 			ar9485Modes_green_spur_ob_db_tx_gain_1_1); | 
					
						
							|  |  |  | 	else if (AR_SREV_9580(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesTxGain, | 
					
						
							|  |  |  | 			ar9580_1p0_type6_tx_gain_table); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef void (*ath_txgain_tab)(struct ath_hw *ah); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-15 17:39:21 -04:00
										 |  |  | static void ar9003_tx_gain_table_apply(struct ath_hw *ah) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2013-01-10 19:41:52 +01:00
										 |  |  | 	static const ath_txgain_tab modes[] = { | 
					
						
							|  |  |  | 		ar9003_tx_gain_table_mode0, | 
					
						
							|  |  |  | 		ar9003_tx_gain_table_mode1, | 
					
						
							|  |  |  | 		ar9003_tx_gain_table_mode2, | 
					
						
							|  |  |  | 		ar9003_tx_gain_table_mode3, | 
					
						
							|  |  |  | 		ar9003_tx_gain_table_mode4, | 
					
						
							|  |  |  | 		ar9003_tx_gain_table_mode5, | 
					
						
							|  |  |  | 		ar9003_tx_gain_table_mode6, | 
					
						
							|  |  |  | 	}; | 
					
						
							|  |  |  | 	int idx = ar9003_hw_get_tx_gain_idx(ah); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (idx >= ARRAY_SIZE(modes)) | 
					
						
							|  |  |  | 		idx = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	modes[idx](ah); | 
					
						
							| 
									
										
										
										
											2010-04-15 17:39:21 -04:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:17 +05:30
										 |  |  | static void ar9003_rx_gain_table_mode0(struct ath_hw *ah) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if (AR_SREV_9330_12(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesRxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9331_common_rx_gain_1p2); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:17 +05:30
										 |  |  | 	else if (AR_SREV_9330_11(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesRxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9331_common_rx_gain_1p1); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:17 +05:30
										 |  |  | 	else if (AR_SREV_9340(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesRxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9340Common_rx_gain_table_1p0); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:17 +05:30
										 |  |  | 	else if (AR_SREV_9485_11(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesRxGain, | 
					
						
							| 
									
										
										
										
											2012-12-26 12:27:39 +05:30
										 |  |  | 			       ar9485_common_rx_gain_1_1); | 
					
						
							| 
									
										
										
										
											2012-07-03 19:13:23 +02:00
										 |  |  | 	else if (AR_SREV_9550(ah)) { | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesRxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar955x_1p0_common_rx_gain_table); | 
					
						
							| 
									
										
										
										
											2012-07-03 19:13:23 +02:00
										 |  |  | 		INIT_INI_ARRAY(&ah->ini_modes_rx_gain_bounds, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar955x_1p0_common_rx_gain_bounds); | 
					
						
							| 
									
										
										
										
											2012-07-03 19:13:23 +02:00
										 |  |  | 	} else if (AR_SREV_9580(ah)) | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:17 +05:30
										 |  |  | 		INIT_INI_ARRAY(&ah->iniModesRxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9580_1p0_rx_gain_table); | 
					
						
							| 
									
										
										
										
											2011-10-13 11:00:44 +05:30
										 |  |  | 	else if (AR_SREV_9462_20(ah)) | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:18 +05:30
										 |  |  | 		INIT_INI_ARRAY(&ah->iniModesRxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9462_common_rx_gain_table_2p0); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:17 +05:30
										 |  |  | 	else | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesRxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 				ar9300Common_rx_gain_table_2p2); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:17 +05:30
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void ar9003_rx_gain_table_mode1(struct ath_hw *ah) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if (AR_SREV_9330_12(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesRxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			ar9331_common_wo_xlna_rx_gain_1p2); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:17 +05:30
										 |  |  | 	else if (AR_SREV_9330_11(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesRxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			ar9331_common_wo_xlna_rx_gain_1p1); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:17 +05:30
										 |  |  | 	else if (AR_SREV_9340(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesRxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			ar9340Common_wo_xlna_rx_gain_table_1p0); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:17 +05:30
										 |  |  | 	else if (AR_SREV_9485_11(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesRxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			ar9485Common_wo_xlna_rx_gain_1_1); | 
					
						
							| 
									
										
										
										
											2011-10-13 11:00:44 +05:30
										 |  |  | 	else if (AR_SREV_9462_20(ah)) | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:18 +05:30
										 |  |  | 		INIT_INI_ARRAY(&ah->iniModesRxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			ar9462_common_wo_xlna_rx_gain_table_2p0); | 
					
						
							| 
									
										
										
										
											2012-07-03 19:13:23 +02:00
										 |  |  | 	else if (AR_SREV_9550(ah)) { | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesRxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			ar955x_1p0_common_wo_xlna_rx_gain_table); | 
					
						
							| 
									
										
										
										
											2012-07-03 19:13:23 +02:00
										 |  |  | 		INIT_INI_ARRAY(&ah->ini_modes_rx_gain_bounds, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			ar955x_1p0_common_wo_xlna_rx_gain_bounds); | 
					
						
							| 
									
										
										
										
											2012-07-03 19:13:23 +02:00
										 |  |  | 	} else if (AR_SREV_9580(ah)) | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:17 +05:30
										 |  |  | 		INIT_INI_ARRAY(&ah->iniModesRxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			ar9580_1p0_wo_xlna_rx_gain_table); | 
					
						
							| 
									
										
										
										
											2012-09-10 09:19:54 +05:30
										 |  |  | 	else if (AR_SREV_9565(ah)) | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesRxGain, | 
					
						
							|  |  |  | 			       ar9565_1p0_common_wo_xlna_rx_gain_table); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:17 +05:30
										 |  |  | 	else | 
					
						
							|  |  |  | 		INIT_INI_ARRAY(&ah->iniModesRxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			ar9300Common_wo_xlna_rx_gain_table_2p2); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:17 +05:30
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:18 +05:30
										 |  |  | static void ar9003_rx_gain_table_mode2(struct ath_hw *ah) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-02-22 12:40:03 +05:30
										 |  |  | 	if (AR_SREV_9462_20(ah)) | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:18 +05:30
										 |  |  | 		INIT_INI_ARRAY(&ah->iniModesRxGain, | 
					
						
							| 
									
										
										
										
											2012-07-15 19:53:33 +02:00
										 |  |  | 			       ar9462_common_mixed_rx_gain_table_2p0); | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:18 +05:30
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-15 17:39:21 -04:00
										 |  |  | static void ar9003_rx_gain_table_apply(struct ath_hw *ah) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	switch (ar9003_hw_get_rx_gain_idx(ah)) { | 
					
						
							|  |  |  | 	case 0: | 
					
						
							|  |  |  | 	default: | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:17 +05:30
										 |  |  | 		ar9003_rx_gain_table_mode0(ah); | 
					
						
							| 
									
										
										
										
											2010-04-15 17:39:21 -04:00
										 |  |  | 		break; | 
					
						
							|  |  |  | 	case 1: | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:17 +05:30
										 |  |  | 		ar9003_rx_gain_table_mode1(ah); | 
					
						
							| 
									
										
										
										
											2010-04-15 17:39:21 -04:00
										 |  |  | 		break; | 
					
						
							| 
									
										
										
										
											2011-09-13 22:38:18 +05:30
										 |  |  | 	case 2: | 
					
						
							|  |  |  | 		ar9003_rx_gain_table_mode2(ah); | 
					
						
							|  |  |  | 		break; | 
					
						
							| 
									
										
										
										
											2010-04-15 17:39:21 -04:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* set gain table pointers according to values read from the eeprom */ | 
					
						
							|  |  |  | static void ar9003_hw_init_mode_gain_regs(struct ath_hw *ah) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	ar9003_tx_gain_table_apply(ah); | 
					
						
							|  |  |  | 	ar9003_rx_gain_table_apply(ah); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-15 17:39:03 -04:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * Helper for ASPM support. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Disable PLL when in L0s as well as receiver clock when in L1. | 
					
						
							|  |  |  |  * This power saving option must be enabled through the SerDes. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Programming the SerDes must go through the same 288 bit serial shift | 
					
						
							|  |  |  |  * register as the other analog registers.  Hence the 9 writes. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | static void ar9003_hw_configpcipowersave(struct ath_hw *ah, | 
					
						
							| 
									
										
										
										
											2011-08-05 13:10:32 +02:00
										 |  |  | 					 bool power_off) | 
					
						
							| 
									
										
										
										
											2010-04-15 17:39:03 -04:00
										 |  |  | { | 
					
						
							|  |  |  | 	/* Nothing to do on restore for 11N */ | 
					
						
							| 
									
										
										
										
											2011-08-05 13:10:32 +02:00
										 |  |  | 	if (!power_off /* !restore */) { | 
					
						
							| 
									
										
										
										
											2010-04-15 17:39:03 -04:00
										 |  |  | 		/* set bit 19 to allow forcing of pcie core into L1 state */ | 
					
						
							|  |  |  | 		REG_SET_BIT(ah, AR_PCIE_PM_CTRL, AR_PCIE_PM_CTRL_ENA); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/* Several PCIe massages to ensure proper behaviour */ | 
					
						
							|  |  |  | 		if (ah->config.pcie_waen) | 
					
						
							|  |  |  | 			REG_WRITE(ah, AR_WA, ah->config.pcie_waen); | 
					
						
							| 
									
										
										
										
											2010-06-21 18:38:47 -04:00
										 |  |  | 		else | 
					
						
							|  |  |  | 			REG_WRITE(ah, AR_WA, ah->WARegVal); | 
					
						
							| 
									
										
										
										
											2010-04-15 17:39:03 -04:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-06-21 18:38:48 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/*
 | 
					
						
							|  |  |  | 	 * Configire PCIE after Ini init. SERDES values now come from ini file | 
					
						
							|  |  |  | 	 * This enables PCIe low power mode. | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2010-06-21 18:38:49 -04:00
										 |  |  | 	if (ah->config.pcieSerDesWrite) { | 
					
						
							| 
									
										
										
										
											2010-06-21 18:38:48 -04:00
										 |  |  | 		unsigned int i; | 
					
						
							| 
									
										
										
										
											2010-06-21 18:38:50 -04:00
										 |  |  | 		struct ar5416IniArray *array; | 
					
						
							| 
									
										
										
										
											2010-06-21 18:38:48 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-21 18:38:50 -04:00
										 |  |  | 		array = power_off ? &ah->iniPcieSerdes : | 
					
						
							|  |  |  | 				    &ah->iniPcieSerdesLowPower; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		for (i = 0; i < array->ia_rows; i++) { | 
					
						
							| 
									
										
										
										
											2010-06-21 18:38:48 -04:00
										 |  |  | 			REG_WRITE(ah, | 
					
						
							| 
									
										
										
										
											2010-06-21 18:38:50 -04:00
										 |  |  | 				  INI_RA(array, i, 0), | 
					
						
							|  |  |  | 				  INI_RA(array, i, 1)); | 
					
						
							| 
									
										
										
										
											2010-06-21 18:38:48 -04:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-04-15 17:39:03 -04:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Sets up the AR9003 hardware familiy callbacks */ | 
					
						
							|  |  |  | void ar9003_hw_attach_ops(struct ath_hw *ah) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	struct ath_hw_private_ops *priv_ops = ath9k_hw_private_ops(ah); | 
					
						
							|  |  |  | 	struct ath_hw_ops *ops = ath9k_hw_ops(ah); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-13 19:54:58 +01:00
										 |  |  | 	ar9003_hw_init_mode_regs(ah); | 
					
						
							| 
									
										
										
										
											2010-04-15 17:39:21 -04:00
										 |  |  | 	priv_ops->init_mode_gain_regs = ar9003_hw_init_mode_gain_regs; | 
					
						
							| 
									
										
										
										
											2010-04-15 17:39:03 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	ops->config_pci_powersave = ar9003_hw_configpcipowersave; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	ar9003_hw_attach_phy_ops(ah); | 
					
						
							|  |  |  | 	ar9003_hw_attach_calib_ops(ah); | 
					
						
							|  |  |  | 	ar9003_hw_attach_mac_ops(ah); | 
					
						
							|  |  |  | } |