Home | History | Annotate | Download | only in Ctrl
      1 /*
      2  * CmdBldCfg.c
      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 /** \file  CmdBldCfg.c
     36  *  \brief Command builder. Configuration commands
     37  *
     38  *  \see   CmdBld.h
     39  */
     40 #define __FILE_ID__  FILE_ID_91
     41 #include "osApi.h"
     42 #include "tidef.h"
     43 #include "report.h"
     44 #include "CmdBld.h"
     45 #include "CmdBldCfgIE.h"
     46 #include "TWDriverInternal.h"
     47 
     48 
     49 /****************************************************************************
     50  *                      cmdBld_CfgRx()
     51  ****************************************************************************
     52  * DESCRIPTION: Sets the filters according to the given configuration.
     53  *
     54  * INPUTS:  RxConfigOption  - The given Rx filters configuration
     55  *          RxFilterOption  - The given Rx filters options
     56  *
     57  * OUTPUT:  None
     58  *
     59  * RETURNS: TI_OK or TI_NOK
     60  ****************************************************************************/
     61 TI_STATUS cmdBld_CfgRx (TI_HANDLE hCmdBld, TI_UINT32 uRxConfigOption, TI_UINT32 uRxFilterOption, void *fCb, TI_HANDLE hCb)
     62 {
     63     DB_WLAN(hCmdBld).RxConfigOption = uRxConfigOption;
     64     DB_WLAN(hCmdBld).RxFilterOption = uRxFilterOption;
     65     DB_WLAN(hCmdBld).RxConfigOption |= RX_CFG_ENABLE_PHY_HEADER_PLCP;
     66   #if defined (TNETW_MASTER_MODE) || defined (TNETW_USB_MODE)
     67     DB_WLAN(hCmdBld).RxConfigOption |= RX_CFG_COPY_RX_STATUS;
     68   #endif
     69 
     70     if (DB_WLAN(hCmdBld).RxDisableBroadcast)
     71     {
     72         DB_WLAN(hCmdBld).RxConfigOption |= RX_CFG_DISABLE_BCAST;
     73     }
     74 
     75     return cmdBld_CfgIeRx (hCmdBld,
     76                            DB_WLAN(hCmdBld).RxConfigOption,
     77                            DB_WLAN(hCmdBld).RxFilterOption,
     78                            fCb,
     79                            hCb);
     80 }
     81 
     82 
     83 /****************************************************************************
     84  *                      cmdBld_CfgArpIpAddrTable()
     85  ****************************************************************************
     86  * DESCRIPTION: Sets the ARP IP table according to the given configuration.
     87  *
     88  * OUTPUT:  None
     89  *
     90  * RETURNS: TI_OK or TI_NOK
     91  ****************************************************************************/
     92 TI_STATUS cmdBld_CfgArpIpAddrTable (TI_HANDLE hCmdBld, TIpAddr tIpAddr, TI_UINT8 bEnabled, EIpVer eIpVer, void *fCb, TI_HANDLE hCb)
     93 {
     94     DB_WLAN(hCmdBld).arp_IP_ver = eIpVer;
     95 
     96     /* no support for IPV6 */
     97     if (eIpVer == IP_VER_4)
     98     {
     99         IP_COPY (DB_WLAN(hCmdBld).arp_IP_addr, tIpAddr);
    100     }
    101 
    102     DB_WLAN(hCmdBld).arpFilterType = (EArpFilterType)bEnabled;
    103 
    104     /* Set the new ip with the current state (e/d) */
    105     return cmdBld_CfgIeArpIpFilter (hCmdBld, tIpAddr, (EArpFilterType)bEnabled, fCb, hCb);
    106 }
    107 
    108  /****************************************************************************
    109  *                      cmdBld_CfgArpIpFilter()
    110  ****************************************************************************
    111  * DESCRIPTION: Enable\Disable the ARP filter
    112  *
    113  * OUTPUT:  None
    114  *
    115  * RETURNS: TI_OK or TI_NOK
    116  ****************************************************************************/
    117 TI_STATUS cmdBld_CfgArpIpFilter (TI_HANDLE hCmdBld, TIpAddr tIpAddr, void *fCb, TI_HANDLE hCb)
    118 {
    119     /* no support for IPV6 */
    120     IP_COPY (DB_WLAN(hCmdBld).arp_IP_addr, tIpAddr);
    121 
    122     return cmdBld_CfgIeArpIpFilter (hCmdBld,
    123                                     tIpAddr,
    124                                     DB_WLAN(hCmdBld).arpFilterType,
    125                                     fCb,
    126                                     hCb);
    127 }
    128 /****************************************************************************
    129  *                      cmdBld_CfgGroupAddressTable()
    130  ****************************************************************************
    131  * DESCRIPTION: Sets the Group table according to the given configuration.
    132  *
    133  * OUTPUT:  None
    134  *
    135  * RETURNS: TI_OK or TI_NOK
    136  ****************************************************************************/
    137 TI_STATUS cmdBld_CfgGroupAddressTable (TI_HANDLE        hCmdBld,
    138                                        TI_UINT8         uNumGroupAddr,
    139                                        TMacAddr         *pGroupAddr,
    140                                        TI_BOOL          bEnabled,
    141                                        void             *fCb,
    142                                        TI_HANDLE        hCb)
    143 {
    144     TCmdBld *pCmdBld = (TCmdBld *)hCmdBld;
    145     TI_UINT32    i;
    146 
    147     if (uNumGroupAddr > MAX_MULTICAST_GROUP_ADDRS)
    148     {
    149         TRACE1(pCmdBld->hReport, REPORT_SEVERITY_ERROR, "cmdBld_CfgGroupAddressTable: numGroupAddrs=%d\n", uNumGroupAddr);
    150         return PARAM_VALUE_NOT_VALID;
    151     }
    152 
    153     if (NULL == pGroupAddr)
    154     {
    155         TRACE2(pCmdBld->hReport, REPORT_SEVERITY_ERROR, "cmdBld_CfgGroupAddressTable: numGroupAddrs=%d Group_addr=0x%x  !!!\n", uNumGroupAddr, pGroupAddr);
    156         return PARAM_VALUE_NOT_VALID;
    157     }
    158 
    159     /* Keeps the parameters in the db */
    160     DB_WLAN(hCmdBld).numGroupAddrs = uNumGroupAddr;
    161     DB_WLAN(hCmdBld).isMacAddrFilteringnabled = bEnabled;
    162 
    163     for (i = 0; i < uNumGroupAddr; i++)
    164     {
    165         MAC_COPY (DB_WLAN(hCmdBld).aGroupAddr[i], *(pGroupAddr + i));
    166     }
    167 
    168     return cmdBld_CfgIeGroupAdressTable (hCmdBld, uNumGroupAddr, pGroupAddr, bEnabled, fCb, hCb);
    169 }
    170 
    171 
    172 /****************************************************************************
    173  *                      cmdBld_CfgRtsThreshold()
    174  ****************************************************************************
    175  * DESCRIPTION: Sets the Rts Threshold.
    176  *
    177  * OUTPUT:  None
    178  *
    179  * RETURNS: TI_OK or TI_NOK  pWlanParams->RtsThreshold
    180  ****************************************************************************/
    181 TI_STATUS cmdBld_CfgRtsThreshold (TI_HANDLE hCmdBld, TI_UINT16 threshold, void *fCb, TI_HANDLE hCb)
    182 {
    183     return cmdBld_CfgIeRtsThreshold (hCmdBld, threshold, fCb, hCb);
    184 }
    185 
    186 /****************************************************************************
    187  *                      cmdBld_CfgDcoItrimParams()
    188  ****************************************************************************
    189  * DESCRIPTION: Sets the DCO Itrim parameters.
    190  *
    191  * OUTPUT:  None
    192  *
    193  * RETURNS: TI_OK or TI_NOK
    194  ****************************************************************************/
    195 TI_STATUS cmdBld_CfgDcoItrimParams (TI_HANDLE hCmdBld, TI_BOOL enable, TI_UINT32 moderationTimeoutUsec, void *fCb, TI_HANDLE hCb)
    196 {
    197     /* Keeps the parameters in the db */
    198     DB_WLAN(hCmdBld).dcoItrimEnabled = enable;
    199     DB_WLAN(hCmdBld).dcoItrimModerationTimeoutUsec = moderationTimeoutUsec;
    200 
    201     return cmdBld_CfgIeDcoItrimParams (hCmdBld, enable, moderationTimeoutUsec, fCb, hCb);
    202 }
    203 
    204 /****************************************************************************
    205  *                      cmdBld_CfgFragmentThreshold()
    206  ****************************************************************************
    207  * DESCRIPTION: Sets the tx fragmentation Threshold.
    208  *
    209  * OUTPUT:  None
    210  *
    211  * RETURNS: TI_OK or TI_NOK
    212  ****************************************************************************/
    213 TI_STATUS cmdBld_CfgFragmentThreshold (TI_HANDLE hCmdBld, TI_UINT16 uFragmentThreshold, void *fCb, TI_HANDLE hCb)
    214 {
    215     DB_WLAN(hCmdBld).FragmentThreshold = uFragmentThreshold;
    216 
    217     return cmdBld_CfgIeFragmentThreshold (hCmdBld, uFragmentThreshold, fCb, hCb);
    218 }
    219 
    220 
    221 /****************************************************************************
    222  *                      cmdBld_CfgPreamble()
    223  ****************************************************************************
    224  * DESCRIPTION: Set the preamble in ?????? hardware register
    225  *
    226  * INPUTS:
    227  *      preambleVal
    228  *
    229  * OUTPUT:  None
    230  *
    231  * RETURNS: None
    232  ****************************************************************************/
    233 TI_STATUS cmdBld_CfgPreamble (TI_HANDLE hCmdBld, Preamble_e ePreamble, void *fCb, TI_HANDLE hCb)
    234 {
    235     DB_WLAN(hCmdBld).preamble = ePreamble;
    236 
    237     return cmdBld_CfgIePreamble (hCmdBld, (TI_UINT8)ePreamble, fCb, hCb);
    238 }
    239 
    240 
    241 /****************************************************************************
    242  *                      cmdBld_CfgBcnBrcOptions()
    243  ****************************************************************************
    244  * DESCRIPTION: Configure the wlan hardware
    245  *
    246  * INPUTS: None
    247  *
    248  * OUTPUT:  None
    249  *
    250  * RETURNS: TI_OK or TI_NOK
    251  ****************************************************************************/
    252 TI_STATUS cmdBld_CfgBcnBrcOptions (TI_HANDLE hCmdBld, TPowerMgmtConfig *pPMConfig, void *fCb, TI_HANDLE hCb)
    253 {
    254     return cmdBld_CfgIeBcnBrcOptions (hCmdBld, pPMConfig, fCb, hCb);
    255 }
    256 
    257 
    258 /****************************************************************************
    259  *                      cmdBld_CfgWakeUpCondition()
    260  ****************************************************************************
    261  * DESCRIPTION: Configure the wlan hardware
    262  *
    263  * INPUTS: None
    264  *
    265  * OUTPUT:  None
    266  *
    267  * RETURNS: TI_OK or TI_NOK
    268  ****************************************************************************/
    269 TI_STATUS cmdBld_CfgWakeUpCondition (TI_HANDLE hCmdBld, TPowerMgmtConfig *pPMConfig, void *fCb, TI_HANDLE hCb)
    270 {
    271     return cmdBld_CfgIeWakeUpCondition (hCmdBld, pPMConfig, fCb, hCb);
    272 }
    273 
    274 
    275 /****************************************************************************
    276  *                      cmdBld_CfgSleepAuth ()
    277  ****************************************************************************
    278  * DESCRIPTION: Set the min power level
    279  *
    280  * INPUTS:
    281  *
    282  * OUTPUT:
    283  *
    284  * RETURNS: TI_OK or TI_NOK
    285  ****************************************************************************/
    286 TI_STATUS cmdBld_CfgSleepAuth (TI_HANDLE hCmdBld, EPowerPolicy eMinPowerLevel, void *fCb, TI_HANDLE hCb)
    287 {
    288     /* Save th parameter in database */
    289     DB_WLAN(hCmdBld).minPowerLevel = eMinPowerLevel;
    290 
    291     return cmdBld_CfgIeSleepAuth (hCmdBld, eMinPowerLevel, fCb, hCb);
    292 }
    293 
    294 
    295 typedef enum { HW_CLOCK_40_MHZ = 40, HW_CLOCK_80_MHZ = 80 } EHwClock;
    296 
    297 
    298 /****************************************************************************
    299  *                      cmdBld_CfgArmClock()
    300  ****************************************************************************
    301  * DESCRIPTION: Configure the arm clock
    302  *  !!! Note that the firmware will set the slot time according to the new clock
    303  *
    304  * INPUTS: None
    305  *
    306  * OUTPUT:  None
    307  *
    308  * RETURNS: TI_OK or TI_NOK
    309  ****************************************************************************/
    310 TI_STATUS cmdBld_CfgArmClock (TI_HANDLE hCmdBld, TI_UINT32 uArmClock, void *fCb, TI_HANDLE hCb)
    311 {
    312     TCmdBld *pCmdBld = (TCmdBld *)hCmdBld;
    313     TWlanParams *pWlanParams = &DB_WLAN(hCmdBld);
    314 
    315     pWlanParams->ArmClock = uArmClock;
    316 
    317     /* Illegal combination Mac=80, Arm=40 ==> force setting 40/40*/
    318     if (pWlanParams->MacClock == HW_CLOCK_80_MHZ && pWlanParams->ArmClock == HW_CLOCK_40_MHZ)
    319     {
    320         TRACE0(pCmdBld->hReport, REPORT_SEVERITY_ERROR, "cmdBld_ArmClockSet: Illegal combination Mac=80, Arm=40 ==> force setting 40/40\n");
    321         pWlanParams->MacClock = HW_CLOCK_40_MHZ;
    322     }
    323 
    324     return cmdBld_CfgIeFeatureConfig (hCmdBld,
    325                                       pWlanParams->FeatureOptions,
    326                                       pWlanParams->FeatureDataFlowOptions,
    327                                       fCb,
    328                                       hCb);
    329 }
    330 
    331 
    332 /****************************************************************************
    333  *                      cmdBld_CfgMacClock()
    334  ****************************************************************************
    335  * DESCRIPTION: Configure the mac clock
    336  *  !!! Note that the firmware will set the slot time according to the new clock
    337  *
    338  * INPUTS: None
    339  *
    340  * OUTPUT:  None
    341  *
    342  * RETURNS: TI_OK or TI_NOK
    343  ****************************************************************************/
    344 TI_STATUS cmdBld_CfgMacClock (TI_HANDLE hCmdBld, TI_UINT32 uMacClock, void *fCb, TI_HANDLE hCb)
    345 {
    346     TCmdBld *pCmdBld = (TCmdBld *)hCmdBld;
    347     TWlanParams *pWlanParams = &DB_WLAN(hCmdBld);
    348 
    349     pWlanParams->MacClock = uMacClock;
    350 
    351     /* Force same clock - for printing */
    352     pWlanParams->ArmClock = uMacClock;
    353 
    354     /* Illegal combination Mac=80, Arm=40 ==> force setting 40/40*/
    355     if (pWlanParams->MacClock == HW_CLOCK_80_MHZ && pWlanParams->ArmClock == HW_CLOCK_40_MHZ)
    356     {
    357         TRACE0(pCmdBld->hReport, REPORT_SEVERITY_ERROR, "cmdBld_MacClockSet: Illegal combination Mac=80, Arm=40 ==> force setting 40/40\n");
    358         pWlanParams->MacClock = HW_CLOCK_40_MHZ;
    359     }
    360 
    361     return cmdBld_CfgIeFeatureConfig (hCmdBld,
    362                                       pWlanParams->FeatureOptions,
    363                                       pWlanParams->FeatureDataFlowOptions,
    364                                       fCb,
    365                                       hCb);
    366 }
    367 
    368 
    369 /****************************************************************************
    370  *                      cmdBld_CfgAid()
    371  ****************************************************************************
    372  * DESCRIPTION: Set the AID
    373  *
    374  * INPUTS:
    375  *
    376  * OUTPUT:
    377  *
    378  * RETURNS: TI_OK or TI_NOK
    379  ****************************************************************************/
    380 TI_STATUS cmdBld_CfgAid (TI_HANDLE hCmdBld, TI_UINT16 uAidVal, void *fCb, TI_HANDLE hCb)
    381 {
    382     return cmdBld_CfgIeAid (hCmdBld, uAidVal, fCb, hCb);
    383 }
    384 
    385 TI_STATUS cmdBld_CfgClkRun (TI_HANDLE hCmdBld, TI_BOOL aClkRunEnable, void *fCb, TI_HANDLE hCb)
    386 {
    387     TWlanParams *pWlanParams = &DB_WLAN(hCmdBld);
    388 
    389     if (aClkRunEnable)
    390     {
    391         pWlanParams->FeatureDataFlowOptions |= FEAT_PCI_CLK_RUN_ENABLE;
    392     }
    393     else
    394     {
    395         pWlanParams->FeatureDataFlowOptions &= ~FEAT_PCI_CLK_RUN_ENABLE;
    396     }
    397 
    398     return cmdBld_CfgIeFeatureConfig (hCmdBld,
    399                                       pWlanParams->FeatureOptions,
    400                                       pWlanParams->FeatureDataFlowOptions,
    401                                       fCb,
    402                                       hCb);
    403 }
    404 
    405 
    406 TI_STATUS cmdBld_CfgRxMsduFormat (TI_HANDLE hCmdBld, TI_BOOL bRxMsduForamtEnable, void *fCb, TI_HANDLE hCb)
    407 {
    408 #if 1
    409     /* WARNING:  Have to check how to control the Rx Frame format select (which bit)
    410                  and then access the HW*/
    411     return TI_OK;
    412 #else
    413     TCmdBld *pCmdBld = (TCmdBld *)hCmdBld;
    414     TWlanParams *pWlanParams = &DB_WLAN(hCmdBld);
    415 
    416     if (aRxMsduForamtEnable)
    417     {
    418         pWlanParams->FeatureDataFlowOptions |= DATA_FLOW_RX_MSDU_FRAME;
    419     }
    420     else
    421     {
    422         pWlanParams->FeatureDataFlowOptions &= ~DATA_FLOW_RX_MSDU_FRAME;
    423     }
    424 
    425     return cmdBld_CfgIeFeatureConfig (hCmdBld,
    426                                       pWlanParams->FeatureOptions,
    427                                       pWlanParams->FeatureDataFlowOptions,
    428                                       fCb,
    429                                       hCb);
    430 #endif
    431 }
    432 
    433 
    434 /****************************************************************************
    435  *                      cmdBld_CfgTid()
    436  ****************************************************************************
    437  * DESCRIPTION: configure Queue traffic params
    438  *
    439  * INPUTS: None
    440  *
    441  * OUTPUT:  None
    442  *
    443  * RETURNS: TI_OK or TI_NOK
    444  ****************************************************************************/
    445 TI_STATUS cmdBld_CfgTid (TI_HANDLE hCmdBld, TQueueTrafficParams *pQtrafficParams, void *fCb, TI_HANDLE hCb)
    446 {
    447     DB_QUEUES(hCmdBld).isQueueConfigured[pQtrafficParams->queueID] = TI_TRUE;
    448     DB_QUEUES(hCmdBld).queues[pQtrafficParams->queueID] = *pQtrafficParams;
    449 
    450     return cmdBld_CfgIeTid (hCmdBld, pQtrafficParams, fCb, hCb);
    451 }
    452 
    453 
    454 /****************************************************************************
    455  *                      cmdBld_CfgAcParams()
    456  ****************************************************************************
    457  * DESCRIPTION: configure AC params
    458  *
    459  * INPUTS: None
    460  *
    461  * OUTPUT:  None
    462  *
    463  * RETURNS: TI_OK or TI_NOK
    464  ****************************************************************************/
    465 TI_STATUS cmdBld_CfgAcParams (TI_HANDLE hCmdBld, TAcQosParams *pAcQosParams, void *fCb, TI_HANDLE hCb)
    466 {
    467     DB_AC(hCmdBld).isAcConfigured[pAcQosParams->ac] = TI_TRUE;
    468     DB_AC(hCmdBld).ac[pAcQosParams->ac] = *pAcQosParams;
    469 
    470     return cmdBld_CfgIeAcParams (hCmdBld, pAcQosParams, fCb, hCb);
    471 }
    472 
    473 
    474 /****************************************************************************
    475  *                      cmdBld_CfgPsRxStreaming()
    476  ****************************************************************************
    477  * DESCRIPTION: configure PS-Rx-Streaming params
    478  *
    479  * INPUTS: None
    480  *
    481  * OUTPUT:  None
    482  *
    483  * RETURNS: TI_OK or TI_NOK
    484  ****************************************************************************/
    485 TI_STATUS cmdBld_CfgPsRxStreaming (TI_HANDLE hCmdBld, TPsRxStreaming *pPsRxStreaming, void *fCb, TI_HANDLE hCb)
    486 {
    487     DB_PS_STREAM(hCmdBld).tid[pPsRxStreaming->uTid] = *pPsRxStreaming;
    488 
    489     return cmdBld_CfgIePsRxStreaming (hCmdBld, pPsRxStreaming, fCb, hCb);
    490 }
    491 
    492 
    493 /****************************************************************************
    494  *                     cmdBld_CfgPacketDetectionThreshold
    495  ****************************************************************************
    496  * DESCRIPTION: Sets Packet Detection Threshold
    497  *
    498  * INPUTS:  None
    499  *
    500  * OUTPUT:  None
    501  *
    502  * RETURNS: TI_OK or TI_NOK
    503  ****************************************************************************/
    504 TI_STATUS cmdBld_CfgPacketDetectionThreshold (TI_HANDLE hCmdBld, TI_UINT32 threshold, void *fCb, TI_HANDLE hCb)
    505 {
    506     DB_WLAN(hCmdBld).PacketDetectionThreshold = threshold;
    507 
    508     return cmdBld_CfgIePacketDetectionThreshold (hCmdBld, threshold, fCb, hCb);
    509 }
    510 
    511 
    512 /****************************************************************************
    513  *                     cmdBld_CfgBeaconFilterOpt
    514  ****************************************************************************
    515  * DESCRIPTION: Sets Beacon filtering state
    516  *
    517  * INPUTS:  None
    518  *
    519  * OUTPUT:  None
    520  *
    521  * RETURNS: TI_OK or TI_NOK
    522  ****************************************************************************/
    523 TI_STATUS cmdBld_CfgBeaconFilterOpt (TI_HANDLE  hCmdBld,
    524                                      TI_UINT8   uBeaconFilteringStatus,
    525                                      TI_UINT8   uNumOfBeaconsToBuffer,
    526                                      void       *fCb,
    527                                      TI_HANDLE  hCb)
    528 {
    529     DB_WLAN(hCmdBld).beaconFilterParams.desiredState = uBeaconFilteringStatus;
    530     DB_WLAN(hCmdBld).beaconFilterParams.numOfElements = uNumOfBeaconsToBuffer;
    531 
    532     return cmdBld_CfgIeBeaconFilterOpt (hCmdBld,
    533                                         uBeaconFilteringStatus,
    534                                         uNumOfBeaconsToBuffer,
    535                                         fCb,
    536                                         hCb);
    537 }
    538 
    539 /****************************************************************************
    540  *                     cmdBld_CfgRateMngDbg
    541  ****************************************************************************
    542  * DESCRIPTION: Sets rate managment params
    543  *
    544  * INPUTS:  None
    545  *
    546  * OUTPUT:  None
    547  *
    548  * RETURNS: TI_OK or TI_NOK
    549  ****************************************************************************/
    550 
    551 TI_STATUS cmdBld_CfgRateMngDbg (TI_HANDLE  hCmdBld,
    552                                 RateMangeParams_t *pRateMngParams ,
    553                                 void       *fCb,
    554                                 TI_HANDLE  hCb)
    555 {
    556 
    557 	TRateMngParams      *pRateMngParamsDB = &DB_RM(hCmdBld);
    558 	int uIndex;
    559 
    560 	pRateMngParamsDB->rateMngParams.paramIndex = pRateMngParams->paramIndex;
    561 
    562 	 switch (pRateMngParams->paramIndex)
    563 		{
    564 		case RATE_MGMT_RETRY_SCORE_PARAM:
    565 			pRateMngParamsDB->rateMngParams.RateRetryScore = pRateMngParams->RateRetryScore;
    566 			break;
    567 		case RATE_MGMT_PER_ADD_PARAM:
    568 			pRateMngParamsDB->rateMngParams.PerAdd = pRateMngParams->PerAdd;
    569 			break;
    570 		case RATE_MGMT_PER_TH1_PARAM:
    571 			pRateMngParamsDB->rateMngParams.PerTh1 = pRateMngParams->PerTh1;
    572 			break;
    573 		case RATE_MGMT_PER_TH2_PARAM:
    574 			pRateMngParamsDB->rateMngParams.PerTh2 = pRateMngParams->PerTh2;
    575 			break;
    576 		case RATE_MGMT_MAX_PER_PARAM:
    577 			pRateMngParamsDB->rateMngParams.MaxPer = pRateMngParams->MaxPer;
    578 			break;
    579 		case RATE_MGMT_INVERSE_CURIOSITY_FACTOR_PARAM:
    580 			pRateMngParamsDB->rateMngParams.InverseCuriosityFactor = pRateMngParams->InverseCuriosityFactor;
    581 			break;
    582 		case RATE_MGMT_TX_FAIL_LOW_TH_PARAM:
    583 			pRateMngParamsDB->rateMngParams.TxFailLowTh = pRateMngParams->TxFailLowTh;
    584 			break;
    585 		case RATE_MGMT_TX_FAIL_HIGH_TH_PARAM:
    586 			pRateMngParamsDB->rateMngParams.TxFailHighTh = pRateMngParams->TxFailHighTh;
    587 			break;
    588 		case RATE_MGMT_PER_ALPHA_SHIFT_PARAM:
    589 			pRateMngParamsDB->rateMngParams.PerAlphaShift = pRateMngParams->PerAlphaShift;
    590 			break;
    591 		case RATE_MGMT_PER_ADD_SHIFT_PARAM:
    592 			pRateMngParamsDB->rateMngParams.PerAddShift = pRateMngParams->PerAddShift;
    593 			break;
    594 		case RATE_MGMT_PER_BETA1_SHIFT_PARAM:
    595 			pRateMngParamsDB->rateMngParams.PerBeta1Shift = pRateMngParams->PerBeta1Shift;
    596 			break;
    597 		case RATE_MGMT_PER_BETA2_SHIFT_PARAM:
    598 			pRateMngParamsDB->rateMngParams.PerBeta2Shift = pRateMngParams->PerBeta2Shift;
    599 			break;
    600 		case RATE_MGMT_RATE_CHECK_UP_PARAM:
    601 			pRateMngParamsDB->rateMngParams.RateCheckUp = pRateMngParams->RateCheckUp;
    602 			break;
    603 		case RATE_MGMT_RATE_CHECK_DOWN_PARAM:
    604 			pRateMngParamsDB->rateMngParams.RateCheckDown = pRateMngParams->RateCheckDown;
    605 			break;
    606 	    case RATE_MGMT_RATE_RETRY_POLICY_PARAM:
    607 			for (uIndex = 0; uIndex < 13; uIndex++)
    608 				{
    609 					pRateMngParamsDB->rateMngParams.RateRetryPolicy[uIndex] = pRateMngParams->RateRetryPolicy[uIndex];
    610 				}
    611 			break;
    612 	 }
    613 
    614 
    615     return cmdBld_CfgIeRateMngDbg (hCmdBld,
    616                                    pRateMngParams,
    617                                    fCb,
    618                                    hCb);
    619 
    620 }
    621 
    622 
    623 /****************************************************************************
    624  *                     cmdBld_CfgBeaconFilterTable
    625  ****************************************************************************
    626  * DESCRIPTION: Sets Beacon filtering state
    627  *
    628  * INPUTS:  None
    629  *
    630  * OUTPUT:  None
    631  *
    632  * RETURNS: TI_OK or TI_NOK
    633  ****************************************************************************/
    634 TI_STATUS cmdBld_CfgBeaconFilterTable (TI_HANDLE    hCmdBld,
    635                                        TI_UINT8     uNumberOfIEs,
    636                                        TI_UINT8     *pIETable,
    637                                        TI_UINT8     uIETableSize,
    638                                        void         *fCb,
    639                                        TI_HANDLE    hCb)
    640 {
    641     TCmdBld   *pCmdBld = (TCmdBld *)hCmdBld;
    642 
    643     if (uIETableSize > BEACON_FILTER_TABLE_MAX_SIZE)
    644     {
    645         TRACE2(pCmdBld->hReport, REPORT_SEVERITY_ERROR, "cmdBld_CfgBeaconFilterTable: Table size is too big %d (>%d)\n", uIETableSize, BEACON_FILTER_TABLE_MAX_SIZE);
    646 
    647         return PARAM_VALUE_NOT_VALID;
    648     }
    649 
    650     os_memoryZero (pCmdBld->hOs,
    651                    (void *)DB_WLAN(hCmdBld).beaconFilterIETable.IETable,
    652                    BEACON_FILTER_TABLE_MAX_SIZE);
    653     os_memoryCopy (pCmdBld->hOs,
    654                    (void *)DB_WLAN(hCmdBld).beaconFilterIETable.IETable,
    655                    (void *)pIETable,
    656                    uIETableSize);
    657     DB_WLAN(hCmdBld).beaconFilterIETable.numberOfIEs = uNumberOfIEs;
    658     DB_WLAN(hCmdBld).beaconFilterIETable.IETableSize = uIETableSize;
    659 
    660     return cmdBld_CfgIeBeaconFilterTable (hCmdBld, uNumberOfIEs, pIETable, uIETableSize, fCb, hCb);
    661 }
    662 
    663 
    664 /*----------------------------------------*/
    665 /* Roaming Trigger Configuration Commands */
    666 /*----------------------------------------*/
    667 
    668 /****************************************************************************
    669  *                      cmdBld_CfgRssiSnrTrigger()
    670  ****************************************************************************
    671  * DESCRIPTION: Set the RSSI/SNR Trigger parameters.
    672  *
    673  * INPUTS:
    674  *
    675  * OUTPUT:  None
    676  *
    677  * RETURNS: None
    678  ****************************************************************************/
    679 TI_STATUS cmdBld_CfgRssiSnrTrigger (TI_HANDLE hCmdBld, RssiSnrTriggerCfg_t *pTriggerParam, void *fCb, TI_HANDLE hCb)
    680 {
    681     DB_WLAN(hCmdBld).tRssiSnrTrigger[pTriggerParam->index].index     = pTriggerParam->index;
    682     DB_WLAN(hCmdBld).tRssiSnrTrigger[pTriggerParam->index].threshold = pTriggerParam->threshold;
    683     DB_WLAN(hCmdBld).tRssiSnrTrigger[pTriggerParam->index].pacing    = pTriggerParam->pacing;
    684     DB_WLAN(hCmdBld).tRssiSnrTrigger[pTriggerParam->index].metric    = pTriggerParam->metric;
    685     DB_WLAN(hCmdBld).tRssiSnrTrigger[pTriggerParam->index].type      = pTriggerParam->type;
    686     DB_WLAN(hCmdBld).tRssiSnrTrigger[pTriggerParam->index].direction = pTriggerParam->direction;
    687     DB_WLAN(hCmdBld).tRssiSnrTrigger[pTriggerParam->index].hystersis = pTriggerParam->hystersis;
    688     DB_WLAN(hCmdBld).tRssiSnrTrigger[pTriggerParam->index].enable    = pTriggerParam->enable;
    689 
    690     return cmdBld_CfgIeRssiSnrTrigger (hCmdBld, pTriggerParam, fCb, hCb);
    691 }
    692 
    693 
    694 /****************************************************************************
    695  *                      cmdBld_CfgRssiSnrWeights()
    696  ****************************************************************************
    697  * DESCRIPTION: Set RSSI/SNR Weights for Average calculations.
    698  *
    699  * INPUTS:
    700  *
    701  * OUTPUT:  None
    702  *
    703  * RETURNS: None
    704  ****************************************************************************/
    705 TI_STATUS cmdBld_CfgRssiSnrWeights (TI_HANDLE hCmdBld, RssiSnrAverageWeights_t *pWeightsParam, void *fCb, TI_HANDLE hCb)
    706 {
    707     TCmdBld *pCmdBld = (TCmdBld *)hCmdBld;
    708 
    709     TRACE4(pCmdBld->hReport, REPORT_SEVERITY_INFORMATION , "\n cmdBld_CfgRssiSnrWeights :\n                             uRssiBeaconAverageWeight = %d\n                             uRssiPacketAverageWeight = %d\n                             uSnrBeaconAverageWeight  = %d\n                             uSnrPacketAverageWeight = %d \n ", pWeightsParam->rssiBeaconAverageWeight, pWeightsParam->rssiPacketAverageWeight, pWeightsParam->snrBeaconAverageWeight , pWeightsParam->snrPacketAverageWeight  );
    710 
    711     DB_WLAN(hCmdBld).tRssiSnrWeights.rssiBeaconAverageWeight = pWeightsParam->rssiBeaconAverageWeight;
    712     DB_WLAN(hCmdBld).tRssiSnrWeights.rssiPacketAverageWeight = pWeightsParam->rssiPacketAverageWeight;
    713     DB_WLAN(hCmdBld).tRssiSnrWeights.snrBeaconAverageWeight  = pWeightsParam->snrBeaconAverageWeight ;
    714     DB_WLAN(hCmdBld).tRssiSnrWeights.snrPacketAverageWeight  = pWeightsParam->snrPacketAverageWeight ;
    715 
    716     return cmdBld_CfgIeRssiSnrWeights (hCmdBld, pWeightsParam, fCb, hCb);
    717 }
    718 
    719 
    720 /****************************************************************************
    721  *                      cmdBld_CfgMaxTxRetry()
    722  ****************************************************************************
    723  * DESCRIPTION: Set Max Tx retry parmaters.
    724  *
    725  * INPUTS:
    726  *      maxTxRetry             max Tx Retry
    727  *
    728  * OUTPUT:  None
    729  *
    730  * RETURNS: None
    731  ****************************************************************************/
    732 TI_STATUS cmdBld_CfgMaxTxRetry (TI_HANDLE hCmdBld, TRroamingTriggerParams *pRoamingTriggerCmd, void *fCb, TI_HANDLE hCb)
    733 {
    734     DB_WLAN(hCmdBld).roamTriggers.maxTxRetry = pRoamingTriggerCmd->maxTxRetry;
    735 
    736     return cmdBld_CfgIeMaxTxRetry (hCmdBld, pRoamingTriggerCmd, fCb, hCb);
    737 }
    738 
    739 
    740 /****************************************************************************
    741  *                      cmdBld_CfgSgEnable()
    742  ****************************************************************************
    743  * DESCRIPTION: Save Soft Gemini enable parameter
    744  *
    745  * INPUTS:
    746  *
    747  * OUTPUT:
    748  *
    749  * RETURNS: TI_OK or TI_NOK
    750  ****************************************************************************/
    751 TI_STATUS cmdBld_CfgSgEnable (TI_HANDLE hCmdBld, ESoftGeminiEnableModes eSgEnable, void *fCb, TI_HANDLE hCb)
    752 {
    753     DB_WLAN(hCmdBld).SoftGeminiEnable = eSgEnable;
    754 
    755     return cmdBld_CfgIeSgEnable (hCmdBld, eSgEnable, fCb, hCb);
    756 }
    757 
    758 
    759 /****************************************************************************
    760  *                      cmdBld_CfgSg()
    761  ****************************************************************************
    762  * DESCRIPTION: Save Soft Gemini config parameter
    763  *
    764  * INPUTS:
    765  *
    766  * OUTPUT:
    767  *
    768  * RETURNS: TI_OK or TI_NOK
    769  ****************************************************************************/
    770 TI_STATUS cmdBld_CfgSg (TI_HANDLE hCmdBld, TSoftGeminiParams *pSgParam, void *fCb, TI_HANDLE hCb)
    771 {
    772     TCmdBld *pCmdBld = (TCmdBld *)hCmdBld;
    773 
    774     /* Copy params for recovery */
    775     os_memoryCopy (pCmdBld->hOs,
    776                    (void*)&DB_WLAN(hCmdBld).SoftGeminiParams,
    777                    (void*)pSgParam,
    778                    sizeof(TSoftGeminiParams));
    779 
    780     return cmdBld_CfgIeSg (hCmdBld, pSgParam, fCb, hCb);
    781 }
    782 
    783 /****************************************************************************
    784  *                      cmdBld_CfgCoexActivity()
    785  ****************************************************************************
    786  * DESCRIPTION: Sets the CoexActivity table.
    787  *
    788  * OUTPUT:  None
    789  *
    790  * RETURNS: TI_OK or TI_NOK  pWlanParams->RtsThreshold
    791  ****************************************************************************/
    792 TI_STATUS cmdBld_CfgCoexActivity (TI_HANDLE hCmdBld, TCoexActivity *pCoexActivity, void *fCb, TI_HANDLE hCb)
    793 {
    794     TCmdBld *pCmdBld = (TCmdBld *)hCmdBld;
    795     TWlanParams *pWlanParams = &DB_WLAN(hCmdBld);
    796     TCoexActivity *pSaveCoex = &pWlanParams->tWlanParamsCoexActivityTable.entry[0];
    797     int numOfElements = pWlanParams->tWlanParamsCoexActivityTable.numOfElements;
    798     int i;
    799 
    800     /* Check if to overwrite existing entry or put on last index */
    801     for (i=0; i<numOfElements; i++)
    802     {
    803         if ((pSaveCoex[i].activityId == pCoexActivity->activityId) && (pSaveCoex->coexIp == pCoexActivity->coexIp))
    804         {
    805             break;
    806         }
    807     }
    808 
    809     TRACE4(pCmdBld->hReport, REPORT_SEVERITY_INFORMATION , "cmdBld_CfgCoexActivity: save Param %d in index %d, %d %d\n", 0, i, pCoexActivity->coexIp, pCoexActivity->activityId);
    810     /* save in WlanParams for recovery */
    811     pSaveCoex[i].coexIp          = pCoexActivity->coexIp;
    812     pSaveCoex[i].activityId      = pCoexActivity->activityId;
    813     pSaveCoex[i].defaultPriority = pCoexActivity->defaultPriority;
    814     pSaveCoex[i].raisedPriority  = pCoexActivity->raisedPriority;
    815     pSaveCoex[i].minService      = pCoexActivity->minService;
    816     pSaveCoex[i].maxService      = pCoexActivity->maxService;
    817 
    818     if (i == numOfElements)
    819     {
    820         /* no existing entry overwrite, increment number of elements */
    821         pWlanParams->tWlanParamsCoexActivityTable.numOfElements++;
    822     }
    823 
    824     return cmdBld_CfgIeCoexActivity (hCmdBld, pCoexActivity, fCb, hCb);
    825 }
    826 
    827 /****************************************************************************
    828  *                      cmdBld_CfgFmCoex()
    829  ****************************************************************************
    830  * DESCRIPTION: Save and configure FM coexistence parameters
    831  *
    832  * INPUTS:
    833  *
    834  * OUTPUT:
    835  *
    836  * RETURNS: TI_OK or TI_NOK
    837  ****************************************************************************/
    838 TI_STATUS cmdBld_CfgFmCoex (TI_HANDLE hCmdBld, TFmCoexParams *pFmCoexParams, void *fCb, TI_HANDLE hCb)
    839 {
    840     TCmdBld *pCmdBld = (TCmdBld *)hCmdBld;
    841 
    842     /* Copy params for recovery */
    843     os_memoryCopy (pCmdBld->hOs,
    844                    (void*)&(DB_WLAN(hCmdBld).tFmCoexParams),
    845                    (void*)pFmCoexParams,
    846                    sizeof(TFmCoexParams));
    847 
    848     return cmdBld_CfgIeFmCoex (hCmdBld, pFmCoexParams, fCb, hCb);
    849 }
    850 
    851 /****************************************************************************
    852  *                      cmdBld_CfgTxRatePolicy()
    853  ****************************************************************************
    854  * DESCRIPTION: configure TxRatePolicy params
    855  *
    856  * INPUTS: None
    857  *
    858  * OUTPUT:  None
    859  *
    860  * RETURNS: TI_OK or TI_NOK
    861  ****************************************************************************/
    862 TI_STATUS cmdBld_CfgTxRatePolicy (TI_HANDLE hCmdBld, TTxRatePolicy *pTxRatePolicy, void *fCb, TI_HANDLE hCb)
    863 {
    864     TCmdBld       *pCmdBld      = (TCmdBld *)hCmdBld;
    865     TTxRateClass  *pTxRateClass = pTxRatePolicy->rateClass;
    866     TI_UINT8       index;
    867 
    868     TRACE1(pCmdBld->hReport, REPORT_SEVERITY_INFORMATION, "_1, Num of classes = 0x%x\n", pTxRatePolicy->numOfRateClasses);
    869 
    870     DB_BSS(hCmdBld).TxRateClassParams.numOfRateClasses = pTxRatePolicy->numOfRateClasses;
    871 
    872     for (index = 0; index < pTxRatePolicy->numOfRateClasses; index++, pTxRateClass++)
    873     {
    874         TRACE4(pCmdBld->hReport, REPORT_SEVERITY_INFORMATION, "_2loop, Index = %d, Short R = 0x%x, Long R = 0x%x, Rates = 0x%x\n", index, pTxRateClass->shortRetryLimit, pTxRateClass->longRetryLimit, pTxRateClass->txEnabledRates);
    875 
    876         DB_BSS(hCmdBld).TxRateClassParams.rateClass[index] = *pTxRateClass;
    877     }
    878 
    879     return cmdBld_CfgIeTxRatePolicy (hCmdBld, pTxRatePolicy, fCb, hCb);
    880 }
    881 
    882 
    883 TI_STATUS cmdBld_CfgSlotTime (TI_HANDLE hCmdBld, ESlotTime eSlotTime, void *fCb, TI_HANDLE hCb)
    884 {
    885     TCmdBld *pCmdBld = (TCmdBld *)hCmdBld;
    886 
    887     DB_WLAN(hCmdBld).SlotTime = eSlotTime;
    888 
    889     TRACE1(pCmdBld->hReport, REPORT_SEVERITY_INFORMATION, "cmdBld_CfgSlotTime: Slot time = %d\n", eSlotTime);
    890 
    891     /* Configure the new Slot-Time value to the FW. */
    892     return cmdBld_CfgIeSlotTime (hCmdBld, (TI_UINT8)eSlotTime, fCb, hCb);
    893 }
    894 
    895 
    896 TI_STATUS cmdBld_CfgEventMask (TI_HANDLE hCmdBld, TI_UINT32 uEventMask, void *fCb, TI_HANDLE hCb)
    897 {
    898     return cmdBld_CfgIeEventMask (hCmdBld, uEventMask, fCb, hCb);
    899 }
    900 
    901 
    902 /*
    903  * ----------------------------------------------------------------------------
    904  * Function : cmdBld_CfgHwEncEnable
    905  *
    906  * Input    :
    907  * Output   :
    908  * Process  :
    909  * Note(s)  :
    910  * -----------------------------------------------------------------------------
    911  */
    912 TI_STATUS cmdBld_CfgHwEncEnable (TI_HANDLE hCmdBld, TI_BOOL bHwEncEnable, TI_BOOL bHwDecEnable, void *fCb, TI_HANDLE hCb)
    913 {
    914     TCmdBld     *pCmdBld = (TCmdBld *)hCmdBld;
    915     TWlanParams *pWlanParams = &DB_WLAN(hCmdBld);
    916 
    917     /* Store the HW encryption Enable flag for reconfigure time (FW reload)*/
    918     DB_KEYS(pCmdBld).bReconfHwEncEnable = bHwEncEnable;
    919     DB_KEYS(pCmdBld).bHwEncDecrEnableValid = TI_TRUE;
    920 
    921     if (bHwEncEnable)
    922     {
    923         pWlanParams->FeatureDataFlowOptions &= ~DF_ENCRYPTION_DISABLE;
    924     }
    925     else
    926     {
    927         pWlanParams->FeatureDataFlowOptions |= DF_ENCRYPTION_DISABLE;
    928     }
    929 
    930     /* Set bit DF_SNIFF_MODE_ENABLE to enable or prevent decryption in fw */
    931     /* WARNING: Have to check how to control the decryption (which bit) and then set/reset
    932                 the  appropriate bit*/
    933     if (bHwDecEnable)
    934     {
    935         pWlanParams->FeatureDataFlowOptions &= ~DF_SNIFF_MODE_ENABLE;
    936     }
    937     else
    938     {
    939         pWlanParams->FeatureDataFlowOptions |= DF_SNIFF_MODE_ENABLE;
    940     }
    941 
    942     return cmdBld_CfgIeFeatureConfig (hCmdBld,
    943                                       pWlanParams->FeatureOptions,
    944                                       pWlanParams->FeatureDataFlowOptions,
    945                                       fCb,
    946                                       hCb);
    947 }
    948 
    949 
    950 TI_STATUS cmdBld_CfgHwEncDecEnable (TI_HANDLE hCmdBld, TI_BOOL bHwEncEnable, void *fCb, TI_HANDLE hCb)
    951 {
    952     return cmdBld_CfgHwEncEnable (hCmdBld, bHwEncEnable, bHwEncEnable, fCb, hCb);
    953 }
    954 
    955 
    956 /*
    957  * ----------------------------------------------------------------------------
    958  * Function : cmdBld_CfgSecureMode
    959  *
    960  * Input    :
    961  * Output   :
    962  * Process  :
    963  * Note(s)  :
    964  * -----------------------------------------------------------------------------
    965  */
    966 TI_STATUS cmdBld_CfgSecureMode (TI_HANDLE hCmdBld, ECipherSuite eSecurMode, void *fCb, TI_HANDLE hCb)
    967 {
    968     TCmdBld  *pCmdBld = (TCmdBld *)hCmdBld;
    969     TI_UINT32     index;
    970 
    971     if (eSecurMode < TWD_CIPHER_MAX)
    972     {
    973         TRACE2(pCmdBld->hReport, REPORT_SEVERITY_INFORMATION , "cmdBld_CfgSecureMode: change tSecurity mode from %d --> %d\n", pCmdBld->tSecurity.eSecurityMode, eSecurMode);
    974         /* check if tSecurity mode is equal to previous one*/
    975         if (pCmdBld->tSecurity.eSecurityMode == eSecurMode)
    976         {
    977             return TI_OK;
    978         }
    979 
    980         /* Reset all reconfig valid fields*/
    981         DB_KEYS(pCmdBld).bHwEncDecrEnableValid = TI_FALSE;
    982         DB_KEYS(pCmdBld).bDefaultKeyIdValid = TI_FALSE;
    983         for (index = 0;
    984              index < pCmdBld->tSecurity.uNumOfStations * NO_OF_RECONF_SECUR_KEYS_PER_STATION + NO_OF_EXTRA_RECONF_SECUR_KEYS;
    985              index++)
    986         {
    987             (DB_KEYS(pCmdBld).pReconfKeys + index)->keyType = KEY_NULL;
    988         }
    989 
    990         /* set the new tSecurity mode*/
    991         pCmdBld->tSecurity.eSecurityMode = eSecurMode;
    992 
    993         /* disable defrag, duplicate detection on TNETW+XCC on chip level*/
    994         /* YV- to add fragmentation control (if there is- artur ?)*/
    995         return cmdBld_CfgRxMsduFormat (hCmdBld,
    996                                        pCmdBld->tSecurity.eSecurityMode != TWD_CIPHER_CKIP,
    997                                        fCb,
    998                                        hCb);
    999     }
   1000     else
   1001     {
   1002         return TI_NOK;
   1003     }
   1004 }
   1005 
   1006 
   1007 TI_STATUS cmdBld_CfgConnMonitParams (TI_HANDLE  hCmdBld,
   1008                                      TRroamingTriggerParams *pRoamingTriggerCmd,
   1009                                      void       *fCb,
   1010                                      TI_HANDLE  hCb)
   1011 {
   1012     TCmdBld *pCmdBld = (TCmdBld *)hCmdBld;
   1013 
   1014     TRACE2(pCmdBld->hReport, REPORT_SEVERITY_INFORMATION , "SetBssLossTsfThresholdParamsCmd :\n                             BssLossTimeout = %d\n                             TsfMissThreshold = %d \n ", pRoamingTriggerCmd->BssLossTimeout, pRoamingTriggerCmd->TsfMissThreshold);
   1015 
   1016     DB_WLAN(hCmdBld).roamTriggers.BssLossTimeout = pRoamingTriggerCmd->BssLossTimeout;
   1017     DB_WLAN(hCmdBld).roamTriggers.TsfMissThreshold = pRoamingTriggerCmd->TsfMissThreshold;
   1018 
   1019     return cmdBld_CfgIeConnMonitParams (hCmdBld, pRoamingTriggerCmd, fCb, hCb);
   1020 }
   1021 
   1022 
   1023 /****************************************************************************
   1024  *                 cmdBld_CfgEnableRxDataFilter()
   1025  ****************************************************************************
   1026  * DESCRIPTION: Enables or disables Rx data filtering.
   1027  *
   1028  * INPUTS:  enabled             - 0 to disable data filtering, any other value to enable.
   1029  *          defaultAction       - The default action to take on non-matching packets.
   1030  *
   1031  * OUTPUT:  None
   1032  *
   1033  * RETURNS: TI_OK or TI_NOK
   1034  ****************************************************************************/
   1035 TI_STATUS cmdBld_CfgEnableRxDataFilter (TI_HANDLE   hCmdBld,
   1036                                         TI_BOOL     bEnabled,
   1037                                         filter_e    eDefaultAction,
   1038                                         void        *fCb,
   1039                                         TI_HANDLE   hCb)
   1040 {
   1041     /* Save parameters for reconfig phase */
   1042     DB_RX_DATA_FLTR(hCmdBld).bEnabled       = bEnabled;
   1043     DB_RX_DATA_FLTR(hCmdBld).eDefaultAction = eDefaultAction;
   1044 
   1045     return cmdBld_CfgIeEnableRxDataFilter (hCmdBld, bEnabled, eDefaultAction, fCb, hCb);
   1046 }
   1047 
   1048 
   1049 /****************************************************************************
   1050 *                      cmdBld_CfgRxDataFilter()
   1051 *****************************************************************************
   1052 * DESCRIPTION: Add/remove Rx Data filter information element.
   1053 *
   1054 * INPUTS:  index               - Index of the Rx Data filter
   1055 *          command             - Add or remove the filter
   1056 *          action              - Action to take on packets matching the pattern
   1057 *          numFieldPatterns    - Number of field patterns in the filter
   1058 *          lenFieldPatterns    - Length of the field pattern series
   1059 *          fieldPatterns       - Series of field patterns
   1060 *
   1061 * OUTPUT:  None
   1062 *
   1063 * RETURNS: TI_OK or TI_NOK
   1064 ****************************************************************************/
   1065 TI_STATUS cmdBld_CfgRxDataFilter (TI_HANDLE hCmdBld,
   1066                                   TI_UINT8     index,
   1067                                   TI_UINT8     command,
   1068                                   filter_e  eAction,
   1069                                   TI_UINT8     uNumFieldPatterns,
   1070                                   TI_UINT8     uLenFieldPatterns,
   1071                                   TI_UINT8  *pFieldPatterns,
   1072                                   void      *fCb,
   1073                                   TI_HANDLE hCb)
   1074 {
   1075     TCmdBld         *pCmdBld  = (TCmdBld *)hCmdBld;
   1076     TRxDataFilter   *pFilters = &(DB_RX_DATA_FLTR(hCmdBld).aRxDataFilter[index]);
   1077 
   1078     /* Save parameters for reconfig phase */
   1079     pFilters->uIndex            = index;
   1080     pFilters->uCommand          = command;
   1081     pFilters->eAction           = eAction;
   1082     pFilters->uNumFieldPatterns = uNumFieldPatterns;
   1083     pFilters->uLenFieldPatterns = uLenFieldPatterns;
   1084     os_memoryCopy(pCmdBld->hOs, pFilters->aFieldPattern, pFieldPatterns, uLenFieldPatterns);
   1085 
   1086     return cmdBld_CfgIeRxDataFilter (hCmdBld,
   1087                                      index,
   1088                                      command,
   1089                                      eAction,
   1090                                      uNumFieldPatterns,
   1091                                      uLenFieldPatterns,
   1092                                      pFieldPatterns,
   1093                                      fCb,
   1094                                      hCb);
   1095 }
   1096 
   1097 
   1098 TI_STATUS cmdBld_CfgCtsProtection (TI_HANDLE hCmdBld, TI_UINT8 uCtsProtection, void *fCb, TI_HANDLE hCb)
   1099     {
   1100         DB_WLAN(hCmdBld).CtsToSelf = uCtsProtection;
   1101 
   1102     return cmdBld_CfgIeCtsProtection (hCmdBld, uCtsProtection, fCb, hCb);
   1103 }
   1104 
   1105 
   1106 TI_STATUS cmdBld_CfgServicePeriodTimeout (TI_HANDLE hCmdBld, TRxTimeOut *pRxTimeOut, void *fCb, TI_HANDLE hCb)
   1107 {
   1108     return cmdBld_CfgIeServicePeriodTimeout (hCmdBld, pRxTimeOut, fCb, hCb);
   1109 }
   1110 
   1111 
   1112 TI_STATUS cmdBld_CfgRxMsduLifeTime (TI_HANDLE hCmdBld, TI_UINT32 uRxMsduLifeTime, void *fCb, TI_HANDLE hCb)
   1113     {
   1114         DB_WLAN(hCmdBld).MaxRxMsduLifetime = uRxMsduLifeTime;
   1115 
   1116     return cmdBld_CfgIeRxMsduLifeTime (hCmdBld, uRxMsduLifeTime, fCb, hCb);
   1117 }
   1118 
   1119 
   1120 TI_STATUS cmdBld_CfgStatisitics (TI_HANDLE hCmdBld, void *fCb, TI_HANDLE hCb)
   1121 {
   1122     return cmdBld_CfgIeStatisitics (hCmdBld, fCb, hCb);
   1123 }
   1124 
   1125 
   1126 TI_STATUS cmdBld_CfgTxPowerDbm (TI_HANDLE hCmdBld, TI_UINT8 uTxPowerDbm, void *fCb, TI_HANDLE hCb)
   1127 {
   1128     return cmdBld_CfgIeTxPowerDbm (hCmdBld, uTxPowerDbm, fCb, hCb);
   1129 }
   1130 
   1131  /*
   1132  * ----------------------------------------------------------------------------
   1133  * Function : cmdBld_CfgBet
   1134  *
   1135  * Input    :   enabled               - 0 to disable BET, 0 to disable BET
   1136  *              MaximumConsecutiveET  - Max number of consecutive beacons
   1137  *                                      that may be early terminated.
   1138  * Output   : TI_STATUS
   1139  * Process  :  Configures Beacon Early Termination information element.
   1140  * Note(s)  :  None
   1141  * -----------------------------------------------------------------------------
   1142  */
   1143 TI_STATUS cmdBld_CfgBet (TI_HANDLE hCmdBld, TI_UINT8 Enable, TI_UINT8 MaximumConsecutiveET, void *fCb, TI_HANDLE hCb)
   1144 {
   1145     DB_WLAN(hCmdBld).BetEnable              = Enable;
   1146     DB_WLAN(hCmdBld).MaximumConsecutiveET   = MaximumConsecutiveET;
   1147 
   1148     return cmdBld_CfgIeBet (hCmdBld, Enable, MaximumConsecutiveET, fCb, hCb);
   1149 }
   1150 
   1151 /****************************************************************************
   1152  *                      cmdBld_CfgKeepAlive()
   1153  ****************************************************************************
   1154  * DESCRIPTION: Set keep-alive paramters for a single index
   1155  *
   1156  * INPUTS: Paramters and CB
   1157  *
   1158  * OUTPUT:  None
   1159  *
   1160  * RETURNS: TI_OK or TI_NOK
   1161  ****************************************************************************/
   1162 TI_STATUS cmdBld_CfgKeepAlive (TI_HANDLE hCmdBld, TKeepAliveParams *pKeepAliveParams, void *fCb, TI_HANDLE hCb)
   1163 {
   1164     TCmdBld   *pCmdBld = (TCmdBld *)hCmdBld;
   1165 
   1166     TRACE4(pCmdBld->hReport, REPORT_SEVERITY_INFORMATION , "CmdBld: Seeting keep-alive params, index=%d, interval=%d msec, trigType=%d, enaFlag=%d\n", pKeepAliveParams->index, pKeepAliveParams->interval, pKeepAliveParams->trigType, pKeepAliveParams->enaDisFlag);
   1167 
   1168     os_memoryCopy (pCmdBld->hOs,
   1169                    (void *)&DB_KLV(hCmdBld).keepAliveParams[ pKeepAliveParams->index ],
   1170                    (void *)pKeepAliveParams,
   1171                    sizeof (TKeepAliveParams));
   1172 
   1173     return cmdBld_CmdIeConfigureKeepAliveParams (hCmdBld,
   1174                                                  pKeepAliveParams->index,
   1175                                                  pKeepAliveParams->enaDisFlag,
   1176                                                  (TI_UINT8)pKeepAliveParams->trigType,
   1177                                                  pKeepAliveParams->interval,
   1178                                                  fCb,
   1179                                                  hCb);
   1180 }
   1181 
   1182 /****************************************************************************
   1183  *                      cmdBld_CfgKeepAliveEnaDis()
   1184  ****************************************************************************
   1185  * DESCRIPTION: Set global keep-alive enable / disable flag
   1186  *
   1187  * INPUTS: Paramters and CB
   1188  *
   1189  * OUTPUT:  None
   1190  *
   1191  * RETURNS: TI_OK or TI_NOK
   1192  ****************************************************************************/
   1193 TI_STATUS cmdBld_CfgKeepAliveEnaDis(TI_HANDLE hCmdBld, TI_UINT8 enaDisFlag, void *fCb, TI_HANDLE hCb)
   1194 {
   1195     TCmdBld   *pCmdBld = (TCmdBld *)hCmdBld;
   1196 
   1197     TRACE1(pCmdBld->hReport, REPORT_SEVERITY_INFORMATION , "CmdBld: Seeting keep-alive Global ena / dis flag to %d\n", (TI_UINT32)enaDisFlag);
   1198 
   1199     DB_KLV(hCmdBld).enaDisFlag = enaDisFlag;
   1200 
   1201     return cmdBld_CmdIeConfigureKeepAliveEnaDis (hCmdBld, enaDisFlag, fCb, hCb);
   1202 }
   1203 
   1204 /**
   1205  * \fn     cmdBld_CfgSetFwHtCapabilities
   1206  * \brief  set the current AP HT Capabilities to the FW.
   1207  *
   1208  * \note
   1209  * \return TI_OK on success or TI_NOK on failure
   1210  * \sa
   1211  */
   1212 TI_STATUS cmdBld_CfgSetFwHtCapabilities (TI_HANDLE hCmdBld,
   1213                                          TI_UINT32 uHtCapabilites,
   1214                                          TMacAddr  tMacAddress,
   1215                                          TI_UINT8  uAmpduMaxLeng,
   1216                                          TI_UINT8  uAmpduMinSpac,
   1217                                          void      *fCb,
   1218                                          TI_HANDLE hCb)
   1219 {
   1220 
   1221     DB_BSS(hCmdBld).bHtCap = TI_TRUE;
   1222     DB_BSS(hCmdBld).uHtCapabilites = uHtCapabilites;
   1223     MAC_COPY ((DB_BSS(hCmdBld).tMacAddress), tMacAddress);
   1224     DB_BSS(hCmdBld).uAmpduMaxLeng = uAmpduMaxLeng;
   1225     DB_BSS(hCmdBld).uAmpduMinSpac = uAmpduMinSpac;
   1226 
   1227     return cmdBld_CfgIeSetFwHtCapabilities (hCmdBld,
   1228                                             uHtCapabilites,
   1229                                             tMacAddress,
   1230                                             uAmpduMaxLeng,
   1231                                             uAmpduMinSpac,
   1232                                             fCb,
   1233                                             hCb);
   1234 }
   1235 
   1236 /**
   1237  * \fn     cmdBld_CfgSetFwHtInformation
   1238  * \brief  set the current AP HT Information to the FW.
   1239  *
   1240  * \note
   1241  * \return TI_OK on success or TI_NOK on failure
   1242  * \sa
   1243  */
   1244 TI_STATUS cmdBld_CfgSetFwHtInformation (TI_HANDLE hCmdBld,
   1245                                         TI_UINT8  uRifsMode,
   1246                                         TI_UINT8  uHtProtection,
   1247                                         TI_UINT8  uGfProtection,
   1248                                         TI_UINT8  uHtTxBurstLimit,
   1249                                         TI_UINT8  uDualCtsProtection,
   1250                                         void      *fCb,
   1251                                         TI_HANDLE hCb)
   1252 {
   1253 
   1254     DB_BSS(hCmdBld).bHtInf = TI_TRUE;
   1255     DB_BSS(hCmdBld).uRifsMode = uRifsMode;
   1256     DB_BSS(hCmdBld).uHtProtection = uHtProtection;
   1257     DB_BSS(hCmdBld).uGfProtection = uGfProtection;
   1258     DB_BSS(hCmdBld).uHtTxBurstLimit = uHtTxBurstLimit;
   1259     DB_BSS(hCmdBld).uDualCtsProtection = uDualCtsProtection;
   1260 
   1261     return cmdBld_CfgIeSetFwHtInformation (hCmdBld,
   1262                                            uRifsMode,
   1263                                            uHtProtection,
   1264                                            uGfProtection,
   1265                                            uHtTxBurstLimit,
   1266                                            uDualCtsProtection,
   1267                                            fCb,
   1268                                            hCb);
   1269 }
   1270 
   1271 /**
   1272  * \fn     cmdBld_CfgSetBaInitiator
   1273  * \brief  configure BA session initiator\receiver parameters setting in the FW.
   1274  *
   1275  * \note
   1276  * \return TI_OK on success or TI_NOK on failure
   1277  * \sa
   1278  */
   1279 TI_STATUS cmdBld_CfgSetBaSession (TI_HANDLE hCmdBld,
   1280                                   InfoElement_e eBaType,
   1281                                   TI_UINT8 uTid,
   1282                                   TI_UINT8 uState,
   1283                                   TMacAddr tRa,
   1284                                   TI_UINT16 uWinSize,
   1285                                   TI_UINT16 uInactivityTimeout,
   1286                                   void *fCb,
   1287                                   TI_HANDLE hCb)
   1288 {
   1289     if (ACX_BA_SESSION_INITIATOR_POLICY == eBaType)
   1290     {
   1291         DB_BSS(hCmdBld).bBaInitiator[uTid] = TI_TRUE;
   1292         DB_BSS(hCmdBld).tBaSessionInitiatorPolicy[uTid].uTid = uTid;
   1293         DB_BSS(hCmdBld).tBaSessionInitiatorPolicy[uTid].uPolicy = uState;
   1294         MAC_COPY ((DB_BSS(hCmdBld).tBaSessionInitiatorPolicy[uTid].aMacAddress),tRa);
   1295         DB_BSS(hCmdBld).tBaSessionInitiatorPolicy[uTid].uWinSize = uWinSize;
   1296         DB_BSS(hCmdBld).tBaSessionInitiatorPolicy[uTid].uInactivityTimeout = uInactivityTimeout;
   1297     }
   1298     else
   1299     {
   1300         DB_BSS(hCmdBld).bBaResponder[uTid] = TI_TRUE;
   1301         DB_BSS(hCmdBld).tBaSessionResponderPolicy[uTid].uTid = uTid;
   1302         DB_BSS(hCmdBld).tBaSessionResponderPolicy[uTid].uPolicy = uState;
   1303         MAC_COPY ((DB_BSS(hCmdBld).tBaSessionResponderPolicy[uTid].aMacAddress),tRa);
   1304         DB_BSS(hCmdBld).tBaSessionResponderPolicy[uTid].uWinSize = uWinSize;
   1305         DB_BSS(hCmdBld).tBaSessionResponderPolicy[uTid].uInactivityTimeout = uInactivityTimeout;
   1306     }
   1307 
   1308     return cmdBld_CfgIeSetBaSession (hCmdBld,
   1309                                      eBaType,
   1310                                      uTid,
   1311                                      uState,
   1312                                      tRa,
   1313                                      uWinSize,
   1314                                      uInactivityTimeout,
   1315                                      fCb,
   1316                                      hCb);
   1317 }
   1318 
   1319 
   1320 TI_STATUS cmdBld_CfgBurstMode (TI_HANDLE hCmdBld, TI_BOOL bEnabled, void *fCb, TI_HANDLE hCb)
   1321 {
   1322 	DB_AC(hCmdBld).isBurstModeEnabled = bEnabled;
   1323 	return cmdBld_CfgIeBurstMode (hCmdBld, bEnabled, fCb, hCb);
   1324 }
   1325 
   1326