xref: /haiku/src/add-ons/kernel/drivers/network/wlan/atheroswifi/dev/ath/ath_hal/ah_eeprom_v3.h (revision 86021fd407331bcef948c739a4870ca453f5c6cd)
1 /*-
2  * SPDX-License-Identifier: ISC
3  *
4  * Copyright (c) 2002-2008 Sam Leffler, Errno Consulting
5  * Copyright (c) 2002-2008 Atheros Communications, Inc.
6  *
7  * Permission to use, copy, modify, and/or distribute this software for any
8  * purpose with or without fee is hereby granted, provided that the above
9  * copyright notice and this permission notice appear in all copies.
10  *
11  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
12  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
13  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
14  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
15  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
16  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
17  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
18  */
19 #ifndef _ATH_AH_EEPROM_V3_H_
20 #define _ATH_AH_EEPROM_V3_H_
21 
22 #include "ah_eeprom.h"
23 
24 /* EEPROM defines for Version 2 & 3 AR5211 chips */
25 #define	AR_EEPROM_RFSILENT	0x0f	/* RF Silent/Clock Run Enable */
26 #define	AR_EEPROM_MAC(i)	(0x1d+(i)) /* MAC address word */
27 #define	AR_EEPROM_MAGIC		0x3d	/* magic number */
28 #define	AR_EEPROM_PROTECT	0x3f	/* EEPROM protect bits */
29 #define	AR_EEPROM_PROTECT_PCIE	0x01	/* EEPROM protect bits for Condor/Swan*/
30 #define	AR_EEPROM_REG_DOMAIN	0xbf	/* current regulatory domain */
31 #define	AR_EEPROM_ATHEROS_BASE	0xc0	/* Base of Atheros-specific data */
32 #define	AR_EEPROM_ATHEROS(i)	(AR_EEPROM_ATHEROS_BASE+(i))
33 #define	AR_EEPROM_ATHEROS_MAX	(0x400-AR_EEPROM_ATHEROS_BASE)
34 #define	AR_EEPROM_VERSION	AR_EEPROM_ATHEROS(1)
35 
36 /* FLASH(EEPROM) Defines for AR531X chips */
37 #define AR_EEPROM_SIZE_LOWER    0x1b    /* size info -- lower */
38 #define AR_EEPROM_SIZE_UPPER    0x1c    /* size info -- upper */
39 #define AR_EEPROM_SIZE_UPPER_MASK 0xfff0
40 #define AR_EEPROM_SIZE_UPPER_SHIFT 4
41 #define	AR_EEPROM_SIZE_ENDLOC_SHIFT 12
42 #define AR_EEPROM_ATHEROS_MAX_LOC 0x400
43 #define AR_EEPROM_ATHEROS_MAX_OFF (AR_EEPROM_ATHEROS_MAX_LOC-AR_EEPROM_ATHEROS_BASE)
44 
45 /* regulatory capabilities offsets */
46 #define AR_EEPROM_REG_CAPABILITIES_OFFSET		0xCA
47 #define AR_EEPROM_REG_CAPABILITIES_OFFSET_PRE4_0	0xCF /* prior to 4.0 */
48 
49 /* regulatory capabilities */
50 #define AR_EEPROM_EEREGCAP_EN_FCC_MIDBAND	0x0040
51 #define AR_EEPROM_EEREGCAP_EN_KK_U1_EVEN	0x0080
52 #define AR_EEPROM_EEREGCAP_EN_KK_U2		0x0100
53 #define AR_EEPROM_EEREGCAP_EN_KK_MIDBAND	0x0200
54 #define AR_EEPROM_EEREGCAP_EN_KK_U1_ODD		0x0400
55 #define AR_EEPROM_EEREGCAP_EN_KK_NEW_11A	0x0800
56 
57 /* regulatory capabilities prior to eeprom version 4.0 */
58 #define AR_EEPROM_EEREGCAP_EN_KK_U1_ODD_PRE4_0	0x4000
59 #define AR_EEPROM_EEREGCAP_EN_KK_NEW_11A_PRE4_0	0x8000
60 
61 /*
62  * AR2413 (includes AR5413)
63  */
64 #define AR_EEPROM_SERIAL_NUM_OFFSET     0xB0    /* EEPROM serial number */
65 #define AR_EEPROM_SERIAL_NUM_SIZE       12      /* EEPROM serial number size */
66 #define AR_EEPROM_CAPABILITIES_OFFSET   0xC9    /* EEPROM Location of capabilities */
67 
68 #define AR_EEPROM_EEPCAP_COMPRESS_DIS	0x0001
69 #define AR_EEPROM_EEPCAP_AES_DIS	0x0002
70 #define AR_EEPROM_EEPCAP_FASTFRAME_DIS	0x0004
71 #define AR_EEPROM_EEPCAP_BURST_DIS	0x0008
72 #define AR_EEPROM_EEPCAP_MAXQCU		0x01F0
73 #define AR_EEPROM_EEPCAP_MAXQCU_S	4
74 #define AR_EEPROM_EEPCAP_HEAVY_CLIP_EN	0x0200
75 #define AR_EEPROM_EEPCAP_KC_ENTRIES	0xF000
76 #define AR_EEPROM_EEPCAP_KC_ENTRIES_S	12
77 
78 /* XXX used to index various EEPROM-derived data structures */
79 enum {
80 	headerInfo11A	= 0,
81 	headerInfo11B	= 1,
82 	headerInfo11G	= 2,
83 };
84 
85 #define GROUPS_OFFSET3_2	0x100	/* groups offset for ver3.2 and earlier */
86 #define GROUPS_OFFSET3_3	0x150	/* groups offset for ver3.3 */
87 /* relative offset of GROUPi to GROUPS_OFFSET */
88 #define GROUP1_OFFSET		0x0
89 #define GROUP2_OFFSET		0x5
90 #define GROUP3_OFFSET		0x37
91 #define GROUP4_OFFSET		0x46
92 #define GROUP5_OFFSET		0x55
93 #define GROUP6_OFFSET		0x65
94 #define GROUP7_OFFSET		0x69
95 #define GROUP8_OFFSET		0x6f
96 
97 /* RF silent fields in EEPROM */
98 #define AR_EEPROM_RFSILENT_GPIO_SEL	0x001c
99 #define AR_EEPROM_RFSILENT_GPIO_SEL_S	2
100 #define AR_EEPROM_RFSILENT_POLARITY	0x0002
101 #define AR_EEPROM_RFSILENT_POLARITY_S	1
102 
103 /* Protect Bits RP is read protect, WP is write protect */
104 #define	AR_EEPROM_PROTECT_RP_0_31	0x0001
105 #define	AR_EEPROM_PROTECT_WP_0_31	0x0002
106 #define	AR_EEPROM_PROTECT_RP_32_63	0x0004
107 #define	AR_EEPROM_PROTECT_WP_32_63	0x0008
108 #define	AR_EEPROM_PROTECT_RP_64_127	0x0010
109 #define	AR_EEPROM_PROTECT_WP_64_127	0x0020
110 #define	AR_EEPROM_PROTECT_RP_128_191	0x0040
111 #define	AR_EEPROM_PROTECT_WP_128_191	0x0080
112 #define	AR_EEPROM_PROTECT_RP_192_207	0x0100
113 #define	AR_EEPROM_PROTECT_WP_192_207	0x0200
114 #define	AR_EEPROM_PROTECT_RP_208_223	0x0400
115 #define	AR_EEPROM_PROTECT_WP_208_223	0x0800
116 #define	AR_EEPROM_PROTECT_RP_224_239	0x1000
117 #define	AR_EEPROM_PROTECT_WP_224_239	0x2000
118 #define	AR_EEPROM_PROTECT_RP_240_255	0x4000
119 #define	AR_EEPROM_PROTECT_WP_240_255	0x8000
120 
121 #define	AR_EEPROM_MODAL_SPURS		5
122 #define	AR_SPUR_5413_1			1640	/* Freq 2464 */
123 #define	AR_SPUR_5413_2			1200	/* Freq 2420 */
124 
125 /*
126  * EEPROM fixed point conversion scale factors.
127  * NB: if you change one be sure to keep the other in sync.
128  */
129 #define EEP_SCALE	100		/* conversion scale to avoid fp arith */
130 #define EEP_DELTA	10		/* SCALE/10, to avoid arith divide */
131 
132 #define PWR_MIN		0
133 #define PWR_MAX		3150		/* 31.5 * SCALE */
134 #define PWR_STEP	50		/* 0.5 * SCALE */
135 /* Keep 2 above defines together */
136 
137 #define NUM_11A_EEPROM_CHANNELS	10
138 #define NUM_2_4_EEPROM_CHANNELS	3
139 #define NUM_PCDAC_VALUES	11
140 #define NUM_TEST_FREQUENCIES	8
141 #define NUM_EDGES	 	8
142 #define NUM_INTERCEPTS	 	11
143 #define FREQ_MASK		0x7f
144 #define FREQ_MASK_3_3		0xff	/* expanded in version 3.3 */
145 #define PCDAC_MASK		0x3f
146 #define POWER_MASK		0x3f
147 #define	NON_EDGE_FLAG_MASK	0x40
148 #define CHANNEL_POWER_INFO	8
149 #define OBDB_UNSET		0xffff
150 #define	CHANNEL_UNUSED		0xff
151 #define	SCALE_OC_DELTA(_x)	(((_x) * 2) / 10)
152 
153 /* Used during pcdac table construction */
154 #define PCDAC_START	1
155 #define PCDAC_STOP	63
156 #define PCDAC_STEP	1
157 #define PWR_TABLE_SIZE	64
158 #define	MAX_RATE_POWER	63
159 
160 /* Used during power/rate table construction */
161 #define NUM_CTLS	16
162 #define	NUM_CTLS_3_3	32		/* expanded in version 3.3 */
163 #define	NUM_CTLS_MAX	NUM_CTLS_3_3
164 
165 typedef struct fullPcdacStruct {
166 	uint16_t	channelValue;
167 	uint16_t	pcdacMin;
168 	uint16_t	pcdacMax;
169 	uint16_t	numPcdacValues;
170 	uint16_t	PcdacValues[64];
171 	/* power is 32bit since in dest it is scaled */
172 	int16_t		PwrValues[64];
173 } FULL_PCDAC_STRUCT;
174 
175 typedef struct dataPerChannel {
176 	uint16_t	channelValue;
177 	uint16_t	pcdacMin;
178 	uint16_t	pcdacMax;
179 	uint16_t	numPcdacValues;
180 	uint16_t	PcdacValues[NUM_PCDAC_VALUES];
181 	/* NB: power is 32bit since in dest it is scaled */
182 	int16_t		PwrValues[NUM_PCDAC_VALUES];
183 } DATA_PER_CHANNEL;
184 
185 /* points to the appropriate pcdac structs in the above struct based on mode */
186 typedef struct pcdacsEeprom {
187 	const uint16_t	*pChannelList;
188 	uint16_t	numChannels;
189 	const DATA_PER_CHANNEL *pDataPerChannel;
190 } PCDACS_EEPROM;
191 
192 typedef struct trgtPowerInfo {
193 	uint16_t	twicePwr54;
194 	uint16_t	twicePwr48;
195 	uint16_t	twicePwr36;
196 	uint16_t	twicePwr6_24;
197 	uint16_t	testChannel;
198 } TRGT_POWER_INFO;
199 
200 typedef struct trgtPowerAllModes {
201 	uint16_t	numTargetPwr_11a;
202 	TRGT_POWER_INFO trgtPwr_11a[NUM_TEST_FREQUENCIES];
203 	uint16_t	numTargetPwr_11g;
204 	TRGT_POWER_INFO trgtPwr_11g[3];
205 	uint16_t	numTargetPwr_11b;
206 	TRGT_POWER_INFO trgtPwr_11b[2];
207 } TRGT_POWER_ALL_MODES;
208 
209 typedef struct cornerCalInfo {
210 	uint16_t	gSel;
211 	uint16_t	pd84;
212 	uint16_t	pd90;
213 	uint16_t	clip;
214 } CORNER_CAL_INFO;
215 
216 /*
217  * EEPROM version 4 definitions
218  */
219 #define NUM_XPD_PER_CHANNEL      4
220 #define NUM_POINTS_XPD0          4
221 #define NUM_POINTS_XPD3          3
222 #define IDEAL_10dB_INTERCEPT_2G  35
223 #define IDEAL_10dB_INTERCEPT_5G  55
224 
225 #define	TENX_OFDM_CCK_DELTA_INIT	15		/* power 1.5 dbm */
226 #define	TENX_CH14_FILTER_CCK_DELTA_INIT	15		/* power 1.5 dbm */
227 #define	CCK_OFDM_GAIN_DELTA		15
228 
229 #define NUM_TARGET_POWER_LOCATIONS_11B  4
230 #define NUM_TARGET_POWER_LOCATIONS_11G  6
231 
232 typedef struct {
233 	uint16_t	xpd_gain;
234 	uint16_t	numPcdacs;
235 	uint16_t	pcdac[NUM_POINTS_XPD0];
236 	int16_t		pwr_t4[NUM_POINTS_XPD0];	/* or gainF */
237 } EXPN_DATA_PER_XPD_5112;
238 
239 typedef struct {
240 	uint16_t	channelValue;
241 	int16_t		maxPower_t4;
242 	EXPN_DATA_PER_XPD_5112	pDataPerXPD[NUM_XPD_PER_CHANNEL];
243 } EXPN_DATA_PER_CHANNEL_5112;
244 
245 typedef struct {
246 	uint16_t	*pChannels;
247 	uint16_t	numChannels;
248 	uint16_t 	xpdMask;	/* mask of permitted xpd_gains */
249 	EXPN_DATA_PER_CHANNEL_5112 *pDataPerChannel;
250 } EEPROM_POWER_EXPN_5112;
251 
252 typedef struct {
253 	uint16_t	channelValue;
254 	uint16_t	pcd1_xg0;
255 	int16_t		pwr1_xg0;
256 	uint16_t	pcd2_delta_xg0;
257 	int16_t		pwr2_xg0;
258 	uint16_t	pcd3_delta_xg0;
259 	int16_t		pwr3_xg0;
260 	uint16_t	pcd4_delta_xg0;
261 	int16_t		pwr4_xg0;
262 	int16_t		maxPower_t4;
263 	int16_t		pwr1_xg3;	/* pcdac = 20 */
264 	int16_t		pwr2_xg3;	/* pcdac = 35 */
265 	int16_t		pwr3_xg3;	/* pcdac = 63 */
266 	/* XXX - Should be pwr1_xg2, etc to agree with documentation */
267 } EEPROM_DATA_PER_CHANNEL_5112;
268 
269 typedef struct {
270 	uint16_t	pChannels[NUM_11A_EEPROM_CHANNELS];
271 	uint16_t	numChannels;
272 	uint16_t	xpdMask;	/* mask of permitted xpd_gains */
273 	EEPROM_DATA_PER_CHANNEL_5112 pDataPerChannel[NUM_11A_EEPROM_CHANNELS];
274 } EEPROM_POWER_5112;
275 
276 /*
277  * EEPROM version 5 definitions (Griffin, et. al.).
278  */
279 #define NUM_2_4_EEPROM_CHANNELS_2413	4
280 #define NUM_11A_EEPROM_CHANNELS_2413    10
281 #define PWR_TABLE_SIZE_2413		128
282 
283 /* Used during pdadc construction */
284 #define	MAX_NUM_PDGAINS_PER_CHANNEL	4
285 #define	NUM_PDGAINS_PER_CHANNEL		2
286 #define	NUM_POINTS_LAST_PDGAIN		5
287 #define	NUM_POINTS_OTHER_PDGAINS	4
288 #define	XPD_GAIN1_GEN5			3
289 #define	XPD_GAIN2_GEN5			1
290 #define	MAX_PWR_RANGE_IN_HALF_DB	64
291 #define	PD_GAIN_BOUNDARY_STRETCH_IN_HALF_DB	4
292 
293 typedef struct {
294 	uint16_t	pd_gain;
295 	uint16_t	numVpd;
296 	uint16_t	Vpd[NUM_POINTS_LAST_PDGAIN];
297 	int16_t		pwr_t4[NUM_POINTS_LAST_PDGAIN];	/* or gainF */
298 } RAW_DATA_PER_PDGAIN_2413;
299 
300 typedef struct {
301 	uint16_t	channelValue;
302 	int16_t		maxPower_t4;
303 	uint16_t	numPdGains;	/* # Pd Gains per channel */
304 	RAW_DATA_PER_PDGAIN_2413 pDataPerPDGain[MAX_NUM_PDGAINS_PER_CHANNEL];
305 } RAW_DATA_PER_CHANNEL_2413;
306 
307 /* XXX: assumes NUM_11A_EEPROM_CHANNELS_2413 >= NUM_2_4_EEPROM_CHANNELS_2413 ??? */
308 typedef struct {
309 	uint16_t	pChannels[NUM_11A_EEPROM_CHANNELS_2413];
310 	uint16_t	numChannels;
311 	uint16_t	xpd_mask;	/* mask of permitted xpd_gains */
312 	RAW_DATA_PER_CHANNEL_2413 pDataPerChannel[NUM_11A_EEPROM_CHANNELS_2413];
313 } RAW_DATA_STRUCT_2413;
314 
315 typedef struct {
316 	uint16_t	channelValue;
317 	uint16_t	numPdGains;
318 	uint16_t	Vpd_I[MAX_NUM_PDGAINS_PER_CHANNEL];
319 	int16_t		pwr_I[MAX_NUM_PDGAINS_PER_CHANNEL];
320 	uint16_t	Vpd_delta[NUM_POINTS_LAST_PDGAIN]
321 				[MAX_NUM_PDGAINS_PER_CHANNEL];
322 	int16_t		pwr_delta_t2[NUM_POINTS_LAST_PDGAIN]
323 				[MAX_NUM_PDGAINS_PER_CHANNEL];
324 	int16_t		maxPower_t4;
325 } EEPROM_DATA_PER_CHANNEL_2413;
326 
327 typedef struct {
328 	uint16_t	pChannels[NUM_11A_EEPROM_CHANNELS_2413];
329 	uint16_t	numChannels;
330 	uint16_t	xpd_mask;	/* mask of permitted xpd_gains */
331 	EEPROM_DATA_PER_CHANNEL_2413 pDataPerChannel[NUM_11A_EEPROM_CHANNELS_2413];
332 } EEPROM_DATA_STRUCT_2413;
333 
334 /*
335  * Information retrieved from EEPROM.
336  */
337 typedef struct {
338 	uint16_t	ee_version;		/* Version field */
339 	uint16_t	ee_protect;		/* EEPROM protect field */
340 	uint16_t	ee_regdomain;		/* Regulatory domain */
341 
342 	/* General Device Parameters */
343 	uint16_t	ee_turbo5Disable;
344 	uint16_t	ee_turbo2Disable;
345 	uint16_t	ee_rfKill;
346 	uint16_t	ee_deviceType;
347 	uint16_t	ee_turbo2WMaxPower5;
348 	uint16_t	ee_turbo2WMaxPower2;
349 	uint16_t	ee_xrTargetPower5;
350 	uint16_t	ee_xrTargetPower2;
351 	uint16_t	ee_Amode;
352 	uint16_t	ee_regCap;
353 	uint16_t	ee_Bmode;
354 	uint16_t	ee_Gmode;
355 	int8_t		ee_antennaGainMax[2];
356 	uint16_t	ee_xtnd5GSupport;
357 	uint8_t		ee_cckOfdmPwrDelta;
358 	uint8_t		ee_exist32kHzCrystal;
359 	uint16_t	ee_targetPowersStart;
360 	uint16_t	ee_fixedBias5;
361 	uint16_t	ee_fixedBias2;
362 	uint16_t	ee_cckOfdmGainDelta;
363 	uint16_t	ee_scaledCh14FilterCckDelta;
364 	uint16_t	ee_eepMap;
365 	uint16_t	ee_earStart;
366 
367 	/* 5 GHz / 2.4 GHz CKK / 2.4 GHz OFDM common parameters */
368 	uint16_t	ee_switchSettling[3];
369 	uint16_t	ee_txrxAtten[3];
370 	uint16_t	ee_txEndToXLNAOn[3];
371 	uint16_t	ee_thresh62[3];
372 	uint16_t	ee_txEndToXPAOff[3];
373 	uint16_t	ee_txFrameToXPAOn[3];
374 	int8_t		ee_adcDesiredSize[3];	 /* 8-bit signed value */
375 	int8_t		ee_pgaDesiredSize[3];	 /* 8-bit signed value */
376 	int16_t		ee_noiseFloorThresh[3];
377 	uint16_t	ee_xlnaGain[3];
378 	uint16_t	ee_xgain[3];
379 	uint16_t	ee_xpd[3];
380 	uint16_t	ee_antennaControl[11][3];
381 	uint16_t	ee_falseDetectBackoff[3];
382 	uint16_t	ee_gainI[3];
383 	uint16_t	ee_rxtxMargin[3];
384 
385 	/* new parameters added for the AR2413 */
386 	HAL_BOOL	ee_disableXr5;
387 	HAL_BOOL	ee_disableXr2;
388 	uint16_t	ee_eepMap2PowerCalStart;
389 	uint16_t	ee_capField;
390 
391 	uint16_t	ee_switchSettlingTurbo[2];
392 	uint16_t	ee_txrxAttenTurbo[2];
393 	int8_t		ee_adcDesiredSizeTurbo[2];
394 	int8_t		ee_pgaDesiredSizeTurbo[2];
395 	uint16_t	ee_rxtxMarginTurbo[2];
396 
397 	/* 5 GHz parameters */
398 	uint16_t	ee_ob1;
399 	uint16_t	ee_db1;
400 	uint16_t	ee_ob2;
401 	uint16_t	ee_db2;
402 	uint16_t	ee_ob3;
403 	uint16_t	ee_db3;
404 	uint16_t	ee_ob4;
405 	uint16_t	ee_db4;
406 
407 	/* 2.4 GHz parameters */
408 	uint16_t	ee_obFor24;
409 	uint16_t	ee_dbFor24;
410 	uint16_t	ee_obFor24g;
411 	uint16_t	ee_dbFor24g;
412 	uint16_t	ee_ob2GHz[2];
413 	uint16_t	ee_db2GHz[2];
414 	uint16_t	ee_numCtls;
415 	uint16_t	ee_ctl[NUM_CTLS_MAX];
416 	uint16_t	ee_iqCalI[2];
417 	uint16_t	ee_iqCalQ[2];
418 	uint16_t	ee_calPier11g[NUM_2_4_EEPROM_CHANNELS];
419 	uint16_t	ee_calPier11b[NUM_2_4_EEPROM_CHANNELS];
420 
421 	/* corner calibration information */
422 	CORNER_CAL_INFO	ee_cornerCal;
423 
424 	uint16_t	ee_opCap;
425 
426 	/* 11a info */
427 	uint16_t	ee_channels11a[NUM_11A_EEPROM_CHANNELS];
428 	uint16_t	ee_numChannels11a;
429 	DATA_PER_CHANNEL ee_dataPerChannel11a[NUM_11A_EEPROM_CHANNELS];
430 
431 	uint16_t	ee_numChannels2_4;
432 	uint16_t	ee_channels11g[NUM_2_4_EEPROM_CHANNELS];
433 	uint16_t	ee_channels11b[NUM_2_4_EEPROM_CHANNELS];
434 	uint16_t	ee_spurChans[AR_EEPROM_MODAL_SPURS][2];
435 
436 	/* 11g info */
437 	DATA_PER_CHANNEL ee_dataPerChannel11g[NUM_2_4_EEPROM_CHANNELS];
438 
439 	/* 11b info */
440 	DATA_PER_CHANNEL ee_dataPerChannel11b[NUM_2_4_EEPROM_CHANNELS];
441 
442 	TRGT_POWER_ALL_MODES ee_tpow;
443 
444 	RD_EDGES_POWER	ee_rdEdgesPower[NUM_EDGES*NUM_CTLS_MAX];
445 
446 	union {
447 		EEPROM_POWER_EXPN_5112  eu_modePowerArray5112[3];
448 		RAW_DATA_STRUCT_2413	eu_rawDataset2413[3];
449 	} ee_u;
450 } HAL_EEPROM;
451 
452 /* write-around defines */
453 #define	ee_numTargetPwr_11a	ee_tpow.numTargetPwr_11a
454 #define	ee_trgtPwr_11a		ee_tpow.trgtPwr_11a
455 #define	ee_numTargetPwr_11g	ee_tpow.numTargetPwr_11g
456 #define	ee_trgtPwr_11g		ee_tpow.trgtPwr_11g
457 #define	ee_numTargetPwr_11b	ee_tpow.numTargetPwr_11b
458 #define	ee_trgtPwr_11b		ee_tpow.trgtPwr_11b
459 #define	ee_modePowerArray5112	ee_u.eu_modePowerArray5112
460 #define	ee_rawDataset2413	ee_u.eu_rawDataset2413
461 #endif /* _ATH_AH_EEPROM_V3_H_ */
462