• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * txCtrl_Api.h
3  *
4  * Copyright(c) 1998 - 2009 Texas Instruments. All rights reserved.
5  * All rights reserved.
6  *
7  * Redistribution and use in source and binary forms, with or without
8  * modification, are permitted provided that the following conditions
9  * are met:
10  *
11  *  * Redistributions of source code must retain the above copyright
12  *    notice, this list of conditions and the following disclaimer.
13  *  * Redistributions in binary form must reproduce the above copyright
14  *    notice, this list of conditions and the following disclaimer in
15  *    the documentation and/or other materials provided with the
16  *    distribution.
17  *  * Neither the name Texas Instruments nor the names of its
18  *    contributors may be used to endorse or promote products derived
19  *    from this software without specific prior written permission.
20  *
21  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
24  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
25  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
26  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
27  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
28  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
29  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
30  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
31  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32  */
33 
34 
35 /***************************************************************************/
36 /*                                                                         */
37 /*    MODULE:   txCtrl_Api.h                                               */
38 /*    PURPOSE:  TxCtrl module API Header file                              */
39 /*                                                                         */
40 /***************************************************************************/
41 #ifndef _TX_CTRL_API_H_
42 #define _TX_CTRL_API_H_
43 
44 #include "GeneralUtilApi.h"
45 #include "DrvMainModules.h"
46 
47 /* TxCtrl Xmit results */
48 typedef enum
49 {
50     STATUS_XMIT_SUCCESS,
51     STATUS_XMIT_BUSY,
52     STATUS_XMIT_ERROR
53 } EStatusXmit;
54 
55 
56 typedef struct
57 {
58 	TI_BOOL    bHtEnable;	                        /* current flag of HT Capabilities enabled */
59     TI_UINT32  uTxCtrlHtControl;        	        /* The HT Control Field for futur use. for now empty and the FW set it */
60 } TtxCtrlHtControl;
61 
62 
63 /* Build the buffers descriptor of a typical two buffers (header & data) Tx packet */
64 #define BUILD_TX_TWO_BUF_PKT_BDL(pPktCtrlBlk, pHdrBuf, uHdrLen, pDataBuf, uDataLen)  \
65     pPktCtrlBlk->tTxnStruct.aBuf[0]   = (TI_UINT8 *) (pHdrBuf);    \
66     pPktCtrlBlk->tTxnStruct.aLen[0]   = (TI_UINT16 ) (uHdrLen);    \
67     pPktCtrlBlk->tTxnStruct.aBuf[1]   = (TI_UINT8 *) (pDataBuf);   \
68     pPktCtrlBlk->tTxnStruct.aLen[1]   = (TI_UINT16 ) (uDataLen);   \
69     pPktCtrlBlk->tTxnStruct.aLen[2]   = 0;                         \
70     pPktCtrlBlk->tTxDescriptor.length = (TI_UINT16)((uHdrLen) + (uDataLen));
71 
72 
73 /****************************************************************/
74 /*                  MODULE  PUBLIC  FUNCTIONS                   */
75 /****************************************************************/
76 
77 /*
78  *  The TxCtrl MAIN public functions (in txCtrl.c):
79  */
80 TI_HANDLE txCtrl_Create (TI_HANDLE hOs);
81 void      txCtrl_Init (TStadHandlesList *pStadHandles);
82 TI_STATUS txCtrl_SetDefaults (TI_HANDLE hTxCtrl, txDataInitParams_t *txDataInitParams);
83 TI_STATUS txCtrl_Unload (TI_HANDLE hTxCtrl);
84 TI_STATUS txCtrl_XmitData (TI_HANDLE hTxCtrl, TTxCtrlBlk *pPktCtrlBlk);
85 TI_STATUS txCtrl_XmitMgmt (TI_HANDLE hTxCtrl, TTxCtrlBlk *pPktCtrlBlk);
86 void      txCtrl_UpdateQueuesMapping (TI_HANDLE hTxCtrl);
87 void *    txCtrl_AllocPacketBuffer (TI_HANDLE hTxCtrl, TTxCtrlBlk *pPktCtrlBlk, TI_UINT32 uPacketLen);
88 void      txCtrl_FreePacket (TI_HANDLE hTxCtrl, TTxCtrlBlk *pPktCtrlBlk, TI_STATUS eStatus);
89 TI_STATUS txCtrl_NotifyFwReset(TI_HANDLE hTxCtrl);
90 TI_STATUS txCtrl_CheckForTxStuck(TI_HANDLE hTxCtrl);
91 TI_UINT32 txCtrl_BuildDataPktHdr (TI_HANDLE hTxCtrl, TTxCtrlBlk *pPktCtrlBlk, AckPolicy_e ackPolicy);
92 
93 
94 /*
95  *  The txCtrlParams.c sub-module public functions:
96  */
97 void      txCtrlParams_resetCounters(TI_HANDLE hTxCtrl);
98 TI_HANDLE txCtrlParams_RegNotif(TI_HANDLE hTxCtrl,
99                                 TI_UINT16 EventMask,
100                                 GeneralEventCall_t CallBack,
101                                 TI_HANDLE context,
102                                 TI_UINT32 Cookie);
103 TI_STATUS txCtrlParams_AddToNotifMask(TI_HANDLE hTxCtrl, TI_HANDLE Notifh, TI_UINT16 EventMask);
104 TI_STATUS txCtrlParams_UnRegNotif(TI_HANDLE hTxCtrl, TI_HANDLE RegEventHandle);
105 TI_STATUS txCtrlParams_setAdmissionCtrlParams(TI_HANDLE hTxCtrl,
106                                               TI_UINT8 acId,
107                                               TI_UINT16 mediumTime,
108                                               TI_UINT32 minimumPHYRate,
109                                               TI_BOOL admFlag);
110 TI_STATUS txCtrlParams_getParam(TI_HANDLE hTxCtrl, paramInfo_t *pParamInfo);
111 TI_STATUS txCtrlParams_setParam(TI_HANDLE hTxCtrl, paramInfo_t *pParamInfo);
112 TI_STATUS txCtrlParams_SetHtControl (TI_HANDLE hTxCtrl, TtxCtrlHtControl *pHtControl);
113 void txCtrlParams_setBssId (TI_HANDLE hTxCtrl, TMacAddr *pCurrBssId);
114 void txCtrlParams_setBssType (TI_HANDLE hTxCtrl, ScanBssType_e currBssType);
115 void txCtrlParams_setQosHeaderConverMode (TI_HANDLE hTxCtrl, EHeaderConvertMode  headerConverMode);
116 void txCtrlParams_setCurrentPrivacyInvokedMode (TI_HANDLE hTxCtrl, TI_BOOL currentPrivacyInvokedMode);
117 void txCtrlParams_setEapolEncryptionStatus (TI_HANDLE hTxCtrl, TI_BOOL eapolEncryptionStatus);
118 void txCtrlParams_setEncryptionFieldSizes (TI_HANDLE hTxCtrl, TI_UINT8 encryptionFieldSize);
119 void txCtrlParams_getCurrentEncryptionInfo (TI_HANDLE hTxCtrl,
120                                             TI_BOOL    *pCurrentPrivacyInvokedMode,
121                                             TI_UINT8   *pEncryptionFieldSize);
122 ERate txCtrlParams_GetTxRate (TI_HANDLE hTxCtrl);
123 void txCtrlParams_setAcAdmissionStatus (TI_HANDLE hTxCtrl,
124                                         TI_UINT8 ac,
125                                         EAdmissionState admissionRequired,
126                                         ETrafficAdmState admissionState);
127 void txCtrlParams_setAcMsduLifeTime (TI_HANDLE hTxCtrl, TI_UINT8 ac, TI_UINT32 msduLifeTime);
128 void txCtrlParams_setAcAckPolicy (TI_HANDLE hTxCtrl, TI_UINT8 ac, AckPolicy_e ackPolicy);
129 void txCtrlParams_updateMgmtRateAttributes(TI_HANDLE hTxCtrl, TI_UINT8 ratePolicyId, TI_UINT8 ac);
130 void txCtrlParams_updateDataRateAttributes(TI_HANDLE hTxCtrl, TI_UINT8 ratePolicyId, TI_UINT8 ac);
131 void txCtrlParams_updateTxSessionCount(TI_HANDLE hTxCtrl, TI_UINT16 txSessionCount);
132 #ifdef TI_DBG
133 void txCtrlParams_printInfo(TI_HANDLE hTxCtrl);
134 void txCtrlParams_printDebugCounters(TI_HANDLE hTxCtrl);
135 void txCtrlParams_resetDbgCounters(TI_HANDLE hTxCtrl);
136 #endif /* TI_DBG */
137 
138 
139 /*
140  *  The txCtrlServ.c sub-module public functions:
141  */
142 TI_STATUS txCtrlServ_buildNullFrame(TI_HANDLE hTxCtrl, TI_UINT8* pFrame, TI_UINT32* pLength);
143 TI_STATUS txCtrlServ_buildWlanHeader(TI_HANDLE hTxCtrl, TI_UINT8* pFrame, TI_UINT32* pLength);
144 
145 #endif /* _TX_CTRL_API_H_ */
146