Full support for Ginger Console
[linux-ginger.git] / drivers / staging / otus / hal / hpusb.h
blob35a0c5668ceae7ea413ecb2d3842b8d4ed81476e
1 /*
2 * Copyright (c) 2000-2005 ZyDAS Technology Corporation
3 * Copyright (c) 2007-2008 Atheros Communications Inc.
5 * Permission to use, copy, modify, and/or distribute this software for any
6 * purpose with or without fee is hereby granted, provided that the above
7 * copyright notice and this permission notice appear in all copies.
9 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
10 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
11 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
12 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
13 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
14 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
15 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
17 /* Module Name : ud_defs.h */
18 /* */
19 /* Abstract */
20 /* This module contains USB data structure definitions. */
21 /* */
22 /* NOTES */
23 /* None */
24 /* */
25 /************************************************************************/
27 #ifndef _HPUSB_H
28 #define _HPUSB_H
30 #define ZM_OTUS_ENABLE_RETRY_FREQ_CHANGE
31 #define ZM_BEACON_BUFFER_ADDRESS 0x117900
33 #define ZM_MAX_CMD_SIZE 64
34 #define ZM_HAL_MAX_EEPROM_REQ 510
35 #define ZM_HAL_MAX_EEPROM_PRQ 2
37 /* For USB STREAM mode */
38 #ifdef ZM_DISABLE_AMSDU8K_SUPPORT
39 #define ZM_MAX_USB_IN_TRANSFER_SIZE 4096
40 #else
41 #define ZM_MAX_USB_IN_TRANSFER_SIZE 8192
42 #endif
43 #define ZM_USB_STREAM_MODE_TAG_LEN 4
44 #define ZM_USB_STREAM_MODE_TAG 0x4e00
45 #define ZM_USB_MAX_EPINT_BUFFER 64
47 struct zsCmdQ
49 u16_t src;
50 u16_t cmdLen;
51 u8_t* buf;
52 u32_t cmd[ZM_MAX_CMD_SIZE/4];
55 struct zsCommand
57 u16_t delayWcmdCount;
58 u32_t delayWcmdAddr[(ZM_CMD_QUEUE_SIZE-4)/4];
59 u32_t delayWcmdVal[(ZM_CMD_QUEUE_SIZE-4)/4];
62 struct zsHalRxInfo
64 u32_t currentRSSI[7]; /* RSSI combined */
65 u32_t currentRxEVM[14];
66 u32_t currentRxDataMT;
67 u32_t currentRxDataMCS;
68 u32_t currentRxDataBW;
69 u32_t currentRxDataSG;
72 struct zsHpPriv
74 u16_t hwFrequency;
75 u8_t hwBw40;
76 u8_t hwExtOffset;
78 u8_t disableDfsCh;
80 u32_t halCapability;
82 /* Fortunately the second loop can be disabled with a bit */
83 /* called en_pd_dc_offset_thr */
84 u8_t hwNotFirstInit;
86 /* command queue */
87 u16_t cmdHead;
88 u16_t cmdTail;
89 #ifdef ZM_XP_USB_MULTCMD
90 u16_t cmdSend; // Used for Mult send USB cmd
91 #endif
92 struct zsCmdQ cmdQ[ZM_CMD_QUEUE_SIZE];
93 u16_t cmdPending;
94 struct zsCommand cmd; /* buffer for delayed commands */
95 u8_t ledMode[2];
96 u32_t ctlBusy;
97 u32_t extBusy;
100 * ANI & Radar support.
102 u32_t procPhyErr; /* Process Phy errs */
103 u8_t hasHwPhyCounters; /* Hardware has phy counters */
104 u32_t aniPeriod; /* ani update list period */
105 struct zsAniStats stats; /* various statistics */
106 struct zsAniState *curani; /* cached last reference */
107 struct zsAniState ani[50]; /* per-channel state */
110 * Ani tables that change between the 5416 and 5312.
111 * These get set at attach time.
112 * XXX don't belong here
113 * XXX need better explanation
115 s32_t totalSizeDesired[5];
116 s32_t coarseHigh[5];
117 s32_t coarseLow[5];
118 s32_t firpwr[5];
121 * ANI related PHY register value.
123 u32_t regPHYDesiredSZ;
124 u32_t regPHYFindSig;
125 u32_t regPHYAgcCtl1;
126 u32_t regPHYSfcorr;
127 u32_t regPHYSfcorrLow;
128 u32_t regPHYTiming5;
129 u32_t regPHYCckDetect;
131 u32_t eepromImage[1024];
132 u32_t eepromImageIndex;
133 u32_t eepromImageRdReq;
135 u8_t halReInit;
137 u8_t OpFlags;
139 u8_t tPow2xCck[4];
140 u8_t tPow2x2g[4];
141 u8_t tPow2x2g24HeavyClipOffset;
142 u8_t tPow2x2gHt20[8];
143 u8_t tPow2x2gHt40[8];
144 u8_t tPow2x5g[4];
145 u8_t tPow2x5gHt20[8];
146 u8_t tPow2x5gHt40[8];
148 /* hwBBHeavyClip : used compatibility */
149 /* 0 : dongle not support. */
150 /* !0: support heavy clip. */
151 u8_t hwBBHeavyClip;
152 u8_t enableBBHeavyClip; /* 0=>force disable 1=>enable */
153 u8_t doBBHeavyClip; /* set 1 if heavy clip need by each frequency switch */
154 u32_t setValueHeavyClip; /* save setting value for heavy clip when completed routine */
157 * Rxdata RSSI, EVM, Rate etc...
159 struct zsHalRxInfo halRxInfo;
161 u32_t usbSendBytes;
162 u32_t usbAcSendBytes[4];
164 u16_t aggMaxDurationBE;
165 u32_t aggPktNum;
167 u16_t txop[4];
168 u16_t cwmin[4];
169 u16_t cwmax[4];
170 u8_t strongRSSI;
171 u8_t rxStrongRSSI;
173 u8_t slotType; //0->20us, 1=>9us
175 #ifdef ZM_OTUS_RX_STREAM_MODE
176 u16_t usbRxRemainLen;
177 u16_t usbRxPktLen;
178 u16_t usbRxPadLen;
179 u16_t usbRxTransferLen;
180 zbuf_t *remainBuf;
181 #endif
183 u8_t dot11Mode;
185 u8_t ibssBcnEnabled;
186 u32_t ibssBcnInterval;
188 // For re-issue the frequency change command
189 u32_t latestFrequency;
190 u8_t latestBw40;
191 u8_t latestExtOffset;
192 u8_t freqRetryCounter;
194 u8_t recordFreqRetryCounter;
195 u8_t isSiteSurvey;
196 u8_t coldResetNeedFreq;
198 u64_t camRollCallTable;
199 u8_t currentAckRtsTpc;
201 /* #1 Save the initial value of the related RIFS register settings */
202 //u32_t isInitialPhy;
203 u32_t initDesiredSigSize;
204 u32_t initAGC;
205 u32_t initAgcControl;
206 u32_t initSearchStartDelay;
207 u32_t initRIFSSearchParams;
208 u32_t initFastChannelChangeControl;
210 /* Dynamic SIFS for retransmission event */
211 u8_t retransmissionEvent;
212 u8_t latestSIFS;
215 extern u32_t zfHpLoadEEPROMFromFW(zdev_t* dev);
218 typedef u8_t A_UINT8;
219 typedef s8_t A_INT8;
220 typedef u16_t A_UINT16;
221 typedef u32_t A_UINT32;
222 #define __ATTRIB_PACK
224 #pragma pack (push, 1)
226 #define AR5416_EEP_VER 0xE
227 #define AR5416_EEP_VER_MINOR_MASK 0xFFF
228 #define AR5416_EEP_NO_BACK_VER 0x1
229 #define AR5416_EEP_MINOR_VER_2 0x2 // Adds modal params txFrameToPaOn, txFrametoDataStart, ht40PowerInc
230 #define AR5416_EEP_MINOR_VER_3 0x3 // Adds modal params bswAtten, bswMargin, swSettle and base OpFlags for HT20/40 Disable
232 // 16-bit offset location start of calibration struct
233 #define AR5416_EEP_START_LOC 256
234 #define AR5416_NUM_5G_CAL_PIERS 8
235 #define AR5416_NUM_2G_CAL_PIERS 4
236 #define AR5416_NUM_5G_20_TARGET_POWERS 8
237 #define AR5416_NUM_5G_40_TARGET_POWERS 8
238 #define AR5416_NUM_2G_CCK_TARGET_POWERS 3
239 #define AR5416_NUM_2G_20_TARGET_POWERS 4
240 #define AR5416_NUM_2G_40_TARGET_POWERS 4
241 #define AR5416_NUM_CTLS 24
242 #define AR5416_NUM_BAND_EDGES 8
243 #define AR5416_NUM_PD_GAINS 4
244 #define AR5416_PD_GAINS_IN_MASK 4
245 #define AR5416_PD_GAIN_ICEPTS 5
246 #define AR5416_EEPROM_MODAL_SPURS 5
247 #define AR5416_MAX_RATE_POWER 63
248 #define AR5416_NUM_PDADC_VALUES 128
249 #define AR5416_NUM_RATES 16
250 #define AR5416_BCHAN_UNUSED 0xFF
251 #define AR5416_MAX_PWR_RANGE_IN_HALF_DB 64
252 #define AR5416_OPFLAGS_11A 0x01
253 #define AR5416_OPFLAGS_11G 0x02
254 #define AR5416_OPFLAGS_5G_HT40 0x04
255 #define AR5416_OPFLAGS_2G_HT40 0x08
256 #define AR5416_OPFLAGS_5G_HT20 0x10
257 #define AR5416_OPFLAGS_2G_HT20 0x20
258 #define AR5416_EEPMISC_BIG_ENDIAN 0x01
259 #define FREQ2FBIN(x,y) ((y) ? ((x) - 2300) : (((x) - 4800) / 5))
260 #define AR5416_MAX_CHAINS 2
261 #define AR5416_ANT_16S 25
263 #define AR5416_NUM_ANT_CHAIN_FIELDS 7
264 #define AR5416_NUM_ANT_COMMON_FIELDS 4
265 #define AR5416_SIZE_ANT_CHAIN_FIELD 3
266 #define AR5416_SIZE_ANT_COMMON_FIELD 4
267 #define AR5416_ANT_CHAIN_MASK 0x7
268 #define AR5416_ANT_COMMON_MASK 0xf
269 #define AR5416_CHAIN_0_IDX 0
270 #define AR5416_CHAIN_1_IDX 1
271 #define AR5416_CHAIN_2_IDX 2
274 /* Capabilities Enum */
275 typedef enum {
276 EEPCAP_COMPRESS_DIS = 0x0001,
277 EEPCAP_AES_DIS = 0x0002,
278 EEPCAP_FASTFRAME_DIS = 0x0004,
279 EEPCAP_BURST_DIS = 0x0008,
280 EEPCAP_MAXQCU_M = 0x01F0,
281 EEPCAP_MAXQCU_S = 4,
282 EEPCAP_HEAVY_CLIP_EN = 0x0200,
283 EEPCAP_KC_ENTRIES_M = 0xF000,
284 EEPCAP_KC_ENTRIES_S = 12,
285 } EEPROM_CAPABILITIES;
287 typedef enum Ar5416_Rates {
288 rate6mb, rate9mb, rate12mb, rate18mb,
289 rate24mb, rate36mb, rate48mb, rate54mb,
290 rate1l, rate2l, rate2s, rate5_5l,
291 rate5_5s, rate11l, rate11s, rateXr,
292 rateHt20_0, rateHt20_1, rateHt20_2, rateHt20_3,
293 rateHt20_4, rateHt20_5, rateHt20_6, rateHt20_7,
294 rateHt40_0, rateHt40_1, rateHt40_2, rateHt40_3,
295 rateHt40_4, rateHt40_5, rateHt40_6, rateHt40_7,
296 rateDupCck, rateDupOfdm, rateExtCck, rateExtOfdm,
297 Ar5416RateSize
298 } AR5416_RATES;
300 typedef struct eepFlags {
301 A_UINT8 opFlags;
302 A_UINT8 eepMisc;
303 } __ATTRIB_PACK EEP_FLAGS;
305 #define AR5416_CHECKSUM_LOCATION (AR5416_EEP_START_LOC + 1)
306 typedef struct BaseEepHeader {
307 A_UINT16 length;
308 A_UINT16 checksum;
309 A_UINT16 version;
310 EEP_FLAGS opCapFlags;
311 A_UINT16 regDmn[2];
312 A_UINT8 macAddr[6];
313 A_UINT8 rxMask;
314 A_UINT8 txMask;
315 A_UINT16 rfSilent;
316 A_UINT16 blueToothOptions;
317 A_UINT16 deviceCap;
318 A_UINT32 binBuildNumber;
319 A_UINT8 deviceType;
320 A_UINT8 futureBase[33];
321 } __ATTRIB_PACK BASE_EEP_HEADER; // 64 B
323 typedef struct spurChanStruct {
324 A_UINT16 spurChan;
325 A_UINT8 spurRangeLow;
326 A_UINT8 spurRangeHigh;
327 } __ATTRIB_PACK SPUR_CHAN;
329 typedef struct ModalEepHeader {
330 A_UINT32 antCtrlChain[AR5416_MAX_CHAINS]; // 12
331 A_UINT32 antCtrlCommon; // 4
332 A_INT8 antennaGainCh[AR5416_MAX_CHAINS]; // 3
333 A_UINT8 switchSettling; // 1
334 A_UINT8 txRxAttenCh[AR5416_MAX_CHAINS]; // 3
335 A_UINT8 rxTxMarginCh[AR5416_MAX_CHAINS]; // 3
336 A_INT8 adcDesiredSize; // 1
337 A_INT8 pgaDesiredSize; // 1
338 A_UINT8 xlnaGainCh[AR5416_MAX_CHAINS]; // 3
339 A_UINT8 txEndToXpaOff; // 1
340 A_UINT8 txEndToRxOn; // 1
341 A_UINT8 txFrameToXpaOn; // 1
342 A_UINT8 thresh62; // 1
343 A_INT8 noiseFloorThreshCh[AR5416_MAX_CHAINS]; // 3
344 A_UINT8 xpdGain; // 1
345 A_UINT8 xpd; // 1
346 A_INT8 iqCalICh[AR5416_MAX_CHAINS]; // 1
347 A_INT8 iqCalQCh[AR5416_MAX_CHAINS]; // 1
348 A_UINT8 pdGainOverlap; // 1
349 A_UINT8 ob; // 1
350 A_UINT8 db; // 1
351 A_UINT8 xpaBiasLvl; // 1
352 A_UINT8 pwrDecreaseFor2Chain; // 1
353 A_UINT8 pwrDecreaseFor3Chain; // 1 -> 48 B
354 A_UINT8 txFrameToDataStart; // 1
355 A_UINT8 txFrameToPaOn; // 1
356 A_UINT8 ht40PowerIncForPdadc; // 1
357 A_UINT8 bswAtten[AR5416_MAX_CHAINS]; // 3
358 A_UINT8 bswMargin[AR5416_MAX_CHAINS]; // 3
359 A_UINT8 swSettleHt40; // 1
360 A_UINT8 futureModal[22]; //
361 SPUR_CHAN spurChans[AR5416_EEPROM_MODAL_SPURS]; // 20 B
362 } __ATTRIB_PACK MODAL_EEP_HEADER; // == 100 B
364 typedef struct calDataPerFreq {
365 A_UINT8 pwrPdg[AR5416_NUM_PD_GAINS][AR5416_PD_GAIN_ICEPTS];
366 A_UINT8 vpdPdg[AR5416_NUM_PD_GAINS][AR5416_PD_GAIN_ICEPTS];
367 } __ATTRIB_PACK CAL_DATA_PER_FREQ;
369 typedef struct CalTargetPowerLegacy {
370 A_UINT8 bChannel;
371 A_UINT8 tPow2x[4];
372 } __ATTRIB_PACK CAL_TARGET_POWER_LEG;
374 typedef struct CalTargetPowerHt {
375 A_UINT8 bChannel;
376 A_UINT8 tPow2x[8];
377 } __ATTRIB_PACK CAL_TARGET_POWER_HT;
379 #if defined(ARCH_BIG_ENDIAN) || defined(BIG_ENDIAN)
380 typedef struct CalCtlEdges {
381 A_UINT8 bChannel;
382 A_UINT8 flag :2,
383 tPower :6;
384 } __ATTRIB_PACK CAL_CTL_EDGES;
385 #else
386 typedef struct CalCtlEdges {
387 A_UINT8 bChannel;
388 A_UINT8 tPower :6,
389 flag :2;
390 } __ATTRIB_PACK CAL_CTL_EDGES;
391 #endif
393 typedef struct CalCtlData {
394 CAL_CTL_EDGES ctlEdges[AR5416_MAX_CHAINS][AR5416_NUM_BAND_EDGES];
395 } __ATTRIB_PACK CAL_CTL_DATA;
397 typedef struct ar5416Eeprom {
398 BASE_EEP_HEADER baseEepHeader; // 64 B
399 A_UINT8 custData[64]; // 64 B
400 MODAL_EEP_HEADER modalHeader[2]; // 200 B
401 A_UINT8 calFreqPier5G[AR5416_NUM_5G_CAL_PIERS];
402 A_UINT8 calFreqPier2G[AR5416_NUM_2G_CAL_PIERS];
403 CAL_DATA_PER_FREQ calPierData5G[AR5416_MAX_CHAINS][AR5416_NUM_5G_CAL_PIERS];
404 CAL_DATA_PER_FREQ calPierData2G[AR5416_MAX_CHAINS][AR5416_NUM_2G_CAL_PIERS];
405 CAL_TARGET_POWER_LEG calTargetPower5G[AR5416_NUM_5G_20_TARGET_POWERS];
406 CAL_TARGET_POWER_HT calTargetPower5GHT20[AR5416_NUM_5G_20_TARGET_POWERS];
407 CAL_TARGET_POWER_HT calTargetPower5GHT40[AR5416_NUM_5G_40_TARGET_POWERS];
408 CAL_TARGET_POWER_LEG calTargetPowerCck[AR5416_NUM_2G_CCK_TARGET_POWERS];
409 CAL_TARGET_POWER_LEG calTargetPower2G[AR5416_NUM_2G_20_TARGET_POWERS];
410 CAL_TARGET_POWER_HT calTargetPower2GHT20[AR5416_NUM_2G_20_TARGET_POWERS];
411 CAL_TARGET_POWER_HT calTargetPower2GHT40[AR5416_NUM_2G_40_TARGET_POWERS];
412 A_UINT8 ctlIndex[AR5416_NUM_CTLS];
413 CAL_CTL_DATA ctlData[AR5416_NUM_CTLS];
414 A_UINT8 padding;
415 } __ATTRIB_PACK AR5416_EEPROM;
417 #pragma pack (pop)
419 typedef enum ConformanceTestLimits {
420 FCC = 0x10,
421 MKK = 0x40,
422 ETSI = 0x30,
423 SD_NO_CTL = 0xE0,
424 NO_CTL = 0xFF,
425 CTL_MODE_M = 0xF,
426 CTL_11A = 0,
427 CTL_11B = 1,
428 CTL_11G = 2,
429 CTL_TURBO = 3,
430 CTL_108G = 4,
431 CTL_2GHT20 = 5,
432 CTL_5GHT20 = 6,
433 CTL_2GHT40 = 7,
434 CTL_5GHT40 = 8,
435 } ATH_CTLS;
437 #endif /* #ifndef _HPUSB_H */