xref: /illumos-gate/usr/src/uts/common/io/arn/arn_hw.h (revision dd1de3740722a4b99a74005255effebbd20a6d70)
1*dd1de374Slin wang - Sun Microsystems - Beijing China /*
2*dd1de374Slin wang - Sun Microsystems - Beijing China  * Copyright 2009 Sun Microsystems, Inc.  All rights reserved.
3*dd1de374Slin wang - Sun Microsystems - Beijing China  * Use is subject to license terms.
4*dd1de374Slin wang - Sun Microsystems - Beijing China  */
5*dd1de374Slin wang - Sun Microsystems - Beijing China 
6*dd1de374Slin wang - Sun Microsystems - Beijing China /*
7*dd1de374Slin wang - Sun Microsystems - Beijing China  * Copyright (c) 2008 Atheros Communications Inc.
8*dd1de374Slin wang - Sun Microsystems - Beijing China  *
9*dd1de374Slin wang - Sun Microsystems - Beijing China  * Permission to use, copy, modify, and/or distribute this software for any
10*dd1de374Slin wang - Sun Microsystems - Beijing China  * purpose with or without fee is hereby granted, provided that the above
11*dd1de374Slin wang - Sun Microsystems - Beijing China  * copyright notice and this permission notice appear in all copies.
12*dd1de374Slin wang - Sun Microsystems - Beijing China  *
13*dd1de374Slin wang - Sun Microsystems - Beijing China  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
14*dd1de374Slin wang - Sun Microsystems - Beijing China  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
15*dd1de374Slin wang - Sun Microsystems - Beijing China  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
16*dd1de374Slin wang - Sun Microsystems - Beijing China  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
17*dd1de374Slin wang - Sun Microsystems - Beijing China  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
18*dd1de374Slin wang - Sun Microsystems - Beijing China  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
19*dd1de374Slin wang - Sun Microsystems - Beijing China  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
20*dd1de374Slin wang - Sun Microsystems - Beijing China  */
21*dd1de374Slin wang - Sun Microsystems - Beijing China 
22*dd1de374Slin wang - Sun Microsystems - Beijing China #ifndef	_ARN_HW_H
23*dd1de374Slin wang - Sun Microsystems - Beijing China #define	_ARN_HW_H
24*dd1de374Slin wang - Sun Microsystems - Beijing China 
25*dd1de374Slin wang - Sun Microsystems - Beijing China #ifdef __cplusplus
26*dd1de374Slin wang - Sun Microsystems - Beijing China extern "C" {
27*dd1de374Slin wang - Sun Microsystems - Beijing China #endif
28*dd1de374Slin wang - Sun Microsystems - Beijing China 
29*dd1de374Slin wang - Sun Microsystems - Beijing China #pragma pack(1)
30*dd1de374Slin wang - Sun Microsystems - Beijing China struct ar5416_desc {
31*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ds_link;
32*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ds_data;
33*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ds_ctl0;
34*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ds_ctl1;
35*dd1de374Slin wang - Sun Microsystems - Beijing China 	union {
36*dd1de374Slin wang - Sun Microsystems - Beijing China 		struct {
37*dd1de374Slin wang - Sun Microsystems - Beijing China 			uint32_t ctl2;
38*dd1de374Slin wang - Sun Microsystems - Beijing China 			uint32_t ctl3;
39*dd1de374Slin wang - Sun Microsystems - Beijing China 			uint32_t ctl4;
40*dd1de374Slin wang - Sun Microsystems - Beijing China 			uint32_t ctl5;
41*dd1de374Slin wang - Sun Microsystems - Beijing China 			uint32_t ctl6;
42*dd1de374Slin wang - Sun Microsystems - Beijing China 			uint32_t ctl7;
43*dd1de374Slin wang - Sun Microsystems - Beijing China 			uint32_t ctl8;
44*dd1de374Slin wang - Sun Microsystems - Beijing China 			uint32_t ctl9;
45*dd1de374Slin wang - Sun Microsystems - Beijing China 			uint32_t ctl10;
46*dd1de374Slin wang - Sun Microsystems - Beijing China 			uint32_t ctl11;
47*dd1de374Slin wang - Sun Microsystems - Beijing China 			uint32_t status0;
48*dd1de374Slin wang - Sun Microsystems - Beijing China 			uint32_t status1;
49*dd1de374Slin wang - Sun Microsystems - Beijing China 			uint32_t status2;
50*dd1de374Slin wang - Sun Microsystems - Beijing China 			uint32_t status3;
51*dd1de374Slin wang - Sun Microsystems - Beijing China 			uint32_t status4;
52*dd1de374Slin wang - Sun Microsystems - Beijing China 			uint32_t status5;
53*dd1de374Slin wang - Sun Microsystems - Beijing China 			uint32_t status6;
54*dd1de374Slin wang - Sun Microsystems - Beijing China 			uint32_t status7;
55*dd1de374Slin wang - Sun Microsystems - Beijing China 			uint32_t status8;
56*dd1de374Slin wang - Sun Microsystems - Beijing China 			uint32_t status9;
57*dd1de374Slin wang - Sun Microsystems - Beijing China 		} tx;
58*dd1de374Slin wang - Sun Microsystems - Beijing China 		struct {
59*dd1de374Slin wang - Sun Microsystems - Beijing China 			uint32_t status0;
60*dd1de374Slin wang - Sun Microsystems - Beijing China 			uint32_t status1;
61*dd1de374Slin wang - Sun Microsystems - Beijing China 			uint32_t status2;
62*dd1de374Slin wang - Sun Microsystems - Beijing China 			uint32_t status3;
63*dd1de374Slin wang - Sun Microsystems - Beijing China 			uint32_t status4;
64*dd1de374Slin wang - Sun Microsystems - Beijing China 			uint32_t status5;
65*dd1de374Slin wang - Sun Microsystems - Beijing China 			uint32_t status6;
66*dd1de374Slin wang - Sun Microsystems - Beijing China 			uint32_t status7;
67*dd1de374Slin wang - Sun Microsystems - Beijing China 			uint32_t status8;
68*dd1de374Slin wang - Sun Microsystems - Beijing China 		} rx;
69*dd1de374Slin wang - Sun Microsystems - Beijing China 	} u;
70*dd1de374Slin wang - Sun Microsystems - Beijing China };
71*dd1de374Slin wang - Sun Microsystems - Beijing China #pragma pack()
72*dd1de374Slin wang - Sun Microsystems - Beijing China 
73*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416DESC(_ds)		((struct ar5416_desc *)(_ds))
74*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416DESC_CONST(_ds)	((const struct ar5416_desc *)(_ds))
75*dd1de374Slin wang - Sun Microsystems - Beijing China 
76*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ds_ctl2		u.tx.ctl2
77*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ds_ctl3		u.tx.ctl3
78*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ds_ctl4		u.tx.ctl4
79*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ds_ctl5		u.tx.ctl5
80*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ds_ctl6		u.tx.ctl6
81*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ds_ctl7		u.tx.ctl7
82*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ds_ctl8		u.tx.ctl8
83*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ds_ctl9		u.tx.ctl9
84*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ds_ctl10	u.tx.ctl10
85*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ds_ctl11	u.tx.ctl11
86*dd1de374Slin wang - Sun Microsystems - Beijing China 
87*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ds_txstatus0	u.tx.status0
88*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ds_txstatus1	u.tx.status1
89*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ds_txstatus2	u.tx.status2
90*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ds_txstatus3	u.tx.status3
91*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ds_txstatus4	u.tx.status4
92*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ds_txstatus5	u.tx.status5
93*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ds_txstatus6	u.tx.status6
94*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ds_txstatus7	u.tx.status7
95*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ds_txstatus8	u.tx.status8
96*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ds_txstatus9	u.tx.status9
97*dd1de374Slin wang - Sun Microsystems - Beijing China 
98*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ds_rxstatus0	u.rx.status0
99*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ds_rxstatus1	u.rx.status1
100*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ds_rxstatus2	u.rx.status2
101*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ds_rxstatus3	u.rx.status3
102*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ds_rxstatus4	u.rx.status4
103*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ds_rxstatus5	u.rx.status5
104*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ds_rxstatus6	u.rx.status6
105*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ds_rxstatus7	u.rx.status7
106*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ds_rxstatus8	u.rx.status8
107*dd1de374Slin wang - Sun Microsystems - Beijing China 
108*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_FrameLen	0x00000fff
109*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_VirtMoreFrag	0x00001000
110*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_TxCtlRsvd00	0x0000e000
111*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_XmitPower	0x003f0000
112*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_XmitPower_S	16
113*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RTSEnable	0x00400000
114*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_VEOL		0x00800000
115*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_ClrDestMask	0x01000000
116*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_TxCtlRsvd01	0x1e000000
117*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_TxIntrReq	0x20000000
118*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_DestIdxValid	0x40000000
119*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_CTSEnable	0x80000000
120*dd1de374Slin wang - Sun Microsystems - Beijing China 
121*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_BufLen		0x00000fff
122*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_TxMore		0x00001000
123*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_DestIdx		0x000fe000
124*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_DestIdx_S		13
125*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_FrameType		0x00f00000
126*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_FrameType_S		20
127*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_NoAck		0x01000000
128*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_InsertTS		0x02000000
129*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_CorruptFCS		0x04000000
130*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_ExtOnly		0x08000000
131*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_ExtAndCtl		0x10000000
132*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_MoreAggr		0x20000000
133*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_IsAggr		0x40000000
134*dd1de374Slin wang - Sun Microsystems - Beijing China 
135*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_BurstDur		0x00007fff
136*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_BurstDur_S		0
137*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_DurUpdateEna		0x00008000
138*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_XmitDataTries0	0x000f0000
139*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_XmitDataTries0_S	16
140*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_XmitDataTries1	0x00f00000
141*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_XmitDataTries1_S	20
142*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_XmitDataTries2	0x0f000000
143*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_XmitDataTries2_S	24
144*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_XmitDataTries3	0xf0000000
145*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_XmitDataTries3_S	28
146*dd1de374Slin wang - Sun Microsystems - Beijing China 
147*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_XmitRate0		0x000000ff
148*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_XmitRate0_S		0
149*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_XmitRate1		0x0000ff00
150*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_XmitRate1_S		8
151*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_XmitRate2		0x00ff0000
152*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_XmitRate2_S		16
153*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_XmitRate3		0xff000000
154*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_XmitRate3_S		24
155*dd1de374Slin wang - Sun Microsystems - Beijing China 
156*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_PacketDur0		0x00007fff
157*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_PacketDur0_S		0
158*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RTSCTSQual0		0x00008000
159*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_PacketDur1		0x7fff0000
160*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_PacketDur1_S		16
161*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RTSCTSQual1		0x80000000
162*dd1de374Slin wang - Sun Microsystems - Beijing China 
163*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_PacketDur2		0x00007fff
164*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_PacketDur2_S		0
165*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RTSCTSQual2		0x00008000
166*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_PacketDur3		0x7fff0000
167*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_PacketDur3_S		16
168*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RTSCTSQual3		0x80000000
169*dd1de374Slin wang - Sun Microsystems - Beijing China 
170*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_AggrLen		0x0000ffff
171*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_AggrLen_S		0
172*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_TxCtlRsvd60		0x00030000
173*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_PadDelim		0x03fc0000
174*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_PadDelim_S		18
175*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_EncrType		0x0c000000
176*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_EncrType_S		26
177*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_TxCtlRsvd61		0xf0000000
178*dd1de374Slin wang - Sun Microsystems - Beijing China 
179*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_2040_0		0x00000001
180*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_GI0			0x00000002
181*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_ChainSel0		0x0000001c
182*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_ChainSel0_S		2
183*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_2040_1		0x00000020
184*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_GI1			0x00000040
185*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_ChainSel1		0x00000380
186*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_ChainSel1_S		7
187*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_2040_2		0x00000400
188*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_GI2			0x00000800
189*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_ChainSel2		0x00007000
190*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_ChainSel2_S		12
191*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_2040_3		0x00008000
192*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_GI3			0x00010000
193*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_ChainSel3		0x000e0000
194*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_ChainSel3_S		17
195*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RTSCTSRate		0x0ff00000
196*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RTSCTSRate_S		20
197*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_TxCtlRsvd70		0xf0000000
198*dd1de374Slin wang - Sun Microsystems - Beijing China 
199*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_TxRSSIAnt00		0x000000ff
200*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_TxRSSIAnt00_S	0
201*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_TxRSSIAnt01		0x0000ff00
202*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_TxRSSIAnt01_S	8
203*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_TxRSSIAnt02		0x00ff0000
204*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_TxRSSIAnt02_S	16
205*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_TxStatusRsvd00	0x3f000000
206*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_TxBaStatus		0x40000000
207*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_TxStatusRsvd01	0x80000000
208*dd1de374Slin wang - Sun Microsystems - Beijing China 
209*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_FrmXmitOK		0x00000001
210*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_ExcessiveRetries	0x00000002
211*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_FIFOUnderrun		0x00000004
212*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_Filtered		0x00000008
213*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RTSFailCnt		0x000000f0
214*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RTSFailCnt_S		4
215*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_DataFailCnt		0x00000f00
216*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_DataFailCnt_S	8
217*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_VirtRetryCnt		0x0000f000
218*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_VirtRetryCnt_S	12
219*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_TxDelimUnderrun	0x00010000
220*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_TxDataUnderrun	0x00020000
221*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_DescCfgErr		0x00040000
222*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_TxTimerExpired	0x00080000
223*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_TxStatusRsvd10	0xfff00000
224*dd1de374Slin wang - Sun Microsystems - Beijing China 
225*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_SendTimestamp	ds_txstatus2
226*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_BaBitmapLow		ds_txstatus3
227*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_BaBitmapHigh		ds_txstatus4
228*dd1de374Slin wang - Sun Microsystems - Beijing China 
229*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_TxRSSIAnt10		0x000000ff
230*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_TxRSSIAnt10_S	0
231*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_TxRSSIAnt11		0x0000ff00
232*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_TxRSSIAnt11_S	8
233*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_TxRSSIAnt12		0x00ff0000
234*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_TxRSSIAnt12_S	16
235*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_TxRSSICombined	0xff000000
236*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_TxRSSICombined_S	24
237*dd1de374Slin wang - Sun Microsystems - Beijing China 
238*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_TxEVM0		ds_txstatus5
239*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_TxEVM1		ds_txstatus6
240*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_TxEVM2		ds_txstatus7
241*dd1de374Slin wang - Sun Microsystems - Beijing China 
242*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_TxDone		0x00000001
243*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_SeqNum		0x00001ffe
244*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_SeqNum_S		1
245*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_TxStatusRsvd80	0x0001e000
246*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_TxOpExceeded		0x00020000
247*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_TxStatusRsvd81	0x001c0000
248*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_FinalTxIdx		0x00600000
249*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_FinalTxIdx_S		21
250*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_TxStatusRsvd82	0x01800000
251*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_PowerMgmt		0x02000000
252*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_TxStatusRsvd83	0xfc000000
253*dd1de374Slin wang - Sun Microsystems - Beijing China 
254*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RxCTLRsvd00		0xffffffff
255*dd1de374Slin wang - Sun Microsystems - Beijing China 
256*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_BufLen		0x00000fff
257*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RxCtlRsvd00		0x00001000
258*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RxIntrReq		0x00002000
259*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RxCtlRsvd01		0xffffc000
260*dd1de374Slin wang - Sun Microsystems - Beijing China 
261*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RxRSSIAnt00		0x000000ff
262*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RxRSSIAnt00_S	0
263*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RxRSSIAnt01		0x0000ff00
264*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RxRSSIAnt01_S	8
265*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RxRSSIAnt02		0x00ff0000
266*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RxRSSIAnt02_S	16
267*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RxRate		0xff000000
268*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RxRate_S		24
269*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RxStatusRsvd00	0xff000000
270*dd1de374Slin wang - Sun Microsystems - Beijing China 
271*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_DataLen		0x00000fff
272*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RxMore		0x00001000
273*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_NumDelim		0x003fc000
274*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_NumDelim_S		14
275*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RxStatusRsvd10	0xff800000
276*dd1de374Slin wang - Sun Microsystems - Beijing China 
277*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RcvTimestamp		ds_rxstatus2
278*dd1de374Slin wang - Sun Microsystems - Beijing China 
279*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_GI			0x00000001
280*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_2040			0x00000002
281*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_Parallel40		0x00000004
282*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_Parallel40_S		2
283*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RxStatusRsvd30	0x000000f8
284*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RxAntenna		0xffffff00
285*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RxAntenna_S		8
286*dd1de374Slin wang - Sun Microsystems - Beijing China 
287*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RxRSSIAnt10		0x000000ff
288*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RxRSSIAnt10_S	0
289*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RxRSSIAnt11		0x0000ff00
290*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RxRSSIAnt11_S	8
291*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RxRSSIAnt12		0x00ff0000
292*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RxRSSIAnt12_S	16
293*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RxRSSICombined	0xff000000
294*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RxRSSICombined_S	24
295*dd1de374Slin wang - Sun Microsystems - Beijing China 
296*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RxEVM0		ds_rxstatus4
297*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RxEVM1		ds_rxstatus5
298*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RxEVM2		ds_rxstatus6
299*dd1de374Slin wang - Sun Microsystems - Beijing China 
300*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RxDone		0x00000001
301*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RxFrameOK		0x00000002
302*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_CRCErr		0x00000004
303*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_DecryptCRCErr	0x00000008
304*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_PHYErr		0x00000010
305*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_MichaelErr		0x00000020
306*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_PreDelimCRCErr	0x00000040
307*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RxStatusRsvd70	0x00000080
308*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RxKeyIdxValid	0x00000100
309*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_KeyIdx		0x0000fe00
310*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_KeyIdx_S		9
311*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_PHYErrCode		0x0000ff00
312*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_PHYErrCode_S		8
313*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RxMoreAggr		0x00010000
314*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RxAggr		0x00020000
315*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_PostDelimCRCErr	0x00040000
316*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_RxStatusRsvd71	0x3ff80000
317*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_DecryptBusyErr	0x40000000
318*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_KeyMiss		0x80000000
319*dd1de374Slin wang - Sun Microsystems - Beijing China 
320*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_MAGIC	0x19641014
321*dd1de374Slin wang - Sun Microsystems - Beijing China 
322*dd1de374Slin wang - Sun Microsystems - Beijing China #define	RXSTATUS_RATE(ah, ads)	(AR_SREV_5416_V20_OR_LATER(ah) ?	\
323*dd1de374Slin wang - Sun Microsystems - Beijing China 	MS(ads->ds_rxstatus0, AR_RxRate) :				\
324*dd1de374Slin wang - Sun Microsystems - Beijing China 	(ads->ds_rxstatus3 >> 2) & 0xFF)
325*dd1de374Slin wang - Sun Microsystems - Beijing China 
326*dd1de374Slin wang - Sun Microsystems - Beijing China #define	set11nTries(_series, _index)	\
327*dd1de374Slin wang - Sun Microsystems - Beijing China 	(SM((_series)[_index].Tries, AR_XmitDataTries##_index))
328*dd1de374Slin wang - Sun Microsystems - Beijing China 
329*dd1de374Slin wang - Sun Microsystems - Beijing China #define	set11nRate(_series, _index)	\
330*dd1de374Slin wang - Sun Microsystems - Beijing China 	(SM((_series)[_index].Rate, AR_XmitRate##_index))
331*dd1de374Slin wang - Sun Microsystems - Beijing China 
332*dd1de374Slin wang - Sun Microsystems - Beijing China #define	set11nPktDurRTSCTS(_series, _index)				\
333*dd1de374Slin wang - Sun Microsystems - Beijing China 	(SM((_series)[_index].PktDuration, AR_PacketDur##_index) |	\
334*dd1de374Slin wang - Sun Microsystems - Beijing China 	((_series)[_index].RateFlags & ATH9K_RATESERIES_RTS_CTS   ?	\
335*dd1de374Slin wang - Sun Microsystems - Beijing China 	    AR_RTSCTSQual##_index : 0))
336*dd1de374Slin wang - Sun Microsystems - Beijing China 
337*dd1de374Slin wang - Sun Microsystems - Beijing China #define	set11nRateFlags(_series, _index)				\
338*dd1de374Slin wang - Sun Microsystems - Beijing China 	(((_series)[_index].RateFlags & ATH9K_RATESERIES_2040 ?		\
339*dd1de374Slin wang - Sun Microsystems - Beijing China 	    AR_2040_##_index : 0)					\
340*dd1de374Slin wang - Sun Microsystems - Beijing China 	|((_series)[_index].RateFlags & ATH9K_RATESERIES_HALFGI ?	\
341*dd1de374Slin wang - Sun Microsystems - Beijing China 	    AR_GI##_index : 0)						\
342*dd1de374Slin wang - Sun Microsystems - Beijing China 	|SM((_series)[_index].ChSel, AR_ChainSel##_index))
343*dd1de374Slin wang - Sun Microsystems - Beijing China 
344*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_SREV_9100(ah)	((ah->ah_macVersion) == AR_SREV_VERSION_9100)
345*dd1de374Slin wang - Sun Microsystems - Beijing China 
346*dd1de374Slin wang - Sun Microsystems - Beijing China #define	INIT_CONFIG_STATUS	0x00000000
347*dd1de374Slin wang - Sun Microsystems - Beijing China #define	INIT_RSSI_THR		0x00000700
348*dd1de374Slin wang - Sun Microsystems - Beijing China #define	INIT_BCON_CNTRL_REG	0x00000000
349*dd1de374Slin wang - Sun Microsystems - Beijing China 
350*dd1de374Slin wang - Sun Microsystems - Beijing China #define	MIN_TX_FIFO_THRESHOLD	0x1
351*dd1de374Slin wang - Sun Microsystems - Beijing China #define	MAX_TX_FIFO_THRESHOLD	((4096 / 64) - 1)
352*dd1de374Slin wang - Sun Microsystems - Beijing China #define	INIT_TX_FIFO_THRESHOLD	MIN_TX_FIFO_THRESHOLD
353*dd1de374Slin wang - Sun Microsystems - Beijing China 
354*dd1de374Slin wang - Sun Microsystems - Beijing China struct ar5416AniState {
355*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct ath9k_channel c;
356*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t noiseImmunityLevel;
357*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t spurImmunityLevel;
358*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t firstepLevel;
359*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t ofdmWeakSigDetectOff;
360*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t cckWeakSigThreshold;
361*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t listenTime;
362*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ofdmTrigHigh;
363*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ofdmTrigLow;
364*dd1de374Slin wang - Sun Microsystems - Beijing China 	int32_t cckTrigHigh;
365*dd1de374Slin wang - Sun Microsystems - Beijing China 	int32_t cckTrigLow;
366*dd1de374Slin wang - Sun Microsystems - Beijing China 	int32_t rssiThrLow;
367*dd1de374Slin wang - Sun Microsystems - Beijing China 	int32_t rssiThrHigh;
368*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t noiseFloor;
369*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t txFrameCount;
370*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t rxFrameCount;
371*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t cycleCount;
372*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ofdmPhyErrCount;
373*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t cckPhyErrCount;
374*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ofdmPhyErrBase;
375*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t cckPhyErrBase;
376*dd1de374Slin wang - Sun Microsystems - Beijing China 	int16_t pktRssi[2];
377*dd1de374Slin wang - Sun Microsystems - Beijing China 	int16_t ofdmErrRssi[2];
378*dd1de374Slin wang - Sun Microsystems - Beijing China 	int16_t cckErrRssi[2];
379*dd1de374Slin wang - Sun Microsystems - Beijing China };
380*dd1de374Slin wang - Sun Microsystems - Beijing China 
381*dd1de374Slin wang - Sun Microsystems - Beijing China #define	HAL_PROCESS_ANI	0x00000001
382*dd1de374Slin wang - Sun Microsystems - Beijing China #define	DO_ANI(ah) \
383*dd1de374Slin wang - Sun Microsystems - Beijing China 	((AH5416(ah)->ah_procPhyErr & HAL_PROCESS_ANI))
384*dd1de374Slin wang - Sun Microsystems - Beijing China 
385*dd1de374Slin wang - Sun Microsystems - Beijing China struct ar5416Stats {
386*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ast_ani_niup;
387*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ast_ani_nidown;
388*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ast_ani_spurup;
389*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ast_ani_spurdown;
390*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ast_ani_ofdmon;
391*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ast_ani_ofdmoff;
392*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ast_ani_cckhigh;
393*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ast_ani_ccklow;
394*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ast_ani_stepup;
395*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ast_ani_stepdown;
396*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ast_ani_ofdmerrs;
397*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ast_ani_cckerrs;
398*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ast_ani_reset;
399*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ast_ani_lzero;
400*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ast_ani_lneg;
401*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct ath9k_mib_stats ast_mibstats;
402*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct ath9k_node_stats ast_nodestats;
403*dd1de374Slin wang - Sun Microsystems - Beijing China };
404*dd1de374Slin wang - Sun Microsystems - Beijing China 
405*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_OPFLAGS_11A		0x01
406*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_OPFLAGS_11G		0x02
407*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_OPFLAGS_N_5G_HT40	0x04
408*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_OPFLAGS_N_2G_HT40	0x08
409*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_OPFLAGS_N_5G_HT20	0x10
410*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_OPFLAGS_N_2G_HT20	0x20
411*dd1de374Slin wang - Sun Microsystems - Beijing China 
412*dd1de374Slin wang - Sun Microsystems - Beijing China #define	EEP_RFSILENT_ENABLED		0x0001
413*dd1de374Slin wang - Sun Microsystems - Beijing China #define	EEP_RFSILENT_ENABLED_S		0
414*dd1de374Slin wang - Sun Microsystems - Beijing China #define	EEP_RFSILENT_POLARITY		0x0002
415*dd1de374Slin wang - Sun Microsystems - Beijing China #define	EEP_RFSILENT_POLARITY_S		1
416*dd1de374Slin wang - Sun Microsystems - Beijing China #define	EEP_RFSILENT_GPIO_SEL		0x001c
417*dd1de374Slin wang - Sun Microsystems - Beijing China #define	EEP_RFSILENT_GPIO_SEL_S		2
418*dd1de374Slin wang - Sun Microsystems - Beijing China 
419*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_EEP_NO_BACK_VER		0x1
420*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_EEP_VER			0xE
421*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_EEP_VER_MINOR_MASK	0x0FFF
422*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_EEP_MINOR_VER_2		0x2
423*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_EEP_MINOR_VER_3		0x3
424*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_EEP_MINOR_VER_7		0x7
425*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_EEP_MINOR_VER_9		0x9
426*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_EEP_MINOR_VER_16		0x10
427*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_EEP_MINOR_VER_17		0x11
428*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_EEP_MINOR_VER_19		0x13
429*dd1de374Slin wang - Sun Microsystems - Beijing China 
430*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_NUM_5G_CAL_PIERS		8
431*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_NUM_2G_CAL_PIERS		4
432*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_NUM_5G_20_TARGET_POWERS	8
433*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_NUM_5G_40_TARGET_POWERS	8
434*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_NUM_2G_CCK_TARGET_POWERS	3
435*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_NUM_2G_20_TARGET_POWERS	4
436*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_NUM_2G_40_TARGET_POWERS	4
437*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_NUM_CTLS			24
438*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_NUM_BAND_EDGES		8
439*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_NUM_PD_GAINS		4
440*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_PD_GAINS_IN_MASK		4
441*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_PD_GAIN_ICEPTS		5
442*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_EEPROM_MODAL_SPURS	5
443*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_MAX_RATE_POWER		63
444*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_NUM_PDADC_VALUES		128
445*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_BCHAN_UNUSED		0xFF
446*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_MAX_PWR_RANGE_IN_HALF_DB	64
447*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_MAX_CHAINS		3
448*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_PWR_TABLE_OFFSET		-5
449*dd1de374Slin wang - Sun Microsystems - Beijing China 
450*dd1de374Slin wang - Sun Microsystems - Beijing China /* Rx gain type values */
451*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_EEP_RXGAIN_23DB_BACKOFF	0
452*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_EEP_RXGAIN_13DB_BACKOFF	1
453*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_EEP_RXGAIN_ORIG		2
454*dd1de374Slin wang - Sun Microsystems - Beijing China 
455*dd1de374Slin wang - Sun Microsystems - Beijing China /* Tx gain type values */
456*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_EEP_TXGAIN_ORIGINAL	0
457*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_EEP_TXGAIN_HIGH_POWER	1
458*dd1de374Slin wang - Sun Microsystems - Beijing China 
459*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_EEP4K_START_LOC					64
460*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_EEP4K_NUM_2G_CAL_PIERS			3
461*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_EEP4K_NUM_2G_CCK_TARGET_POWERS	3
462*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_EEP4K_NUM_2G_20_TARGET_POWERS	3
463*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_EEP4K_NUM_2G_40_TARGET_POWERS	3
464*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_EEP4K_NUM_CTLS					12
465*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_EEP4K_NUM_BAND_EDGES				4
466*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_EEP4K_NUM_PD_GAINS				2
467*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_EEP4K_PD_GAINS_IN_MASK			4
468*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_EEP4K_PD_GAIN_ICEPTS				5
469*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_EEP4K_MAX_CHAINS					1
470*dd1de374Slin wang - Sun Microsystems - Beijing China 
471*dd1de374Slin wang - Sun Microsystems - Beijing China enum eeprom_param {
472*dd1de374Slin wang - Sun Microsystems - Beijing China 	EEP_NFTHRESH_5,
473*dd1de374Slin wang - Sun Microsystems - Beijing China 	EEP_NFTHRESH_2,
474*dd1de374Slin wang - Sun Microsystems - Beijing China 	EEP_MAC_MSW,
475*dd1de374Slin wang - Sun Microsystems - Beijing China 	EEP_MAC_MID,
476*dd1de374Slin wang - Sun Microsystems - Beijing China 	EEP_MAC_LSW,
477*dd1de374Slin wang - Sun Microsystems - Beijing China 	EEP_REG_0,
478*dd1de374Slin wang - Sun Microsystems - Beijing China 	EEP_REG_1,
479*dd1de374Slin wang - Sun Microsystems - Beijing China 	EEP_OP_CAP,
480*dd1de374Slin wang - Sun Microsystems - Beijing China 	EEP_OP_MODE,
481*dd1de374Slin wang - Sun Microsystems - Beijing China 	EEP_RF_SILENT,
482*dd1de374Slin wang - Sun Microsystems - Beijing China 	EEP_OB_5,
483*dd1de374Slin wang - Sun Microsystems - Beijing China 	EEP_DB_5,
484*dd1de374Slin wang - Sun Microsystems - Beijing China 	EEP_OB_2,
485*dd1de374Slin wang - Sun Microsystems - Beijing China 	EEP_DB_2,
486*dd1de374Slin wang - Sun Microsystems - Beijing China 	EEP_MINOR_REV,
487*dd1de374Slin wang - Sun Microsystems - Beijing China 	EEP_TX_MASK,
488*dd1de374Slin wang - Sun Microsystems - Beijing China 	EEP_RX_MASK,
489*dd1de374Slin wang - Sun Microsystems - Beijing China 	EEP_RXGAIN_TYPE,
490*dd1de374Slin wang - Sun Microsystems - Beijing China 	EEP_TXGAIN_TYPE,
491*dd1de374Slin wang - Sun Microsystems - Beijing China };
492*dd1de374Slin wang - Sun Microsystems - Beijing China 
493*dd1de374Slin wang - Sun Microsystems - Beijing China enum ar5416_rates {
494*dd1de374Slin wang - Sun Microsystems - Beijing China 	rate6mb, rate9mb, rate12mb, rate18mb,
495*dd1de374Slin wang - Sun Microsystems - Beijing China 	rate24mb, rate36mb, rate48mb, rate54mb,
496*dd1de374Slin wang - Sun Microsystems - Beijing China 	rate1l, rate2l, rate2s, rate5_5l,
497*dd1de374Slin wang - Sun Microsystems - Beijing China 	rate5_5s, rate11l, rate11s, rateXr,
498*dd1de374Slin wang - Sun Microsystems - Beijing China 	rateHt20_0, rateHt20_1, rateHt20_2, rateHt20_3,
499*dd1de374Slin wang - Sun Microsystems - Beijing China 	rateHt20_4, rateHt20_5, rateHt20_6, rateHt20_7,
500*dd1de374Slin wang - Sun Microsystems - Beijing China 	rateHt40_0, rateHt40_1, rateHt40_2, rateHt40_3,
501*dd1de374Slin wang - Sun Microsystems - Beijing China 	rateHt40_4, rateHt40_5, rateHt40_6, rateHt40_7,
502*dd1de374Slin wang - Sun Microsystems - Beijing China 	rateDupCck, rateDupOfdm, rateExtCck, rateExtOfdm,
503*dd1de374Slin wang - Sun Microsystems - Beijing China 	Ar5416RateSize
504*dd1de374Slin wang - Sun Microsystems - Beijing China };
505*dd1de374Slin wang - Sun Microsystems - Beijing China 
506*dd1de374Slin wang - Sun Microsystems - Beijing China enum ath9k_hal_freq_band {
507*dd1de374Slin wang - Sun Microsystems - Beijing China 	ATH9K_HAL_FREQ_BAND_5GHZ = 0,
508*dd1de374Slin wang - Sun Microsystems - Beijing China 	ATH9K_HAL_FREQ_BAND_2GHZ = 1
509*dd1de374Slin wang - Sun Microsystems - Beijing China };
510*dd1de374Slin wang - Sun Microsystems - Beijing China 
511*dd1de374Slin wang - Sun Microsystems - Beijing China #pragma pack(1)
512*dd1de374Slin wang - Sun Microsystems - Beijing China struct base_eep_header {
513*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint16_t length;
514*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint16_t checksum;
515*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint16_t version;
516*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t opCapFlags;
517*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t eepMisc;
518*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint16_t regDmn[2];
519*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t macAddr[6];
520*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t rxMask;
521*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t txMask;
522*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint16_t rfSilent;
523*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint16_t blueToothOptions;
524*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint16_t deviceCap;
525*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t binBuildNumber;
526*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t deviceType;
527*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t pwdclkind;
528*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t futureBase_1[2];
529*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t rxGainType;
530*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t futureBase_2[3];
531*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t txGainType;
532*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t futureBase_3[25];
533*dd1de374Slin wang - Sun Microsystems - Beijing China };
534*dd1de374Slin wang - Sun Microsystems - Beijing China 
535*dd1de374Slin wang - Sun Microsystems - Beijing China struct base_eep_header_4k {
536*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint16_t length;
537*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint16_t checksum;
538*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint16_t version;
539*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t opCapFlags;
540*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t eepMisc;
541*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint16_t regDmn[2];
542*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t macAddr[6];
543*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t rxMask;
544*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t txMask;
545*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint16_t rfSilent;
546*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint16_t blueToothOptions;
547*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint16_t deviceCap;
548*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t binBuildNumber;
549*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t deviceType;
550*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t futureBase[1];
551*dd1de374Slin wang - Sun Microsystems - Beijing China };
552*dd1de374Slin wang - Sun Microsystems - Beijing China 
553*dd1de374Slin wang - Sun Microsystems - Beijing China struct spur_chan {
554*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint16_t spurChan;
555*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t spurRangeLow;
556*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t spurRangeHigh;
557*dd1de374Slin wang - Sun Microsystems - Beijing China };
558*dd1de374Slin wang - Sun Microsystems - Beijing China 
559*dd1de374Slin wang - Sun Microsystems - Beijing China struct modal_eep_header {
560*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t antCtrlChain[AR5416_MAX_CHAINS];
561*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t antCtrlCommon;
562*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t antennaGainCh[AR5416_MAX_CHAINS];
563*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t switchSettling;
564*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t txRxAttenCh[AR5416_MAX_CHAINS];
565*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t rxTxMarginCh[AR5416_MAX_CHAINS];
566*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t adcDesiredSize;
567*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t pgaDesiredSize;
568*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t xlnaGainCh[AR5416_MAX_CHAINS];
569*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t txEndToXpaOff;
570*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t txEndToRxOn;
571*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t txFrameToXpaOn;
572*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t thresh62;
573*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t noiseFloorThreshCh[AR5416_MAX_CHAINS];
574*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t xpdGain;
575*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t xpd;
576*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t iqCalICh[AR5416_MAX_CHAINS];
577*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t iqCalQCh[AR5416_MAX_CHAINS];
578*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t pdGainOverlap;
579*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t ob;
580*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t db;
581*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t xpaBiasLvl;
582*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t pwrDecreaseFor2Chain;
583*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t pwrDecreaseFor3Chain;
584*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t txFrameToDataStart;
585*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t txFrameToPaOn;
586*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t ht40PowerIncForPdadc;
587*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t bswAtten[AR5416_MAX_CHAINS];
588*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t bswMargin[AR5416_MAX_CHAINS];
589*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t swSettleHt40;
590*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t xatten2Db[AR5416_MAX_CHAINS];
591*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t xatten2Margin[AR5416_MAX_CHAINS];
592*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t ob_ch1;
593*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t db_ch1;
594*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t useAnt1:1,
595*dd1de374Slin wang - Sun Microsystems - Beijing China 	    force_xpaon:1,
596*dd1de374Slin wang - Sun Microsystems - Beijing China 	    local_bias:1,
597*dd1de374Slin wang - Sun Microsystems - Beijing China 	    femBandSelectUsed:1, xlnabufin:1, xlnaisel:2, xlnabufmode:1;
598*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t futureModalar9280;
599*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint16_t xpaBiasLvlFreq[3];
600*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t futureModal[6];
601*dd1de374Slin wang - Sun Microsystems - Beijing China 
602*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct spur_chan spurChans[AR5416_EEPROM_MODAL_SPURS];
603*dd1de374Slin wang - Sun Microsystems - Beijing China };
604*dd1de374Slin wang - Sun Microsystems - Beijing China 
605*dd1de374Slin wang - Sun Microsystems - Beijing China struct modal_eep_4k_header {
606*dd1de374Slin wang - Sun Microsystems - Beijing China     uint32_t  antCtrlChain[AR5416_EEP4K_MAX_CHAINS];
607*dd1de374Slin wang - Sun Microsystems - Beijing China     uint32_t  antCtrlCommon;
608*dd1de374Slin wang - Sun Microsystems - Beijing China     uint8_t   antennaGainCh[AR5416_EEP4K_MAX_CHAINS];
609*dd1de374Slin wang - Sun Microsystems - Beijing China     uint8_t   switchSettling;
610*dd1de374Slin wang - Sun Microsystems - Beijing China     uint8_t   txRxAttenCh[AR5416_EEP4K_MAX_CHAINS];
611*dd1de374Slin wang - Sun Microsystems - Beijing China     uint8_t   rxTxMarginCh[AR5416_EEP4K_MAX_CHAINS];
612*dd1de374Slin wang - Sun Microsystems - Beijing China     uint8_t   adcDesiredSize;
613*dd1de374Slin wang - Sun Microsystems - Beijing China     uint8_t   pgaDesiredSize;
614*dd1de374Slin wang - Sun Microsystems - Beijing China     uint8_t   xlnaGainCh[AR5416_EEP4K_MAX_CHAINS];
615*dd1de374Slin wang - Sun Microsystems - Beijing China     uint8_t   txEndToXpaOff;
616*dd1de374Slin wang - Sun Microsystems - Beijing China     uint8_t   txEndToRxOn;
617*dd1de374Slin wang - Sun Microsystems - Beijing China     uint8_t   txFrameToXpaOn;
618*dd1de374Slin wang - Sun Microsystems - Beijing China     uint8_t   thresh62;
619*dd1de374Slin wang - Sun Microsystems - Beijing China     uint8_t   noiseFloorThreshCh[AR5416_EEP4K_MAX_CHAINS];
620*dd1de374Slin wang - Sun Microsystems - Beijing China     uint8_t   xpdGain;
621*dd1de374Slin wang - Sun Microsystems - Beijing China     uint8_t   xpd;
622*dd1de374Slin wang - Sun Microsystems - Beijing China     uint8_t   iqCalICh[AR5416_EEP4K_MAX_CHAINS];
623*dd1de374Slin wang - Sun Microsystems - Beijing China     uint8_t   iqCalQCh[AR5416_EEP4K_MAX_CHAINS];
624*dd1de374Slin wang - Sun Microsystems - Beijing China     uint8_t   pdGainOverlap;
625*dd1de374Slin wang - Sun Microsystems - Beijing China     uint8_t   ob_01;
626*dd1de374Slin wang - Sun Microsystems - Beijing China     uint8_t   db1_01;
627*dd1de374Slin wang - Sun Microsystems - Beijing China     uint8_t   xpaBiasLvl;
628*dd1de374Slin wang - Sun Microsystems - Beijing China     uint8_t   txFrameToDataStart;
629*dd1de374Slin wang - Sun Microsystems - Beijing China     uint8_t   txFrameToPaOn;
630*dd1de374Slin wang - Sun Microsystems - Beijing China     uint8_t   ht40PowerIncForPdadc;
631*dd1de374Slin wang - Sun Microsystems - Beijing China     uint8_t   bswAtten[AR5416_EEP4K_MAX_CHAINS];
632*dd1de374Slin wang - Sun Microsystems - Beijing China     uint8_t   bswMargin[AR5416_EEP4K_MAX_CHAINS];
633*dd1de374Slin wang - Sun Microsystems - Beijing China     uint8_t   swSettleHt40;
634*dd1de374Slin wang - Sun Microsystems - Beijing China     uint8_t   xatten2Db[AR5416_EEP4K_MAX_CHAINS];
635*dd1de374Slin wang - Sun Microsystems - Beijing China     uint8_t   xatten2Margin[AR5416_EEP4K_MAX_CHAINS];
636*dd1de374Slin wang - Sun Microsystems - Beijing China     uint8_t   db2_01;
637*dd1de374Slin wang - Sun Microsystems - Beijing China     uint8_t   version;
638*dd1de374Slin wang - Sun Microsystems - Beijing China     uint16_t  ob_234;
639*dd1de374Slin wang - Sun Microsystems - Beijing China     uint16_t  db1_234;
640*dd1de374Slin wang - Sun Microsystems - Beijing China     uint16_t  db2_234;
641*dd1de374Slin wang - Sun Microsystems - Beijing China     uint8_t   futureModal[4];
642*dd1de374Slin wang - Sun Microsystems - Beijing China 
643*dd1de374Slin wang - Sun Microsystems - Beijing China     struct spur_chan spurChans[AR5416_EEPROM_MODAL_SPURS];
644*dd1de374Slin wang - Sun Microsystems - Beijing China };
645*dd1de374Slin wang - Sun Microsystems - Beijing China 
646*dd1de374Slin wang - Sun Microsystems - Beijing China struct cal_data_per_freq {
647*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t pwrPdg[AR5416_NUM_PD_GAINS][AR5416_PD_GAIN_ICEPTS];
648*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t vpdPdg[AR5416_NUM_PD_GAINS][AR5416_PD_GAIN_ICEPTS];
649*dd1de374Slin wang - Sun Microsystems - Beijing China };
650*dd1de374Slin wang - Sun Microsystems - Beijing China 
651*dd1de374Slin wang - Sun Microsystems - Beijing China struct cal_data_per_freq_4k {
652*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t pwrPdg[AR5416_EEP4K_NUM_PD_GAINS][AR5416_EEP4K_PD_GAIN_ICEPTS];
653*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t vpdPdg[AR5416_EEP4K_NUM_PD_GAINS][AR5416_EEP4K_PD_GAIN_ICEPTS];
654*dd1de374Slin wang - Sun Microsystems - Beijing China };
655*dd1de374Slin wang - Sun Microsystems - Beijing China 
656*dd1de374Slin wang - Sun Microsystems - Beijing China struct cal_target_power_leg {
657*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t bChannel;
658*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t tPow2x[4];
659*dd1de374Slin wang - Sun Microsystems - Beijing China };
660*dd1de374Slin wang - Sun Microsystems - Beijing China 
661*dd1de374Slin wang - Sun Microsystems - Beijing China struct cal_target_power_ht {
662*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t bChannel;
663*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t tPow2x[8];
664*dd1de374Slin wang - Sun Microsystems - Beijing China };
665*dd1de374Slin wang - Sun Microsystems - Beijing China 
666*dd1de374Slin wang - Sun Microsystems - Beijing China #ifdef __BIG_ENDIAN_BITFIELD
667*dd1de374Slin wang - Sun Microsystems - Beijing China struct cal_ctl_edges {
668*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t bChannel;
669*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t flag:2, tPower:6;
670*dd1de374Slin wang - Sun Microsystems - Beijing China };
671*dd1de374Slin wang - Sun Microsystems - Beijing China #else
672*dd1de374Slin wang - Sun Microsystems - Beijing China struct cal_ctl_edges {
673*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t bChannel;
674*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t tPower:6, flag:2;
675*dd1de374Slin wang - Sun Microsystems - Beijing China };
676*dd1de374Slin wang - Sun Microsystems - Beijing China #endif
677*dd1de374Slin wang - Sun Microsystems - Beijing China 
678*dd1de374Slin wang - Sun Microsystems - Beijing China struct cal_ctl_data {
679*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct cal_ctl_edges
680*dd1de374Slin wang - Sun Microsystems - Beijing China 	    ctlEdges[AR5416_MAX_CHAINS][AR5416_NUM_BAND_EDGES];
681*dd1de374Slin wang - Sun Microsystems - Beijing China };
682*dd1de374Slin wang - Sun Microsystems - Beijing China 
683*dd1de374Slin wang - Sun Microsystems - Beijing China struct cal_ctl_data_4k {
684*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct cal_ctl_edges
685*dd1de374Slin wang - Sun Microsystems - Beijing China 	ctlEdges[AR5416_EEP4K_MAX_CHAINS][AR5416_EEP4K_NUM_BAND_EDGES];
686*dd1de374Slin wang - Sun Microsystems - Beijing China };
687*dd1de374Slin wang - Sun Microsystems - Beijing China 
688*dd1de374Slin wang - Sun Microsystems - Beijing China struct ar5416_eeprom_def {
689*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct base_eep_header baseEepHeader;
690*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t custData[64];
691*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct modal_eep_header modalHeader[2];
692*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t calFreqPier5G[AR5416_NUM_5G_CAL_PIERS];
693*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t calFreqPier2G[AR5416_NUM_2G_CAL_PIERS];
694*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct cal_data_per_freq
695*dd1de374Slin wang - Sun Microsystems - Beijing China 	    calPierData5G[AR5416_MAX_CHAINS][AR5416_NUM_5G_CAL_PIERS];
696*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct cal_data_per_freq
697*dd1de374Slin wang - Sun Microsystems - Beijing China 	    calPierData2G[AR5416_MAX_CHAINS][AR5416_NUM_2G_CAL_PIERS];
698*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct cal_target_power_leg
699*dd1de374Slin wang - Sun Microsystems - Beijing China 	    calTargetPower5G[AR5416_NUM_5G_20_TARGET_POWERS];
700*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct cal_target_power_ht
701*dd1de374Slin wang - Sun Microsystems - Beijing China 	    calTargetPower5GHT20[AR5416_NUM_5G_20_TARGET_POWERS];
702*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct cal_target_power_ht
703*dd1de374Slin wang - Sun Microsystems - Beijing China 	    calTargetPower5GHT40[AR5416_NUM_5G_40_TARGET_POWERS];
704*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct cal_target_power_leg
705*dd1de374Slin wang - Sun Microsystems - Beijing China 	    calTargetPowerCck[AR5416_NUM_2G_CCK_TARGET_POWERS];
706*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct cal_target_power_leg
707*dd1de374Slin wang - Sun Microsystems - Beijing China 	    calTargetPower2G[AR5416_NUM_2G_20_TARGET_POWERS];
708*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct cal_target_power_ht
709*dd1de374Slin wang - Sun Microsystems - Beijing China 	    calTargetPower2GHT20[AR5416_NUM_2G_20_TARGET_POWERS];
710*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct cal_target_power_ht
711*dd1de374Slin wang - Sun Microsystems - Beijing China 	    calTargetPower2GHT40[AR5416_NUM_2G_40_TARGET_POWERS];
712*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t ctlIndex[AR5416_NUM_CTLS];
713*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct cal_ctl_data ctlData[AR5416_NUM_CTLS];
714*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t padding;
715*dd1de374Slin wang - Sun Microsystems - Beijing China };
716*dd1de374Slin wang - Sun Microsystems - Beijing China 
717*dd1de374Slin wang - Sun Microsystems - Beijing China struct ar5416_eeprom_4k {
718*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct base_eep_header_4k baseEepHeader;
719*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t custData[20];
720*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct modal_eep_4k_header modalHeader;
721*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t calFreqPier2G[AR5416_EEP4K_NUM_2G_CAL_PIERS];
722*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct cal_data_per_freq_4k
723*dd1de374Slin wang - Sun Microsystems - Beijing China 	calPierData2G[AR5416_EEP4K_MAX_CHAINS][AR5416_EEP4K_NUM_2G_CAL_PIERS];
724*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct cal_target_power_leg
725*dd1de374Slin wang - Sun Microsystems - Beijing China 	calTargetPowerCck[AR5416_EEP4K_NUM_2G_CCK_TARGET_POWERS];
726*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct cal_target_power_leg
727*dd1de374Slin wang - Sun Microsystems - Beijing China 	calTargetPower2G[AR5416_EEP4K_NUM_2G_20_TARGET_POWERS];
728*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct cal_target_power_ht
729*dd1de374Slin wang - Sun Microsystems - Beijing China 	calTargetPower2GHT20[AR5416_EEP4K_NUM_2G_20_TARGET_POWERS];
730*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct cal_target_power_ht
731*dd1de374Slin wang - Sun Microsystems - Beijing China 	calTargetPower2GHT40[AR5416_EEP4K_NUM_2G_40_TARGET_POWERS];
732*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t ctlIndex[AR5416_EEP4K_NUM_CTLS];
733*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct cal_ctl_data_4k ctlData[AR5416_EEP4K_NUM_CTLS];
734*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t padding;
735*dd1de374Slin wang - Sun Microsystems - Beijing China };
736*dd1de374Slin wang - Sun Microsystems - Beijing China #pragma pack()
737*dd1de374Slin wang - Sun Microsystems - Beijing China 
738*dd1de374Slin wang - Sun Microsystems - Beijing China struct ar5416IniArray {
739*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t *ia_array;
740*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ia_rows;
741*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ia_columns;
742*dd1de374Slin wang - Sun Microsystems - Beijing China };
743*dd1de374Slin wang - Sun Microsystems - Beijing China 
744*dd1de374Slin wang - Sun Microsystems - Beijing China #define	INIT_INI_ARRAY(iniarray, array, rows, columns) do {	\
745*dd1de374Slin wang - Sun Microsystems - Beijing China 		(iniarray)->ia_array = (uint32_t *)(array);		\
746*dd1de374Slin wang - Sun Microsystems - Beijing China 		(iniarray)->ia_rows = (rows);			\
747*dd1de374Slin wang - Sun Microsystems - Beijing China 		(iniarray)->ia_columns = (columns);		\
748*dd1de374Slin wang - Sun Microsystems - Beijing China 		_NOTE(CONSTCOND) \
749*dd1de374Slin wang - Sun Microsystems - Beijing China 	} while (0)
750*dd1de374Slin wang - Sun Microsystems - Beijing China 
751*dd1de374Slin wang - Sun Microsystems - Beijing China #define	INI_RA(iniarray, row, column) \
752*dd1de374Slin wang - Sun Microsystems - Beijing China 	(((iniarray)->ia_array)[(row) *	((iniarray)->ia_columns) + (column)])
753*dd1de374Slin wang - Sun Microsystems - Beijing China 
754*dd1de374Slin wang - Sun Microsystems - Beijing China #define	INIT_CAL(_perCal) do {				\
755*dd1de374Slin wang - Sun Microsystems - Beijing China 		(_perCal)->calState = CAL_WAITING;	\
756*dd1de374Slin wang - Sun Microsystems - Beijing China 		(_perCal)->calNext = NULL;		\
757*dd1de374Slin wang - Sun Microsystems - Beijing China 	} while (0)
758*dd1de374Slin wang - Sun Microsystems - Beijing China 
759*dd1de374Slin wang - Sun Microsystems - Beijing China #define	INSERT_CAL(_ahp, _perCal)					\
760*dd1de374Slin wang - Sun Microsystems - Beijing China 	do {								\
761*dd1de374Slin wang - Sun Microsystems - Beijing China 		if ((_ahp)->ah_cal_list_last == NULL) {			\
762*dd1de374Slin wang - Sun Microsystems - Beijing China 			(_ahp)->ah_cal_list =				\
763*dd1de374Slin wang - Sun Microsystems - Beijing China 				(_ahp)->ah_cal_list_last = (_perCal);	\
764*dd1de374Slin wang - Sun Microsystems - Beijing China 			((_ahp)->ah_cal_list_last)->calNext = (_perCal); \
765*dd1de374Slin wang - Sun Microsystems - Beijing China 		} else {						\
766*dd1de374Slin wang - Sun Microsystems - Beijing China 			((_ahp)->ah_cal_list_last)->calNext = (_perCal); \
767*dd1de374Slin wang - Sun Microsystems - Beijing China 			(_ahp)->ah_cal_list_last = (_perCal);		\
768*dd1de374Slin wang - Sun Microsystems - Beijing China 			(_perCal)->calNext = (_ahp)->ah_cal_list;	\
769*dd1de374Slin wang - Sun Microsystems - Beijing China 		}							\
770*dd1de374Slin wang - Sun Microsystems - Beijing China 	} while (0)
771*dd1de374Slin wang - Sun Microsystems - Beijing China 
772*dd1de374Slin wang - Sun Microsystems - Beijing China enum hal_cal_types {
773*dd1de374Slin wang - Sun Microsystems - Beijing China 	ADC_DC_INIT_CAL = 0x1,
774*dd1de374Slin wang - Sun Microsystems - Beijing China 	ADC_GAIN_CAL = 0x2,
775*dd1de374Slin wang - Sun Microsystems - Beijing China 	ADC_DC_CAL = 0x4,
776*dd1de374Slin wang - Sun Microsystems - Beijing China 	IQ_MISMATCH_CAL = 0x8
777*dd1de374Slin wang - Sun Microsystems - Beijing China };
778*dd1de374Slin wang - Sun Microsystems - Beijing China 
779*dd1de374Slin wang - Sun Microsystems - Beijing China enum hal_cal_state {
780*dd1de374Slin wang - Sun Microsystems - Beijing China 	CAL_INACTIVE,
781*dd1de374Slin wang - Sun Microsystems - Beijing China 	CAL_WAITING,
782*dd1de374Slin wang - Sun Microsystems - Beijing China 	CAL_RUNNING,
783*dd1de374Slin wang - Sun Microsystems - Beijing China 	CAL_DONE
784*dd1de374Slin wang - Sun Microsystems - Beijing China };
785*dd1de374Slin wang - Sun Microsystems - Beijing China 
786*dd1de374Slin wang - Sun Microsystems - Beijing China #define	MIN_CAL_SAMPLES		1
787*dd1de374Slin wang - Sun Microsystems - Beijing China #define	MAX_CAL_SAMPLES		64
788*dd1de374Slin wang - Sun Microsystems - Beijing China #define	INIT_LOG_COUNT		5
789*dd1de374Slin wang - Sun Microsystems - Beijing China #define	PER_MIN_LOG_COUNT	2
790*dd1de374Slin wang - Sun Microsystems - Beijing China #define	PER_MAX_LOG_COUNT	10
791*dd1de374Slin wang - Sun Microsystems - Beijing China 
792*dd1de374Slin wang - Sun Microsystems - Beijing China struct hal_percal_data {
793*dd1de374Slin wang - Sun Microsystems - Beijing China 	enum hal_cal_types calType;
794*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t calNumSamples;
795*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t calCountMax;
796*dd1de374Slin wang - Sun Microsystems - Beijing China 	void (*calCollect) (struct ath_hal *);
797*dd1de374Slin wang - Sun Microsystems - Beijing China 	void (*calPostProc) (struct ath_hal *, uint8_t);
798*dd1de374Slin wang - Sun Microsystems - Beijing China };
799*dd1de374Slin wang - Sun Microsystems - Beijing China 
800*dd1de374Slin wang - Sun Microsystems - Beijing China struct hal_cal_list {
801*dd1de374Slin wang - Sun Microsystems - Beijing China 	const struct hal_percal_data *calData;
802*dd1de374Slin wang - Sun Microsystems - Beijing China 	enum hal_cal_state calState;
803*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct hal_cal_list *calNext;
804*dd1de374Slin wang - Sun Microsystems - Beijing China };
805*dd1de374Slin wang - Sun Microsystems - Beijing China 
806*dd1de374Slin wang - Sun Microsystems - Beijing China /*
807*dd1de374Slin wang - Sun Microsystems - Beijing China  * Enum to indentify the eeprom mappings
808*dd1de374Slin wang - Sun Microsystems - Beijing China  */
809*dd1de374Slin wang - Sun Microsystems - Beijing China enum hal_eep_map {
810*dd1de374Slin wang - Sun Microsystems - Beijing China 	EEP_MAP_DEFAULT = 0x0,
811*dd1de374Slin wang - Sun Microsystems - Beijing China 	EEP_MAP_4KBITS,
812*dd1de374Slin wang - Sun Microsystems - Beijing China 	EEP_MAP_MAX
813*dd1de374Slin wang - Sun Microsystems - Beijing China };
814*dd1de374Slin wang - Sun Microsystems - Beijing China 
815*dd1de374Slin wang - Sun Microsystems - Beijing China struct ath_hal_5416 {
816*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct ath_hal ah;
817*dd1de374Slin wang - Sun Microsystems - Beijing China 	union {
818*dd1de374Slin wang - Sun Microsystems - Beijing China 		struct ar5416_eeprom_def def;
819*dd1de374Slin wang - Sun Microsystems - Beijing China 		struct ar5416_eeprom_4k map4k;
820*dd1de374Slin wang - Sun Microsystems - Beijing China 	} ah_eeprom;
821*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct ar5416Stats ah_stats;
822*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct ath9k_tx_queue_info ah_txq[ATH9K_NUM_TX_QUEUES];
823*dd1de374Slin wang - Sun Microsystems - Beijing China 
824*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t ah_macaddr[IEEE80211_ADDR_LEN];
825*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t ah_bssid[IEEE80211_ADDR_LEN];
826*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t ah_bssidmask[IEEE80211_ADDR_LEN];
827*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint16_t ah_assocId;
828*dd1de374Slin wang - Sun Microsystems - Beijing China 
829*dd1de374Slin wang - Sun Microsystems - Beijing China 	int16_t ah_curchanRadIndex;
830*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ah_maskReg;
831*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ah_txOkInterruptMask;
832*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ah_txErrInterruptMask;
833*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ah_txDescInterruptMask;
834*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ah_txEolInterruptMask;
835*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ah_txUrnInterruptMask;
836*dd1de374Slin wang - Sun Microsystems - Beijing China 	boolean_t ah_chipFullSleep;
837*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ah_atimWindow;
838*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint16_t ah_antennaSwitchSwap;
839*dd1de374Slin wang - Sun Microsystems - Beijing China 	enum ath9k_power_mode ah_powerMode;
840*dd1de374Slin wang - Sun Microsystems - Beijing China 	enum ath9k_ant_setting ah_diversityControl;
841*dd1de374Slin wang - Sun Microsystems - Beijing China 
842*dd1de374Slin wang - Sun Microsystems - Beijing China 	/* Calibration */
843*dd1de374Slin wang - Sun Microsystems - Beijing China 	enum hal_cal_types ah_suppCals;
844*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct hal_cal_list ah_iqCalData;
845*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct hal_cal_list ah_adcGainCalData;
846*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct hal_cal_list ah_adcDcCalInitData;
847*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct hal_cal_list ah_adcDcCalData;
848*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct hal_cal_list *ah_cal_list;
849*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct hal_cal_list *ah_cal_list_last;
850*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct hal_cal_list *ah_cal_list_curr;
851*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ah_totalPowerMeasI ah_Meas0.unsign
852*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ah_totalPowerMeasQ ah_Meas1.unsign
853*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ah_totalIqCorrMeas ah_Meas2.sign
854*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ah_totalAdcIOddPhase  ah_Meas0.unsign
855*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ah_totalAdcIEvenPhase ah_Meas1.unsign
856*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ah_totalAdcQOddPhase  ah_Meas2.unsign
857*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ah_totalAdcQEvenPhase ah_Meas3.unsign
858*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ah_totalAdcDcOffsetIOddPhase  ah_Meas0.sign
859*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ah_totalAdcDcOffsetIEvenPhase ah_Meas1.sign
860*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ah_totalAdcDcOffsetQOddPhase  ah_Meas2.sign
861*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ah_totalAdcDcOffsetQEvenPhase ah_Meas3.sign
862*dd1de374Slin wang - Sun Microsystems - Beijing China 	union {
863*dd1de374Slin wang - Sun Microsystems - Beijing China 		uint32_t unsign[AR5416_MAX_CHAINS];
864*dd1de374Slin wang - Sun Microsystems - Beijing China 		int32_t sign[AR5416_MAX_CHAINS];
865*dd1de374Slin wang - Sun Microsystems - Beijing China 	} ah_Meas0;
866*dd1de374Slin wang - Sun Microsystems - Beijing China 	union {
867*dd1de374Slin wang - Sun Microsystems - Beijing China 		uint32_t unsign[AR5416_MAX_CHAINS];
868*dd1de374Slin wang - Sun Microsystems - Beijing China 		int32_t sign[AR5416_MAX_CHAINS];
869*dd1de374Slin wang - Sun Microsystems - Beijing China 	} ah_Meas1;
870*dd1de374Slin wang - Sun Microsystems - Beijing China 	union {
871*dd1de374Slin wang - Sun Microsystems - Beijing China 		uint32_t unsign[AR5416_MAX_CHAINS];
872*dd1de374Slin wang - Sun Microsystems - Beijing China 		int32_t sign[AR5416_MAX_CHAINS];
873*dd1de374Slin wang - Sun Microsystems - Beijing China 	} ah_Meas2;
874*dd1de374Slin wang - Sun Microsystems - Beijing China 	union {
875*dd1de374Slin wang - Sun Microsystems - Beijing China 		uint32_t unsign[AR5416_MAX_CHAINS];
876*dd1de374Slin wang - Sun Microsystems - Beijing China 		int32_t sign[AR5416_MAX_CHAINS];
877*dd1de374Slin wang - Sun Microsystems - Beijing China 	} ah_Meas3;
878*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint16_t ah_CalSamples;
879*dd1de374Slin wang - Sun Microsystems - Beijing China 
880*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ah_staId1Defaults;
881*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ah_miscMode;
882*dd1de374Slin wang - Sun Microsystems - Beijing China 	enum {
883*dd1de374Slin wang - Sun Microsystems - Beijing China 		AUTO_32KHZ,
884*dd1de374Slin wang - Sun Microsystems - Beijing China 		USE_32KHZ,
885*dd1de374Slin wang - Sun Microsystems - Beijing China 		DONT_USE_32KHZ,
886*dd1de374Slin wang - Sun Microsystems - Beijing China 	} ah_enable32kHzClock;
887*dd1de374Slin wang - Sun Microsystems - Beijing China 
888*dd1de374Slin wang - Sun Microsystems - Beijing China 	/* RF */
889*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t *ah_analogBank0Data;
890*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t *ah_analogBank1Data;
891*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t *ah_analogBank2Data;
892*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t *ah_analogBank3Data;
893*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t *ah_analogBank6Data;
894*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t *ah_analogBank6TPCData;
895*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t *ah_analogBank7Data;
896*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t *ah_addac5416_21;
897*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t *ah_bank6Temp;
898*dd1de374Slin wang - Sun Microsystems - Beijing China 
899*dd1de374Slin wang - Sun Microsystems - Beijing China 	int16_t ah_txPowerIndexOffset;
900*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ah_beaconInterval;
901*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ah_slottime;
902*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ah_acktimeout;
903*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ah_ctstimeout;
904*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ah_globaltxtimeout;
905*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t ah_gBeaconRate;
906*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ah_gpioSelect;
907*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ah_polarity;
908*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ah_gpioBit;
909*dd1de374Slin wang - Sun Microsystems - Beijing China 
910*dd1de374Slin wang - Sun Microsystems - Beijing China 	/* ANI */
911*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ah_procPhyErr;
912*dd1de374Slin wang - Sun Microsystems - Beijing China 	boolean_t ah_hasHwPhyCounters;
913*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ah_aniPeriod;
914*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct ar5416AniState *ah_curani;
915*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct ar5416AniState ah_ani[255];
916*dd1de374Slin wang - Sun Microsystems - Beijing China 	int ah_totalSizeDesired[5];
917*dd1de374Slin wang - Sun Microsystems - Beijing China 	int ah_coarseHigh[5];
918*dd1de374Slin wang - Sun Microsystems - Beijing China 	int ah_coarseLow[5];
919*dd1de374Slin wang - Sun Microsystems - Beijing China 	int ah_firpwr[5];
920*dd1de374Slin wang - Sun Microsystems - Beijing China 	enum ath9k_ani_cmd ah_ani_function;
921*dd1de374Slin wang - Sun Microsystems - Beijing China 
922*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint32_t ah_intrTxqs;
923*dd1de374Slin wang - Sun Microsystems - Beijing China 	boolean_t ah_intrMitigation;
924*dd1de374Slin wang - Sun Microsystems - Beijing China 	enum ath9k_ht_extprotspacing ah_extprotspacing;
925*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t ah_txchainmask;
926*dd1de374Slin wang - Sun Microsystems - Beijing China 	uint8_t ah_rxchainmask;
927*dd1de374Slin wang - Sun Microsystems - Beijing China 
928*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct ar5416IniArray ah_iniModes;
929*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct ar5416IniArray ah_iniCommon;
930*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct ar5416IniArray ah_iniBank0;
931*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct ar5416IniArray ah_iniBB_RfGain;
932*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct ar5416IniArray ah_iniBank1;
933*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct ar5416IniArray ah_iniBank2;
934*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct ar5416IniArray ah_iniBank3;
935*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct ar5416IniArray ah_iniBank6;
936*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct ar5416IniArray ah_iniBank6TPC;
937*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct ar5416IniArray ah_iniBank7;
938*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct ar5416IniArray ah_iniAddac;
939*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct ar5416IniArray ah_iniPcieSerdes;
940*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct ar5416IniArray ah_iniModesAdditional;
941*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct ar5416IniArray ah_iniModesRxGain;
942*dd1de374Slin wang - Sun Microsystems - Beijing China 	struct ar5416IniArray ah_iniModesTxGain;
943*dd1de374Slin wang - Sun Microsystems - Beijing China 	/* To indicate EEPROM mapping used */
944*dd1de374Slin wang - Sun Microsystems - Beijing China 	enum hal_eep_map ah_eep_map;
945*dd1de374Slin wang - Sun Microsystems - Beijing China };
946*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AH5416(_ah) ((struct ath_hal_5416 *)(_ah))
947*dd1de374Slin wang - Sun Microsystems - Beijing China 
948*dd1de374Slin wang - Sun Microsystems - Beijing China #define	FREQ2FBIN(x, y) ((y) ? ((x) - 2300) : (((x) - 4800) / 5))
949*dd1de374Slin wang - Sun Microsystems - Beijing China 
950*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ar5416RfDetach(ah) do {					\
951*dd1de374Slin wang - Sun Microsystems - Beijing China 		if (AH5416(ah)->ah_rfHal.rfDetach != NULL)	\
952*dd1de374Slin wang - Sun Microsystems - Beijing China 			AH5416(ah)->ah_rfHal.rfDetach(ah);	\
953*dd1de374Slin wang - Sun Microsystems - Beijing China 	} while (0)
954*dd1de374Slin wang - Sun Microsystems - Beijing China 
955*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ath9k_hw_use_flash(_ah)	\
956*dd1de374Slin wang - Sun Microsystems - Beijing China 	(!(_ah->ah_flags & AH_USE_EEPROM))
957*dd1de374Slin wang - Sun Microsystems - Beijing China 
958*dd1de374Slin wang - Sun Microsystems - Beijing China 
959*dd1de374Slin wang - Sun Microsystems - Beijing China #define	DO_DELAY(x) do {			\
960*dd1de374Slin wang - Sun Microsystems - Beijing China 		if ((++(x) % 64) == 0)          \
961*dd1de374Slin wang - Sun Microsystems - Beijing China 			drv_usecwait(1);	\
962*dd1de374Slin wang - Sun Microsystems - Beijing China 	} while (0)
963*dd1de374Slin wang - Sun Microsystems - Beijing China 
964*dd1de374Slin wang - Sun Microsystems - Beijing China #define	REG_WRITE_ARRAY(iniarray, column, regWr) do {                   \
965*dd1de374Slin wang - Sun Microsystems - Beijing China 		int r;							\
966*dd1de374Slin wang - Sun Microsystems - Beijing China 		for (r = 0; r < ((iniarray)->ia_rows); r++) {		\
967*dd1de374Slin wang - Sun Microsystems - Beijing China 			REG_WRITE(ah, INI_RA((iniarray), (r), 0),	\
968*dd1de374Slin wang - Sun Microsystems - Beijing China 			    INI_RA((iniarray), r, (column)));		\
969*dd1de374Slin wang - Sun Microsystems - Beijing China 			DO_DELAY(regWr);				\
970*dd1de374Slin wang - Sun Microsystems - Beijing China 		}							\
971*dd1de374Slin wang - Sun Microsystems - Beijing China 	} while (0)
972*dd1de374Slin wang - Sun Microsystems - Beijing China 
973*dd1de374Slin wang - Sun Microsystems - Beijing China #define	BASE_ACTIVATE_DELAY		100
974*dd1de374Slin wang - Sun Microsystems - Beijing China #define	RTC_PLL_SETTLE_DELAY		1000
975*dd1de374Slin wang - Sun Microsystems - Beijing China #define	COEF_SCALE_S			24
976*dd1de374Slin wang - Sun Microsystems - Beijing China #define	HT40_CHANNEL_CENTER_SHIFT	10
977*dd1de374Slin wang - Sun Microsystems - Beijing China 
978*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_EEPROM_MAGIC_OFFSET	0x0
979*dd1de374Slin wang - Sun Microsystems - Beijing China 
980*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_EEPROM_S			2
981*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_EEPROM_OFFSET		0x2000
982*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_EEPROM_START_ADDR	\
983*dd1de374Slin wang - Sun Microsystems - Beijing China 	(AR_SREV_9100(ah)) ? 0x1fff1000 : 0x503f1200
984*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_EEPROM_MAX	0xae0
985*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ar5416_get_eep_ver(_ahp)	\
986*dd1de374Slin wang - Sun Microsystems - Beijing China 	(((_ahp)->ah_eeprom.def.baseEepHeader.version >> 12) & 0xF)
987*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ar5416_get_eep_rev(_ahp)	\
988*dd1de374Slin wang - Sun Microsystems - Beijing China 	(((_ahp)->ah_eeprom.def.baseEepHeader.version) & 0xFFF)
989*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ar5416_get_ntxchains(_txchainmask)	\
990*dd1de374Slin wang - Sun Microsystems - Beijing China 	(((_txchainmask >> 2) & 1) +	\
991*dd1de374Slin wang - Sun Microsystems - Beijing China 	((_txchainmask >> 1) & 1) + (_txchainmask & 1))
992*dd1de374Slin wang - Sun Microsystems - Beijing China 
993*dd1de374Slin wang - Sun Microsystems - Beijing China /* EEPROM 4K bit map definations */
994*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ar5416_get_eep4k_ver(_ahp)   \
995*dd1de374Slin wang - Sun Microsystems - Beijing China 	(((_ahp)->ah_eeprom.map4k.baseEepHeader.version >> 12) & 0xF)
996*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ar5416_get_eep4k_rev(_ahp)   \
997*dd1de374Slin wang - Sun Microsystems - Beijing China 	(((_ahp)->ah_eeprom.map4k.baseEepHeader.version) & 0xFFF)
998*dd1de374Slin wang - Sun Microsystems - Beijing China 
999*dd1de374Slin wang - Sun Microsystems - Beijing China #ifdef __BIG_ENDIAN
1000*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_EEPROM_MAGIC	0x5aa5
1001*dd1de374Slin wang - Sun Microsystems - Beijing China #else
1002*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR5416_EEPROM_MAGIC	0xa55a
1003*dd1de374Slin wang - Sun Microsystems - Beijing China #endif
1004*dd1de374Slin wang - Sun Microsystems - Beijing China 
1005*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ATH9K_POW_SM(_r, _s)		(((_r) & 0x3f) << (_s))
1006*dd1de374Slin wang - Sun Microsystems - Beijing China 
1007*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ATH9K_ANTENNA0_CHAINMASK	0x1
1008*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ATH9K_ANTENNA1_CHAINMASK	0x2
1009*dd1de374Slin wang - Sun Microsystems - Beijing China 
1010*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ATH9K_NUM_DMA_DEBUG_REGS	8
1011*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ATH9K_NUM_QUEUES		10
1012*dd1de374Slin wang - Sun Microsystems - Beijing China 
1013*dd1de374Slin wang - Sun Microsystems - Beijing China #define	HAL_NOISE_IMMUNE_MAX		4
1014*dd1de374Slin wang - Sun Microsystems - Beijing China #define	HAL_SPUR_IMMUNE_MAX		7
1015*dd1de374Slin wang - Sun Microsystems - Beijing China #define	HAL_FIRST_STEP_MAX		2
1016*dd1de374Slin wang - Sun Microsystems - Beijing China 
1017*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ATH9K_ANI_OFDM_TRIG_HIGH	500
1018*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ATH9K_ANI_OFDM_TRIG_LOW		200
1019*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ATH9K_ANI_CCK_TRIG_HIGH		200
1020*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ATH9K_ANI_CCK_TRIG_LOW		100
1021*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ATH9K_ANI_NOISE_IMMUNE_LVL	4
1022*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ATH9K_ANI_USE_OFDM_WEAK_SIG	B_TRUE
1023*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ATH9K_ANI_CCK_WEAK_SIG_THR	B_FALSE
1024*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ATH9K_ANI_SPUR_IMMUNE_LVL	7
1025*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ATH9K_ANI_FIRSTEP_LVL		0
1026*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ATH9K_ANI_RSSI_THR_HIGH		40
1027*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ATH9K_ANI_RSSI_THR_LOW		7
1028*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ATH9K_ANI_PERIOD		100
1029*dd1de374Slin wang - Sun Microsystems - Beijing China 
1030*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_GPIOD_MASK		0x00001FFF
1031*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_GPIO_BIT(_gpio)	(1 << (_gpio))
1032*dd1de374Slin wang - Sun Microsystems - Beijing China 
1033*dd1de374Slin wang - Sun Microsystems - Beijing China #define	HAL_EP_RND(x, mul)	\
1034*dd1de374Slin wang - Sun Microsystems - Beijing China 	((((x)%(mul)) >= ((mul)/2)) ? ((x) + ((mul) - 1)) / (mul) : (x)/(mul))
1035*dd1de374Slin wang - Sun Microsystems - Beijing China #define	BEACON_RSSI(ahp)	\
1036*dd1de374Slin wang - Sun Microsystems - Beijing China 	HAL_EP_RND(ahp->ah_stats.ast_nodestats.ns_avgbrssi,	\
1037*dd1de374Slin wang - Sun Microsystems - Beijing China 	ATH9K_RSSI_EP_MULTIPLIER)
1038*dd1de374Slin wang - Sun Microsystems - Beijing China 
1039*dd1de374Slin wang - Sun Microsystems - Beijing China #define	ah_mibStats	ah_stats.ast_mibstats
1040*dd1de374Slin wang - Sun Microsystems - Beijing China 
1041*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AH_TIMEOUT	100000
1042*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AH_TIME_QUANTUM	10
1043*dd1de374Slin wang - Sun Microsystems - Beijing China 
1044*dd1de374Slin wang - Sun Microsystems - Beijing China #define	AR_KEYTABLE_SIZE	128
1045*dd1de374Slin wang - Sun Microsystems - Beijing China #define	POWER_UP_TIME		200000
1046*dd1de374Slin wang - Sun Microsystems - Beijing China 
1047*dd1de374Slin wang - Sun Microsystems - Beijing China #define	EXT_ADDITIVE	(0x8000)
1048*dd1de374Slin wang - Sun Microsystems - Beijing China #define	CTL_11A_EXT	(CTL_11A | EXT_ADDITIVE)
1049*dd1de374Slin wang - Sun Microsystems - Beijing China #define	CTL_11G_EXT	(CTL_11G | EXT_ADDITIVE)
1050*dd1de374Slin wang - Sun Microsystems - Beijing China #define	CTL_11B_EXT	(CTL_11B | EXT_ADDITIVE)
1051*dd1de374Slin wang - Sun Microsystems - Beijing China 
1052*dd1de374Slin wang - Sun Microsystems - Beijing China #define	SUB_NUM_CTL_MODES_AT_5G_40	2
1053*dd1de374Slin wang - Sun Microsystems - Beijing China #define	SUB_NUM_CTL_MODES_AT_2G_40	3
1054*dd1de374Slin wang - Sun Microsystems - Beijing China #define	SPUR_RSSI_THRESH		40
1055*dd1de374Slin wang - Sun Microsystems - Beijing China 
1056*dd1de374Slin wang - Sun Microsystems - Beijing China #define	TU_TO_USEC(_tu)		((_tu) << 10)
1057*dd1de374Slin wang - Sun Microsystems - Beijing China 
1058*dd1de374Slin wang - Sun Microsystems - Beijing China #define	CAB_TIMEOUT_VAL		10
1059*dd1de374Slin wang - Sun Microsystems - Beijing China #define	BEACON_TIMEOUT_VAL	10
1060*dd1de374Slin wang - Sun Microsystems - Beijing China #define	MIN_BEACON_TIMEOUT_VAL	1
1061*dd1de374Slin wang - Sun Microsystems - Beijing China #define	SLEEP_SLOP		3
1062*dd1de374Slin wang - Sun Microsystems - Beijing China 
1063*dd1de374Slin wang - Sun Microsystems - Beijing China #define	CCK_SIFS_TIME		10
1064*dd1de374Slin wang - Sun Microsystems - Beijing China #define	CCK_PREAMBLE_BITS	144
1065*dd1de374Slin wang - Sun Microsystems - Beijing China #define	CCK_PLCP_BITS		48
1066*dd1de374Slin wang - Sun Microsystems - Beijing China 
1067*dd1de374Slin wang - Sun Microsystems - Beijing China #define	OFDM_SIFS_TIME		16
1068*dd1de374Slin wang - Sun Microsystems - Beijing China #define	OFDM_PREAMBLE_TIME	20
1069*dd1de374Slin wang - Sun Microsystems - Beijing China #define	OFDM_PLCP_BITS		22
1070*dd1de374Slin wang - Sun Microsystems - Beijing China #define	OFDM_SYMBOL_TIME	4
1071*dd1de374Slin wang - Sun Microsystems - Beijing China 
1072*dd1de374Slin wang - Sun Microsystems - Beijing China #define	OFDM_SIFS_TIME_HALF	32
1073*dd1de374Slin wang - Sun Microsystems - Beijing China #define	OFDM_PREAMBLE_TIME_HALF	40
1074*dd1de374Slin wang - Sun Microsystems - Beijing China #define	OFDM_PLCP_BITS_HALF	22
1075*dd1de374Slin wang - Sun Microsystems - Beijing China #define	OFDM_SYMBOL_TIME_HALF	8
1076*dd1de374Slin wang - Sun Microsystems - Beijing China 
1077*dd1de374Slin wang - Sun Microsystems - Beijing China #define	OFDM_SIFS_TIME_QUARTER		64
1078*dd1de374Slin wang - Sun Microsystems - Beijing China #define	OFDM_PREAMBLE_TIME_QUARTER	80
1079*dd1de374Slin wang - Sun Microsystems - Beijing China #define	OFDM_PLCP_BITS_QUARTER		22
1080*dd1de374Slin wang - Sun Microsystems - Beijing China #define	OFDM_SYMBOL_TIME_QUARTER	16
1081*dd1de374Slin wang - Sun Microsystems - Beijing China 
1082*dd1de374Slin wang - Sun Microsystems - Beijing China uint32_t ath9k_hw_get_eeprom(struct ath_hal *ah,
1083*dd1de374Slin wang - Sun Microsystems - Beijing China     enum eeprom_param param);
1084*dd1de374Slin wang - Sun Microsystems - Beijing China 
1085*dd1de374Slin wang - Sun Microsystems - Beijing China #ifdef __cplusplus
1086*dd1de374Slin wang - Sun Microsystems - Beijing China }
1087*dd1de374Slin wang - Sun Microsystems - Beijing China #endif
1088*dd1de374Slin wang - Sun Microsystems - Beijing China 
1089*dd1de374Slin wang - Sun Microsystems - Beijing China #endif /* _ARN_HW_H */
1090