2 *************************************************************************
4 * 5F., No.36, Taiyuan St., Jhubei City,
8 * (c) Copyright 2002-2007, Ralink Technology, Inc.
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. *
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. *
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. *
25 *************************************************************************
32 #include <linux/usb.h>
36 #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)
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
49 #define RETRY_LIMIT 10
50 #define BUFFER_SIZE 2400 //2048
55 // Flags for Bulkflags control for bulk out data
57 #define fRTUSB_BULK_OUT_DATA_NULL 0x00000001
58 #define fRTUSB_BULK_OUT_RTS 0x00000002
59 #define fRTUSB_BULK_OUT_MLME 0x00000004
61 #define fRTUSB_BULK_OUT_DATA_NORMAL 0x00010000
62 #define fRTUSB_BULK_OUT_DATA_NORMAL_2 0x00020000
63 #define fRTUSB_BULK_OUT_DATA_NORMAL_3 0x00040000
64 #define fRTUSB_BULK_OUT_DATA_NORMAL_4 0x00080000
65 #define fRTUSB_BULK_OUT_DATA_NORMAL_5 0x00100000
67 #define fRTUSB_BULK_OUT_PSPOLL 0x00000020
68 #define fRTUSB_BULK_OUT_DATA_FRAG 0x00000040
69 #define fRTUSB_BULK_OUT_DATA_FRAG_2 0x00000080
70 #define fRTUSB_BULK_OUT_DATA_FRAG_3 0x00000100
71 #define fRTUSB_BULK_OUT_DATA_FRAG_4 0x00000200
73 #define FREE_HTTX_RING(_p, _b, _t) \
75 if ((_t)->ENextBulkOutPosition == (_t)->CurWritePosition) \
77 (_t)->bRingEmpty = TRUE; \
79 /*NdisInterlockedDecrement(&(_p)->TxCount); */\
83 // RXINFO appends at the end of each rx packet.
85 typedef struct PACKED _RXINFO_STRUC
{
90 UINT32 U2M
:1; // 1: this RX frame is unicast to me
91 UINT32 Mcast
:1; // 1: this is a multicast frame
92 UINT32 Bcast
:1; // 1: this is a broadcast frame
93 UINT32 MyBss
:1; // 1: this frame belongs to the same BSSID
94 UINT32 Crc
:1; // 1: CRC error
95 UINT32 CipherErr
:2; // 0: decryption okay, 1:ICV error, 2:MIC error, 3:KEY not valid
96 UINT32 AMSDU
:1; // rx with 802.3 header, not 802.11 header.
100 UINT32 AMPDU
:1; // To be moved
105 UINT32 PlcpSignal
:12;
106 } RXINFO_STRUC
, *PRXINFO_STRUC
, RT28XX_RXD_STRUC
, *PRT28XX_RXD_STRUC
;
111 typedef struct _TXINFO_STRUC
{
113 UINT32 USBDMATxPktLen
:16; //used ONLY in USB bulk Aggregation, Total byte counts of all sub-frame.
115 UINT32 WIV
:1; // Wireless Info Valid. 1 if Driver already fill WI, o if DMA needs to copy WI to correctposition
116 UINT32 QSEL
:2; // select on-chip FIFO ID for 2nd-stage output scheduler.0:MGMT, 1:HCCA 2:EDCA
117 UINT32 SwUseLastRound
:1; // Software use.
118 UINT32 rsv2
:2; // Software use.
119 UINT32 USBDMANextVLD
:1; //used ONLY in USB bulk Aggregation, NextValid
120 UINT32 USBDMATxburst
:1;//used ONLY in USB bulk Aggre. Force USB DMA transmit frame from current selected endpoint
121 } TXINFO_STRUC
, *PTXINFO_STRUC
;
123 #define TXINFO_SIZE 4
124 #define RXINFO_SIZE 4
125 #define TXPADDING_SIZE 11
128 // Management ring buffer format
130 typedef struct _MGMT_STRUC
{
134 } MGMT_STRUC
, *PMGMT_STRUC
;
137 /* ----------------- EEPROM Related MACRO ----------------- */
138 #define RT28xx_EEPROM_READ16(pAd, offset, var) \
140 RTUSBReadEEPROM(pAd, offset, (PUCHAR)&(var), 2); \
141 if(!pAd->bUseEfuse) \
142 var = le2cpu16(var); \
145 #define RT28xx_EEPROM_WRITE16(pAd, offset, var) \
147 USHORT _tmpVar=var; \
148 if(!pAd->bUseEfuse) \
149 _tmpVar = cpu2le16(var); \
150 RTUSBWriteEEPROM(pAd, offset, (PUCHAR)&(_tmpVar), 2); \
153 /* ----------------- TASK/THREAD Related MACRO ----------------- */
154 #define RT28XX_TASK_THREAD_INIT(pAd, Status) \
155 Status = CreateThreads(net_dev);
158 /* ----------------- Frimware Related MACRO ----------------- */
159 #define RT28XX_WRITE_FIRMWARE(_pAd, _pFwImage, _FwLen) \
160 RTUSBFirmwareWrite(_pAd, _pFwImage, _FwLen)
162 /* ----------------- TX Related MACRO ----------------- */
163 #define RT28XX_START_DEQUEUE(pAd, QueIdx, irqFlags) \
165 RTMP_IRQ_LOCK(&pAd->DeQueueLock[QueIdx], irqFlags); \
166 if (pAd->DeQueueRunning[QueIdx]) \
168 RTMP_IRQ_UNLOCK(&pAd->DeQueueLock[QueIdx], irqFlags);\
169 printk("DeQueueRunning[%d]= TRUE!\n", QueIdx); \
174 pAd->DeQueueRunning[QueIdx] = TRUE; \
175 RTMP_IRQ_UNLOCK(&pAd->DeQueueLock[QueIdx], irqFlags);\
178 #define RT28XX_STOP_DEQUEUE(pAd, QueIdx, irqFlags) \
180 RTMP_IRQ_LOCK(&pAd->DeQueueLock[QueIdx], irqFlags); \
181 pAd->DeQueueRunning[QueIdx] = FALSE; \
182 RTMP_IRQ_UNLOCK(&pAd->DeQueueLock[QueIdx], irqFlags); \
186 #define RT28XX_HAS_ENOUGH_FREE_DESC(pAd, pTxBlk, freeNum, pPacket) \
187 (RTUSBFreeDescriptorRequest(pAd, pTxBlk->QueIdx, (pTxBlk->TotalFrameLen + GET_OS_PKT_LEN(pPacket))) == NDIS_STATUS_SUCCESS)
189 #define RT28XX_RELEASE_DESC_RESOURCE(pAd, QueIdx) \
192 #define NEED_QUEUE_BACK_FOR_AGG(_pAd, _QueIdx, _freeNum, _TxFrameType) \
193 ((_TxFrameType == TX_RALINK_FRAME) && (RTUSBNeedQueueBackForAgg(_pAd, _QueIdx)))
197 #define fRTMP_ADAPTER_NEED_STOP_TX \
198 (fRTMP_ADAPTER_NIC_NOT_EXIST | fRTMP_ADAPTER_HALT_IN_PROGRESS | \
199 fRTMP_ADAPTER_RESET_IN_PROGRESS | fRTMP_ADAPTER_BULKOUT_RESET | \
200 fRTMP_ADAPTER_RADIO_OFF | fRTMP_ADAPTER_REMOVE_IN_PROGRESS)
203 #define HAL_WriteSubTxResource(pAd, pTxBlk, bIsLast, pFreeNumber) \
204 RtmpUSB_WriteSubTxResource(pAd, pTxBlk, bIsLast, pFreeNumber)
206 #define HAL_WriteTxResource(pAd, pTxBlk,bIsLast, pFreeNumber) \
207 RtmpUSB_WriteSingleTxResource(pAd, pTxBlk,bIsLast, pFreeNumber)
209 #define HAL_WriteFragTxResource(pAd, pTxBlk, fragNum, pFreeNumber) \
210 RtmpUSB_WriteFragTxResource(pAd, pTxBlk, fragNum, pFreeNumber)
212 #define HAL_WriteMultiTxResource(pAd, pTxBlk,frameNum, pFreeNumber) \
213 RtmpUSB_WriteMultiTxResource(pAd, pTxBlk,frameNum, pFreeNumber)
215 #define HAL_FinalWriteTxResource(pAd, pTxBlk, totalMPDUSize, TxIdx) \
216 RtmpUSB_FinalWriteTxResource(pAd, pTxBlk, totalMPDUSize, TxIdx)
218 #define HAL_LastTxIdx(pAd, QueIdx,TxIdx) \
219 /*RtmpUSBDataLastTxIdx(pAd, QueIdx,TxIdx)*/
221 #define HAL_KickOutTx(pAd, pTxBlk, QueIdx) \
222 RtmpUSBDataKickOut(pAd, pTxBlk, QueIdx)
225 #define HAL_KickOutMgmtTx(pAd, QueIdx, pPacket, pSrcBufVA, SrcBufLen) \
226 RtmpUSBMgmtKickOut(pAd, QueIdx, pPacket, pSrcBufVA, SrcBufLen)
228 #define HAL_KickOutNullFrameTx(_pAd, _QueIdx, _pNullFrame, _frameLen) \
229 RtmpUSBNullFrameKickOut(_pAd, _QueIdx, _pNullFrame, _frameLen)
231 #define RTMP_PKT_TAIL_PADDING 11 // 3(max 4 byte padding) + 4 (last packet padding) + 4 (MaxBulkOutsize align padding)
233 extern UCHAR EpToQueue
[6];
237 #define GET_TXRING_FREENO(_pAd, _QueIdx) (_QueIdx) //(_pAd->TxRing[_QueIdx].TxSwFreeIdx)
238 #define GET_MGMTRING_FREENO(_pAd) (_pAd->MgmtRing.TxSwFreeIdx)
242 /* ----------------- RX Related MACRO ----------------- */
243 //#define RT28XX_RX_ERROR_CHECK RTMPCheckRxWI
245 #define RT28XX_RV_ALL_BUF_END(bBulkReceive) \
246 /* We return STATUS_MORE_PROCESSING_REQUIRED so that the completion */ \
247 /* routine (IofCompleteRequest) will stop working on the irp. */ \
248 if (bBulkReceive == TRUE) RTUSBBulkReceive(pAd);
251 /* ----------------- ASIC Related MACRO ----------------- */
253 // reset MAC of a station entry to 0xFFFFFFFFFFFF
254 #define RT28XX_STA_ENTRY_MAC_RESET(pAd, Wcid) \
255 { RT_SET_ASIC_WCID SetAsicWcid; \
256 SetAsicWcid.WCID = Wcid; \
257 SetAsicWcid.SetTid = 0xffffffff; \
258 SetAsicWcid.DeleteTid = 0xffffffff; \
259 RTUSBEnqueueInternalCmd(pAd, CMDTHREAD_SET_ASIC_WCID, \
260 &SetAsicWcid, sizeof(RT_SET_ASIC_WCID)); }
262 // add this entry into ASIC RX WCID search table
263 #define RT28XX_STA_ENTRY_ADD(pAd, pEntry) \
264 RTUSBEnqueueInternalCmd(pAd, CMDTHREAD_SET_CLIENT_MAC_ENTRY, \
265 pEntry, sizeof(MAC_TABLE_ENTRY));
267 // remove Pair-wise key material from ASIC
269 #define RT28XX_STA_ENTRY_KEY_DEL(pAd, BssIdx, Wcid)
271 // add Client security information into ASIC WCID table and IVEIV table
272 #define RT28XX_STA_SECURITY_INFO_ADD(pAd, apidx, KeyID, pEntry) \
273 { RT28XX_STA_ENTRY_MAC_RESET(pAd, pEntry->Aid); \
274 if (pEntry->Aid >= 1) { \
275 RT_SET_ASIC_WCID_ATTRI SetAsicWcidAttri; \
276 SetAsicWcidAttri.WCID = pEntry->Aid; \
277 if ((pEntry->AuthMode <= Ndis802_11AuthModeAutoSwitch) && \
278 (pEntry->WepStatus == Ndis802_11Encryption1Enabled)) \
280 SetAsicWcidAttri.Cipher = pAd->SharedKey[apidx][KeyID].CipherAlg; \
282 else if (pEntry->AuthMode == Ndis802_11AuthModeWPANone) \
284 SetAsicWcidAttri.Cipher = pAd->SharedKey[apidx][KeyID].CipherAlg; \
286 else SetAsicWcidAttri.Cipher = 0; \
287 DBGPRINT(RT_DEBUG_TRACE, ("aid cipher = %ld\n",SetAsicWcidAttri.Cipher)); \
288 RTUSBEnqueueInternalCmd(pAd, CMDTHREAD_SET_ASIC_WCID_CIPHER, \
289 &SetAsicWcidAttri, sizeof(RT_SET_ASIC_WCID_ATTRI)); } }
291 // Insert the BA bitmap to ASIC for the Wcid entry
292 #define RT28XX_ADD_BA_SESSION_TO_ASIC(_pAd, _Aid, _TID) \
294 RT_SET_ASIC_WCID SetAsicWcid; \
295 SetAsicWcid.WCID = (_Aid); \
296 SetAsicWcid.SetTid = (0x10000<<(_TID)); \
297 SetAsicWcid.DeleteTid = 0xffffffff; \
298 RTUSBEnqueueInternalCmd((_pAd), CMDTHREAD_SET_ASIC_WCID, &SetAsicWcid, sizeof(RT_SET_ASIC_WCID)); \
301 // Remove the BA bitmap from ASIC for the Wcid entry
302 #define RT28XX_DEL_BA_SESSION_FROM_ASIC(_pAd, _Wcid, _TID) \
304 RT_SET_ASIC_WCID SetAsicWcid; \
305 SetAsicWcid.WCID = (_Wcid); \
306 SetAsicWcid.SetTid = (0xffffffff); \
307 SetAsicWcid.DeleteTid = (0x10000<<(_TID) ); \
308 RTUSBEnqueueInternalCmd((_pAd), CMDTHREAD_SET_ASIC_WCID, &SetAsicWcid, sizeof(RT_SET_ASIC_WCID)); \
312 /* ----------------- PCI/USB Related MACRO ----------------- */
313 #define RT28XX_HANDLE_DEV_ASSIGN(handle, dev_p) \
314 ((POS_COOKIE)handle)->pUsb_Dev = dev_p;
317 #define RT28XX_UNMAP()
318 #define RT28XX_IRQ_REQUEST(net_dev)
319 #define RT28XX_IRQ_RELEASE(net_dev)
320 #define RT28XX_IRQ_INIT(pAd)
321 #define RT28XX_IRQ_ENABLE(pAd)
324 /* ----------------- MLME Related MACRO ----------------- */
325 #define RT28XX_MLME_HANDLER(pAd) RTUSBMlmeUp(pAd)
327 #define RT28XX_MLME_PRE_SANITY_CHECK(pAd) \
328 { if ((pAd->CommonCfg.bHardwareRadio == TRUE) && \
329 (!RTMP_TEST_FLAG(pAd, fRTMP_ADAPTER_NIC_NOT_EXIST)) && \
330 (!RTMP_TEST_FLAG(pAd, fRTMP_ADAPTER_HALT_IN_PROGRESS))) { \
331 RTUSBEnqueueInternalCmd(pAd, CMDTHREAD_CHECK_GPIO, NULL, 0); } }
333 #define RT28XX_MLME_STA_QUICK_RSP_WAKE_UP(pAd) \
334 { RTUSBEnqueueInternalCmd(pAd, CMDTHREAD_QKERIODIC_EXECUT, NULL, 0); \
337 #define RT28XX_MLME_RESET_STATE_MACHINE(pAd) \
338 MlmeEnqueue(pAd, MLME_CNTL_STATE_MACHINE, MT2_RESET_CONF, 0, NULL); \
341 #define RT28XX_HANDLE_COUNTER_MEASURE(_pAd, _pEntry) \
342 { RTUSBEnqueueInternalCmd(_pAd, CMDTHREAD_802_11_COUNTER_MEASURE, _pEntry, sizeof(MAC_TABLE_ENTRY)); \
347 /* ----------------- Power Save Related MACRO ----------------- */
348 #define RT28XX_PS_POLL_ENQUEUE(pAd) \
349 { RTUSB_SET_BULK_FLAG(pAd, fRTUSB_BULK_OUT_PSPOLL); \
350 RTUSBKickBulkOut(pAd); }
352 #define RT28xx_CHIP_NAME "RTxx70"
354 #define USB_CYC_CFG 0x02a4
355 #define STATUS_SUCCESS 0x00
356 #define STATUS_UNSUCCESSFUL 0x01
357 #define NT_SUCCESS(status) (((status) > 0) ? (1):(0))
358 #define InterlockedIncrement atomic_inc
359 #define NdisInterlockedIncrement atomic_inc
360 #define InterlockedDecrement atomic_dec
361 #define NdisInterlockedDecrement atomic_dec
362 #define InterlockedExchange atomic_set
363 //#define NdisMSendComplete RTMP_SendComplete
364 #define NdisMCancelTimer RTMPCancelTimer
365 #define NdisAllocMemory(_ptr, _size, _flag) \
366 do{_ptr = kmalloc((_size),(_flag));}while(0)
367 #define NdisFreeMemory(a, b, c) kfree((a))
368 #define NdisMSleep RTMPusecDelay /* unit: microsecond */
371 #define USBD_TRANSFER_DIRECTION_OUT 0
372 #define USBD_TRANSFER_DIRECTION_IN 0
373 #define USBD_SHORT_TRANSFER_OK 0
376 #define RTUSB_FREE_URB(pUrb) usb_free_urb(pUrb)
378 //#undef MlmeAllocateMemory
379 //#undef MlmeFreeMemory
381 typedef struct usb_device
* PUSB_DEV
;
383 /* MACRO for linux usb */
384 typedef struct urb
*purbb_t
;
385 typedef struct usb_ctrlrequest devctrlrequest
;
388 #define NDIS_OID UINT
389 #ifndef USB_ST_NOERROR
390 #define USB_ST_NOERROR 0
393 // vendor-specific control operations
394 #define CONTROL_TIMEOUT_JIFFIES ( (100 * HZ) / 1000)
395 #define UNLINK_TIMEOUT_MS 3
398 #define RTUSB_UNLINK_URB(pUrb) usb_kill_urb(pUrb)
400 // Prototypes of completion funuc.
401 VOID
RTUSBBulkOutDataPacketComplete(purbb_t purb
, struct pt_regs
*pt_regs
);
402 VOID
RTUSBBulkOutMLMEPacketComplete(purbb_t pUrb
, struct pt_regs
*pt_regs
);
403 VOID
RTUSBBulkOutNullFrameComplete(purbb_t pUrb
, struct pt_regs
*pt_regs
);
404 VOID
RTUSBBulkOutRTSFrameComplete(purbb_t pUrb
, struct pt_regs
*pt_regs
);
405 VOID
RTUSBBulkOutPsPollComplete(purbb_t pUrb
, struct pt_regs
*pt_regs
);
406 VOID
RTUSBBulkRxComplete(purbb_t pUrb
, struct pt_regs
*pt_regs
);
408 #define RTUSBMlmeUp(pAd) \
410 POS_COOKIE pObj = (POS_COOKIE) pAd->OS_Cookie; \
411 if (pid_nr(pObj->MLMEThr_pid) > 0) \
412 up(&(pAd->mlme_semaphore)); \
415 #define RTUSBCMDUp(pAd) \
417 POS_COOKIE pObj = (POS_COOKIE) pAd->OS_Cookie; \
418 if (pid_nr(pObj->RTUSBCmdThr_pid) > 0) \
419 up(&(pAd->RTUSBCmd_semaphore)); \
422 static inline NDIS_STATUS
RTMPAllocateMemory(
426 *ptr
= kmalloc(size
, GFP_ATOMIC
);
428 return NDIS_STATUS_SUCCESS
;
430 return NDIS_STATUS_RESOURCES
;
434 #define BEACON_RING_SIZE 2
435 #define DEVICE_VENDOR_REQUEST_OUT 0x40
436 #define DEVICE_VENDOR_REQUEST_IN 0xc0
437 #define INTERFACE_VENDOR_REQUEST_OUT 0x41
438 #define INTERFACE_VENDOR_REQUEST_IN 0xc1
439 #define MGMTPIPEIDX 0 // EP6 is highest priority
441 #define BULKOUT_MGMT_RESET_FLAG 0x80
443 #define RTUSB_SET_BULK_FLAG(_M, _F) ((_M)->BulkFlags |= (_F))
444 #define RTUSB_CLEAR_BULK_FLAG(_M, _F) ((_M)->BulkFlags &= ~(_F))
445 #define RTUSB_TEST_BULK_FLAG(_M, _F) (((_M)->BulkFlags & (_F)) != 0)
447 #define EnqueueCmd(cmdq, cmdqelmt) \
449 if (cmdq->size == 0) \
450 cmdq->head = cmdqelmt; \
452 cmdq->tail->next = cmdqelmt; \
453 cmdq->tail = cmdqelmt; \
454 cmdqelmt->next = NULL; \
458 typedef struct _RT_SET_ASIC_WCID
{
459 ULONG WCID
; // mechanism for rekeying: 0:disable, 1: time-based, 2: packet-based
460 ULONG SetTid
; // time-based: seconds, packet-based: kilo-packets
461 ULONG DeleteTid
; // time-based: seconds, packet-based: kilo-packets
462 UCHAR Addr
[MAC_ADDR_LEN
]; // avoid in interrupt when write key
463 } RT_SET_ASIC_WCID
,*PRT_SET_ASIC_WCID
;
465 typedef struct _RT_SET_ASIC_WCID_ATTRI
{
466 ULONG WCID
; // mechanism for rekeying: 0:disable, 1: time-based, 2: packet-based
467 ULONG Cipher
; // ASIC Cipher definition
468 UCHAR Addr
[ETH_LENGTH_OF_ADDRESS
];
469 } RT_SET_ASIC_WCID_ATTRI
,*PRT_SET_ASIC_WCID_ATTRI
;
471 typedef struct _MLME_MEMORY_STRUCT
{
472 PVOID AllocVa
; //Pointer to the base virtual address of the allocated memory
473 struct _MLME_MEMORY_STRUCT
*Next
; //Pointer to the next virtual address of the allocated memory
474 } MLME_MEMORY_STRUCT
, *PMLME_MEMORY_STRUCT
;
476 typedef struct _MLME_MEMORY_HANDLER
{
477 BOOLEAN MemRunning
; //The flag of the Mlme memory handler's status
478 UINT MemoryCount
; //Total nonpaged system-space memory not size
479 UINT InUseCount
; //Nonpaged system-space memory in used counts
480 UINT UnUseCount
; //Nonpaged system-space memory available counts
481 INT PendingCount
; //Nonpaged system-space memory for free counts
482 PMLME_MEMORY_STRUCT pInUseHead
; //Pointer to the first nonpaed memory not used
483 PMLME_MEMORY_STRUCT pInUseTail
; //Pointer to the last nonpaged memory not used
484 PMLME_MEMORY_STRUCT pUnUseHead
; //Pointer to the first nonpaged memory in used
485 PMLME_MEMORY_STRUCT pUnUseTail
; //Pointer to the last nonpaged memory in used
486 PULONG MemFreePending
[MAX_MLME_HANDLER_MEMORY
]; //an array to keep pending free-memory's pointer (32bits)
487 } MLME_MEMORY_HANDLER
, *PMLME_MEMORY_HANDLER
;
489 typedef struct _CmdQElmt
{
494 BOOLEAN SetOperation
;
495 struct _CmdQElmt
*next
;
496 } CmdQElmt
, *PCmdQElmt
;
498 typedef struct _CmdQ
{
506 // Cipher suite type for mixed mode group cipher, P802.11i-2004
507 typedef enum _RT_802_11_CIPHER_SUITE_TYPE
{
514 } RT_802_11_CIPHER_SUITE_TYPE
, *PRT_802_11_CIPHER_SUITE_TYPE
;
516 //CMDTHREAD_MULTI_READ_MAC
517 //CMDTHREAD_MULTI_WRITE_MAC
518 //CMDTHREAD_VENDOR_EEPROM_READ
519 //CMDTHREAD_VENDOR_EEPROM_WRITE
520 typedef struct _CMDHandler_TLV
{
524 } CMDHandler_TLV
, *PCMDHandler_TLV
;
526 // New for MeetingHouse Api support
527 #define CMDTHREAD_VENDOR_RESET 0x0D730101 // cmd
528 #define CMDTHREAD_VENDOR_UNPLUG 0x0D730102 // cmd
529 #define CMDTHREAD_VENDOR_SWITCH_FUNCTION 0x0D730103 // cmd
530 #define CMDTHREAD_MULTI_WRITE_MAC 0x0D730107 // cmd
531 #define CMDTHREAD_MULTI_READ_MAC 0x0D730108 // cmd
532 #define CMDTHREAD_VENDOR_EEPROM_WRITE 0x0D73010A // cmd
533 #define CMDTHREAD_VENDOR_EEPROM_READ 0x0D73010B // cmd
534 #define CMDTHREAD_VENDOR_ENTER_TESTMODE 0x0D73010C // cmd
535 #define CMDTHREAD_VENDOR_EXIT_TESTMODE 0x0D73010D // cmd
536 #define CMDTHREAD_VENDOR_WRITE_BBP 0x0D730119 // cmd
537 #define CMDTHREAD_VENDOR_READ_BBP 0x0D730118 // cmd
538 #define CMDTHREAD_VENDOR_WRITE_RF 0x0D73011A // cmd
539 #define CMDTHREAD_VENDOR_FLIP_IQ 0x0D73011D // cmd
540 #define CMDTHREAD_RESET_BULK_OUT 0x0D730210 // cmd
541 #define CMDTHREAD_RESET_BULK_IN 0x0D730211 // cmd
542 #define CMDTHREAD_SET_PSM_BIT_SAVE 0x0D730212 // cmd
543 #define CMDTHREAD_SET_RADIO 0x0D730214 // cmd
544 #define CMDTHREAD_UPDATE_TX_RATE 0x0D730216 // cmd
545 #define CMDTHREAD_802_11_ADD_KEY_WEP 0x0D730218 // cmd
546 #define CMDTHREAD_RESET_FROM_ERROR 0x0D73021A // cmd
547 #define CMDTHREAD_LINK_DOWN 0x0D73021B // cmd
548 #define CMDTHREAD_RESET_FROM_NDIS 0x0D73021C // cmd
549 #define CMDTHREAD_CHECK_GPIO 0x0D730215 // cmd
550 #define CMDTHREAD_FORCE_WAKE_UP 0x0D730222 // cmd
551 #define CMDTHREAD_SET_BW 0x0D730225 // cmd
552 #define CMDTHREAD_SET_ASIC_WCID 0x0D730226 // cmd
553 #define CMDTHREAD_SET_ASIC_WCID_CIPHER 0x0D730227 // cmd
554 #define CMDTHREAD_QKERIODIC_EXECUT 0x0D73023D // cmd
555 #define CMDTHREAD_SET_CLIENT_MAC_ENTRY 0x0D73023E // cmd
556 #define CMDTHREAD_802_11_QUERY_HARDWARE_REGISTER 0x0D710105 // cmd
557 #define CMDTHREAD_802_11_SET_PHY_MODE 0x0D79010C // cmd
558 #define CMDTHREAD_802_11_SET_STA_CONFIG 0x0D790111 // cmd
559 #define CMDTHREAD_802_11_SET_PREAMBLE 0x0D790101 // cmd
560 #define CMDTHREAD_802_11_COUNTER_MEASURE 0x0D790102 // cmd
561 #define CMDTHREAD_UPDATE_PROTECT 0x0D790103 // cmd
563 #define WPA1AKMBIT 0x01
564 #define WPA2AKMBIT 0x02
565 #define WPA1PSKAKMBIT 0x04
566 #define WPA2PSKAKMBIT 0x08
571 #define RT28XX_STA_FORCE_WAKEUP(pAd, bFromTx) \
572 RT28xxUsbStaAsicForceWakeup(pAd, bFromTx);
574 #define RT28XX_STA_SLEEP_THEN_AUTO_WAKEUP(pAd, TbttNumToNextWakeUp) \
575 RT28xxUsbStaAsicSleepThenAutoWakeup(pAd, TbttNumToNextWakeUp);
577 #define RT28XX_MLME_RADIO_ON(pAd) \
578 RT28xxUsbMlmeRadioOn(pAd);
580 #define RT28XX_MLME_RADIO_OFF(pAd) \
581 RT28xxUsbMlmeRadioOFF(pAd);
583 #endif //__RT2870_H__