diff -r 000000000000 -r 10c42ec6c05f TWD/Ctrl/CmdBldCfg.c --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/TWD/Ctrl/CmdBldCfg.c Tue Jun 29 12:34:26 2010 +0100 @@ -0,0 +1,1362 @@ +/* + * CmdBldCfg.c + * + * Copyright(c) 1998 - 2010 Texas Instruments. All rights reserved. + * All rights reserved. + * + * This program and the accompanying materials are made available under the + * terms of the Eclipse Public License v1.0 or BSD License which accompanies + * this distribution. The Eclipse Public License is available at + * http://www.eclipse.org/legal/epl-v10.html and the BSD License is as below. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * + * * Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * * Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in + * the documentation and/or other materials provided with the + * distribution. + * * Neither the name Texas Instruments nor the names of its + * contributors may be used to endorse or promote products derived + * from this software without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS + * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT + * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR + * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT + * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, + * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT + * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, + * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY + * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT + * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE + * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + */ + + +/** \file CmdBldCfg.c + * \brief Command builder. Configuration commands + * + * \see CmdBld.h + */ +#define __FILE_ID__ FILE_ID_91 +#include "osApi.h" +#include "tidef.h" +#include "report.h" +#include "CmdBld.h" +#include "CmdBldCfgIE.h" +#include "TWDriverInternal.h" + + +/**************************************************************************** + * cmdBld_CfgRx() + **************************************************************************** + * DESCRIPTION: Sets the filters according to the given configuration. + * + * INPUTS: RxConfigOption - The given Rx filters configuration + * RxFilterOption - The given Rx filters options + * + * OUTPUT: None + * + * RETURNS: TI_OK or TI_NOK + ****************************************************************************/ +TI_STATUS cmdBld_CfgRx (TI_HANDLE hCmdBld, TI_UINT32 uRxConfigOption, TI_UINT32 uRxFilterOption, void *fCb, TI_HANDLE hCb) +{ + DB_WLAN(hCmdBld).RxConfigOption = uRxConfigOption; + DB_WLAN(hCmdBld).RxFilterOption = uRxFilterOption; + DB_WLAN(hCmdBld).RxConfigOption |= RX_CFG_ENABLE_PHY_HEADER_PLCP; + #if defined (TNETW_MASTER_MODE) || defined (TNETW_USB_MODE) + DB_WLAN(hCmdBld).RxConfigOption |= RX_CFG_COPY_RX_STATUS; + #endif + + if (DB_WLAN(hCmdBld).RxDisableBroadcast) + { + DB_WLAN(hCmdBld).RxConfigOption |= RX_CFG_DISABLE_BCAST; + } + + return cmdBld_CfgIeRx (hCmdBld, + DB_WLAN(hCmdBld).RxConfigOption, + DB_WLAN(hCmdBld).RxFilterOption, + fCb, + hCb); +} + + +/**************************************************************************** + * cmdBld_CfgArpIpAddrTable() + **************************************************************************** + * DESCRIPTION: Sets the ARP IP table according to the given configuration. + * + * OUTPUT: None + * + * RETURNS: TI_OK or TI_NOK + ****************************************************************************/ +TI_STATUS cmdBld_CfgArpIpAddrTable (TI_HANDLE hCmdBld, TIpAddr tIpAddr, TI_BOOL bEnabled, EIpVer eIpVer, void *fCb, TI_HANDLE hCb) +{ + DB_WLAN(hCmdBld).arp_IP_ver = eIpVer; + + /* no support for IPV6 */ + if (eIpVer == IP_VER_4) + { + IP_COPY (DB_WLAN(hCmdBld).arp_IP_addr, tIpAddr); + } + + DB_WLAN(hCmdBld).isArpIpFilteringEnabled = bEnabled; + + /* Set the new ip with the current state (e/d) */ + return cmdBld_CfgIeArpIpFilter (hCmdBld, tIpAddr, bEnabled, fCb, hCb); +} + + /**************************************************************************** + * cmdBld_CfgArpIpFilter() + **************************************************************************** + * DESCRIPTION: Enable\Disable the ARP filter + * + * OUTPUT: None + * + * RETURNS: TI_OK or TI_NOK + ****************************************************************************/ +TI_STATUS cmdBld_CfgArpIpFilter (TI_HANDLE hCmdBld, TI_BOOL bEnabled, void *fCb, TI_HANDLE hCb) +{ + /* Set the current ip address with the new state (e/d) */ + DB_WLAN(hCmdBld).isArpIpFilteringEnabled = bEnabled; + + return cmdBld_CfgIeArpIpFilter (hCmdBld, + DB_WLAN(hCmdBld).arp_IP_addr, + bEnabled, + fCb, + hCb); +} +/**************************************************************************** + * cmdBld_CfgGroupAddressTable() + **************************************************************************** + * DESCRIPTION: Sets the Group table according to the given configuration. + * + * OUTPUT: None + * + * RETURNS: TI_OK or TI_NOK + ****************************************************************************/ +TI_STATUS cmdBld_CfgGroupAddressTable (TI_HANDLE hCmdBld, + TI_UINT8 uNumGroupAddr, + TMacAddr *pGroupAddr, + TI_BOOL bEnabled, + void *fCb, + TI_HANDLE hCb) +{ + TCmdBld *pCmdBld = (TCmdBld *)hCmdBld; + TI_UINT32 i; + + if (uNumGroupAddr > MAX_MULTICAST_GROUP_ADDRS) + { + TRACE1(pCmdBld->hReport, REPORT_SEVERITY_ERROR, "cmdBld_CfgGroupAddressTable: numGroupAddrs=%d\n", uNumGroupAddr); + return PARAM_VALUE_NOT_VALID; + } + + if (NULL == pGroupAddr) + { + TRACE2(pCmdBld->hReport, REPORT_SEVERITY_ERROR, "cmdBld_CfgGroupAddressTable: numGroupAddrs=%d Group_addr=0x%x !!!\n", uNumGroupAddr, pGroupAddr); + return PARAM_VALUE_NOT_VALID; + } + + /* Keeps the parameters in the db */ + DB_WLAN(hCmdBld).numGroupAddrs = uNumGroupAddr; + DB_WLAN(hCmdBld).isMacAddrFilteringnabled = bEnabled; + + for (i = 0; i < uNumGroupAddr; i++) + { + MAC_COPY (DB_WLAN(hCmdBld).aGroupAddr[i], *(pGroupAddr + i)); + } + + return cmdBld_CfgIeGroupAdressTable (hCmdBld, uNumGroupAddr, pGroupAddr, bEnabled, fCb, hCb); +} + + +/**************************************************************************** + * cmdBld_CfgRtsThreshold() + **************************************************************************** + * DESCRIPTION: Sets the Rts Threshold. + * + * OUTPUT: None + * + * RETURNS: TI_OK or TI_NOK pWlanParams->RtsThreshold + ****************************************************************************/ +TI_STATUS cmdBld_CfgRtsThreshold (TI_HANDLE hCmdBld, TI_UINT16 threshold, void *fCb, TI_HANDLE hCb) +{ + return cmdBld_CfgIeRtsThreshold (hCmdBld, threshold, fCb, hCb); +} + +/**************************************************************************** + * cmdBld_CfgDcoItrimParams() + **************************************************************************** + * DESCRIPTION: Sets the DCO Itrim parameters. + * + * OUTPUT: None + * + * RETURNS: TI_OK or TI_NOK + ****************************************************************************/ +TI_STATUS cmdBld_CfgDcoItrimParams (TI_HANDLE hCmdBld, TI_BOOL enable, TI_UINT32 moderationTimeoutUsec, void *fCb, TI_HANDLE hCb) +{ + /* Keeps the parameters in the db */ + DB_WLAN(hCmdBld).dcoItrimEnabled = enable; + DB_WLAN(hCmdBld).dcoItrimModerationTimeoutUsec = moderationTimeoutUsec; + + return cmdBld_CfgIeDcoItrimParams (hCmdBld, enable, moderationTimeoutUsec, fCb, hCb); +} + +/**************************************************************************** + * cmdBld_CfgFragmentThreshold() + **************************************************************************** + * DESCRIPTION: Sets the tx fragmentation Threshold. + * + * OUTPUT: None + * + * RETURNS: TI_OK or TI_NOK + ****************************************************************************/ +TI_STATUS cmdBld_CfgFragmentThreshold (TI_HANDLE hCmdBld, TI_UINT16 uFragmentThreshold, void *fCb, TI_HANDLE hCb) +{ + DB_WLAN(hCmdBld).FragmentThreshold = uFragmentThreshold; + + return cmdBld_CfgIeFragmentThreshold (hCmdBld, uFragmentThreshold, fCb, hCb); +} + + +/**************************************************************************** + * cmdBld_CfgPreamble() + **************************************************************************** + * DESCRIPTION: Set the preamble in ?????? hardware register + * + * INPUTS: + * preambleVal + * + * OUTPUT: None + * + * RETURNS: None + ****************************************************************************/ +TI_STATUS cmdBld_CfgPreamble (TI_HANDLE hCmdBld, Preamble_e ePreamble, void *fCb, TI_HANDLE hCb) +{ + DB_WLAN(hCmdBld).preamble = ePreamble; + + return cmdBld_CfgIePreamble (hCmdBld, (TI_UINT8)ePreamble, fCb, hCb); +} + + +/**************************************************************************** + * cmdBld_CfgBcnBrcOptions() + **************************************************************************** + * DESCRIPTION: Configure the wlan hardware + * + * INPUTS: None + * + * OUTPUT: None + * + * RETURNS: TI_OK or TI_NOK + ****************************************************************************/ +TI_STATUS cmdBld_CfgBcnBrcOptions (TI_HANDLE hCmdBld, TPowerMgmtConfig *pPMConfig, void *fCb, TI_HANDLE hCb) +{ + return cmdBld_CfgIeBcnBrcOptions (hCmdBld, pPMConfig, fCb, hCb); +} + + +/**************************************************************************** + * cmdBld_CfgWakeUpCondition() + **************************************************************************** + * DESCRIPTION: Configure the wlan hardware + * + * INPUTS: None + * + * OUTPUT: None + * + * RETURNS: TI_OK or TI_NOK + ****************************************************************************/ +TI_STATUS cmdBld_CfgWakeUpCondition (TI_HANDLE hCmdBld, TPowerMgmtConfig *pPMConfig, void *fCb, TI_HANDLE hCb) +{ + return cmdBld_CfgIeWakeUpCondition (hCmdBld, pPMConfig, fCb, hCb); +} + + +/**************************************************************************** + * cmdBld_CfgSleepAuth () + **************************************************************************** + * DESCRIPTION: Set the min power level + * + * INPUTS: + * + * OUTPUT: + * + * RETURNS: TI_OK or TI_NOK + ****************************************************************************/ +TI_STATUS cmdBld_CfgSleepAuth (TI_HANDLE hCmdBld, EPowerPolicy eMinPowerLevel, void *fCb, TI_HANDLE hCb) +{ + /* Save th parameter in database */ + DB_WLAN(hCmdBld).minPowerLevel = eMinPowerLevel; + + return cmdBld_CfgIeSleepAuth (hCmdBld, eMinPowerLevel, fCb, hCb); +} + + +typedef enum { HW_CLOCK_40_MHZ = 40, HW_CLOCK_80_MHZ = 80 } EHwClock; + + +/**************************************************************************** + * cmdBld_CfgArmClock() + **************************************************************************** + * DESCRIPTION: Configure the arm clock + * !!! Note that the firmware will set the slot time according to the new clock + * + * INPUTS: None + * + * OUTPUT: None + * + * RETURNS: TI_OK or TI_NOK + ****************************************************************************/ +TI_STATUS cmdBld_CfgArmClock (TI_HANDLE hCmdBld, TI_UINT32 uArmClock, void *fCb, TI_HANDLE hCb) +{ + TCmdBld *pCmdBld = (TCmdBld *)hCmdBld; + TWlanParams *pWlanParams = &DB_WLAN(hCmdBld); + + pWlanParams->ArmClock = uArmClock; + + /* Illegal combination Mac=80, Arm=40 ==> force setting 40/40*/ + if (pWlanParams->MacClock == HW_CLOCK_80_MHZ && pWlanParams->ArmClock == HW_CLOCK_40_MHZ) + { + TRACE0(pCmdBld->hReport, REPORT_SEVERITY_ERROR, "cmdBld_ArmClockSet: Illegal combination Mac=80, Arm=40 ==> force setting 40/40\n"); + pWlanParams->MacClock = HW_CLOCK_40_MHZ; + } + + return cmdBld_CfgIeFeatureConfig (hCmdBld, + pWlanParams->FeatureOptions, + pWlanParams->FeatureDataFlowOptions, + fCb, + hCb); +} + + +/**************************************************************************** + * cmdBld_CfgMacClock() + **************************************************************************** + * DESCRIPTION: Configure the mac clock + * !!! Note that the firmware will set the slot time according to the new clock + * + * INPUTS: None + * + * OUTPUT: None + * + * RETURNS: TI_OK or TI_NOK + ****************************************************************************/ +TI_STATUS cmdBld_CfgMacClock (TI_HANDLE hCmdBld, TI_UINT32 uMacClock, void *fCb, TI_HANDLE hCb) +{ + TCmdBld *pCmdBld = (TCmdBld *)hCmdBld; + TWlanParams *pWlanParams = &DB_WLAN(hCmdBld); + + pWlanParams->MacClock = uMacClock; + + /* Force same clock - for printing */ + pWlanParams->ArmClock = uMacClock; + + /* Illegal combination Mac=80, Arm=40 ==> force setting 40/40*/ + if (pWlanParams->MacClock == HW_CLOCK_80_MHZ && pWlanParams->ArmClock == HW_CLOCK_40_MHZ) + { + TRACE0(pCmdBld->hReport, REPORT_SEVERITY_ERROR, "cmdBld_MacClockSet: Illegal combination Mac=80, Arm=40 ==> force setting 40/40\n"); + pWlanParams->MacClock = HW_CLOCK_40_MHZ; + } + + return cmdBld_CfgIeFeatureConfig (hCmdBld, + pWlanParams->FeatureOptions, + pWlanParams->FeatureDataFlowOptions, + fCb, + hCb); +} + + +/**************************************************************************** + * cmdBld_CfgAid() + **************************************************************************** + * DESCRIPTION: Set the AID + * + * INPUTS: + * + * OUTPUT: + * + * RETURNS: TI_OK or TI_NOK + ****************************************************************************/ +TI_STATUS cmdBld_CfgAid (TI_HANDLE hCmdBld, TI_UINT16 uAidVal, void *fCb, TI_HANDLE hCb) +{ + return cmdBld_CfgIeAid (hCmdBld, uAidVal, fCb, hCb); +} + +TI_STATUS cmdBld_CfgClkRun (TI_HANDLE hCmdBld, TI_BOOL aClkRunEnable, void *fCb, TI_HANDLE hCb) +{ + TWlanParams *pWlanParams = &DB_WLAN(hCmdBld); + + if (aClkRunEnable) + { + pWlanParams->FeatureDataFlowOptions |= FEAT_PCI_CLK_RUN_ENABLE; + } + else + { + pWlanParams->FeatureDataFlowOptions &= ~FEAT_PCI_CLK_RUN_ENABLE; + } + + return cmdBld_CfgIeFeatureConfig (hCmdBld, + pWlanParams->FeatureOptions, + pWlanParams->FeatureDataFlowOptions, + fCb, + hCb); +} + + +TI_STATUS cmdBld_CfgRxMsduFormat (TI_HANDLE hCmdBld, TI_BOOL bRxMsduForamtEnable, void *fCb, TI_HANDLE hCb) +{ +#if 1 + /* WARNING: Have to check how to control the Rx Frame format select (which bit) + and then access the HW*/ + return TI_OK; +#else + TCmdBld *pCmdBld = (TCmdBld *)hCmdBld; + TWlanParams *pWlanParams = &DB_WLAN(hCmdBld); + + if (aRxMsduForamtEnable) + { + pWlanParams->FeatureDataFlowOptions |= DATA_FLOW_RX_MSDU_FRAME; + } + else + { + pWlanParams->FeatureDataFlowOptions &= ~DATA_FLOW_RX_MSDU_FRAME; + } + + return cmdBld_CfgIeFeatureConfig (hCmdBld, + pWlanParams->FeatureOptions, + pWlanParams->FeatureDataFlowOptions, + fCb, + hCb); +#endif +} + + +/**************************************************************************** + * cmdBld_CfgTid() + **************************************************************************** + * DESCRIPTION: configure Queue traffic params + * + * INPUTS: None + * + * OUTPUT: None + * + * RETURNS: TI_OK or TI_NOK + ****************************************************************************/ +TI_STATUS cmdBld_CfgTid (TI_HANDLE hCmdBld, TQueueTrafficParams *pQtrafficParams, void *fCb, TI_HANDLE hCb) +{ + DB_QUEUES(hCmdBld).isQueueConfigured[pQtrafficParams->queueID] = TI_TRUE; + DB_QUEUES(hCmdBld).queues[pQtrafficParams->queueID] = *pQtrafficParams; + + return cmdBld_CfgIeTid (hCmdBld, pQtrafficParams, fCb, hCb); +} + + +/**************************************************************************** + * cmdBld_CfgAcParams() + **************************************************************************** + * DESCRIPTION: configure AC params + * + * INPUTS: None + * + * OUTPUT: None + * + * RETURNS: TI_OK or TI_NOK + ****************************************************************************/ +TI_STATUS cmdBld_CfgAcParams (TI_HANDLE hCmdBld, TAcQosParams *pAcQosParams, void *fCb, TI_HANDLE hCb) +{ + DB_AC(hCmdBld).isAcConfigured[pAcQosParams->ac] = TI_TRUE; + DB_AC(hCmdBld).ac[pAcQosParams->ac] = *pAcQosParams; + + return cmdBld_CfgIeAcParams (hCmdBld, pAcQosParams, fCb, hCb); +} + + +/**************************************************************************** + * cmdBld_CfgPsRxStreaming() + **************************************************************************** + * DESCRIPTION: configure PS-Rx-Streaming params + * + * INPUTS: None + * + * OUTPUT: None + * + * RETURNS: TI_OK or TI_NOK + ****************************************************************************/ +TI_STATUS cmdBld_CfgPsRxStreaming (TI_HANDLE hCmdBld, TPsRxStreaming *pPsRxStreaming, void *fCb, TI_HANDLE hCb) +{ + DB_PS_STREAM(hCmdBld).tid[pPsRxStreaming->uTid] = *pPsRxStreaming; + + return cmdBld_CfgIePsRxStreaming (hCmdBld, pPsRxStreaming, fCb, hCb); +} + + +/**************************************************************************** + * cmdBld_CfgPacketDetectionThreshold + **************************************************************************** + * DESCRIPTION: Sets Packet Detection Threshold + * + * INPUTS: None + * + * OUTPUT: None + * + * RETURNS: TI_OK or TI_NOK + ****************************************************************************/ +TI_STATUS cmdBld_CfgPacketDetectionThreshold (TI_HANDLE hCmdBld, TI_UINT32 threshold, void *fCb, TI_HANDLE hCb) +{ + DB_WLAN(hCmdBld).PacketDetectionThreshold = threshold; + + return cmdBld_CfgIePacketDetectionThreshold (hCmdBld, threshold, fCb, hCb); +} + + +/**************************************************************************** + * cmdBld_CfgBeaconFilterOpt + **************************************************************************** + * DESCRIPTION: Sets Beacon filtering state + * + * INPUTS: None + * + * OUTPUT: None + * + * RETURNS: TI_OK or TI_NOK + ****************************************************************************/ +TI_STATUS cmdBld_CfgBeaconFilterOpt (TI_HANDLE hCmdBld, + TI_UINT8 uBeaconFilteringStatus, + TI_UINT8 uNumOfBeaconsToBuffer, + void *fCb, + TI_HANDLE hCb) +{ + DB_WLAN(hCmdBld).beaconFilterParams.desiredState = uBeaconFilteringStatus; + DB_WLAN(hCmdBld).beaconFilterParams.numOfElements = uNumOfBeaconsToBuffer; + + return cmdBld_CfgIeBeaconFilterOpt (hCmdBld, + uBeaconFilteringStatus, + uNumOfBeaconsToBuffer, + fCb, + hCb); +} + +/**************************************************************************** + * cmdBld_CfgRateMngDbg + **************************************************************************** + * DESCRIPTION: Sets rate managment params + * + * INPUTS: None + * + * OUTPUT: None + * + * RETURNS: TI_OK or TI_NOK + ****************************************************************************/ + +TI_STATUS cmdBld_CfgRateMngDbg (TI_HANDLE hCmdBld, + RateMangeParams_t *pRateMngParams , + void *fCb, + TI_HANDLE hCb) +{ + + TRateMngParams *pRateMngParamsDB = &DB_RM(hCmdBld); + int uIndex; + + pRateMngParamsDB->rateMngParams.paramIndex = pRateMngParams->paramIndex; + + switch (pRateMngParams->paramIndex) + { + case RATE_MGMT_RETRY_SCORE_PARAM: + pRateMngParamsDB->rateMngParams.RateRetryScore = pRateMngParams->RateRetryScore; + break; + case RATE_MGMT_PER_ADD_PARAM: + pRateMngParamsDB->rateMngParams.PerAdd = pRateMngParams->PerAdd; + break; + case RATE_MGMT_PER_TH1_PARAM: + pRateMngParamsDB->rateMngParams.PerTh1 = pRateMngParams->PerTh1; + break; + case RATE_MGMT_PER_TH2_PARAM: + pRateMngParamsDB->rateMngParams.PerTh2 = pRateMngParams->PerTh2; + break; + case RATE_MGMT_MAX_PER_PARAM: + pRateMngParamsDB->rateMngParams.MaxPer = pRateMngParams->MaxPer; + break; + case RATE_MGMT_INVERSE_CURIOSITY_FACTOR_PARAM: + pRateMngParamsDB->rateMngParams.InverseCuriosityFactor[0] = pRateMngParams->InverseCuriosityFactor[0]; + pRateMngParamsDB->rateMngParams.InverseCuriosityFactor[1] = pRateMngParams->InverseCuriosityFactor[1]; + break; + case RATE_MGMT_TX_FAIL_LOW_TH_PARAM: + pRateMngParamsDB->rateMngParams.TxFailLowTh = pRateMngParams->TxFailLowTh; + break; + case RATE_MGMT_TX_FAIL_HIGH_TH_PARAM: + pRateMngParamsDB->rateMngParams.TxFailHighTh = pRateMngParams->TxFailHighTh; + break; + case RATE_MGMT_PER_ALPHA_SHIFT_PARAM: + pRateMngParamsDB->rateMngParams.PerAlphaShift = pRateMngParams->PerAlphaShift; + break; + case RATE_MGMT_PER_ADD_SHIFT_PARAM: + pRateMngParamsDB->rateMngParams.PerAddShift = pRateMngParams->PerAddShift; + break; + case RATE_MGMT_PER_BETA1_SHIFT_PARAM: + pRateMngParamsDB->rateMngParams.PerBeta1Shift = pRateMngParams->PerBeta1Shift; + break; + case RATE_MGMT_PER_BETA2_SHIFT_PARAM: + pRateMngParamsDB->rateMngParams.PerBeta2Shift = pRateMngParams->PerBeta2Shift; + break; + case RATE_MGMT_RATE_CHECK_UP_PARAM: + pRateMngParamsDB->rateMngParams.RateCheckUp = pRateMngParams->RateCheckUp; + break; + case RATE_MGMT_RATE_CHECK_DOWN_PARAM: + pRateMngParamsDB->rateMngParams.RateCheckDown = pRateMngParams->RateCheckDown; + break; + case RATE_MGMT_RATE_RETRY_POLICY_PARAM: + for (uIndex = 0; uIndex < 13; uIndex++) + { + pRateMngParamsDB->rateMngParams.RateRetryPolicy[uIndex] = pRateMngParams->RateRetryPolicy[uIndex]; + } + break; + case RATE_MGMT_PER_WEIGHT_SHIFT_PARAM: + pRateMngParamsDB->rateMngParams.PerWeightShift[0] = pRateMngParams->PerWeightShift[0]; + pRateMngParamsDB->rateMngParams.PerWeightShift[1] = pRateMngParams->PerWeightShift[1]; + break; + case RATE_MGMT_TP_WEIGHT_SHIFT_PARAM: + pRateMngParamsDB->rateMngParams.TpWeightShift[0] = pRateMngParams->TpWeightShift[0]; + pRateMngParamsDB->rateMngParams.TpWeightShift[1] = pRateMngParams->TpWeightShift[1]; + break; + case RATE_MGMT_ALL_PARAMS: + pRateMngParamsDB->rateMngParams.RateRetryScore = pRateMngParams->RateRetryScore; + pRateMngParamsDB->rateMngParams.PerAdd = pRateMngParams->PerAdd; + pRateMngParamsDB->rateMngParams.PerTh1 = pRateMngParams->PerTh1; + pRateMngParamsDB->rateMngParams.PerTh2 = pRateMngParams->PerTh2; + pRateMngParamsDB->rateMngParams.MaxPer = pRateMngParams->MaxPer; + pRateMngParamsDB->rateMngParams.InverseCuriosityFactor[0] = pRateMngParams->InverseCuriosityFactor[0]; + pRateMngParamsDB->rateMngParams.InverseCuriosityFactor[1] = pRateMngParams->InverseCuriosityFactor[1]; + pRateMngParamsDB->rateMngParams.TxFailLowTh = pRateMngParams->TxFailLowTh; + pRateMngParamsDB->rateMngParams.TxFailHighTh = pRateMngParams->TxFailHighTh; + pRateMngParamsDB->rateMngParams.PerAlphaShift = pRateMngParams->PerAlphaShift; + pRateMngParamsDB->rateMngParams.PerAddShift = pRateMngParams->PerAddShift; + pRateMngParamsDB->rateMngParams.PerBeta1Shift = pRateMngParams->PerBeta1Shift; + pRateMngParamsDB->rateMngParams.PerBeta2Shift = pRateMngParams->PerBeta2Shift; + pRateMngParamsDB->rateMngParams.RateCheckUp = pRateMngParams->RateCheckUp; + pRateMngParamsDB->rateMngParams.RateCheckDown = pRateMngParams->RateCheckDown; + for (uIndex = 0; uIndex < 13; uIndex++) + { + pRateMngParamsDB->rateMngParams.RateRetryPolicy[uIndex] = pRateMngParams->RateRetryPolicy[uIndex]; + } + pRateMngParamsDB->rateMngParams.PerWeightShift[0] = pRateMngParams->PerWeightShift[0]; + pRateMngParamsDB->rateMngParams.PerWeightShift[1] = pRateMngParams->PerWeightShift[1]; + pRateMngParamsDB->rateMngParams.TpWeightShift[0] = pRateMngParams->TpWeightShift[0]; + pRateMngParamsDB->rateMngParams.TpWeightShift[1] = pRateMngParams->TpWeightShift[1]; + break; + } + + return cmdBld_CfgIeRateMngDbg (hCmdBld, + pRateMngParams, + fCb, + hCb); +} + + +/**************************************************************************** + * cmdBld_CfgBeaconFilterTable + **************************************************************************** + * DESCRIPTION: Sets Beacon filtering state + * + * INPUTS: None + * + * OUTPUT: None + * + * RETURNS: TI_OK or TI_NOK + ****************************************************************************/ +TI_STATUS cmdBld_CfgBeaconFilterTable (TI_HANDLE hCmdBld, + TI_UINT8 uNumberOfIEs, + TI_UINT8 *pIETable, + TI_UINT8 uIETableSize, + void *fCb, + TI_HANDLE hCb) +{ + TCmdBld *pCmdBld = (TCmdBld *)hCmdBld; + + if (uIETableSize > BEACON_FILTER_TABLE_MAX_SIZE) + { + TRACE2(pCmdBld->hReport, REPORT_SEVERITY_ERROR, "cmdBld_CfgBeaconFilterTable: Table size is too big %d (>%d)\n", uIETableSize, BEACON_FILTER_TABLE_MAX_SIZE); + + return PARAM_VALUE_NOT_VALID; + } + + os_memoryZero (pCmdBld->hOs, + (void *)DB_WLAN(hCmdBld).beaconFilterIETable.IETable, + BEACON_FILTER_TABLE_MAX_SIZE); + os_memoryCopy (pCmdBld->hOs, + (void *)DB_WLAN(hCmdBld).beaconFilterIETable.IETable, + (void *)pIETable, + uIETableSize); + DB_WLAN(hCmdBld).beaconFilterIETable.numberOfIEs = uNumberOfIEs; + DB_WLAN(hCmdBld).beaconFilterIETable.IETableSize = uIETableSize; + + return cmdBld_CfgIeBeaconFilterTable (hCmdBld, uNumberOfIEs, pIETable, uIETableSize, fCb, hCb); +} + + +/*----------------------------------------*/ +/* Roaming Trigger Configuration Commands */ +/*----------------------------------------*/ + +/**************************************************************************** + * cmdBld_CfgRssiSnrTrigger() + **************************************************************************** + * DESCRIPTION: Set the RSSI/SNR Trigger parameters. + * + * INPUTS: + * + * OUTPUT: None + * + * RETURNS: None + ****************************************************************************/ +TI_STATUS cmdBld_CfgRssiSnrTrigger (TI_HANDLE hCmdBld, RssiSnrTriggerCfg_t *pTriggerParam, void *fCb, TI_HANDLE hCb) +{ + DB_WLAN(hCmdBld).tRssiSnrTrigger[pTriggerParam->index].index = pTriggerParam->index; + DB_WLAN(hCmdBld).tRssiSnrTrigger[pTriggerParam->index].threshold = pTriggerParam->threshold; + DB_WLAN(hCmdBld).tRssiSnrTrigger[pTriggerParam->index].pacing = pTriggerParam->pacing; + DB_WLAN(hCmdBld).tRssiSnrTrigger[pTriggerParam->index].metric = pTriggerParam->metric; + DB_WLAN(hCmdBld).tRssiSnrTrigger[pTriggerParam->index].type = pTriggerParam->type; + DB_WLAN(hCmdBld).tRssiSnrTrigger[pTriggerParam->index].direction = pTriggerParam->direction; + DB_WLAN(hCmdBld).tRssiSnrTrigger[pTriggerParam->index].hystersis = pTriggerParam->hystersis; + DB_WLAN(hCmdBld).tRssiSnrTrigger[pTriggerParam->index].enable = pTriggerParam->enable; + + return cmdBld_CfgIeRssiSnrTrigger (hCmdBld, pTriggerParam, fCb, hCb); +} + + +/**************************************************************************** + * cmdBld_CfgRssiSnrWeights() + **************************************************************************** + * DESCRIPTION: Set RSSI/SNR Weights for Average calculations. + * + * INPUTS: + * + * OUTPUT: None + * + * RETURNS: None + ****************************************************************************/ +TI_STATUS cmdBld_CfgRssiSnrWeights (TI_HANDLE hCmdBld, RssiSnrAverageWeights_t *pWeightsParam, void *fCb, TI_HANDLE hCb) +{ + TCmdBld *pCmdBld = (TCmdBld *)hCmdBld; + + 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 ); + + DB_WLAN(hCmdBld).tRssiSnrWeights.rssiBeaconAverageWeight = pWeightsParam->rssiBeaconAverageWeight; + DB_WLAN(hCmdBld).tRssiSnrWeights.rssiPacketAverageWeight = pWeightsParam->rssiPacketAverageWeight; + DB_WLAN(hCmdBld).tRssiSnrWeights.snrBeaconAverageWeight = pWeightsParam->snrBeaconAverageWeight ; + DB_WLAN(hCmdBld).tRssiSnrWeights.snrPacketAverageWeight = pWeightsParam->snrPacketAverageWeight ; + + return cmdBld_CfgIeRssiSnrWeights (hCmdBld, pWeightsParam, fCb, hCb); +} + + +/**************************************************************************** + * cmdBld_CfgMaxTxRetry() + **************************************************************************** + * DESCRIPTION: Set Max Tx retry parmaters. + * + * INPUTS: + * maxTxRetry max Tx Retry + * + * OUTPUT: None + * + * RETURNS: None + ****************************************************************************/ +TI_STATUS cmdBld_CfgMaxTxRetry (TI_HANDLE hCmdBld, TRroamingTriggerParams *pRoamingTriggerCmd, void *fCb, TI_HANDLE hCb) +{ + DB_WLAN(hCmdBld).roamTriggers.maxTxRetry = pRoamingTriggerCmd->maxTxRetry; + + return cmdBld_CfgIeMaxTxRetry (hCmdBld, pRoamingTriggerCmd, fCb, hCb); +} + + +/**************************************************************************** + * cmdBld_CfgSgEnable() + **************************************************************************** + * DESCRIPTION: Save Soft Gemini enable parameter + * + * INPUTS: + * + * OUTPUT: + * + * RETURNS: TI_OK or TI_NOK + ****************************************************************************/ +TI_STATUS cmdBld_CfgSgEnable (TI_HANDLE hCmdBld, ESoftGeminiEnableModes eSgEnable, void *fCb, TI_HANDLE hCb) +{ + DB_WLAN(hCmdBld).SoftGeminiEnable = eSgEnable; + + return cmdBld_CfgIeSgEnable (hCmdBld, eSgEnable, fCb, hCb); +} + + +/**************************************************************************** + * cmdBld_CfgSg() + **************************************************************************** + * DESCRIPTION: Save Soft Gemini config parameter + * + * INPUTS: + * + * OUTPUT: + * + * RETURNS: TI_OK or TI_NOK + ****************************************************************************/ +TI_STATUS cmdBld_CfgSg (TI_HANDLE hCmdBld, TSoftGeminiParams *pSgParam, void *fCb, TI_HANDLE hCb) +{ + TCmdBld *pCmdBld = (TCmdBld *)hCmdBld; + + /* Copy params for recovery */ + os_memoryCopy (pCmdBld->hOs, + (void*)&DB_WLAN(hCmdBld).SoftGeminiParams, + (void*)pSgParam, + sizeof(TSoftGeminiParams)); + + return cmdBld_CfgIeSg (hCmdBld, pSgParam, fCb, hCb); +} + +/**************************************************************************** + * cmdBld_CfgCoexActivity() + **************************************************************************** + * DESCRIPTION: Sets the CoexActivity table. + * + * OUTPUT: None + * + * RETURNS: TI_OK or TI_NOK pWlanParams->RtsThreshold + ****************************************************************************/ +TI_STATUS cmdBld_CfgCoexActivity (TI_HANDLE hCmdBld, TCoexActivity *pCoexActivity, void *fCb, TI_HANDLE hCb) +{ + TCmdBld *pCmdBld = (TCmdBld *)hCmdBld; + TWlanParams *pWlanParams = &DB_WLAN(hCmdBld); + TCoexActivity *pSaveCoex = &pWlanParams->tWlanParamsCoexActivityTable.entry[0]; + int numOfElements = pWlanParams->tWlanParamsCoexActivityTable.numOfElements; + int i; + + /* Check if to overwrite existing entry or put on last index */ + for (i=0; iactivityId) && (pSaveCoex->coexIp == pCoexActivity->coexIp)) + { + break; + } + } + + TRACE4(pCmdBld->hReport, REPORT_SEVERITY_INFORMATION , "cmdBld_CfgCoexActivity: save Param %d in index %d, %d %d\n", 0, i, pCoexActivity->coexIp, pCoexActivity->activityId); + /* save in WlanParams for recovery */ + pSaveCoex[i].coexIp = pCoexActivity->coexIp; + pSaveCoex[i].activityId = pCoexActivity->activityId; + pSaveCoex[i].defaultPriority = pCoexActivity->defaultPriority; + pSaveCoex[i].raisedPriority = pCoexActivity->raisedPriority; + pSaveCoex[i].minService = pCoexActivity->minService; + pSaveCoex[i].maxService = pCoexActivity->maxService; + + if (i == numOfElements) + { + /* no existing entry overwrite, increment number of elements */ + pWlanParams->tWlanParamsCoexActivityTable.numOfElements++; + } + + return cmdBld_CfgIeCoexActivity (hCmdBld, pCoexActivity, fCb, hCb); +} + +/**************************************************************************** + * cmdBld_CfgFmCoex() + **************************************************************************** + * DESCRIPTION: Save and configure FM coexistence parameters + * + * INPUTS: + * + * OUTPUT: + * + * RETURNS: TI_OK or TI_NOK + ****************************************************************************/ +TI_STATUS cmdBld_CfgFmCoex (TI_HANDLE hCmdBld, TFmCoexParams *pFmCoexParams, void *fCb, TI_HANDLE hCb) +{ + TCmdBld *pCmdBld = (TCmdBld *)hCmdBld; + + /* Copy params for recovery */ + os_memoryCopy (pCmdBld->hOs, + (void*)&(DB_WLAN(hCmdBld).tFmCoexParams), + (void*)pFmCoexParams, + sizeof(TFmCoexParams)); + + return cmdBld_CfgIeFmCoex (hCmdBld, pFmCoexParams, fCb, hCb); +} + +/**************************************************************************** + * cmdBld_CfgTxRatePolicy() + **************************************************************************** + * DESCRIPTION: configure TxRatePolicy params + * + * INPUTS: None + * + * OUTPUT: None + * + * RETURNS: TI_OK or TI_NOK + ****************************************************************************/ +TI_STATUS cmdBld_CfgTxRatePolicy (TI_HANDLE hCmdBld, TTxRatePolicy *pTxRatePolicy, void *fCb, TI_HANDLE hCb) +{ + TCmdBld *pCmdBld = (TCmdBld *)hCmdBld; + TTxRateClass *pTxRateClass = pTxRatePolicy->rateClass; + TI_UINT8 index; + + TRACE1(pCmdBld->hReport, REPORT_SEVERITY_INFORMATION, "_1, Num of classes = 0x%x\n", pTxRatePolicy->numOfRateClasses); + + DB_BSS(hCmdBld).TxRateClassParams.numOfRateClasses = pTxRatePolicy->numOfRateClasses; + + for (index = 0; index < pTxRatePolicy->numOfRateClasses; index++, pTxRateClass++) + { + 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); + + DB_BSS(hCmdBld).TxRateClassParams.rateClass[index] = *pTxRateClass; + } + + return cmdBld_CfgIeTxRatePolicy (hCmdBld, pTxRatePolicy, fCb, hCb); +} + + +TI_STATUS cmdBld_CfgSlotTime (TI_HANDLE hCmdBld, ESlotTime eSlotTime, void *fCb, TI_HANDLE hCb) +{ + TCmdBld *pCmdBld = (TCmdBld *)hCmdBld; + + DB_WLAN(hCmdBld).SlotTime = eSlotTime; + + TRACE1(pCmdBld->hReport, REPORT_SEVERITY_INFORMATION, "cmdBld_CfgSlotTime: Slot time = %d\n", eSlotTime); + + /* Configure the new Slot-Time value to the FW. */ + return cmdBld_CfgIeSlotTime (hCmdBld, (TI_UINT8)eSlotTime, fCb, hCb); +} + + +TI_STATUS cmdBld_CfgEventMask (TI_HANDLE hCmdBld, TI_UINT32 uEventMask, void *fCb, TI_HANDLE hCb) +{ + return cmdBld_CfgIeEventMask (hCmdBld, uEventMask, fCb, hCb); +} + + +/* + * ---------------------------------------------------------------------------- + * Function : cmdBld_CfgHwEncEnable + * + * Input : + * Output : + * Process : + * Note(s) : + * ----------------------------------------------------------------------------- + */ +TI_STATUS cmdBld_CfgHwEncEnable (TI_HANDLE hCmdBld, TI_BOOL bHwEncEnable, TI_BOOL bHwDecEnable, void *fCb, TI_HANDLE hCb) +{ + TCmdBld *pCmdBld = (TCmdBld *)hCmdBld; + TWlanParams *pWlanParams = &DB_WLAN(hCmdBld); + + /* Store the HW encryption Enable flag for reconfigure time (FW reload)*/ + DB_KEYS(pCmdBld).bReconfHwEncEnable = bHwEncEnable; + DB_KEYS(pCmdBld).bHwEncDecrEnableValid = TI_TRUE; + + if (bHwEncEnable) + { + pWlanParams->FeatureDataFlowOptions &= ~DF_ENCRYPTION_DISABLE; + } + else + { + pWlanParams->FeatureDataFlowOptions |= DF_ENCRYPTION_DISABLE; + } + + /* Set bit DF_SNIFF_MODE_ENABLE to enable or prevent decryption in fw */ + /* WARNING: Have to check how to control the decryption (which bit) and then set/reset + the appropriate bit*/ + if (bHwDecEnable) + { + pWlanParams->FeatureDataFlowOptions &= ~DF_SNIFF_MODE_ENABLE; + } + else + { + pWlanParams->FeatureDataFlowOptions |= DF_SNIFF_MODE_ENABLE; + } + + return cmdBld_CfgIeFeatureConfig (hCmdBld, + pWlanParams->FeatureOptions, + pWlanParams->FeatureDataFlowOptions, + fCb, + hCb); +} + + +TI_STATUS cmdBld_CfgHwEncDecEnable (TI_HANDLE hCmdBld, TI_BOOL bHwEncEnable, void *fCb, TI_HANDLE hCb) +{ + return cmdBld_CfgHwEncEnable (hCmdBld, bHwEncEnable, bHwEncEnable, fCb, hCb); +} + + +/* + * ---------------------------------------------------------------------------- + * Function : cmdBld_CfgSecureMode + * + * Input : + * Output : + * Process : + * Note(s) : + * ----------------------------------------------------------------------------- + */ +TI_STATUS cmdBld_CfgSecureMode (TI_HANDLE hCmdBld, ECipherSuite eSecurMode, void *fCb, TI_HANDLE hCb) +{ + TCmdBld *pCmdBld = (TCmdBld *)hCmdBld; + TI_UINT32 index; + + if (eSecurMode < TWD_CIPHER_MAX) + { + TRACE2(pCmdBld->hReport, REPORT_SEVERITY_INFORMATION , "cmdBld_CfgSecureMode: change tSecurity mode from %d --> %d\n", pCmdBld->tSecurity.eSecurityMode, eSecurMode); + /* check if tSecurity mode is equal to previous one*/ + if (pCmdBld->tSecurity.eSecurityMode == eSecurMode) + { + return TI_OK; + } + + /* Reset all reconfig valid fields*/ + DB_KEYS(pCmdBld).bHwEncDecrEnableValid = TI_FALSE; + DB_KEYS(pCmdBld).bDefaultKeyIdValid = TI_FALSE; + for (index = 0; + index < pCmdBld->tSecurity.uNumOfStations * NO_OF_RECONF_SECUR_KEYS_PER_STATION + NO_OF_EXTRA_RECONF_SECUR_KEYS; + index++) + { + (DB_KEYS(pCmdBld).pReconfKeys + index)->keyType = KEY_NULL; + } + + /* set the new tSecurity mode*/ + pCmdBld->tSecurity.eSecurityMode = eSecurMode; + + /* disable defrag, duplicate detection on TNETW+XCC on chip level*/ + /* YV- to add fragmentation control (if there is- artur ?)*/ + return cmdBld_CfgRxMsduFormat (hCmdBld, + pCmdBld->tSecurity.eSecurityMode != TWD_CIPHER_CKIP, + fCb, + hCb); + } + else + { + return TI_NOK; + } +} + + +TI_STATUS cmdBld_CfgConnMonitParams (TI_HANDLE hCmdBld, + TRroamingTriggerParams *pRoamingTriggerCmd, + void *fCb, + TI_HANDLE hCb) +{ + TCmdBld *pCmdBld = (TCmdBld *)hCmdBld; + + TRACE2(pCmdBld->hReport, REPORT_SEVERITY_INFORMATION , "SetBssLossTsfThresholdParamsCmd :\n BssLossTimeout = %d\n TsfMissThreshold = %d \n ", pRoamingTriggerCmd->BssLossTimeout, pRoamingTriggerCmd->TsfMissThreshold); + + DB_WLAN(hCmdBld).roamTriggers.BssLossTimeout = pRoamingTriggerCmd->BssLossTimeout; + DB_WLAN(hCmdBld).roamTriggers.TsfMissThreshold = pRoamingTriggerCmd->TsfMissThreshold; + + return cmdBld_CfgIeConnMonitParams (hCmdBld, pRoamingTriggerCmd, fCb, hCb); +} + + +/**************************************************************************** + * cmdBld_CfgEnableRxDataFilter() + **************************************************************************** + * DESCRIPTION: Enables or disables Rx data filtering. + * + * INPUTS: enabled - 0 to disable data filtering, any other value to enable. + * defaultAction - The default action to take on non-matching packets. + * + * OUTPUT: None + * + * RETURNS: TI_OK or TI_NOK + ****************************************************************************/ +TI_STATUS cmdBld_CfgEnableRxDataFilter (TI_HANDLE hCmdBld, + TI_BOOL bEnabled, + filter_e eDefaultAction, + void *fCb, + TI_HANDLE hCb) +{ + /* Save parameters for reconfig phase */ + DB_RX_DATA_FLTR(hCmdBld).bEnabled = bEnabled; + DB_RX_DATA_FLTR(hCmdBld).eDefaultAction = eDefaultAction; + + return cmdBld_CfgIeEnableRxDataFilter (hCmdBld, bEnabled, eDefaultAction, fCb, hCb); +} + + +/**************************************************************************** +* cmdBld_CfgRxDataFilter() +***************************************************************************** +* DESCRIPTION: Add/remove Rx Data filter information element. +* +* INPUTS: index - Index of the Rx Data filter +* command - Add or remove the filter +* action - Action to take on packets matching the pattern +* numFieldPatterns - Number of field patterns in the filter +* lenFieldPatterns - Length of the field pattern series +* fieldPatterns - Series of field patterns +* +* OUTPUT: None +* +* RETURNS: TI_OK or TI_NOK +****************************************************************************/ +TI_STATUS cmdBld_CfgRxDataFilter (TI_HANDLE hCmdBld, + TI_UINT8 index, + TI_UINT8 command, + filter_e eAction, + TI_UINT8 uNumFieldPatterns, + TI_UINT8 uLenFieldPatterns, + TI_UINT8 *pFieldPatterns, + void *fCb, + TI_HANDLE hCb) +{ + TCmdBld *pCmdBld = (TCmdBld *)hCmdBld; + TRxDataFilter *pFilters = &(DB_RX_DATA_FLTR(hCmdBld).aRxDataFilter[index]); + + /* Save parameters for reconfig phase */ + pFilters->uIndex = index; + pFilters->uCommand = command; + pFilters->eAction = eAction; + pFilters->uNumFieldPatterns = uNumFieldPatterns; + pFilters->uLenFieldPatterns = uLenFieldPatterns; + os_memoryCopy(pCmdBld->hOs, pFilters->aFieldPattern, pFieldPatterns, uLenFieldPatterns); + + return cmdBld_CfgIeRxDataFilter (hCmdBld, + index, + command, + eAction, + uNumFieldPatterns, + uLenFieldPatterns, + pFieldPatterns, + fCb, + hCb); +} + + +TI_STATUS cmdBld_CfgCtsProtection (TI_HANDLE hCmdBld, TI_UINT8 uCtsProtection, void *fCb, TI_HANDLE hCb) + { + DB_WLAN(hCmdBld).CtsToSelf = uCtsProtection; + + return cmdBld_CfgIeCtsProtection (hCmdBld, uCtsProtection, fCb, hCb); +} + + +TI_STATUS cmdBld_CfgServicePeriodTimeout (TI_HANDLE hCmdBld, TRxTimeOut *pRxTimeOut, void *fCb, TI_HANDLE hCb) +{ + return cmdBld_CfgIeServicePeriodTimeout (hCmdBld, pRxTimeOut, fCb, hCb); +} + + +TI_STATUS cmdBld_CfgRxMsduLifeTime (TI_HANDLE hCmdBld, TI_UINT32 uRxMsduLifeTime, void *fCb, TI_HANDLE hCb) + { + DB_WLAN(hCmdBld).MaxRxMsduLifetime = uRxMsduLifeTime; + + return cmdBld_CfgIeRxMsduLifeTime (hCmdBld, uRxMsduLifeTime, fCb, hCb); +} + + +TI_STATUS cmdBld_CfgStatisitics (TI_HANDLE hCmdBld, void *fCb, TI_HANDLE hCb) +{ + return cmdBld_CfgIeStatisitics (hCmdBld, fCb, hCb); +} + + +TI_STATUS cmdBld_CfgTxPowerDbm (TI_HANDLE hCmdBld, TI_UINT8 uTxPowerDbm, void *fCb, TI_HANDLE hCb) +{ + return cmdBld_CfgIeTxPowerDbm (hCmdBld, uTxPowerDbm, fCb, hCb); +} + + /* + * ---------------------------------------------------------------------------- + * Function : cmdBld_CfgBet + * + * Input : enabled - 0 to disable BET, 0 to disable BET + * MaximumConsecutiveET - Max number of consecutive beacons + * that may be early terminated. + * Output : TI_STATUS + * Process : Configures Beacon Early Termination information element. + * Note(s) : None + * ----------------------------------------------------------------------------- + */ +TI_STATUS cmdBld_CfgBet (TI_HANDLE hCmdBld, TI_UINT8 Enable, TI_UINT8 MaximumConsecutiveET, void *fCb, TI_HANDLE hCb) +{ + DB_WLAN(hCmdBld).BetEnable = Enable; + DB_WLAN(hCmdBld).MaximumConsecutiveET = MaximumConsecutiveET; + + return cmdBld_CfgIeBet (hCmdBld, Enable, MaximumConsecutiveET, fCb, hCb); +} + +/**************************************************************************** + * cmdBld_CfgKeepAlive() + **************************************************************************** + * DESCRIPTION: Set keep-alive paramters for a single index + * + * INPUTS: Paramters and CB + * + * OUTPUT: None + * + * RETURNS: TI_OK or TI_NOK + ****************************************************************************/ +TI_STATUS cmdBld_CfgKeepAlive (TI_HANDLE hCmdBld, TKeepAliveParams *pKeepAliveParams, void *fCb, TI_HANDLE hCb) +{ + TCmdBld *pCmdBld = (TCmdBld *)hCmdBld; + + 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); + + os_memoryCopy (pCmdBld->hOs, + (void *)&DB_KLV(hCmdBld).keepAliveParams[ pKeepAliveParams->index ], + (void *)pKeepAliveParams, + sizeof (TKeepAliveParams)); + + return cmdBld_CmdIeConfigureKeepAliveParams (hCmdBld, + pKeepAliveParams->index, + pKeepAliveParams->enaDisFlag, + (TI_UINT8)pKeepAliveParams->trigType, + pKeepAliveParams->interval, + fCb, + hCb); +} + +/**************************************************************************** + * cmdBld_CfgKeepAliveEnaDis() + **************************************************************************** + * DESCRIPTION: Set global keep-alive enable / disable flag + * + * INPUTS: Paramters and CB + * + * OUTPUT: None + * + * RETURNS: TI_OK or TI_NOK + ****************************************************************************/ +TI_STATUS cmdBld_CfgKeepAliveEnaDis(TI_HANDLE hCmdBld, TI_UINT8 enaDisFlag, void *fCb, TI_HANDLE hCb) +{ + TCmdBld *pCmdBld = (TCmdBld *)hCmdBld; + + TRACE1(pCmdBld->hReport, REPORT_SEVERITY_INFORMATION , "CmdBld: Seeting keep-alive Global ena / dis flag to %d\n", (TI_UINT32)enaDisFlag); + + DB_KLV(hCmdBld).enaDisFlag = enaDisFlag; + + return cmdBld_CmdIeConfigureKeepAliveEnaDis (hCmdBld, enaDisFlag, fCb, hCb); +} + +/** + * \fn cmdBld_CfgSetFwHtCapabilities + * \brief set the current AP HT Capabilities to the FW. + * + * \note + * \return TI_OK on success or TI_NOK on failure + * \sa + */ +TI_STATUS cmdBld_CfgSetFwHtCapabilities (TI_HANDLE hCmdBld, + TI_UINT32 uHtCapabilites, + TMacAddr tMacAddress, + TI_UINT8 uAmpduMaxLeng, + TI_UINT8 uAmpduMinSpac, + void *fCb, + TI_HANDLE hCb) +{ + + DB_BSS(hCmdBld).bHtCap = TI_TRUE; + DB_BSS(hCmdBld).uHtCapabilites = uHtCapabilites; + MAC_COPY ((DB_BSS(hCmdBld).tMacAddress), tMacAddress); + DB_BSS(hCmdBld).uAmpduMaxLeng = uAmpduMaxLeng; + DB_BSS(hCmdBld).uAmpduMinSpac = uAmpduMinSpac; + + return cmdBld_CfgIeSetFwHtCapabilities (hCmdBld, + uHtCapabilites, + tMacAddress, + uAmpduMaxLeng, + uAmpduMinSpac, + fCb, + hCb); +} + +/** + * \fn cmdBld_CfgSetFwHtInformation + * \brief set the current AP HT Information to the FW. + * + * \note + * \return TI_OK on success or TI_NOK on failure + * \sa + */ +TI_STATUS cmdBld_CfgSetFwHtInformation (TI_HANDLE hCmdBld, + TI_UINT8 uRifsMode, + TI_UINT8 uHtProtection, + TI_UINT8 uGfProtection, + TI_UINT8 uHtTxBurstLimit, + TI_UINT8 uDualCtsProtection, + void *fCb, + TI_HANDLE hCb) +{ + + DB_BSS(hCmdBld).bHtInf = TI_TRUE; + DB_BSS(hCmdBld).uRifsMode = uRifsMode; + DB_BSS(hCmdBld).uHtProtection = uHtProtection; + DB_BSS(hCmdBld).uGfProtection = uGfProtection; + DB_BSS(hCmdBld).uHtTxBurstLimit = uHtTxBurstLimit; + DB_BSS(hCmdBld).uDualCtsProtection = uDualCtsProtection; + + return cmdBld_CfgIeSetFwHtInformation (hCmdBld, + uRifsMode, + uHtProtection, + uGfProtection, + uHtTxBurstLimit, + uDualCtsProtection, + fCb, + hCb); +} + +/** + * \fn cmdBld_CfgSetBaInitiator + * \brief configure BA session initiator\receiver parameters setting in the FW. + * + * \note + * \return TI_OK on success or TI_NOK on failure + * \sa + */ +TI_STATUS cmdBld_CfgSetBaSession (TI_HANDLE hCmdBld, + InfoElement_e eBaType, + TI_UINT8 uTid, + TI_UINT8 uState, + TMacAddr tRa, + TI_UINT16 uWinSize, + TI_UINT16 uInactivityTimeout, + void *fCb, + TI_HANDLE hCb) +{ + if (ACX_BA_SESSION_INITIATOR_POLICY == eBaType) + { + DB_BSS(hCmdBld).bBaInitiator[uTid] = TI_TRUE; + DB_BSS(hCmdBld).tBaSessionInitiatorPolicy[uTid].uTid = uTid; + DB_BSS(hCmdBld).tBaSessionInitiatorPolicy[uTid].uPolicy = uState; + MAC_COPY ((DB_BSS(hCmdBld).tBaSessionInitiatorPolicy[uTid].aMacAddress),tRa); + DB_BSS(hCmdBld).tBaSessionInitiatorPolicy[uTid].uWinSize = uWinSize; + DB_BSS(hCmdBld).tBaSessionInitiatorPolicy[uTid].uInactivityTimeout = uInactivityTimeout; + } + else + { + DB_BSS(hCmdBld).bBaResponder[uTid] = TI_TRUE; + DB_BSS(hCmdBld).tBaSessionResponderPolicy[uTid].uTid = uTid; + DB_BSS(hCmdBld).tBaSessionResponderPolicy[uTid].uPolicy = uState; + MAC_COPY ((DB_BSS(hCmdBld).tBaSessionResponderPolicy[uTid].aMacAddress),tRa); + DB_BSS(hCmdBld).tBaSessionResponderPolicy[uTid].uWinSize = uWinSize; + DB_BSS(hCmdBld).tBaSessionResponderPolicy[uTid].uInactivityTimeout = uInactivityTimeout; + } + + return cmdBld_CfgIeSetBaSession (hCmdBld, + eBaType, + uTid, + uState, + tRa, + uWinSize, + uInactivityTimeout, + fCb, + hCb); +} + + +TI_STATUS cmdBld_CfgBurstMode (TI_HANDLE hCmdBld, TI_BOOL bEnabled, void *fCb, TI_HANDLE hCb) +{ + DB_AC(hCmdBld).isBurstModeEnabled = bEnabled; + return cmdBld_CfgIeBurstMode (hCmdBld, bEnabled, fCb, hCb); +} +