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 __ar9300template_wasp_2_h__
26250003Sadrian#define __ar9300template_wasp_2_h__
27250003Sadrianstatic ar9300_eeprom_t ar9300_template_wasp_2=
28250003Sadrian{
29250003Sadrian
30250003Sadrian	2, //  eepromVersion;
31250003Sadrian
32250003Sadrian    ar9300_eeprom_template_wasp_2, //  templateVersion;
33250003Sadrian
34250003Sadrian	{0x00,0x03,0x7f,0x0,0x0,0x0}, //mac_addr[6];
35250003Sadrian
36250003Sadrian    //static  A_UINT8   custData[OSPREY_CUSTOMER_DATA_SIZE]=
37250003Sadrian
38250003Sadrian	{0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},
39250003Sadrian
40250003Sadrian    //static OSPREY_BASE_EEP_HEADER baseEepHeader=
41250003Sadrian
42250003Sadrian	{
43250003Sadrian		    {0,0x1f},	//   regDmn[2]; //Does this need to be outside of this structure, if it gets written after calibration
44250003Sadrian		    0x33,	//   txrxMask;  //4 bits tx and 4 bits rx
45250003Sadrian		    {AR9300_OPFLAGS_11G | AR9300_OPFLAGS_11A, 3},	//   opCapFlags;
46250003Sadrian		    0,		//   rfSilent;
47250003Sadrian		    0,		//   blueToothOptions;
48250003Sadrian		    0,		//   deviceCap;
49250003Sadrian		    4,		//   deviceType; // takes lower byte in eeprom location
50250003Sadrian		    OSPREY_PWR_TABLE_OFFSET,	//    pwrTableOffset; // offset in dB to be added to beginning of pdadc table in calibration
51250003Sadrian			{0,0},	//   params_for_tuning_caps[2];  //placeholder, get more details from Don
52250003Sadrian            0x0c,     //featureEnable; //bit0 - enable tx temp comp
53250003Sadrian                             //bit1 - enable tx volt comp
54250003Sadrian                             //bit2 - enable fastClock - default to 1
55250003Sadrian                             //bit3 - enable doubling - default to 1
56250003Sadrian 							 //bit4 - enable internal regulator - default to 0
57250003Sadrian    		0,       //miscConfiguration: bit0 - turn down drivestrength
58250003Sadrian			3,		// eepromWriteEnableGpio
59250003Sadrian			0,		// wlanDisableGpio
60250003Sadrian			8,		// wlanLedGpio
61250003Sadrian			0xff,		// rxBandSelectGpio
62250003Sadrian			0,			// txrxgain
63250003Sadrian            0,		//   swreg
64250003Sadrian	},
65250003Sadrian
66250003Sadrian
67250003Sadrian	//static OSPREY_MODAL_EEP_HEADER modalHeader2G=
68250003Sadrian	{
69250003Sadrian
70250003Sadrian		    0x220,			//  antCtrlCommon;                         // 4   idle, t1, t2, b (4 bits per setting)
71250003Sadrian		    0x88888,		//  antCtrlCommon2;                        // 4    ra1l1, ra2l1, ra1l2, ra2l2, ra12
72250003Sadrian		    {0x150,0x150,0x150},	//  antCtrlChain[OSPREY_MAX_CHAINS];       // 6   idle, t, r, rx1, rx12, b (2 bits each)
73250003Sadrian		    {0,0,0},			//   xatten1DB[OSPREY_MAX_CHAINS];           // 3  //xatten1_db for merlin (0xa20c/b20c 5:0)
74250003Sadrian		    {0,0,0},			//   xatten1Margin[OSPREY_MAX_CHAINS];          // 3  //xatten1_margin for merlin (0xa20c/b20c 16:12
75250003Sadrian			36,				//    tempSlope;
76250003Sadrian			0,				//    voltSlope;
77250003Sadrian		    {0,0,0,0,0}, // spurChans[OSPREY_EEPROM_MODAL_SPURS];  // spur channels in usual fbin coding format
78250003Sadrian		    {-1,0,0},			//    noiseFloorThreshCh[OSPREY_MAX_CHAINS]; // 3    //Check if the register is per chain
79250003Sadrian            {0, 0, 0, 0, 0, 0,0,0,0,0,0},               // reserved
80250003Sadrian            0,                                          // quick drop
81250003Sadrian		    0,				//   xpaBiasLvl;                            // 1
82250003Sadrian		    0x0e,			//   txFrameToDataStart;                    // 1
83250003Sadrian		    0x0e,			//   txFrameToPaOn;                         // 1
84250003Sadrian		    3,				//   txClip;                                     // 4 bits tx_clip, 4 bits dac_scale_cck
85250003Sadrian		    0,				//    antennaGain;                           // 1
86250003Sadrian		    0x2c,			//   switchSettling;                        // 1
87250003Sadrian		    -30,			//    adcDesiredSize;                        // 1
88250003Sadrian		    0,				//   txEndToXpaOff;                         // 1
89250003Sadrian		    0x2,			//   txEndToRxOn;                           // 1
90250003Sadrian		    0xe,			//   txFrameToXpaOn;                        // 1
91250003Sadrian		    28,				//   thresh62;                              // 1
92250003Sadrian			0x0c80C080,		//	 papdRateMaskHt20						// 4
93250003Sadrian  			0x0080C080,		//	 papdRateMaskHt40
94250003Sadrian		    0,				//   switchcomspdt;                         // 2
95250003Sadrian			0,				// bit: 0,1:chain0, 2,3:chain1, 4,5:chain2
96250003Sadrian			0,				//  rf_gain_cap
97250003Sadrian			0,				//  tx_gain_cap
98250003Sadrian			{0,0,0,0,0}    //futureModal[5];
99250003Sadrian	},
100250003Sadrian
101250003Sadrian	{
102250003Sadrian		0,									//   ant_div_control
103250003Sadrian			{0,0},					// base_ext1
104250003Sadrian			0,						// misc_enable
105250003Sadrian			{0,0,0,0,0,0,0,0},		// temp slop extension
106250003Sadrian		0,									// quick drop low
107250003Sadrian		0,									// quick drop high
108250003Sadrian	},
109250003Sadrian
110250003Sadrian	//static A_UINT8 calFreqPier2G[OSPREY_NUM_2G_CAL_PIERS]=
111250003Sadrian	{
112250003Sadrian		FREQ2FBIN(2412, 1),
113250003Sadrian		FREQ2FBIN(2437, 1),
114250003Sadrian		FREQ2FBIN(2472, 1)
115250003Sadrian	},
116250003Sadrian
117250003Sadrian	//static OSP_CAL_DATA_PER_FREQ_OP_LOOP calPierData2G[OSPREY_MAX_CHAINS][OSPREY_NUM_2G_CAL_PIERS]=
118250003Sadrian
119250003Sadrian	{	{{0,0,0,0,0,0},  {0,0,0,0,0,0},  {0,0,0,0,0,0}},
120250003Sadrian		{{0,0,0,0,0,0},  {0,0,0,0,0,0},  {0,0,0,0,0,0}},
121250003Sadrian		{{0,0,0,0,0,0},  {0,0,0,0,0,0},  {0,0,0,0,0,0}},
122250003Sadrian	},
123250003Sadrian
124250003Sadrian	//A_UINT8 calTarget_freqbin_Cck[OSPREY_NUM_2G_CCK_TARGET_POWERS];
125250003Sadrian
126250003Sadrian	{
127250003Sadrian		FREQ2FBIN(2412, 1),
128250003Sadrian		FREQ2FBIN(2484, 1)
129250003Sadrian	},
130250003Sadrian
131250003Sadrian	//static CAL_TARGET_POWER_LEG calTarget_freqbin_2G[OSPREY_NUM_2G_20_TARGET_POWERS]
132250003Sadrian	{
133250003Sadrian		FREQ2FBIN(2412, 1),
134250003Sadrian		FREQ2FBIN(2437, 1),
135250003Sadrian		FREQ2FBIN(2472, 1)
136250003Sadrian	},
137250003Sadrian
138250003Sadrian	//static   OSP_CAL_TARGET_POWER_HT  calTarget_freqbin_2GHT20[OSPREY_NUM_2G_20_TARGET_POWERS]
139250003Sadrian	{
140250003Sadrian		FREQ2FBIN(2412, 1),
141250003Sadrian		FREQ2FBIN(2437, 1),
142250003Sadrian		FREQ2FBIN(2472, 1)
143250003Sadrian	},
144250003Sadrian
145250003Sadrian	//static   OSP_CAL_TARGET_POWER_HT  calTarget_freqbin_2GHT40[OSPREY_NUM_2G_40_TARGET_POWERS]
146250003Sadrian	{
147250003Sadrian		FREQ2FBIN(2412, 1),
148250003Sadrian		FREQ2FBIN(2437, 1),
149250003Sadrian		FREQ2FBIN(2472, 1)
150250003Sadrian	},
151250003Sadrian
152250003Sadrian	//static CAL_TARGET_POWER_LEG calTargetPowerCck[OSPREY_NUM_2G_CCK_TARGET_POWERS]=
153250003Sadrian	{
154250003Sadrian		//1L-5L,5S,11L,11S
155250003Sadrian        {{36,36,36,36}},
156250003Sadrian	 	{{36,36,36,36}}
157250003Sadrian	 },
158250003Sadrian
159250003Sadrian	//static CAL_TARGET_POWER_LEG calTargetPower2G[OSPREY_NUM_2G_20_TARGET_POWERS]=
160250003Sadrian	{
161250003Sadrian        //6-24,36,48,54
162250003Sadrian		{{32,32,28,24}},
163250003Sadrian		{{32,32,28,24}},
164250003Sadrian		{{32,32,28,24}},
165250003Sadrian	},
166250003Sadrian
167250003Sadrian	//static   OSP_CAL_TARGET_POWER_HT  calTargetPower2GHT20[OSPREY_NUM_2G_20_TARGET_POWERS]=
168250003Sadrian	{
169250003Sadrian        //0_8_16,1-3_9-11_17-19,
170250003Sadrian        //      4,5,6,7,12,13,14,15,20,21,22,23
171250003Sadrian		{{32,32,32,32,28,20,32,32,28,20,32,32,28,20}},
172250003Sadrian		{{32,32,32,32,28,20,32,32,28,20,32,32,28,20}},
173250003Sadrian		{{32,32,32,32,28,20,32,32,28,20,32,32,28,20}},
174250003Sadrian	},
175250003Sadrian
176250003Sadrian	//static    OSP_CAL_TARGET_POWER_HT  calTargetPower2GHT40[OSPREY_NUM_2G_40_TARGET_POWERS]=
177250003Sadrian	{
178250003Sadrian        //0_8_16,1-3_9-11_17-19,
179250003Sadrian        //      4,5,6,7,12,13,14,15,20,21,22,23
180250003Sadrian		{{32,32,32,32,28,20,32,32,28,20,32,32,28,20}},
181250003Sadrian		{{32,32,32,32,28,20,32,32,28,20,32,32,28,20}},
182250003Sadrian		{{32,32,32,32,28,20,32,32,28,20,32,32,28,20}},
183250003Sadrian	},
184250003Sadrian
185250003Sadrian//static    A_UINT8            ctlIndex_2G[OSPREY_NUM_CTLS_2G]=
186250003Sadrian
187250003Sadrian	{
188250003Sadrian
189250003Sadrian		    0x11,
190250003Sadrian    		0x12,
191250003Sadrian    		0x15,
192250003Sadrian    		0x17,
193250003Sadrian    		0x41,
194250003Sadrian    		0x42,
195250003Sadrian   			0x45,
196250003Sadrian    		0x47,
197250003Sadrian   			0x31,
198250003Sadrian    		0x32,
199250003Sadrian    		0x35,
200250003Sadrian    		0x37
201250003Sadrian
202250003Sadrian    },
203250003Sadrian
204250003Sadrian//A_UINT8   ctl_freqbin_2G[OSPREY_NUM_CTLS_2G][OSPREY_NUM_BAND_EDGES_2G];
205250003Sadrian
206250003Sadrian	{
207250003Sadrian		{FREQ2FBIN(2412, 1),
208250003Sadrian		 FREQ2FBIN(2417, 1),
209250003Sadrian		 FREQ2FBIN(2457, 1),
210250003Sadrian		 FREQ2FBIN(2462, 1)},
211250003Sadrian
212250003Sadrian		{FREQ2FBIN(2412, 1),
213250003Sadrian		 FREQ2FBIN(2417, 1),
214250003Sadrian		 FREQ2FBIN(2462, 1),
215250003Sadrian		 0xFF},
216250003Sadrian
217250003Sadrian		{FREQ2FBIN(2412, 1),
218250003Sadrian		 FREQ2FBIN(2417, 1),
219250003Sadrian		 FREQ2FBIN(2462, 1),
220250003Sadrian		 0xFF},
221250003Sadrian
222250003Sadrian		{FREQ2FBIN(2422, 1),
223250003Sadrian		 FREQ2FBIN(2427, 1),
224250003Sadrian		 FREQ2FBIN(2447, 1),
225250003Sadrian		 FREQ2FBIN(2452, 1)},
226250003Sadrian
227250003Sadrian		{/*Data[4].ctlEdges[0].bChannel*/FREQ2FBIN(2412, 1),
228250003Sadrian		/*Data[4].ctlEdges[1].bChannel*/FREQ2FBIN(2417, 1),
229250003Sadrian		/*Data[4].ctlEdges[2].bChannel*/FREQ2FBIN(2472, 1),
230250003Sadrian		/*Data[4].ctlEdges[3].bChannel*/FREQ2FBIN(2484, 1)},
231250003Sadrian
232250003Sadrian		{/*Data[5].ctlEdges[0].bChannel*/FREQ2FBIN(2412, 1),
233250003Sadrian		 /*Data[5].ctlEdges[1].bChannel*/FREQ2FBIN(2417, 1),
234250003Sadrian		 /*Data[5].ctlEdges[2].bChannel*/FREQ2FBIN(2472, 1),
235250003Sadrian		 0},
236250003Sadrian
237250003Sadrian		{/*Data[6].ctlEdges[0].bChannel*/FREQ2FBIN(2412, 1),
238250003Sadrian		 /*Data[6].ctlEdges[1].bChannel*/FREQ2FBIN(2417, 1),
239250003Sadrian		 FREQ2FBIN(2472, 1),
240250003Sadrian		 0},
241250003Sadrian
242250003Sadrian		{/*Data[7].ctlEdges[0].bChannel*/FREQ2FBIN(2422, 1),
243250003Sadrian		 /*Data[7].ctlEdges[1].bChannel*/FREQ2FBIN(2427, 1),
244250003Sadrian		 /*Data[7].ctlEdges[2].bChannel*/FREQ2FBIN(2447, 1),
245250003Sadrian		 /*Data[7].ctlEdges[3].bChannel*/FREQ2FBIN(2462, 1)},
246250003Sadrian
247250003Sadrian		{/*Data[8].ctlEdges[0].bChannel*/FREQ2FBIN(2412, 1),
248250003Sadrian		 /*Data[8].ctlEdges[1].bChannel*/FREQ2FBIN(2417, 1),
249250003Sadrian		 /*Data[8].ctlEdges[2].bChannel*/FREQ2FBIN(2472, 1),
250250003Sadrian		 0},
251250003Sadrian
252250003Sadrian		{/*Data[9].ctlEdges[0].bChannel*/FREQ2FBIN(2412, 1),
253250003Sadrian		 /*Data[9].ctlEdges[1].bChannel*/FREQ2FBIN(2417, 1),
254250003Sadrian		 /*Data[9].ctlEdges[2].bChannel*/FREQ2FBIN(2472, 1),
255250003Sadrian		 0},
256250003Sadrian
257250003Sadrian		{/*Data[10].ctlEdges[0].bChannel*/FREQ2FBIN(2412, 1),
258250003Sadrian		 /*Data[10].ctlEdges[1].bChannel*/FREQ2FBIN(2417, 1),
259250003Sadrian		 /*Data[10].ctlEdges[2].bChannel*/FREQ2FBIN(2472, 1),
260250003Sadrian		 0},
261250003Sadrian
262250003Sadrian		{/*Data[11].ctlEdges[0].bChannel*/FREQ2FBIN(2422, 1),
263250003Sadrian		 /*Data[11].ctlEdges[1].bChannel*/FREQ2FBIN(2427, 1),
264250003Sadrian		 /*Data[11].ctlEdges[2].bChannel*/FREQ2FBIN(2447, 1),
265250003Sadrian		 /*Data[11].ctlEdges[3].bChannel*/FREQ2FBIN(2462, 1)}
266250003Sadrian	},
267250003Sadrian
268250003Sadrian
269250003Sadrian//OSP_CAL_CTL_DATA_2G   ctlPowerData_2G[OSPREY_NUM_CTLS_2G];
270250003Sadrian
271250003Sadrian#if AH_BYTE_ORDER == AH_BIG_ENDIAN
272250003Sadrian    {
273250003Sadrian
274250003Sadrian	    {{{0, 60}, {1, 60}, {0, 60}, {0, 60}}},
275250003Sadrian	    {{{0, 60}, {1, 60}, {0, 60}, {0, 60}}},
276250003Sadrian	    {{{1, 60}, {0, 60}, {0, 60}, {1, 60}}},
277250003Sadrian
278250003Sadrian	    {{{1, 60}, {0, 60}, {0, 60}, {0, 60}}},
279250003Sadrian	    {{{0, 60}, {1, 60}, {0, 60}, {0, 60}}},
280250003Sadrian	    {{{0, 60}, {1, 60}, {0, 60}, {0, 60}}},
281250003Sadrian
282250003Sadrian	    {{{0, 60}, {1, 60}, {1, 60}, {0, 60}}},
283250003Sadrian	    {{{0, 60}, {1, 60}, {0, 60}, {0, 60}}},
284250003Sadrian	    {{{0, 60}, {1, 60}, {0, 60}, {0, 60}}},
285250003Sadrian
286250003Sadrian	    {{{0, 60}, {1, 60}, {0, 60}, {0, 60}}},
287250003Sadrian	    {{{0, 60}, {1, 60}, {1, 60}, {1, 60}}},
288250003Sadrian	    {{{0, 60}, {1, 60}, {1, 60}, {1, 60}}},
289250003Sadrian
290250003Sadrian    },
291250003Sadrian#else
292250003Sadrian	{
293250003Sadrian	    {{{60, 0}, {60, 1}, {60, 0}, {60, 0}}},
294250003Sadrian	    {{{60, 0}, {60, 1}, {60, 0}, {60, 0}}},
295250003Sadrian	    {{{60, 1}, {60, 0}, {60, 0}, {60, 1}}},
296250003Sadrian
297250003Sadrian	    {{{60, 1}, {60, 0}, {60, 0}, {60, 0}}},
298250003Sadrian	    {{{60, 0}, {60, 1}, {60, 0}, {60, 0}}},
299250003Sadrian	    {{{60, 0}, {60, 1}, {60, 0}, {60, 0}}},
300250003Sadrian
301250003Sadrian	    {{{60, 0}, {60, 1}, {60, 1}, {60, 0}}},
302250003Sadrian	    {{{60, 0}, {60, 1}, {60, 0}, {60, 0}}},
303250003Sadrian	    {{{60, 0}, {60, 1}, {60, 0}, {60, 0}}},
304250003Sadrian
305250003Sadrian	    {{{60, 0}, {60, 1}, {60, 0}, {60, 0}}},
306250003Sadrian	    {{{60, 0}, {60, 1}, {60, 1}, {60, 1}}},
307250003Sadrian	    {{{60, 0}, {60, 1}, {60, 1}, {60, 1}}},
308250003Sadrian	},
309250003Sadrian#endif
310250003Sadrian
311250003Sadrian//static    OSPREY_MODAL_EEP_HEADER   modalHeader5G=
312250003Sadrian
313250003Sadrian	{
314250003Sadrian
315250003Sadrian		    0x440,			//  antCtrlCommon;                         // 4   idle, t1, t2, b (4 bits per setting)
316250003Sadrian		    0x11111,		//  antCtrlCommon2;                        // 4    ra1l1, ra2l1, ra1l2, ra2l2, ra12
317250003Sadrian		    {0x000,0x000,0x000},	//  antCtrlChain[OSPREY_MAX_CHAINS];       // 6   idle, t, r, rx1, rx12, b (2 bits each)
318250003Sadrian		    {0,0,0},			//   xatten1DB[OSPREY_MAX_CHAINS];           // 3  //xatten1_db for merlin (0xa20c/b20c 5:0)
319250003Sadrian		    {0,0,0},			//   xatten1Margin[OSPREY_MAX_CHAINS];          // 3  //xatten1_margin for merlin (0xa20c/b20c 16:12
320250003Sadrian			68,				//    tempSlope;
321250003Sadrian			0,				//    voltSlope;
322250003Sadrian		    {0,0,0,0,0}, // spurChans[OSPREY_EEPROM_MODAL_SPURS];  // spur channels in usual fbin coding format
323250003Sadrian		    {-1,0,0},			//    noiseFloorThreshCh[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,				//   xpaBiasLvl;                            // 1
327250003Sadrian		    0x0e,			//   txFrameToDataStart;                    // 1
328250003Sadrian		    0x0e,			//   txFrameToPaOn;                         // 1
329250003Sadrian		    3,				//   txClip;                                     // 4 bits tx_clip, 4 bits dac_scale_cck
330250003Sadrian		    0,				//    antennaGain;                           // 1
331250003Sadrian		    0x2d,			//   switchSettling;                        // 1
332250003Sadrian		    -30,			//    adcDesiredSize;                        // 1
333250003Sadrian		    0,				//   txEndToXpaOff;                         // 1
334250003Sadrian		    0x2,			//   txEndToRxOn;                           // 1
335250003Sadrian		    0xe,			//   txFrameToXpaOn;                        // 1
336250003Sadrian		    28,				//   thresh62;                              // 1
337250003Sadrian  			0x0cf0e0e0,		//	 papdRateMaskHt20						// 4
338250003Sadrian  			0x6cf0e0e0,		//	 papdRateMaskHt40						// 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		0,
348250003Sadrian		0,
349250003Sadrian		{0,0,0},
350250003Sadrian		{0,0,0},
351250003Sadrian		{0,0,0},
352250003Sadrian		{0,0,0}
353250003Sadrian	},
354250003Sadrian
355250003Sadrian//static    A_UINT8            calFreqPier5G[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(5725, 0),
371250003Sadrian    		//pPiers[7] =
372250003Sadrian    		FREQ2FBIN(5825, 0)
373250003Sadrian	},
374250003Sadrian
375250003Sadrian//static    OSP_CAL_DATA_PER_FREQ_OP_LOOP calPierData5G[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}},
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}},
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}},
381250003Sadrian
382250003Sadrian	},
383250003Sadrian
384250003Sadrian//static    CAL_TARGET_POWER_LEG calTarget_freqbin_5G[OSPREY_NUM_5G_20_TARGET_POWERS]=
385250003Sadrian
386250003Sadrian	{
387250003Sadrian			FREQ2FBIN(5180, 0),
388250003Sadrian			FREQ2FBIN(5220, 0),
389250003Sadrian			FREQ2FBIN(5320, 0),
390250003Sadrian			FREQ2FBIN(5400, 0),
391250003Sadrian			FREQ2FBIN(5500, 0),
392250003Sadrian			FREQ2FBIN(5600, 0),
393250003Sadrian			FREQ2FBIN(5725, 0),
394250003Sadrian			FREQ2FBIN(5825, 0)
395250003Sadrian	},
396250003Sadrian
397250003Sadrian//static    OSP_CAL_TARGET_POWER_HT  calTargetPower5GHT20[OSPREY_NUM_5G_20_TARGET_POWERS]=
398250003Sadrian
399250003Sadrian	{
400250003Sadrian			FREQ2FBIN(5180, 0),
401250003Sadrian			FREQ2FBIN(5240, 0),
402250003Sadrian			FREQ2FBIN(5320, 0),
403250003Sadrian			FREQ2FBIN(5500, 0),
404250003Sadrian			FREQ2FBIN(5700, 0),
405250003Sadrian			FREQ2FBIN(5745, 0),
406250003Sadrian			FREQ2FBIN(5725, 0),
407250003Sadrian			FREQ2FBIN(5825, 0)
408250003Sadrian	},
409250003Sadrian
410250003Sadrian//static    OSP_CAL_TARGET_POWER_HT  calTargetPower5GHT40[OSPREY_NUM_5G_40_TARGET_POWERS]=
411250003Sadrian
412250003Sadrian	{
413250003Sadrian			FREQ2FBIN(5180, 0),
414250003Sadrian			FREQ2FBIN(5240, 0),
415250003Sadrian			FREQ2FBIN(5320, 0),
416250003Sadrian			FREQ2FBIN(5500, 0),
417250003Sadrian			FREQ2FBIN(5700, 0),
418250003Sadrian			FREQ2FBIN(5745, 0),
419250003Sadrian			FREQ2FBIN(5725, 0),
420250003Sadrian			FREQ2FBIN(5825, 0)
421250003Sadrian	},
422250003Sadrian
423250003Sadrian
424250003Sadrian//static    CAL_TARGET_POWER_LEG calTargetPower5G[OSPREY_NUM_5G_20_TARGET_POWERS]=
425250003Sadrian
426250003Sadrian
427250003Sadrian	{
428250003Sadrian        //6-24,36,48,54
429250003Sadrian	    {{20,20,20,10}},
430250003Sadrian	    {{20,20,20,10}},
431250003Sadrian	    {{20,20,20,10}},
432250003Sadrian	    {{20,20,20,10}},
433250003Sadrian	    {{20,20,20,10}},
434250003Sadrian	    {{20,20,20,10}},
435250003Sadrian	    {{20,20,20,10}},
436250003Sadrian	    {{20,20,20,10}},
437250003Sadrian	},
438250003Sadrian
439250003Sadrian//static    OSP_CAL_TARGET_POWER_HT  calTargetPower5GHT20[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	    {{20,20,10,10,0,0,10,10,0,0,10,10,0,0}},
445250003Sadrian	    {{20,20,10,10,0,0,10,10,0,0,10,10,0,0}},
446250003Sadrian	    {{20,20,10,10,0,0,10,10,0,0,10,10,0,0}},
447250003Sadrian	    {{20,20,10,10,0,0,10,10,0,0,10,10,0,0}},
448250003Sadrian	    {{20,20,10,10,0,0,10,10,0,0,10,10,0,0}},
449250003Sadrian	    {{20,20,10,10,0,0,10,10,0,0,10,10,0,0}},
450250003Sadrian	    {{20,20,10,10,0,0,10,10,0,0,10,10,0,0}},
451250003Sadrian	    {{20,20,10,10,0,0,10,10,0,0,10,10,0,0}},
452250003Sadrian	},
453250003Sadrian
454250003Sadrian//static    OSP_CAL_TARGET_POWER_HT  calTargetPower5GHT40[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	    {{20,20,10,10,0,0,10,10,0,0,10,10,0,0}},
459250003Sadrian	    {{20,20,10,10,0,0,10,10,0,0,10,10,0,0}},
460250003Sadrian	    {{20,20,10,10,0,0,10,10,0,0,10,10,0,0}},
461250003Sadrian	    {{20,20,10,10,0,0,10,10,0,0,10,10,0,0}},
462250003Sadrian	    {{20,20,10,10,0,0,10,10,0,0,10,10,0,0}},
463250003Sadrian	    {{20,20,10,10,0,0,10,10,0,0,10,10,0,0}},
464250003Sadrian	    {{20,20,10,10,0,0,10,10,0,0,10,10,0,0}},
465250003Sadrian	    {{20,20,10,10,0,0,10,10,0,0,10,10,0,0}},
466250003Sadrian	},
467250003Sadrian
468250003Sadrian//static    A_UINT8            ctlIndex_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].ctlEdges[0].bChannel*/FREQ2FBIN(5180, 0),
495250003Sadrian	    /* Data[0].ctlEdges[1].bChannel*/FREQ2FBIN(5260, 0),
496250003Sadrian	    /* Data[0].ctlEdges[2].bChannel*/FREQ2FBIN(5280, 0),
497250003Sadrian	    /* Data[0].ctlEdges[3].bChannel*/FREQ2FBIN(5500, 0),
498250003Sadrian	    /* Data[0].ctlEdges[4].bChannel*/FREQ2FBIN(5600, 0),
499250003Sadrian	    /* Data[0].ctlEdges[5].bChannel*/FREQ2FBIN(5700, 0),
500250003Sadrian	    /* Data[0].ctlEdges[6].bChannel*/FREQ2FBIN(5745, 0),
501250003Sadrian	    /* Data[0].ctlEdges[7].bChannel*/FREQ2FBIN(5825, 0)},
502250003Sadrian
503250003Sadrian	    {/* Data[1].ctlEdges[0].bChannel*/FREQ2FBIN(5180, 0),
504250003Sadrian	    /* Data[1].ctlEdges[1].bChannel*/FREQ2FBIN(5260, 0),
505250003Sadrian	    /* Data[1].ctlEdges[2].bChannel*/FREQ2FBIN(5280, 0),
506250003Sadrian	    /* Data[1].ctlEdges[3].bChannel*/FREQ2FBIN(5500, 0),
507250003Sadrian	    /* Data[1].ctlEdges[4].bChannel*/FREQ2FBIN(5520, 0),
508250003Sadrian	    /* Data[1].ctlEdges[5].bChannel*/FREQ2FBIN(5700, 0),
509250003Sadrian	    /* Data[1].ctlEdges[6].bChannel*/FREQ2FBIN(5745, 0),
510250003Sadrian	    /* Data[1].ctlEdges[7].bChannel*/FREQ2FBIN(5825, 0)},
511250003Sadrian
512250003Sadrian	    {/* Data[2].ctlEdges[0].bChannel*/FREQ2FBIN(5190, 0),
513250003Sadrian	    /* Data[2].ctlEdges[1].bChannel*/FREQ2FBIN(5230, 0),
514250003Sadrian	    /* Data[2].ctlEdges[2].bChannel*/FREQ2FBIN(5270, 0),
515250003Sadrian	    /* Data[2].ctlEdges[3].bChannel*/FREQ2FBIN(5310, 0),
516250003Sadrian	    /* Data[2].ctlEdges[4].bChannel*/FREQ2FBIN(5510, 0),
517250003Sadrian	    /* Data[2].ctlEdges[5].bChannel*/FREQ2FBIN(5550, 0),
518250003Sadrian	    /* Data[2].ctlEdges[6].bChannel*/FREQ2FBIN(5670, 0),
519250003Sadrian	    /* Data[2].ctlEdges[7].bChannel*/FREQ2FBIN(5755, 0)},
520250003Sadrian
521250003Sadrian	    {/* Data[3].ctlEdges[0].bChannel*/FREQ2FBIN(5180, 0),
522250003Sadrian	    /* Data[3].ctlEdges[1].bChannel*/FREQ2FBIN(5200, 0),
523250003Sadrian	    /* Data[3].ctlEdges[2].bChannel*/FREQ2FBIN(5260, 0),
524250003Sadrian	    /* Data[3].ctlEdges[3].bChannel*/FREQ2FBIN(5320, 0),
525250003Sadrian	    /* Data[3].ctlEdges[4].bChannel*/FREQ2FBIN(5500, 0),
526250003Sadrian	    /* Data[3].ctlEdges[5].bChannel*/FREQ2FBIN(5700, 0),
527250003Sadrian	    /* Data[3].ctlEdges[6].bChannel*/0xFF,
528250003Sadrian	    /* Data[3].ctlEdges[7].bChannel*/0xFF},
529250003Sadrian
530250003Sadrian	    {/* Data[4].ctlEdges[0].bChannel*/FREQ2FBIN(5180, 0),
531250003Sadrian	    /* Data[4].ctlEdges[1].bChannel*/FREQ2FBIN(5260, 0),
532250003Sadrian	    /* Data[4].ctlEdges[2].bChannel*/FREQ2FBIN(5500, 0),
533250003Sadrian	    /* Data[4].ctlEdges[3].bChannel*/FREQ2FBIN(5700, 0),
534250003Sadrian	    /* Data[4].ctlEdges[4].bChannel*/0xFF,
535250003Sadrian	    /* Data[4].ctlEdges[5].bChannel*/0xFF,
536250003Sadrian	    /* Data[4].ctlEdges[6].bChannel*/0xFF,
537250003Sadrian	    /* Data[4].ctlEdges[7].bChannel*/0xFF},
538250003Sadrian
539250003Sadrian	    {/* Data[5].ctlEdges[0].bChannel*/FREQ2FBIN(5190, 0),
540250003Sadrian	    /* Data[5].ctlEdges[1].bChannel*/FREQ2FBIN(5270, 0),
541250003Sadrian	    /* Data[5].ctlEdges[2].bChannel*/FREQ2FBIN(5310, 0),
542250003Sadrian	    /* Data[5].ctlEdges[3].bChannel*/FREQ2FBIN(5510, 0),
543250003Sadrian	    /* Data[5].ctlEdges[4].bChannel*/FREQ2FBIN(5590, 0),
544250003Sadrian	    /* Data[5].ctlEdges[5].bChannel*/FREQ2FBIN(5670, 0),
545250003Sadrian	    /* Data[5].ctlEdges[6].bChannel*/0xFF,
546250003Sadrian	    /* Data[5].ctlEdges[7].bChannel*/0xFF},
547250003Sadrian
548250003Sadrian	    {/* Data[6].ctlEdges[0].bChannel*/FREQ2FBIN(5180, 0),
549250003Sadrian	    /* Data[6].ctlEdges[1].bChannel*/FREQ2FBIN(5200, 0),
550250003Sadrian	    /* Data[6].ctlEdges[2].bChannel*/FREQ2FBIN(5220, 0),
551250003Sadrian	    /* Data[6].ctlEdges[3].bChannel*/FREQ2FBIN(5260, 0),
552250003Sadrian	    /* Data[6].ctlEdges[4].bChannel*/FREQ2FBIN(5500, 0),
553250003Sadrian	    /* Data[6].ctlEdges[5].bChannel*/FREQ2FBIN(5600, 0),
554250003Sadrian	    /* Data[6].ctlEdges[6].bChannel*/FREQ2FBIN(5700, 0),
555250003Sadrian	    /* Data[6].ctlEdges[7].bChannel*/FREQ2FBIN(5745, 0)},
556250003Sadrian
557250003Sadrian	    {/* Data[7].ctlEdges[0].bChannel*/FREQ2FBIN(5180, 0),
558250003Sadrian	    /* Data[7].ctlEdges[1].bChannel*/FREQ2FBIN(5260, 0),
559250003Sadrian	    /* Data[7].ctlEdges[2].bChannel*/FREQ2FBIN(5320, 0),
560250003Sadrian	    /* Data[7].ctlEdges[3].bChannel*/FREQ2FBIN(5500, 0),
561250003Sadrian	    /* Data[7].ctlEdges[4].bChannel*/FREQ2FBIN(5560, 0),
562250003Sadrian	    /* Data[7].ctlEdges[5].bChannel*/FREQ2FBIN(5700, 0),
563250003Sadrian	    /* Data[7].ctlEdges[6].bChannel*/FREQ2FBIN(5745, 0),
564250003Sadrian	    /* Data[7].ctlEdges[7].bChannel*/FREQ2FBIN(5825, 0)},
565250003Sadrian
566250003Sadrian	    {/* Data[8].ctlEdges[0].bChannel*/FREQ2FBIN(5190, 0),
567250003Sadrian	    /* Data[8].ctlEdges[1].bChannel*/FREQ2FBIN(5230, 0),
568250003Sadrian	    /* Data[8].ctlEdges[2].bChannel*/FREQ2FBIN(5270, 0),
569250003Sadrian	    /* Data[8].ctlEdges[3].bChannel*/FREQ2FBIN(5510, 0),
570250003Sadrian	    /* Data[8].ctlEdges[4].bChannel*/FREQ2FBIN(5550, 0),
571250003Sadrian	    /* Data[8].ctlEdges[5].bChannel*/FREQ2FBIN(5670, 0),
572250003Sadrian	    /* Data[8].ctlEdges[6].bChannel*/FREQ2FBIN(5755, 0),
573250003Sadrian	    /* Data[8].ctlEdges[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
748