1250003Sadrian/*
2250003Sadrian * Copyright (c) 2013 Qualcomm Atheros, Inc.
3250003Sadrian *
4250003Sadrian * Permission to use, copy, modify, and/or distribute this software for any
5250003Sadrian * purpose with or without fee is hereby granted, provided that the above
6250003Sadrian * copyright notice and this permission notice appear in all copies.
7250003Sadrian *
8250003Sadrian * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
9250003Sadrian * REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
10250003Sadrian * AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
11250003Sadrian * INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
12250003Sadrian * LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
13250003Sadrian * OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
14250003Sadrian * PERFORMANCE OF THIS SOFTWARE.
15250003Sadrian */
16250003Sadrian
17250003Sadrian/*
18250003Sadrian * READ THIS NOTICE!
19250003Sadrian *
20250003Sadrian * Values defined in this file may only be changed under exceptional circumstances.
21250003Sadrian *
22250003Sadrian * Please ask Fiona Cain before making any changes.
23250003Sadrian */
24250003Sadrian
25250003Sadrian#ifndef __ar9300templateAP121_h__
26250003Sadrian#define __ar9300templateAP121_h__
27250003Sadrian
28250003Sadrianstatic ar9300_eeprom_t ar9300_template_ap121=
29250003Sadrian{
30250003Sadrian
31250003Sadrian	2, //  eeprom_version;
32250003Sadrian
33250003Sadrian    ar9300_eeprom_template_ap121, //  template_version;
34250003Sadrian
35250003Sadrian	{0x00,0x03,0x7f,0x0,0x0,0x0}, //mac_addr[6];
36250003Sadrian
37250003Sadrian    //static  A_UINT8   custData[OSPREY_CUSTOMER_DATA_SIZE]=
38250003Sadrian
39250003Sadrian	{"ap121-010-00000"},
40250003Sadrian//	{0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},
41250003Sadrian
42250003Sadrian    //static OSPREY_BASE_EEP_HEADER base_eep_header=
43250003Sadrian
44250003Sadrian	{
45250003Sadrian		    {0,0x1f},	//   reg_dmn[2]; //Does this need to be outside of this structure, if it gets written after calibration
46250003Sadrian		    0x11,	//   txrx_mask;  //4 bits tx and 4 bits rx
47250003Sadrian		    {AR9300_OPFLAGS_11G , 0},	//   op_cap_flags;
48250003Sadrian		    0,		//   rf_silent;
49250003Sadrian		    0,		//   blue_tooth_options;
50250003Sadrian		    0,		//   device_cap;
51250003Sadrian		    4,		//   device_type; // takes lower byte in eeprom location
52250003Sadrian		    OSPREY_PWR_TABLE_OFFSET,	//    pwrTableOffset; // offset in dB to be added to beginning of pdadc table in calibration
53250003Sadrian			{0,0},	//   params_for_tuning_caps[2];  //placeholder, get more details from Don
54250003Sadrian            0x0d,     //feature_enable; //bit0 - enable tx temp comp
55250003Sadrian                             //bit1 - enable tx volt comp
56250003Sadrian                             //bit2 - enable fastClock - default to 1
57250003Sadrian                             //bit3 - enable doubling - default to 1
58250003Sadrian 							 //bit4 - enable internal regulator - default to 0
59250003Sadrian							 //bit5 - enable paprd -- default to 0
60250003Sadrian    		0,       //misc_configuration: bit0 - turn down drivestrength
61250003Sadrian			6,		// eeprom_write_enable_gpio
62250003Sadrian			0,		// wlan_disable_gpio
63250003Sadrian			8,		// wlan_led_gpio
64250003Sadrian			0xff,		// rx_band_select_gpio
65250003Sadrian			0x10,			// txrxgain
66250003Sadrian            0,		//   swreg
67250003Sadrian	},
68250003Sadrian
69250003Sadrian
70250003Sadrian	//static OSPREY_MODAL_EEP_HEADER modal_header_2g=
71250003Sadrian	{
72250003Sadrian
73250003Sadrian		    0x110,			//  ant_ctrl_common;                         // 4   idle, t1, t2, b (4 bits per setting)
74250003Sadrian		    0x44444,		//  ant_ctrl_common2;                        // 4    ra1l1, ra2l1, ra1l2, ra2l2, ra12
75250003Sadrian		    {0x150,0x150,0x150},	//  ant_ctrl_chain[OSPREY_MAX_CHAINS];       // 6   idle, t, r, rx1, rx12, b (2 bits each)
76250003Sadrian		    {0,0,0},			//   xatten1_db[OSPREY_MAX_CHAINS];           // 3  //xatten1_db for merlin (0xa20c/b20c 5:0)
77250003Sadrian		    {0,0,0},			//   xatten1_margin[OSPREY_MAX_CHAINS];          // 3  //xatten1_margin for merlin (0xa20c/b20c 16:12
78250003Sadrian			25,				//    temp_slope;
79250003Sadrian			0,				//    voltSlope;
80250003Sadrian		    {FREQ2FBIN(2464, 1),0,0,0,0}, // spur_chans[OSPREY_EEPROM_MODAL_SPURS];  // spur channels in usual fbin coding format
81250003Sadrian		    {-1,0,0},			//    noise_floor_thresh_ch[OSPREY_MAX_CHAINS]; // 3    //Check if the register is per chain
82250003Sadrian            {0, 0, 0, 0, 0, 0,0,0,0,0,0},               // reserved
83250003Sadrian            0,                                          // quick drop
84250003Sadrian		    0,				//   xpa_bias_lvl;                            // 1
85250003Sadrian		    0x0e,			//   tx_frame_to_data_start;                    // 1
86250003Sadrian		    0x0e,			//   tx_frame_to_pa_on;                         // 1
87250003Sadrian		    3,				//   txClip;                                     // 4 bits tx_clip, 4 bits dac_scale_cck
88250003Sadrian		    0,				//    antenna_gain;                           // 1
89250003Sadrian		    0x2c,			//   switchSettling;                        // 1
90250003Sadrian		    -30,			//    adcDesiredSize;                        // 1
91250003Sadrian		    0,				//   txEndToXpaOff;                         // 1
92250003Sadrian		    0x2,			//   txEndToRxOn;                           // 1
93250003Sadrian		    0xe,			//   tx_frame_to_xpa_on;                        // 1
94250003Sadrian		    28,				//   thresh62;                              // 1
95250003Sadrian			0x80c0e0,		//	 paprd_rate_mask_ht20						// 4
96250003Sadrian  			0x1ffffff,		//	 paprd_rate_mask_ht40
97250003Sadrian		    0,				//   switchcomspdt;                         // 2
98250003Sadrian			0,				// bit: 0,1:chain0, 2,3:chain1, 4,5:chain2
99250003Sadrian			0,				//  rf_gain_cap
100250003Sadrian			0,				//  tx_gain_cap
101250003Sadrian			{0,0,0,0,0}    //futureModal[5];
102250003Sadrian	},
103250003Sadrian
104250003Sadrian	{
105250003Sadrian			6,					    // ant_div_control
106250003Sadrian			{0,0},					// base_ext1
107250003Sadrian			0,						// misc_enable
108250003Sadrian			{0,0,0,0,0,0,0,0},		// temp slop extension
109250003Sadrian            0,                      // quick drop low
110250003Sadrian            0,                      // quick drop high
111250003Sadrian    },
112250003Sadrian	//static A_UINT8 cal_freq_pier_2g[OSPREY_NUM_2G_CAL_PIERS]=
113250003Sadrian	{
114250003Sadrian		FREQ2FBIN(2412, 1),
115250003Sadrian		FREQ2FBIN(2437, 1),
116250003Sadrian		FREQ2FBIN(2462, 1)
117250003Sadrian	},
118250003Sadrian
119250003Sadrian	//static OSP_CAL_DATA_PER_FREQ_OP_LOOP cal_pier_data_2g[OSPREY_MAX_CHAINS][OSPREY_NUM_2G_CAL_PIERS]=
120250003Sadrian
121250003Sadrian	{	{{0,0,0,0,0,0},  {0,0,0,0,0,0},  {0,0,0,0,0,0}},
122250003Sadrian		{{0,0,0,0,0,0},  {0,0,0,0,0,0},  {0,0,0,0,0,0}},
123250003Sadrian		{{0,0,0,0,0,0},  {0,0,0,0,0,0},  {0,0,0,0,0,0}},
124250003Sadrian	},
125250003Sadrian
126250003Sadrian	//A_UINT8 cal_target_freqbin_cck[OSPREY_NUM_2G_CCK_TARGET_POWERS];
127250003Sadrian
128250003Sadrian	{
129250003Sadrian		FREQ2FBIN(2412, 1),
130250003Sadrian		FREQ2FBIN(2472, 1)
131250003Sadrian	},
132250003Sadrian
133250003Sadrian	//static CAL_TARGET_POWER_LEG cal_target_freqbin_2g[OSPREY_NUM_2G_20_TARGET_POWERS]
134250003Sadrian	{
135250003Sadrian		FREQ2FBIN(2412, 1),
136250003Sadrian		FREQ2FBIN(2437, 1),
137250003Sadrian		FREQ2FBIN(2472, 1)
138250003Sadrian	},
139250003Sadrian
140250003Sadrian	//static   OSP_CAL_TARGET_POWER_HT  cal_target_freqbin_2g_ht20[OSPREY_NUM_2G_20_TARGET_POWERS]
141250003Sadrian	{
142250003Sadrian		FREQ2FBIN(2412, 1),
143250003Sadrian		FREQ2FBIN(2437, 1),
144250003Sadrian		FREQ2FBIN(2472, 1)
145250003Sadrian	},
146250003Sadrian
147250003Sadrian	//static   OSP_CAL_TARGET_POWER_HT  cal_target_freqbin_2g_ht40[OSPREY_NUM_2G_40_TARGET_POWERS]
148250003Sadrian	{
149250003Sadrian		FREQ2FBIN(2412, 1),
150250003Sadrian		FREQ2FBIN(2437, 1),
151250003Sadrian		FREQ2FBIN(2472, 1)
152250003Sadrian	},
153250003Sadrian
154250003Sadrian	//static CAL_TARGET_POWER_LEG cal_target_power_cck[OSPREY_NUM_2G_CCK_TARGET_POWERS]=
155250003Sadrian	{
156250003Sadrian		//1L-5L,5S,11L,11S
157250003Sadrian        {{34,34,34,34}},
158250003Sadrian	 	{{34,34,34,34}}
159250003Sadrian	 },
160250003Sadrian
161250003Sadrian	//static CAL_TARGET_POWER_LEG cal_target_power_2g[OSPREY_NUM_2G_20_TARGET_POWERS]=
162250003Sadrian	{
163250003Sadrian        //6-24,36,48,54
164250003Sadrian		{{34,34,32,32}},
165250003Sadrian		{{34,34,32,32}},
166250003Sadrian		{{34,34,32,32}},
167250003Sadrian	},
168250003Sadrian
169250003Sadrian	//static   OSP_CAL_TARGET_POWER_HT  cal_target_power_2g_ht20[OSPREY_NUM_2G_20_TARGET_POWERS]=
170250003Sadrian	{
171250003Sadrian        //0_8_16,1-3_9-11_17-19,
172250003Sadrian        //      4,5,6,7,12,13,14,15,20,21,22,23
173250003Sadrian		{{32,32,32,32,32,30,32,32,30,28,28,28,28,24}},
174250003Sadrian		{{32,32,32,32,32,30,32,32,30,28,28,28,28,24}},
175250003Sadrian		{{32,32,32,32,32,30,32,32,30,28,28,28,28,24}},
176250003Sadrian	},
177250003Sadrian
178250003Sadrian	//static    OSP_CAL_TARGET_POWER_HT  cal_target_power_2g_ht40[OSPREY_NUM_2G_40_TARGET_POWERS]=
179250003Sadrian	{
180250003Sadrian        //0_8_16,1-3_9-11_17-19,
181250003Sadrian        //      4,5,6,7,12,13,14,15,20,21,22,23
182250003Sadrian		{{30,30,30,30,30,28,30,30,28,26,26,26,26,22}},
183250003Sadrian		{{30,30,30,30,30,28,30,30,28,26,26,26,26,22}},
184250003Sadrian		{{30,30,30,30,30,28,30,30,28,26,26,26,26,22}},
185250003Sadrian	},
186250003Sadrian
187250003Sadrian//static    A_UINT8            ctl_index_2g[OSPREY_NUM_CTLS_2G]=
188250003Sadrian
189250003Sadrian	{
190250003Sadrian
191250003Sadrian		    0x11,
192250003Sadrian    		0x12,
193250003Sadrian    		0x15,
194250003Sadrian    		0x17,
195250003Sadrian    		0x41,
196250003Sadrian    		0x42,
197250003Sadrian   			0x45,
198250003Sadrian    		0x47,
199250003Sadrian   			0x31,
200250003Sadrian    		0x32,
201250003Sadrian    		0x35,
202250003Sadrian    		0x37
203250003Sadrian
204250003Sadrian    },
205250003Sadrian
206250003Sadrian//A_UINT8   ctl_freqbin_2G[OSPREY_NUM_CTLS_2G][OSPREY_NUM_BAND_EDGES_2G];
207250003Sadrian
208250003Sadrian	{
209250003Sadrian		{FREQ2FBIN(2412, 1),
210250003Sadrian		 FREQ2FBIN(2417, 1),
211250003Sadrian		 FREQ2FBIN(2457, 1),
212250003Sadrian		 FREQ2FBIN(2462, 1)},
213250003Sadrian
214250003Sadrian		{FREQ2FBIN(2412, 1),
215250003Sadrian		 FREQ2FBIN(2417, 1),
216250003Sadrian		 FREQ2FBIN(2462, 1),
217250003Sadrian		 0xFF},
218250003Sadrian
219250003Sadrian		{FREQ2FBIN(2412, 1),
220250003Sadrian		 FREQ2FBIN(2417, 1),
221250003Sadrian		 FREQ2FBIN(2462, 1),
222250003Sadrian		 0xFF},
223250003Sadrian
224250003Sadrian		{FREQ2FBIN(2422, 1),
225250003Sadrian		 FREQ2FBIN(2427, 1),
226250003Sadrian		 FREQ2FBIN(2447, 1),
227250003Sadrian		 FREQ2FBIN(2452, 1)},
228250003Sadrian
229250003Sadrian		{/*Data[4].ctl_edges[0].bChannel*/FREQ2FBIN(2412, 1),
230250003Sadrian		/*Data[4].ctl_edges[1].bChannel*/FREQ2FBIN(2417, 1),
231250003Sadrian		/*Data[4].ctl_edges[2].bChannel*/FREQ2FBIN(2472, 1),
232250003Sadrian		/*Data[4].ctl_edges[3].bChannel*/FREQ2FBIN(2484, 1)},
233250003Sadrian
234250003Sadrian		{/*Data[5].ctl_edges[0].bChannel*/FREQ2FBIN(2412, 1),
235250003Sadrian		 /*Data[5].ctl_edges[1].bChannel*/FREQ2FBIN(2417, 1),
236250003Sadrian		 /*Data[5].ctl_edges[2].bChannel*/FREQ2FBIN(2472, 1),
237250003Sadrian		 0},
238250003Sadrian
239250003Sadrian		{/*Data[6].ctl_edges[0].bChannel*/FREQ2FBIN(2412, 1),
240250003Sadrian		 /*Data[6].ctl_edges[1].bChannel*/FREQ2FBIN(2417, 1),
241250003Sadrian		 FREQ2FBIN(2472, 1),
242250003Sadrian		 0},
243250003Sadrian
244250003Sadrian		{/*Data[7].ctl_edges[0].bChannel*/FREQ2FBIN(2422, 1),
245250003Sadrian		 /*Data[7].ctl_edges[1].bChannel*/FREQ2FBIN(2427, 1),
246250003Sadrian		 /*Data[7].ctl_edges[2].bChannel*/FREQ2FBIN(2447, 1),
247250003Sadrian		 /*Data[7].ctl_edges[3].bChannel*/FREQ2FBIN(2462, 1)},
248250003Sadrian
249250003Sadrian		{/*Data[8].ctl_edges[0].bChannel*/FREQ2FBIN(2412, 1),
250250003Sadrian		 /*Data[8].ctl_edges[1].bChannel*/FREQ2FBIN(2417, 1),
251250003Sadrian		 /*Data[8].ctl_edges[2].bChannel*/FREQ2FBIN(2472, 1),
252250003Sadrian		 0},
253250003Sadrian
254250003Sadrian		{/*Data[9].ctl_edges[0].bChannel*/FREQ2FBIN(2412, 1),
255250003Sadrian		 /*Data[9].ctl_edges[1].bChannel*/FREQ2FBIN(2417, 1),
256250003Sadrian		 /*Data[9].ctl_edges[2].bChannel*/FREQ2FBIN(2472, 1),
257250003Sadrian		 0},
258250003Sadrian
259250003Sadrian		{/*Data[10].ctl_edges[0].bChannel*/FREQ2FBIN(2412, 1),
260250003Sadrian		 /*Data[10].ctl_edges[1].bChannel*/FREQ2FBIN(2417, 1),
261250003Sadrian		 /*Data[10].ctl_edges[2].bChannel*/FREQ2FBIN(2472, 1),
262250003Sadrian		 0},
263250003Sadrian
264250003Sadrian		{/*Data[11].ctl_edges[0].bChannel*/FREQ2FBIN(2422, 1),
265250003Sadrian		 /*Data[11].ctl_edges[1].bChannel*/FREQ2FBIN(2427, 1),
266250003Sadrian		 /*Data[11].ctl_edges[2].bChannel*/FREQ2FBIN(2447, 1),
267250003Sadrian		 /*Data[11].ctl_edges[3].bChannel*/FREQ2FBIN(2462, 1)}
268250003Sadrian	},
269250003Sadrian
270250003Sadrian
271250003Sadrian//OSP_CAL_CTL_DATA_2G   ctl_power_data_2g[OSPREY_NUM_CTLS_2G];
272250003Sadrian
273250003Sadrian#if AH_BYTE_ORDER == AH_BIG_ENDIAN
274250003Sadrian    {
275250003Sadrian
276250003Sadrian	    {{{0, 60}, {1, 60}, {0, 60}, {0, 60}}},
277250003Sadrian	    {{{0, 60}, {1, 60}, {0, 60}, {0, 60}}},
278250003Sadrian	    {{{1, 60}, {0, 60}, {0, 60}, {1, 60}}},
279250003Sadrian
280250003Sadrian	    {{{1, 60}, {0, 60}, {0, 60}, {0, 60}}},
281250003Sadrian	    {{{0, 60}, {1, 60}, {0, 60}, {0, 60}}},
282250003Sadrian	    {{{0, 60}, {1, 60}, {0, 60}, {0, 60}}},
283250003Sadrian
284250003Sadrian	    {{{0, 60}, {1, 60}, {1, 60}, {0, 60}}},
285250003Sadrian	    {{{0, 60}, {1, 60}, {0, 60}, {0, 60}}},
286250003Sadrian	    {{{0, 60}, {1, 60}, {0, 60}, {0, 60}}},
287250003Sadrian
288250003Sadrian	    {{{0, 60}, {1, 60}, {0, 60}, {0, 60}}},
289250003Sadrian	    {{{0, 60}, {1, 60}, {1, 60}, {1, 60}}},
290250003Sadrian
291250003Sadrian    },
292250003Sadrian#else
293250003Sadrian	{
294250003Sadrian	    {{{60, 0}, {60, 1}, {60, 0}, {60, 0}}},
295250003Sadrian	    {{{60, 0}, {60, 1}, {60, 0}, {60, 0}}},
296250003Sadrian	    {{{60, 1}, {60, 0}, {60, 0}, {60, 1}}},
297250003Sadrian
298250003Sadrian	    {{{60, 1}, {60, 0}, {60, 0}, {60, 0}}},
299250003Sadrian	    {{{60, 0}, {60, 1}, {60, 0}, {60, 0}}},
300250003Sadrian	    {{{60, 0}, {60, 1}, {60, 0}, {60, 0}}},
301250003Sadrian
302250003Sadrian	    {{{60, 0}, {60, 1}, {60, 1}, {60, 0}}},
303250003Sadrian	    {{{60, 0}, {60, 1}, {60, 0}, {60, 0}}},
304250003Sadrian	    {{{60, 0}, {60, 1}, {60, 0}, {60, 0}}},
305250003Sadrian
306250003Sadrian	    {{{60, 0}, {60, 1}, {60, 0}, {60, 0}}},
307250003Sadrian	    {{{60, 0}, {60, 1}, {60, 1}, {60, 1}}},
308250003Sadrian	},
309250003Sadrian#endif
310250003Sadrian
311250003Sadrian//static    OSPREY_MODAL_EEP_HEADER   modal_header_5g=
312250003Sadrian
313250003Sadrian	{
314250003Sadrian
315250003Sadrian		    0x220,			//  ant_ctrl_common;                         // 4   idle, t1, t2, b (4 bits per setting)
316250003Sadrian		    0x44444,		//  ant_ctrl_common2;                        // 4    ra1l1, ra2l1, ra1l2, ra2l2, ra12
317250003Sadrian		    {0x150,0x150,0x150},	//  ant_ctrl_chain[OSPREY_MAX_CHAINS];       // 6   idle, t, r, rx1, rx12, b (2 bits each)
318250003Sadrian		    {0,0,0},			//   xatten1_db[OSPREY_MAX_CHAINS];           // 3  //xatten1_db for merlin (0xa20c/b20c 5:0)
319250003Sadrian		    {0,0,0},			//   xatten1_margin[OSPREY_MAX_CHAINS];          // 3  //xatten1_margin for merlin (0xa20c/b20c 16:12
320250003Sadrian			45,				//    temp_slope;
321250003Sadrian			0,				//    voltSlope;
322250003Sadrian		    {0,0,0,0,0}, // spur_chans[OSPREY_EEPROM_MODAL_SPURS];  // spur channels in usual fbin coding format
323250003Sadrian		    {-1,0,0},			//    noise_floor_thresh_ch[OSPREY_MAX_CHAINS]; // 3    //Check if the register is per chain
324250003Sadrian			{0, 0, 0, 0, 0, 0,0,0,0,0,0},				// reserved
325250003Sadrian			0,											// quick drop
326250003Sadrian		    0,				//   xpa_bias_lvl;                            // 1
327250003Sadrian		    0x0e,			//   tx_frame_to_data_start;                    // 1
328250003Sadrian		    0x0e,			//   tx_frame_to_pa_on;                         // 1
329250003Sadrian		    3,				//   txClip;                                     // 4 bits tx_clip, 4 bits dac_scale_cck
330250003Sadrian		    0,				//    antenna_gain;                           // 1
331250003Sadrian		    0x2d,			//   switchSettling;                        // 1
332250003Sadrian		    -30,			//    adcDesiredSize;                        // 1
333250003Sadrian		    0,				//   txEndToXpaOff;                         // 1
334250003Sadrian		    0x2,			//   txEndToRxOn;                           // 1
335250003Sadrian		    0xe,			//   tx_frame_to_xpa_on;                        // 1
336250003Sadrian		    28,				//   thresh62;                              // 1
337250003Sadrian  			0xf0e0e0,		//	 paprd_rate_mask_ht20						// 4
338250003Sadrian  			0xf0e0e0,		//	 paprd_rate_mask_ht40						// 4
339250003Sadrian		    0,				//   switchcomspdt;                         // 2
340250003Sadrian			0,				// bit: 0,1:chain0, 2,3:chain1, 4,5:chain2
341250003Sadrian			0,				//  rf_gain_cap
342250003Sadrian			0,				//  tx_gain_cap
343250003Sadrian			{0,0,0,0,0}    //futureModal[5];
344250003Sadrian	},
345250003Sadrian
346250003Sadrian	{				// base_ext2
347250003Sadrian		40,				// temp_slope_low
348250003Sadrian		50,				// temp_slope_high
349250003Sadrian		{0,0,0},
350250003Sadrian		{0,0,0},
351250003Sadrian		{0,0,0},
352250003Sadrian		{0,0,0}
353250003Sadrian	},
354250003Sadrian
355250003Sadrian//static    A_UINT8            cal_freq_pier_5g[OSPREY_NUM_5G_CAL_PIERS]=
356250003Sadrian	{
357250003Sadrian		    //pPiers[0] =
358250003Sadrian		    FREQ2FBIN(5180, 0),
359250003Sadrian		    //pPiers[1] =
360250003Sadrian		    FREQ2FBIN(5220, 0),
361250003Sadrian		    //pPiers[2] =
362250003Sadrian		    FREQ2FBIN(5320, 0),
363250003Sadrian		    //pPiers[3] =
364250003Sadrian		    FREQ2FBIN(5400, 0),
365250003Sadrian		    //pPiers[4] =
366250003Sadrian		    FREQ2FBIN(5500, 0),
367250003Sadrian		    //pPiers[5] =
368250003Sadrian		    FREQ2FBIN(5600, 0),
369250003Sadrian		    //pPiers[6] =
370250003Sadrian		    FREQ2FBIN(5700, 0),
371250003Sadrian    		//pPiers[7] =
372250003Sadrian		    FREQ2FBIN(5785, 0),
373250003Sadrian	},
374250003Sadrian
375250003Sadrian//static    OSP_CAL_DATA_PER_FREQ_OP_LOOP cal_pier_data_5g[OSPREY_MAX_CHAINS][OSPREY_NUM_5G_CAL_PIERS]=
376250003Sadrian
377250003Sadrian	{
378250003Sadrian		{{0,0,0,0,0,0},  {0,0,0,0,0,0},  {0,0,0,0,0,0},  {0,0,0,0,0,0},  {0,0,0,0,0,0},  {0,0,0,0,0,0},    {0,0,0,0,0,0},  {0,0,0,0,0,0}},
379250003Sadrian		{{0,0,0,0,0,0},  {0,0,0,0,0,0},  {0,0,0,0,0,0},  {0,0,0,0,0,0},  {0,0,0,0,0,0},  {0,0,0,0,0,0},    {0,0,0,0,0,0},  {0,0,0,0,0,0}},
380250003Sadrian		{{0,0,0,0,0,0},  {0,0,0,0,0,0},  {0,0,0,0,0,0},  {0,0,0,0,0,0},  {0,0,0,0,0,0},  {0,0,0,0,0,0},    {0,0,0,0,0,0},  {0,0,0,0,0,0}},
381250003Sadrian
382250003Sadrian	},
383250003Sadrian
384250003Sadrian//static    CAL_TARGET_POWER_LEG cal_target_freqbin_5g[OSPREY_NUM_5G_20_TARGET_POWERS]=
385250003Sadrian
386250003Sadrian	{
387250003Sadrian			FREQ2FBIN(5180, 0),
388250003Sadrian			FREQ2FBIN(5240, 0),
389250003Sadrian			FREQ2FBIN(5320, 0),
390250003Sadrian			FREQ2FBIN(5400, 0),
391250003Sadrian			FREQ2FBIN(5500, 0),
392250003Sadrian			FREQ2FBIN(5600, 0),
393250003Sadrian			FREQ2FBIN(5700, 0),
394250003Sadrian			FREQ2FBIN(5825, 0)
395250003Sadrian	},
396250003Sadrian
397250003Sadrian//static    OSP_CAL_TARGET_POWER_HT  cal_target_power_5g_ht20[OSPREY_NUM_5G_20_TARGET_POWERS]=
398250003Sadrian
399250003Sadrian	{
400250003Sadrian			FREQ2FBIN(5180, 0),
401250003Sadrian			FREQ2FBIN(5240, 0),
402250003Sadrian			FREQ2FBIN(5320, 0),
403250003Sadrian			FREQ2FBIN(5400, 0),
404250003Sadrian			FREQ2FBIN(5500, 0),
405250003Sadrian			FREQ2FBIN(5700, 0),
406250003Sadrian			FREQ2FBIN(5745, 0),
407250003Sadrian			FREQ2FBIN(5825, 0)
408250003Sadrian	},
409250003Sadrian
410250003Sadrian//static    OSP_CAL_TARGET_POWER_HT  cal_target_power_5g_ht40[OSPREY_NUM_5G_40_TARGET_POWERS]=
411250003Sadrian
412250003Sadrian	{
413250003Sadrian			FREQ2FBIN(5180, 0),
414250003Sadrian			FREQ2FBIN(5240, 0),
415250003Sadrian			FREQ2FBIN(5320, 0),
416250003Sadrian			FREQ2FBIN(5400, 0),
417250003Sadrian			FREQ2FBIN(5500, 0),
418250003Sadrian			FREQ2FBIN(5700, 0),
419250003Sadrian			FREQ2FBIN(5745, 0),
420250003Sadrian			FREQ2FBIN(5825, 0)
421250003Sadrian	},
422250003Sadrian
423250003Sadrian
424250003Sadrian//static    CAL_TARGET_POWER_LEG cal_target_power_5g[OSPREY_NUM_5G_20_TARGET_POWERS]=
425250003Sadrian
426250003Sadrian
427250003Sadrian	{
428250003Sadrian        //6-24,36,48,54
429250003Sadrian	    {{30,30,28,24}},
430250003Sadrian	    {{30,30,28,24}},
431250003Sadrian	    {{30,30,28,24}},
432250003Sadrian	    {{30,30,28,24}},
433250003Sadrian	    {{30,30,28,24}},
434250003Sadrian	    {{30,30,28,24}},
435250003Sadrian	    {{30,30,28,24}},
436250003Sadrian	    {{30,30,28,24}},
437250003Sadrian	},
438250003Sadrian
439250003Sadrian//static    OSP_CAL_TARGET_POWER_HT  cal_target_power_5g_ht20[OSPREY_NUM_5G_20_TARGET_POWERS]=
440250003Sadrian
441250003Sadrian	{
442250003Sadrian        //0_8_16,1-3_9-11_17-19,
443250003Sadrian        //      4,5,6,7,12,13,14,15,20,21,22,23
444250003Sadrian	    {{30,30,30,28,24,20,30,28,24,20,20,20,20,16}},
445250003Sadrian	    {{30,30,30,28,24,20,30,28,24,20,20,20,20,16}},
446250003Sadrian	    {{30,30,30,26,22,18,30,26,22,18,18,18,18,16}},
447250003Sadrian	    {{30,30,30,26,22,18,30,26,22,18,18,18,18,16}},
448250003Sadrian	    {{30,30,30,24,20,16,30,24,20,16,16,16,16,14}},
449250003Sadrian	    {{30,30,30,24,20,16,30,24,20,16,16,16,16,14}},
450250003Sadrian	    {{30,30,30,22,18,14,30,22,18,14,14,14,14,12}},
451250003Sadrian	    {{30,30,30,22,18,14,30,22,18,14,14,14,14,12}},
452250003Sadrian	},
453250003Sadrian
454250003Sadrian//static    OSP_CAL_TARGET_POWER_HT  cal_target_power_5g_ht40[OSPREY_NUM_5G_40_TARGET_POWERS]=
455250003Sadrian	{
456250003Sadrian        //0_8_16,1-3_9-11_17-19,
457250003Sadrian        //      4,5,6,7,12,13,14,15,20,21,22,23
458250003Sadrian	    {{28,28,28,26,22,18,28,26,22,18,18,18,18,14}},
459250003Sadrian	    {{28,28,28,26,22,18,28,26,22,18,18,18,18,14}},
460250003Sadrian	    {{28,28,28,24,20,16,28,24,20,16,16,16,16,12}},
461250003Sadrian	    {{28,28,28,24,20,16,28,24,20,16,16,16,16,12}},
462250003Sadrian	    {{28,28,28,22,18,14,28,22,18,14,14,14,14,10}},
463250003Sadrian	    {{28,28,28,22,18,14,28,22,18,14,14,14,14,10}},
464250003Sadrian	    {{28,28,28,20,16,12,28,20,16,12,12,12,12,8}},
465250003Sadrian	    {{28,28,28,20,16,12,28,20,16,12,12,12,12,8}},
466250003Sadrian	},
467250003Sadrian
468250003Sadrian//static    A_UINT8            ctl_index_5g[OSPREY_NUM_CTLS_5G]=
469250003Sadrian
470250003Sadrian	{
471250003Sadrian		    //pCtlIndex[0] =
472250003Sadrian		    0x10,
473250003Sadrian		    //pCtlIndex[1] =
474250003Sadrian		    0x16,
475250003Sadrian		    //pCtlIndex[2] =
476250003Sadrian		    0x18,
477250003Sadrian		    //pCtlIndex[3] =
478250003Sadrian		    0x40,
479250003Sadrian		    //pCtlIndex[4] =
480250003Sadrian		    0x46,
481250003Sadrian		    //pCtlIndex[5] =
482250003Sadrian		    0x48,
483250003Sadrian		    //pCtlIndex[6] =
484250003Sadrian		    0x30,
485250003Sadrian		    //pCtlIndex[7] =
486250003Sadrian		    0x36,
487250003Sadrian    		//pCtlIndex[8] =
488250003Sadrian    		0x38
489250003Sadrian	},
490250003Sadrian
491250003Sadrian//    A_UINT8   ctl_freqbin_5G[OSPREY_NUM_CTLS_5G][OSPREY_NUM_BAND_EDGES_5G];
492250003Sadrian
493250003Sadrian	{
494250003Sadrian	    {/* Data[0].ctl_edges[0].bChannel*/FREQ2FBIN(5180, 0),
495250003Sadrian	    /* Data[0].ctl_edges[1].bChannel*/FREQ2FBIN(5260, 0),
496250003Sadrian	    /* Data[0].ctl_edges[2].bChannel*/FREQ2FBIN(5280, 0),
497250003Sadrian	    /* Data[0].ctl_edges[3].bChannel*/FREQ2FBIN(5500, 0),
498250003Sadrian	    /* Data[0].ctl_edges[4].bChannel*/FREQ2FBIN(5600, 0),
499250003Sadrian	    /* Data[0].ctl_edges[5].bChannel*/FREQ2FBIN(5700, 0),
500250003Sadrian	    /* Data[0].ctl_edges[6].bChannel*/FREQ2FBIN(5745, 0),
501250003Sadrian	    /* Data[0].ctl_edges[7].bChannel*/FREQ2FBIN(5825, 0)},
502250003Sadrian
503250003Sadrian	    {/* Data[1].ctl_edges[0].bChannel*/FREQ2FBIN(5180, 0),
504250003Sadrian	    /* Data[1].ctl_edges[1].bChannel*/FREQ2FBIN(5260, 0),
505250003Sadrian	    /* Data[1].ctl_edges[2].bChannel*/FREQ2FBIN(5280, 0),
506250003Sadrian	    /* Data[1].ctl_edges[3].bChannel*/FREQ2FBIN(5500, 0),
507250003Sadrian	    /* Data[1].ctl_edges[4].bChannel*/FREQ2FBIN(5520, 0),
508250003Sadrian	    /* Data[1].ctl_edges[5].bChannel*/FREQ2FBIN(5700, 0),
509250003Sadrian	    /* Data[1].ctl_edges[6].bChannel*/FREQ2FBIN(5745, 0),
510250003Sadrian	    /* Data[1].ctl_edges[7].bChannel*/FREQ2FBIN(5825, 0)},
511250003Sadrian
512250003Sadrian	    {/* Data[2].ctl_edges[0].bChannel*/FREQ2FBIN(5190, 0),
513250003Sadrian	    /* Data[2].ctl_edges[1].bChannel*/FREQ2FBIN(5230, 0),
514250003Sadrian	    /* Data[2].ctl_edges[2].bChannel*/FREQ2FBIN(5270, 0),
515250003Sadrian	    /* Data[2].ctl_edges[3].bChannel*/FREQ2FBIN(5310, 0),
516250003Sadrian	    /* Data[2].ctl_edges[4].bChannel*/FREQ2FBIN(5510, 0),
517250003Sadrian	    /* Data[2].ctl_edges[5].bChannel*/FREQ2FBIN(5550, 0),
518250003Sadrian	    /* Data[2].ctl_edges[6].bChannel*/FREQ2FBIN(5670, 0),
519250003Sadrian	    /* Data[2].ctl_edges[7].bChannel*/FREQ2FBIN(5755, 0)},
520250003Sadrian
521250003Sadrian	    {/* Data[3].ctl_edges[0].bChannel*/FREQ2FBIN(5180, 0),
522250003Sadrian	    /* Data[3].ctl_edges[1].bChannel*/FREQ2FBIN(5200, 0),
523250003Sadrian	    /* Data[3].ctl_edges[2].bChannel*/FREQ2FBIN(5260, 0),
524250003Sadrian	    /* Data[3].ctl_edges[3].bChannel*/FREQ2FBIN(5320, 0),
525250003Sadrian	    /* Data[3].ctl_edges[4].bChannel*/FREQ2FBIN(5500, 0),
526250003Sadrian	    /* Data[3].ctl_edges[5].bChannel*/FREQ2FBIN(5700, 0),
527250003Sadrian	    /* Data[3].ctl_edges[6].bChannel*/0xFF,
528250003Sadrian	    /* Data[3].ctl_edges[7].bChannel*/0xFF},
529250003Sadrian
530250003Sadrian	    {/* Data[4].ctl_edges[0].bChannel*/FREQ2FBIN(5180, 0),
531250003Sadrian	    /* Data[4].ctl_edges[1].bChannel*/FREQ2FBIN(5260, 0),
532250003Sadrian	    /* Data[4].ctl_edges[2].bChannel*/FREQ2FBIN(5500, 0),
533250003Sadrian	    /* Data[4].ctl_edges[3].bChannel*/FREQ2FBIN(5700, 0),
534250003Sadrian	    /* Data[4].ctl_edges[4].bChannel*/0xFF,
535250003Sadrian	    /* Data[4].ctl_edges[5].bChannel*/0xFF,
536250003Sadrian	    /* Data[4].ctl_edges[6].bChannel*/0xFF,
537250003Sadrian	    /* Data[4].ctl_edges[7].bChannel*/0xFF},
538250003Sadrian
539250003Sadrian	    {/* Data[5].ctl_edges[0].bChannel*/FREQ2FBIN(5190, 0),
540250003Sadrian	    /* Data[5].ctl_edges[1].bChannel*/FREQ2FBIN(5270, 0),
541250003Sadrian	    /* Data[5].ctl_edges[2].bChannel*/FREQ2FBIN(5310, 0),
542250003Sadrian	    /* Data[5].ctl_edges[3].bChannel*/FREQ2FBIN(5510, 0),
543250003Sadrian	    /* Data[5].ctl_edges[4].bChannel*/FREQ2FBIN(5590, 0),
544250003Sadrian	    /* Data[5].ctl_edges[5].bChannel*/FREQ2FBIN(5670, 0),
545250003Sadrian	    /* Data[5].ctl_edges[6].bChannel*/0xFF,
546250003Sadrian	    /* Data[5].ctl_edges[7].bChannel*/0xFF},
547250003Sadrian
548250003Sadrian	    {/* Data[6].ctl_edges[0].bChannel*/FREQ2FBIN(5180, 0),
549250003Sadrian	    /* Data[6].ctl_edges[1].bChannel*/FREQ2FBIN(5200, 0),
550250003Sadrian	    /* Data[6].ctl_edges[2].bChannel*/FREQ2FBIN(5220, 0),
551250003Sadrian	    /* Data[6].ctl_edges[3].bChannel*/FREQ2FBIN(5260, 0),
552250003Sadrian	    /* Data[6].ctl_edges[4].bChannel*/FREQ2FBIN(5500, 0),
553250003Sadrian	    /* Data[6].ctl_edges[5].bChannel*/FREQ2FBIN(5600, 0),
554250003Sadrian	    /* Data[6].ctl_edges[6].bChannel*/FREQ2FBIN(5700, 0),
555250003Sadrian	    /* Data[6].ctl_edges[7].bChannel*/FREQ2FBIN(5745, 0)},
556250003Sadrian
557250003Sadrian	    {/* Data[7].ctl_edges[0].bChannel*/FREQ2FBIN(5180, 0),
558250003Sadrian	    /* Data[7].ctl_edges[1].bChannel*/FREQ2FBIN(5260, 0),
559250003Sadrian	    /* Data[7].ctl_edges[2].bChannel*/FREQ2FBIN(5320, 0),
560250003Sadrian	    /* Data[7].ctl_edges[3].bChannel*/FREQ2FBIN(5500, 0),
561250003Sadrian	    /* Data[7].ctl_edges[4].bChannel*/FREQ2FBIN(5560, 0),
562250003Sadrian	    /* Data[7].ctl_edges[5].bChannel*/FREQ2FBIN(5700, 0),
563250003Sadrian	    /* Data[7].ctl_edges[6].bChannel*/FREQ2FBIN(5745, 0),
564250003Sadrian	    /* Data[7].ctl_edges[7].bChannel*/FREQ2FBIN(5825, 0)},
565250003Sadrian
566250003Sadrian	    {/* Data[8].ctl_edges[0].bChannel*/FREQ2FBIN(5190, 0),
567250003Sadrian	    /* Data[8].ctl_edges[1].bChannel*/FREQ2FBIN(5230, 0),
568250003Sadrian	    /* Data[8].ctl_edges[2].bChannel*/FREQ2FBIN(5270, 0),
569250003Sadrian	    /* Data[8].ctl_edges[3].bChannel*/FREQ2FBIN(5510, 0),
570250003Sadrian	    /* Data[8].ctl_edges[4].bChannel*/FREQ2FBIN(5550, 0),
571250003Sadrian	    /* Data[8].ctl_edges[5].bChannel*/FREQ2FBIN(5670, 0),
572250003Sadrian	    /* Data[8].ctl_edges[6].bChannel*/FREQ2FBIN(5755, 0),
573250003Sadrian	    /* Data[8].ctl_edges[7].bChannel*/FREQ2FBIN(5795, 0)}
574250003Sadrian	},
575250003Sadrian
576250003Sadrian//static    OSP_CAL_CTL_DATA_5G   ctlData_5G[OSPREY_NUM_CTLS_5G]=
577250003Sadrian
578250003Sadrian#if AH_BYTE_ORDER == AH_BIG_ENDIAN
579250003Sadrian	{
580250003Sadrian	    {{{1, 60},
581250003Sadrian	      {1, 60},
582250003Sadrian	      {1, 60},
583250003Sadrian	      {1, 60},
584250003Sadrian	      {1, 60},
585250003Sadrian	      {1, 60},
586250003Sadrian	      {1, 60},
587250003Sadrian	      {0, 60}}},
588250003Sadrian
589250003Sadrian	    {{{1, 60},
590250003Sadrian	      {1, 60},
591250003Sadrian	      {1, 60},
592250003Sadrian	      {1, 60},
593250003Sadrian	      {1, 60},
594250003Sadrian	      {1, 60},
595250003Sadrian	      {1, 60},
596250003Sadrian	      {0, 60}}},
597250003Sadrian
598250003Sadrian	    {{{0, 60},
599250003Sadrian	      {1, 60},
600250003Sadrian	      {0, 60},
601250003Sadrian	      {1, 60},
602250003Sadrian	      {1, 60},
603250003Sadrian	      {1, 60},
604250003Sadrian	      {1, 60},
605250003Sadrian	      {1, 60}}},
606250003Sadrian
607250003Sadrian	    {{{0, 60},
608250003Sadrian	      {1, 60},
609250003Sadrian	      {1, 60},
610250003Sadrian	      {0, 60},
611250003Sadrian	      {1, 60},
612250003Sadrian	      {0, 60},
613250003Sadrian	      {0, 60},
614250003Sadrian	      {0, 60}}},
615250003Sadrian
616250003Sadrian	    {{{1, 60},
617250003Sadrian	      {1, 60},
618250003Sadrian	      {1, 60},
619250003Sadrian	      {0, 60},
620250003Sadrian	      {0, 60},
621250003Sadrian	      {0, 60},
622250003Sadrian	      {0, 60},
623250003Sadrian	      {0, 60}}},
624250003Sadrian
625250003Sadrian	    {{{1, 60},
626250003Sadrian	      {1, 60},
627250003Sadrian	      {1, 60},
628250003Sadrian	      {1, 60},
629250003Sadrian	      {1, 60},
630250003Sadrian	      {0, 60},
631250003Sadrian	      {0, 60},
632250003Sadrian	      {0, 60}}},
633250003Sadrian
634250003Sadrian	    {{{1, 60},
635250003Sadrian	      {1, 60},
636250003Sadrian	      {1, 60},
637250003Sadrian	      {1, 60},
638250003Sadrian	      {1, 60},
639250003Sadrian	      {1, 60},
640250003Sadrian	      {1, 60},
641250003Sadrian	      {1, 60}}},
642250003Sadrian
643250003Sadrian	    {{{1, 60},
644250003Sadrian	      {1, 60},
645250003Sadrian	      {0, 60},
646250003Sadrian	      {1, 60},
647250003Sadrian	      {1, 60},
648250003Sadrian	      {1, 60},
649250003Sadrian	      {1, 60},
650250003Sadrian	      {0, 60}}},
651250003Sadrian
652250003Sadrian	    {{{1, 60},
653250003Sadrian	      {0, 60},
654250003Sadrian	      {1, 60},
655250003Sadrian	      {1, 60},
656250003Sadrian	      {1, 60},
657250003Sadrian	      {1, 60},
658250003Sadrian	      {0, 60},
659250003Sadrian	      {1, 60}}},
660250003Sadrian	}
661250003Sadrian#else
662250003Sadrian	{
663250003Sadrian	    {{{60, 1},
664250003Sadrian	      {60, 1},
665250003Sadrian	      {60, 1},
666250003Sadrian	      {60, 1},
667250003Sadrian	      {60, 1},
668250003Sadrian	      {60, 1},
669250003Sadrian	      {60, 1},
670250003Sadrian	      {60, 0}}},
671250003Sadrian
672250003Sadrian	    {{{60, 1},
673250003Sadrian	      {60, 1},
674250003Sadrian	      {60, 1},
675250003Sadrian	      {60, 1},
676250003Sadrian	      {60, 1},
677250003Sadrian	      {60, 1},
678250003Sadrian	      {60, 1},
679250003Sadrian	      {60, 0}}},
680250003Sadrian
681250003Sadrian	    {{{60, 0},
682250003Sadrian	      {60, 1},
683250003Sadrian	      {60, 0},
684250003Sadrian	      {60, 1},
685250003Sadrian	      {60, 1},
686250003Sadrian	      {60, 1},
687250003Sadrian	      {60, 1},
688250003Sadrian	      {60, 1}}},
689250003Sadrian
690250003Sadrian	    {{{60, 0},
691250003Sadrian	      {60, 1},
692250003Sadrian	      {60, 1},
693250003Sadrian	      {60, 0},
694250003Sadrian	      {60, 1},
695250003Sadrian	      {60, 0},
696250003Sadrian	      {60, 0},
697250003Sadrian	      {60, 0}}},
698250003Sadrian
699250003Sadrian	    {{{60, 1},
700250003Sadrian	      {60, 1},
701250003Sadrian	      {60, 1},
702250003Sadrian	      {60, 0},
703250003Sadrian	      {60, 0},
704250003Sadrian	      {60, 0},
705250003Sadrian	      {60, 0},
706250003Sadrian	      {60, 0}}},
707250003Sadrian
708250003Sadrian	    {{{60, 1},
709250003Sadrian	      {60, 1},
710250003Sadrian	      {60, 1},
711250003Sadrian	      {60, 1},
712250003Sadrian	      {60, 1},
713250003Sadrian	      {60, 0},
714250003Sadrian	      {60, 0},
715250003Sadrian	      {60, 0}}},
716250003Sadrian
717250003Sadrian	    {{{60, 1},
718250003Sadrian	      {60, 1},
719250003Sadrian	      {60, 1},
720250003Sadrian	      {60, 1},
721250003Sadrian	      {60, 1},
722250003Sadrian	      {60, 1},
723250003Sadrian	      {60, 1},
724250003Sadrian	      {60, 1}}},
725250003Sadrian
726250003Sadrian	    {{{60, 1},
727250003Sadrian	      {60, 1},
728250003Sadrian	      {60, 0},
729250003Sadrian	      {60, 1},
730250003Sadrian	      {60, 1},
731250003Sadrian	      {60, 1},
732250003Sadrian	      {60, 1},
733250003Sadrian	      {60, 0}}},
734250003Sadrian
735250003Sadrian	    {{{60, 1},
736250003Sadrian	      {60, 0},
737250003Sadrian	      {60, 1},
738250003Sadrian	      {60, 1},
739250003Sadrian	      {60, 1},
740250003Sadrian	      {60, 1},
741250003Sadrian	      {60, 0},
742250003Sadrian	      {60, 1}}},
743250003Sadrian	}
744250003Sadrian#endif
745250003Sadrian};
746250003Sadrian
747250003Sadrian#endif
748250003Sadrian
749