blob: 29e3b53e52a1be04c06797344ed95ff810d23e40 [file] [log] [blame]
Greg Kroah-Hartmanc55519f2008-12-17 17:04:23 -08001/*
2 *************************************************************************
3 * Ralink Tech Inc.
4 * 5F., No.36, Taiyuan St., Jhubei City,
5 * Hsinchu County 302,
6 * Taiwan, R.O.C.
7 *
8 * (c) Copyright 2002-2007, Ralink Technology, Inc.
9 *
10 * This program is free software; you can redistribute it and/or modify *
11 * it under the terms of the GNU General Public License as published by *
12 * the Free Software Foundation; either version 2 of the License, or *
13 * (at your option) any later version. *
14 * *
15 * This program is distributed in the hope that it will be useful, *
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
18 * GNU General Public License for more details. *
19 * *
20 * You should have received a copy of the GNU General Public License *
21 * along with this program; if not, write to the *
22 * Free Software Foundation, Inc., *
23 * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
24 * *
25 *************************************************************************
26 */
27
28#ifndef __RT2870_H__
29#define __RT2870_H__
30
31//usb header files
32#include <linux/usb.h>
33
34/* rtmp_def.h */
35//
Greg Kroah-Hartmanc55519f2008-12-17 17:04:23 -080036#define BULKAGGRE_ZISE 100
37#define RT28XX_DRVDATA_SET(_a) usb_set_intfdata(_a, pAd);
38#define RT28XX_PUT_DEVICE usb_put_dev
39#define RTUSB_ALLOC_URB(iso) usb_alloc_urb(iso, GFP_ATOMIC)
40#define RTUSB_SUBMIT_URB(pUrb) usb_submit_urb(pUrb, GFP_ATOMIC)
41#define RTUSB_URB_ALLOC_BUFFER(pUsb_Dev, BufSize, pDma_addr) usb_buffer_alloc(pUsb_Dev, BufSize, GFP_ATOMIC, pDma_addr)
42#define RTUSB_URB_FREE_BUFFER(pUsb_Dev, BufSize, pTransferBuf, Dma_addr) usb_buffer_free(pUsb_Dev, BufSize, pTransferBuf, Dma_addr)
Greg Kroah-Hartmanc55519f2008-12-17 17:04:23 -080043
44#define RXBULKAGGRE_ZISE 12
45#define MAX_TXBULK_LIMIT (LOCAL_TXBUF_SIZE*(BULKAGGRE_ZISE-1))
46#define MAX_TXBULK_SIZE (LOCAL_TXBUF_SIZE*BULKAGGRE_ZISE)
47#define MAX_RXBULK_SIZE (LOCAL_TXBUF_SIZE*RXBULKAGGRE_ZISE)
48#define MAX_MLME_HANDLER_MEMORY 20
Bartlomiej Zolnierkiewiczd1e4861a2009-04-26 16:06:18 +020049#ifndef RT30xx
Greg Kroah-Hartmanc55519f2008-12-17 17:04:23 -080050#define RETRY_LIMIT 10
Bartlomiej Zolnierkiewiczd1e4861a2009-04-26 16:06:18 +020051#endif
Greg Kroah-Hartmanc55519f2008-12-17 17:04:23 -080052#define BUFFER_SIZE 2400 //2048
53#define TX_RING 0xa
54#define PRIO_RING 0xc
55
56
57// Flags for Bulkflags control for bulk out data
58//
59#define fRTUSB_BULK_OUT_DATA_NULL 0x00000001
60#define fRTUSB_BULK_OUT_RTS 0x00000002
61#define fRTUSB_BULK_OUT_MLME 0x00000004
62
63#define fRTUSB_BULK_OUT_DATA_NORMAL 0x00010000
64#define fRTUSB_BULK_OUT_DATA_NORMAL_2 0x00020000
65#define fRTUSB_BULK_OUT_DATA_NORMAL_3 0x00040000
66#define fRTUSB_BULK_OUT_DATA_NORMAL_4 0x00080000
Bartlomiej Zolnierkiewiczd1e4861a2009-04-26 16:06:18 +020067#ifdef RT30xx
68#define fRTUSB_BULK_OUT_DATA_NORMAL_5 0x00100000
69#endif
Greg Kroah-Hartmanc55519f2008-12-17 17:04:23 -080070
71#define fRTUSB_BULK_OUT_PSPOLL 0x00000020
72#define fRTUSB_BULK_OUT_DATA_FRAG 0x00000040
73#define fRTUSB_BULK_OUT_DATA_FRAG_2 0x00000080
74#define fRTUSB_BULK_OUT_DATA_FRAG_3 0x00000100
75#define fRTUSB_BULK_OUT_DATA_FRAG_4 0x00000200
76
Bartlomiej Zolnierkiewiczd1e4861a2009-04-26 16:06:18 +020077#ifndef RT30xx
Greg Kroah-Hartmanc55519f2008-12-17 17:04:23 -080078#define RT2870_USB_DEVICES \
79{ \
80 {USB_DEVICE(0x148F,0x2770)}, /* Ralink */ \
Josef Jirua955dc32009-03-11 15:50:48 +010081 {USB_DEVICE(0x1737,0x0071)}, /* Linksys WUSB600N */ \
Greg Kroah-Hartmanc55519f2008-12-17 17:04:23 -080082 {USB_DEVICE(0x148F,0x2870)}, /* Ralink */ \
83 {USB_DEVICE(0x148F,0x3070)}, /* Ralink */ \
84 {USB_DEVICE(0x0B05,0x1731)}, /* Asus */ \
85 {USB_DEVICE(0x0B05,0x1732)}, /* Asus */ \
86 {USB_DEVICE(0x0B05,0x1742)}, /* Asus */ \
87 {USB_DEVICE(0x0DF6,0x0017)}, /* Sitecom */ \
88 {USB_DEVICE(0x0DF6,0x002B)}, /* Sitecom */ \
89 {USB_DEVICE(0x0DF6,0x002C)}, /* Sitecom */ \
90 {USB_DEVICE(0x0DF6,0x002D)}, /* Sitecom */ \
Daniele Napolitano7cf94022009-04-01 14:53:39 -070091 {USB_DEVICE(0x0DF6,0x0039)}, /* Sitecom */ \
Jorrit Schippers8dfb0052009-06-10 15:34:26 +020092 {USB_DEVICE(0x0DF6,0x003F)}, /* Sitecom WL-608 */ \
Greg Kroah-Hartmanc55519f2008-12-17 17:04:23 -080093 {USB_DEVICE(0x14B2,0x3C06)}, /* Conceptronic */ \
94 {USB_DEVICE(0x14B2,0x3C28)}, /* Conceptronic */ \
95 {USB_DEVICE(0x2019,0xED06)}, /* Planex Communications, Inc. */ \
96 {USB_DEVICE(0x2019,0xAB25)}, /* Planex Communications, Inc. RT3070 */ \
97 {USB_DEVICE(0x07D1,0x3C09)}, /* D-Link */ \
98 {USB_DEVICE(0x07D1,0x3C11)}, /* D-Link */ \
99 {USB_DEVICE(0x14B2,0x3C07)}, /* AL */ \
100 {USB_DEVICE(0x14B2,0x3C12)}, /* AL */ \
101 {USB_DEVICE(0x050D,0x8053)}, /* Belkin */ \
102 {USB_DEVICE(0x14B2,0x3C23)}, /* Airlink */ \
103 {USB_DEVICE(0x14B2,0x3C27)}, /* Airlink */ \
104 {USB_DEVICE(0x07AA,0x002F)}, /* Corega */ \
105 {USB_DEVICE(0x07AA,0x003C)}, /* Corega */ \
106 {USB_DEVICE(0x07AA,0x003F)}, /* Corega */ \
107 {USB_DEVICE(0x18C5,0x0012)}, /* Corega */ \
108 {USB_DEVICE(0x1044,0x800B)}, /* Gigabyte */ \
109 {USB_DEVICE(0x15A9,0x0006)}, /* Sparklan */ \
110 {USB_DEVICE(0x083A,0xB522)}, /* SMC */ \
111 {USB_DEVICE(0x083A,0xA618)}, /* SMC */ \
112 {USB_DEVICE(0x083A,0x7522)}, /* Arcadyan */ \
113 {USB_DEVICE(0x0CDE,0x0022)}, /* ZCOM */ \
114 {USB_DEVICE(0x0586,0x3416)}, /* Zyxel */ \
115 {USB_DEVICE(0x0CDE,0x0025)}, /* Zyxel */ \
116 {USB_DEVICE(0x1740,0x9701)}, /* EnGenius */ \
117 {USB_DEVICE(0x1740,0x9702)}, /* EnGenius */ \
118 {USB_DEVICE(0x0471,0x200f)}, /* Philips */ \
119 {USB_DEVICE(0x14B2,0x3C25)}, /* Draytek */ \
120 {USB_DEVICE(0x13D3,0x3247)}, /* AzureWave */ \
121 {USB_DEVICE(0x083A,0x6618)}, /* Accton */ \
122 {USB_DEVICE(0x15c5,0x0008)}, /* Amit */ \
123 {USB_DEVICE(0x0E66,0x0001)}, /* Hawking */ \
124 {USB_DEVICE(0x0E66,0x0003)}, /* Hawking */ \
125 {USB_DEVICE(0x129B,0x1828)}, /* Siemens */ \
126 {USB_DEVICE(0x157E,0x300E)}, /* U-Media */ \
127 {USB_DEVICE(0x050d,0x805c)}, \
128 {USB_DEVICE(0x1482,0x3C09)}, /* Abocom*/ \
129 {USB_DEVICE(0x14B2,0x3C09)}, /* Alpha */ \
130 {USB_DEVICE(0x04E8,0x2018)}, /* samsung */ \
131 {USB_DEVICE(0x07B8,0x3070)}, /* AboCom */ \
132 {USB_DEVICE(0x07B8,0x3071)}, /* AboCom */ \
133 {USB_DEVICE(0x07B8,0x2870)}, /* AboCom */ \
134 {USB_DEVICE(0x07B8,0x2770)}, /* AboCom */ \
135 {USB_DEVICE(0x7392,0x7711)}, /* Edimax */ \
136 {USB_DEVICE(0x5A57,0x0280)}, /* Zinwell */ \
137 {USB_DEVICE(0x5A57,0x0282)}, /* Zinwell */ \
138 {USB_DEVICE(0x0789,0x0162)}, /* Logitec */ \
139 {USB_DEVICE(0x0789,0x0163)}, /* Logitec */ \
140 {USB_DEVICE(0x0789,0x0164)}, /* Logitec */ \
Dave Hayesa9ed12e2009-04-18 02:18:37 -0500141 {USB_DEVICE(0x7392,0x7717)}, /* Edimax */ \
Greg Kroah-Hartmanc55519f2008-12-17 17:04:23 -0800142 { }/* Terminating entry */ \
143}
Bartlomiej Zolnierkiewiczd1e4861a2009-04-26 16:06:18 +0200144#endif
145#ifdef RT30xx
146#define RT2870_USB_DEVICES \
147{ \
148 {USB_DEVICE(0x148F,0x2770)}, /* Ralink */ \
149 {USB_DEVICE(0x148F,0x2870)}, /* Ralink */ \
150 {USB_DEVICE(0x148F,0x3070)}, /* Ralink 3070 */ \
151 {USB_DEVICE(0x148F,0x3071)}, /* Ralink 3071 */ \
152 {USB_DEVICE(0x148F,0x3072)}, /* Ralink 3072 */ \
153 {USB_DEVICE(0x0B05,0x1731)}, /* Asus */ \
154 {USB_DEVICE(0x0B05,0x1732)}, /* Asus */ \
155 {USB_DEVICE(0x0B05,0x1742)}, /* Asus */ \
156 {USB_DEVICE(0x0DF6,0x0017)}, /* Sitecom */ \
157 {USB_DEVICE(0x0DF6,0x002B)}, /* Sitecom */ \
158 {USB_DEVICE(0x0DF6,0x002C)}, /* Sitecom */ \
159 {USB_DEVICE(0x0DF6,0x003E)}, /* Sitecom 3070 */ \
160 {USB_DEVICE(0x0DF6,0x002D)}, /* Sitecom */ \
161 {USB_DEVICE(0x0DF6,0x0039)}, /* Sitecom 2770 */ \
162 {USB_DEVICE(0x14B2,0x3C06)}, /* Conceptronic */ \
163 {USB_DEVICE(0x14B2,0x3C28)}, /* Conceptronic */ \
164 {USB_DEVICE(0x2019,0xED06)}, /* Planex Communications, Inc. */ \
165 {USB_DEVICE(0x2019,0xAB25)}, /* Planex Communications, Inc. RT3070 */ \
166 {USB_DEVICE(0x07D1,0x3C09)}, /* D-Link */ \
167 {USB_DEVICE(0x07D1,0x3C11)}, /* D-Link */ \
168 {USB_DEVICE(0x2001,0x3C09)}, /* D-Link */ \
169 {USB_DEVICE(0x2001,0x3C0A)}, /* D-Link 3072*/ \
170 {USB_DEVICE(0x14B2,0x3C07)}, /* AL */ \
171 {USB_DEVICE(0x14B2,0x3C12)}, /* AL 3070 */ \
172 {USB_DEVICE(0x050D,0x8053)}, /* Belkin */ \
173 {USB_DEVICE(0x14B2,0x3C23)}, /* Airlink */ \
174 {USB_DEVICE(0x14B2,0x3C27)}, /* Airlink */ \
175 {USB_DEVICE(0x07AA,0x002F)}, /* Corega */ \
176 {USB_DEVICE(0x07AA,0x003C)}, /* Corega */ \
177 {USB_DEVICE(0x07AA,0x003F)}, /* Corega */ \
178 {USB_DEVICE(0x18C5,0x0012)}, /* Corega 3070 */ \
179 {USB_DEVICE(0x1044,0x800B)}, /* Gigabyte */ \
180 {USB_DEVICE(0x1044,0x800D)}, /* Gigabyte GN-WB32L 3070 */ \
181 {USB_DEVICE(0x15A9,0x0006)}, /* Sparklan */ \
182 {USB_DEVICE(0x083A,0xB522)}, /* SMC */ \
183 {USB_DEVICE(0x083A,0xA618)}, /* SMC */ \
184 {USB_DEVICE(0x083A,0x8522)}, /* Arcadyan */ \
185 {USB_DEVICE(0x083A,0x7512)}, /* Arcadyan 2770 */ \
186 {USB_DEVICE(0x083A,0x7522)}, /* Arcadyan */ \
187 {USB_DEVICE(0x083A,0x7511)}, /* Arcadyan 3070 */ \
188 {USB_DEVICE(0x0CDE,0x0022)}, /* ZCOM */ \
189 {USB_DEVICE(0x0586,0x3416)}, /* Zyxel */ \
190 {USB_DEVICE(0x0CDE,0x0025)}, /* Zyxel */ \
191 {USB_DEVICE(0x1740,0x9701)}, /* EnGenius */ \
192 {USB_DEVICE(0x1740,0x9702)}, /* EnGenius */ \
193 {USB_DEVICE(0x1740,0x9703)}, /* EnGenius 3070 */ \
194 {USB_DEVICE(0x0471,0x200f)}, /* Philips */ \
195 {USB_DEVICE(0x14B2,0x3C25)}, /* Draytek */ \
196 {USB_DEVICE(0x13D3,0x3247)}, /* AzureWave */ \
197 {USB_DEVICE(0x13D3,0x3273)}, /* AzureWave 3070*/ \
198 {USB_DEVICE(0x083A,0x6618)}, /* Accton */ \
199 {USB_DEVICE(0x15c5,0x0008)}, /* Amit */ \
200 {USB_DEVICE(0x0E66,0x0001)}, /* Hawking */ \
201 {USB_DEVICE(0x0E66,0x0003)}, /* Hawking */ \
202 {USB_DEVICE(0x129B,0x1828)}, /* Siemens */ \
203 {USB_DEVICE(0x157E,0x300E)}, /* U-Media */ \
204 {USB_DEVICE(0x050d,0x805c)}, \
205 {USB_DEVICE(0x1482,0x3C09)}, /* Abocom*/ \
206 {USB_DEVICE(0x14B2,0x3C09)}, /* Alpha */ \
207 {USB_DEVICE(0x04E8,0x2018)}, /* samsung */ \
208 {USB_DEVICE(0x07B8,0x3070)}, /* AboCom 3070 */ \
209 {USB_DEVICE(0x07B8,0x3071)}, /* AboCom 3071 */ \
210 {USB_DEVICE(0x07B8,0x3072)}, /* Abocom 3072 */ \
211 {USB_DEVICE(0x7392,0x7711)}, /* Edimax 3070 */ \
212 {USB_DEVICE(0x5A57,0x0280)}, /* Zinwell */ \
213 {USB_DEVICE(0x5A57,0x0282)}, /* Zinwell */ \
214 {USB_DEVICE(0x1A32,0x0304)}, /* Quanta 3070 */ \
215 {USB_DEVICE(0x0789,0x0162)}, /* Logitec 2870 */ \
216 {USB_DEVICE(0x0789,0x0163)}, /* Logitec 2870 */ \
217 {USB_DEVICE(0x0789,0x0164)}, /* Logitec 2870 */ \
218 {USB_DEVICE(0x1EDA,0x2310)}, /* AirTies 3070 */ \
219 { }/* Terminating entry */ \
220}
221#endif
Greg Kroah-Hartmanc55519f2008-12-17 17:04:23 -0800222
223#define FREE_HTTX_RING(_p, _b, _t) \
224{ \
225 if ((_t)->ENextBulkOutPosition == (_t)->CurWritePosition) \
226 { \
227 (_t)->bRingEmpty = TRUE; \
228 } \
229 /*NdisInterlockedDecrement(&(_p)->TxCount); */\
230}
231
232//
233// RXINFO appends at the end of each rx packet.
234//
Greg Kroah-Hartmanc55519f2008-12-17 17:04:23 -0800235typedef struct PACKED _RXINFO_STRUC {
236 UINT32 BA:1;
237 UINT32 DATA:1;
238 UINT32 NULLDATA:1;
239 UINT32 FRAG:1;
240 UINT32 U2M:1; // 1: this RX frame is unicast to me
241 UINT32 Mcast:1; // 1: this is a multicast frame
242 UINT32 Bcast:1; // 1: this is a broadcast frame
243 UINT32 MyBss:1; // 1: this frame belongs to the same BSSID
244 UINT32 Crc:1; // 1: CRC error
245 UINT32 CipherErr:2; // 0: decryption okay, 1:ICV error, 2:MIC error, 3:KEY not valid
246 UINT32 AMSDU:1; // rx with 802.3 header, not 802.11 header.
247 UINT32 HTC:1;
248 UINT32 RSSI:1;
249 UINT32 L2PAD:1;
250 UINT32 AMPDU:1; // To be moved
251 UINT32 Decrypted:1;
252 UINT32 PlcpRssil:1;
253 UINT32 CipherAlg:1;
254 UINT32 LastAMSDU:1;
255 UINT32 PlcpSignal:12;
256} RXINFO_STRUC, *PRXINFO_STRUC, RT28XX_RXD_STRUC, *PRT28XX_RXD_STRUC;
Greg Kroah-Hartmanc55519f2008-12-17 17:04:23 -0800257
258//
259// TXINFO
260//
Greg Kroah-Hartmanc55519f2008-12-17 17:04:23 -0800261typedef struct _TXINFO_STRUC {
262 // Word 0
263 UINT32 USBDMATxPktLen:16; //used ONLY in USB bulk Aggregation, Total byte counts of all sub-frame.
264 UINT32 rsv:8;
265 UINT32 WIV:1; // Wireless Info Valid. 1 if Driver already fill WI, o if DMA needs to copy WI to correctposition
266 UINT32 QSEL:2; // select on-chip FIFO ID for 2nd-stage output scheduler.0:MGMT, 1:HCCA 2:EDCA
267 UINT32 SwUseLastRound:1; // Software use.
268 UINT32 rsv2:2; // Software use.
269 UINT32 USBDMANextVLD:1; //used ONLY in USB bulk Aggregation, NextValid
270 UINT32 USBDMATxburst:1;//used ONLY in USB bulk Aggre. Force USB DMA transmit frame from current selected endpoint
271} TXINFO_STRUC, *PTXINFO_STRUC;
Greg Kroah-Hartmanc55519f2008-12-17 17:04:23 -0800272
273#define TXINFO_SIZE 4
274#define RXINFO_SIZE 4
275#define TXPADDING_SIZE 11
276
277//
278// Management ring buffer format
279//
280typedef struct _MGMT_STRUC {
281 BOOLEAN Valid;
282 PUCHAR pBuffer;
283 ULONG Length;
284} MGMT_STRUC, *PMGMT_STRUC;
285
286
287/* ----------------- EEPROM Related MACRO ----------------- */
Bartlomiej Zolnierkiewiczd1e4861a2009-04-26 16:06:18 +0200288#ifdef RT30xx
289#define RT28xx_EEPROM_READ16(pAd, offset, var) \
290 do { \
291 RTUSBReadEEPROM(pAd, offset, (PUCHAR)&(var), 2); \
292 if(!pAd->bUseEfuse) \
293 var = le2cpu16(var); \
294 }while(0)
295
296#define RT28xx_EEPROM_WRITE16(pAd, offset, var) \
297 do{ \
298 USHORT _tmpVar=var; \
299 if(!pAd->bUseEfuse) \
300 _tmpVar = cpu2le16(var); \
301 RTUSBWriteEEPROM(pAd, offset, (PUCHAR)&(_tmpVar), 2); \
302 }while(0)
303#endif // RT30xx //
304#ifndef RT30xx
Greg Kroah-Hartmanc55519f2008-12-17 17:04:23 -0800305#define RT28xx_EEPROM_READ16(pAd, offset, var) \
306 do { \
307 RTUSBReadEEPROM(pAd, offset, (PUCHAR)&(var), 2); \
308 var = le2cpu16(var); \
309 }while(0)
310
311#define RT28xx_EEPROM_WRITE16(pAd, offset, var) \
312 do{ \
313 USHORT _tmpVar; \
314 _tmpVar = cpu2le16(var); \
315 RTUSBWriteEEPROM(pAd, offset, (PUCHAR)&(_tmpVar), 2); \
316 }while(0)
Bartlomiej Zolnierkiewiczd1e4861a2009-04-26 16:06:18 +0200317#endif // RT30xx //
Greg Kroah-Hartmanc55519f2008-12-17 17:04:23 -0800318
319/* ----------------- TASK/THREAD Related MACRO ----------------- */
320#define RT28XX_TASK_THREAD_INIT(pAd, Status) \
321 Status = CreateThreads(net_dev);
322
323
324/* ----------------- Frimware Related MACRO ----------------- */
Greg Kroah-Hartmanc55519f2008-12-17 17:04:23 -0800325#define RT28XX_WRITE_FIRMWARE(_pAd, _pFwImage, _FwLen) \
326 RTUSBFirmwareWrite(_pAd, _pFwImage, _FwLen)
Greg Kroah-Hartmanc55519f2008-12-17 17:04:23 -0800327
328/* ----------------- TX Related MACRO ----------------- */
329#define RT28XX_START_DEQUEUE(pAd, QueIdx, irqFlags) \
330 { \
331 RTMP_IRQ_LOCK(&pAd->DeQueueLock[QueIdx], irqFlags); \
332 if (pAd->DeQueueRunning[QueIdx]) \
333 { \
334 RTMP_IRQ_UNLOCK(&pAd->DeQueueLock[QueIdx], irqFlags);\
335 printk("DeQueueRunning[%d]= TRUE!\n", QueIdx); \
336 continue; \
337 } \
338 else \
339 { \
340 pAd->DeQueueRunning[QueIdx] = TRUE; \
341 RTMP_IRQ_UNLOCK(&pAd->DeQueueLock[QueIdx], irqFlags);\
342 } \
343 }
344#define RT28XX_STOP_DEQUEUE(pAd, QueIdx, irqFlags) \
345 do{ \
346 RTMP_IRQ_LOCK(&pAd->DeQueueLock[QueIdx], irqFlags); \
347 pAd->DeQueueRunning[QueIdx] = FALSE; \
348 RTMP_IRQ_UNLOCK(&pAd->DeQueueLock[QueIdx], irqFlags); \
349 }while(0)
350
351
352#define RT28XX_HAS_ENOUGH_FREE_DESC(pAd, pTxBlk, freeNum, pPacket) \
353 (RTUSBFreeDescriptorRequest(pAd, pTxBlk->QueIdx, (pTxBlk->TotalFrameLen + GET_OS_PKT_LEN(pPacket))) == NDIS_STATUS_SUCCESS)
354
355#define RT28XX_RELEASE_DESC_RESOURCE(pAd, QueIdx) \
356 do{}while(0)
357
358#define NEED_QUEUE_BACK_FOR_AGG(_pAd, _QueIdx, _freeNum, _TxFrameType) \
359 ((_TxFrameType == TX_RALINK_FRAME) && (RTUSBNeedQueueBackForAgg(_pAd, _QueIdx)))
360
361
362
363#define fRTMP_ADAPTER_NEED_STOP_TX \
364 (fRTMP_ADAPTER_NIC_NOT_EXIST | fRTMP_ADAPTER_HALT_IN_PROGRESS | \
365 fRTMP_ADAPTER_RESET_IN_PROGRESS | fRTMP_ADAPTER_BULKOUT_RESET | \
366 fRTMP_ADAPTER_RADIO_OFF | fRTMP_ADAPTER_REMOVE_IN_PROGRESS)
367
368
369#define HAL_WriteSubTxResource(pAd, pTxBlk, bIsLast, pFreeNumber) \
370 RtmpUSB_WriteSubTxResource(pAd, pTxBlk, bIsLast, pFreeNumber)
371
372#define HAL_WriteTxResource(pAd, pTxBlk,bIsLast, pFreeNumber) \
373 RtmpUSB_WriteSingleTxResource(pAd, pTxBlk,bIsLast, pFreeNumber)
374
375#define HAL_WriteFragTxResource(pAd, pTxBlk, fragNum, pFreeNumber) \
376 RtmpUSB_WriteFragTxResource(pAd, pTxBlk, fragNum, pFreeNumber)
377
378#define HAL_WriteMultiTxResource(pAd, pTxBlk,frameNum, pFreeNumber) \
379 RtmpUSB_WriteMultiTxResource(pAd, pTxBlk,frameNum, pFreeNumber)
380
381#define HAL_FinalWriteTxResource(pAd, pTxBlk, totalMPDUSize, TxIdx) \
382 RtmpUSB_FinalWriteTxResource(pAd, pTxBlk, totalMPDUSize, TxIdx)
383
384#define HAL_LastTxIdx(pAd, QueIdx,TxIdx) \
385 /*RtmpUSBDataLastTxIdx(pAd, QueIdx,TxIdx)*/
386
387#define HAL_KickOutTx(pAd, pTxBlk, QueIdx) \
388 RtmpUSBDataKickOut(pAd, pTxBlk, QueIdx)
389
390
391#define HAL_KickOutMgmtTx(pAd, QueIdx, pPacket, pSrcBufVA, SrcBufLen) \
392 RtmpUSBMgmtKickOut(pAd, QueIdx, pPacket, pSrcBufVA, SrcBufLen)
393
394#define HAL_KickOutNullFrameTx(_pAd, _QueIdx, _pNullFrame, _frameLen) \
395 RtmpUSBNullFrameKickOut(_pAd, _QueIdx, _pNullFrame, _frameLen)
396
397#define RTMP_PKT_TAIL_PADDING 11 // 3(max 4 byte padding) + 4 (last packet padding) + 4 (MaxBulkOutsize align padding)
398
399extern UCHAR EpToQueue[6];
400
401
402#ifdef RT2870
403#define GET_TXRING_FREENO(_pAd, _QueIdx) (_QueIdx) //(_pAd->TxRing[_QueIdx].TxSwFreeIdx)
404#define GET_MGMTRING_FREENO(_pAd) (_pAd->MgmtRing.TxSwFreeIdx)
405#endif // RT2870 //
406
407
408/* ----------------- RX Related MACRO ----------------- */
409//#define RT28XX_RX_ERROR_CHECK RTMPCheckRxWI
410
Greg Kroah-Hartmanc55519f2008-12-17 17:04:23 -0800411#define RT28XX_RV_ALL_BUF_END(bBulkReceive) \
412 /* We return STATUS_MORE_PROCESSING_REQUIRED so that the completion */ \
413 /* routine (IofCompleteRequest) will stop working on the irp. */ \
414 if (bBulkReceive == TRUE) RTUSBBulkReceive(pAd);
415
416
417/* ----------------- ASIC Related MACRO ----------------- */
Greg Kroah-Hartmanc55519f2008-12-17 17:04:23 -0800418
419// reset MAC of a station entry to 0xFFFFFFFFFFFF
420#define RT28XX_STA_ENTRY_MAC_RESET(pAd, Wcid) \
421 { RT_SET_ASIC_WCID SetAsicWcid; \
422 SetAsicWcid.WCID = Wcid; \
423 SetAsicWcid.SetTid = 0xffffffff; \
424 SetAsicWcid.DeleteTid = 0xffffffff; \
425 RTUSBEnqueueInternalCmd(pAd, CMDTHREAD_SET_ASIC_WCID, \
426 &SetAsicWcid, sizeof(RT_SET_ASIC_WCID)); }
427
428// add this entry into ASIC RX WCID search table
429#define RT28XX_STA_ENTRY_ADD(pAd, pEntry) \
430 RTUSBEnqueueInternalCmd(pAd, CMDTHREAD_SET_CLIENT_MAC_ENTRY, \
431 pEntry, sizeof(MAC_TABLE_ENTRY));
432
Bartlomiej Zolnierkiewiczd1e4861a2009-04-26 16:06:18 +0200433#ifdef RT30xx
434// add by johnli, fix "in_interrupt" error when call "MacTableDeleteEntry" in Rx tasklet
435// Set MAC register value according operation mode
436#define RT28XX_UPDATE_PROTECT(pAd) \
437 RTUSBEnqueueInternalCmd(pAd, CMDTHREAD_UPDATE_PROTECT, NULL, 0);
438// end johnli
439#endif
440
Greg Kroah-Hartmanc55519f2008-12-17 17:04:23 -0800441// remove Pair-wise key material from ASIC
442// yet implement
443#define RT28XX_STA_ENTRY_KEY_DEL(pAd, BssIdx, Wcid)
444
445// add Client security information into ASIC WCID table and IVEIV table
446#define RT28XX_STA_SECURITY_INFO_ADD(pAd, apidx, KeyID, pEntry) \
447 { RT28XX_STA_ENTRY_MAC_RESET(pAd, pEntry->Aid); \
448 if (pEntry->Aid >= 1) { \
449 RT_SET_ASIC_WCID_ATTRI SetAsicWcidAttri; \
450 SetAsicWcidAttri.WCID = pEntry->Aid; \
451 if ((pEntry->AuthMode <= Ndis802_11AuthModeAutoSwitch) && \
452 (pEntry->WepStatus == Ndis802_11Encryption1Enabled)) \
453 { \
454 SetAsicWcidAttri.Cipher = pAd->SharedKey[apidx][KeyID].CipherAlg; \
455 } \
456 else if (pEntry->AuthMode == Ndis802_11AuthModeWPANone) \
457 { \
458 SetAsicWcidAttri.Cipher = pAd->SharedKey[apidx][KeyID].CipherAlg; \
459 } \
460 else SetAsicWcidAttri.Cipher = 0; \
461 DBGPRINT(RT_DEBUG_TRACE, ("aid cipher = %ld\n",SetAsicWcidAttri.Cipher)); \
462 RTUSBEnqueueInternalCmd(pAd, CMDTHREAD_SET_ASIC_WCID_CIPHER, \
463 &SetAsicWcidAttri, sizeof(RT_SET_ASIC_WCID_ATTRI)); } }
464
465// Insert the BA bitmap to ASIC for the Wcid entry
466#define RT28XX_ADD_BA_SESSION_TO_ASIC(_pAd, _Aid, _TID) \
467 do{ \
468 RT_SET_ASIC_WCID SetAsicWcid; \
469 SetAsicWcid.WCID = (_Aid); \
470 SetAsicWcid.SetTid = (0x10000<<(_TID)); \
471 SetAsicWcid.DeleteTid = 0xffffffff; \
472 RTUSBEnqueueInternalCmd((_pAd), CMDTHREAD_SET_ASIC_WCID, &SetAsicWcid, sizeof(RT_SET_ASIC_WCID)); \
473 }while(0)
474
475// Remove the BA bitmap from ASIC for the Wcid entry
476#define RT28XX_DEL_BA_SESSION_FROM_ASIC(_pAd, _Wcid, _TID) \
477 do{ \
478 RT_SET_ASIC_WCID SetAsicWcid; \
479 SetAsicWcid.WCID = (_Wcid); \
480 SetAsicWcid.SetTid = (0xffffffff); \
481 SetAsicWcid.DeleteTid = (0x10000<<(_TID) ); \
482 RTUSBEnqueueInternalCmd((_pAd), CMDTHREAD_SET_ASIC_WCID, &SetAsicWcid, sizeof(RT_SET_ASIC_WCID)); \
483 }while(0)
484
485
486/* ----------------- PCI/USB Related MACRO ----------------- */
487#define RT28XX_HANDLE_DEV_ASSIGN(handle, dev_p) \
488 ((POS_COOKIE)handle)->pUsb_Dev = dev_p;
489
490// no use
491#define RT28XX_UNMAP()
492#define RT28XX_IRQ_REQUEST(net_dev)
493#define RT28XX_IRQ_RELEASE(net_dev)
494#define RT28XX_IRQ_INIT(pAd)
495#define RT28XX_IRQ_ENABLE(pAd)
496
497
498/* ----------------- MLME Related MACRO ----------------- */
499#define RT28XX_MLME_HANDLER(pAd) RTUSBMlmeUp(pAd)
500
501#define RT28XX_MLME_PRE_SANITY_CHECK(pAd) \
502 { if ((pAd->CommonCfg.bHardwareRadio == TRUE) && \
503 (!RTMP_TEST_FLAG(pAd, fRTMP_ADAPTER_NIC_NOT_EXIST)) && \
504 (!RTMP_TEST_FLAG(pAd, fRTMP_ADAPTER_HALT_IN_PROGRESS))) { \
505 RTUSBEnqueueInternalCmd(pAd, CMDTHREAD_CHECK_GPIO, NULL, 0); } }
506
507#define RT28XX_MLME_STA_QUICK_RSP_WAKE_UP(pAd) \
508 { RTUSBEnqueueInternalCmd(pAd, CMDTHREAD_QKERIODIC_EXECUT, NULL, 0); \
509 RTUSBMlmeUp(pAd); }
510
511#define RT28XX_MLME_RESET_STATE_MACHINE(pAd) \
512 MlmeEnqueue(pAd, MLME_CNTL_STATE_MACHINE, MT2_RESET_CONF, 0, NULL); \
513 RTUSBMlmeUp(pAd);
514
515#define RT28XX_HANDLE_COUNTER_MEASURE(_pAd, _pEntry) \
516 { RTUSBEnqueueInternalCmd(_pAd, CMDTHREAD_802_11_COUNTER_MEASURE, _pEntry, sizeof(MAC_TABLE_ENTRY)); \
517 RTUSBMlmeUp(_pAd); \
518 }
519
520
521/* ----------------- Power Save Related MACRO ----------------- */
522#define RT28XX_PS_POLL_ENQUEUE(pAd) \
523 { RTUSB_SET_BULK_FLAG(pAd, fRTUSB_BULK_OUT_PSPOLL); \
524 RTUSBKickBulkOut(pAd); }
525
526#define RT28xx_CHIP_NAME "RT2870"
527#define USB_CYC_CFG 0x02a4
Bartlomiej Zolnierkiewiczd1e4861a2009-04-26 16:06:18 +0200528#ifndef RT30xx
Greg Kroah-Hartmanc55519f2008-12-17 17:04:23 -0800529#define STATUS_SUCCESS 0x00
530#define STATUS_UNSUCCESSFUL 0x01
Bartlomiej Zolnierkiewiczd1e4861a2009-04-26 16:06:18 +0200531#endif
Greg Kroah-Hartmanc55519f2008-12-17 17:04:23 -0800532#define NT_SUCCESS(status) (((status) > 0) ? (1):(0))
533#define InterlockedIncrement atomic_inc
534#define NdisInterlockedIncrement atomic_inc
535#define InterlockedDecrement atomic_dec
536#define NdisInterlockedDecrement atomic_dec
537#define InterlockedExchange atomic_set
538//#define NdisMSendComplete RTMP_SendComplete
539#define NdisMCancelTimer RTMPCancelTimer
540#define NdisAllocMemory(_ptr, _size, _flag) \
541 do{_ptr = kmalloc((_size),(_flag));}while(0)
542#define NdisFreeMemory(a, b, c) kfree((a))
543#define NdisMSleep RTMPusecDelay /* unit: microsecond */
544
545
546#define USBD_TRANSFER_DIRECTION_OUT 0
547#define USBD_TRANSFER_DIRECTION_IN 0
548#define USBD_SHORT_TRANSFER_OK 0
549#define PURB purbb_t
550
551#define RTUSB_FREE_URB(pUrb) usb_free_urb(pUrb)
552
553//#undef MlmeAllocateMemory
554//#undef MlmeFreeMemory
555
Bartlomiej Zolnierkiewiczd1e4861a2009-04-26 16:06:18 +0200556#ifndef RT30xx
Greg Kroah-Hartmanc55519f2008-12-17 17:04:23 -0800557typedef int NTSTATUS;
Bartlomiej Zolnierkiewiczd1e4861a2009-04-26 16:06:18 +0200558#endif
Greg Kroah-Hartmanc55519f2008-12-17 17:04:23 -0800559typedef struct usb_device * PUSB_DEV;
560
561/* MACRO for linux usb */
562typedef struct urb *purbb_t;
563typedef struct usb_ctrlrequest devctrlrequest;
564#define PIRP PVOID
565#define PMDL PVOID
566#define NDIS_OID UINT
567#ifndef USB_ST_NOERROR
568#define USB_ST_NOERROR 0
569#endif
570
571// vendor-specific control operations
572#define CONTROL_TIMEOUT_JIFFIES ( (100 * HZ) / 1000)
573#define UNLINK_TIMEOUT_MS 3
574
575/* unlink urb */
Greg Kroah-Hartmanc55519f2008-12-17 17:04:23 -0800576#define RTUSB_UNLINK_URB(pUrb) usb_kill_urb(pUrb)
Greg Kroah-Hartmanc55519f2008-12-17 17:04:23 -0800577
578// Prototypes of completion funuc.
Greg Kroah-Hartmanc55519f2008-12-17 17:04:23 -0800579VOID RTUSBBulkOutDataPacketComplete(purbb_t purb, struct pt_regs *pt_regs);
580VOID RTUSBBulkOutMLMEPacketComplete(purbb_t pUrb, struct pt_regs *pt_regs);
581VOID RTUSBBulkOutNullFrameComplete(purbb_t pUrb, struct pt_regs *pt_regs);
582VOID RTUSBBulkOutRTSFrameComplete(purbb_t pUrb, struct pt_regs *pt_regs);
583VOID RTUSBBulkOutPsPollComplete(purbb_t pUrb, struct pt_regs *pt_regs);
584VOID RTUSBBulkRxComplete(purbb_t pUrb, struct pt_regs *pt_regs);
585
Bartlomiej Zolnierkiewiczd1e4861a2009-04-26 16:06:18 +0200586#ifndef RT30xx
Greg Kroah-Hartmanc55519f2008-12-17 17:04:23 -0800587#define RTUSBMlmeUp(pAd) \
588{ \
589 POS_COOKIE pObj = (POS_COOKIE) pAd->OS_Cookie; \
Peter Teohd44ca7a2009-03-21 02:20:23 +0800590 BUG_ON(pObj->MLMEThr_task == NULL); \
591 CHECK_PID_LEGALITY(task_pid(pObj->MLMEThr_task)) \
Greg Kroah-Hartmanc55519f2008-12-17 17:04:23 -0800592 up(&(pAd->mlme_semaphore)); \
593}
594
595#define RTUSBCMDUp(pAd) \
596{ \
597 POS_COOKIE pObj = (POS_COOKIE) pAd->OS_Cookie; \
Peter Teohd44ca7a2009-03-21 02:20:23 +0800598 BUG_ON(pObj->RTUSBCmdThr_task == NULL); \
599 CHECK_PID_LEGALITY(task_pid(pObj->RTUSBCmdThr_task)) \
Greg Kroah-Hartmanc55519f2008-12-17 17:04:23 -0800600 up(&(pAd->RTUSBCmd_semaphore)); \
601}
Bartlomiej Zolnierkiewiczd1e4861a2009-04-26 16:06:18 +0200602#endif
603#ifdef RT30xx
604#define RTUSBMlmeUp(pAd) \
605{ \
606 POS_COOKIE pObj = (POS_COOKIE) pAd->OS_Cookie; \
607 if(pObj->MLMEThr_pid>0) \
608 up(&(pAd->mlme_semaphore)); \
609}
Greg Kroah-Hartmanc55519f2008-12-17 17:04:23 -0800610
Bartlomiej Zolnierkiewiczd1e4861a2009-04-26 16:06:18 +0200611#define RTUSBCMDUp(pAd) \
612{ \
613 POS_COOKIE pObj = (POS_COOKIE) pAd->OS_Cookie; \
614 if(pObj->RTUSBCmdThr_pid>0) \
615 up(&(pAd->RTUSBCmd_semaphore)); \
616}
617#endif
Greg Kroah-Hartmanc55519f2008-12-17 17:04:23 -0800618
619static inline NDIS_STATUS RTMPAllocateMemory(
620 OUT PVOID *ptr,
621 IN size_t size)
622{
623 *ptr = kmalloc(size, GFP_ATOMIC);
624 if(*ptr)
625 return NDIS_STATUS_SUCCESS;
626 else
627 return NDIS_STATUS_RESOURCES;
628}
629
630/* rtmp.h */
631#define BEACON_RING_SIZE 2
632#define DEVICE_VENDOR_REQUEST_OUT 0x40
633#define DEVICE_VENDOR_REQUEST_IN 0xc0
634#define INTERFACE_VENDOR_REQUEST_OUT 0x41
635#define INTERFACE_VENDOR_REQUEST_IN 0xc1
636#define MGMTPIPEIDX 0 // EP6 is highest priority
637
638#define BULKOUT_MGMT_RESET_FLAG 0x80
639
640#define RTUSB_SET_BULK_FLAG(_M, _F) ((_M)->BulkFlags |= (_F))
641#define RTUSB_CLEAR_BULK_FLAG(_M, _F) ((_M)->BulkFlags &= ~(_F))
642#define RTUSB_TEST_BULK_FLAG(_M, _F) (((_M)->BulkFlags & (_F)) != 0)
643
644#define EnqueueCmd(cmdq, cmdqelmt) \
645{ \
646 if (cmdq->size == 0) \
647 cmdq->head = cmdqelmt; \
648 else \
649 cmdq->tail->next = cmdqelmt; \
650 cmdq->tail = cmdqelmt; \
651 cmdqelmt->next = NULL; \
652 cmdq->size++; \
653}
654
655typedef struct _RT_SET_ASIC_WCID {
656 ULONG WCID; // mechanism for rekeying: 0:disable, 1: time-based, 2: packet-based
657 ULONG SetTid; // time-based: seconds, packet-based: kilo-packets
658 ULONG DeleteTid; // time-based: seconds, packet-based: kilo-packets
Bartlomiej Zolnierkiewiczd1e4861a2009-04-26 16:06:18 +0200659#ifndef RT30xx
Greg Kroah-Hartmanc55519f2008-12-17 17:04:23 -0800660 UCHAR Addr[MAC_ADDR_LEN]; // avoid in interrupt when write key
Bartlomiej Zolnierkiewiczd1e4861a2009-04-26 16:06:18 +0200661#endif
Greg Kroah-Hartmanc55519f2008-12-17 17:04:23 -0800662} RT_SET_ASIC_WCID,*PRT_SET_ASIC_WCID;
663
664typedef struct _RT_SET_ASIC_WCID_ATTRI {
665 ULONG WCID; // mechanism for rekeying: 0:disable, 1: time-based, 2: packet-based
666 ULONG Cipher; // ASIC Cipher definition
667 UCHAR Addr[ETH_LENGTH_OF_ADDRESS];
668} RT_SET_ASIC_WCID_ATTRI,*PRT_SET_ASIC_WCID_ATTRI;
669
670typedef struct _MLME_MEMORY_STRUCT {
671 PVOID AllocVa; //Pointer to the base virtual address of the allocated memory
672 struct _MLME_MEMORY_STRUCT *Next; //Pointer to the next virtual address of the allocated memory
673} MLME_MEMORY_STRUCT, *PMLME_MEMORY_STRUCT;
674
675typedef struct _MLME_MEMORY_HANDLER {
676 BOOLEAN MemRunning; //The flag of the Mlme memory handler's status
677 UINT MemoryCount; //Total nonpaged system-space memory not size
678 UINT InUseCount; //Nonpaged system-space memory in used counts
679 UINT UnUseCount; //Nonpaged system-space memory available counts
680 INT PendingCount; //Nonpaged system-space memory for free counts
681 PMLME_MEMORY_STRUCT pInUseHead; //Pointer to the first nonpaed memory not used
682 PMLME_MEMORY_STRUCT pInUseTail; //Pointer to the last nonpaged memory not used
683 PMLME_MEMORY_STRUCT pUnUseHead; //Pointer to the first nonpaged memory in used
684 PMLME_MEMORY_STRUCT pUnUseTail; //Pointer to the last nonpaged memory in used
685 PULONG MemFreePending[MAX_MLME_HANDLER_MEMORY]; //an array to keep pending free-memory's pointer (32bits)
686} MLME_MEMORY_HANDLER, *PMLME_MEMORY_HANDLER;
687
688typedef struct _CmdQElmt {
689 UINT command;
690 PVOID buffer;
691 ULONG bufferlength;
692 BOOLEAN CmdFromNdis;
693 BOOLEAN SetOperation;
694 struct _CmdQElmt *next;
695} CmdQElmt, *PCmdQElmt;
696
697typedef struct _CmdQ {
698 UINT size;
699 CmdQElmt *head;
700 CmdQElmt *tail;
701 UINT32 CmdQState;
702}CmdQ, *PCmdQ;
703
Greg Kroah-Hartmanc55519f2008-12-17 17:04:23 -0800704/* oid.h */
705// Cipher suite type for mixed mode group cipher, P802.11i-2004
706typedef enum _RT_802_11_CIPHER_SUITE_TYPE {
707 Cipher_Type_NONE,
708 Cipher_Type_WEP40,
709 Cipher_Type_TKIP,
710 Cipher_Type_RSVD,
711 Cipher_Type_CCMP,
712 Cipher_Type_WEP104
713} RT_802_11_CIPHER_SUITE_TYPE, *PRT_802_11_CIPHER_SUITE_TYPE;
714
715//CMDTHREAD_MULTI_READ_MAC
716//CMDTHREAD_MULTI_WRITE_MAC
717//CMDTHREAD_VENDOR_EEPROM_READ
718//CMDTHREAD_VENDOR_EEPROM_WRITE
719typedef struct _CMDHandler_TLV {
720 USHORT Offset;
721 USHORT Length;
722 UCHAR DataFirst;
723} CMDHandler_TLV, *PCMDHandler_TLV;
724
725// New for MeetingHouse Api support
726#define CMDTHREAD_VENDOR_RESET 0x0D730101 // cmd
727#define CMDTHREAD_VENDOR_UNPLUG 0x0D730102 // cmd
728#define CMDTHREAD_VENDOR_SWITCH_FUNCTION 0x0D730103 // cmd
729#define CMDTHREAD_MULTI_WRITE_MAC 0x0D730107 // cmd
730#define CMDTHREAD_MULTI_READ_MAC 0x0D730108 // cmd
731#define CMDTHREAD_VENDOR_EEPROM_WRITE 0x0D73010A // cmd
732#define CMDTHREAD_VENDOR_EEPROM_READ 0x0D73010B // cmd
733#define CMDTHREAD_VENDOR_ENTER_TESTMODE 0x0D73010C // cmd
734#define CMDTHREAD_VENDOR_EXIT_TESTMODE 0x0D73010D // cmd
735#define CMDTHREAD_VENDOR_WRITE_BBP 0x0D730119 // cmd
736#define CMDTHREAD_VENDOR_READ_BBP 0x0D730118 // cmd
737#define CMDTHREAD_VENDOR_WRITE_RF 0x0D73011A // cmd
738#define CMDTHREAD_VENDOR_FLIP_IQ 0x0D73011D // cmd
739#define CMDTHREAD_RESET_BULK_OUT 0x0D730210 // cmd
740#define CMDTHREAD_RESET_BULK_IN 0x0D730211 // cmd
741#define CMDTHREAD_SET_PSM_BIT_SAVE 0x0D730212 // cmd
742#define CMDTHREAD_SET_RADIO 0x0D730214 // cmd
743#define CMDTHREAD_UPDATE_TX_RATE 0x0D730216 // cmd
744#define CMDTHREAD_802_11_ADD_KEY_WEP 0x0D730218 // cmd
745#define CMDTHREAD_RESET_FROM_ERROR 0x0D73021A // cmd
746#define CMDTHREAD_LINK_DOWN 0x0D73021B // cmd
747#define CMDTHREAD_RESET_FROM_NDIS 0x0D73021C // cmd
748#define CMDTHREAD_CHECK_GPIO 0x0D730215 // cmd
749#define CMDTHREAD_FORCE_WAKE_UP 0x0D730222 // cmd
750#define CMDTHREAD_SET_BW 0x0D730225 // cmd
751#define CMDTHREAD_SET_ASIC_WCID 0x0D730226 // cmd
752#define CMDTHREAD_SET_ASIC_WCID_CIPHER 0x0D730227 // cmd
753#define CMDTHREAD_QKERIODIC_EXECUT 0x0D73023D // cmd
754#define RT_CMD_SET_KEY_TABLE 0x0D730228 // cmd
755#define RT_CMD_SET_RX_WCID_TABLE 0x0D730229 // cmd
756#define CMDTHREAD_SET_CLIENT_MAC_ENTRY 0x0D73023E // cmd
757#define CMDTHREAD_802_11_QUERY_HARDWARE_REGISTER 0x0D710105 // cmd
758#define CMDTHREAD_802_11_SET_PHY_MODE 0x0D79010C // cmd
759#define CMDTHREAD_802_11_SET_STA_CONFIG 0x0D790111 // cmd
760#define CMDTHREAD_802_11_SET_PREAMBLE 0x0D790101 // cmd
761#define CMDTHREAD_802_11_COUNTER_MEASURE 0x0D790102 // cmd
762
Bartlomiej Zolnierkiewiczd1e4861a2009-04-26 16:06:18 +0200763#ifdef RT30xx
764// add by johnli, fix "in_interrupt" error when call "MacTableDeleteEntry" in Rx tasklet
765#define CMDTHREAD_UPDATE_PROTECT 0x0D790103 // cmd
766// end johnli
767#endif
Greg Kroah-Hartmanc55519f2008-12-17 17:04:23 -0800768
769#define WPA1AKMBIT 0x01
770#define WPA2AKMBIT 0x02
771#define WPA1PSKAKMBIT 0x04
772#define WPA2PSKAKMBIT 0x08
773#define TKIPBIT 0x01
774#define CCMPBIT 0x02
775
776
777#define RT28XX_STA_FORCE_WAKEUP(pAd, bFromTx) \
778 RT28xxUsbStaAsicForceWakeup(pAd, bFromTx);
779
780#define RT28XX_STA_SLEEP_THEN_AUTO_WAKEUP(pAd, TbttNumToNextWakeUp) \
781 RT28xxUsbStaAsicSleepThenAutoWakeup(pAd, TbttNumToNextWakeUp);
782
783#define RT28XX_MLME_RADIO_ON(pAd) \
784 RT28xxUsbMlmeRadioOn(pAd);
785
786#define RT28XX_MLME_RADIO_OFF(pAd) \
787 RT28xxUsbMlmeRadioOFF(pAd);
788
789#endif //__RT2870_H__