|
@@ -51,7 +51,6 @@
|
|
|
|
|
|
#define MAX_INTERRUPT_SIZE 32
|
|
|
|
|
|
-
|
|
|
#define RX_BLOCKS 64 // form 0x60 to 0xA0
|
|
|
#define TX_BLOCKS 32 // from 0xA0 to 0xC0
|
|
|
|
|
@@ -63,8 +62,6 @@
|
|
|
#define CB_RD_NUM 64 // default # of RD
|
|
|
#define CB_TD_NUM 64 // default # of TD
|
|
|
|
|
|
-
|
|
|
-
|
|
|
//
|
|
|
// Bits in the RSR register
|
|
|
//
|
|
@@ -87,7 +84,6 @@
|
|
|
#define NEWRSR_BCNHITAID 0x02 // 0000 0010
|
|
|
#define NEWRSR_BCNHITAID0 0x01 // 0000 0001
|
|
|
|
|
|
-
|
|
|
//
|
|
|
// Bits in the TSR register
|
|
|
//
|
|
@@ -96,17 +92,13 @@
|
|
|
#define TSR_ACKDATA 0x02 // 0000 0010
|
|
|
#define TSR_VALID 0x01 // 0000 0001
|
|
|
|
|
|
-
|
|
|
#define CB_PROTOCOL_RESERVED_SECTION 16
|
|
|
|
|
|
-
|
|
|
-
|
|
|
// if retrys excess 15 times , tx will abort, and
|
|
|
// if tx fifo underflow, tx will fail
|
|
|
// we should try to resend it
|
|
|
#define CB_MAX_TX_ABORT_RETRY 3
|
|
|
|
|
|
-
|
|
|
#define FIFOCTL_AUTO_FB_1 0x1000 // 0001 0000 0000 0000
|
|
|
#define FIFOCTL_AUTO_FB_0 0x0800 // 0000 1000 0000 0000
|
|
|
#define FIFOCTL_GRPACK 0x0400 // 0000 0100 0000 0000
|
|
@@ -137,7 +129,6 @@
|
|
|
#define FRAGCTL_STAFRAG 0x0001 // 0000 0000 0000 0001
|
|
|
#define FRAGCTL_NONFRAG 0x0000 // 0000 0000 0000 0000
|
|
|
|
|
|
-
|
|
|
//#define TYPE_AC0DMA 0
|
|
|
//#define TYPE_TXDMA0 1
|
|
|
#define TYPE_TXDMA0 0
|
|
@@ -152,8 +143,6 @@
|
|
|
#define TYPE_RXDMA1 1
|
|
|
#define TYPE_MAXRD 2
|
|
|
|
|
|
-
|
|
|
-
|
|
|
// TD_INFO flags control bit
|
|
|
#define TD_FLAGS_NETIF_SKB 0x01 // check if need release skb
|
|
|
#define TD_FLAGS_PRIV_SKB 0x02 // check if called from private skb(hostap)
|
|
@@ -162,7 +151,6 @@
|
|
|
|
|
|
/*--------------------- Export Types ------------------------------*/
|
|
|
|
|
|
-
|
|
|
//
|
|
|
// RsvTime buffer header
|
|
|
//
|
|
@@ -173,8 +161,9 @@ typedef struct tagSRrvTime_gRTS {
|
|
|
WORD wReserved;
|
|
|
WORD wTxRrvTime_b;
|
|
|
WORD wTxRrvTime_a;
|
|
|
-}__attribute__ ((__packed__))
|
|
|
+} __attribute__ ((__packed__))
|
|
|
SRrvTime_gRTS, *PSRrvTime_gRTS;
|
|
|
+
|
|
|
typedef const SRrvTime_gRTS *PCSRrvTime_gRTS;
|
|
|
|
|
|
typedef struct tagSRrvTime_gCTS {
|
|
@@ -182,22 +171,25 @@ typedef struct tagSRrvTime_gCTS {
|
|
|
WORD wReserved;
|
|
|
WORD wTxRrvTime_b;
|
|
|
WORD wTxRrvTime_a;
|
|
|
-}__attribute__ ((__packed__))
|
|
|
+} __attribute__ ((__packed__))
|
|
|
SRrvTime_gCTS, *PSRrvTime_gCTS;
|
|
|
+
|
|
|
typedef const SRrvTime_gCTS *PCSRrvTime_gCTS;
|
|
|
|
|
|
typedef struct tagSRrvTime_ab {
|
|
|
WORD wRTSTxRrvTime;
|
|
|
WORD wTxRrvTime;
|
|
|
-}__attribute__ ((__packed__))
|
|
|
+} __attribute__ ((__packed__))
|
|
|
SRrvTime_ab, *PSRrvTime_ab;
|
|
|
+
|
|
|
typedef const SRrvTime_ab *PCSRrvTime_ab;
|
|
|
|
|
|
typedef struct tagSRrvTime_atim {
|
|
|
WORD wCTSTxRrvTime_ba;
|
|
|
WORD wTxRrvTime_a;
|
|
|
-}__attribute__ ((__packed__))
|
|
|
+} __attribute__ ((__packed__))
|
|
|
SRrvTime_atim, *PSRrvTime_atim;
|
|
|
+
|
|
|
typedef const SRrvTime_atim *PCSRrvTime_atim;
|
|
|
|
|
|
//
|
|
@@ -208,8 +200,9 @@ typedef struct tagSRTSData {
|
|
|
WORD wDurationID;
|
|
|
BYTE abyRA[ETH_ALEN];
|
|
|
BYTE abyTA[ETH_ALEN];
|
|
|
-}__attribute__ ((__packed__))
|
|
|
+} __attribute__ ((__packed__))
|
|
|
SRTSData, *PSRTSData;
|
|
|
+
|
|
|
typedef const SRTSData *PCSRTSData;
|
|
|
|
|
|
typedef struct tagSRTS_g {
|
|
@@ -224,11 +217,10 @@ typedef struct tagSRTS_g {
|
|
|
WORD wDuration_bb;
|
|
|
WORD wReserved;
|
|
|
SRTSData Data;
|
|
|
-}__attribute__ ((__packed__))
|
|
|
+} __attribute__ ((__packed__))
|
|
|
SRTS_g, *PSRTS_g;
|
|
|
typedef const SRTS_g *PCSRTS_g;
|
|
|
|
|
|
-
|
|
|
typedef struct tagSRTS_g_FB {
|
|
|
BYTE bySignalField_b;
|
|
|
BYTE byServiceField_b;
|
|
@@ -245,10 +237,10 @@ typedef struct tagSRTS_g_FB {
|
|
|
WORD wRTSDuration_ba_f1;
|
|
|
WORD wRTSDuration_aa_f1;
|
|
|
SRTSData Data;
|
|
|
-}__attribute__ ((__packed__))
|
|
|
+} __attribute__ ((__packed__))
|
|
|
SRTS_g_FB, *PSRTS_g_FB;
|
|
|
-typedef const SRTS_g_FB *PCSRTS_g_FB;
|
|
|
|
|
|
+typedef const SRTS_g_FB *PCSRTS_g_FB;
|
|
|
|
|
|
typedef struct tagSRTS_ab {
|
|
|
BYTE bySignalField;
|
|
@@ -257,10 +249,10 @@ typedef struct tagSRTS_ab {
|
|
|
WORD wDuration;
|
|
|
WORD wReserved;
|
|
|
SRTSData Data;
|
|
|
-}__attribute__ ((__packed__))
|
|
|
+} __attribute__ ((__packed__))
|
|
|
SRTS_ab, *PSRTS_ab;
|
|
|
-typedef const SRTS_ab *PCSRTS_ab;
|
|
|
|
|
|
+typedef const SRTS_ab *PCSRTS_ab;
|
|
|
|
|
|
typedef struct tagSRTS_a_FB {
|
|
|
BYTE bySignalField;
|
|
@@ -271,8 +263,9 @@ typedef struct tagSRTS_a_FB {
|
|
|
WORD wRTSDuration_f0;
|
|
|
WORD wRTSDuration_f1;
|
|
|
SRTSData Data;
|
|
|
-}__attribute__ ((__packed__))
|
|
|
+} __attribute__ ((__packed__))
|
|
|
SRTS_a_FB, *PSRTS_a_FB;
|
|
|
+
|
|
|
typedef const SRTS_a_FB *PCSRTS_a_FB;
|
|
|
|
|
|
|
|
@@ -284,7 +277,7 @@ typedef struct tagSCTSData {
|
|
|
WORD wDurationID;
|
|
|
BYTE abyRA[ETH_ALEN];
|
|
|
WORD wReserved;
|
|
|
-}__attribute__ ((__packed__))
|
|
|
+} __attribute__ ((__packed__))
|
|
|
SCTSData, *PSCTSData;
|
|
|
|
|
|
typedef struct tagSCTS {
|
|
@@ -294,8 +287,9 @@ typedef struct tagSCTS {
|
|
|
WORD wDuration_ba;
|
|
|
WORD wReserved;
|
|
|
SCTSData Data;
|
|
|
-}__attribute__ ((__packed__))
|
|
|
+} __attribute__ ((__packed__))
|
|
|
SCTS, *PSCTS;
|
|
|
+
|
|
|
typedef const SCTS *PCSCTS;
|
|
|
|
|
|
typedef struct tagSCTS_FB {
|
|
@@ -307,10 +301,10 @@ typedef struct tagSCTS_FB {
|
|
|
WORD wCTSDuration_ba_f0;
|
|
|
WORD wCTSDuration_ba_f1;
|
|
|
SCTSData Data;
|
|
|
-}__attribute__ ((__packed__))
|
|
|
+} __attribute__ ((__packed__))
|
|
|
SCTS_FB, *PSCTS_FB;
|
|
|
-typedef const SCTS_FB *PCSCTS_FB;
|
|
|
|
|
|
+typedef const SCTS_FB *PCSCTS_FB;
|
|
|
|
|
|
//
|
|
|
// Tx FIFO header
|
|
@@ -321,14 +315,14 @@ typedef struct tagSTxBufHead {
|
|
|
WORD wTimeStamp;
|
|
|
WORD wFragCtl;
|
|
|
WORD wReserved;
|
|
|
-}__attribute__ ((__packed__))
|
|
|
+} __attribute__ ((__packed__))
|
|
|
STxBufHead, *PSTxBufHead;
|
|
|
typedef const STxBufHead *PCSTxBufHead;
|
|
|
|
|
|
typedef struct tagSTxShortBufHead {
|
|
|
WORD wFIFOCtl;
|
|
|
WORD wTimeStamp;
|
|
|
-}__attribute__ ((__packed__))
|
|
|
+} __attribute__ ((__packed__))
|
|
|
STxShortBufHead, *PSTxShortBufHead;
|
|
|
typedef const STxShortBufHead *PCSTxShortBufHead;
|
|
|
|
|
@@ -346,8 +340,9 @@ typedef struct tagSTxDataHead_g {
|
|
|
WORD wDuration_a;
|
|
|
WORD wTimeStampOff_b;
|
|
|
WORD wTimeStampOff_a;
|
|
|
-}__attribute__ ((__packed__))
|
|
|
+} __attribute__ ((__packed__))
|
|
|
STxDataHead_g, *PSTxDataHead_g;
|
|
|
+
|
|
|
typedef const STxDataHead_g *PCSTxDataHead_g;
|
|
|
|
|
|
typedef struct tagSTxDataHead_g_FB {
|
|
@@ -363,22 +358,20 @@ typedef struct tagSTxDataHead_g_FB {
|
|
|
WORD wDuration_a_f1;
|
|
|
WORD wTimeStampOff_b;
|
|
|
WORD wTimeStampOff_a;
|
|
|
-}__attribute__ ((__packed__))
|
|
|
+} __attribute__ ((__packed__))
|
|
|
STxDataHead_g_FB, *PSTxDataHead_g_FB;
|
|
|
typedef const STxDataHead_g_FB *PCSTxDataHead_g_FB;
|
|
|
|
|
|
-
|
|
|
typedef struct tagSTxDataHead_ab {
|
|
|
BYTE bySignalField;
|
|
|
BYTE byServiceField;
|
|
|
WORD wTransmitLength;
|
|
|
WORD wDuration;
|
|
|
WORD wTimeStampOff;
|
|
|
-}__attribute__ ((__packed__))
|
|
|
+} __attribute__ ((__packed__))
|
|
|
STxDataHead_ab, *PSTxDataHead_ab;
|
|
|
typedef const STxDataHead_ab *PCSTxDataHead_ab;
|
|
|
|
|
|
-
|
|
|
typedef struct tagSTxDataHead_a_FB {
|
|
|
BYTE bySignalField;
|
|
|
BYTE byServiceField;
|
|
@@ -387,7 +380,7 @@ typedef struct tagSTxDataHead_a_FB {
|
|
|
WORD wTimeStampOff;
|
|
|
WORD wDuration_f0;
|
|
|
WORD wDuration_f1;
|
|
|
-}__attribute__ ((__packed__))
|
|
|
+} __attribute__ ((__packed__))
|
|
|
STxDataHead_a_FB, *PSTxDataHead_a_FB;
|
|
|
typedef const STxDataHead_a_FB *PCSTxDataHead_a_FB;
|
|
|
|
|
@@ -398,23 +391,23 @@ typedef struct tagSMICHDRHead {
|
|
|
DWORD adwHDR0[4];
|
|
|
DWORD adwHDR1[4];
|
|
|
DWORD adwHDR2[4];
|
|
|
-}__attribute__ ((__packed__))
|
|
|
+} __attribute__ ((__packed__))
|
|
|
SMICHDRHead, *PSMICHDRHead;
|
|
|
+
|
|
|
typedef const SMICHDRHead *PCSMICHDRHead;
|
|
|
|
|
|
typedef struct tagSBEACONCtl {
|
|
|
DWORD BufReady : 1;
|
|
|
- DWORD TSF : 15;
|
|
|
- DWORD BufLen : 11;
|
|
|
+ DWORD TSF : 15;
|
|
|
+ DWORD BufLen : 11;
|
|
|
DWORD Reserved : 5;
|
|
|
-}__attribute__ ((__packed__))
|
|
|
+} __attribute__ ((__packed__))
|
|
|
SBEACONCtl;
|
|
|
|
|
|
-
|
|
|
typedef struct tagSSecretKey {
|
|
|
DWORD dwLowDword;
|
|
|
BYTE byHighByte;
|
|
|
-}__attribute__ ((__packed__))
|
|
|
+} __attribute__ ((__packed__))
|
|
|
SSecretKey;
|
|
|
|
|
|
typedef struct tagSKeyEntry {
|
|
@@ -426,7 +419,7 @@ typedef struct tagSKeyEntry {
|
|
|
DWORD dwKey2[4];
|
|
|
DWORD dwKey3[4];
|
|
|
DWORD dwKey4[4];
|
|
|
-}__attribute__ ((__packed__))
|
|
|
+} __attribute__ ((__packed__))
|
|
|
SKeyEntry;
|
|
|
/*--------------------- Export Macros ------------------------------*/
|
|
|
|