334 lines
7.4 KiB
C
334 lines
7.4 KiB
C
|
#ifndef __HAL88XX_TXDESC_H__
|
||
|
#define __HAL88XX_TXDESC_H__
|
||
|
|
||
|
typedef struct _TX_DESC_88XX_
|
||
|
{
|
||
|
volatile u4Byte Dword0;
|
||
|
volatile u4Byte Dword1;
|
||
|
volatile u4Byte Dword2;
|
||
|
volatile u4Byte Dword3;
|
||
|
volatile u4Byte Dword4;
|
||
|
volatile u4Byte Dword5;
|
||
|
volatile u4Byte Dword6;
|
||
|
volatile u4Byte Dword7;
|
||
|
volatile u4Byte Dword8;
|
||
|
volatile u4Byte Dword9;
|
||
|
} TX_DESC_88XX, *PTX_DESC_88XX;
|
||
|
|
||
|
#define SIZE_TXDESC_88XX 40
|
||
|
|
||
|
typedef enum _HCI_TX_DMA_QUEUE_88XX_
|
||
|
{
|
||
|
//MGT
|
||
|
HCI_TX_DMA_QUEUE_MGT = 0,
|
||
|
|
||
|
//QoS
|
||
|
HCI_TX_DMA_QUEUE_BK,
|
||
|
HCI_TX_DMA_QUEUE_BE,
|
||
|
HCI_TX_DMA_QUEUE_VI,
|
||
|
HCI_TX_DMA_QUEUE_VO,
|
||
|
|
||
|
//HI
|
||
|
HCI_TX_DMA_QUEUE_HI0,
|
||
|
HCI_TX_DMA_QUEUE_HI1,
|
||
|
HCI_TX_DMA_QUEUE_HI2,
|
||
|
HCI_TX_DMA_QUEUE_HI3,
|
||
|
HCI_TX_DMA_QUEUE_HI4,
|
||
|
HCI_TX_DMA_QUEUE_HI5,
|
||
|
HCI_TX_DMA_QUEUE_HI6,
|
||
|
HCI_TX_DMA_QUEUE_HI7,
|
||
|
|
||
|
// Beacon
|
||
|
HCI_TX_DMA_QUEUE_BCN,
|
||
|
|
||
|
HCI_TX_DMA_QUEUE_MAX_NUM //14
|
||
|
} HCI_TX_DMA_QUEUE_88XX, *PHCI_TX_DMA_QUEUE_88XX;
|
||
|
|
||
|
#if 0
|
||
|
// TODO: endian....
|
||
|
#ifdef _BIG_ENDIAN_
|
||
|
typedef struct _TXBD_ELEMENT_DW0_
|
||
|
{
|
||
|
u4Byte Rsvd_31 :1;
|
||
|
u4Byte PsbLen :15;
|
||
|
u4Byte Rsvd_14_15 :2;
|
||
|
u4Byte Len :14;
|
||
|
} TXBD_ELEMENT_DW0,*PTXBD_ELEMENT_DW0;
|
||
|
|
||
|
typedef struct _TXBD_ELEMENT_DW_
|
||
|
{
|
||
|
u4Byte AmpduEn :1;
|
||
|
u4Byte Rsvd16To30 :15;
|
||
|
u4Byte Len :16;
|
||
|
} TXBD_ELEMENT_DW,*PTXBD_ELEMENT_DW;
|
||
|
#else // _LITTLE_ENDIAN_
|
||
|
typedef struct _TXBD_ELEMENT_DW0_
|
||
|
{
|
||
|
u4Byte Len :14;
|
||
|
u4Byte Rsvd_14_15 :2;
|
||
|
u4Byte PsbLen :15;
|
||
|
u4Byte Rsvd_31 :1;
|
||
|
} TXBD_ELEMENT_DW0,*PTXBD_ELEMENT_DW0;
|
||
|
|
||
|
typedef struct _TXBD_ELEMENT_DW_
|
||
|
{
|
||
|
u4Byte Len :16;
|
||
|
u4Byte Rsvd16To30 :15;
|
||
|
u4Byte AmpduEn :1;
|
||
|
} TXBD_ELEMENT_DW,*PTXBD_ELEMENT_DW;
|
||
|
#endif
|
||
|
#endif
|
||
|
|
||
|
typedef struct _TXBD_ELEMENT_
|
||
|
{
|
||
|
u4Byte Dword0;
|
||
|
u4Byte Dword1;
|
||
|
#if TXBD_SEG_32_64_SEL
|
||
|
u4Byte Dword2;
|
||
|
u4Byte Dword3;
|
||
|
#endif //TXBD_SEG_32_64_SEL
|
||
|
} TXBD_ELEMENT,*PTXBD_ELEMENT;
|
||
|
|
||
|
typedef struct _TX_BUFFER_DESCRIPTOR_
|
||
|
{
|
||
|
TXBD_ELEMENT TXBD_ELE[TXBD_ELE_NUM];
|
||
|
} TX_BUFFER_DESCRIPTOR, *PTX_BUFFER_DESCRIPTOR;
|
||
|
|
||
|
typedef struct _HCI_TX_DMA_QUEUE_STRUCT_88XX_
|
||
|
{
|
||
|
//TXBD
|
||
|
PTX_BUFFER_DESCRIPTOR pTXBD_head;
|
||
|
|
||
|
//TXBD Queue management
|
||
|
u2Byte hw_idx;
|
||
|
u2Byte host_idx;
|
||
|
|
||
|
//Two Method:
|
||
|
// 1.) TXDESC Only
|
||
|
// 2.) TXDESC + Payload
|
||
|
PVOID ptx_desc_head;
|
||
|
u2Byte total_txbd_num;
|
||
|
u2Byte avail_txbd_num;
|
||
|
|
||
|
// RWPtr IDX Reg
|
||
|
u4Byte reg_rwptr_idx;
|
||
|
} HCI_TX_DMA_QUEUE_STRUCT_88XX, *PHCI_TX_DMA_QUEUE_STRUCT_88XX;
|
||
|
|
||
|
typedef struct _HCI_TX_DMA_MANAGER_88XX_
|
||
|
{
|
||
|
HCI_TX_DMA_QUEUE_STRUCT_88XX tx_queue[HCI_TX_DMA_QUEUE_MAX_NUM];
|
||
|
} HCI_TX_DMA_MANAGER_88XX, *PHCI_TX_DMA_MANAGER_88XX;
|
||
|
|
||
|
//typedef struct _TXBD_INFO_
|
||
|
//{
|
||
|
// u4Byte Length;
|
||
|
// u4Byte AddrLow;
|
||
|
//} TXBD_INFO_88XX, *PTXBD_INFO_88XX;
|
||
|
|
||
|
typedef struct _TX_DESC_DATA_88XX_
|
||
|
{
|
||
|
// header
|
||
|
pu1Byte pHdr;
|
||
|
u4Byte hdrLen;
|
||
|
u4Byte llcLen;
|
||
|
|
||
|
// frame
|
||
|
pu1Byte pBuf;
|
||
|
u4Byte frLen;
|
||
|
|
||
|
// encryption
|
||
|
pu1Byte pMic;
|
||
|
pu1Byte pIcv;
|
||
|
|
||
|
// TXDESC Dword 1
|
||
|
u4Byte rateId;
|
||
|
u1Byte macId;
|
||
|
u1Byte tid;
|
||
|
BOOLEAN moreData;
|
||
|
|
||
|
// TXDESC Dword 2
|
||
|
BOOLEAN aggEn;
|
||
|
u1Byte ampduDensity;
|
||
|
BOOLEAN frag;
|
||
|
BOOLEAN bk;
|
||
|
u4Byte p_aid;
|
||
|
BOOLEAN g_id;
|
||
|
#if CFG_HAL_HW_AES_IV
|
||
|
BOOLEAN hwAESIv;
|
||
|
#endif
|
||
|
|
||
|
// TXDESC Dword 3
|
||
|
BOOLEAN RTSEn;
|
||
|
BOOLEAN HWRTSEn;
|
||
|
BOOLEAN CTS2Self;
|
||
|
BOOLEAN useRate;
|
||
|
BOOLEAN disRTSFB;
|
||
|
BOOLEAN disDataFB;
|
||
|
u1Byte maxAggNum;
|
||
|
BOOLEAN navUseHdr;
|
||
|
BOOLEAN ndpa;
|
||
|
|
||
|
// TXDESC Dword 4
|
||
|
u1Byte RTSRate;
|
||
|
u1Byte RTSRateFBLmt;
|
||
|
u1Byte dataRate;
|
||
|
BOOLEAN rtyLmtEn;
|
||
|
u1Byte dataRtyLmt;
|
||
|
u1Byte dataRateFBLmt;
|
||
|
|
||
|
// TXDESC Dword 5
|
||
|
u1Byte dataBW;
|
||
|
u1Byte dataSC;
|
||
|
u1Byte RTSSC;
|
||
|
u1Byte dataStbc;
|
||
|
u1Byte dataLdpc;
|
||
|
u1Byte dataShort;
|
||
|
u1Byte RTSShort;
|
||
|
u1Byte TXPowerOffset;
|
||
|
u1Byte TXAnt;
|
||
|
#if (CFG_HAL_HW_TX_SHORTCUT_REUSE_TXDESC || CFG_HAL_HW_TX_SHORTCUT_HDR_CONV)
|
||
|
// TXDESC Dword 8
|
||
|
BOOLEAN smhEn;
|
||
|
BOOLEAN stwEn;
|
||
|
BOOLEAN stwAntDis;
|
||
|
BOOLEAN stwRateDis;
|
||
|
BOOLEAN stwRbDis;
|
||
|
BOOLEAN stwPktReDis;
|
||
|
BOOLEAN macCp;
|
||
|
BOOLEAN txwifiCp;
|
||
|
#endif
|
||
|
|
||
|
// encrypt
|
||
|
u4Byte iv;
|
||
|
u4Byte icv;
|
||
|
u4Byte mic;
|
||
|
u4Byte secType;
|
||
|
BOOLEAN swCrypt;
|
||
|
|
||
|
} TX_DESC_DATA_88XX, *PTX_DESC_DATA_88XX;
|
||
|
|
||
|
VOID
|
||
|
TxPolling88XX(
|
||
|
IN HAL_PADAPTER Adapter,
|
||
|
IN u1Byte QueueIndex
|
||
|
);
|
||
|
|
||
|
VOID
|
||
|
SigninBeaconTXBD88XX
|
||
|
(
|
||
|
IN HAL_PADAPTER Adapter,
|
||
|
IN pu4Byte beaconbuf,
|
||
|
IN u2Byte frlen
|
||
|
);
|
||
|
|
||
|
VOID
|
||
|
SetBeaconDownload88XX (
|
||
|
IN HAL_PADAPTER Adapter,
|
||
|
IN u4Byte Value
|
||
|
);
|
||
|
|
||
|
u2Byte
|
||
|
GetTxQueueHWIdx88XX
|
||
|
(
|
||
|
IN HAL_PADAPTER Adapter,
|
||
|
IN u4Byte q_num //enum _TX_QUEUE_
|
||
|
);
|
||
|
|
||
|
BOOLEAN
|
||
|
FillTxHwCtrl88XX(
|
||
|
IN HAL_PADAPTER Adapter,
|
||
|
IN u4Byte queueIndex, //HCI_TX_DMA_QUEUE_88XX
|
||
|
IN PVOID pDescData
|
||
|
);
|
||
|
|
||
|
RT_STATUS
|
||
|
SyncSWTXBDHostIdxToHW88XX (
|
||
|
IN HAL_PADAPTER Adapter,
|
||
|
IN u4Byte queueIndex //HCI_TX_DMA_QUEUE_88XX
|
||
|
);
|
||
|
|
||
|
BOOLEAN
|
||
|
QueryTxConditionMatch88XX(
|
||
|
IN HAL_PADAPTER Adapter
|
||
|
);
|
||
|
|
||
|
RT_STATUS
|
||
|
PrepareTXBD88XX(
|
||
|
IN HAL_PADAPTER Adapter
|
||
|
);
|
||
|
|
||
|
VOID
|
||
|
FillBeaconDesc88XX
|
||
|
(
|
||
|
IN HAL_PADAPTER Adapter,
|
||
|
IN PVOID _pdesc,
|
||
|
IN PVOID data_content,
|
||
|
IN u2Byte txLength,
|
||
|
IN BOOLEAN bForceUpdate
|
||
|
);
|
||
|
|
||
|
VOID
|
||
|
GetBeaconTXBDTXDESC88XX(
|
||
|
IN HAL_PADAPTER Adapter,
|
||
|
OUT PTX_BUFFER_DESCRIPTOR *pTXBD,
|
||
|
OUT PTX_DESC_88XX *ptx_desc
|
||
|
);
|
||
|
|
||
|
#if CFG_HAL_TX_SHORTCUT
|
||
|
#if 0
|
||
|
PVOID
|
||
|
GetShortCutTxDesc88XX(
|
||
|
IN HAL_PADAPTER Adapter
|
||
|
);
|
||
|
|
||
|
VOID
|
||
|
ReleaseShortCutTxDesc88XX(
|
||
|
IN HAL_PADAPTER Adapter,
|
||
|
IN PVOID pTxDesc
|
||
|
);
|
||
|
#endif
|
||
|
|
||
|
VOID
|
||
|
SetShortCutTxBuffSize88XX(
|
||
|
IN HAL_PADAPTER Adapter,
|
||
|
IN PVOID pTxDesc,
|
||
|
IN u2Byte txPktSize
|
||
|
);
|
||
|
|
||
|
u2Byte
|
||
|
GetShortCutTxBuffSize88XX(
|
||
|
IN HAL_PADAPTER Adapter,
|
||
|
IN PVOID pTxDesc
|
||
|
);
|
||
|
|
||
|
PVOID
|
||
|
CopyShortCutTxDesc88XX(
|
||
|
IN HAL_PADAPTER Adapter,
|
||
|
IN u4Byte queueIndex, //HCI_TX_DMA_QUEUE_88XX
|
||
|
IN PVOID pTxDesc,
|
||
|
IN u4Byte direction
|
||
|
);
|
||
|
|
||
|
BOOLEAN
|
||
|
FillShortCutTxHwCtrl88XX(
|
||
|
IN HAL_PADAPTER Adapter,
|
||
|
IN u4Byte queueIndex, //HCI_TX_DMA_QUEUE_88XX
|
||
|
IN PVOID pDescData,
|
||
|
IN PVOID pTxDesc,
|
||
|
IN u4Byte direction
|
||
|
);
|
||
|
|
||
|
#endif // CFG_HAL_TX_SHORTCUT
|
||
|
|
||
|
void DumpTxBDesc88XX(
|
||
|
IN HAL_PADAPTER Adapter,
|
||
|
#ifdef CONFIG_RTL_PROC_NEW
|
||
|
IN struct seq_file *s,
|
||
|
#endif
|
||
|
IN u4Byte q_num
|
||
|
);
|
||
|
|
||
|
#endif //#ifndef __HAL88XX_TXDESC_H__
|
||
|
|
||
|
|