MT7601u/src/common/cmm_info.c
Murat Demirtas 612db32659 FIXED
2016-10-30 14:40:00 +00:00

6657 lines
181 KiB
C

/****************************************************************************
* Ralink Tech Inc.
* 4F, No. 2 Technology 5th Rd.
* Science-based Industrial Park
* Hsin-chu, Taiwan, R.O.C.
* (c) Copyright 2002, Ralink Technology, Inc.
*
* All rights reserved. Ralink's source code is an unpublished work and the
* use of a copyright notice does not imply otherwise. This source code
* contains confidential trade secret material of Ralink Tech. Any attemp
* or participation in deciphering, decoding, reverse engineering or in any
* way altering the source code is stricitly prohibited, unless the prior
* written consent of Ralink Technology, Inc. is obtained.
****************************************************************************
Module Name:
cmm_info.c
Abstract:
Revision History:
Who When What
--------- ---------- ----------------------------------------------
*/
#include "rt_config.h"
/*
==========================================================================
Description:
Get Driver version.
Return:
==========================================================================
*/
INT Set_DriverVersion_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
#ifdef CONFIG_AP_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
DBGPRINT(RT_DEBUG_TRACE, ("Driver version-%s\n", AP_DRIVER_VERSION));
#endif /* CONFIG_AP_SUPPORT */
#ifdef CONFIG_STA_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_STA(pAd)
DBGPRINT(RT_DEBUG_TRACE, ("Driver version-%s\n", STA_DRIVER_VERSION));
#endif /* CONFIG_STA_SUPPORT */
return TRUE;
}
/*
==========================================================================
Description:
Set Country Region.
This command will not work, if the field of CountryRegion in eeprom is programmed.
Return:
TRUE if all parameters are OK, FALSE otherwise
==========================================================================
*/
INT Set_CountryRegion_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
int retval;
#ifdef EXT_BUILD_CHANNEL_LIST
return -EOPNOTSUPP;
#endif /* EXT_BUILD_CHANNEL_LIST */
retval = RT_CfgSetCountryRegion(pAd, arg, BAND_24G);
if (retval == FALSE)
return FALSE;
/* if set country region, driver needs to be reset*/
BuildChannelList(pAd);
DBGPRINT(RT_DEBUG_TRACE, ("Set_CountryRegion_Proc::(CountryRegion=%d)\n", pAd->CommonCfg.CountryRegion));
return TRUE;
}
/*
==========================================================================
Description:
Set Country Region for A band.
This command will not work, if the field of CountryRegion in eeprom is programmed.
Return:
TRUE if all parameters are OK, FALSE otherwise
==========================================================================
*/
INT Set_CountryRegionABand_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
int retval;
#ifdef EXT_BUILD_CHANNEL_LIST
return -EOPNOTSUPP;
#endif /* EXT_BUILD_CHANNEL_LIST */
retval = RT_CfgSetCountryRegion(pAd, arg, BAND_5G);
if (retval == FALSE)
return FALSE;
/* if set country region, driver needs to be reset*/
BuildChannelList(pAd);
DBGPRINT(RT_DEBUG_TRACE, ("Set_CountryRegionABand_Proc::(CountryRegion=%d)\n", pAd->CommonCfg.CountryRegionForABand));
return TRUE;
}
INT Set_Cmm_WirelessMode_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg,
IN BOOLEAN FlgIsDiffMbssModeUsed)
{
INT success = TRUE;
#ifdef CONFIG_AP_SUPPORT
UINT32 i = 0;
#ifdef MBSS_SUPPORT
POS_COOKIE pObj = (POS_COOKIE) pAd->OS_Cookie;
if (FlgIsDiffMbssModeUsed) {
LONG cfg_mode = simple_strtol(arg, 0, 10);
/* assign wireless mode for the BSS */
pAd->ApCfg.MBSSID[pObj->ioctl_if].PhyMode =
cfgmode_2_wmode((UCHAR)cfg_mode);
/*
If the band is different with other BSS, we will correct it in
RT_CfgSetMbssWirelessMode()
*/
success = RT_CfgSetMbssWirelessMode(pAd, arg);
}
else
#endif /* MBSS_SUPPORT */
#endif /* CONFIG_AP_SUPPORT */
success = RT_CfgSetWirelessMode(pAd, arg);
if (success)
{
#ifdef CONFIG_AP_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
{
/* recover Wmm Capable for "each" BSS */
/* all phy mode of MBSS are the same */
for(i=0; i<pAd->ApCfg.BssidNum; i++)
{
pAd->ApCfg.MBSSID[i].bWmmCapable = \
pAd->ApCfg.MBSSID[i].bWmmCapableOrg;
#ifdef MBSS_SUPPORT
/* In Same-MBSS Mode, all phy modes are the same */
if (FlgIsDiffMbssModeUsed == 0)
pAd->ApCfg.MBSSID[i].PhyMode = pAd->CommonCfg.PhyMode;
#endif /* MBSS_SUPPORT */
}
RTMPSetPhyMode(pAd, pAd->CommonCfg.PhyMode);
}
#endif /* CONFIG_AP_SUPPORT */
#ifdef CONFIG_STA_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_STA(pAd)
{
/* clean up previous SCAN result */
BssTableInit(&pAd->ScanTab);
pAd->StaCfg.LastScanTime = 0;
RTMPSetPhyMode(pAd, pAd->CommonCfg.PhyMode);
/* Set AdhocMode rates*/
if (pAd->StaCfg.BssType == BSS_ADHOC)
{
MlmeUpdateTxRates(pAd, FALSE, 0);
MakeIbssBeacon(pAd); /* re-build BEACON frame*/
AsicEnableIbssSync(pAd); /* copy to on-chip memory*/
}
}
#endif /* CONFIG_STA_SUPPORT */
#ifdef CONFIG_AP_SUPPORT
#ifdef MBSS_SUPPORT
DBGPRINT(RT_DEBUG_TRACE, ("Set_Cmm_WirelessMode_Proc::(=%d)\n", pAd->CommonCfg.PhyMode));
DBGPRINT(RT_DEBUG_TRACE, ("Set_Cmm_WirelessMode_Proc::(BSS%d=%d)\n",
pObj->ioctl_if, pAd->ApCfg.MBSSID[pObj->ioctl_if].PhyMode));
for(i=0; i<pAd->ApCfg.BssidNum; i++)
{
/*
When last mode is not 11B-only, new mode is 11B, we need to re-make
beacon frame content.
Because we put support rate/extend support rate element in
APMakeBssBeacon(), not APUpdateBeaconFrame().
*/
APMakeBssBeacon(pAd, i);
}
#endif /* MBSS_SUPPORT */
#endif /* CONFIG_AP_SUPPORT */
}
else
{
DBGPRINT(RT_DEBUG_ERROR, ("Set_WirelessMode_Proc::parameters out of range\n"));
}
return success;
}
#ifdef CONFIG_AP_SUPPORT
#ifdef MBSS_SUPPORT
/*
==========================================================================
Description:
Set Wireless Mode for MBSS
Return:
TRUE if all parameters are OK, FALSE otherwise
==========================================================================
*/
INT Set_MBSS_WirelessMode_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
return Set_Cmm_WirelessMode_Proc(pAd, arg, 1);
}
#endif /* MBSS_SUPPORT */
#endif /* CONFIG_AP_SUPPORT */
/*
==========================================================================
Description:
Set Wireless Mode
Return:
TRUE if all parameters are OK, FALSE otherwise
==========================================================================
*/
INT Set_WirelessMode_Proc(RTMP_ADAPTER *pAd, PSTRING arg)
{
return Set_Cmm_WirelessMode_Proc(pAd, arg, 0);
}
/*
==========================================================================
Description:
Set Channel
Return:
TRUE if all parameters are OK, FALSE otherwise
==========================================================================
*/
INT Set_Channel_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
#ifdef CONFIG_AP_SUPPORT
INT i;
#endif /* CONFIG_AP_SUPPORT */
INT success = TRUE;
UCHAR Channel;
Channel = (UCHAR) simple_strtol(arg, 0, 10);
/* check if this channel is valid*/
if (ChannelSanity(pAd, Channel) == TRUE)
{
#ifdef CONFIG_STA_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_STA(pAd)
{
pAd->CommonCfg.Channel = Channel;
/* Save the channel on MlmeAux for CntlOidRTBssidProc used. */
pAd->MlmeAux.Channel = Channel;
if (MONITOR_ON(pAd))
{
UCHAR rf_channel;
#ifdef DOT11_N_SUPPORT
N_ChannelCheck(pAd);
if (WMODE_CAP_N(pAd->CommonCfg.PhyMode) &&
pAd->CommonCfg.RegTransmitSetting.field.BW == BW_40)
rf_channel = N_SetCenCh(pAd, pAd->CommonCfg.Channel);
else
#endif /* DOT11_N_SUPPORT */
rf_channel = pAd->CommonCfg.Channel;
AsicSwitchChannel(pAd, rf_channel, FALSE);
AsicLockChannel(pAd, rf_channel);
DBGPRINT(RT_DEBUG_TRACE, ("%s(): CtrlChannel(%d), CentralChannel(%d) \n",
__FUNCTION__, pAd->CommonCfg.Channel,
pAd->CommonCfg.CentralChannel));
}
}
#endif /* CONFIG_STA_SUPPORT */
success = TRUE;
}
else
{
#ifdef CONFIG_AP_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
{
Channel = FirstChannel(pAd);
DBGPRINT(RT_DEBUG_WARN,("This channel is out of channel list, set as the first channel(%d) \n ", Channel));
}
#endif /* CONFIG_AP_SUPPORT */
#ifdef CONFIG_STA_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_STA(pAd)
success = FALSE;
DBGPRINT(RT_DEBUG_WARN,("This channel is out of channel list, nothing to do!\n "));
#endif /* CONFIG_STA_SUPPORT */
}
#ifdef CONFIG_AP_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
{
if ((WMODE_CAP_5G(pAd->CommonCfg.PhyMode))
&& (pAd->CommonCfg.bIEEE80211H == TRUE))
{
for (i = 0; i < pAd->ChannelListNum; i++)
{
if (pAd->ChannelList[i].Channel == Channel)
{
if (pAd->ChannelList[i].RemainingTimeForUse > 0)
{
DBGPRINT(RT_DEBUG_ERROR, ("ERROR: previous detection of a radar on this channel(Channel=%d)\n", Channel));
success = FALSE;
break;
}
else
{
DBGPRINT(RT_DEBUG_INFO, ("RemainingTimeForUse %d ,Channel %d\n",
pAd->ChannelList[i].RemainingTimeForUse, Channel));
}
}
}
}
if (success == TRUE)
{
pAd->CommonCfg.Channel = Channel;
#ifdef DOT11_N_SUPPORT
N_ChannelCheck(pAd);
#endif /* DOT11_N_SUPPORT */
if ((pAd->CommonCfg.Channel > 14 )
&& (pAd->CommonCfg.bIEEE80211H == TRUE))
{
if (pAd->Dot11_H.RDMode == RD_SILENCE_MODE)
{
APStop(pAd);
APStartUp(pAd);
}
else
{
NotifyChSwAnnToPeerAPs(pAd, ZERO_MAC_ADDR, pAd->CurrentAddress, 1, pAd->CommonCfg.Channel);
pAd->Dot11_H.RDMode = RD_SWITCHING_MODE;
pAd->Dot11_H.CSCount = 0;
}
}
else
{
APStop(pAd);
APStartUp(pAd);
}
}
}
#endif /* CONFIG_AP_SUPPORT */
if (success == TRUE)
DBGPRINT(RT_DEBUG_TRACE, ("Set_Channel_Proc::(Channel=%d)\n", pAd->CommonCfg.Channel));
return success;
}
/*
==========================================================================
Description:
Set Short Slot Time Enable or Disable
Return:
TRUE if all parameters are OK, FALSE otherwise
==========================================================================
*/
INT Set_ShortSlot_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
int retval;
retval = RT_CfgSetShortSlot(pAd, arg);
if (retval == TRUE)
DBGPRINT(RT_DEBUG_TRACE, ("Set_ShortSlot_Proc::(ShortSlot=%d)\n", pAd->CommonCfg.bUseShortSlotTime));
return retval;
}
/*
==========================================================================
Description:
Set Tx power
Return:
TRUE if all parameters are OK, FALSE otherwise
==========================================================================
*/
INT Set_TxPower_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
LONG TxPower;
INT success = FALSE;
TxPower = simple_strtol(arg, 0, 10);
if (TxPower <= 100)
{
#ifdef CONFIG_AP_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
pAd->CommonCfg.TxPowerPercentage = TxPower;
#endif /* CONFIG_AP_SUPPORT */
#ifdef CONFIG_STA_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_STA(pAd)
{
pAd->CommonCfg.TxPowerDefault = TxPower;
pAd->CommonCfg.TxPowerPercentage = pAd->CommonCfg.TxPowerDefault;
}
#endif /* CONFIG_STA_SUPPORT */
success = TRUE;
}
else
success = FALSE;
DBGPRINT(RT_DEBUG_TRACE, ("Set_TxPower_Proc::(TxPowerPercentage=%ld)\n", pAd->CommonCfg.TxPowerPercentage));
return success;
}
/*
==========================================================================
Description:
Set 11B/11G Protection
Return:
TRUE if all parameters are OK, FALSE otherwise
==========================================================================
*/
INT Set_BGProtection_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
switch (simple_strtol(arg, 0, 10))
{
case 0: /*AUTO*/
pAd->CommonCfg.UseBGProtection = 0;
break;
case 1: /*Always On*/
pAd->CommonCfg.UseBGProtection = 1;
break;
case 2: /*Always OFF*/
pAd->CommonCfg.UseBGProtection = 2;
break;
default: /*Invalid argument */
return FALSE;
}
#ifdef CONFIG_AP_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
APUpdateCapabilityAndErpIe(pAd);
#endif /* CONFIG_AP_SUPPORT */
DBGPRINT(RT_DEBUG_TRACE, ("Set_BGProtection_Proc::(BGProtection=%ld)\n", pAd->CommonCfg.UseBGProtection));
return TRUE;
}
/*
==========================================================================
Description:
Set TxPreamble
Return:
TRUE if all parameters are OK, FALSE otherwise
==========================================================================
*/
INT Set_TxPreamble_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
RT_802_11_PREAMBLE Preamble;
Preamble = (RT_802_11_PREAMBLE)simple_strtol(arg, 0, 10);
#ifdef CONFIG_AP_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
if (Preamble == Rt802_11PreambleAuto)
return FALSE;
#endif /* CONFIG_AP_SUPPORT */
switch (Preamble)
{
case Rt802_11PreambleShort:
pAd->CommonCfg.TxPreamble = Preamble;
#ifdef CONFIG_STA_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_STA(pAd)
MlmeSetTxPreamble(pAd, Rt802_11PreambleShort);
#endif /* CONFIG_STA_SUPPORT */
break;
case Rt802_11PreambleLong:
#ifdef CONFIG_STA_SUPPORT
case Rt802_11PreambleAuto:
/*
If user wants AUTO, initialize to LONG here, then change according to AP's
capability upon association
*/
#endif /* CONFIG_STA_SUPPORT */
pAd->CommonCfg.TxPreamble = Preamble;
#ifdef CONFIG_STA_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_STA(pAd)
MlmeSetTxPreamble(pAd, Rt802_11PreambleLong);
#endif /* CONFIG_STA_SUPPORT */
break;
default: /*Invalid argument */
return FALSE;
}
DBGPRINT(RT_DEBUG_TRACE, ("Set_TxPreamble_Proc::(TxPreamble=%ld)\n", pAd->CommonCfg.TxPreamble));
return TRUE;
}
/*
==========================================================================
Description:
Set RTS Threshold
Return:
TRUE if all parameters are OK, FALSE otherwise
==========================================================================
*/
INT Set_RTSThreshold_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
NDIS_802_11_RTS_THRESHOLD RtsThresh;
RtsThresh = simple_strtol(arg, 0, 10);
if((RtsThresh > 0) && (RtsThresh <= MAX_RTS_THRESHOLD))
pAd->CommonCfg.RtsThreshold = (USHORT)RtsThresh;
#ifdef CONFIG_STA_SUPPORT
else if (RtsThresh == 0)
pAd->CommonCfg.RtsThreshold = MAX_RTS_THRESHOLD;
#endif /* CONFIG_STA_SUPPORT */
else
return FALSE; /*Invalid argument */
DBGPRINT(RT_DEBUG_TRACE, ("Set_RTSThreshold_Proc::(RTSThreshold=%d)\n", pAd->CommonCfg.RtsThreshold));
return TRUE;
}
/*
==========================================================================
Description:
Set Fragment Threshold
Return:
TRUE if all parameters are OK, FALSE otherwise
==========================================================================
*/
INT Set_FragThreshold_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
NDIS_802_11_FRAGMENTATION_THRESHOLD FragThresh;
FragThresh = simple_strtol(arg, 0, 10);
if (FragThresh > MAX_FRAG_THRESHOLD || FragThresh < MIN_FRAG_THRESHOLD)
{
/*Illegal FragThresh so we set it to default*/
pAd->CommonCfg.FragmentThreshold = MAX_FRAG_THRESHOLD;
}
else if (FragThresh % 2 == 1)
{
/*
The length of each fragment shall always be an even number of octets,
except for the last fragment of an MSDU or MMPDU, which may be either
an even or an odd number of octets.
*/
pAd->CommonCfg.FragmentThreshold = (USHORT)(FragThresh - 1);
}
else
{
pAd->CommonCfg.FragmentThreshold = (USHORT)FragThresh;
}
#ifdef CONFIG_STA_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_STA(pAd)
{
if (pAd->CommonCfg.FragmentThreshold == MAX_FRAG_THRESHOLD)
pAd->CommonCfg.bUseZeroToDisableFragment = TRUE;
else
pAd->CommonCfg.bUseZeroToDisableFragment = FALSE;
}
#endif /* CONFIG_STA_SUPPORT */
DBGPRINT(RT_DEBUG_TRACE, ("Set_FragThreshold_Proc::(FragThreshold=%d)\n", pAd->CommonCfg.FragmentThreshold));
return TRUE;
}
/*
==========================================================================
Description:
Set TxBurst
Return:
TRUE if all parameters are OK, FALSE otherwise
==========================================================================
*/
INT Set_TxBurst_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
LONG TxBurst;
TxBurst = simple_strtol(arg, 0, 10);
if (TxBurst == 1)
pAd->CommonCfg.bEnableTxBurst = TRUE;
else if (TxBurst == 0)
pAd->CommonCfg.bEnableTxBurst = FALSE;
else
return FALSE; /*Invalid argument */
DBGPRINT(RT_DEBUG_TRACE, ("Set_TxBurst_Proc::(TxBurst=%d)\n", pAd->CommonCfg.bEnableTxBurst));
return TRUE;
}
#ifdef AGGREGATION_SUPPORT
/*
==========================================================================
Description:
Set TxBurst
Return:
TRUE if all parameters are OK, FALSE otherwise
==========================================================================
*/
INT Set_PktAggregate_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
LONG aggre;
aggre = simple_strtol(arg, 0, 10);
if (aggre == 1)
pAd->CommonCfg.bAggregationCapable = TRUE;
else if (aggre == 0)
pAd->CommonCfg.bAggregationCapable = FALSE;
else
return FALSE; /*Invalid argument */
#ifdef CONFIG_AP_SUPPORT
#ifdef PIGGYBACK_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
{
pAd->CommonCfg.bPiggyBackCapable = pAd->CommonCfg.bAggregationCapable;
RTMPSetPiggyBack(pAd, pAd->CommonCfg.bPiggyBackCapable);
}
#endif /* PIGGYBACK_SUPPORT */
#endif /* CONFIG_AP_SUPPORT */
DBGPRINT(RT_DEBUG_TRACE, ("Set_PktAggregate_Proc::(AGGRE=%d)\n", pAd->CommonCfg.bAggregationCapable));
return TRUE;
}
#endif
#ifdef INF_PPA_SUPPORT
INT Set_INF_AMAZON_SE_PPA_Proc(
IN PRTMP_ADAPTER pAd,
IN PUCHAR arg)
{
ULONG aggre;
UINT status;
aggre = simple_strtol(arg, 0, 10);
if (aggre == 1)
{
if(pAd->PPAEnable==TRUE)
{
DBGPRINT(RT_DEBUG_TRACE, ("INF_AMAZON_SE_PPA already enabled \n"));
}
else
{
if (ppa_hook_directpath_register_dev_fn)
{
UINT32 g_if_id;
if (pAd->pDirectpathCb == NULL)
{
/* pAd->pDirectpathCb = (PPA_DIRECTPATH_CB *) kmalloc (sizeof(PPA_DIRECTPATH_CB), GFP_ATOMIC);*/
os_alloc_mem(NULL, (UCHAR **)&(pAd->pDirectpathCb), sizeof(PPA_DIRECTPATH_CB));
DBGPRINT(RT_DEBUG_TRACE, ("Realloc memory for pDirectpathCb ??\n"));
}
/* register callback */
pAd->pDirectpathCb->rx_fn = ifx_ra_start_xmit;
pAd->pDirectpathCb->stop_tx_fn = NULL;
pAd->pDirectpathCb->start_tx_fn = NULL;
status = ppa_hook_directpath_register_dev_fn(&g_if_id, pAd->net_dev, pAd->pDirectpathCb, PPA_F_DIRECTPATH_REGISTER|PPA_F_DIRECTPATH_ETH_IF);
if(status==IFX_SUCCESS)
{
pAd->g_if_id=g_if_id;
DBGPRINT(RT_DEBUG_TRACE, ("register INF_AMAZON_SE_PPA success :ret:%d id:%d:%d\n",status,pAd->g_if_id,g_if_id));
pAd->PPAEnable=TRUE;
}
else
{
DBGPRINT(RT_DEBUG_TRACE, ("register INF_AMAZON_SE_PPA fail :ret:%d\n",status));
}
}
else
{
DBGPRINT(RT_DEBUG_TRACE, ("INF_AMAZON_SE_PPA enable fail : there is no INF_AMAZON_SE_PPA module . \n"));
}
}
}
else if (aggre == 0)
{
if(pAd->PPAEnable==FALSE)
{
DBGPRINT(RT_DEBUG_TRACE, ("INF_AMAZON_SE_PPA already disable \n"));
}
else
{
if (ppa_hook_directpath_register_dev_fn)
{
UINT32 g_if_id;
g_if_id=pAd->g_if_id;
DBGPRINT(RT_DEBUG_TRACE, ("g_if_id=%d \n",pAd->g_if_id));
status=ppa_hook_directpath_register_dev_fn(&g_if_id, pAd->net_dev, NULL, 0/*PPA_F_DIRECTPATH_REGISTER*/);
if(status==1)
{
pAd->g_if_id=0;
DBGPRINT(RT_DEBUG_TRACE, ("unregister INF_AMAZON_SE_PPA success :ret:%d\n",status));
pAd->PPAEnable=FALSE;
}
else
{
DBGPRINT(RT_DEBUG_TRACE, ("unregister INF_AMAZON_SE_PPA fail :ret:%d\n",status));
}
}
else
{
DBGPRINT(RT_DEBUG_TRACE, ("INF_AMAZON_SE_PPA enable fail : there is no INF_AMAZON_SE_PPA module . \n"));
}
}
}
else
{
DBGPRINT(RT_DEBUG_TRACE, ("Invalid argument %d \n",aggre));
return FALSE; /*Invalid argument */
}
return TRUE;
}
#endif /* INF_PPA_SUPPORT */
/*
==========================================================================
Description:
Set IEEE80211H.
This parameter is 1 when needs radar detection, otherwise 0
Return:
TRUE if all parameters are OK, FALSE otherwise
==========================================================================
*/
INT Set_IEEE80211H_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
LONG ieee80211h;
ieee80211h = simple_strtol(arg, 0, 10);
if (ieee80211h == 1)
pAd->CommonCfg.bIEEE80211H = TRUE;
else if (ieee80211h == 0)
pAd->CommonCfg.bIEEE80211H = FALSE;
else
return FALSE; /*Invalid argument */
DBGPRINT(RT_DEBUG_TRACE, ("Set_IEEE80211H_Proc::(IEEE80211H=%d)\n", pAd->CommonCfg.bIEEE80211H));
return TRUE;
}
#ifdef EXT_BUILD_CHANNEL_LIST
/*
==========================================================================
Description:
Set Country Code.
Return:
TRUE if all parameters are OK, FALSE otherwise
==========================================================================
*/
INT Set_ExtCountryCode_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
if (RTMP_DRIVER_IOCTL_SANITY_CHECK(pAd, NULL) == NDIS_STATUS_SUCCESS)
{
DBGPRINT(RT_DEBUG_TRACE, ("%s can only be used when interface is down.\n", __FUNCTION__));
return TRUE;
}
if(strlen(arg) == 2)
{
NdisMoveMemory(pAd->CommonCfg.CountryCode, arg, 2);
pAd->CommonCfg.bCountryFlag = TRUE;
}
else
{
NdisZeroMemory(pAd->CommonCfg.CountryCode, 3);
pAd->CommonCfg.bCountryFlag = FALSE;
}
{
UCHAR CountryCode[3] = {0};
NdisMoveMemory(CountryCode, pAd->CommonCfg.CountryCode, 2);
DBGPRINT(RT_DEBUG_TRACE, ("Set_CountryCode_Proc::(bCountryFlag=%d, CountryCode=%s)\n",
pAd->CommonCfg.bCountryFlag,
CountryCode));
}
return TRUE;
}
/*
==========================================================================
Description:
Set Ext DFS Type
Return:
TRUE if all parameters are OK, FALSE otherwise
==========================================================================
*/
INT Set_ExtDfsType_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
UCHAR *pDfsType = &pAd->CommonCfg.DfsType;
if (RTMP_DRIVER_IOCTL_SANITY_CHECK(pAd, NULL) == NDIS_STATUS_SUCCESS)
{
DBGPRINT(RT_DEBUG_TRACE, ("%s can only be used when interface is down.\n", __FUNCTION__));
return TRUE;
}
if (!strcmp(arg, "CE"))
*pDfsType = CE;
else if (!strcmp(arg, "FCC"))
*pDfsType = FCC;
else if (!strcmp(arg, "JAP"))
*pDfsType = JAP;
else
DBGPRINT(RT_DEBUG_TRACE, ("Unsupported DFS type:%s (Legal types are: CE, FCC, JAP)\n", arg));
return TRUE;
}
/*
==========================================================================
Description:
Add new channel list
Return:
TRUE if all parameters are OK, FALSE otherwise
==========================================================================
*/
INT Set_ChannelListAdd_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
CH_DESP inChDesp;
PCH_REGION pChRegion = NULL;
if (RTMP_DRIVER_IOCTL_SANITY_CHECK(pAd, NULL) == NDIS_STATUS_SUCCESS)
{
DBGPRINT(RT_DEBUG_TRACE, ("%s can only be used when interface is down.\n", __FUNCTION__));
return TRUE;
}
/* Get Channel Region (CountryCode)*/
{
INT loop = 0;
while (strcmp((PSTRING) ChRegion[loop].CountReg, "") != 0)
{
if (strncmp((PSTRING) ChRegion[loop].CountReg, pAd->CommonCfg.CountryCode, 2) == 0)
{
pChRegion = &ChRegion[loop];
break;
}
loop++;
}
if (pChRegion == NULL)
{
DBGPRINT(RT_DEBUG_TRACE, ("CountryCode is not configured or not valid\n"));
return TRUE;
}
}
/* Parsing the arg, IN:arg; OUT:inChRegion */
{
UCHAR strBuff[64], count = 0;
PUCHAR pStart, pEnd, tempIdx, tempBuff[5];
if (strlen(arg) <64)
NdisCopyMemory(strBuff, arg, strlen(arg));
if ((pStart = rtstrchr(strBuff, '[')) != NULL)
{
if ((pEnd = rtstrchr(pStart++, ']')) != NULL)
{
tempBuff[count++] = pStart;
for(tempIdx = pStart ;tempIdx != pEnd; tempIdx++)
{
if(*tempIdx == ',')
{
*tempIdx = '\0';
tempBuff[count++] = ++tempIdx;
}
}
*(pEnd) = '\0';
if (count != 5)
{
DBGPRINT(RT_DEBUG_TRACE, ("Input Error. Too more or too less parameters.\n"));
return TRUE;
}
else
{
inChDesp.FirstChannel = (UCHAR) simple_strtol(tempBuff[0], 0, 10);
inChDesp.NumOfCh = (UCHAR) simple_strtol(tempBuff[1], 0, 10);
inChDesp.MaxTxPwr = (UCHAR) simple_strtol(tempBuff[2], 0, 10);
inChDesp.Geography = (!strcmp(tempBuff[3], "BOTH") ? BOTH: (!strcmp(tempBuff[3], "IDOR") ? IDOR : ODOR));
inChDesp.DfsReq= (!strcmp(tempBuff[4], "TRUE") ? TRUE : FALSE);
}
}
else
{
DBGPRINT(RT_DEBUG_TRACE, ("Missing End \"]\"\n"));
return TRUE;
}
}
else
{
DBGPRINT(RT_DEBUG_TRACE, ("%s: Invalid input format.\n", __FUNCTION__));
return TRUE;
}
}
/* Add entry to Channel List*/
{
UCHAR EntryIdx;
PCH_DESP pChDesp = NULL;
UCHAR CountryCode[3] = {0};
if (pAd->CommonCfg.pChDesp == NULL)
{
os_alloc_mem(pAd, &pAd->CommonCfg.pChDesp, MAX_PRECONFIG_DESP_ENTRY_SIZE*sizeof(CH_DESP));
pChDesp = (PCH_DESP) pAd->CommonCfg.pChDesp;
if (pChDesp)
{
for (EntryIdx= 0; pChRegion->pChDesp[EntryIdx].FirstChannel != 0; EntryIdx++)
{
if (EntryIdx == (MAX_PRECONFIG_DESP_ENTRY_SIZE-2)) /* Keep an NULL entry in the end of table*/
{
DBGPRINT(RT_DEBUG_TRACE, ("Table is full.\n"));
return TRUE;
}
NdisCopyMemory(&pChDesp[EntryIdx], &pChRegion->pChDesp[EntryIdx], sizeof(CH_DESP));
}
/* Copy the NULL entry*/
NdisCopyMemory(&pChDesp[EntryIdx], &pChRegion->pChDesp[EntryIdx], sizeof(CH_DESP));
}
else
{
DBGPRINT(RT_DEBUG_ERROR, ("os_alloc_mem failded.\n"));
return FALSE;
}
}
else
{
pChDesp = (PCH_DESP) pAd->CommonCfg.pChDesp;
for (EntryIdx= 0; pChDesp[EntryIdx].FirstChannel != 0; EntryIdx++)
{
if(EntryIdx == (MAX_PRECONFIG_DESP_ENTRY_SIZE-2)) /* Keep an NULL entry in the end of table*/
{
DBGPRINT(RT_DEBUG_TRACE, ("Table is full.\n"));
return TRUE;
}
}
}
NdisMoveMemory(CountryCode, pAd->CommonCfg.CountryCode, 2);
DBGPRINT(RT_DEBUG_TRACE, ("Add channel lists {%u, %u, %u, %s, %s} to %s.\n",
inChDesp.FirstChannel,
inChDesp.NumOfCh,
inChDesp.MaxTxPwr,
(inChDesp.Geography == BOTH) ? "BOTH" : (inChDesp.Geography == IDOR) ? "IDOR" : "ODOR",
(inChDesp.DfsReq == TRUE) ? "TRUE" : "FALSE",
CountryCode));
NdisCopyMemory(&pChDesp[EntryIdx], &inChDesp, sizeof(CH_DESP));
pChDesp[++EntryIdx].FirstChannel = 0;
}
return TRUE;
}
INT Set_ChannelListShow_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
PCH_REGION pChRegion = NULL;
UCHAR EntryIdx, CountryCode[3]={0};
/* Get Channel Region (CountryCode)*/
{
INT loop = 0;
while (strcmp((PSTRING) ChRegion[loop].CountReg, "") != 0)
{
if (strncmp((PSTRING) ChRegion[loop].CountReg, pAd->CommonCfg.CountryCode, 2) == 0)
{
pChRegion = &ChRegion[loop];
break;
}
loop++;
}
if (pChRegion == NULL)
{
DBGPRINT(RT_DEBUG_TRACE, ("CountryCode is not configured or not valid\n"));
return TRUE;
}
}
NdisMoveMemory(CountryCode, pAd->CommonCfg.CountryCode, 2);
if (pAd->CommonCfg.DfsType == MAX_RD_REGION)
pAd->CommonCfg.DfsType = pChRegion->DfsType;
DBGPRINT(RT_DEBUG_ERROR, ("=========================================\n"));
DBGPRINT(RT_DEBUG_ERROR, ("CountryCode:%s\n", CountryCode));
DBGPRINT(RT_DEBUG_ERROR, ("DfsType:%s\n",
(pAd->CommonCfg.DfsType == JAP) ? "JAP" :
((pAd->CommonCfg.DfsType == FCC) ? "FCC" : "CE" )));
if (pAd->CommonCfg.pChDesp != NULL)
{
PCH_DESP pChDesp = (PCH_DESP) pAd->CommonCfg.pChDesp;
for (EntryIdx = 0; pChDesp[EntryIdx].FirstChannel != 0; EntryIdx++)
{
DBGPRINT(RT_DEBUG_ERROR, ("%u. {%3u, %2u, %2u, %s, %5s}.\n",
EntryIdx,
pChDesp[EntryIdx].FirstChannel,
pChDesp[EntryIdx].NumOfCh,
pChDesp[EntryIdx].MaxTxPwr,
(pChDesp[EntryIdx].Geography == BOTH) ? "BOTH" : (pChDesp[EntryIdx].Geography == IDOR) ? "IDOR" : "ODOR",
(pChDesp[EntryIdx].DfsReq == TRUE) ? "TRUE" : "FALSE"));
}
}
else
{
DBGPRINT(RT_DEBUG_TRACE, ("Default channel list table:\n"));
for (EntryIdx = 0; pChRegion->pChDesp[EntryIdx].FirstChannel != 0; EntryIdx++)
{
DBGPRINT(RT_DEBUG_ERROR, ("%u. {%3u, %2u, %2u, %s, %5s}.\n",
EntryIdx,
pChRegion->pChDesp[EntryIdx].FirstChannel,
pChRegion->pChDesp[EntryIdx].NumOfCh,
pChRegion->pChDesp[EntryIdx].MaxTxPwr,
(pChRegion->pChDesp[EntryIdx].Geography == BOTH) ? "BOTH" : (pChRegion->pChDesp[EntryIdx].Geography == IDOR) ? "IDOR" : "ODOR",
(pChRegion->pChDesp[EntryIdx].DfsReq == TRUE) ? "TRUE" : "FALSE"));
}
}
DBGPRINT(RT_DEBUG_ERROR, ("=========================================\n"));
return TRUE;
}
INT Set_ChannelListDel_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
UCHAR EntryIdx, TargetIdx, NumOfEntry;
PCH_REGION pChRegion = NULL;
PCH_DESP pChDesp = NULL;
TargetIdx = simple_strtol(arg, 0, 10);
if (RTMP_DRIVER_IOCTL_SANITY_CHECK(pAd, NULL) == NDIS_STATUS_SUCCESS)
{
DBGPRINT(RT_DEBUG_TRACE, ("%s can only be used when interface is down.\n", __FUNCTION__));
return TRUE;
}
/* Get Channel Region (CountryCode)*/
{
INT loop = 0;
while (strcmp((PSTRING) ChRegion[loop].CountReg, "") != 0)
{
if (strncmp((PSTRING) ChRegion[loop].CountReg, pAd->CommonCfg.CountryCode, 2) == 0)
{
pChRegion = &ChRegion[loop];
break;
}
loop++;
}
if (pChRegion == NULL)
{
DBGPRINT(RT_DEBUG_TRACE, ("CountryCode is not configured or not valid\n"));
return TRUE;
}
}
if (pAd->CommonCfg.pChDesp == NULL)
{
os_alloc_mem(pAd, &pAd->CommonCfg.pChDesp, MAX_PRECONFIG_DESP_ENTRY_SIZE*sizeof(CH_DESP));
if (pAd->CommonCfg.pChDesp)
{
pChDesp = (PCH_DESP) pAd->CommonCfg.pChDesp;
for (EntryIdx= 0; pChRegion->pChDesp[EntryIdx].FirstChannel != 0; EntryIdx++)
{
if (EntryIdx == (MAX_PRECONFIG_DESP_ENTRY_SIZE-2)) /* Keep an NULL entry in the end of table*/
{
DBGPRINT(RT_DEBUG_TRACE, ("Table is full.\n"));
return TRUE;
}
NdisCopyMemory(&pChDesp[EntryIdx], &pChRegion->pChDesp[EntryIdx], sizeof(CH_DESP));
}
/* Copy the NULL entry*/
NdisCopyMemory(&pChDesp[EntryIdx], &pChRegion->pChDesp[EntryIdx], sizeof(CH_DESP));
}
else
{
DBGPRINT(RT_DEBUG_ERROR, ("os_alloc_mem failded.\n"));
return FALSE;
}
}
else
pChDesp = (PCH_DESP) pAd->CommonCfg.pChDesp;
if (!strcmp(arg, "default"))
{
DBGPRINT(RT_DEBUG_TRACE, ("Default table used.\n" ));
if (pAd->CommonCfg.pChDesp != NULL)
os_free_mem(NULL, pAd->CommonCfg.pChDesp);
pAd->CommonCfg.pChDesp = NULL;
pAd->CommonCfg.DfsType = MAX_RD_REGION;
}
else if (!strcmp(arg, "all"))
{
DBGPRINT(RT_DEBUG_TRACE, ("Remove all entries.\n" ));
for (EntryIdx = 0; EntryIdx < MAX_PRECONFIG_DESP_ENTRY_SIZE; EntryIdx++)
NdisZeroMemory(&pChDesp[EntryIdx], sizeof(CH_DESP));
}
else if (TargetIdx < (MAX_PRECONFIG_DESP_ENTRY_SIZE-1))
{
for (EntryIdx= 0; pChDesp[EntryIdx].FirstChannel != 0; EntryIdx++)
{
if(EntryIdx == (MAX_PRECONFIG_DESP_ENTRY_SIZE-2)) /* Keep an NULL entry in the end of table */
{
DBGPRINT(RT_DEBUG_TRACE, ("Last entry should be NULL.\n"));
pChDesp[EntryIdx].FirstChannel = 0;
return TRUE;
}
}
NumOfEntry = EntryIdx;
if (TargetIdx >= NumOfEntry)
{
DBGPRINT(RT_DEBUG_TRACE, ("Out of table range.\n"));
return TRUE;
}
for (EntryIdx = TargetIdx; EntryIdx < NumOfEntry; EntryIdx++)
NdisCopyMemory(&pChDesp[EntryIdx], &pChDesp[EntryIdx+1], sizeof(CH_DESP));
NdisZeroMemory(&pChDesp[EntryIdx], sizeof(CH_DESP)); /*NULL entry*/
DBGPRINT(RT_DEBUG_TRACE, ("Entry %u deleted.\n", TargetIdx));
}
else
DBGPRINT(RT_DEBUG_TRACE, ("Entry not found.\n"));
return TRUE;
}
#endif /* EXT_BUILD_CHANNEL_LIST */
#ifdef WSC_INCLUDED
INT Set_WscGenPinCode_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
PWSC_CTRL pWscControl = NULL;
POS_COOKIE pObj = (POS_COOKIE) pAd->OS_Cookie;
UCHAR apidx = pObj->ioctl_if;
#ifdef CONFIG_AP_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
{
#ifdef APCLI_SUPPORT
if (pObj->ioctl_if_type == INT_APCLI)
{
pWscControl = &pAd->ApCfg.ApCliTab[apidx].WscControl;
DBGPRINT(RT_DEBUG_TRACE, ("IF(apcli%d) Set_WscGenPinCode_Proc:: This command is from apcli interface now.\n", apidx));
}
else
#endif /* APCLI_SUPPORT */
{
pWscControl = &pAd->ApCfg.MBSSID[apidx].WscControl;
DBGPRINT(RT_DEBUG_TRACE, ("IF(ra%d) Set_WscGenPinCode_Proc:: This command is from ra interface now.\n", apidx));
}
}
#endif /* CONFIG_AP_SUPPORT */
#ifdef P2P_SUPPORT
if (pObj->ioctl_if_type == INT_P2P)
{
pWscControl = &pAd->ApCfg.ApCliTab[apidx].WscControl;
DBGPRINT(RT_DEBUG_TRACE, ("IF(p2p%d) Set_WscGenPinCode_Proc:: This command is from apcli interface now.\n", apidx));
}
#endif /* P2P_SUPPORT */
#ifdef CONFIG_STA_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_STA(pAd)
{
#ifdef P2P_SUPPORT
if (pObj->ioctl_if_type != INT_P2P)
#endif /* P2P_SUPPORT */
{
pWscControl = &pAd->StaCfg.WscControl;
}
}
#endif /* CONFIG_STA_SUPPORT */
if (pWscControl == NULL)
{
DBGPRINT(RT_DEBUG_ERROR, ("%s: pWscControl == NULL!\n", __FUNCTION__));
return TRUE;
}
if (pWscControl->WscEnrollee4digitPinCode)
{
pWscControl->WscEnrolleePinCodeLen = 4;
pWscControl->WscEnrolleePinCode = WscRandomGen4digitPinCode(pAd);
}
else
{
pWscControl->WscEnrolleePinCodeLen = 8;
pWscControl->WscEnrolleePinCode = WscRandomGeneratePinCode(pAd, apidx);
}
#ifdef P2P_SUPPORT
if (pObj->ioctl_if_type == INT_P2P)
{
PWSC_CTRL pApWscControl = &pAd->ApCfg.MBSSID[apidx].WscControl;
pApWscControl->WscEnrolleePinCodeLen = pWscControl->WscEnrolleePinCodeLen;
pApWscControl->WscEnrolleePinCode = pWscControl->WscEnrolleePinCode;
}
#endif /* P2P_SUPPORT */
DBGPRINT(RT_DEBUG_TRACE, ("Set_WscGenPinCode_Proc:: Enrollee PinCode\t\t%08u\n", pWscControl->WscEnrolleePinCode));
return TRUE;
}
INT Set_WscVendorPinCode_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
PWSC_CTRL pWscControl = NULL;
POS_COOKIE pObj = (POS_COOKIE) pAd->OS_Cookie;
UCHAR apidx = pObj->ioctl_if;
#ifdef CONFIG_AP_SUPPORT
/* POS_COOKIE pObj = (POS_COOKIE) pAd->OS_Cookie;*/
/* UCHAR apidx = pObj->ioctl_if;*/
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
{
#ifdef APCLI_SUPPORT
if (pObj->ioctl_if_type == INT_APCLI)
{
pWscControl = &pAd->ApCfg.ApCliTab[apidx].WscControl;
DBGPRINT(RT_DEBUG_TRACE, ("Set_WscVendorPinCode_Proc() for apcli(%d)\n", apidx));
}
else
#endif /* APCLI_SUPPORT */
{
pWscControl = &pAd->ApCfg.MBSSID[apidx].WscControl;
DBGPRINT(RT_DEBUG_TRACE, ("Set_WscVendorPinCode_Proc() for ra%d!\n", apidx));
}
}
#endif /* CONFIG_AP_SUPPORT */
#ifdef P2P_SUPPORT
if (pObj->ioctl_if_type == INT_P2P)
{
pWscControl = &pAd->ApCfg.MBSSID[apidx].WscControl;
RT_CfgSetWscPinCode(pAd, arg, pWscControl);
pWscControl = &pAd->ApCfg.ApCliTab[apidx].WscControl;
RT_CfgSetWscPinCode(pAd, arg, pWscControl);
DBGPRINT(RT_DEBUG_TRACE, ("Set_WscVendorPinCode_Proc() for p2p(%d)\n", apidx));
return TRUE;
}
#endif /* P2P_SUPPORT */
#ifdef CONFIG_STA_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_STA(pAd)
{
#ifdef P2P_SUPPORT
if (pObj->ioctl_if_type != INT_P2P)
#endif /* P2P_SUPPORT */
pWscControl = &pAd->StaCfg.WscControl;
}
#endif /* CONFIG_STA_SUPPORT */
if (!pWscControl)
return FALSE;
else
return RT_CfgSetWscPinCode(pAd, arg, pWscControl);
}
#endif /* WSC_INCLUDED */
#ifdef DBG
/*
==========================================================================
Description:
For Debug information
Return:
TRUE if all parameters are OK, FALSE otherwise
==========================================================================
*/
INT Set_Debug_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
DBGPRINT(RT_DEBUG_TRACE, ("==>%s()\n", __FUNCTION__));
if(simple_strtol(arg, 0, 10) <= RT_DEBUG_LOUD)
RTDebugLevel = simple_strtol(arg, 0, 10);
DBGPRINT(RT_DEBUG_TRACE, ("<==%s(RTDebugLevel = %ld)\n",
__FUNCTION__, RTDebugLevel));
return TRUE;
}
/*
==========================================================================
Description:
For DebugFunc information
Return:
TRUE if all parameters are OK, FALSE otherwise
==========================================================================
*/
INT Set_DebugFunc_Proc(
IN RTMP_ADAPTER *pAd,
IN PSTRING arg)
{
DBGPRINT_S(RT_DEBUG_TRACE, ("==>%s()\n", __FUNCTION__));
RTDebugFunc = simple_strtol(arg, 0, 10);
DBGPRINT_S(RT_DEBUG_TRACE, ("Set RTDebugFunc = 0x%x\n",__FUNCTION__, RTDebugFunc));
return TRUE;
}
#endif
INT Show_DescInfo_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
return TRUE;
}
/*
==========================================================================
Description:
Reset statistics counter
Arguments:
pAd Pointer to our adapter
arg
Return:
TRUE if all parameters are OK, FALSE otherwise
==========================================================================
*/
INT Set_ResetStatCounter_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
/*UCHAR i;*/
/*MAC_TABLE_ENTRY *pEntry;*/
DBGPRINT(RT_DEBUG_TRACE, ("==>Set_ResetStatCounter_Proc\n"));
/* add the most up-to-date h/w raw counters into software counters*/
NICUpdateRawCounters(pAd);
NdisZeroMemory(&pAd->WlanCounters, sizeof(COUNTER_802_11));
NdisZeroMemory(&pAd->Counters8023, sizeof(COUNTER_802_3));
NdisZeroMemory(&pAd->RalinkCounters, sizeof(COUNTER_RALINK));
#ifdef CONFIG_AP_SUPPORT
#endif /* CONFIG_AP_SUPPORT */
#ifdef TXBF_SUPPORT
if (pAd->chipCap.FlgHwTxBfCap)
{
int i;
for (i=0; i<MAX_LEN_OF_MAC_TABLE; i++)
NdisZeroMemory(&pAd->MacTab.Content[i].TxBFCounters, sizeof(pAd->MacTab.Content[i].TxBFCounters));
}
#endif /* TXBF_SUPPORT */
return TRUE;
}
BOOLEAN RTMPCheckStrPrintAble(
IN CHAR *pInPutStr,
IN UCHAR strLen)
{
UCHAR i=0;
for (i=0; i<strLen; i++)
{
if ((pInPutStr[i] < 0x20) ||
(pInPutStr[i] > 0x7E))
return FALSE;
}
return TRUE;
}
/*
========================================================================
Routine Description:
Remove WPA Key process
Arguments:
pAd Pointer to our adapter
pBuf Pointer to the where the key stored
Return Value:
NDIS_SUCCESS Add key successfully
IRQL = DISPATCH_LEVEL
Note:
========================================================================
*/
#ifdef CONFIG_STA_SUPPORT
VOID RTMPSetDesiredRates(
IN PRTMP_ADAPTER pAdapter,
IN LONG Rates)
{
NDIS_802_11_RATES aryRates;
memset(&aryRates, 0x00, sizeof(NDIS_802_11_RATES));
switch (pAdapter->CommonCfg.PhyMode)
{
case (WMODE_A): /* A only*/
switch (Rates)
{
case 6000000: /*6M*/
aryRates[0] = 0x0c; /* 6M*/
pAdapter->StaCfg.DesiredTransmitSetting.field.MCS = MCS_0;
break;
case 9000000: /*9M*/
aryRates[0] = 0x12; /* 9M*/
pAdapter->StaCfg.DesiredTransmitSetting.field.MCS = MCS_1;
break;
case 12000000: /*12M*/
aryRates[0] = 0x18; /* 12M*/
pAdapter->StaCfg.DesiredTransmitSetting.field.MCS = MCS_2;
break;
case 18000000: /*18M*/
aryRates[0] = 0x24; /* 18M*/
pAdapter->StaCfg.DesiredTransmitSetting.field.MCS = MCS_3;
break;
case 24000000: /*24M*/
aryRates[0] = 0x30; /* 24M*/
pAdapter->StaCfg.DesiredTransmitSetting.field.MCS = MCS_4;
break;
case 36000000: /*36M*/
aryRates[0] = 0x48; /* 36M*/
pAdapter->StaCfg.DesiredTransmitSetting.field.MCS = MCS_5;
break;
case 48000000: /*48M*/
aryRates[0] = 0x60; /* 48M*/
pAdapter->StaCfg.DesiredTransmitSetting.field.MCS = MCS_6;
break;
case 54000000: /*54M*/
aryRates[0] = 0x6c; /* 54M*/
pAdapter->StaCfg.DesiredTransmitSetting.field.MCS = MCS_7;
break;
case -1: /*Auto*/
default:
aryRates[0] = 0x6c; /* 54Mbps*/
aryRates[1] = 0x60; /* 48Mbps*/
aryRates[2] = 0x48; /* 36Mbps*/
aryRates[3] = 0x30; /* 24Mbps*/
aryRates[4] = 0x24; /* 18M*/
aryRates[5] = 0x18; /* 12M*/
aryRates[6] = 0x12; /* 9M*/
aryRates[7] = 0x0c; /* 6M*/
pAdapter->StaCfg.DesiredTransmitSetting.field.MCS = MCS_AUTO;
break;
}
break;
case (WMODE_B | WMODE_G): /* B/G Mixed*/
case (WMODE_B): /* B only*/
case (WMODE_A | WMODE_B | WMODE_G): /* A/B/G Mixed*/
default:
switch (Rates)
{
case 1000000: /*1M*/
aryRates[0] = 0x02;
pAdapter->StaCfg.DesiredTransmitSetting.field.MCS = MCS_0;
break;
case 2000000: /*2M*/
aryRates[0] = 0x04;
pAdapter->StaCfg.DesiredTransmitSetting.field.MCS = MCS_1;
break;
case 5000000: /*5.5M*/
aryRates[0] = 0x0b; /* 5.5M*/
pAdapter->StaCfg.DesiredTransmitSetting.field.MCS = MCS_2;
break;
case 11000000: /*11M*/
aryRates[0] = 0x16; /* 11M*/
pAdapter->StaCfg.DesiredTransmitSetting.field.MCS = MCS_3;
break;
case 6000000: /*6M*/
aryRates[0] = 0x0c; /* 6M*/
pAdapter->StaCfg.DesiredTransmitSetting.field.MCS = MCS_0;
break;
case 9000000: /*9M*/
aryRates[0] = 0x12; /* 9M*/
pAdapter->StaCfg.DesiredTransmitSetting.field.MCS = MCS_1;
break;
case 12000000: /*12M*/
aryRates[0] = 0x18; /* 12M*/
pAdapter->StaCfg.DesiredTransmitSetting.field.MCS = MCS_2;
break;
case 18000000: /*18M*/
aryRates[0] = 0x24; /* 18M*/
pAdapter->StaCfg.DesiredTransmitSetting.field.MCS = MCS_3;
break;
case 24000000: /*24M*/
aryRates[0] = 0x30; /* 24M*/
pAdapter->StaCfg.DesiredTransmitSetting.field.MCS = MCS_4;
break;
case 36000000: /*36M*/
aryRates[0] = 0x48; /* 36M*/
pAdapter->StaCfg.DesiredTransmitSetting.field.MCS = MCS_5;
break;
case 48000000: /*48M*/
aryRates[0] = 0x60; /* 48M*/
pAdapter->StaCfg.DesiredTransmitSetting.field.MCS = MCS_6;
break;
case 54000000: /*54M*/
aryRates[0] = 0x6c; /* 54M*/
pAdapter->StaCfg.DesiredTransmitSetting.field.MCS = MCS_7;
break;
case -1: /*Auto*/
default:
if (pAdapter->CommonCfg.PhyMode == WMODE_B)
{ /*B Only*/
aryRates[0] = 0x16; /* 11Mbps*/
aryRates[1] = 0x0b; /* 5.5Mbps*/
aryRates[2] = 0x04; /* 2Mbps*/
aryRates[3] = 0x02; /* 1Mbps*/
}
else
{ /*(B/G) Mixed or (A/B/G) Mixed*/
aryRates[0] = 0x6c; /* 54Mbps*/
aryRates[1] = 0x60; /* 48Mbps*/
aryRates[2] = 0x48; /* 36Mbps*/
aryRates[3] = 0x30; /* 24Mbps*/
aryRates[4] = 0x16; /* 11Mbps*/
aryRates[5] = 0x0b; /* 5.5Mbps*/
aryRates[6] = 0x04; /* 2Mbps*/
aryRates[7] = 0x02; /* 1Mbps*/
}
pAdapter->StaCfg.DesiredTransmitSetting.field.MCS = MCS_AUTO;
break;
}
break;
}
NdisZeroMemory(pAdapter->CommonCfg.DesireRate, MAX_LEN_OF_SUPPORTED_RATES);
NdisMoveMemory(pAdapter->CommonCfg.DesireRate, &aryRates, sizeof(NDIS_802_11_RATES));
DBGPRINT(RT_DEBUG_TRACE, (" RTMPSetDesiredRates (%02x,%02x,%02x,%02x,%02x,%02x,%02x,%02x)\n",
pAdapter->CommonCfg.DesireRate[0],pAdapter->CommonCfg.DesireRate[1],
pAdapter->CommonCfg.DesireRate[2],pAdapter->CommonCfg.DesireRate[3],
pAdapter->CommonCfg.DesireRate[4],pAdapter->CommonCfg.DesireRate[5],
pAdapter->CommonCfg.DesireRate[6],pAdapter->CommonCfg.DesireRate[7] ));
/* Changing DesiredRate may affect the MAX TX rate we used to TX frames out*/
MlmeUpdateTxRates(pAdapter, FALSE, 0);
}
#endif /* CONFIG_STA_SUPPORT */
#if defined(CONFIG_STA_SUPPORT) || defined(APCLI_WPA_SUPPLICANT_SUPPORT)
NDIS_STATUS RTMPWPARemoveKeyProc(
IN PRTMP_ADAPTER pAd,
IN PVOID pBuf)
{
PNDIS_802_11_REMOVE_KEY pKey;
ULONG KeyIdx;
NDIS_STATUS Status = NDIS_STATUS_FAILURE;
BOOLEAN bTxKey; /* Set the key as transmit key*/
BOOLEAN bPairwise; /* Indicate the key is pairwise key*/
BOOLEAN bKeyRSC; /* indicate the receive SC set by KeyRSC value.*/
/* Otherwise, it will set by the NIC.*/
BOOLEAN bAuthenticator; /* indicate key is set by authenticator.*/
INT i;
#ifdef APCLI_SUPPORT
#ifdef APCLI_WPA_SUPPLICANT_SUPPORT
UCHAR ifIndex;
BOOLEAN apcliEn=FALSE;
INT idx, BssIdx;
POS_COOKIE pObj = (POS_COOKIE) pAd->OS_Cookie;
#endif/*APCLI_WPA_SUPPLICANT_SUPPORT*/
#endif/*APCLI_SUPPORT*/
DBGPRINT(RT_DEBUG_TRACE,("---> RTMPWPARemoveKeyProc\n"));
pKey = (PNDIS_802_11_REMOVE_KEY) pBuf;
KeyIdx = pKey->KeyIndex & 0xff;
/* Bit 31 of Add-key, Tx Key*/
bTxKey = (pKey->KeyIndex & 0x80000000) ? TRUE : FALSE;
/* Bit 30 of Add-key PairwiseKey*/
bPairwise = (pKey->KeyIndex & 0x40000000) ? TRUE : FALSE;
/* Bit 29 of Add-key KeyRSC*/
bKeyRSC = (pKey->KeyIndex & 0x20000000) ? TRUE : FALSE;
/* Bit 28 of Add-key Authenticator*/
bAuthenticator = (pKey->KeyIndex & 0x10000000) ? TRUE : FALSE;
/* 1. If bTx is TRUE, return failure information*/
if (bTxKey == TRUE)
return(NDIS_STATUS_INVALID_DATA);
/* 2. Check Pairwise Key*/
if (bPairwise)
{
/* a. If BSSID is broadcast, remove all pairwise keys.*/
/* b. If not broadcast, remove the pairwise specified by BSSID*/
for (i = 0; i < SHARE_KEY_NUM; i++)
{
#ifdef APCLI_SUPPORT
#ifdef APCLI_WPA_SUPPLICANT_SUPPORT
if (pObj->ioctl_if_type == INT_APCLI)
{
/*if (MAC_ADDR_EQUAL(pAd->ApCfg.ApCliTab[ifIndex].SharedKey[i].BssId, pKey->BSSID)) */
{
ifIndex = pObj->ioctl_if;
BssIdx = pAd->ApCfg.BssidNum + MAX_MESH_NUM + ifIndex;
DBGPRINT(RT_DEBUG_TRACE,("APCLI RTMPWPARemoveKeyProc(KeyIdx=%d)\n", i));
pAd->ApCfg.ApCliTab[ifIndex].SharedKey[i].KeyLen = 0;
pAd->ApCfg.ApCliTab[ifIndex].SharedKey[i].CipherAlg = CIPHER_NONE;
AsicRemoveSharedKeyEntry(pAd, BssIdx, (UCHAR)i);
Status = NDIS_STATUS_SUCCESS;
break;
}
}
else
#endif/*APCLI_WPA_SUPPLICANT_SUPPORT*/
#endif/*APCLI_SUPPORT*/
{
#ifdef CONFIG_STA_SUPPORT
if (MAC_ADDR_EQUAL(pAd->SharedKey[BSS0][i].BssId, pKey->BSSID))
{
DBGPRINT(RT_DEBUG_TRACE,("RTMPWPARemoveKeyProc(KeyIdx=%d)\n", i));
pAd->SharedKey[BSS0][i].KeyLen = 0;
pAd->SharedKey[BSS0][i].CipherAlg = CIPHER_NONE;
AsicRemoveSharedKeyEntry(pAd, BSS0, (UCHAR)i);
Status = NDIS_STATUS_SUCCESS;
break;
}
#endif/*CONFIG_STA_SUPPORT*/
}
}
}
/* 3. Group Key*/
else
{
/* a. If BSSID is broadcast, remove all group keys indexed*/
/* b. If BSSID matched, delete the group key indexed.*/
DBGPRINT(RT_DEBUG_TRACE,("RTMPWPARemoveKeyProc(KeyIdx=%ld)\n", KeyIdx));
pAd->SharedKey[BSS0][KeyIdx].KeyLen = 0;
pAd->SharedKey[BSS0][KeyIdx].CipherAlg = CIPHER_NONE;
AsicRemoveSharedKeyEntry(pAd, BSS0, (UCHAR)KeyIdx);
Status = NDIS_STATUS_SUCCESS;
}
return (Status);
}
#endif /* defined(CONFIG_STA_SUPPORT) || defined(APCLI_WPA_SUPPLICANT_SUPPORT) */
#ifdef CONFIG_STA_SUPPORT
/*
========================================================================
Routine Description:
Remove All WPA Keys
Arguments:
pAd Pointer to our adapter
Return Value:
None
IRQL = DISPATCH_LEVEL
Note:
========================================================================
*/
VOID RTMPWPARemoveAllKeys(
IN PRTMP_ADAPTER pAd)
{
UCHAR i;
DBGPRINT(RT_DEBUG_TRACE,("RTMPWPARemoveAllKeys(AuthMode=%d, WepStatus=%d)\n", pAd->StaCfg.AuthMode, pAd->StaCfg.WepStatus));
/*
For WEP/CKIP, there is no need to remove it, since WinXP won't set it
again after Link up. And it will be replaced if user changed it.
*/
if (pAd->StaCfg.AuthMode < Ndis802_11AuthModeWPA)
return;
/* For WPA-None, there is no need to remove it, since WinXP won't set it again after*/
/* Link up. And it will be replaced if user changed it.*/
if (pAd->StaCfg.AuthMode == Ndis802_11AuthModeWPANone)
return;
#ifdef PCIE_PS_SUPPORT
RTMP_CLEAR_PSFLAG(pAd, fRTMP_PS_CAN_GO_SLEEP);
#endif /* PCIE_PS_SUPPORT */
/* set BSSID wcid entry of the Pair-wise Key table as no-security mode*/
AsicRemovePairwiseKeyEntry(pAd, BSSID_WCID);
/* set all shared key mode as no-security. */
for (i = 0; i < SHARE_KEY_NUM; i++)
{
DBGPRINT(RT_DEBUG_TRACE,("remove %s key #%d\n", CipherName[pAd->SharedKey[BSS0][i].CipherAlg], i));
NdisZeroMemory(&pAd->SharedKey[BSS0][i], sizeof(CIPHER_KEY));
AsicRemoveSharedKeyEntry(pAd, BSS0, i);
}
#ifdef PCIE_PS_SUPPORT
RTMP_SET_PSFLAG(pAd, fRTMP_PS_CAN_GO_SLEEP);
#endif /* PCIE_PS_SUPPORT */
}
#endif /* CONFIG_STA_SUPPORT */
/*
========================================================================
Routine Description:
Change NIC PHY mode. Re-association may be necessary
Arguments:
pAd - Pointer to our adapter
phymode -
IRQL = PASSIVE_LEVEL
IRQL = DISPATCH_LEVEL
========================================================================
*/
VOID RTMPSetPhyMode(
IN RTMP_ADAPTER *pAd,
IN ULONG phymode)
{
INT i;
/* the selected phymode must be supported by the RF IC encoded in E2PROM*/
pAd->CommonCfg.PhyMode = (UCHAR)phymode;
DBGPRINT(RT_DEBUG_TRACE,("RTMPSetPhyMode : PhyMode=%d, channel=%d \n", pAd->CommonCfg.PhyMode, pAd->CommonCfg.Channel));
#ifdef EXT_BUILD_CHANNEL_LIST
BuildChannelListEx(pAd);
#else
BuildChannelList(pAd);
#endif /* EXT_BUILD_CHANNEL_LIST */
/* sanity check user setting*/
for (i = 0; i < pAd->ChannelListNum; i++)
{
if (pAd->CommonCfg.Channel == pAd->ChannelList[i].Channel)
break;
}
if (i == pAd->ChannelListNum)
{
#ifdef CONFIG_AP_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
if (pAd->CommonCfg.Channel != 0)
pAd->CommonCfg.Channel = FirstChannel(pAd);
#endif /* CONFIG_AP_SUPPORT */
#ifdef CONFIG_STA_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_STA(pAd)
pAd->CommonCfg.Channel = FirstChannel(pAd);
#endif /* CONFIG_STA_SUPPORT */
DBGPRINT(RT_DEBUG_ERROR, ("RTMPSetPhyMode: channel is out of range, use first channel=%d \n", pAd->CommonCfg.Channel));
}
NdisZeroMemory(pAd->CommonCfg.SupRate, MAX_LEN_OF_SUPPORTED_RATES);
NdisZeroMemory(pAd->CommonCfg.ExtRate, MAX_LEN_OF_SUPPORTED_RATES);
NdisZeroMemory(pAd->CommonCfg.DesireRate, MAX_LEN_OF_SUPPORTED_RATES);
switch (phymode) {
case (WMODE_B):
pAd->CommonCfg.SupRate[0] = 0x82; /* 1 mbps, in units of 0.5 Mbps, basic rate*/
pAd->CommonCfg.SupRate[1] = 0x84; /* 2 mbps, in units of 0.5 Mbps, basic rate*/
pAd->CommonCfg.SupRate[2] = 0x8B; /* 5.5 mbps, in units of 0.5 Mbps, basic rate*/
pAd->CommonCfg.SupRate[3] = 0x96; /* 11 mbps, in units of 0.5 Mbps, basic rate*/
pAd->CommonCfg.SupRateLen = 4;
pAd->CommonCfg.ExtRateLen = 0;
pAd->CommonCfg.DesireRate[0] = 2; /* 1 mbps, in units of 0.5 Mbps*/
pAd->CommonCfg.DesireRate[1] = 4; /* 2 mbps, in units of 0.5 Mbps*/
pAd->CommonCfg.DesireRate[2] = 11; /* 5.5 mbps, in units of 0.5 Mbps*/
pAd->CommonCfg.DesireRate[3] = 22; /* 11 mbps, in units of 0.5 Mbps*/
/*pAd->CommonCfg.HTPhyMode.field.MODE = MODE_CCK; This MODE is only FYI. not use*/
break;
/*
In current design, we will put supported/extended rate element in
beacon even we are 11n-only mode.
Or some 11n stations will not connect to us if we do not put
supported/extended rate element in beacon.
*/
case (WMODE_G):
case (WMODE_B | WMODE_G):
case (WMODE_A | WMODE_B | WMODE_G):
#ifdef DOT11_N_SUPPORT
case (WMODE_GN):
case (WMODE_A | WMODE_B | WMODE_G | WMODE_GN | WMODE_AN):
case (WMODE_B | WMODE_G | WMODE_GN):
case (WMODE_G | WMODE_GN):
#endif /* DOT11_N_SUPPORT */
pAd->CommonCfg.SupRate[0] = 0x82; /* 1 mbps, in units of 0.5 Mbps, basic rate*/
pAd->CommonCfg.SupRate[1] = 0x84; /* 2 mbps, in units of 0.5 Mbps, basic rate*/
pAd->CommonCfg.SupRate[2] = 0x8B; /* 5.5 mbps, in units of 0.5 Mbps, basic rate*/
pAd->CommonCfg.SupRate[3] = 0x96; /* 11 mbps, in units of 0.5 Mbps, basic rate*/
pAd->CommonCfg.SupRate[4] = 0x12; /* 9 mbps, in units of 0.5 Mbps*/
pAd->CommonCfg.SupRate[5] = 0x24; /* 18 mbps, in units of 0.5 Mbps*/
pAd->CommonCfg.SupRate[6] = 0x48; /* 36 mbps, in units of 0.5 Mbps*/
pAd->CommonCfg.SupRate[7] = 0x6c; /* 54 mbps, in units of 0.5 Mbps*/
pAd->CommonCfg.SupRateLen = 8;
pAd->CommonCfg.ExtRate[0] = 0x0C; /* 6 mbps, in units of 0.5 Mbps*/
pAd->CommonCfg.ExtRate[1] = 0x18; /* 12 mbps, in units of 0.5 Mbps*/
pAd->CommonCfg.ExtRate[2] = 0x30; /* 24 mbps, in units of 0.5 Mbps*/
pAd->CommonCfg.ExtRate[3] = 0x60; /* 48 mbps, in units of 0.5 Mbps*/
pAd->CommonCfg.ExtRateLen = 4;
pAd->CommonCfg.DesireRate[0] = 2; /* 1 mbps, in units of 0.5 Mbps*/
pAd->CommonCfg.DesireRate[1] = 4; /* 2 mbps, in units of 0.5 Mbps*/
pAd->CommonCfg.DesireRate[2] = 11; /* 5.5 mbps, in units of 0.5 Mbps*/
pAd->CommonCfg.DesireRate[3] = 22; /* 11 mbps, in units of 0.5 Mbps*/
pAd->CommonCfg.DesireRate[4] = 12; /* 6 mbps, in units of 0.5 Mbps*/
pAd->CommonCfg.DesireRate[5] = 18; /* 9 mbps, in units of 0.5 Mbps*/
pAd->CommonCfg.DesireRate[6] = 24; /* 12 mbps, in units of 0.5 Mbps*/
pAd->CommonCfg.DesireRate[7] = 36; /* 18 mbps, in units of 0.5 Mbps*/
pAd->CommonCfg.DesireRate[8] = 48; /* 24 mbps, in units of 0.5 Mbps*/
pAd->CommonCfg.DesireRate[9] = 72; /* 36 mbps, in units of 0.5 Mbps*/
pAd->CommonCfg.DesireRate[10] = 96; /* 48 mbps, in units of 0.5 Mbps*/
pAd->CommonCfg.DesireRate[11] = 108; /* 54 mbps, in units of 0.5 Mbps*/
break;
case (WMODE_A):
#ifdef DOT11_N_SUPPORT
case (WMODE_A | WMODE_AN):
case (WMODE_A | WMODE_G | WMODE_GN | WMODE_AN):
case (WMODE_AN):
#endif /* DOT11_N_SUPPORT */
#ifdef DOT11_VHT_AC
case (WMODE_A | WMODE_AN | WMODE_AC):
case (WMODE_AN | WMODE_AC):
#endif /* DOT11_VHT_AC */
pAd->CommonCfg.SupRate[0] = 0x8C; /* 6 mbps, in units of 0.5 Mbps, basic rate*/
pAd->CommonCfg.SupRate[1] = 0x12; /* 9 mbps, in units of 0.5 Mbps*/
pAd->CommonCfg.SupRate[2] = 0x98; /* 12 mbps, in units of 0.5 Mbps, basic rate*/
pAd->CommonCfg.SupRate[3] = 0x24; /* 18 mbps, in units of 0.5 Mbps*/
pAd->CommonCfg.SupRate[4] = 0xb0; /* 24 mbps, in units of 0.5 Mbps, basic rate*/
pAd->CommonCfg.SupRate[5] = 0x48; /* 36 mbps, in units of 0.5 Mbps*/
pAd->CommonCfg.SupRate[6] = 0x60; /* 48 mbps, in units of 0.5 Mbps*/
pAd->CommonCfg.SupRate[7] = 0x6c; /* 54 mbps, in units of 0.5 Mbps*/
pAd->CommonCfg.SupRateLen = 8;
pAd->CommonCfg.ExtRateLen = 0;
pAd->CommonCfg.DesireRate[0] = 12; /* 6 mbps, in units of 0.5 Mbps*/
pAd->CommonCfg.DesireRate[1] = 18; /* 9 mbps, in units of 0.5 Mbps*/
pAd->CommonCfg.DesireRate[2] = 24; /* 12 mbps, in units of 0.5 Mbps*/
pAd->CommonCfg.DesireRate[3] = 36; /* 18 mbps, in units of 0.5 Mbps*/
pAd->CommonCfg.DesireRate[4] = 48; /* 24 mbps, in units of 0.5 Mbps*/
pAd->CommonCfg.DesireRate[5] = 72; /* 36 mbps, in units of 0.5 Mbps*/
pAd->CommonCfg.DesireRate[6] = 96; /* 48 mbps, in units of 0.5 Mbps*/
pAd->CommonCfg.DesireRate[7] = 108; /* 54 mbps, in units of 0.5 Mbps*/
/*pAd->CommonCfg.HTPhyMode.field.MODE = MODE_OFDM; This MODE is only FYI. not use*/
break;
default:
break;
}
#ifdef CONFIG_AP_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
{
UINT apidx;
for (apidx = 0; apidx < pAd->ApCfg.BssidNum; apidx++)
{
MlmeUpdateTxRates(pAd, FALSE, apidx);
}
#ifdef APCLI_SUPPORT
for (apidx = 0; apidx < MAX_APCLI_NUM; apidx++)
{
MlmeUpdateTxRates(pAd, FALSE, apidx + MIN_NET_DEVICE_FOR_APCLI);
}
#endif /* APCLI_SUPPORT */
}
#endif /* CONFIG_AP_SUPPORT */
#ifdef P2P_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_STA(pAd)
{
UINT apidx;
for (apidx = 0; apidx < pAd->ApCfg.BssidNum; apidx++)
{
MlmeUpdateTxRates(pAd, FALSE, apidx + MIN_NET_DEVICE_FOR_P2P_GO);
}
for (apidx = 0; apidx < MAX_APCLI_NUM; apidx++)
{
MlmeUpdateTxRates(pAd, FALSE, apidx + MIN_NET_DEVICE_FOR_APCLI);
}
}
#endif /* P2P_SUPPORT */
#ifdef DOT11_N_SUPPORT
SetCommonHT(pAd);
#endif /* DOT11_N_SUPPORT */
#ifdef DOT11_VHT_AC
SetCommonVHT(pAd);
#endif /* DOT11_VHT_AC */
}
/*
========================================================================
Description:
Add Client security information into ASIC WCID table and IVEIV table.
Return:
========================================================================
*/
VOID RTMPAddWcidAttributeEntry(
IN PRTMP_ADAPTER pAd,
IN UCHAR BssIdx,
IN UCHAR KeyIdx,
IN UCHAR CipherAlg,
IN MAC_TABLE_ENTRY *pEntry)
{
UINT32 WCIDAttri = 0;
USHORT offset;
UCHAR IVEIV = 0;
USHORT Wcid = 0;
#ifdef CONFIG_AP_SUPPORT
BOOLEAN IEEE8021X = FALSE;
#endif /* CONFIG_AP_SUPPORT */
{
#ifdef CONFIG_AP_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
{
#ifdef APCLI_SUPPORT
if (BssIdx >= MIN_NET_DEVICE_FOR_APCLI)
{
if (pEntry)
BssIdx -= MIN_NET_DEVICE_FOR_APCLI;
else
{
DBGPRINT(RT_DEBUG_WARN, ("RTMPAddWcidAttributeEntry: AP-Client link doesn't need to set Group WCID Attribute. \n"));
return;
}
}
else
#endif /* APCLI_SUPPORT */
{
if (BssIdx >= pAd->ApCfg.BssidNum)
{
DBGPRINT(RT_DEBUG_ERROR, ("RTMPAddWcidAttributeEntry: The BSS-index(%d) is out of range for MBSSID link. \n", BssIdx));
return;
}
}
/* choose wcid number*/
if (pEntry)
Wcid = pEntry->Aid;
else
GET_GroupKey_WCID(pAd, Wcid, BssIdx);
#ifdef DOT1X_SUPPORT
if ((BssIdx < pAd->ApCfg.BssidNum) && (BssIdx < MAX_MBSSID_NUM(pAd)) && (BssIdx < HW_BEACON_MAX_NUM))
IEEE8021X = pAd->ApCfg.MBSSID[BssIdx].IEEE8021X;
#endif /* DOT1X_SUPPORT */
}
#endif /* CONFIG_AP_SUPPORT */
#ifdef CONFIG_STA_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_STA(pAd)
{
if (BssIdx > BSS0)
{
DBGPRINT(RT_DEBUG_ERROR, ("RTMPAddWcidAttributeEntry: The BSS-index(%d) is out of range for Infra link. \n", BssIdx));
return;
}
/*
1. In ADHOC mode, the AID is wcid number. And NO mesh link exists.
2. In Infra mode, the AID:1 MUST be wcid of infra STA.
the AID:2~ assign to mesh link entry.
*/
if (pEntry)
Wcid = pEntry->Aid;
else
Wcid = MCAST_WCID;
}
#endif /* CONFIG_STA_SUPPORT */
}
/* Update WCID attribute table*/
offset = MAC_WCID_ATTRIBUTE_BASE + (Wcid * HW_WCID_ATTRI_SIZE);
#ifdef CONFIG_AP_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
{
/*
1. Wds-links and Mesh-links always use Pair-wise key table.
2. When the CipherAlg is TKIP, AES or the dynamic WEP is enabled,
it needs to set key into Pair-wise Key Table.
3. The pair-wise key security mode is set NONE, it means as no security.
*/
if (pEntry && (IS_ENTRY_WDS(pEntry) || IS_ENTRY_MESH(pEntry)))
WCIDAttri = (BssIdx<<4) | (CipherAlg<<1) | PAIRWISEKEYTABLE;
else if ((pEntry) &&
((CipherAlg == CIPHER_TKIP) ||
(CipherAlg == CIPHER_AES) ||
(CipherAlg == CIPHER_NONE) ||
(IEEE8021X == TRUE)))
WCIDAttri = (BssIdx<<4) | (CipherAlg<<1) | PAIRWISEKEYTABLE;
else
WCIDAttri = (BssIdx<<4) | (CipherAlg<<1) | SHAREDKEYTABLE;
}
#endif /* CONFIG_AP_SUPPORT */
#ifdef CONFIG_STA_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_STA(pAd)
{
if (pEntry && IS_ENTRY_MESH(pEntry))
WCIDAttri = (CipherAlg<<1) | PAIRWISEKEYTABLE;
#if defined(DOT11Z_TDLS_SUPPORT) || defined(QOS_DLS_SUPPORT)
else if ((pEntry) && (IS_ENTRY_DLS(pEntry) || IS_ENTRY_TDLS(pEntry)) &&
((CipherAlg == CIPHER_TKIP) ||
(CipherAlg == CIPHER_AES) ||
(CipherAlg == CIPHER_NONE)))
WCIDAttri = (CipherAlg<<1) | PAIRWISEKEYTABLE;
#endif /* defined(DOT11Z_TDLS_SUPPORT) || defined(QOS_DLS_SUPPORT) */
else
WCIDAttri = (CipherAlg<<1) | SHAREDKEYTABLE;
}
#endif /* CONFIG_STA_SUPPORT */
RTMP_IO_WRITE32(pAd, offset, WCIDAttri);
/* Update IV/EIV table*/
offset = MAC_IVEIV_TABLE_BASE + (Wcid * HW_IVEIV_ENTRY_SIZE);
/* WPA mode*/
if ((CipherAlg == CIPHER_TKIP) || (CipherAlg == CIPHER_AES))
{
/* Eiv bit on. keyid always is 0 for pairwise key */
IVEIV = (KeyIdx <<6) | 0x20;
}
else
{
/* WEP KeyIdx is default tx key. */
IVEIV = (KeyIdx << 6);
}
/* For key index and ext IV bit, so only need to update the position(offset+3).*/
#ifdef RTMP_MAC_USB
RTUSBMultiWrite_OneByte(pAd, offset+3, &IVEIV);
#endif /* RTMP_MAC_USB */
DBGPRINT(RT_DEBUG_TRACE,("RTMPAddWcidAttributeEntry: WCID #%d, KeyIndex #%d, Alg=%s\n",Wcid, KeyIdx, CipherName[CipherAlg]));
DBGPRINT(RT_DEBUG_TRACE,(" WCIDAttri = 0x%x \n", WCIDAttri));
}
/*
==========================================================================
Description:
Parse encryption type
Arguments:
pAdapter Pointer to our adapter
wrq Pointer to the ioctl argument
Return Value:
None
Note:
==========================================================================
*/
PSTRING GetEncryptType(CHAR enc)
{
if(enc == Ndis802_11WEPDisabled)
return "NONE";
if(enc == Ndis802_11WEPEnabled)
return "WEP";
if(enc == Ndis802_11Encryption2Enabled)
return "TKIP";
if(enc == Ndis802_11Encryption3Enabled)
return "AES";
if(enc == Ndis802_11Encryption4Enabled)
return "TKIPAES";
#ifdef WAPI_SUPPORT
if(enc == Ndis802_11EncryptionSMS4Enabled)
return "SMS4";
#endif /* WAPI_SUPPORT */
else
return "UNKNOW";
}
PSTRING GetAuthMode(CHAR auth)
{
if(auth == Ndis802_11AuthModeOpen)
return "OPEN";
if(auth == Ndis802_11AuthModeShared)
return "SHARED";
if(auth == Ndis802_11AuthModeAutoSwitch)
return "AUTOWEP";
if(auth == Ndis802_11AuthModeWPA)
return "WPA";
if(auth == Ndis802_11AuthModeWPAPSK)
return "WPAPSK";
if(auth == Ndis802_11AuthModeWPANone)
return "WPANONE";
if(auth == Ndis802_11AuthModeWPA2)
return "WPA2";
if(auth == Ndis802_11AuthModeWPA2PSK)
return "WPA2PSK";
if(auth == Ndis802_11AuthModeWPA1WPA2)
return "WPA1WPA2";
if(auth == Ndis802_11AuthModeWPA1PSKWPA2PSK)
return "WPA1PSKWPA2PSK";
#ifdef WAPI_SUPPORT
if(auth == Ndis802_11AuthModeWAICERT)
return "WAI-CERT";
if(auth == Ndis802_11AuthModeWAIPSK)
return "WAI-PSK";
#endif /* WAPI_SUPPORT */
return "UNKNOW";
}
/*
==========================================================================
Description:
Get site survey results
Arguments:
pAdapter Pointer to our adapter
wrq Pointer to the ioctl argument
Return Value:
None
Note:
Usage:
1.) UI needs to wait 4 seconds after issue a site survey command
2.) iwpriv ra0 get_site_survey
3.) UI needs to prepare at least 4096bytes to get the results
==========================================================================
*/
#define LINE_LEN (4+33+20+23+9+7+7+3) /* Channel+SSID+Bssid+Security+Signal+WiressMode+ExtCh+NetworkType*/
#ifdef CONFIG_STA_SUPPORT
#ifdef WSC_STA_SUPPORT
#define WPS_LINE_LEN (4+5) /* WPS+DPID*/
#endif /* WSC_STA_SUPPORT */
#endif /* CONFIG_STA_SUPPORT */
VOID RTMPCommSiteSurveyData(
IN PSTRING msg,
IN PBSS_ENTRY pBss,
IN UINT32 MsgLen)
{
INT Rssi = 0;
UINT Rssi_Quality = 0;
NDIS_802_11_NETWORK_TYPE wireless_mode;
CHAR Ssid[MAX_LEN_OF_SSID +1];
STRING SecurityStr[32] = {0};
NDIS_802_11_ENCRYPTION_STATUS ap_cipher = Ndis802_11EncryptionDisabled;
NDIS_802_11_AUTHENTICATION_MODE ap_auth_mode = Ndis802_11AuthModeOpen;
/*Channel*/
sprintf(msg+strlen(msg),"%-4d", pBss->Channel);
/*SSID*/
NdisZeroMemory(Ssid, (MAX_LEN_OF_SSID +1));
if (RTMPCheckStrPrintAble((PCHAR)pBss->Ssid, pBss->SsidLen))
NdisMoveMemory(Ssid, pBss->Ssid, pBss->SsidLen);
else
{
INT idx = 0;
sprintf(Ssid, "0x");
for (idx = 0; (idx < 14) && (idx < pBss->SsidLen); idx++)
sprintf(Ssid + 2 + (idx*2), "%02X", (UCHAR)pBss->Ssid[idx]);
}
sprintf(msg+strlen(msg),"%-33s", Ssid);
/*BSSID*/
sprintf(msg+strlen(msg),"%02x:%02x:%02x:%02x:%02x:%02x ",
pBss->Bssid[0],
pBss->Bssid[1],
pBss->Bssid[2],
pBss->Bssid[3],
pBss->Bssid[4],
pBss->Bssid[5]);
/*Security*/
RTMPZeroMemory(SecurityStr, 32);
if ((Ndis802_11AuthModeWPA <= pBss->AuthMode) &&
(pBss->AuthMode <= Ndis802_11AuthModeWPA1PSKWPA2PSK))
{
if (pBss->AuthMode == Ndis802_11AuthModeWPANone)
{
ap_auth_mode = pBss->AuthMode;
ap_cipher = pBss->WPA.PairCipher;
}
else if (pBss->AuthModeAux == Ndis802_11AuthModeOpen)
{
ap_auth_mode = pBss->AuthMode;
if ((ap_auth_mode == Ndis802_11AuthModeWPA) ||
(ap_auth_mode == Ndis802_11AuthModeWPAPSK))
{
if (pBss->WPA.PairCipherAux == Ndis802_11WEPDisabled)
ap_cipher = pBss->WPA.PairCipher;
else
ap_cipher = Ndis802_11Encryption4Enabled;
}
else if ((ap_auth_mode == Ndis802_11AuthModeWPA2) ||
(ap_auth_mode == Ndis802_11AuthModeWPA2PSK))
{
if (pBss->WPA2.PairCipherAux == Ndis802_11WEPDisabled)
ap_cipher = pBss->WPA2.PairCipher;
else
ap_cipher = Ndis802_11Encryption4Enabled;
}
}
else if ((pBss->AuthMode == Ndis802_11AuthModeWPAPSK) ||
(pBss->AuthMode == Ndis802_11AuthModeWPA2PSK))
{
if ((pBss->AuthModeAux == Ndis802_11AuthModeWPAPSK) ||
(pBss->AuthModeAux == Ndis802_11AuthModeWPA2PSK))
ap_auth_mode = Ndis802_11AuthModeWPA1PSKWPA2PSK;
else
ap_auth_mode = pBss->AuthMode;
if (pBss->WPA.PairCipher != pBss->WPA2.PairCipher)
ap_cipher = Ndis802_11Encryption4Enabled;
else if ((pBss->WPA.PairCipher == pBss->WPA2.PairCipher) &&
(pBss->WPA.PairCipherAux != pBss->WPA2.PairCipherAux))
ap_cipher = Ndis802_11Encryption4Enabled;
else if ((pBss->WPA.PairCipher == pBss->WPA2.PairCipher) &&
(pBss->WPA.PairCipherAux == pBss->WPA2.PairCipherAux) &&
(pBss->WPA.PairCipherAux != Ndis802_11WEPDisabled))
ap_cipher = Ndis802_11Encryption4Enabled;
else if ((pBss->WPA.PairCipher == pBss->WPA2.PairCipher) &&
(pBss->WPA.PairCipherAux == pBss->WPA2.PairCipherAux) &&
(pBss->WPA.PairCipherAux == Ndis802_11WEPDisabled))
ap_cipher = pBss->WPA.PairCipher;
}
else if ((pBss->AuthMode == Ndis802_11AuthModeWPA) ||
(pBss->AuthMode == Ndis802_11AuthModeWPA2))
{
if ((pBss->AuthModeAux == Ndis802_11AuthModeWPA) ||
(pBss->AuthModeAux == Ndis802_11AuthModeWPA2))
ap_auth_mode = Ndis802_11AuthModeWPA1WPA2;
else
ap_auth_mode = pBss->AuthMode;
if (pBss->WPA.PairCipher != pBss->WPA2.PairCipher)
ap_cipher = Ndis802_11Encryption4Enabled;
else if ((pBss->WPA.PairCipher == pBss->WPA2.PairCipher) &&
(pBss->WPA.PairCipherAux != pBss->WPA2.PairCipherAux))
ap_cipher = Ndis802_11Encryption4Enabled;
else if ((pBss->WPA.PairCipher == pBss->WPA2.PairCipher) &&
(pBss->WPA.PairCipherAux == pBss->WPA2.PairCipherAux) &&
(pBss->WPA.PairCipherAux != Ndis802_11WEPDisabled))
ap_cipher = Ndis802_11Encryption4Enabled;
else if ((pBss->WPA.PairCipher == pBss->WPA2.PairCipher) &&
(pBss->WPA.PairCipherAux == pBss->WPA2.PairCipherAux) &&
(pBss->WPA.PairCipherAux == Ndis802_11WEPDisabled))
ap_cipher = pBss->WPA.PairCipher;
}
sprintf(SecurityStr, "%s/%s", GetAuthMode((CHAR)ap_auth_mode), GetEncryptType((CHAR)ap_cipher));
}
else
{
ap_auth_mode = pBss->AuthMode;
ap_cipher = pBss->WepStatus;
if (ap_cipher == Ndis802_11WEPDisabled)
sprintf(SecurityStr, "NONE");
else if (ap_cipher == Ndis802_11WEPEnabled)
sprintf(SecurityStr, "WEP");
else
sprintf(SecurityStr, "%s/%s", GetAuthMode((CHAR)ap_auth_mode), GetEncryptType((CHAR)ap_cipher));
}
sprintf(msg+strlen(msg), "%-23s", SecurityStr);
/* Rssi*/
Rssi = (INT)pBss->Rssi;
if (Rssi >= -50)
Rssi_Quality = 100;
else if (Rssi >= -80) /* between -50 ~ -80dbm*/
Rssi_Quality = (UINT)(24 + ((Rssi + 80) * 26)/10);
else if (Rssi >= -90) /* between -80 ~ -90dbm*/
Rssi_Quality = (UINT)(((Rssi + 90) * 26)/10);
else /* < -84 dbm*/
Rssi_Quality = 0;
sprintf(msg+strlen(msg),"%-9d", Rssi_Quality);
/* Wireless Mode*/
wireless_mode = NetworkTypeInUseSanity(pBss);
if (wireless_mode == Ndis802_11FH ||
wireless_mode == Ndis802_11DS)
sprintf(msg+strlen(msg),"%-7s", "11b");
else if (wireless_mode == Ndis802_11OFDM5)
sprintf(msg+strlen(msg),"%-7s", "11a");
else if (wireless_mode == Ndis802_11OFDM5_N)
sprintf(msg+strlen(msg),"%-7s", "11a/n");
else if (wireless_mode == Ndis802_11OFDM24)
sprintf(msg+strlen(msg),"%-7s", "11b/g");
else if (wireless_mode == Ndis802_11OFDM24_N)
sprintf(msg+strlen(msg),"%-7s", "11b/g/n");
else
sprintf(msg+strlen(msg),"%-7s", "unknow");
/* Ext Channel*/
if (pBss->AddHtInfoLen > 0)
{
if (pBss->AddHtInfo.AddHtInfo.ExtChanOffset == EXTCHA_ABOVE)
sprintf(msg+strlen(msg),"%-7s", " ABOVE");
else if (pBss->AddHtInfo.AddHtInfo.ExtChanOffset == EXTCHA_BELOW)
sprintf(msg+strlen(msg),"%-7s", " BELOW");
else
sprintf(msg+strlen(msg),"%-7s", " NONE");
}
else
{
sprintf(msg+strlen(msg),"%-7s", " NONE");
}
/*Network Type */
if (pBss->BssType == BSS_ADHOC)
sprintf(msg+strlen(msg),"%-3s", " Ad");
else
sprintf(msg+strlen(msg),"%-3s", " In");
sprintf(msg+strlen(msg),"\n");
return;
}
#if defined (AP_SCAN_SUPPORT) || defined (CONFIG_STA_SUPPORT)
VOID RTMPIoctlGetSiteSurvey(
IN PRTMP_ADAPTER pAdapter,
IN RTMP_IOCTL_INPUT_STRUCT *wrq)
{
PSTRING msg;
INT i=0;
INT WaitCnt;
INT Status=0;
INT max_len = LINE_LEN;
PBSS_ENTRY pBss;
UINT32 TotalLen, BufLen = IW_SCAN_MAX_DATA;
#ifdef CONFIG_STA_SUPPORT
#ifdef WSC_STA_SUPPORT
max_len += WPS_LINE_LEN;
#endif /* WSC_STA_SUPPORT */
#endif /* CONFIG_STA_SUPPORT */
TotalLen = sizeof(CHAR)*((MAX_LEN_OF_BSS_TABLE)*max_len) + 100;
if (wrq->u.data.length == 0)
BufLen = IW_SCAN_MAX_DATA;
else
BufLen = wrq->u.data.length;
os_alloc_mem(NULL, (PUCHAR *)&msg, TotalLen);
if (msg == NULL)
{
DBGPRINT(RT_DEBUG_TRACE, ("RTMPIoctlGetSiteSurvey - msg memory alloc fail.\n"));
return;
}
memset(msg, 0 , TotalLen);
sprintf(msg,"%s","\n");
sprintf(msg+strlen(msg),"%-4s%-33s%-20s%-23s%-9s%-7s%-7s%-3s\n",
"Ch", "SSID", "BSSID", "Security", "Siganl(%)", "W-Mode", " ExtCH"," NT");
#ifdef WSC_INCLUDED
sprintf(msg+strlen(msg)-1,"%-4s%-5s\n", " WPS", " DPID");
#endif /* WSC_INCLUDED */
#ifdef CONFIG_STA_SUPPORT
#endif /* CONFIG_STA_SUPPORT */
WaitCnt = 0;
#ifdef CONFIG_STA_SUPPORT
pAdapter->StaCfg.bSkipAutoScanConn = TRUE;
#endif /* CONFIG_STA_SUPPORT */
while ((ScanRunning(pAdapter) == TRUE) && (WaitCnt++ < 200))
OS_WAIT(500);
for(i=0; i<pAdapter->ScanTab.BssNr ;i++)
{
pBss = &pAdapter->ScanTab.BssEntry[i];
if( pBss->Channel==0)
break;
if((strlen(msg)+100 ) >= BufLen)
break;
RTMPCommSiteSurveyData(msg, pBss, TotalLen);
#ifdef WSC_INCLUDED
/*WPS*/
if (pBss->WpsAP & 0x01)
sprintf(msg+strlen(msg)-1,"%-4s", " YES");
else
sprintf(msg+strlen(msg)-1,"%-4s", " NO");
if (pBss->WscDPIDFromWpsAP == DEV_PASS_ID_PIN)
sprintf(msg+strlen(msg),"%-5s\n", " PIN");
else if (pBss->WscDPIDFromWpsAP == DEV_PASS_ID_PBC)
sprintf(msg+strlen(msg),"%-5s\n", " PBC");
else
sprintf(msg+strlen(msg),"%-5s\n", " ");
#endif /* WSC_INCLUDED */
#ifdef CONFIG_STA_SUPPORT
#endif /* CONFIG_STA_SUPPORT */
}
#ifdef CONFIG_STA_SUPPORT
pAdapter->StaCfg.bSkipAutoScanConn = FALSE;
#endif /* CONFIG_STA_SUPPORT */
wrq->u.data.length = strlen(msg);
Status = copy_to_user(wrq->u.data.pointer, msg, wrq->u.data.length);
DBGPRINT(RT_DEBUG_TRACE, ("RTMPIoctlGetSiteSurvey - wrq->u.data.length = %d\n", wrq->u.data.length));
os_free_mem(NULL, (PUCHAR)msg);
}
#endif
#define MAC_LINE_LEN (1+14+4+4+4+4+10+10+10+6+6) /* "\n"+Addr+aid+psm+datatime+rxbyte+txbyte+current tx rate+last tx rate+"\n" */
VOID RTMPIoctlGetMacTable(
IN PRTMP_ADAPTER pAd,
IN RTMP_IOCTL_INPUT_STRUCT *wrq)
{
INT i;
/* RT_802_11_MAC_TABLE MacTab;*/
RT_802_11_MAC_TABLE *pMacTab = NULL;
RT_802_11_MAC_ENTRY *pDst;
MAC_TABLE_ENTRY *pEntry;
char *msg;
/* allocate memory */
os_alloc_mem(NULL, (UCHAR **)&pMacTab, sizeof(RT_802_11_MAC_TABLE));
if (pMacTab == NULL)
{
DBGPRINT(RT_DEBUG_ERROR, ("%s: Allocate memory fail!!!\n", __FUNCTION__));
return;
}
NdisZeroMemory(pMacTab, sizeof(RT_802_11_MAC_TABLE));
pMacTab->Num = 0;
for (i=0; i<MAX_LEN_OF_MAC_TABLE; i++)
{
pEntry = &(pAd->MacTab.Content[i]);
if (IS_ENTRY_CLIENT(pEntry) && (pEntry->Sst == SST_ASSOC))
{
pDst = &pMacTab->Entry[pMacTab->Num];
pDst->ApIdx = (UCHAR)pEntry->apidx;
COPY_MAC_ADDR(pDst->Addr, &pEntry->Addr);
pDst->Aid = (UCHAR)pEntry->Aid;
pDst->Psm = pEntry->PsMode;
#ifdef DOT11_N_SUPPORT
pDst->MimoPs = pEntry->MmpsMode;
#endif /* DOT11_N_SUPPORT */
/* Fill in RSSI per entry*/
pDst->AvgRssi0 = pEntry->RssiSample.AvgRssi0;
pDst->AvgRssi1 = pEntry->RssiSample.AvgRssi1;
pDst->AvgRssi2 = pEntry->RssiSample.AvgRssi2;
/* the connected time per entry*/
pDst->ConnectedTime = pEntry->StaConnectTime;
pDst->TxRate.word = pEntry->HTPhyMode.word;
pMacTab->Num += 1;
}
}
wrq->u.data.length = sizeof(RT_802_11_MAC_TABLE);
if (copy_to_user(wrq->u.data.pointer, pMacTab, wrq->u.data.length))
{
DBGPRINT(RT_DEBUG_TRACE, ("%s: copy_to_user() fail\n", __FUNCTION__));
}
/* msg = kmalloc(sizeof(CHAR)*(MAX_LEN_OF_MAC_TABLE*MAC_LINE_LEN), MEM_ALLOC_FLAG);*/
os_alloc_mem(NULL, (UCHAR **)&msg, sizeof(CHAR)*(MAX_LEN_OF_MAC_TABLE*MAC_LINE_LEN));
if (msg == NULL)
{
DBGPRINT(RT_DEBUG_ERROR, ("%s():Alloc memory failed\n", __FUNCTION__));
goto LabelOK;
}
memset(msg, 0 ,MAX_LEN_OF_MAC_TABLE*MAC_LINE_LEN );
sprintf(msg,"%s","\n");
sprintf(msg+strlen(msg),"%-14s%-4s%-4s%-4s%-4s%-6s%-6s%-10s%-10s%-10s\n",
"MAC", "AP", "AID", "PSM", "AUTH", "CTxR", "LTxR","LDT", "RxB", "TxB");
for (i=0; i<MAX_LEN_OF_MAC_TABLE; i++)
{
PMAC_TABLE_ENTRY pEntry = &pAd->MacTab.Content[i];
if (IS_ENTRY_CLIENT(pEntry) && (pEntry->Sst == SST_ASSOC))
{
if((strlen(msg)+MAC_LINE_LEN ) >= (MAX_LEN_OF_MAC_TABLE*MAC_LINE_LEN) )
break;
sprintf(msg+strlen(msg),"%02x%02x%02x%02x%02x%02x ",
pEntry->Addr[0], pEntry->Addr[1], pEntry->Addr[2],
pEntry->Addr[3], pEntry->Addr[4], pEntry->Addr[5]);
sprintf(msg+strlen(msg),"%-4d", (int)pEntry->apidx);
sprintf(msg+strlen(msg),"%-4d", (int)pEntry->Aid);
sprintf(msg+strlen(msg),"%-4d", (int)pEntry->PsMode);
sprintf(msg+strlen(msg),"%-4d", (int)pEntry->AuthState);
sprintf(msg+strlen(msg),"%-6d",RateIdToMbps[pAd->MacTab.Content[i].CurrTxRate]);
sprintf(msg+strlen(msg),"%-6d",0/*RateIdToMbps[pAd->MacTab.Content[i].HTPhyMode.word]*/); /* ToDo*/
sprintf(msg+strlen(msg),"%-10d",0/*pAd->MacTab.Content[i].HSCounter.LastDataPacketTime*/); /* ToDo*/
sprintf(msg+strlen(msg),"%-10d",0/*pAd->MacTab.Content[i].HSCounter.TotalRxByteCount*/); /* ToDo*/
sprintf(msg+strlen(msg),"%-10d\n",0/*pAd->MacTab.Content[i].HSCounter.TotalTxByteCount*/); /* ToDo*/
}
}
/* for compatible with old API just do the printk to console*/
DBGPRINT(RT_DEBUG_TRACE, ("%s", msg));
/* kfree(msg);*/
os_free_mem(NULL, msg);
LabelOK:
if (pMacTab != NULL)
os_free_mem(NULL, pMacTab);
}
#ifdef INF_AR9
#ifdef AR9_MAPI_SUPPORT
#ifdef CONFIG_AP_SUPPORT
VOID RTMPAR9IoctlGetMacTable(
IN PRTMP_ADAPTER pAd,
IN RTMP_IOCTL_INPUT_STRUCT *wrq)
{
INT i;
char *msg;
/* msg = kmalloc(sizeof(CHAR)*(MAX_LEN_OF_MAC_TABLE*MAC_LINE_LEN), MEM_ALLOC_FLAG);*/
os_alloc_mem(NULL, (UCHAR **)&msg, sizeof(CHAR)*(MAX_LEN_OF_MAC_TABLE*MAC_LINE_LEN));
if (msg == NULL)
{
DBGPRINT(RT_DEBUG_ERROR, ("%s():Alloc memory failed\n", __FUNCTION__));
return;
}
memset(msg, 0 ,MAX_LEN_OF_MAC_TABLE*MAC_LINE_LEN );
sprintf(msg,"%s","\n");
sprintf(msg+strlen(msg),"%-14s%-4s%-4s%-4s%-4s%-6s%-6s%-10s%-10s%-10s\n",
"MAC", "AP", "AID", "PSM", "AUTH", "CTxR", "LTxR","LDT", "RxB", "TxB");
for (i=0; i<MAX_LEN_OF_MAC_TABLE; i++)
{
PMAC_TABLE_ENTRY pEntry = &pAd->MacTab.Content[i];
if (IS_ENTRY_CLIENT(pEntry) && (pEntry->Sst == SST_ASSOC))
{
if((strlen(msg)+MAC_LINE_LEN ) >= (MAX_LEN_OF_MAC_TABLE*MAC_LINE_LEN) )
break;
sprintf(msg+strlen(msg),"%02x%02x%02x%02x%02x%02x ",
pEntry->Addr[0], pEntry->Addr[1], pEntry->Addr[2],
pEntry->Addr[3], pEntry->Addr[4], pEntry->Addr[5]);
sprintf(msg+strlen(msg),"%-4d", (int)pEntry->apidx);
sprintf(msg+strlen(msg),"%-4d", (int)pEntry->Aid);
sprintf(msg+strlen(msg),"%-4d", (int)pEntry->PsMode);
sprintf(msg+strlen(msg),"%-4d", (int)pEntry->AuthState);
sprintf(msg+strlen(msg),"%-6d",RateIdToMbps[pAd->MacTab.Content[i].CurrTxRate]);
sprintf(msg+strlen(msg),"%-6d",0/*RateIdToMbps[pAd->MacTab.Content[i].HTPhyMode.word]*/); /* ToDo*/
sprintf(msg+strlen(msg),"%-10d",0/*pAd->MacTab.Content[i].HSCounter.LastDataPacketTime*/); /* ToDo*/
sprintf(msg+strlen(msg),"%-10d",0/*pAd->MacTab.Content[i].HSCounter.TotalRxByteCount*/); /* ToDo*/
sprintf(msg+strlen(msg),"%-10d\n",0/*pAd->MacTab.Content[i].HSCounter.TotalTxByteCount*/); /* ToDo*/
}
}
/* for compatible with old API just do the printk to console*/
wrq->u.data.length = strlen(msg);
if (copy_to_user(wrq->u.data.pointer, msg, wrq->u.data.length))
{
DBGPRINT(RT_DEBUG_OFF, ("%s", msg));
}
/* kfree(msg);*/
os_free_mem(NULL, msg);
}
VOID RTMPIoctlGetSTAT2(
IN PRTMP_ADAPTER pAd,
IN RTMP_IOCTL_INPUT_STRUCT *wrq)
{
char *msg;
PMULTISSID_STRUCT pMbss;
INT apidx;
/* msg = kmalloc(sizeof(CHAR)*(pAd->ApCfg.BssidNum*(14*128)), MEM_ALLOC_FLAG);*/
os_alloc_mem(NULL, (UCHAR **)&msg, sizeof(CHAR)*(pAd->ApCfg.BssidNum*(14*128)));
if (msg == NULL)
{
DBGPRINT(RT_DEBUG_ERROR, ("%s():Alloc memory failed\n", __FUNCTION__));
return;
}
memset(msg, 0 ,pAd->ApCfg.BssidNum*(14*128));
sprintf(msg,"%s","\n");
for (apidx=0; apidx<pAd->ApCfg.BssidNum; apidx++)
{
pMbss=&pAd->ApCfg.MBSSID[apidx];
sprintf(msg+strlen(msg),"ra%d\n",apidx);
sprintf(msg+strlen(msg),"bytesTx = %ld\n",(pMbss->TransmittedByteCount));
sprintf(msg+strlen(msg),"bytesRx = %ld\n",(pMbss->ReceivedByteCount));
sprintf(msg+strlen(msg),"pktsTx = %ld\n",pMbss->TxCount);
sprintf(msg+strlen(msg),"pktsRx = %ld\n",pMbss->RxCount);
sprintf(msg+strlen(msg),"errorsTx = %ld\n",pMbss->TxErrorCount);
sprintf(msg+strlen(msg),"errorsRx = %ld\n",pMbss->RxErrorCount);
sprintf(msg+strlen(msg),"discardPktsTx = %ld\n",pMbss->TxDropCount);
sprintf(msg+strlen(msg),"discardPktsRx = %ld\n",pMbss->RxDropCount);
sprintf(msg+strlen(msg),"ucPktsTx = %ld\n",pMbss->ucPktsTx);
sprintf(msg+strlen(msg),"ucPktsRx = %ld\n",pMbss->ucPktsRx);
sprintf(msg+strlen(msg),"mcPktsTx = %ld\n",pMbss->mcPktsTx);
sprintf(msg+strlen(msg),"mcPktsRx = %ld\n",pMbss->mcPktsRx);
sprintf(msg+strlen(msg),"bcPktsTx = %ld\n",pMbss->bcPktsTx);
sprintf(msg+strlen(msg),"bcPktsRx = %ld\n",pMbss->bcPktsRx);
}
wrq->u.data.length = strlen(msg);
if (copy_to_user(wrq->u.data.pointer, msg, wrq->u.data.length))
{
DBGPRINT(RT_DEBUG_OFF, ("%s", msg));
}
/* kfree(msg);*/
os_free_mem(NULL, msg);
}
VOID RTMPIoctlGetRadioDynInfo(
IN PRTMP_ADAPTER pAd,
IN RTMP_IOCTL_INPUT_STRUCT *wrq)
{
char *msg;
PMULTISSID_STRUCT pMbss;
INT status,bandwidth,ShortGI;
/* msg = kmalloc(sizeof(CHAR)*(4096), MEM_ALLOC_FLAG);*/
os_alloc_mem(NULL, (UCHAR **)&msg, sizeof(CHAR)*(4096));
if (msg == NULL)
{
DBGPRINT(RT_DEBUG_ERROR, ("%s():Alloc memory failed\n", __FUNCTION__));
return;
}
memset(msg, 0 ,4096);
sprintf(msg,"%s","\n");
pMbss=&pAd->ApCfg.MBSSID[0];
if(RTMP_TEST_FLAG(pAd, fRTMP_ADAPTER_RADIO_OFF))
status = 0;
else
status = 1;
if(pAd->CommonCfg.HtCapability.HtCapInfo.ChannelWidth == BW_40)
bandwidth = 1;
else
bandwidth = 0;
if(pAd->CommonCfg.RegTransmitSetting.field.ShortGI == GI_800)
ShortGI = 1;
else
ShortGI = 0;
sprintf(msg+strlen(msg),"status = %d\n",status);
sprintf(msg+strlen(msg),"channelsInUse = %d\n",pAd->ChannelListNum);
sprintf(msg+strlen(msg),"channel = %d\n",pAd->CommonCfg.Channel);
sprintf(msg+strlen(msg),"chanWidth = %d\n",bandwidth);
sprintf(msg+strlen(msg),"guardIntvl = %d\n",ShortGI);
sprintf(msg+strlen(msg),"MCS = %d\n",pMbss->DesiredTransmitSetting.field.MCS);
wrq->u.data.length = strlen(msg);
if (copy_to_user(wrq->u.data.pointer, msg, wrq->u.data.length))
{
DBGPRINT(RT_DEBUG_OFF, ("%s", msg));
}
/* kfree(msg);*/
os_free_mem(NULL, msg);
}
#endif/*CONFIG_AP_SUPPORT*/
#endif/*AR9_MAPI_SUPPORT*/
#endif/* INF_AR9 */
#ifdef DOT11_N_SUPPORT
INT Set_BASetup_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
UCHAR mac[6], tid;
PSTRING token;
STRING sepValue[] = ":", DASH = '-';
INT i;
MAC_TABLE_ENTRY *pEntry;
/*
The BASetup inupt string format should be xx:xx:xx:xx:xx:xx-d,
=>The six 2 digit hex-decimal number previous are the Mac address,
=>The seventh decimal number is the tid value.
*/
/*DBGPRINT(RT_DEBUG_TRACE,("\n%s\n", arg));*/
if(strlen(arg) < 19) /*Mac address acceptable format 01:02:03:04:05:06 length 17 plus the "-" and tid value in decimal format.*/
return FALSE;
token = strchr(arg, DASH);
if ((token != NULL) && (strlen(token)>1))
{
tid = (UCHAR) simple_strtol((token+1), 0, 10);
/* tid is 0 ~ 7; Or kernel will crash in BAOriSessionSetUp() */
if (tid > (NUM_OF_TID-1))
return FALSE;
*token = '\0';
for (i = 0, token = rstrtok(arg, &sepValue[0]); token; token = rstrtok(NULL, &sepValue[0]), i++)
{
if((strlen(token) != 2) || (!isxdigit(*token)) || (!isxdigit(*(token+1))))
return FALSE;
AtoH(token, (&mac[i]), 1);
}
if(i != 6)
return FALSE;
DBGPRINT(RT_DEBUG_OFF, ("\n%02x:%02x:%02x:%02x:%02x:%02x-%02x\n",
mac[0], mac[1], mac[2], mac[3], mac[4], mac[5], tid));
pEntry = MacTableLookup(pAd, (PUCHAR) mac);
if (pEntry) {
DBGPRINT(RT_DEBUG_OFF, ("\nSetup BA Session: Tid = %d\n", tid));
BAOriSessionSetUp(pAd, pEntry, tid, 0, 100, TRUE);
}
return TRUE;
}
return FALSE;
}
INT Set_BADecline_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
ULONG bBADecline;
bBADecline = simple_strtol(arg, 0, 10);
if (bBADecline == 0)
{
pAd->CommonCfg.bBADecline = FALSE;
}
else if (bBADecline == 1)
{
pAd->CommonCfg.bBADecline = TRUE;
}
else
{
return FALSE; /*Invalid argument*/
}
DBGPRINT(RT_DEBUG_TRACE, ("Set_BADecline_Proc::(BADecline=%d)\n", pAd->CommonCfg.bBADecline));
return TRUE;
}
INT Set_BAOriTearDown_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
UCHAR mac[6], tid;
PSTRING token;
STRING sepValue[] = ":", DASH = '-';
INT i;
MAC_TABLE_ENTRY *pEntry;
/*DBGPRINT(RT_DEBUG_TRACE,("\n%s\n", arg));*/
/*
The BAOriTearDown inupt string format should be xx:xx:xx:xx:xx:xx-d,
=>The six 2 digit hex-decimal number previous are the Mac address,
=>The seventh decimal number is the tid value.
*/
if(strlen(arg) < 19) /*Mac address acceptable format 01:02:03:04:05:06 length 17 plus the "-" and tid value in decimal format.*/
return FALSE;
token = strchr(arg, DASH);
if ((token != NULL) && (strlen(token)>1))
{
tid = simple_strtol((token+1), 0, 10);
/* tid will be 0 ~ 7; Or kernel will crash in BAOriSessionTearDown() */
if (tid > (NUM_OF_TID-1))
return FALSE;
*token = '\0';
for (i = 0, token = rstrtok(arg, &sepValue[0]); token; token = rstrtok(NULL, &sepValue[0]), i++)
{
if((strlen(token) != 2) || (!isxdigit(*token)) || (!isxdigit(*(token+1))))
return FALSE;
AtoH(token, (&mac[i]), 1);
}
if(i != 6)
return FALSE;
DBGPRINT(RT_DEBUG_OFF, ("\n%02x:%02x:%02x:%02x:%02x:%02x-%02x",
mac[0], mac[1], mac[2], mac[3], mac[4], mac[5], tid));
pEntry = MacTableLookup(pAd, (PUCHAR) mac);
if (pEntry) {
DBGPRINT(RT_DEBUG_OFF, ("\nTear down Ori BA Session: Tid = %d\n", tid));
BAOriSessionTearDown(pAd, pEntry->Aid, tid, FALSE, TRUE);
}
return TRUE;
}
return FALSE;
}
INT Set_BARecTearDown_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
UCHAR mac[6], tid;
PSTRING token;
STRING sepValue[] = ":", DASH = '-';
INT i;
MAC_TABLE_ENTRY *pEntry;
/*DBGPRINT(RT_DEBUG_TRACE,("\n%s\n", arg));*/
/*
The BARecTearDown inupt string format should be xx:xx:xx:xx:xx:xx-d,
=>The six 2 digit hex-decimal number previous are the Mac address,
=>The seventh decimal number is the tid value.
*/
if(strlen(arg) < 19) /*Mac address acceptable format 01:02:03:04:05:06 length 17 plus the "-" and tid value in decimal format.*/
return FALSE;
token = strchr(arg, DASH);
if ((token != NULL) && (strlen(token)>1))
{
tid = simple_strtol((token+1), 0, 10);
/* tid will be 0 ~ 7; Or kernel will crash in BARecSessionTearDown() */
if (tid > (NUM_OF_TID-1))
return FALSE;
*token = '\0';
for (i = 0, token = rstrtok(arg, &sepValue[0]); token; token = rstrtok(NULL, &sepValue[0]), i++)
{
if((strlen(token) != 2) || (!isxdigit(*token)) || (!isxdigit(*(token+1))))
return FALSE;
AtoH(token, (&mac[i]), 1);
}
if(i != 6)
return FALSE;
DBGPRINT(RT_DEBUG_OFF, ("\n%02x:%02x:%02x:%02x:%02x:%02x-%02x",
mac[0], mac[1], mac[2], mac[3], mac[4], mac[5], tid));
pEntry = MacTableLookup(pAd, (PUCHAR) mac);
if (pEntry) {
DBGPRINT(RT_DEBUG_OFF, ("\nTear down Rec BA Session: Tid = %d\n", tid));
BARecSessionTearDown(pAd, pEntry->Aid, tid, FALSE);
}
return TRUE;
}
return FALSE;
}
INT Set_HtBw_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
ULONG HtBw;
HtBw = simple_strtol(arg, 0, 10);
if (HtBw == BW_40)
pAd->CommonCfg.RegTransmitSetting.field.BW = BW_40;
else if (HtBw == BW_20)
pAd->CommonCfg.RegTransmitSetting.field.BW = BW_20;
else
return FALSE; /*Invalid argument */
SetCommonHT(pAd);
DBGPRINT(RT_DEBUG_TRACE, ("Set_HtBw_Proc::(HtBw=%d)\n", pAd->CommonCfg.RegTransmitSetting.field.BW));
return TRUE;
}
INT Set_HtMcs_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
ULONG HtMcs, Mcs_tmp, ValidMcs = 15;
#ifdef CONFIG_AP_SUPPORT
POS_COOKIE pObj = (POS_COOKIE) pAd->OS_Cookie;
#endif /* CONFIG_AP_SUPPORT */
#ifdef CONFIG_STA_SUPPORT
BOOLEAN bAutoRate = FALSE;
#endif /* CONFIG_STA_SUPPORT */
#ifdef DOT11N_SS3_SUPPORT
if (pAd->CommonCfg.TxStream >= 3)
ValidMcs = 23;
#endif /* DOT11N_SS3_SUPPORT */
Mcs_tmp = simple_strtol(arg, 0, 10);
if (Mcs_tmp <= ValidMcs || Mcs_tmp == 32)
HtMcs = Mcs_tmp;
else
HtMcs = MCS_AUTO;
#ifdef CONFIG_AP_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
{
pAd->ApCfg.MBSSID[pObj->ioctl_if].DesiredTransmitSetting.field.MCS = HtMcs;
DBGPRINT(RT_DEBUG_TRACE, ("Set_HtMcs_Proc::(HtMcs=%d) for ra%d\n",
pAd->ApCfg.MBSSID[pObj->ioctl_if].DesiredTransmitSetting.field.MCS, pObj->ioctl_if));
}
#endif /* CONFIG_AP_SUPPORT */
#ifdef CONFIG_STA_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_STA(pAd)
{
pAd->StaCfg.DesiredTransmitSetting.field.MCS = HtMcs;
pAd->StaCfg.bAutoTxRateSwitch = (HtMcs == MCS_AUTO) ? TRUE:FALSE;
DBGPRINT(RT_DEBUG_TRACE, ("Set_HtMcs_Proc::(HtMcs=%d, bAutoTxRateSwitch = %d)\n",
pAd->StaCfg.DesiredTransmitSetting.field.MCS, pAd->StaCfg.bAutoTxRateSwitch));
if ((!WMODE_CAP_N(pAd->CommonCfg.PhyMode)) ||
(pAd->MacTab.Content[BSSID_WCID].HTPhyMode.field.MODE < MODE_HTMIX))
{
if ((pAd->StaCfg.DesiredTransmitSetting.field.MCS != MCS_AUTO) &&
(HtMcs <= 3) &&
(pAd->StaCfg.DesiredTransmitSetting.field.FixedTxMode == FIXED_TXMODE_CCK))
{
RTMPSetDesiredRates(pAd, (LONG) (RateIdToMbps[HtMcs] * 1000000));
}
else if ((pAd->StaCfg.DesiredTransmitSetting.field.MCS != MCS_AUTO) &&
(HtMcs <= 7) &&
(pAd->StaCfg.DesiredTransmitSetting.field.FixedTxMode == FIXED_TXMODE_OFDM))
{
RTMPSetDesiredRates(pAd, (LONG) (RateIdToMbps[HtMcs+4] * 1000000));
}
else
bAutoRate = TRUE;
if (bAutoRate)
{
pAd->StaCfg.DesiredTransmitSetting.field.MCS = MCS_AUTO;
RTMPSetDesiredRates(pAd, -1);
}
DBGPRINT(RT_DEBUG_TRACE, ("Set_HtMcs_Proc::(FixedTxMode=%d)\n",pAd->StaCfg.DesiredTransmitSetting.field.FixedTxMode));
}
if (ADHOC_ON(pAd))
return TRUE;
}
#endif /* CONFIG_STA_SUPPORT */
SetCommonHT(pAd);
return TRUE;
}
INT Set_HtGi_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
ULONG HtGi;
HtGi = simple_strtol(arg, 0, 10);
if ( HtGi == GI_400)
pAd->CommonCfg.RegTransmitSetting.field.ShortGI = GI_400;
else if ( HtGi == GI_800 )
pAd->CommonCfg.RegTransmitSetting.field.ShortGI = GI_800;
else
return FALSE; /* Invalid argument */
SetCommonHT(pAd);
DBGPRINT(RT_DEBUG_TRACE, ("Set_HtGi_Proc::(ShortGI=%d)\n",pAd->CommonCfg.RegTransmitSetting.field.ShortGI));
return TRUE;
}
INT Set_HtTxBASize_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
UCHAR Size;
Size = simple_strtol(arg, 0, 10);
if (Size <=0 || Size >=64)
{
Size = 8;
}
pAd->CommonCfg.TxBASize = Size-1;
DBGPRINT(RT_DEBUG_ERROR, ("Set_HtTxBASize ::(TxBASize= %d)\n", Size));
return TRUE;
}
INT Set_HtDisallowTKIP_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
ULONG Value;
Value = simple_strtol(arg, 0, 10);
if (Value == 1)
{
pAd->CommonCfg.HT_DisallowTKIP = TRUE;
}
else
{
pAd->CommonCfg.HT_DisallowTKIP = FALSE;
}
DBGPRINT(RT_DEBUG_TRACE, ("Set_HtDisallowTKIP_Proc ::%s\n",
(pAd->CommonCfg.HT_DisallowTKIP == TRUE) ? "enabled" : "disabled"));
return TRUE;
}
INT Set_HtOpMode_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
ULONG Value;
Value = simple_strtol(arg, 0, 10);
if (Value == HTMODE_GF)
pAd->CommonCfg.RegTransmitSetting.field.HTMODE = HTMODE_GF;
else if ( Value == HTMODE_MM )
pAd->CommonCfg.RegTransmitSetting.field.HTMODE = HTMODE_MM;
else
return FALSE; /*Invalid argument */
SetCommonHT(pAd);
DBGPRINT(RT_DEBUG_TRACE, ("Set_HtOpMode_Proc::(HtOpMode=%d)\n",pAd->CommonCfg.RegTransmitSetting.field.HTMODE));
return TRUE;
}
INT Set_HtStbc_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
ULONG Value;
Value = simple_strtol(arg, 0, 10);
if (Value == STBC_USE)
pAd->CommonCfg.RegTransmitSetting.field.STBC = STBC_USE;
else if ( Value == STBC_NONE )
pAd->CommonCfg.RegTransmitSetting.field.STBC = STBC_NONE;
else
return FALSE; /*Invalid argument */
SetCommonHT(pAd);
DBGPRINT(RT_DEBUG_TRACE, ("Set_Stbc_Proc::(HtStbc=%d)\n",pAd->CommonCfg.RegTransmitSetting.field.STBC));
return TRUE;
}
INT Set_HtHtc_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
ULONG Value;
Value = simple_strtol(arg, 0, 10);
if (Value == 0)
pAd->HTCEnable = FALSE;
else if ( Value ==1 )
pAd->HTCEnable = TRUE;
else
return FALSE; /*Invalid argument */
DBGPRINT(RT_DEBUG_TRACE, ("Set_HtHtc_Proc::(HtHtc=%d)\n",pAd->HTCEnable));
return TRUE;
}
INT Set_HtExtcha_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
ULONG Value;
Value = simple_strtol(arg, 0, 10);
if (Value == 0)
pAd->CommonCfg.RegTransmitSetting.field.EXTCHA = EXTCHA_BELOW;
else if ( Value ==1 )
pAd->CommonCfg.RegTransmitSetting.field.EXTCHA = EXTCHA_ABOVE;
else
return FALSE; /*Invalid argument */
SetCommonHT(pAd);
DBGPRINT(RT_DEBUG_TRACE, ("Set_HtExtcha_Proc::(HtExtcha=%d)\n",pAd->CommonCfg.RegTransmitSetting.field.EXTCHA));
return TRUE;
}
INT Set_HtMpduDensity_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
ULONG Value;
Value = simple_strtol(arg, 0, 10);
if (Value <=7)
pAd->CommonCfg.BACapability.field.MpduDensity = Value;
else
pAd->CommonCfg.BACapability.field.MpduDensity = 4;
SetCommonHT(pAd);
DBGPRINT(RT_DEBUG_TRACE, ("Set_HtMpduDensity_Proc::(HtMpduDensity=%d)\n",pAd->CommonCfg.BACapability.field.MpduDensity));
return TRUE;
}
INT Set_HtBaWinSize_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
ULONG Value;
Value = simple_strtol(arg, 0, 10);
#ifdef CONFIG_AP_SUPPORT
/* Intel IOT*/
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
Value = 64;
#endif /* CONFIG_AP_SUPPORT */
if (Value >=1 && Value <= 64)
{
pAd->CommonCfg.REGBACapability.field.RxBAWinLimit = Value;
pAd->CommonCfg.BACapability.field.RxBAWinLimit = Value;
}
else
{
pAd->CommonCfg.REGBACapability.field.RxBAWinLimit = 64;
pAd->CommonCfg.BACapability.field.RxBAWinLimit = 64;
}
SetCommonHT(pAd);
DBGPRINT(RT_DEBUG_TRACE, ("Set_HtBaWinSize_Proc::(HtBaWinSize=%d)\n",pAd->CommonCfg.BACapability.field.RxBAWinLimit));
return TRUE;
}
INT Set_HtRdg_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
ULONG Value;
Value = simple_strtol(arg, 0, 10);
if (Value == 0)
pAd->CommonCfg.bRdg = FALSE;
else if ( Value ==1 )
{
pAd->HTCEnable = TRUE;
pAd->CommonCfg.bRdg = TRUE;
}
else
return FALSE; /*Invalid argument*/
SetCommonHT(pAd);
DBGPRINT(RT_DEBUG_TRACE, ("Set_HtRdg_Proc::(HtRdg=%d)\n",pAd->CommonCfg.bRdg));
return TRUE;
}
INT Set_HtLinkAdapt_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
ULONG Value;
Value = simple_strtol(arg, 0, 10);
if (Value == 0)
pAd->bLinkAdapt = FALSE;
else if ( Value ==1 )
{
pAd->HTCEnable = TRUE;
pAd->bLinkAdapt = TRUE;
}
else
return FALSE; /*Invalid argument*/
DBGPRINT(RT_DEBUG_TRACE, ("Set_HtLinkAdapt_Proc::(HtLinkAdapt=%d)\n",pAd->bLinkAdapt));
return TRUE;
}
INT Set_HtAmsdu_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
ULONG Value;
Value = simple_strtol(arg, 0, 10);
if (Value == 0)
pAd->CommonCfg.BACapability.field.AmsduEnable = FALSE;
else if ( Value == 1 )
pAd->CommonCfg.BACapability.field.AmsduEnable = TRUE;
else
return FALSE; /*Invalid argument*/
SetCommonHT(pAd);
DBGPRINT(RT_DEBUG_TRACE, ("Set_HtAmsdu_Proc::(HtAmsdu=%d)\n",pAd->CommonCfg.BACapability.field.AmsduEnable));
return TRUE;
}
INT Set_HtAutoBa_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
ULONG Value;
Value = simple_strtol(arg, 0, 10);
if (Value == 0)
{
pAd->CommonCfg.BACapability.field.AutoBA = FALSE;
pAd->CommonCfg.BACapability.field.Policy = BA_NOTUSE;
}
else if (Value == 1)
{
pAd->CommonCfg.BACapability.field.AutoBA = TRUE;
pAd->CommonCfg.BACapability.field.Policy = IMMED_BA;
}
else
return FALSE; /*Invalid argument*/
pAd->CommonCfg.REGBACapability.field.AutoBA = pAd->CommonCfg.BACapability.field.AutoBA;
pAd->CommonCfg.REGBACapability.field.Policy = pAd->CommonCfg.BACapability.field.Policy;
SetCommonHT(pAd);
DBGPRINT(RT_DEBUG_TRACE, ("Set_HtAutoBa_Proc::(HtAutoBa=%d)\n",pAd->CommonCfg.BACapability.field.AutoBA));
return TRUE;
}
INT Set_HtProtect_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
ULONG Value;
Value = simple_strtol(arg, 0, 10);
if (Value == 0)
pAd->CommonCfg.bHTProtect = FALSE;
else if (Value == 1)
pAd->CommonCfg.bHTProtect = TRUE;
else
return FALSE; /*Invalid argument*/
DBGPRINT(RT_DEBUG_TRACE, ("Set_HtProtect_Proc::(HtProtect=%d)\n",pAd->CommonCfg.bHTProtect));
return TRUE;
}
INT Set_SendPSMPAction_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
UCHAR mac[6], mode;
PSTRING token;
STRING sepValue[] = ":", DASH = '-';
INT i;
MAC_TABLE_ENTRY *pEntry;
/*DBGPRINT(RT_DEBUG_TRACE,("\n%s\n", arg));*/
/*
The BARecTearDown inupt string format should be xx:xx:xx:xx:xx:xx-d,
=>The six 2 digit hex-decimal number previous are the Mac address,
=>The seventh decimal number is the mode value.
*/
if(strlen(arg) < 19) /*Mac address acceptable format 01:02:03:04:05:06 length 17 plus the "-" and mode value in decimal format.*/
return FALSE;
token = strchr(arg, DASH);
if ((token != NULL) && (strlen(token)>1))
{
mode = simple_strtol((token+1), 0, 10);
if (mode > MMPS_ENABLE)
return FALSE;
*token = '\0';
for (i = 0, token = rstrtok(arg, &sepValue[0]); token; token = rstrtok(NULL, &sepValue[0]), i++)
{
if((strlen(token) != 2) || (!isxdigit(*token)) || (!isxdigit(*(token+1))))
return FALSE;
AtoH(token, (&mac[i]), 1);
}
if(i != 6)
return FALSE;
DBGPRINT(RT_DEBUG_OFF, ("\n%02x:%02x:%02x:%02x:%02x:%02x-%02x",
mac[0], mac[1], mac[2], mac[3], mac[4], mac[5], mode));
pEntry = MacTableLookup(pAd, mac);
if (pEntry) {
DBGPRINT(RT_DEBUG_OFF, ("\nSendPSMPAction MIPS mode = %d\n", mode));
SendPSMPAction(pAd, pEntry->Aid, mode);
}
return TRUE;
}
return FALSE;
}
INT Set_HtMIMOPSmode_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
ULONG Value;
Value = simple_strtol(arg, 0, 10);
if (Value <=3)
pAd->CommonCfg.BACapability.field.MMPSmode = Value;
else
pAd->CommonCfg.BACapability.field.MMPSmode = 3;
SetCommonHT(pAd);
DBGPRINT(RT_DEBUG_TRACE, ("Set_HtMIMOPSmode_Proc::(MIMOPS mode=%d)\n",pAd->CommonCfg.BACapability.field.MMPSmode));
return TRUE;
}
#ifdef CONFIG_AP_SUPPORT
/*
==========================================================================
Description:
Set Tx Stream number
Return:
TRUE if all parameters are OK, FALSE otherwise
==========================================================================
*/
INT Set_HtTxStream_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
ULONG Value;
Value = simple_strtol(arg, 0, 10);
if ((Value <= 3) && (Value >= 1) && (Value <= pAd->Antenna.field.TxPath)) /* 3*3*/
pAd->CommonCfg.TxStream = Value;
else
pAd->CommonCfg.TxStream = pAd->Antenna.field.TxPath;
if ((pAd->MACVersion < RALINK_2883_VERSION) &&
(pAd->CommonCfg.TxStream > 2))
{
pAd->CommonCfg.TxStream = 2; /* only 2 TX streams for RT2860 series*/
}
SetCommonHT(pAd);
APStop(pAd);
APStartUp(pAd);
DBGPRINT(RT_DEBUG_TRACE, ("Set_HtTxStream_Proc::(Tx Stream=%d)\n",pAd->CommonCfg.TxStream));
return TRUE;
}
/*
==========================================================================
Description:
Set Rx Stream number
Return:
TRUE if all parameters are OK, FALSE otherwise
==========================================================================
*/
INT Set_HtRxStream_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
ULONG Value;
Value = simple_strtol(arg, 0, 10);
if ((Value <= 3) && (Value >= 1) && (Value <= pAd->Antenna.field.RxPath))
pAd->CommonCfg.RxStream = Value;
else
pAd->CommonCfg.RxStream = pAd->Antenna.field.RxPath;
if ((pAd->MACVersion < RALINK_2883_VERSION) &&
(pAd->CommonCfg.RxStream > 2)) /* 3*3*/
{
pAd->CommonCfg.RxStream = 2; /* only 2 RX streams for RT2860 series*/
}
SetCommonHT(pAd);
APStop(pAd);
APStartUp(pAd);
DBGPRINT(RT_DEBUG_TRACE, ("Set_HtRxStream_Proc::(Rx Stream=%d)\n",pAd->CommonCfg.RxStream));
return TRUE;
}
#ifdef DOT11_N_SUPPORT
#ifdef GREENAP_SUPPORT
INT Set_GreenAP_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
ULONG Value;
Value = simple_strtol(arg, 0, 10);
if (Value == 0)
{
pAd->ApCfg.bGreenAPActive=FALSE;
pAd->ApCfg.bGreenAPEnable = FALSE;
}
else if (Value == 1)
pAd->ApCfg.bGreenAPEnable = TRUE;
else
return FALSE; /*Invalid argument*/
DBGPRINT(RT_DEBUG_TRACE, ("Set_GreenAP_Proc::(bGreenAPEnable=%d)\n",pAd->ApCfg.bGreenAPEnable));
return TRUE;
}
#endif /* GREENAP_SUPPORT */
#endif /* DOT11_N_SUPPORT */
#endif /* CONFIG_AP_SUPPORT */
INT Set_ForceShortGI_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
ULONG Value;
Value = simple_strtol(arg, 0, 10);
if (Value == 0)
pAd->WIFItestbed.bShortGI = FALSE;
else if (Value == 1)
pAd->WIFItestbed.bShortGI = TRUE;
else
return FALSE; /*Invalid argument*/
SetCommonHT(pAd);
DBGPRINT(RT_DEBUG_TRACE, ("Set_ForceShortGI_Proc::(ForceShortGI=%d)\n", pAd->WIFItestbed.bShortGI));
return TRUE;
}
INT Set_ForceGF_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
ULONG Value;
Value = simple_strtol(arg, 0, 10);
if (Value == 0)
pAd->WIFItestbed.bGreenField = FALSE;
else if (Value == 1)
pAd->WIFItestbed.bGreenField = TRUE;
else
return FALSE; /*Invalid argument*/
SetCommonHT(pAd);
DBGPRINT(RT_DEBUG_TRACE, ("Set_ForceGF_Proc::(ForceGF=%d)\n", pAd->WIFItestbed.bGreenField));
return TRUE;
}
INT Set_HtMimoPs_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
ULONG Value;
Value = simple_strtol(arg, 0, 10);
if (Value == 0)
pAd->CommonCfg.bMIMOPSEnable = FALSE;
else if (Value == 1)
pAd->CommonCfg.bMIMOPSEnable = TRUE;
else
return FALSE; /*Invalid argument*/
DBGPRINT(RT_DEBUG_TRACE, ("Set_HtMimoPs_Proc::(HtMimoPs=%d)\n",pAd->CommonCfg.bMIMOPSEnable));
return TRUE;
}
#ifdef DOT11N_DRAFT3
INT Set_HT_BssCoex_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING pParam)
{
UCHAR bBssCoexEnable = simple_strtol(pParam, 0, 10);
pAd->CommonCfg.bBssCoexEnable = ((bBssCoexEnable == 1) ? TRUE: FALSE);
DBGPRINT(RT_DEBUG_TRACE, ("Set bBssCoexEnable=%d!\n", pAd->CommonCfg.bBssCoexEnable));
return TRUE;
}
INT Set_HT_BssCoexApCntThr_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING pParam)
{
pAd->CommonCfg.BssCoexApCntThr = simple_strtol(pParam, 0, 10);
DBGPRINT(RT_DEBUG_TRACE, ("Set BssCoexApCntThr=%d!\n", pAd->CommonCfg.BssCoexApCntThr));
return TRUE;
}
#endif /* DOT11N_DRAFT3 */
#endif /* DOT11_N_SUPPORT */
#ifdef DOT11_VHT_AC
INT Set_VhtBw_Proc(
IN RTMP_ADAPTER *pAd,
IN PSTRING arg)
{
ULONG vht_cw;
UCHAR cent_ch;
vht_cw = simple_strtol(arg, 0, 10);
if (vht_cw == VHT_BW_80)
pAd->CommonCfg.vht_bw = VHT_BW_80;
else
pAd->CommonCfg.vht_bw = VHT_BW_2040;
#ifdef DOT11_VHT_AC
if (!WMODE_CAP_AC(pAd->CommonCfg.PhyMode))
goto direct_done;
SetCommonHT(pAd);
if(pAd->CommonCfg.BBPCurrentBW == BW_80)
cent_ch = pAd->CommonCfg.vht_cent_ch;
else
cent_ch = pAd->CommonCfg.CentralChannel;
AsicSwitchChannel(pAd, cent_ch, FALSE);
AsicLockChannel(pAd, cent_ch);
DBGPRINT(RT_DEBUG_TRACE, ("BW_%s, PrimaryChannel(%d), %s CentralChannel = %d, apply it immediately\n",
(pAd->CommonCfg.BBPCurrentBW == BW_80 ? "80":
(pAd->CommonCfg.BBPCurrentBW == BW_40 ? "40" :
"20")),
pAd->CommonCfg.Channel,
(pAd->CommonCfg.BBPCurrentBW == BW_80 ? "VHT" : "HT"), cent_ch));
direct_done:
#endif /* DOT11_VHT_AC */
DBGPRINT(RT_DEBUG_TRACE, ("Set_VhtBw_Proc::(VHT_BW=%d)\n", pAd->CommonCfg.vht_bw));
return TRUE;
}
INT Set_VhtStbc_Proc(
IN RTMP_ADAPTER *pAd,
IN PSTRING arg)
{
ULONG Value;
Value = simple_strtol(arg, 0, 10);
if (Value == STBC_USE)
pAd->CommonCfg.RegTransmitSetting.field.STBC = STBC_USE;
else if ( Value == STBC_NONE )
pAd->CommonCfg.RegTransmitSetting.field.STBC = STBC_NONE;
else
return FALSE; /*Invalid argument */
SetCommonHT(pAd);
DBGPRINT(RT_DEBUG_TRACE, ("Set_Stbc_Proc::(HtStbc=%d)\n",pAd->CommonCfg.RegTransmitSetting.field.STBC));
return TRUE;
}
#endif /* DOT11_VHT_AC */
INT Set_FixedTxMode_Proc(RTMP_ADAPTER *pAd, PSTRING arg)
{
#ifdef CONFIG_AP_SUPPORT
POS_COOKIE pObj = (POS_COOKIE) pAd->OS_Cookie;
#endif /* CONFIG_AP_SUPPORT */
INT fix_tx_mode = RT_CfgSetFixedTxPhyMode(arg);
#ifdef CONFIG_AP_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
pAd->ApCfg.MBSSID[pObj->ioctl_if].DesiredTransmitSetting.field.FixedTxMode = fix_tx_mode;
#endif /* CONFIG_AP_SUPPORT */
#ifdef CONFIG_STA_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_STA(pAd)
pAd->StaCfg.DesiredTransmitSetting.field.FixedTxMode = fix_tx_mode;
#endif /* CONFIG_STA_SUPPORT */
DBGPRINT(RT_DEBUG_TRACE, ("%s():(FixedTxMode=%d)\n",
__FUNCTION__, fix_tx_mode));
return TRUE;
}
#ifdef CONFIG_APSTA_MIXED_SUPPORT
INT Set_OpMode_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
ULONG Value;
Value = simple_strtol(arg, 0, 10);
#ifdef RTMP_MAC_USB
if (RTMP_TEST_FLAG(pAd, fRTMP_ADAPTER_START_UP))
#endif /* RTMP_MAC_USB */
{
DBGPRINT(RT_DEBUG_ERROR, ("Can not switch operate mode on interface up !! \n"));
return FALSE;
}
if (Value == 0)
pAd->OpMode = OPMODE_STA;
else if (Value == 1)
pAd->OpMode = OPMODE_AP;
else
return FALSE; /*Invalid argument*/
DBGPRINT(RT_DEBUG_TRACE, ("Set_OpMode_Proc::(OpMode=%s)\n", pAd->OpMode == 1 ? "AP Mode" : "STA Mode"));
return TRUE;
}
#endif /* CONFIG_APSTA_MIXED_SUPPORT */
#ifdef DBG_CTRL_SUPPORT
#ifdef INCLUDE_DEBUG_QUEUE
/* ---------------------- DEBUG QUEUE ------------------------*/
#define DBQ_LENGTH 512
#define DBQ_DATA_LENGTH 8
/* Define to include TX and RX HT Control field in log */
/* #define DBQ_INCLUDE_HTC */
typedef
struct {
UCHAR type; /* type of data*/
ULONG timestamp; /* sec/usec timestamp from gettimeofday*/
UCHAR data[DBQ_DATA_LENGTH]; /* data*/
} DBQUEUE_ENTRY;
/* Type field definitions */
#define DBQ_TYPE_EMPTY 0
#define DBQ_TYPE_TXWI 0x70 /* TXWI*/
#define DBQ_TYPE_TXHDR 0x72 /* TX Header*/
#define DBQ_TYPE_TXFIFO 0x73 /* TX Stat FIFO*/
#define DBQ_TYPE_RXWI 0x78 /* RXWI uses 0x78 to 0x7A for 5 longs*/
#define DBQ_TYPE_RXHDR 0x7B /* RX Header*/
#define DBQ_TYPE_TXQHTC 0x7c /* RX Qos+HT Control field*/
#define DBQ_TYPE_RXQHTC 0x7d /* RX Qos+HT Control field */
#define DBQ_TYPE_RALOG 0x7e /* RA Log */
#define DBQ_INIT_SIG 0x4442484E /* 'DBIN' - dbqInit initialized flag*/
#define DBQ_ENA_SIG 0x4442454E /* 'DBEN' - dbqEnable enabled flag*/
static DBQUEUE_ENTRY dbQueue[DBQ_LENGTH];
static ULONG dbqTail=0;
static ULONG dbqEnable=0;
static ULONG dbqInit=0;
/* dbQueueInit - initialize Debug Queue variables and clear the queue*/
void dbQueueInit(void)
{
int i;
for (i=0; i<DBQ_LENGTH; i++)
dbQueue[i].type = DBQ_TYPE_EMPTY;
dbqTail = 0;
dbqInit = DBQ_INIT_SIG;
}
/* dbQueueEnqueue - enqueue data*/
void dbQueueEnqueue(UCHAR type, UCHAR *data)
{
DBQUEUE_ENTRY *oldTail;
struct timeval tval;
if (dbqEnable!=DBQ_ENA_SIG || data==NULL)
return;
if (dbqInit!=DBQ_INIT_SIG || dbqTail>=DBQ_LENGTH)
dbQueueInit();
oldTail = &dbQueue[dbqTail];
/* Advance tail and mark as empty*/
if (dbqTail >= DBQ_LENGTH-1)
dbqTail = 0;
else
dbqTail++;
dbQueue[dbqTail].type = DBQ_TYPE_EMPTY;
/* Enqueue data*/
oldTail->type = type;
do_gettimeofday(&tval);
oldTail->timestamp = tval.tv_sec*1000000L + tval.tv_usec;
memcpy(oldTail->data, data, DBQ_DATA_LENGTH);
}
void dbQueueEnqueueTxFrame(UCHAR *pTxWI, UCHAR *pHeader_802_11)
{
dbQueueEnqueue(DBQ_TYPE_TXWI, pTxWI);
/* 802.11 Header */
if (pHeader_802_11 != NULL) {
dbQueueEnqueue(DBQ_TYPE_TXHDR, pHeader_802_11);
#ifdef DBQ_INCLUDE_HTC
/* Qos+HT Control field */
if ((pHeader_802_11[0] & 0x08) && (pHeader_802_11[1] & 0x80))
dbQueueEnqueue(DBQ_TYPE_TXQHTC, pHeader_802_11+24);
#endif /* DBQ_INCLUDE_HTC */
}
}
void dbQueueEnqueueRxFrame(UCHAR *pRxWI, UCHAR *pHeader_802_11, ULONG flags)
{
/* Ignore Beacons if disabled */
if ((flags & DBF_DBQ_NO_BCN) && (pHeader_802_11[0] & 0xfc)==0x80)
return;
/* RXWI */
dbQueueEnqueue(DBQ_TYPE_RXWI, pRxWI);
if (flags & DBF_DBQ_RXWI_FULL) {
dbQueueEnqueue(DBQ_TYPE_RXWI+1, pRxWI+8);
dbQueueEnqueue(DBQ_TYPE_RXWI+2, pRxWI+16);
}
/* 802.11 Header */
dbQueueEnqueue(DBQ_TYPE_RXHDR, (UCHAR *)pHeader_802_11);
#ifdef DBQ_INCLUDE_HTC
/* Qos+HT Control field */
if ((pHeader_802_11[0] & 0x08) &&
(pHeader_802_11[1] & 0x80))
dbQueueEnqueue(DBQ_TYPE_RXQHTC, pHeader_802_11+24);
#endif /* DBQ_INCLUDE_HTC */
}
/* dbQueueDisplayPhy - Display PHY rate */
static void dbQueueDisplayPHY(USHORT phyRate)
{
static CHAR *mode[4] = {" C", "oM","mM", "gM"};
DBGPRINT(RT_DEBUG_OFF, ("%2s%02d %c%c%c%c",
//(phyRate>>8) & 0xFF, phyRate & 0xFF,
mode[(phyRate>>14) & 0x3], // Mode: c, o, m, g
phyRate & 0x7F, // MCS
(phyRate & 0x0100)? 'S': 'L', // Guard Int: S or L
(phyRate & 0x0080)? '4': '2', // BW: 4 or 2
(phyRate & 0x0200)? 'S': 's', // STBC: S or s
(phyRate & 0x2000)? 'I': ((phyRate & 0x800)? 'E': '_') // Beamforming: E or I or _
) );
}
/* dbQueueDump - dump contents of debug queue*/
static void dbQueueDump(
IN PRTMP_ADAPTER pAd,
BOOLEAN decode)
{
DBQUEUE_ENTRY *oldTail;
int i, origMCS, succMCS;
ULONG lastTimestamp=0;
BOOLEAN showTimestamp;
USHORT phyRate;
if (dbqInit!=DBQ_INIT_SIG || dbqTail>=DBQ_LENGTH)
return;
oldTail = &dbQueue[dbqTail];
for (i=0; i<DBQ_LENGTH; i++) {
if (++oldTail >= &dbQueue[DBQ_LENGTH])
oldTail = dbQueue;
/* Skip empty entries*/
if (oldTail->type == DBQ_TYPE_EMPTY)
continue;
showTimestamp = FALSE;
switch (oldTail->type) {
case 0x70: /* TXWI - 2 longs, MSB to LSB */
case 0x78: /* RXWI - 2 longs, MSB to LSB */
showTimestamp = TRUE;
if (decode && oldTail->type==0x70) {
DBGPRINT(RT_DEBUG_OFF, ("\nTxWI ") );
dbQueueDisplayPHY(oldTail->data[3]*256 + oldTail->data[2]);
DBGPRINT(RT_DEBUG_OFF, ("%c s=%03X %02X %s-",
(oldTail->data[0] & 0x10)? 'A': '_', // AMPDU
(oldTail->data[7]*256 + oldTail->data[6]) & 0xFFF, // Size
oldTail->data[5], // WCID
(oldTail->data[4] & 0x01)? "AK": "NA" )); // ACK/NACK
}
else if (decode && oldTail->type==0x78) {
DBGPRINT(RT_DEBUG_OFF, ("\nRxWI ") );
dbQueueDisplayPHY(oldTail->data[7]*256 + oldTail->data[6]);
DBGPRINT(RT_DEBUG_OFF, (" s=%03X %02X %02X%01X-",
(oldTail->data[3]*256 + oldTail->data[2]) & 0xFFF, // Size
oldTail->data[0], // WCID
oldTail->data[5], oldTail->data[4]>>4 )); // Seq Number
}
else
DBGPRINT(RT_DEBUG_OFF, ("\n%cxWI %02X%02X %02X%02X-%02X%02X %02X%02X----",
oldTail->type==0x70? 'T': 'R',
oldTail->data[3], oldTail->data[2], oldTail->data[1], oldTail->data[0],
oldTail->data[7], oldTail->data[6], oldTail->data[5], oldTail->data[4]) );
break;
case 0x79: /* RXWI - next 2 longs, MSB to LSB */
if (decode) {
DBGPRINT(RT_DEBUG_OFF, ("Rx2 %2d %2d %2d S:%d %d %d ",
ConvertToRssi(pAd, (CHAR)oldTail->data[0], RSSI_0),
ConvertToRssi(pAd, (CHAR)oldTail->data[1], RSSI_1),
ConvertToRssi(pAd, (CHAR)oldTail->data[2], RSSI_2),
(oldTail->data[4]*3 + 8)/16,
(oldTail->data[5]*3 + 8)/16,
(oldTail->data[6]*3 + 8)/16) );
}
else
DBGPRINT(RT_DEBUG_OFF, ("Rx2 %02X%02X %02X%02X-%02X%02X %02X%02X ",
oldTail->data[3], oldTail->data[2], oldTail->data[1], oldTail->data[0],
oldTail->data[7], oldTail->data[6], oldTail->data[5], oldTail->data[4]) );
break;
case 0x7c: /* TX HTC+QoS, 6 bytes, MSB to LSB */
case 0x7d: /* RX HTC+QoS, 6 bytes, MSB to LSB */
DBGPRINT(RT_DEBUG_OFF, ("%cxHTC H:%02X%02X%02X%02X Q:%02X%02X ",
oldTail->type==0x7c? 'T': 'R',
oldTail->data[5], oldTail->data[4], oldTail->data[3], oldTail->data[2],
oldTail->data[1], oldTail->data[0]) );
break;
case 0x72: /* Tx 802.11 header, MSB to LSB, translate type/subtype*/
case 0x7b: /* Rx*/
{
UCHAR tCode;
struct _typeTableEntry {
UCHAR code; /* Type/subtype*/
CHAR str[4];
} *pTab;
static struct _typeTableEntry typeTable[] = {
{0x00, "mARq"}, {0x01, "mARp"}, {0x02, "mRRq"}, {0x03, "mRRp"},
{0x04, "mPRq"}, {0x05, "mPRp"}, {0x08, "mBcn"}, {0x09, "mATI"},
{0x0a, "mDis"}, {0x0b, "mAut"}, {0x0c, "mDAu"}, {0x0d, "mAct"},
{0x0e, "mANA"},
{0x17, "cCWr"}, {0x18, "cBAR"}, {0x19, "cBAc"}, {0x1a, "cPSP"},
{0x1b, "cRTS"}, {0x1c, "cCTS"}, {0x1d, "cACK"}, {0x1e, "cCFE"},
{0x1f, "cCEA"},
{0x20, "dDat"}, {0x21, "dDCA"}, {0x22, "dDCP"}, {0x23, "dDAP"},
{0x24, "dNul"}, {0x25, "dCFA"}, {0x26, "dCFP"}, {0x27, "dCAP"},
{0x28, "dQDa"}, {0x29, "dQCA"}, {0x2a, "dQCP"}, {0x2b, "dQAP"},
{0x2c, "dQNu"}, {0x2e, "dQNP"}, {0x2f, "dQNA"},
{0xFF, "RESV"}};
tCode = ((oldTail->data[0]<<2) & 0x30) | ((oldTail->data[0]>>4) & 0xF);
for (pTab=typeTable; pTab->code!=0xFF; pTab++) {
if (pTab->code == tCode)
break;
}
DBGPRINT(RT_DEBUG_OFF, ("%cxH %c%c%c%c [%02X%02X %02X%02X] \n",
oldTail->type==0x72? 'T': 'R',
pTab->str[0], pTab->str[1], pTab->str[2], pTab->str[3],
oldTail->data[3], oldTail->data[2], oldTail->data[1], oldTail->data[0]) );
}
break;
case 0x73: /* TX STAT FIFO*/
showTimestamp = TRUE;
/* origMCS is limited to 4 bits. Check for case of MCS16 to 23*/
origMCS = (oldTail->data[0]>>1) & 0xF;
succMCS = (oldTail->data[2] & 0x7F);
if (succMCS>origMCS && origMCS<8)
origMCS += 16;
phyRate = (oldTail->data[3]<<8) + oldTail->data[2];
DBGPRINT(RT_DEBUG_OFF, ("TxFI %02X%02X%02X%02X=%c%c%c%c%c M%02d/%02d%c%c",
oldTail->data[3], oldTail->data[2],
oldTail->data[1], oldTail->data[0],
(phyRate & 0x0100)? 'S': 'L', /* Guard Int: S or L */
(phyRate & 0x0080)? '4': '2', /* BW: 4 or 2 */
(phyRate & 0x0200)? 'S': 's', /* STBC: S or s */
(phyRate & 0x2000)? 'I': ((phyRate & 0x0800)? 'E': '_'), /* Beamforming: E or I or _ */
(oldTail->data[0] & 0x40)? 'A': '_', /* Aggregated: A or _ */
succMCS, origMCS, /* MCS: <Final>/<orig> */
succMCS==origMCS? ' ': '*', /* Retry: '*' if MCS doesn't match */
(oldTail->data[0] & 0x20)? ' ': 'F') ); /* Success/Fail _ or F */
break;
case 0x7E: /* RA Log info */
{
struct {USHORT phy; USHORT per; USHORT tp; USHORT bfPer;} *p = (void*)(oldTail->data);
DBGPRINT(RT_DEBUG_OFF, ("RALog %02X%02X %d %d %d ",
(p->phy>>8) & 0xFF, p->phy & 0xFF, p->per, p->tp, p->bfPer) );
}
break;
default:
DBGPRINT(RT_DEBUG_OFF, ("%02X %02X%02X %02X%02X %02X%02X %02X%02X ", oldTail->type,
oldTail->data[0], oldTail->data[1], oldTail->data[2], oldTail->data[3],
oldTail->data[4], oldTail->data[5], oldTail->data[6], oldTail->data[7]) );
break;
}
if (showTimestamp)
{
ULONG t = oldTail->timestamp;
ULONG dt = oldTail->timestamp-lastTimestamp;
DBGPRINT(RT_DEBUG_OFF, ("%lu.%06lu ", t/1000000L, t % 1000000L) );
if (dt>999999L)
DBGPRINT(RT_DEBUG_OFF, ("+%lu.%06lu s\n", dt/1000000L, dt % 1000000L) );
else
DBGPRINT(RT_DEBUG_OFF, ("+%lu us\n", dt) );
lastTimestamp = oldTail->timestamp;
}
}
}
/*
Set_DebugQueue_Proc - Control DBQueue
iwpriv ra0 set DBQueue=dd.
dd: 0=>disable, 1=>enable, 2=>dump, 3=>clear, 4=>dump & decode
*/
INT Set_DebugQueue_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
ULONG argValue = simple_strtol(arg, 0, 10);
switch (argValue) {
case 0:
dbqEnable = 0;
break;
case 1:
dbqEnable = DBQ_ENA_SIG;
break;
case 2:
dbQueueDump(pAd, FALSE);
break;
case 3:
dbQueueInit();
break;
case 4:
dbQueueDump(pAd, TRUE);
break;
default:
return FALSE;
}
return TRUE;
}
#endif /* INCLUDE_DEBUG_QUEUE */
#endif /* DBG_CTRL_SUPPORT */
#ifdef STREAM_MODE_SUPPORT
/*
========================================================================
Routine Description:
Set the enable/disable the stream mode
Arguments:
1: enable for 1SS
2: enable for 2SS
3: enable for 1SS and 2SS
0: disable
Notes:
Currently only support 1SS
========================================================================
*/
INT Set_StreamMode_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
UINT32 streamWord, reg, regAddr;
if (pAd->chipCap.FlgHwStreamMode == FALSE)
{
DBGPRINT(RT_DEBUG_ERROR, ("chip not supported feature\n"));
return FALSE;
}
pAd->CommonCfg.StreamMode = (simple_strtol(arg, 0, 10) & 0x3);
DBGPRINT(RT_DEBUG_TRACE, ("%s():StreamMode=%d\n", __FUNCTION__, pAd->CommonCfg.StreamMode));
streamWord = StreamModeRegVal(pAd);
for (regAddr = TX_CHAIN_ADDR0_H; regAddr <= TX_CHAIN_ADDR3_H; regAddr += 8)
{
RTMP_IO_READ32(pAd, regAddr, &reg);
reg &= (~0x000F0000);
RTMP_IO_WRITE32(pAd, regAddr, streamWord | reg);
}
return TRUE;
}
INT Set_StreamModeMac_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
return FALSE;
}
INT Set_StreamModeMCS_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
pAd->CommonCfg.StreamModeMCS = simple_strtol(arg, 0, 16);
DBGPRINT(RT_DEBUG_TRACE, ("%s():StreamModeMCS=%02X\n",
__FUNCTION__, pAd->CommonCfg.StreamModeMCS));
return TRUE;
}
#endif /* STREAM_MODE_SUPPORT */
#ifdef PRE_ANT_SWITCH
/*
Set_PreAntSwitch_Proc - enable/disable Preamble Antenna Switch
usage: iwpriv ra0 set PreAntSwitch=[0 | 1]
*/
INT Set_PreAntSwitch_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
pAd->CommonCfg.PreAntSwitch = simple_strtol(arg, 0, 10)!=0;
DBGPRINT(RT_DEBUG_TRACE, ("%s():(PreAntSwitch=%d)\n",
__FUNCTION__, pAd->CommonCfg.PreAntSwitch));
return TRUE;
}
/*
Set_PreAntSwitchRSSI_Proc - set Preamble Antenna Switch RSSI threshold
usage: iwpriv ra0 set PreAntSwitchRSSI=<RSSI threshold in dBm>
*/
INT Set_PreAntSwitchRSSI_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
pAd->CommonCfg.PreAntSwitchRSSI = simple_strtol(arg, 0, 10);
DBGPRINT(RT_DEBUG_TRACE, ("%s():(PreAntSwitchRSSI=%d)\n",
__FUNCTION__, pAd->CommonCfg.PreAntSwitchRSSI));
return TRUE;
}
/*
Set_PreAntSwitchTimeout_Proc - set Preamble Antenna Switch Timeout threshold
usage: iwpriv ra0 set PreAntSwitchTimeout=<timeout in seconds, 0=>disabled>
*/
INT Set_PreAntSwitchTimeout_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
pAd->CommonCfg.PreAntSwitchTimeout = simple_strtol(arg, 0, 10);
DBGPRINT(RT_DEBUG_TRACE, ("%s():(PreAntSwitchTimeout=%d)\n",
__FUNCTION__, pAd->CommonCfg.PreAntSwitchTimeout));
return TRUE;
}
#endif /* PRE_ANT_SWITCH */
#ifdef CFO_TRACK
/*
Set_CFOTrack_Proc - enable/disable CFOTrack
usage: iwpriv ra0 set CFOTrack=[0..8]
*/
INT Set_CFOTrack_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
pAd->CommonCfg.CFOTrack = simple_strtol(arg, 0, 10);
DBGPRINT(RT_DEBUG_TRACE, ("%s():(CFOTrack=%d)\n",
__FUNCTION__, pAd->CommonCfg.CFOTrack));
return TRUE;
}
#endif /* CFO_TRACK */
#ifdef DBG_CTRL_SUPPORT
INT Set_DebugFlags_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
pAd->CommonCfg.DebugFlags = simple_strtol(arg, 0, 16);
DBGPRINT(RT_DEBUG_TRACE, ("Set_DebugFlags_Proc::(DebugFlags=%02lX)\n", pAd->CommonCfg.DebugFlags));
return TRUE;
}
#endif /* DBG_CTRL_SUPPORT */
INT Set_LongRetryLimit_Proc(
IN PRTMP_ADAPTER pAdapter,
IN PSTRING arg)
{
TX_RTY_CFG_STRUC tx_rty_cfg;
UCHAR LongRetryLimit = (UCHAR)simple_strtol(arg, 0, 10);
RTMP_IO_READ32(pAdapter, TX_RTY_CFG, &tx_rty_cfg.word);
tx_rty_cfg.field.LongRtyLimit = LongRetryLimit;
RTMP_IO_WRITE32(pAdapter, TX_RTY_CFG, tx_rty_cfg.word);
DBGPRINT(RT_DEBUG_TRACE, ("IF Set_LongRetryLimit_Proc::(tx_rty_cfg=0x%x)\n", tx_rty_cfg.word));
return TRUE;
}
INT Set_ShortRetryLimit_Proc(
IN PRTMP_ADAPTER pAdapter,
IN PSTRING arg)
{
TX_RTY_CFG_STRUC tx_rty_cfg;
UCHAR ShortRetryLimit = (UCHAR)simple_strtol(arg, 0, 10);
RTMP_IO_READ32(pAdapter, TX_RTY_CFG, &tx_rty_cfg.word);
tx_rty_cfg.field.ShortRtyLimit = ShortRetryLimit;
RTMP_IO_WRITE32(pAdapter, TX_RTY_CFG, tx_rty_cfg.word);
DBGPRINT(RT_DEBUG_TRACE, ("IF Set_ShortRetryLimit_Proc::(tx_rty_cfg=0x%x)\n", tx_rty_cfg.word));
return TRUE;
}
INT Set_AutoFallBack_Proc(
IN PRTMP_ADAPTER pAdapter,
IN PSTRING arg)
{
return RT_CfgSetAutoFallBack(pAdapter, arg);
}
PSTRING RTMPGetRalinkAuthModeStr(
IN NDIS_802_11_AUTHENTICATION_MODE authMode)
{
switch(authMode)
{
case Ndis802_11AuthModeOpen:
return "OPEN";
case Ndis802_11AuthModeWPAPSK:
return "WPAPSK";
case Ndis802_11AuthModeShared:
return "SHARED";
case Ndis802_11AuthModeAutoSwitch:
return "WEPAUTO";
case Ndis802_11AuthModeWPA:
return "WPA";
case Ndis802_11AuthModeWPA2:
return "WPA2";
case Ndis802_11AuthModeWPA2PSK:
return "WPA2PSK";
case Ndis802_11AuthModeWPA1PSKWPA2PSK:
return "WPAPSKWPA2PSK";
case Ndis802_11AuthModeWPA1WPA2:
return "WPA1WPA2";
case Ndis802_11AuthModeWPANone:
return "WPANONE";
default:
return "UNKNOW";
}
}
PSTRING RTMPGetRalinkEncryModeStr(
IN USHORT encryMode)
{
switch(encryMode)
{
case Ndis802_11WEPDisabled:
return "NONE";
case Ndis802_11WEPEnabled:
return "WEP";
case Ndis802_11Encryption2Enabled:
return "TKIP";
case Ndis802_11Encryption3Enabled:
return "AES";
case Ndis802_11Encryption4Enabled:
return "TKIPAES";
default:
return "UNKNOW";
}
}
INT Show_SSID_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
UCHAR ssid_str[33];
NdisZeroMemory(&ssid_str[0], 33);
#ifdef CONFIG_AP_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
{
POS_COOKIE pObj = (POS_COOKIE) pAd->OS_Cookie;
NdisMoveMemory(&ssid_str[0],
pAd->ApCfg.MBSSID[pObj->ioctl_if].Ssid,
pAd->ApCfg.MBSSID[pObj->ioctl_if].SsidLen);
}
#endif /* CONFIG_AP_SUPPORT */
#ifdef CONFIG_STA_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_STA(pAd)
{
NdisMoveMemory(&ssid_str[0],
pAd->CommonCfg.Ssid,
pAd->CommonCfg.SsidLen);
}
#endif /* CONFIG_STA_SUPPORT */
snprintf(pBuf, BufLen, "\t%s", ssid_str);
return 0;
}
INT Show_WirelessMode_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
switch(pAd->CommonCfg.PhyMode)
{
case (WMODE_B | WMODE_G):
snprintf(pBuf, BufLen, "\t11B/G");
break;
case (WMODE_B):
snprintf(pBuf, BufLen, "\t11B");
break;
case (WMODE_A):
snprintf(pBuf, BufLen, "\t11A");
break;
case (WMODE_A | WMODE_B | WMODE_G):
snprintf(pBuf, BufLen, "\t11A/B/G");
break;
case (WMODE_G):
snprintf(pBuf, BufLen, "\t11G");
break;
#ifdef DOT11_N_SUPPORT
case (WMODE_A | WMODE_B | WMODE_G | WMODE_GN | WMODE_AN):
snprintf(pBuf, BufLen, "\t11A/B/G/N");
break;
case (WMODE_GN):
snprintf(pBuf, BufLen, "\t11N only with 2.4G");
break;
case (WMODE_G | WMODE_GN):
snprintf(pBuf, BufLen, "\t11G/N");
break;
case (WMODE_A | WMODE_AN):
snprintf(pBuf, BufLen, "\t11A/N");
break;
case (WMODE_B | WMODE_G | WMODE_GN):
snprintf(pBuf, BufLen, "\t11B/G/N");
break;
case (WMODE_A | WMODE_G | WMODE_GN | WMODE_AN):
snprintf(pBuf, BufLen, "\t11A/G/N");
break;
case (WMODE_AN):
snprintf(pBuf, BufLen, "\t11N only with 5G");
break;
#endif /* DOT11_N_SUPPORT */
default:
snprintf(pBuf, BufLen, "\tUnknow Value(%d)", pAd->CommonCfg.PhyMode);
break;
}
return 0;
}
INT Show_TxBurst_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
snprintf(pBuf, BufLen, "\t%s", pAd->CommonCfg.bEnableTxBurst ? "TRUE":"FALSE");
return 0;
}
INT Show_TxPreamble_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
switch(pAd->CommonCfg.TxPreamble)
{
case Rt802_11PreambleShort:
snprintf(pBuf, BufLen, "\tShort");
break;
case Rt802_11PreambleLong:
snprintf(pBuf, BufLen, "\tLong");
break;
case Rt802_11PreambleAuto:
snprintf(pBuf, BufLen, "\tAuto");
break;
default:
snprintf(pBuf, BufLen, "\tUnknown Value(%lu)", pAd->CommonCfg.TxPreamble);
break;
}
return 0;
}
INT Show_TxPower_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
snprintf(pBuf, BufLen, "\t%lu", pAd->CommonCfg.TxPowerPercentage);
return 0;
}
INT Show_Channel_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
snprintf(pBuf, BufLen, "\t%d", pAd->CommonCfg.Channel);
return 0;
}
INT Show_BGProtection_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
switch(pAd->CommonCfg.UseBGProtection)
{
case 1: /*Always On*/
snprintf(pBuf, BufLen, "\tON");
break;
case 2: /*Always OFF*/
snprintf(pBuf, BufLen, "\tOFF");
break;
case 0: /*AUTO*/
snprintf(pBuf, BufLen, "\tAuto");
break;
default:
snprintf(pBuf, BufLen, "\tUnknow Value(%lu)", pAd->CommonCfg.UseBGProtection);
break;
}
return 0;
}
INT Show_RTSThreshold_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
snprintf(pBuf, BufLen, "\t%u", pAd->CommonCfg.RtsThreshold);
return 0;
}
INT Show_FragThreshold_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
snprintf(pBuf, BufLen, "\t%u", pAd->CommonCfg.FragmentThreshold);
return 0;
}
#ifdef DOT11_N_SUPPORT
INT Show_HtBw_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
if (pAd->CommonCfg.RegTransmitSetting.field.BW == BW_40)
{
snprintf(pBuf, BufLen, "\t40 MHz");
}
else
{
snprintf(pBuf, BufLen, "\t20 MHz");
}
return 0;
}
INT Show_HtMcs_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
#ifdef CONFIG_AP_SUPPORT
POS_COOKIE pObj = (POS_COOKIE) pAd->OS_Cookie;
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
snprintf(pBuf, BufLen, "\t%u", pAd->ApCfg.MBSSID[pObj->ioctl_if].DesiredTransmitSetting.field.MCS);
#endif /* CONFIG_AP_SUPPORT */
#ifdef CONFIG_STA_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_STA(pAd)
snprintf(pBuf, BufLen, "\t%u", pAd->StaCfg.DesiredTransmitSetting.field.MCS);
#endif /* CONFIG_STA_SUPPORT */
return 0;
}
INT Show_HtGi_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
switch(pAd->CommonCfg.RegTransmitSetting.field.ShortGI)
{
case GI_400:
snprintf(pBuf, BufLen, "\tGI_400");
break;
case GI_800:
snprintf(pBuf, BufLen, "\tGI_800");
break;
default:
snprintf(pBuf, BufLen, "\tUnknow Value(%u)", pAd->CommonCfg.RegTransmitSetting.field.ShortGI);
break;
}
return 0;
}
INT Show_HtOpMode_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
switch(pAd->CommonCfg.RegTransmitSetting.field.HTMODE)
{
case HTMODE_GF:
snprintf(pBuf, BufLen, "\tGF");
break;
case HTMODE_MM:
snprintf(pBuf, BufLen, "\tMM");
break;
default:
snprintf(pBuf, BufLen, "\tUnknow Value(%u)", pAd->CommonCfg.RegTransmitSetting.field.HTMODE);
break;
}
return 0;
}
INT Show_HtExtcha_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
switch(pAd->CommonCfg.RegTransmitSetting.field.EXTCHA)
{
case EXTCHA_BELOW:
snprintf(pBuf, BufLen, "\tBelow");
break;
case EXTCHA_ABOVE:
snprintf(pBuf, BufLen, "\tAbove");
break;
default:
snprintf(pBuf, BufLen, "\tUnknow Value(%u)", pAd->CommonCfg.RegTransmitSetting.field.EXTCHA);
break;
}
return 0;
}
INT Show_HtMpduDensity_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
snprintf(pBuf, BufLen, "\t%u", pAd->CommonCfg.BACapability.field.MpduDensity);
return 0;
}
INT Show_HtBaWinSize_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
snprintf(pBuf, BufLen, "\t%u", pAd->CommonCfg.BACapability.field.RxBAWinLimit);
return 0;
}
INT Show_HtRdg_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
snprintf(pBuf, BufLen, "\t%s", pAd->CommonCfg.bRdg ? "TRUE":"FALSE");
return 0;
}
INT Show_HtAmsdu_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
snprintf(pBuf, BufLen, "\t%s", pAd->CommonCfg.BACapability.field.AmsduEnable ? "TRUE":"FALSE");
return 0;
}
INT Show_HtAutoBa_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
snprintf(pBuf, BufLen, "\t%s", pAd->CommonCfg.BACapability.field.AutoBA ? "TRUE":"FALSE");
return 0;
}
#endif /* DOT11_N_SUPPORT */
INT Show_CountryRegion_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
snprintf(pBuf, BufLen, "\t%d", pAd->CommonCfg.CountryRegion);
return 0;
}
INT Show_CountryRegionABand_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
snprintf(pBuf, BufLen, "\t%d", pAd->CommonCfg.CountryRegionForABand);
return 0;
}
INT Show_CountryCode_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
snprintf(pBuf, BufLen, "\t%s", pAd->CommonCfg.CountryCode);
return 0;
}
#ifdef AGGREGATION_SUPPORT
INT Show_PktAggregate_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
snprintf(pBuf, BufLen, "\t%s", pAd->CommonCfg.bAggregationCapable ? "TRUE":"FALSE");
return 0;
}
#endif /* AGGREGATION_SUPPORT */
#ifdef WMM_SUPPORT
INT Show_WmmCapable_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
#ifdef CONFIG_AP_SUPPORT
POS_COOKIE pObj = (POS_COOKIE) pAd->OS_Cookie;
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
snprintf(pBuf, BufLen, "\t%s", pAd->ApCfg.MBSSID[pObj->ioctl_if].bWmmCapable ? "TRUE":"FALSE");
#endif /* CONFIG_AP_SUPPORT */
#ifdef CONFIG_STA_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_STA(pAd)
snprintf(pBuf, BufLen, "\t%s", pAd->CommonCfg.bWmmCapable ? "TRUE":"FALSE");
#endif /* CONFIG_STA_SUPPORT */
return 0;
}
#endif /* WMM_SUPPORT */
INT Show_IEEE80211H_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
snprintf(pBuf, BufLen, "\t%s", pAd->CommonCfg.bIEEE80211H ? "TRUE":"FALSE");
return 0;
}
#ifdef CONFIG_STA_SUPPORT
INT Show_NetworkType_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
switch(pAd->StaCfg.BssType)
{
case BSS_ADHOC:
snprintf(pBuf, BufLen, "\tAdhoc");
break;
case BSS_INFRA:
snprintf(pBuf, BufLen, "\tInfra");
break;
case BSS_ANY:
snprintf(pBuf, BufLen, "\tAny");
break;
case BSS_MONITOR:
snprintf(pBuf, BufLen, "\tMonitor");
break;
default:
sprintf(pBuf, "\tUnknow Value(%d)", pAd->StaCfg.BssType);
break;
}
return 0;
}
#ifdef WSC_STA_SUPPORT
INT Show_WpsPbcBand_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
switch(pAd->StaCfg.WscControl.WpsApBand)
{
case PREFERRED_WPS_AP_PHY_TYPE_2DOT4_G_FIRST:
snprintf(pBuf, BufLen, "\t2.4G");
break;
case PREFERRED_WPS_AP_PHY_TYPE_5_G_FIRST:
snprintf(pBuf, BufLen, "\t5G");
break;
case PREFERRED_WPS_AP_PHY_TYPE_AUTO_SELECTION:
snprintf(pBuf, BufLen, "\tAuto");
break;
default:
snprintf(pBuf, BufLen, "\tUnknow Value(%d)", pAd->StaCfg.WscControl.WpsApBand);
break;
}
return 0;
}
#endif /* WSC_STA_SUPPORT */
INT Show_WPAPSK_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
if ((pAd->StaCfg.WpaPassPhraseLen >= 8) &&
(pAd->StaCfg.WpaPassPhraseLen < 64))
snprintf(pBuf, BufLen, "\tWPAPSK = %s", pAd->StaCfg.WpaPassPhrase);
else
{
INT idx;
snprintf(pBuf, BufLen, "\tWPAPSK = ");
for (idx = 0; idx < 32; idx++)
snprintf(pBuf+strlen(pBuf), BufLen-strlen(pBuf), "%02X", pAd->StaCfg.WpaPassPhrase[idx]);
}
return 0;
}
INT Show_AutoReconnect_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
snprintf(pBuf, BufLen, "\tAutoReconnect = %d", pAd->StaCfg.bAutoReconnect);
return 0;
}
#endif /* CONFIG_STA_SUPPORT */
INT Show_AuthMode_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
NDIS_802_11_AUTHENTICATION_MODE AuthMode = Ndis802_11AuthModeOpen;
#ifdef CONFIG_AP_SUPPORT
POS_COOKIE pObj = (POS_COOKIE) pAd->OS_Cookie;
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
AuthMode = pAd->ApCfg.MBSSID[pObj->ioctl_if].AuthMode;
#endif /* CONFIG_AP_SUPPORT */
#ifdef CONFIG_STA_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_STA(pAd)
AuthMode = pAd->StaCfg.AuthMode;
#endif /* CONFIG_STA_SUPPORT */
if ((AuthMode >= Ndis802_11AuthModeOpen) &&
(AuthMode <= Ndis802_11AuthModeWPA1PSKWPA2PSK))
snprintf(pBuf, BufLen, "\t%s", RTMPGetRalinkAuthModeStr(AuthMode));
#ifdef WAPI_SUPPORT
else if (AuthMode == Ndis802_11AuthModeWAICERT)
snprintf(pBuf, BufLen, "\t%s", "WAI_CERT");
else if (AuthMode == Ndis802_11AuthModeWAIPSK)
snprintf(pBuf, BufLen, "\t%s", "WAI_PSK");
#endif /* WAPI_SUPPORT */
else
snprintf(pBuf, BufLen, "\tUnknow Value(%d)", AuthMode);
return 0;
}
INT Show_EncrypType_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
NDIS_802_11_WEP_STATUS WepStatus = Ndis802_11WEPDisabled;
#ifdef CONFIG_AP_SUPPORT
POS_COOKIE pObj = (POS_COOKIE) pAd->OS_Cookie;
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
WepStatus = pAd->ApCfg.MBSSID[pObj->ioctl_if].WepStatus;
#endif /* CONFIG_AP_SUPPORT */
#ifdef CONFIG_STA_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_STA(pAd)
WepStatus = pAd->StaCfg.WepStatus;
#endif /* CONFIG_STA_SUPPORT */
if ((WepStatus >= Ndis802_11WEPEnabled) &&
(WepStatus <= Ndis802_11Encryption4KeyAbsent))
snprintf(pBuf, BufLen, "\t%s", RTMPGetRalinkEncryModeStr(WepStatus));
#ifdef WAPI_SUPPORT
else if (WepStatus == Ndis802_11EncryptionSMS4Enabled)
snprintf(pBuf, BufLen, "\t%s", "WPI_SMS4");
#endif /* WAPI_SUPPORT */
else
snprintf(pBuf, BufLen, "\tUnknow Value(%d)", WepStatus);
return 0;
}
INT Show_DefaultKeyID_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
UCHAR DefaultKeyId = 0;
#ifdef CONFIG_AP_SUPPORT
POS_COOKIE pObj = (POS_COOKIE) pAd->OS_Cookie;
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
DefaultKeyId = pAd->ApCfg.MBSSID[pObj->ioctl_if].DefaultKeyId;
#endif /* CONFIG_AP_SUPPORT */
#ifdef CONFIG_STA_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_STA(pAd)
DefaultKeyId = pAd->StaCfg.DefaultKeyId;
#endif /* CONFIG_STA_SUPPORT */
snprintf(pBuf, BufLen, "\t%d", DefaultKeyId);
return 0;
}
INT Show_WepKey_Proc(
IN PRTMP_ADAPTER pAd,
IN INT KeyIdx,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
UCHAR Key[16] = {0}, KeyLength = 0;
INT index = BSS0;
#ifdef CONFIG_AP_SUPPORT
POS_COOKIE pObj = (POS_COOKIE) pAd->OS_Cookie;
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
index = pObj->ioctl_if;
#endif /* CONFIG_AP_SUPPORT */
KeyLength = pAd->SharedKey[index][KeyIdx].KeyLen;
NdisMoveMemory(Key, pAd->SharedKey[index][KeyIdx].Key, KeyLength);
/*check key string is ASCII or not*/
if (RTMPCheckStrPrintAble((PCHAR)Key, KeyLength))
sprintf(pBuf, "\t%s", Key);
else
{
int idx;
sprintf(pBuf, "\t");
for (idx = 0; idx < KeyLength; idx++)
sprintf(pBuf+strlen(pBuf), "%02X", Key[idx]);
}
return 0;
}
INT Show_Key1_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
Show_WepKey_Proc(pAd, 0, pBuf, BufLen);
return 0;
}
INT Show_Key2_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
Show_WepKey_Proc(pAd, 1, pBuf, BufLen);
return 0;
}
INT Show_Key3_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
Show_WepKey_Proc(pAd, 2, pBuf, BufLen);
return 0;
}
INT Show_Key4_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
Show_WepKey_Proc(pAd, 3, pBuf, BufLen);
return 0;
}
INT Show_PMK_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
INT idx;
UCHAR PMK[32] = {0};
#ifdef CONFIG_AP_SUPPORT
POS_COOKIE pObj = (POS_COOKIE) pAd->OS_Cookie;
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
NdisMoveMemory(PMK, pAd->ApCfg.MBSSID[pObj->ioctl_if].PMK, 32);
#endif /* CONFIG_AP_SUPPORT */
#ifdef CONFIG_STA_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_STA(pAd)
NdisMoveMemory(PMK, pAd->StaCfg.PMK, 32);
#endif /* CONFIG_STA_SUPPORT */
sprintf(pBuf, "\tPMK = ");
for (idx = 0; idx < 32; idx++)
sprintf(pBuf+strlen(pBuf), "%02X", PMK[idx]);
return 0;
}
INT Show_STA_RAInfo_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
sprintf(pBuf, "\n");
#ifdef PRE_ANT_SWITCH
sprintf(pBuf+strlen(pBuf), "PreAntSwitch: %d\n", pAd->CommonCfg.PreAntSwitch);
sprintf(pBuf+strlen(pBuf), "PreAntSwitchRSSI: %d\n", pAd->CommonCfg.PreAntSwitchRSSI);
#endif /* PRE_ANT_SWITCH */
#ifdef NEW_RATE_ADAPT_SUPPORT
sprintf(pBuf+strlen(pBuf), "LowTrafficThrd: %d\n", pAd->CommonCfg.lowTrafficThrd);
sprintf(pBuf+strlen(pBuf), "TrainUpRule: %d\n", pAd->CommonCfg.TrainUpRule);
sprintf(pBuf+strlen(pBuf), "TrainUpRuleRSSI: %d\n", pAd->CommonCfg.TrainUpRuleRSSI);
sprintf(pBuf+strlen(pBuf), "TrainUpLowThrd: %d\n", pAd->CommonCfg.TrainUpLowThrd);
sprintf(pBuf+strlen(pBuf), "TrainUpHighThrd: %d\n", pAd->CommonCfg.TrainUpHighThrd);
#endif // NEW_RATE_ADAPT_SUPPORT //
#ifdef STREAM_MODE_SUPPORT
sprintf(pBuf+strlen(pBuf), "StreamMode: %d\n", pAd->CommonCfg.StreamMode);
sprintf(pBuf+strlen(pBuf), "StreamModeMCS: 0x%04x\n", pAd->CommonCfg.StreamModeMCS);
#endif // STREAM_MODE_SUPPORT //
#ifdef TXBF_SUPPORT
sprintf(pBuf+strlen(pBuf), "ITxBfEn: %d\n", pAd->CommonCfg.RegTransmitSetting.field.ITxBfEn);
sprintf(pBuf+strlen(pBuf), "ITxBfTimeout: %ld\n", pAd->CommonCfg.ITxBfTimeout);
sprintf(pBuf+strlen(pBuf), "ETxBfTimeout: %ld\n", pAd->CommonCfg.ETxBfTimeout);
sprintf(pBuf+strlen(pBuf), "ETxBfEnCond: %ld\n", pAd->CommonCfg.ETxBfEnCond);
sprintf(pBuf+strlen(pBuf), "ETxBfNoncompress: %d\n", pAd->CommonCfg.ETxBfNoncompress);
sprintf(pBuf+strlen(pBuf), "ETxBfIncapable: %d\n", pAd->CommonCfg.ETxBfIncapable);
#endif // TXBF_SUPPORT //
#ifdef DBG_CTRL_SUPPORT
sprintf(pBuf+strlen(pBuf), "DebugFlags: 0x%lx\n", pAd->CommonCfg.DebugFlags);
#endif /* DBG_CTRL_SUPPORT */
return 0;
}
INT show_devinfo_proc(RTMP_ADAPTER *pAd, PSTRING arg)
{
UCHAR *pstr;
DBGPRINT(RT_DEBUG_OFF, ("Device MAC\n"));
if (pAd->OpMode == OPMODE_AP)
pstr = "AP";
else if (pAd->OpMode == OPMODE_STA)
pstr = "STA";
else
pstr = "Unknown";
DBGPRINT(RT_DEBUG_OFF, ("Operation Mode: %s\n", pstr));
pstr = wmode_2_str(pAd->CommonCfg.PhyMode);
if (pstr) {
DBGPRINT(RT_DEBUG_OFF, ("WirelessMode: %s(%d)\n", pstr, pAd->CommonCfg.PhyMode));
os_free_mem(pAd, pstr);
}
DBGPRINT(RT_DEBUG_OFF, ("Channel: %d\n", pAd->CommonCfg.Channel));
DBGPRINT(RT_DEBUG_OFF, ("\tCentralChannel: %d\n", pAd->CommonCfg.CentralChannel));
#ifdef DOT11_VHT_AC
if (WMODE_CAP_AC(pAd->CommonCfg.PhyMode))
DBGPRINT(RT_DEBUG_OFF, ("\tVHT CentralChannel: %d\n", pAd->CommonCfg.vht_cent_ch));
#endif /* DOT11_VHT_AC */
DBGPRINT(RT_DEBUG_OFF, ("\tRF Channel: %d\n", pAd->LatchRfRegs.Channel));
DBGPRINT(RT_DEBUG_OFF, ("Bandwidth\n"));
pstr = (pAd->CommonCfg.RegTransmitSetting.field.BW) ? "20/40" : "20";
DBGPRINT(RT_DEBUG_OFF, ("\tHT-BW: %s\n", pstr));
#ifdef DOT11_VHT_AC
if (WMODE_CAP_AC(pAd->CommonCfg.PhyMode))
{
if (pAd->CommonCfg.vht_bw)
pstr = "80";
DBGPRINT(RT_DEBUG_OFF, ("\tVHT-BW: %s\n", pstr));
}
#endif /* DOT11_VHT_AC */
#ifdef RT65xx
if (IS_RT65XX(pAd))
{
dump_bw_info(pAd);
}
#endif /* RT65xx */
DBGPRINT(RT_DEBUG_OFF, ("Security\n"));
DBGPRINT(RT_DEBUG_OFF, ("MAC Ver: %s\n", MAC_VERSION));
DBGPRINT(RT_DEBUG_OFF, ("BBP Ver: %s\n", BBP_VERSION));
DBGPRINT(RT_DEBUG_OFF, ("RF Ver: %s\n", RF_VERSION));
return TRUE;
}
#ifdef WSC_STA_SUPPORT
INT Show_WpsManufacturer_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
sprintf(pBuf, "\tManufacturer = %s", pAd->StaCfg.WscControl.RegData.SelfInfo.Manufacturer);
return 0;
}
INT Show_WpsModelName_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
sprintf(pBuf, "\tModelName = %s", pAd->StaCfg.WscControl.RegData.SelfInfo.ModelName);
return 0;
}
INT Show_WpsDeviceName_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
sprintf(pBuf, "\tDeviceName = %s", pAd->StaCfg.WscControl.RegData.SelfInfo.DeviceName);
return 0;
}
INT Show_WpsModelNumber_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
sprintf(pBuf, "\tModelNumber = %s", pAd->StaCfg.WscControl.RegData.SelfInfo.ModelNumber);
return 0;
}
INT Show_WpsSerialNumber_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
sprintf(pBuf, "\tSerialNumber = %s", pAd->StaCfg.WscControl.RegData.SelfInfo.SerialNumber);
return 0;
}
INT Show_WpsUuid_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
UCHAR *bin = pAd->StaCfg.WscControl.RegData.SelfInfo.Uuid;
sprintf(pBuf, "\tUuid = %02x%02x%02x%02x-%02x%02x-%02x%02x-"
"%02x%02x-%02x%02x%02x%02x%02x%02x",
bin[0], bin[1], bin[2], bin[3],
bin[4], bin[5], bin[6], bin[7],
bin[8], bin[9], bin[10], bin[11],
bin[12], bin[13], bin[14], bin[15]);
return 0;
}
#endif /* WSC_STA_SUPPORT */
#ifdef SINGLE_SKU
INT Show_ModuleTxpower_Proc(
IN PRTMP_ADAPTER pAd,
OUT PSTRING pBuf,
IN ULONG BufLen)
{
snprintf(pBuf, BufLen, "\tModuleTxpower = %d", pAd->CommonCfg.ModuleTxpower);
return 0;
}
#endif /* SINGLE_SKU */
#ifdef APCLI_SUPPORT
INT RTMPIoctlConnStatus(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
INT i=0;
POS_COOKIE pObj;
UCHAR ifIndex;
BOOLEAN bConnect=FALSE;
pObj = (POS_COOKIE) pAd->OS_Cookie;
DBGPRINT(RT_DEBUG_TRACE, ("==>RTMPIoctlConnStatus\n"));
if (pObj->ioctl_if_type != INT_APCLI)
return FALSE;
ifIndex = pObj->ioctl_if;
DBGPRINT(RT_DEBUG_OFF, ("=============================================================\n"));
if((pAd->ApCfg.ApCliTab[ifIndex].CtrlCurrState == APCLI_CTRL_CONNECTED)
&& (pAd->ApCfg.ApCliTab[ifIndex].SsidLen != 0))
{
for (i=0; i<MAX_LEN_OF_MAC_TABLE; i++)
{
PMAC_TABLE_ENTRY pEntry = &pAd->MacTab.Content[i];
if ( IS_ENTRY_APCLI(pEntry)
&& (pEntry->Sst == SST_ASSOC)
&& (pEntry->PortSecured == WPA_802_1X_PORT_SECURED))
{
DBGPRINT(RT_DEBUG_OFF, ("ApCli%d Connected AP : %02X:%02X:%02X:%02X:%02X:%02X SSID:%s\n",ifIndex,
pEntry->Addr[0], pEntry->Addr[1], pEntry->Addr[2],
pEntry->Addr[3], pEntry->Addr[4], pEntry->Addr[5],
pAd->ApCfg.ApCliTab[ifIndex].Ssid));
bConnect=TRUE;
}
}
if (!bConnect)
DBGPRINT(RT_DEBUG_OFF, ("ApCli%d Connected AP : Disconnect\n",ifIndex));
}
else
{
DBGPRINT(RT_DEBUG_OFF, ("ApCli%d Connected AP : Disconnect\n",ifIndex));
}
DBGPRINT(RT_DEBUG_OFF, ("=============================================================\n"));
DBGPRINT(RT_DEBUG_TRACE, ("<==RTMPIoctlConnStatus\n"));
return TRUE;
}
#endif/*APCLI_SUPPORT*/
void getRate(HTTRANSMIT_SETTING HTSetting, ULONG* fLastTxRxRate)
{
INT MCSMappingRateTable[] =
{2, 4, 11, 22, /* CCK*/
12, 18, 24, 36, 48, 72, 96, 108, /* OFDM*/
13, 26, 39, 52, 78, 104, 117, 130, 26, 52, 78, 104, 156, 208, 234, 260, /* 20MHz, 800ns GI, MCS: 0 ~ 15*/
39, 78, 117, 156, 234, 312, 351, 390, /* 20MHz, 800ns GI, MCS: 16 ~ 23*/
27, 54, 81, 108, 162, 216, 243, 270, 54, 108, 162, 216, 324, 432, 486, 540, /* 40MHz, 800ns GI, MCS: 0 ~ 15*/
81, 162, 243, 324, 486, 648, 729, 810, /* 40MHz, 800ns GI, MCS: 16 ~ 23*/
14, 29, 43, 57, 87, 115, 130, 144, 29, 59, 87, 115, 173, 230, 260, 288, /* 20MHz, 400ns GI, MCS: 0 ~ 15*/
43, 87, 130, 173, 260, 317, 390, 433, /* 20MHz, 400ns GI, MCS: 16 ~ 23*/
30, 60, 90, 120, 180, 240, 270, 300, 60, 120, 180, 240, 360, 480, 540, 600, /* 40MHz, 400ns GI, MCS: 0 ~ 15*/
90, 180, 270, 360, 540, 720, 810, 900};
int rate_count = sizeof(MCSMappingRateTable)/sizeof(int);
int rate_index = 0;
int value = 0;
#ifdef DOT11_N_SUPPORT
if (HTSetting.field.MODE >= MODE_HTMIX)
{
/* rate_index = 12 + ((UCHAR)ht_setting.field.BW *16) + ((UCHAR)ht_setting.field.ShortGI *32) + ((UCHAR)ht_setting.field.MCS);*/
rate_index = 12 + ((UCHAR)HTSetting.field.BW *24) + ((UCHAR)HTSetting.field.ShortGI *48) + ((UCHAR)HTSetting.field.MCS);
}
else
#endif /* DOT11_N_SUPPORT */
if (HTSetting.field.MODE == MODE_OFDM)
rate_index = (UCHAR)(HTSetting.field.MCS) + 4;
else if (HTSetting.field.MODE == MODE_CCK)
rate_index = (UCHAR)(HTSetting.field.MCS);
if (rate_index < 0)
rate_index = 0;
if (rate_index >= rate_count)
rate_index = rate_count-1;
value = (MCSMappingRateTable[rate_index] * 5)/10;
*fLastTxRxRate=(ULONG)value;
return;
}
#ifdef TXBF_SUPPORT
/*
Set_ReadITxBf_Proc - Read Implicit BF profile and display it
iwpriv ra0 set ReadITxBf=<profile number>
*/
INT Set_ReadITxBf_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
int profileNum = simple_strtol(arg, 0, 10);
int scIndex, i, maxCarriers;
Read_TxBfProfile(pAd, &profData, profileNum, TRUE);
/* Display profile. Note: each column is displayed as a row. This shortens the display */
DBGPRINT(RT_DEBUG_OFF, ("---ITxBF Profile: %d - %dx%d, %dMHz\n",
profileNum, profData.rows, profData.columns, profData.fortyMHz? 40: 20));
maxCarriers = profData.fortyMHz? PROFILE_MAX_CARRIERS_40: PROFILE_MAX_CARRIERS_20;
for (scIndex=0; scIndex<maxCarriers; scIndex++) {
for (i=0; i<profData.rows; i++) {
DBGPRINT(RT_DEBUG_OFF, ("%d %d ", Unpack_IBFValue(profData.data[scIndex], 2*i+1), Unpack_IBFValue(profData.data[scIndex], 2*i)));
}
DBGPRINT(RT_DEBUG_OFF, ("\n"));
if (profData.columns>1) {
for (i=0; i<profData.rows; i++) {
DBGPRINT(RT_DEBUG_OFF, ("%d %d ", Unpack_IBFValue(profData.data[scIndex], 2*i+7), Unpack_IBFValue(profData.data[scIndex], 2*i+6)));
}
DBGPRINT(RT_DEBUG_OFF, ("\n"));
}
}
return TRUE;
}
/*
Set_ReadETxBf_Proc - Read Explicit BF profile and display it
usage: iwpriv ra0 set ReadETxBf=<profile number>
*/
INT Set_ReadETxBf_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
int profileNum = simple_strtol(arg, 0, 10);
int scIndex, i, maxCarriers;
Read_TxBfProfile(pAd, &profData, profileNum, FALSE);
/* Dump ETxBF profile values. Note: each column is displayed as a row. This shortens the display */
DBGPRINT(RT_DEBUG_OFF, ("---ETxBF Profile: %d - %dx%d, %dMHz, grp=%d\n",
profileNum, profData.rows, profData.columns, profData.fortyMHz? 40: 20, profData.grouping));
maxCarriers = profData.fortyMHz? PROFILE_MAX_CARRIERS_40: PROFILE_MAX_CARRIERS_20;
for (scIndex=0; scIndex<maxCarriers; scIndex++) {
for (i=0; i<profData.rows; i++) {
DBGPRINT(RT_DEBUG_OFF, ("%d %d\t", (CHAR)(profData.data[scIndex][6*i]), (CHAR)(profData.data[scIndex][6*i+1]) ));
}
DBGPRINT(RT_DEBUG_OFF, ("\n"));
if (profData.columns>1) {
for (i=0; i<profData.rows; i++) {
DBGPRINT(RT_DEBUG_OFF, ("%d %d ", (CHAR)(profData.data[scIndex][6*i+2]), (CHAR)(profData.data[scIndex][6*i+3]) ));
}
DBGPRINT(RT_DEBUG_OFF, ("\n"));
}
if (profData.columns>2) {
for (i=0; i<profData.rows; i++) {
DBGPRINT(RT_DEBUG_OFF, ("%d %d ", (CHAR)(profData.data[scIndex][6*i+4]), (CHAR)(profData.data[scIndex][6*i+5]) ));
}
DBGPRINT(RT_DEBUG_OFF, ("\n"));
}
}
return TRUE;
}
/*
Set_WriteITxBf_Proc - Write Implicit BF matrix
usage: iwpriv ra0 set WriteITxBf=<profile number>
Assumes profData contains a valid Implicit Profile
*/
INT Set_WriteITxBf_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
int profileNum = simple_strtol(arg, 0, 10);
if (!profData.impProfile)
return FALSE;
Write_TxBfProfile(pAd, &profData, profileNum);
return TRUE;
}
/*
Set_WriteETxBf_Proc - Write Explicit BF matrix
usage: iwpriv ra0 set WriteETxBf=<profile number>
Assumes profData contains a valid Explicit Profile
*/
INT Set_WriteETxBf_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
int profileNum = simple_strtol(arg, 0, 10);
if (profData.impProfile)
return FALSE;
Write_TxBfProfile(pAd, &profData, profileNum);
return TRUE;
}
/*
Set_StatITxBf_Proc - Compute power of each chain in Implicit BF matrix
usage: iwpriv ra0 set StatITxBf=<profile number>
*/
INT Set_StatITxBf_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
int scIndex, maxCarriers, i;
unsigned long col1Power[3] = {0,0,0}, col2Power[3] = {0,0,0};
int profileNum = simple_strtol(arg, 0, 10);
PROFILE_DATA *pProfData;
pProfData = (PROFILE_DATA *)kmalloc(sizeof(PROFILE_DATA), MEM_ALLOC_FLAG);
if (pProfData == NULL)
{
DBGPRINT(RT_DEBUG_OFF, ("Set_StatITxBf_Proc: kmalloc failed\n"));
return FALSE;
}
Read_TxBfProfile(pAd, pProfData, profileNum, TRUE);
maxCarriers = pProfData->fortyMHz? PROFILE_MAX_CARRIERS_40: PROFILE_MAX_CARRIERS_20;
for (scIndex=0; scIndex<maxCarriers; scIndex++) {
for (i=0; i<pProfData->rows; i++) {
int ival = Unpack_IBFValue(pProfData->data[scIndex], 2*i+1);
int qval = Unpack_IBFValue(pProfData->data[scIndex], 2*i);
col1Power[i] += ival*ival+qval*qval;
if (pProfData->columns==2) {
ival = Unpack_IBFValue(pProfData->data[scIndex], 2*i+7);
qval = Unpack_IBFValue(pProfData->data[scIndex], 2*i+6);
col2Power[i] += ival*ival+qval*qval;
}
}
}
/* Remove implied scale factor of 2^-16. Convert to thousandths */
for (i=0; i<pProfData->rows; i++) {
col1Power[i] >>= 12;
col1Power[i] = ((col1Power[i]*1000)/maxCarriers)>>4;
col2Power[i] >>= 12;
col2Power[i] = ((col2Power[i]*1000)/maxCarriers)>>4;
}
/* Display stats */
DBGPRINT(RT_DEBUG_OFF, ("ITxBF Stats:\n %dx1=[0.%03lu 0.%03lu, 0.%03lu]\n",
pProfData->rows, col1Power[0], col1Power[1], col1Power[2]));
if (pProfData->columns==2) {
DBGPRINT(RT_DEBUG_OFF, (" %dx2=[0.%03lu 0.%03lu, 0.%03lu]\n",
pProfData->rows, (col1Power[0]+col2Power[0])/2, (col1Power[1]+col2Power[1])/2,
(col1Power[2]+col2Power[2])/2) );
}
kfree(pProfData);
return TRUE;
}
/*
Set_StatETxBf_Proc - Compute power of each chain in Explicit BF matrix
usage: iwpriv ra0 set StatETxBf=<profile number>
*/
INT Set_StatETxBf_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
int scIndex, maxCarriers, i;
unsigned long col1Power[3] = {0,0,0}, col2Power[3] = {0,0,0}, col3Power[3] = {0,0,0};
int profileNum = simple_strtol(arg, 0, 10);
PROFILE_DATA *pProfData;
pProfData = (PROFILE_DATA *)kmalloc(sizeof(PROFILE_DATA), MEM_ALLOC_FLAG);
if (pProfData == NULL)
{
DBGPRINT(RT_DEBUG_OFF, ("Set_StatETxBf_Proc: kmalloc failed\n"));
return FALSE;
}
Read_TxBfProfile(pAd, pProfData, profileNum, FALSE);
maxCarriers = pProfData->fortyMHz? PROFILE_MAX_CARRIERS_40: PROFILE_MAX_CARRIERS_20;
for (scIndex=0; scIndex<maxCarriers; scIndex++) {
for (i=0; i<pProfData->rows; i++) {
int ival = (CHAR)(pProfData->data[scIndex][6*i]);
int qval = (CHAR)(pProfData->data[scIndex][6*i+1]);
col1Power[i] += ival*ival+qval*qval;
if (pProfData->columns>1) {
ival = (CHAR)(pProfData->data[scIndex][6*i+2]);
qval = (CHAR)(pProfData->data[scIndex][6*i+3]);
col2Power[i] += ival*ival+qval*qval;
}
if (pProfData->columns>2) {
ival = (CHAR)(pProfData->data[scIndex][6*i+4]);
qval = (CHAR)(pProfData->data[scIndex][6*i+5]);
col3Power[i] += ival*ival+qval*qval;
}
}
}
/* Remove implied scale factor of 2^-14. Convert to thousandths */
for (i=0; i<pProfData->rows; i++) {
col1Power[i] >>= 10;
col1Power[i] = ((col1Power[i]*1000)/maxCarriers)>>4;
col2Power[i] >>= 10;
col2Power[i] = ((col2Power[i]*1000)/maxCarriers)>>4;
col3Power[i] >>= 10;
col3Power[i] = ((col3Power[i]*1000)/maxCarriers)>>4;
}
/* Display stats */
DBGPRINT(RT_DEBUG_OFF, ("ETxBF Stats:\n %dx1=[0.%03lu 0.%03lu, 0.%03lu]\n",
pProfData->rows, col1Power[0], col1Power[1], col1Power[2]));
if (pProfData->columns==2) {
DBGPRINT(RT_DEBUG_OFF, (" %dx2=[0.%03lu 0.%03lu, 0.%03lu]\n",
pProfData->rows, (col1Power[0]+col2Power[0])/2,
(col1Power[1]+col2Power[1])/2, (col1Power[2]+col2Power[2])/2) );
}
if (pProfData->columns==3) {
DBGPRINT(RT_DEBUG_OFF, (" %dx3=[0.%03lu 0.%03lu, 0.%03lu]\n",
pProfData->rows, (col1Power[0]+col2Power[0]+col3Power[0])/3,
(col1Power[1]+col2Power[1]+col3Power[1])/3,
(col1Power[2]+col2Power[2]+col3Power[2])/3) );
}
kfree(pProfData);
return TRUE;
}
/*
Set_TxBfTag_Proc - Display BF Profile Tags
usage: "iwpriv ra0 set TxBfTag=n"
n: 0=>all,
1=>Explicit,
2=>Implicit,
3=>dump Power table
*/
INT Set_TxBfTag_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
int argVal = simple_strtol(arg, 0, 10);
int profileNum;
if (argVal==0 || argVal==1) {
/* Display Explicit tagfield */
DBGPRINT(RT_DEBUG_OFF, ("---Explicit TxBfTag:\n"));
RTMP_BBP_IO_WRITE8_BY_REG_ID(pAd, BBP_R179, 4);
for (profileNum=0; profileNum<4; profileNum++)
displayTagfield(pAd, profileNum, FALSE);
}
if (argVal==0 || argVal==2) {
/* Display Implicit tagfield */
DBGPRINT(RT_DEBUG_OFF, ("---Implicit TxBfTag:\n"));
RTMP_BBP_IO_WRITE8_BY_REG_ID(pAd, BBP_R179, 0);
for (profileNum=0; profileNum<4; profileNum++)
displayTagfield(pAd, profileNum, TRUE);
}
if (argVal==3) {
int i;
/* 4. Dump power table */
for (i = 0; i < (14 + 12 + 16 + 7); i++)
DBGPRINT(RT_DEBUG_OFF, ("%d: Ch%2d=[%d, %d %d]\n", i,
pAd->TxPower[i].Channel, pAd->TxPower[i].Power,
pAd->TxPower[i].Power2, pAd->TxPower[i].Power3));
}
return TRUE;
}
/*
Set_InvTxBfTag_Proc - Invalidate BF Profile Tags
usage: "iwpriv ra0 set InvTxBfTag=n"
Reset Valid bit and zero out MAC address of each profile. The next profile will be stored in profile 0
*/
INT Set_InvTxBfTag_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
int profileNum;
UCHAR row[EXP_MAX_BYTES];
UCHAR r163Value = 0;
/* Disable Profile Updates during access */
RTMP_BBP_IO_READ8_BY_REG_ID(pAd, BBP_R163, &r163Value);
RTMP_BBP_IO_WRITE8_BY_REG_ID(pAd, BBP_R163, r163Value & ~0x88);
/* Invalidate Implicit tags */
RTMP_BBP_IO_WRITE8_BY_REG_ID(pAd, BBP_R179, 0);
for (profileNum=0; profileNum<4; profileNum++) {
Read_TagField(pAd, row, profileNum);
row[0] &= 0x7F;
row[1] = row[2] = row[3] = row[4] = row[5] = row[6] = 0xAA;
Write_TagField(pAd, row, profileNum);
}
/* Invalidate Explicit tags */
RTMP_BBP_IO_WRITE8_BY_REG_ID(pAd, BBP_R179, 4);
for (profileNum=0; profileNum<4; profileNum++) {
Read_TagField(pAd, row, profileNum);
row[0] &= 0x7F;
row[1] = row[2] = row[3] = row[4] = row[5] = row[6] = 0x55;
Write_TagField(pAd, row, profileNum);
}
/* Restore Profile Updates */
RTMP_BBP_IO_WRITE8_BY_REG_ID(pAd, BBP_R163, r163Value);
return TRUE;
}
/*
Set_ITxBfTimeout_Proc - Set ITxBF timeout value
usage: iwpriv ra0 set ITxBfTimeout=<decimal timeout in units of 25 microsecs>
*/
INT Set_ITxBfTimeout_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
ULONG t = simple_strtol(arg, 0, 10);
if (t > 65535) {
DBGPRINT(RT_DEBUG_ERROR, ("Set_ITxBfTimeout_Proc: value > 65535!\n"));
return FALSE;
}
pAd->CommonCfg.ITxBfTimeout = t;
RTMP_BBP_IO_WRITE8_BY_REG_ID(pAd, BBP_R179, 0x02);
RTMP_BBP_IO_WRITE8_BY_REG_ID(pAd, BBP_R180, 0);
RTMP_BBP_IO_WRITE8_BY_REG_ID(pAd, BBP_R182, pAd->CommonCfg.ITxBfTimeout & 0xFF);
RTMP_BBP_IO_WRITE8_BY_REG_ID(pAd, BBP_R180, 1);
RTMP_BBP_IO_WRITE8_BY_REG_ID(pAd, BBP_R182, (pAd->CommonCfg.ITxBfTimeout>>8) & 0xFF);
DBGPRINT(RT_DEBUG_TRACE, ("Set_ITxBfTimeout_Proc::(ITxBfTimeout=%d)\n", (int)pAd->CommonCfg.ITxBfTimeout));
return TRUE;
}
/*
Set_ETxBfTimeout_Proc - Set ITxBF timeout value
usage: iwpriv ra0 set ETxBfTimeout=<decimal timeout in units of 25 microsecs>
*/
INT Set_ETxBfTimeout_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
ULONG t = simple_strtol(arg, 0, 10);
if (t > 65535) {
DBGPRINT(RT_DEBUG_ERROR, ("Set_ETxBfTimeout_Proc: value > 65535!\n"));
return FALSE;
}
pAd->CommonCfg.ETxBfTimeout = t;
RTMP_IO_WRITE32(pAd, TX_TXBF_CFG_3, pAd->CommonCfg.ETxBfTimeout);
DBGPRINT(RT_DEBUG_TRACE, ("Set_ETxBfTimeout_Proc::(ETxBfTimeout=%d)\n", (int)pAd->CommonCfg.ETxBfTimeout));
return TRUE;
}
/*
Set_ETxBfCodebook_Proc - Set ETxBf Codebook
usage: iwpriv ra0 set ETxBfCodebook=0 to 3
*/
INT Set_ETxBfCodebook_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
TX_TXBF_CFG_0_STRUC regValue;
ULONG t = simple_strtol(arg, 0, 10);
if (t > 3) {
DBGPRINT(RT_DEBUG_ERROR, ("Set_ETxBfCodebook_Proc: value > 3!\n"));
return FALSE;
}
RTMP_IO_READ32(pAd, TX_TXBF_CFG_0, &regValue.word);
regValue.field.EtxbfFbkCode = t;
RTMP_IO_WRITE32(pAd, TX_TXBF_CFG_0, regValue.word);
return TRUE;
}
/*
Set_ETxBfCoefficient_Proc - Set ETxBf Coefficient
usage: iwpriv ra0 set ETxBfCoefficient=0 to 3
*/
INT Set_ETxBfCoefficient_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
TX_TXBF_CFG_0_STRUC regValue;
ULONG t = simple_strtol(arg, 0, 10);
if (t > 3) {
DBGPRINT(RT_DEBUG_ERROR, ("Set_ETxBfCoefficient_Proc: value > 3!\n"));
return FALSE;
}
RTMP_IO_READ32(pAd, TX_TXBF_CFG_0, &regValue.word);
regValue.field.EtxbfFbkCoef = t;
RTMP_IO_WRITE32(pAd, TX_TXBF_CFG_0, regValue.word);
return TRUE;
}
/*
Set_ETxBfGrouping_Proc - Set ETxBf Grouping
usage: iwpriv ra0 set ETxBfGrouping=0 to 2
*/
INT Set_ETxBfGrouping_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
TX_TXBF_CFG_0_STRUC regValue;
ULONG t = simple_strtol(arg, 0, 10);
if (t > 2) {
DBGPRINT(RT_DEBUG_ERROR, ("Set_ETxBfGrouping_Proc: value > 2!\n"));
return FALSE;
}
RTMP_IO_READ32(pAd, TX_TXBF_CFG_0, &regValue.word);
regValue.field.EtxbfFbkNg = t;
RTMP_IO_WRITE32(pAd, TX_TXBF_CFG_0, regValue.word);
return TRUE;
}
/*
Set_ETxBfNoncompress_Proc - Set ETxBf Noncompress option
usage: iwpriv ra0 set ETxBfNoncompress=0 or 1
*/
INT Set_ETxBfNoncompress_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
ULONG t = simple_strtol(arg, 0, 10);
if (t > 1) {
DBGPRINT(RT_DEBUG_ERROR, ("Set_ETxBfNoncompress_Proc: value > 1!\n"));
return FALSE;
}
pAd->CommonCfg.ETxBfNoncompress = t;
return TRUE;
}
/*
Set_ETxBfIncapable_Proc - Set ETxBf Incapable option
usage: iwpriv ra0 set ETxBfIncapable=0 or 1
*/
INT Set_ETxBfIncapable_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
ULONG t = simple_strtol(arg, 0, 10);
if (t > 1)
return FALSE;
pAd->CommonCfg.ETxBfIncapable = t;
setETxBFCap(pAd, &pAd->CommonCfg.HtCapability.TxBFCap);
return TRUE;
}
/*
Set_ITxBfDivCal_Proc - Calculate ITxBf Divider Calibration parameters
usage: iwpriv ra0 set ITxBfDivCal=dd
0=>display calibration parameters
1=>update EEPROM values
2=>update BBP R176
10=>display calibration parameters and dump capture data
11=>Skip divider calibration, just capture and dump capture data
*/
INT Set_ITxBfDivCal_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
int calFunction;
calFunction = simple_strtol(arg, 0, 10);
return ITxBFDividerCalibration(pAd, calFunction, 0, NULL);
}
/*
Set_ITxBfLNACal_Proc - Calculate ITxBf LNA Calibration parameters
usage: iwpriv ra0 set ITxBfLnaCal=dd
0=>display calibration parameters
1=>update EEPROM values
2=>update BBP R174
10=>display calibration parameters and dump capture data
*/
INT Set_ITxBfLnaCal_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
UCHAR channel = pAd->CommonCfg.Channel;
int calFunction;
#ifdef RALINK_ATE
if (ATE_ON(pAd))
channel = pAd->ate.Channel;
#endif /* RALINK_ATE */
calFunction = simple_strtol(arg, 0, 10);
return ITxBFLNACalibration(pAd, calFunction, 0, channel<=14);
}
/*
Set_ITxBfCal_Proc - Calculate ITxBf Calibration parameters
usage: "iwpriv ra0 set ITxBfCal=[0 | 1]"
0=>calculate values, 1=>update BBP and EEPROM
*/
INT Set_ITxBfCal_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
int calFunction = simple_strtol(arg, 0, 10);
int calParams[2];
int ret;
UCHAR channel = pAd->CommonCfg.Channel;
#ifdef RALINK_ATE
if (ATE_ON(pAd))
channel = pAd->ate.Channel;
#endif /* RALINK_ATE */
ret = iCalcCalibration(pAd, calParams, 0);
if (ret < 0) {
if (ret == -3)
DBGPRINT(RT_DEBUG_OFF, ("Set_ITxBfCal_Proc: kmalloc failed\n"));
else if (ret == -2)
DBGPRINT(RT_DEBUG_OFF, ("Set_ITxBfCal_Proc: MAC Address mismatch\n"));
else
DBGPRINT(RT_DEBUG_OFF, ("Set_ITxBfCal_Proc: Invalid profiles\n"));
return FALSE;
}
/* Display result */
DBGPRINT((calFunction==0? RT_DEBUG_OFF: RT_DEBUG_WARN),
("ITxBfCal Result = [0x%02x 0x%02x]\n", calParams[0], calParams[1]));
#ifdef RALINK_ATE
pAd->ate.calParams[0] = (UCHAR)calParams[0];
pAd->ate.calParams[1] = (UCHAR)calParams[1];
/* Double check */
DBGPRINT((calFunction==0? RT_DEBUG_OFF: RT_DEBUG_WARN),
("ITxBfCal Result in ATE = [0x%02x 0x%02x]\n", pAd->ate.calParams[0], pAd->ate.calParams[1]));
#endif /* RALINK_ATE */
/* Update BBP R176 and EEPROM for Ant 0 and 2 */
if (calFunction == 1) {
UCHAR r27Value = 0, r173Value = 0;
ITXBF_PHASE_PARAMS phaseParams;
UCHAR divPhase[2] = {0}, phaseValues[2] = {0};
/* Read R173 to see if Phase compensation is already enabled */
RTMP_BBP_IO_READ8_BY_REG_ID(pAd, BBP_R173, &r173Value);
/* Select Ant 0 */
RTMP_BBP_IO_READ8_BY_REG_ID(pAd, BBP_R27, &r27Value);
r27Value &= ~0x60;
RTMP_BBP_IO_WRITE8_BY_REG_ID(pAd, BBP_R27, r27Value);
/* Update R176 */
if (r173Value & 0x08) {
RTMP_BBP_IO_READ8_BY_REG_ID(pAd, BBP_R176, &phaseValues[0]);
phaseValues[0] += calParams[0];
}
else
phaseValues[0] = calParams[0];
RTMP_BBP_IO_WRITE8_BY_REG_ID(pAd, BBP_R176, phaseValues[0]);
/* Select Ant 2 */
RTMP_BBP_IO_WRITE8_BY_REG_ID(pAd, BBP_R27, r27Value | 0x40);
/* Update R176 */
if (r173Value & 0x08) {
RTMP_BBP_IO_READ8_BY_REG_ID(pAd, BBP_R176, &phaseValues[1]);
phaseValues[1] += calParams[1];
}
else
phaseValues[1] = calParams[1];
RTMP_BBP_IO_WRITE8_BY_REG_ID(pAd, BBP_R176, phaseValues[1]);
/* Enable TX Phase Compensation */
RTMP_BBP_IO_WRITE8_BY_REG_ID(pAd, BBP_R173, r173Value | 0x08);
/* Remove Divider phase */
ITxBFDividerCalibration(pAd, 3, 0, divPhase);
phaseValues[0] -= divPhase[0];
phaseValues[1] -= divPhase[1];
/* Update EEPROM */
ITxBFGetEEPROM(pAd, &phaseParams, 0, 0);
/* Only allow calibration on specific channels */
if (channel == 1) {
phaseParams.gBeg[0] = phaseValues[0];
phaseParams.gBeg[1] = phaseValues[1];
}
else if (channel == 14) {
phaseParams.gEnd[0] = phaseValues[0];
phaseParams.gEnd[1] = phaseValues[1];
}
else if (channel == 36) {
phaseParams.aLowBeg[0] = phaseValues[0];
phaseParams.aLowBeg[1] = phaseValues[1];
}
else if (channel == 64) {
phaseParams.aLowEnd[0] = phaseValues[0];
phaseParams.aLowEnd[1] = phaseValues[1];
}
else if (channel == 100) {
phaseParams.aMidBeg[0] = phaseValues[0];
phaseParams.aMidBeg[1] = phaseValues[1];
}
else if (channel == 128) {
phaseParams.aMidEnd[0] = phaseValues[0];
phaseParams.aMidEnd[1] = phaseValues[1];
}
else if (channel == 132) {
phaseParams.aHighBeg[0] = phaseValues[0];
phaseParams.aHighBeg[1] = phaseValues[1];
}
else if (channel == 165) {
phaseParams.aHighEnd[0] = phaseValues[0];
phaseParams.aHighEnd[1] = phaseValues[1];
}
else {
DBGPRINT(RT_DEBUG_OFF,
("Invalid channel: %d\nMust calibrate channel 1, 14, 36, 64, 100, 128, 132 or 165", channel) );
return FALSE;
}
ITxBFSetEEPROM(pAd, &phaseParams, 0, 0);
DBGPRINT(RT_DEBUG_WARN, ("Set_ITxBfCal_Proc: Calibration Parameters updated\n"));
}
return TRUE;
}
/*
Set_ETxBfEnCond_Proc - enable/disable ETxBF
usage: iwpriv ra0 set ETxBfEnCond=dd
0=>disable, 1=>enable
Note: After use this command, need to re-run apStartup()/LinkUp() operations to sync all status.
If ETxBfIncapable!=0 then we don't need to reassociate.
*/
INT Set_ETxBfEnCond_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
UCHAR i, enableETxBf;
MAC_TABLE_ENTRY *pEntry;
UINT8 byteValue;
enableETxBf = simple_strtol(arg, 0, 10);
if (enableETxBf > 1)
return FALSE;
pAd->CommonCfg.ETxBfEnCond = enableETxBf && (pAd->Antenna.field.TxPath > 1);
pAd->CommonCfg.RegTransmitSetting.field.TxBF = enableETxBf==0? 0: 1;
setETxBFCap(pAd, &pAd->CommonCfg.HtCapability.TxBFCap);
rtmp_asic_set_bf(pAd);
for (i=0; i<MAX_LEN_OF_MAC_TABLE; i++)
{
pEntry = &pAd->MacTab.Content[i];
if (!IS_ENTRY_NONE(pEntry))
{
pEntry->eTxBfEnCond = clientSupportsETxBF(pAd, &pEntry->HTCapability.TxBFCap)? enableETxBf: 0;
pEntry->bfState = READY_FOR_SNDG0;
}
}
if (pAd->CommonCfg.RegTransmitSetting.field.ITxBfEn || enableETxBf)
{
RT30xxReadRFRegister(pAd, RF_R39, (PUCHAR)&byteValue);
byteValue |= 0x40;
RT30xxWriteRFRegister(pAd, RF_R39, (UCHAR)byteValue);
RT30xxReadRFRegister(pAd, RF_R49, (PUCHAR)&byteValue);
byteValue |= 0x20;
RT30xxWriteRFRegister(pAd, RF_R49, (UCHAR)byteValue);
}
else
{
/* depends on Gary Tsao's comments. we shall disable it */
if (pAd->CommonCfg.RegTransmitSetting.field.ITxBfEn == 0)
{
RT30xxReadRFRegister(pAd, RF_R39, (PUCHAR)&byteValue);
byteValue &= (~0x40);
RT30xxWriteRFRegister(pAd, RF_R39, (UCHAR)byteValue);
RT30xxReadRFRegister(pAd, RF_R49, (PUCHAR)&byteValue);
byteValue &= (~0x20);
RT30xxWriteRFRegister(pAd, RF_R49, (UCHAR)byteValue);
}
}
return TRUE;
}
INT Set_NoSndgCntThrd_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
UCHAR i;
for (i=0; i<MAX_LEN_OF_MAC_TABLE; i++){
pAd->MacTab.Content[i].noSndgCntThrd = simple_strtol(arg, 0, 10);
}
return TRUE;
}
INT Set_NdpSndgStreams_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
UCHAR i;
for (i=0; i<MAX_LEN_OF_MAC_TABLE; i++){
pAd->MacTab.Content[i].ndpSndgStreams = simple_strtol(arg, 0, 10);
}
return TRUE;
}
INT Set_Trigger_Sounding_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
UCHAR macAddr[MAC_ADDR_LEN];
CHAR *value;
INT i;
MAC_TABLE_ENTRY *pEntry = NULL;
/* Mac address acceptable format 01:02:03:04:05:06 length 17 */
if(strlen(arg) != 17)
return FALSE;
for (i=0, value = rstrtok(arg,":"); value; value = rstrtok(NULL,":"))
{
if((strlen(value) != 2) || (!isxdigit(*value)) || (!isxdigit(*(value+1))) )
return FALSE; /*Invalid*/
AtoH(value, &macAddr[i++], 1);
}
/*DBGPRINT(RT_DEBUG_TRACE, ("TriggerSounding=%02x:%02x:%02x:%02x:%02x:%02x\n",*/
/* macAddr[0], macAddr[1], macAddr[2], macAddr[3], macAddr[4], macAddr[5], macAddr[6]) );*/
pEntry = MacTableLookup(pAd, macAddr);
if (pEntry==NULL)
return FALSE;
Trigger_Sounding_Packet(pAd, SNDG_TYPE_SOUNDING, 0, pEntry->sndgMcs, pEntry);
return TRUE;
}
/*
Set_ITxBfEn_Proc - enable/disable ITxBF
usage: iwpriv ra0 set ITxBfEn=dd
0=>disable, 1=>enable
*/
INT Set_ITxBfEn_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
UCHAR i;
UCHAR enableITxBF;
BOOLEAN bCalibrated;
UINT8 byteValue;
enableITxBF = simple_strtol(arg, 0, 10);
if (enableITxBF > 1)
return FALSE;
bCalibrated = rtmp_chk_itxbf_calibration(pAd);
DBGPRINT(RT_DEBUG_TRACE, ("Set ITxBfEn=%d, calibration of ITxBF=%d, so enableITxBF=%d!\n",
enableITxBF , bCalibrated, (enableITxBF & bCalibrated)));
enableITxBF &= bCalibrated;
pAd->CommonCfg.RegTransmitSetting.field.ITxBfEn = enableITxBF && (pAd->Antenna.field.TxPath > 1);
rtmp_asic_set_bf(pAd);
for (i=0; i<MAX_LEN_OF_MAC_TABLE; i++)
{
MAC_TABLE_ENTRY *pMacEntry = &pAd->MacTab.Content[i];
if ((!IS_ENTRY_NONE(pMacEntry)) && (pAd->Antenna.field.TxPath> 1))
pMacEntry->iTxBfEn = enableITxBF;
}
if (enableITxBF || pAd->CommonCfg.ETxBfEnCond)
{
RT30xxReadRFRegister(pAd, RF_R39, (PUCHAR)&byteValue);
byteValue |= 0x40;
RT30xxWriteRFRegister(pAd, RF_R39, (UCHAR)byteValue);
RT30xxReadRFRegister(pAd, RF_R49, (PUCHAR)&byteValue);
byteValue |= 0x20;
RT30xxWriteRFRegister(pAd, RF_R49, (UCHAR)byteValue);
}
/* If enabling ITxBF then set LNA compensation, do a Divider Calibration and update BBP registers */
if (enableITxBF) {
ITxBFLoadLNAComp(pAd);
ITxBFDividerCalibration(pAd, 2, 0, NULL);
}
else
{
/* depends on Gary Tsao's comments. */
if (pAd->CommonCfg.ETxBfEnCond == 0)
{
RT30xxReadRFRegister(pAd, RF_R39, (PUCHAR)&byteValue);
byteValue &= (~0x40);
RT30xxWriteRFRegister(pAd, RF_R39, (UCHAR)byteValue);
RT30xxReadRFRegister(pAd, RF_R49, (PUCHAR)&byteValue);
byteValue &= (~0x20);
RT30xxWriteRFRegister(pAd, RF_R49, (UCHAR)byteValue);
}
RTMP_BBP_IO_WRITE8_BY_REG_ID(pAd, BBP_R173, 0);
RTMP_BBP_IO_READ8_BY_REG_ID(pAd, BBP_R27, &byteValue);
byteValue &= ~0x60;
for ( i = 0; i < 3; i++)
{
RTMP_BBP_IO_WRITE8_BY_REG_ID(pAd, BBP_R27, (byteValue & (i << 5)));
RTMP_BBP_IO_WRITE8_BY_REG_ID(pAd, BBP_R174, 0);
RTMP_BBP_IO_WRITE8_BY_REG_ID(pAd, BBP_R176, 0);
}
}
return TRUE;
}
#endif /* TXBF_SUPPORT */
#ifdef DOT11_N_SUPPORT
void assoc_ht_info_debugshow(
IN PRTMP_ADAPTER pAd,
IN MAC_TABLE_ENTRY *pEntry,
IN UCHAR ht_cap_len,
IN HT_CAPABILITY_IE *pHTCapability)
{
HT_CAP_INFO *pHTCap;
HT_CAP_PARM *pHTCapParm;
EXT_HT_CAP_INFO *pExtHT;
#ifdef TXBF_SUPPORT
HT_BF_CAP *pBFCap;
#endif /* TXBF_SUPPORT */
if (pHTCapability && (ht_cap_len > 0))
{
pHTCap = &pHTCapability->HtCapInfo;
pHTCapParm = &pHTCapability->HtCapParm;
pExtHT = &pHTCapability->ExtHtCapInfo;
#ifdef TXBF_SUPPORT
pBFCap = &pHTCapability->TxBFCap;
#endif /* TXBF_SUPPORT */
DBGPRINT(RT_DEBUG_TRACE, ("Peer - 11n HT Info\n"));
DBGPRINT(RT_DEBUG_TRACE, ("\tHT Cap Info: \n"));
DBGPRINT(RT_DEBUG_TRACE, ("\t\t AdvCode(%d), BW(%d), MIMOPS(%d), GF(%d), ShortGI_20(%d), ShortGI_40(%d)\n",
pHTCap->AdvCoding, pHTCap->ChannelWidth, pHTCap->MimoPs, pHTCap->GF,
pHTCap->ShortGIfor20, pHTCap->ShortGIfor40));
DBGPRINT(RT_DEBUG_TRACE, ("\t\t TxSTBC(%d), RxSTBC(%d), DelayedBA(%d), A-MSDU(%d), CCK_40(%d)\n",
pHTCap->TxSTBC, pHTCap->RxSTBC, pHTCap->DelayedBA, pHTCap->AMsduSize, pHTCap->CCKmodein40));
DBGPRINT(RT_DEBUG_TRACE, ("\t\t PSMP(%d), Forty_Mhz_Intolerant(%d), L-SIG(%d)\n",
pHTCap->PSMP, pHTCap->Forty_Mhz_Intolerant, pHTCap->LSIGTxopProSup));
DBGPRINT(RT_DEBUG_TRACE, ("\tHT Parm Info: \n"));
DBGPRINT(RT_DEBUG_TRACE, ("\t\t MaxRx A-MPDU Factor(%d), MPDU Density(%d)\n",
pHTCapParm->MaxRAmpduFactor, pHTCapParm->MpduDensity));
DBGPRINT(RT_DEBUG_TRACE, ("\tHT MCS set: \n"));
DBGPRINT(RT_DEBUG_TRACE, ("\t\t RxMCS(%02x %02x %02x %02x %02x) MaxRxMbps(%d) TxMCSSetDef(%02x)\n",
pHTCapability->MCSSet[0], pHTCapability->MCSSet[1], pHTCapability->MCSSet[2],
pHTCapability->MCSSet[3], pHTCapability->MCSSet[4],
(pHTCapability->MCSSet[11]<<8) + pHTCapability->MCSSet[10],
pHTCapability->MCSSet[12]));
DBGPRINT(RT_DEBUG_TRACE, ("\tExt HT Cap Info: \n"));
DBGPRINT(RT_DEBUG_TRACE, ("\t\t PCO(%d), TransTime(%d), MCSFeedback(%d), +HTC(%d), RDG(%d)\n",
pExtHT->Pco, pExtHT->TranTime, pExtHT->MCSFeedback, pExtHT->PlusHTC, pExtHT->RDGSupport));
#ifdef TXBF_SUPPORT
DBGPRINT(RT_DEBUG_TRACE, ("\tTX BF Cap: \n"));
DBGPRINT(RT_DEBUG_TRACE, ("\t\t ImpRxCap(%d), RXStagSnd(%d), TXStagSnd(%d), RxNDP(%d), TxNDP(%d) ImpTxCap(%d)\n",
pBFCap->TxBFRecCapable, pBFCap->RxSoundCapable, pBFCap->TxSoundCapable,
pBFCap->RxNDPCapable, pBFCap->TxNDPCapable, pBFCap->ImpTxBFCapable));
DBGPRINT(RT_DEBUG_TRACE, ("\t\t Calibration(%d), ExpCSICapable(%d), ExpComSteerCapable(%d), ExpCSIFbk(%d), ExpNoComBF(%d) ExpComBF(%d)\n",
pBFCap->Calibration, pBFCap->ExpCSICapable, pBFCap->ExpComSteerCapable,
pBFCap->ExpCSIFbk, pBFCap->ExpNoComBF, pBFCap->ExpComBF));
DBGPRINT(RT_DEBUG_TRACE, ("\t\t MinGrouping(%d), CSIBFAntSup(%d), NoComSteerBFAntSup(%d), ComSteerBFAntSup(%d), CSIRowBFSup(%d) ChanEstimation(%d)\n",
pBFCap->MinGrouping, pBFCap->CSIBFAntSup, pBFCap->NoComSteerBFAntSup,
pBFCap->ComSteerBFAntSup, pBFCap->CSIRowBFSup, pBFCap->ChanEstimation));
#endif /* TXBF_SUPPORT */
DBGPRINT(RT_DEBUG_TRACE, ("\nPeer - MODE=%d, BW=%d, MCS=%d, ShortGI=%d, MaxRxFactor=%d, MpduDensity=%d, MIMOPS=%d, AMSDU=%d\n",
pEntry->HTPhyMode.field.MODE, pEntry->HTPhyMode.field.BW,
pEntry->HTPhyMode.field.MCS, pEntry->HTPhyMode.field.ShortGI,
pEntry->MaxRAmpduFactor, pEntry->MpduDensity,
pEntry->MmpsMode, pEntry->AMsduSize));
#ifdef DOT11N_DRAFT3
DBGPRINT(RT_DEBUG_TRACE, ("\tExt Cap Info: \n"));
DBGPRINT(RT_DEBUG_TRACE, ("\t\tBss2040CoexistMgmt=%d\n", pEntry->BSS2040CoexistenceMgmtSupport));
#endif /* DOT11N_DRAFT3 */
}
}
INT Set_BurstMode_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
ULONG Value;
Value = simple_strtol(arg, 0, 10);
if (Value == 1)
{
pAd->CommonCfg.bRalinkBurstMode= TRUE;
RTMP_SET_FLAG(pAd, fRTMP_ADAPTER_RALINK_BURST_MODE);
AsicEnableRalinkBurstMode(pAd);
}
else
{
pAd->CommonCfg.bRalinkBurstMode = FALSE;
RTMP_CLEAR_FLAG(pAd, fRTMP_ADAPTER_RALINK_BURST_MODE);
AsicDisableRalinkBurstMode(pAd);
}
DBGPRINT(RT_DEBUG_TRACE, ("Set_BurstMode_Proc ::%s\n",
(pAd->CommonCfg.bRalinkBurstMode == TRUE) ? "enabled" : "disabled"));
return TRUE;
}
#endif /* DOT11_N_SUPPORT */
#ifdef DOT11_VHT_AC
VOID assoc_vht_info_debugshow(
IN RTMP_ADAPTER *pAd,
IN MAC_TABLE_ENTRY *pEntry,
IN VHT_CAP_IE *vht_cap,
IN VHT_OP_IE *vht_op)
{
VHT_CAP_INFO *cap_info;
VHT_MCS_SET *mcs_set;
VHT_OP_INFO *op_info;
VHT_MCS_MAP *mcs_map;
if (!WMODE_CAP_AC(pAd->CommonCfg.PhyMode))
return;
DBGPRINT(RT_DEBUG_TRACE, ("Peer - 11AC VHT Info\n"));
if (vht_cap)
{
cap_info = &vht_cap->vht_cap;
mcs_set = &vht_cap->mcs_set;
hex_dump("peer vht_cap raw data", (UCHAR *)cap_info, sizeof(VHT_CAP_INFO));
hex_dump("peer vht_mcs raw data", (UCHAR *)mcs_set, sizeof(VHT_MCS_SET));
DBGPRINT(RT_DEBUG_TRACE, ("\tVHT Cap Info: \n"));
DBGPRINT(RT_DEBUG_TRACE, ("\t\tMaxMpduLen(%d), BW(%d), SGI_80M(%d), TxSTBC(%d), RxSTBC(%d), +HTC-VHT(%d)\n",
cap_info->max_mpdu_len, cap_info->ch_width, cap_info->sgi_80M, cap_info->tx_stbc,
cap_info->rx_stbc, cap_info->htc_vht_cap));
DBGPRINT(RT_DEBUG_TRACE, ("\t\tMaxAmpduExp(%d), VhtLinkAdapt(%d), RxAntConsist(%d), TxAntConsist(%d)\n",
cap_info->max_ampdu_exp, cap_info->vht_link_adapt, cap_info->rx_ant_consistency, cap_info->tx_ant_consistency));
mcs_map = &mcs_set->rx_mcs_map;
DBGPRINT(RT_DEBUG_TRACE, ("\t\tRxMcsSet: HighRate(%d), RxMCSMap(%d,%d,%d,%d,%d,%d,%d)\n",
mcs_set->rx_high_rate, mcs_map->mcs_ss1, mcs_map->mcs_ss2, mcs_map->mcs_ss3,
mcs_map->mcs_ss4, mcs_map->mcs_ss5, mcs_map->mcs_ss6, mcs_map->mcs_ss7));
mcs_map = &mcs_set->tx_mcs_map;
DBGPRINT(RT_DEBUG_TRACE, ("\t\tTxMcsSet: HighRate(%d), TxMcsMap(%d,%d,%d,%d,%d,%d,%d)\n",
mcs_set->tx_high_rate, mcs_map->mcs_ss1, mcs_map->mcs_ss2, mcs_map->mcs_ss3,
mcs_map->mcs_ss4, mcs_map->mcs_ss5, mcs_map->mcs_ss6, mcs_map->mcs_ss7));
}
if (vht_op)
{
op_info = &vht_op->vht_op_info;
mcs_map = &vht_op->basic_mcs_set;
DBGPRINT(RT_DEBUG_TRACE, ("\tHT OP Info: \n"));
DBGPRINT(RT_DEBUG_TRACE, ("\t\tChannel Width(%d), CenteralFreq1(%d), CenteralFreq2(%d)\n",
op_info->ch_width, op_info->center_freq_1, op_info->center_freq_2));
DBGPRINT(RT_DEBUG_TRACE, ("\t\tBasicMCSSet(SS1:%d, SS2:%d, SS3:%d, SS4:%d, SS5:%d, SS6:%d, SS7:%d)\n",
mcs_map->mcs_ss1, mcs_map->mcs_ss2, mcs_map->mcs_ss3,
mcs_map->mcs_ss4, mcs_map->mcs_ss5, mcs_map->mcs_ss6,
mcs_map->mcs_ss7));
}
DBGPRINT(RT_DEBUG_TRACE, ("\n"));
}
#endif /* DOT11_VHT_AC */
INT Set_RateAdaptInterval(
IN RTMP_ADAPTER *pAd,
IN PSTRING arg)
{
UINT32 ra_time, ra_qtime;
PSTRING token;
char sep = ':';
ULONG irqFlags;
/*
The ra_interval inupt string format should be d:d, in units of ms.
=>The first decimal number indicates the rate adaptation checking period,
=>The second decimal number indicates the rate adaptation quick response checking period.
*/
DBGPRINT(RT_DEBUG_TRACE,("%s():%s\n", __FUNCTION__, arg));
token = strchr(arg, sep);
if (token != NULL)
{
*token = '\0';
if (strlen(arg) && strlen(token+1))
{
ra_time = simple_strtol(arg, 0, 10);
ra_qtime = simple_strtol(token+1, 0, 10);
DBGPRINT(RT_DEBUG_OFF, ("%s():Set RateAdaptation TimeInterval as(%d:%d) ms\n",
__FUNCTION__, ra_time, ra_qtime));
RTMP_IRQ_LOCK(&pAd->irq_lock, irqFlags);
pAd->ra_interval = ra_time;
pAd->ra_fast_interval = ra_qtime;
#ifdef CONFIG_AP_SUPPORT
if (pAd->ApCfg.ApQuickResponeForRateUpTimerRunning == TRUE)
{
BOOLEAN Cancelled;
RTMPCancelTimer(&pAd->ApCfg.ApQuickResponeForRateUpTimer, &Cancelled);
pAd->ApCfg.ApQuickResponeForRateUpTimerRunning = FALSE;
}
#endif /* CONFIG_AP_SUPPORT */
RTMP_IRQ_UNLOCK(&pAd->irq_lock, irqFlags);
return TRUE;
}
}
return FALSE;
}
INT Set_VcoPeriod_Proc(
IN RTMP_ADAPTER *pAd,
IN PSTRING arg)
{
pAd->chipCap.VcoPeriod = simple_strtol(arg, 0, 10);
DBGPRINT(RT_DEBUG_TRACE,
("VCO Period = %d seconds\n", pAd->chipCap.VcoPeriod));
return TRUE;
}
#ifdef SINGLE_SKU
INT Set_ModuleTxpower_Proc(
IN PRTMP_ADAPTER pAd,
IN PSTRING arg)
{
UINT16 Value;
if(RTMP_TEST_FLAG(pAd, fRTMP_ADAPTER_INTERRUPT_IN_USE))
{
DBGPRINT(RT_DEBUG_ERROR, ("Do NOT accept this command after interface is up.\n"));
return FALSE;
}
Value = (UINT16)simple_strtol(arg, 0, 10);
pAd->CommonCfg.ModuleTxpower = Value;
DBGPRINT(RT_DEBUG_TRACE, ("IF Set_ModuleTxpower_Proc::(ModuleTxpower=%d)\n", pAd->CommonCfg.ModuleTxpower));
return TRUE;
}
#endif /* SINGLE_SKU */
#ifdef FPGA_MODE
INT set_tx_kickcnt(RTMP_ADAPTER *pAd, PSTRING arg)
{
pAd->tx_kick_cnt = (INT)simple_strtol(arg, 0, 10);
DBGPRINT(RT_DEBUG_TRACE, ("%s():tx_kick_cnt=%d\n", __FUNCTION__, pAd->tx_kick_cnt));
return TRUE;
}
INT set_data_phy_mode(RTMP_ADAPTER *pAd, PSTRING arg)
{
pAd->data_phy = (INT)simple_strtol(arg, 0, 10);
DBGPRINT(RT_DEBUG_TRACE, ("%s(): data_phy=%d\n", __FUNCTION__, pAd->data_phy));
return TRUE;
}
INT set_data_bw(RTMP_ADAPTER *pAd, PSTRING arg)
{
pAd->data_bw = (UCHAR)simple_strtol(arg, 0, 10);
DBGPRINT(RT_DEBUG_TRACE, ("%s(): data_bw=%d\n", __FUNCTION__, pAd->data_bw));
return TRUE;
}
INT set_data_mcs(RTMP_ADAPTER *pAd, PSTRING arg)
{
UCHAR mcs = (UCHAR)simple_strtol(arg, 0, 10);
pAd->data_mcs = ((mcs / 10) <<4) | (mcs % 10);
DBGPRINT(RT_DEBUG_TRACE, ("%s(): data_mcs=%d\n", __FUNCTION__, pAd->data_mcs));
return TRUE;
}
INT set_data_gi(RTMP_ADAPTER *pAd, PSTRING arg)
{
pAd->data_gi = (UCHAR)simple_strtol(arg, 0, 10);
DBGPRINT(RT_DEBUG_TRACE, ("%s(): data_gi=%d\n", __FUNCTION__, pAd->data_gi));
return TRUE;
}
INT set_data_basize(RTMP_ADAPTER *pAd, PSTRING arg)
{
pAd->data_basize = (UCHAR)simple_strtol(arg, 0, 10);
DBGPRINT(RT_DEBUG_TRACE, ("%s(): data_basize=%d\n", __FUNCTION__, pAd->data_basize));
return TRUE;
}
INT set_fpga_mode(RTMP_ADAPTER *pAd, PSTRING arg)
{
ULONG fpga_on;
fpga_on = simple_strtol(arg, 0, 10);
if (fpga_on & 2)
{
pAd->data_phy = MODE_VHT;
pAd->data_bw = BW_80;
pAd->data_gi = 1;
pAd->data_mcs = 7;
pAd->data_basize = 31;
#ifdef CONFIG_AP_SUPPORT
pAd->ApCfg.MBSSID[0].bAutoTxRateSwitch = FALSE;
#endif /* CONFIG_AP_SUPPORT */
} else {
#ifdef CONFIG_AP_SUPPORT
pAd->ApCfg.MBSSID[0].bAutoTxRateSwitch = TRUE;
#endif /* CONFIG_AP_SUPPORT */
}
if (fpga_on & 4)
pAd->data_mcs = (1 <<4) | 7;
pAd->fpga_on = fpga_on;
DBGPRINT(RT_DEBUG_TRACE, ("%s(): fpga_on=%d\n", __FUNCTION__, pAd->fpga_on));
DBGPRINT(RT_DEBUG_TRACE, ("%s(): data_phy=%d\n", __FUNCTION__, pAd->data_phy));
DBGPRINT(RT_DEBUG_TRACE, ("%s(): data_bw=%d\n", __FUNCTION__, pAd->data_bw));
DBGPRINT(RT_DEBUG_TRACE, ("%s(): data_mcs=%d\n", __FUNCTION__, pAd->data_mcs));
DBGPRINT(RT_DEBUG_TRACE, ("%s(): data_gi=%d\n", __FUNCTION__, pAd->data_gi));
DBGPRINT(RT_DEBUG_TRACE, ("%s(): data_basize=%d\n", __FUNCTION__, pAd->data_basize));
#ifdef CONFIG_AP_SUPPORT
DBGPRINT(RT_DEBUG_TRACE, ("%s(): bAutoTxRateSwitch=%d\n",
__FUNCTION__,
pAd->ApCfg.MBSSID[0].bAutoTxRateSwitch));
#endif /* CONFIG_AP_SUPPORT */
return TRUE;
}
#endif /* FPGA_MODE */
#ifdef WFA_VHT_PF
INT set_force_amsdu(RTMP_ADAPTER *pAd, PSTRING arg)
{
pAd->force_amsdu = (simple_strtol(arg, 0, 10) > 0 ? TRUE : FALSE);
DBGPRINT(RT_DEBUG_TRACE, ("%s(): force_amsdu=%d\n",
__FUNCTION__, pAd->force_amsdu));
return TRUE;
}
#endif /* WFA_VHT_PF */
#ifdef RLT_RF
INT set_rf(RTMP_ADAPTER *pAd, PSTRING arg)
{
INT bank_id = 0, rf_id = 0, rv = 0;
UCHAR rf_val = 0;
if (arg)
{
rv = sscanf(arg, "%d-%d-%x", &(bank_id), &(rf_id), &(rf_val));
DBGPRINT(RT_DEBUG_TRACE, ("%s():rv = %d, bank_id = %d, rf_id = %d, rf_val = 0x%02x\n", __FUNCTION__, rv, bank_id, rf_id, rf_val));
if (rv == 3)
{
rlt_rf_write(pAd, (UCHAR)bank_id, (UCHAR)rf_id, (UCHAR)rf_val);
rlt_rf_read(pAd, bank_id, rf_id, &rf_val);
DBGPRINT(RT_DEBUG_TRACE, ("%s():%d %03d 0x%02X\n", __FUNCTION__, bank_id, rf_id, rf_val));
}
else if (rv == 2)
{
rlt_rf_read(pAd, bank_id, rf_id, &rf_val);
DBGPRINT(RT_DEBUG_TRACE, ("%s():%d %03d 0x%02X\n", __FUNCTION__, bank_id, rf_id, rf_val));
}
}
return TRUE;
}
#endif /* RLT_RF */
static struct {
PSTRING name;
INT (*show_proc)(PRTMP_ADAPTER pAdapter, PSTRING arg, ULONG BufLen);
} *PRTMP_PRIVATE_STA_SHOW_CFG_VALUE_PROC, RTMP_PRIVATE_STA_SHOW_CFG_VALUE_PROC[] = {
#ifdef DBG
{"SSID", Show_SSID_Proc},
{"WirelessMode", Show_WirelessMode_Proc},
{"TxBurst", Show_TxBurst_Proc},
{"TxPreamble", Show_TxPreamble_Proc},
{"TxPower", Show_TxPower_Proc},
{"Channel", Show_Channel_Proc},
{"BGProtection", Show_BGProtection_Proc},
{"RTSThreshold", Show_RTSThreshold_Proc},
{"FragThreshold", Show_FragThreshold_Proc},
#ifdef DOT11_N_SUPPORT
{"HtBw", Show_HtBw_Proc},
{"HtMcs", Show_HtMcs_Proc},
{"HtGi", Show_HtGi_Proc},
{"HtOpMode", Show_HtOpMode_Proc},
{"HtExtcha", Show_HtExtcha_Proc},
{"HtMpduDensity", Show_HtMpduDensity_Proc},
{"HtBaWinSize", Show_HtBaWinSize_Proc},
{"HtRdg", Show_HtRdg_Proc},
{"HtAmsdu", Show_HtAmsdu_Proc},
{"HtAutoBa", Show_HtAutoBa_Proc},
#endif /* DOT11_N_SUPPORT */
{"CountryRegion", Show_CountryRegion_Proc},
{"CountryRegionABand", Show_CountryRegionABand_Proc},
{"CountryCode", Show_CountryCode_Proc},
#ifdef AGGREGATION_SUPPORT
{"PktAggregate", Show_PktAggregate_Proc},
#endif
#ifdef WMM_SUPPORT
{"WmmCapable", Show_WmmCapable_Proc},
#endif
{"IEEE80211H", Show_IEEE80211H_Proc},
#ifdef CONFIG_STA_SUPPORT
{"NetworkType", Show_NetworkType_Proc},
#ifdef WSC_STA_SUPPORT
{"WpsApBand", Show_WpsPbcBand_Proc},
{"Manufacturer", Show_WpsManufacturer_Proc},
{"ModelName", Show_WpsModelName_Proc},
{"DeviceName", Show_WpsDeviceName_Proc},
{"ModelNumber", Show_WpsModelNumber_Proc},
{"SerialNumber", Show_WpsSerialNumber_Proc},
{"Uuid", Show_WpsUuid_Proc},
#endif /* WSC_STA_SUPPORT */
{"WPAPSK", Show_WPAPSK_Proc},
{"AutoReconnect", Show_AutoReconnect_Proc},
#endif /* CONFIG_STA_SUPPORT */
{"AuthMode", Show_AuthMode_Proc},
{"EncrypType", Show_EncrypType_Proc},
{"DefaultKeyID", Show_DefaultKeyID_Proc},
{"Key1", Show_Key1_Proc},
{"Key2", Show_Key2_Proc},
{"Key3", Show_Key3_Proc},
{"Key4", Show_Key4_Proc},
{"PMK", Show_PMK_Proc},
#ifdef SINGLE_SKU
{"ModuleTxpower", Show_ModuleTxpower_Proc},
#endif /* SINGLE_SKU */
#endif /* DBG */
{"rainfo", Show_STA_RAInfo_Proc},
{NULL, NULL}
};
INT RTMPShowCfgValue(
IN PRTMP_ADAPTER pAd,
IN PSTRING pName,
IN PSTRING pBuf,
IN UINT32 MaxLen)
{
INT Status = 0;
for (PRTMP_PRIVATE_STA_SHOW_CFG_VALUE_PROC = RTMP_PRIVATE_STA_SHOW_CFG_VALUE_PROC; PRTMP_PRIVATE_STA_SHOW_CFG_VALUE_PROC->name; PRTMP_PRIVATE_STA_SHOW_CFG_VALUE_PROC++)
{
if (!strcmp(pName, PRTMP_PRIVATE_STA_SHOW_CFG_VALUE_PROC->name))
{
if(PRTMP_PRIVATE_STA_SHOW_CFG_VALUE_PROC->show_proc(pAd, pBuf, MaxLen))
Status = -EINVAL;
break; /*Exit for loop.*/
}
}
if(PRTMP_PRIVATE_STA_SHOW_CFG_VALUE_PROC->name == NULL)
{
snprintf(pBuf, MaxLen, "\n");
for (PRTMP_PRIVATE_STA_SHOW_CFG_VALUE_PROC = RTMP_PRIVATE_STA_SHOW_CFG_VALUE_PROC; PRTMP_PRIVATE_STA_SHOW_CFG_VALUE_PROC->name; PRTMP_PRIVATE_STA_SHOW_CFG_VALUE_PROC++)
{
if ((strlen(pBuf) + strlen(PRTMP_PRIVATE_STA_SHOW_CFG_VALUE_PROC->name)) >= MaxLen)
break;
sprintf(pBuf, "%s%s\n", pBuf, PRTMP_PRIVATE_STA_SHOW_CFG_VALUE_PROC->name);
}
}
return Status;
}