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

5884 lines
176 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_profile.c
Abstract:
Revision History:
Who When What
--------- ---------- ----------------------------------------------
*/
#include "rt_config.h"
#define ETH_MAC_ADDR_STR_LEN 17 /* in format of xx:xx:xx:xx:xx:xx*/
/* We assume the s1 is a sting, s2 is a memory space with 6 bytes. and content of s1 will be changed.*/
BOOLEAN rtstrmactohex(PSTRING s1, PSTRING s2)
{
int i = 0;
PSTRING ptokS = s1, ptokE = s1;
if (strlen(s1) != ETH_MAC_ADDR_STR_LEN)
return FALSE;
while((*ptokS) != '\0')
{
if((ptokE = strchr(ptokS, ':')) != NULL)
*ptokE++ = '\0';
if ((strlen(ptokS) != 2) || (!isxdigit(*ptokS)) || (!isxdigit(*(ptokS+1))))
break; /* fail*/
AtoH(ptokS, (PUCHAR)&s2[i++], 1);
ptokS = ptokE;
if (ptokS == NULL)
break;
if (i == 6)
break; /* parsing finished*/
}
return ( i == 6 ? TRUE : FALSE);
}
#define ASC_LOWER(_x) ((((_x) >= 0x41) && ((_x) <= 0x5a)) ? (_x) + 0x20 : (_x))
/* we assume the s1 and s2 both are strings.*/
BOOLEAN rtstrcasecmp(PSTRING s1, PSTRING s2)
{
PSTRING p1 = s1, p2 = s2;
CHAR c1, c2;
if (strlen(s1) != strlen(s2))
return FALSE;
while(*p1 != '\0')
{
c1 = ASC_LOWER(*p1);
c2 = ASC_LOWER(*p2);
if(c1 != c2)
return FALSE;
p1++;
p2++;
}
return TRUE;
}
/* we assume the s1 (buffer) and s2 (key) both are strings.*/
PSTRING rtstrstruncasecmp(PSTRING s1, PSTRING s2)
{
INT l1, l2, i;
char temp1, temp2;
l2 = strlen(s2);
if (!l2)
return (char *) s1;
l1 = strlen(s1);
while (l1 >= l2)
{
l1--;
for(i=0; i<l2; i++)
{
temp1 = *(s1+i);
temp2 = *(s2+i);
if (('a' <= temp1) && (temp1 <= 'z'))
temp1 = 'A'+(temp1-'a');
if (('a' <= temp2) && (temp2 <= 'z'))
temp2 = 'A'+(temp2-'a');
if (temp1 != temp2)
break;
}
if (i == l2)
return (char *) s1;
s1++;
}
return NULL; /* not found*/
}
/**
* strstr - Find the first substring in a %NUL terminated string
* @s1: The string to be searched
* @s2: The string to search for
*/
PSTRING rtstrstr(PSTRING s1,const PSTRING s2)
{
INT l1, l2;
l2 = strlen(s2);
if (!l2)
return s1;
l1 = strlen(s1);
while (l1 >= l2)
{
l1--;
if (!memcmp(s1,s2,l2))
return s1;
s1++;
}
return NULL;
}
/**
* rstrtok - Split a string into tokens
* @s: The string to be searched
* @ct: The characters to search for
* * WARNING: strtok is deprecated, use strsep instead. However strsep is not compatible with old architecture.
*/
PSTRING __rstrtok;
PSTRING rstrtok(PSTRING s,const PSTRING ct)
{
PSTRING sbegin, send;
sbegin = s ? s : __rstrtok;
if (!sbegin)
{
return NULL;
}
sbegin += strspn(sbegin,ct);
if (*sbegin == '\0')
{
__rstrtok = NULL;
return( NULL );
}
send = strpbrk( sbegin, ct);
if (send && *send != '\0')
*send++ = '\0';
__rstrtok = send;
return (sbegin);
}
/**
* delimitcnt - return the count of a given delimiter in a given string.
* @s: The string to be searched.
* @ct: The delimiter to search for.
* Notice : We suppose the delimiter is a single-char string(for example : ";").
*/
INT delimitcnt(PSTRING s,PSTRING ct)
{
INT count = 0;
/* point to the beginning of the line */
PSTRING token = s;
for ( ;; )
{
token = strpbrk(token, ct); /* search for delimiters */
if ( token == NULL )
{
/* advanced to the terminating null character */
break;
}
/* skip the delimiter */
++token;
/*
* Print the found text: use len with %.*s to specify field width.
*/
/* accumulate delimiter count */
++count;
}
return count;
}
/*
* converts the Internet host address from the standard numbers-and-dots notation
* into binary data.
* returns nonzero if the address is valid, zero if not.
*/
int rtinet_aton(PSTRING cp, unsigned int *addr)
{
unsigned int val;
int base, n;
STRING c;
unsigned int parts[4];
unsigned int *pp = parts;
for (;;)
{
/*
* Collect number up to ``.''.
* Values are specified as for C:
* 0x=hex, 0=octal, other=decimal.
*/
val = 0;
base = 10;
if (*cp == '0')
{
if (*++cp == 'x' || *cp == 'X')
base = 16, cp++;
else
base = 8;
}
while ((c = *cp) != '\0')
{
if (isdigit((unsigned char) c))
{
val = (val * base) + (c - '0');
cp++;
continue;
}
if (base == 16 && isxdigit((unsigned char) c))
{
val = (val << 4) +
(c + 10 - (islower((unsigned char) c) ? 'a' : 'A'));
cp++;
continue;
}
break;
}
if (*cp == '.')
{
/*
* Internet format: a.b.c.d a.b.c (with c treated as 16-bits)
* a.b (with b treated as 24 bits)
*/
if (pp >= parts + 3 || val > 0xff)
return 0;
*pp++ = val, cp++;
}
else
break;
}
/*
* Check for trailing junk.
*/
while (*cp)
if (!isspace((unsigned char) *cp++))
return 0;
/*
* Concoct the address according to the number of parts specified.
*/
n = pp - parts + 1;
switch (n)
{
case 1: /* a -- 32 bits */
break;
case 2: /* a.b -- 8.24 bits */
if (val > 0xffffff)
return 0;
val |= parts[0] << 24;
break;
case 3: /* a.b.c -- 8.8.16 bits */
if (val > 0xffff)
return 0;
val |= (parts[0] << 24) | (parts[1] << 16);
break;
case 4: /* a.b.c.d -- 8.8.8.8 bits */
if (val > 0xff)
return 0;
val |= (parts[0] << 24) | (parts[1] << 16) | (parts[2] << 8);
break;
}
*addr = OS_HTONL(val);
return 1;
}
/*
========================================================================
Routine Description:
Find key section for Get key parameter.
Arguments:
buffer Pointer to the buffer to start find the key section
section the key of the secion to be find
Return Value:
NULL Fail
Others Success
========================================================================
*/
PSTRING RTMPFindSection(
IN PSTRING buffer)
{
STRING temp_buf[32];
PSTRING ptr;
strcpy(temp_buf, "Default");
if((ptr = rtstrstr(buffer, temp_buf)) != NULL)
return (ptr+strlen("\n"));
else
return NULL;
}
/*
========================================================================
Routine Description:
Get key parameter.
Arguments:
key Pointer to key string
dest Pointer to destination
destsize The datasize of the destination
buffer Pointer to the buffer to start find the key
bTrimSpace Set true if you want to strip the space character of the result pattern
Return Value:
TRUE Success
FALSE Fail
Note:
This routine get the value with the matched key (case case-sensitive)
For SSID and security key related parameters, we SHALL NOT trim the space(' ') character.
========================================================================
*/
INT RTMPGetKeyParameter(
IN PSTRING key,
OUT PSTRING dest,
IN INT destsize,
IN PSTRING buffer,
IN BOOLEAN bTrimSpace)
{
PSTRING pMemBuf, temp_buf1 = NULL, temp_buf2 = NULL;
PSTRING start_ptr, end_ptr;
PSTRING ptr;
PSTRING offset = NULL;
INT len, keyLen;
keyLen = strlen(key);
os_alloc_mem(NULL, (PUCHAR *)&pMemBuf, MAX_PARAM_BUFFER_SIZE * 2);
if (pMemBuf == NULL)
return (FALSE);
memset(pMemBuf, 0, MAX_PARAM_BUFFER_SIZE * 2);
temp_buf1 = pMemBuf;
temp_buf2 = (PSTRING)(pMemBuf + MAX_PARAM_BUFFER_SIZE);
/*find section*/
if((offset = RTMPFindSection(buffer)) == NULL)
{
os_free_mem(NULL, (PUCHAR)pMemBuf);
return (FALSE);
}
strcpy(temp_buf1, "\n");
strcat(temp_buf1, key);
strcat(temp_buf1, "=");
/*search key*/
if((start_ptr=rtstrstr(offset, temp_buf1)) == NULL)
{
os_free_mem(NULL, (PUCHAR)pMemBuf);
return (FALSE);
}
start_ptr += strlen("\n");
if((end_ptr = rtstrstr(start_ptr, "\n"))==NULL)
end_ptr = start_ptr+strlen(start_ptr);
if (end_ptr<start_ptr)
{
os_free_mem(NULL, (PUCHAR)pMemBuf);
return (FALSE);
}
NdisMoveMemory(temp_buf2, start_ptr, end_ptr-start_ptr);
temp_buf2[end_ptr-start_ptr]='\0';
if((start_ptr=rtstrstr(temp_buf2, "=")) == NULL)
{
os_free_mem(NULL, (PUCHAR)pMemBuf);
return (FALSE);
}
ptr = (start_ptr +1);
/*trim special characters, i.e., TAB or space*/
while(*start_ptr != 0x00)
{
if( ((*ptr == ' ') && bTrimSpace) || (*ptr == '\t') )
ptr++;
else
break;
}
len = strlen(start_ptr);
memset(dest, 0x00, destsize);
strncpy(dest, ptr, ((len >= destsize) ? destsize: len));
os_free_mem(NULL, (PUCHAR)pMemBuf);
return TRUE;
}
/*
========================================================================
Routine Description:
Get multiple key parameter.
Arguments:
key Pointer to key string
dest Pointer to destination
destsize The datasize of the destination
buffer Pointer to the buffer to start find the key
Return Value:
TRUE Success
FALSE Fail
Note:
This routine get the value with the matched key (case case-sensitive)
========================================================================
*/
INT RTMPGetKeyParameterWithOffset(
IN PSTRING key,
OUT PSTRING dest,
OUT USHORT *end_offset,
IN INT destsize,
IN PSTRING buffer,
IN BOOLEAN bTrimSpace)
{
PSTRING temp_buf1 = NULL;
PSTRING temp_buf2 = NULL;
PSTRING start_ptr;
PSTRING end_ptr;
PSTRING ptr;
PSTRING offset = 0;
INT len;
if (*end_offset >= MAX_INI_BUFFER_SIZE)
return (FALSE);
os_alloc_mem(NULL, (PUCHAR *)&temp_buf1, MAX_PARAM_BUFFER_SIZE);
if(temp_buf1 == NULL)
return (FALSE);
os_alloc_mem(NULL, (PUCHAR *)&temp_buf2, MAX_PARAM_BUFFER_SIZE);
if(temp_buf2 == NULL)
{
os_free_mem(NULL, (PUCHAR)temp_buf1);
return (FALSE);
}
/*find section */
if(*end_offset == 0)
{
if ((offset = RTMPFindSection(buffer)) == NULL)
{
os_free_mem(NULL, (PUCHAR)temp_buf1);
os_free_mem(NULL, (PUCHAR)temp_buf2);
return (FALSE);
}
}
else
offset = buffer + (*end_offset);
strcpy(temp_buf1, "\n");
strcat(temp_buf1, key);
strcat(temp_buf1, "=");
/*search key*/
if((start_ptr=rtstrstr(offset, temp_buf1))==NULL)
{
os_free_mem(NULL, (PUCHAR)temp_buf1);
os_free_mem(NULL, (PUCHAR)temp_buf2);
return (FALSE);
}
start_ptr+=strlen("\n");
if((end_ptr=rtstrstr(start_ptr, "\n"))==NULL)
end_ptr=start_ptr+strlen(start_ptr);
if (end_ptr<start_ptr)
{
os_free_mem(NULL, (PUCHAR)temp_buf1);
os_free_mem(NULL, (PUCHAR)temp_buf2);
return (FALSE);
}
*end_offset = end_ptr - buffer;
NdisMoveMemory(temp_buf2, start_ptr, end_ptr-start_ptr);
temp_buf2[end_ptr-start_ptr]='\0';
len = strlen(temp_buf2);
strcpy(temp_buf1, temp_buf2);
if((start_ptr=rtstrstr(temp_buf1, "=")) == NULL)
{
os_free_mem(NULL, (PUCHAR)temp_buf1);
os_free_mem(NULL, (PUCHAR)temp_buf2);
return (FALSE);
}
strcpy(temp_buf2, start_ptr+1);
ptr = temp_buf2;
/*trim space or tab*/
while(*ptr != 0x00)
{
if((bTrimSpace && (*ptr == ' ')) || (*ptr == '\t') )
ptr++;
else
break;
}
len = strlen(ptr);
memset(dest, 0x00, destsize);
strncpy(dest, ptr, len >= destsize ? destsize: len);
os_free_mem(NULL, (PUCHAR)temp_buf1);
os_free_mem(NULL, (PUCHAR)temp_buf2);
return TRUE;
}
#ifdef CONFIG_STA_SUPPORT
inline void RTMPSetSTADefKeyId(RTMP_ADAPTER *pAd, ULONG KeyIdx)
{
if((KeyIdx >= 1 ) && (KeyIdx <= 4))
pAd->StaCfg.DefaultKeyId = (UCHAR) (KeyIdx - 1);
else
pAd->StaCfg.DefaultKeyId = 0;
}
#endif /* CONFIG_STA_SUPPORT */
static int rtmp_parse_key_buffer_from_file(IN PRTMP_ADAPTER pAd,IN PSTRING buffer,IN ULONG KeyType,IN INT BSSIdx,IN INT KeyIdx)
{
PSTRING keybuff;
/*INT i = BSSIdx, idx = KeyIdx, retVal;*/
ULONG KeyLen;
/*UCHAR CipherAlg = CIPHER_WEP64;*/
CIPHER_KEY *pSharedKey;
keybuff = buffer;
KeyLen = strlen(keybuff);
pSharedKey = &pAd->SharedKey[BSSIdx][KeyIdx];
if(((KeyType != 0) && (KeyType != 1)) ||
((KeyType == 0) && (KeyLen != 10) && (KeyLen != 26)) ||
((KeyType== 1) && (KeyLen != 5) && (KeyLen != 13)))
{
DBGPRINT(RT_DEBUG_ERROR, ("Key%dStr is Invalid key length(%ld) or Type(%ld)\n",
KeyIdx+1, KeyLen, KeyType));
return FALSE;
}
else
{
return RT_CfgSetWepKey(pAd, buffer, pSharedKey, KeyIdx);
}
}
static void rtmp_read_key_parms_from_file(IN PRTMP_ADAPTER pAd, PSTRING tmpbuf, PSTRING buffer)
{
STRING tok_str[16];
PSTRING macptr;
INT i = 0, idx;
ULONG KeyType[HW_BEACON_MAX_NUM];
ULONG KeyIdx;
NdisZeroMemory(KeyType, sizeof(KeyType));
/*DefaultKeyID*/
if(RTMPGetKeyParameter("DefaultKeyID", tmpbuf, 25, buffer, TRUE))
{
#ifdef CONFIG_AP_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
if (i >= pAd->ApCfg.BssidNum)
{
break;
}
KeyIdx = simple_strtol(macptr, 0, 10);
if((KeyIdx >= 1 ) && (KeyIdx <= 4))
pAd->ApCfg.MBSSID[i].DefaultKeyId = (UCHAR) (KeyIdx - 1 );
else
pAd->ApCfg.MBSSID[i].DefaultKeyId = 0;
DBGPRINT(RT_DEBUG_TRACE, ("I/F(ra%d) DefaultKeyID(0~3)=%d\n", i, pAd->ApCfg.MBSSID[i].DefaultKeyId));
}
}
#endif /* CONFIG_AP_SUPPORT */
#ifdef CONFIG_STA_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_STA(pAd)
{
KeyIdx = simple_strtol(tmpbuf, 0, 10);
RTMPSetSTADefKeyId(pAd, KeyIdx);
DBGPRINT(RT_DEBUG_TRACE, ("DefaultKeyID(0~3)=%d\n", pAd->StaCfg.DefaultKeyId));
}
#endif /* CONFIG_STA_SUPPORT */
}
for (idx = 0; idx < 4; idx++)
{
snprintf(tok_str, sizeof(tok_str), "Key%dType", idx + 1);
/*Key1Type*/
if (RTMPGetKeyParameter(tok_str, tmpbuf, 128, buffer, TRUE))
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
/*
do sanity check for KeyType length;
or in station mode, the KeyType length > 1,
the code will overwrite the stack of caller
(RTMPSetProfileParameters) and cause srcbuf = NULL
*/
if (i < MAX_MBSSID_NUM(pAd))
KeyType[i] = simple_strtol(macptr, 0, 10);
}
#ifdef CONFIG_AP_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
{
if (TRUE)
{
BOOLEAN bKeyxStryIsUsed = FALSE;
//GPRINT(RT_DEBUG_TRACE, ("pAd->ApCfg.BssidNum=%d\n", pAd->ApCfg.BssidNum));
for (i = 0; i < pAd->ApCfg.BssidNum; i++)
{
snprintf(tok_str, sizeof(tok_str), "Key%dStr%d", idx + 1, i + 1);
if (RTMPGetKeyParameter(tok_str, tmpbuf, 128, buffer, FALSE))
{
rtmp_parse_key_buffer_from_file(pAd, tmpbuf, KeyType[i], i, idx);
if (bKeyxStryIsUsed == FALSE)
{
bKeyxStryIsUsed = TRUE;
}
}
}
if (bKeyxStryIsUsed == FALSE)
{
snprintf(tok_str, sizeof(tok_str), "Key%dStr", idx + 1);
if (RTMPGetKeyParameter(tok_str, tmpbuf, 128, buffer, FALSE))
{
if (pAd->ApCfg.BssidNum == 1)
{
rtmp_parse_key_buffer_from_file(pAd, tmpbuf, KeyType[BSS0], BSS0, idx);
}
else
{
/* Anyway, we still do the legacy dissection of the whole KeyxStr string.*/
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
rtmp_parse_key_buffer_from_file(pAd, macptr, KeyType[i], i, idx);
}
}
}
}
}
}
#endif /* CONFIG_AP_SUPPORT */
#ifdef CONFIG_STA_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_STA(pAd)
{
snprintf(tok_str, sizeof(tok_str), "Key%dStr", idx + 1);
if (RTMPGetKeyParameter(tok_str, tmpbuf, 128, buffer, FALSE))
{
rtmp_parse_key_buffer_from_file(pAd, tmpbuf, KeyType[BSS0], BSS0, idx);
}
}
#endif /* CONFIG_STA_SUPPORT */
}
}
}
#ifdef CONFIG_AP_SUPPORT
#ifdef APCLI_SUPPORT
static void rtmp_read_ap_client_from_file(
IN PRTMP_ADAPTER pAd,
IN PSTRING tmpbuf,
IN PSTRING buffer)
{
PSTRING macptr = NULL;
INT i=0, j=0, idx;
UCHAR macAddress[MAC_ADDR_LEN];
/*UCHAR keyMaterial[40];*/
PAPCLI_STRUCT pApCliEntry = NULL;
ULONG KeyIdx;
STRING tok_str[16];
ULONG KeyType[MAX_APCLI_NUM];
ULONG KeyLen;
/*UCHAR CipherAlg = CIPHER_WEP64;*/
NdisZeroMemory(KeyType, sizeof(KeyType));
/*ApCliEnable*/
if(RTMPGetKeyParameter("ApCliEnable", tmpbuf, 128, buffer, TRUE))
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); (macptr && i < MAX_APCLI_NUM); macptr = rstrtok(NULL,";"), i++)
{
pApCliEntry = &pAd->ApCfg.ApCliTab[i];
if ((strncmp(macptr, "0", 1) == 0))
pApCliEntry->Enable = FALSE;
else if ((strncmp(macptr, "1", 1) == 0))
pApCliEntry->Enable = TRUE;
else
pApCliEntry->Enable = FALSE;
if (pApCliEntry->Enable)
{
/*pApCliEntry->WpaState = SS_NOTUSE;*/
/*pApCliEntry->PortSecured = WPA_802_1X_PORT_NOT_SECURED;*/
/*NdisZeroMemory(pApCliEntry->ReplayCounter, LEN_KEY_DESC_REPLAY); */
}
DBGPRINT(RT_DEBUG_TRACE, ("ApCliEntry[%d].Enable=%d\n", i, pApCliEntry->Enable));
}
}
/*ApCliSsid*/
if(RTMPGetKeyParameter("ApCliSsid", tmpbuf, MAX_PARAM_BUFFER_SIZE, buffer, FALSE))
{
for (i=0, macptr = rstrtok(tmpbuf,";"); (macptr && i < MAX_APCLI_NUM); macptr = rstrtok(NULL,";"), i++)
{
pApCliEntry = &pAd->ApCfg.ApCliTab[i];
/*Ssid acceptable strlen must be less than 32 and bigger than 0.*/
pApCliEntry->CfgSsidLen = (UCHAR)strlen(macptr);
if (pApCliEntry->CfgSsidLen > 32)
{
pApCliEntry->CfgSsidLen = 0;
continue;
}
if(pApCliEntry->CfgSsidLen > 0)
{
memcpy(&pApCliEntry->CfgSsid, macptr, pApCliEntry->CfgSsidLen);
pApCliEntry->Valid = FALSE;/* it should be set when successfuley association*/
} else
{
NdisZeroMemory(&(pApCliEntry->CfgSsid), MAX_LEN_OF_SSID);
continue;
}
DBGPRINT(RT_DEBUG_TRACE, ("ApCliEntry[%d].CfgSsidLen=%d, CfgSsid=%s\n", i, pApCliEntry->CfgSsidLen, pApCliEntry->CfgSsid));
}
}
/*ApCliBssid*/
if(RTMPGetKeyParameter("ApCliBssid", tmpbuf, MAX_PARAM_BUFFER_SIZE, buffer, TRUE))
{
for (i=0, macptr = rstrtok(tmpbuf,";"); (macptr && i < MAX_APCLI_NUM); macptr = rstrtok(NULL,";"), i++)
{
pApCliEntry = &pAd->ApCfg.ApCliTab[i];
if(strlen(macptr) != 17) /*Mac address acceptable format 01:02:03:04:05:06 length 17*/
continue;
if(strcmp(macptr,"00:00:00:00:00:00") == 0)
continue;
for (j=0; j<ETH_LENGTH_OF_ADDRESS; j++)
{
AtoH(macptr, &macAddress[j], 1);
macptr=macptr+3;
}
memcpy(pApCliEntry->CfgApCliBssid, &macAddress, ETH_LENGTH_OF_ADDRESS);
pApCliEntry->Valid = FALSE;/* it should be set when successfuley association*/
}
}
/*ApCliAuthMode*/
if (RTMPGetKeyParameter("ApCliAuthMode", tmpbuf, 255, buffer, TRUE))
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); (macptr && i < MAX_APCLI_NUM); macptr = rstrtok(NULL,";"), i++)
{
pApCliEntry = &pAd->ApCfg.ApCliTab[i];
if ((strncmp(macptr, "WEPAUTO", 7) == 0) || (strncmp(macptr, "wepauto", 7) == 0))
pApCliEntry->AuthMode = Ndis802_11AuthModeAutoSwitch;
else if ((strncmp(macptr, "SHARED", 6) == 0) || (strncmp(macptr, "shared", 6) == 0))
pApCliEntry->AuthMode = Ndis802_11AuthModeShared;
else if ((strncmp(macptr, "WPAPSK", 6) == 0) || (strncmp(macptr, "wpapsk", 6) == 0))
pApCliEntry->AuthMode = Ndis802_11AuthModeWPAPSK;
else if ((strncmp(macptr, "WPA2PSK", 7) == 0) || (strncmp(macptr, "wpa2psk", 7) == 0))
pApCliEntry->AuthMode = Ndis802_11AuthModeWPA2PSK;
else
pApCliEntry->AuthMode = Ndis802_11AuthModeOpen;
/*pApCliEntry->PortSecured = WPA_802_1X_PORT_NOT_SECURED;*/
DBGPRINT(RT_DEBUG_TRACE, ("I/F(apcli%d) ApCli_AuthMode=%d \n", i, pApCliEntry->AuthMode));
RTMPMakeRSNIE(pAd, pApCliEntry->AuthMode, pApCliEntry->WepStatus, (i + MIN_NET_DEVICE_FOR_APCLI));
}
}
/*ApCliEncrypType*/
if (RTMPGetKeyParameter("ApCliEncrypType", tmpbuf, 255, buffer, TRUE))
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); (macptr && i < MAX_APCLI_NUM); macptr = rstrtok(NULL,";"), i++)
{
pApCliEntry = &pAd->ApCfg.ApCliTab[i];
pApCliEntry->WepStatus = Ndis802_11WEPDisabled;
if ((strncmp(macptr, "WEP", 3) == 0) || (strncmp(macptr, "wep", 3) == 0))
{
if (pApCliEntry->AuthMode < Ndis802_11AuthModeWPA)
pApCliEntry->WepStatus = Ndis802_11WEPEnabled;
}
else if ((strncmp(macptr, "TKIP", 4) == 0) || (strncmp(macptr, "tkip", 4) == 0))
{
if (pApCliEntry->AuthMode >= Ndis802_11AuthModeWPA)
pApCliEntry->WepStatus = Ndis802_11Encryption2Enabled;
}
else if ((strncmp(macptr, "AES", 3) == 0) || (strncmp(macptr, "aes", 3) == 0))
{
if (pApCliEntry->AuthMode >= Ndis802_11AuthModeWPA)
pApCliEntry->WepStatus = Ndis802_11Encryption3Enabled;
}
else
{
pApCliEntry->WepStatus = Ndis802_11WEPDisabled;
}
pApCliEntry->PairCipher = pApCliEntry->WepStatus;
pApCliEntry->GroupCipher = pApCliEntry->WepStatus;
pApCliEntry->bMixCipher = FALSE;
/*pApCliEntry->PortSecured = WPA_802_1X_PORT_NOT_SECURED;*/
DBGPRINT(RT_DEBUG_TRACE, ("I/F(apcli%d) APCli_EncrypType = %d \n", i, pApCliEntry->WepStatus));
RTMPMakeRSNIE(pAd, pApCliEntry->AuthMode, pApCliEntry->WepStatus, (i + MIN_NET_DEVICE_FOR_APCLI));
}
}
/*ApCliWPAPSK*/
if (RTMPGetKeyParameter("ApCliWPAPSK", tmpbuf, 255, buffer, FALSE))
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); (macptr && i < MAX_APCLI_NUM); macptr = rstrtok(NULL,";"), i++)
{
int retval = TRUE;
pApCliEntry = &pAd->ApCfg.ApCliTab[i];
if((strlen(macptr) < 8) || (strlen(macptr) > 64))
{
DBGPRINT(RT_DEBUG_ERROR, ("APCli_WPAPSK_KEY, key string required 8 ~ 64 characters!!!\n"));
continue;
}
NdisMoveMemory(pApCliEntry->PSK, macptr, strlen(macptr));
pApCliEntry->PSKLen = strlen(macptr);
DBGPRINT(RT_DEBUG_TRACE, ("I/F(apcli%d) APCli_WPAPSK_KEY=%s, Len=%d\n", i, pApCliEntry->PSK, pApCliEntry->PSKLen));
if ((pApCliEntry->AuthMode != Ndis802_11AuthModeWPAPSK) &&
(pApCliEntry->AuthMode != Ndis802_11AuthModeWPA2PSK))
{
retval = FALSE;
}
{
retval = RT_CfgSetWPAPSKKey(pAd, macptr, strlen(macptr), (PUCHAR)pApCliEntry->CfgSsid, (INT)pApCliEntry->CfgSsidLen, pApCliEntry->PMK);
}
if (retval == TRUE)
{
/* Start STA supplicant WPA state machine*/
DBGPRINT(RT_DEBUG_TRACE, ("Start AP-client WPAPSK state machine \n"));
/*pApCliEntry->WpaState = SS_START; */
}
/*RTMPMakeRSNIE(pAd, pApCliEntry->AuthMode, pApCliEntry->WepStatus, (i + MIN_NET_DEVICE_FOR_APCLI)); */
#ifdef DBG
DBGPRINT(RT_DEBUG_TRACE, ("I/F(apcli%d) PMK Material => \n", i));
for (j = 0; j < 32; j++)
{
DBGPRINT(RT_DEBUG_OFF, ("%02x:", pApCliEntry->PMK[j]));
if ((j%16) == 15)
DBGPRINT(RT_DEBUG_OFF, ("\n"));
}
DBGPRINT(RT_DEBUG_OFF,("\n"));
#endif
}
}
/*ApCliDefaultKeyID*/
if (RTMPGetKeyParameter("ApCliDefaultKeyID", tmpbuf, 255, buffer, TRUE))
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); (macptr && i < MAX_APCLI_NUM); macptr = rstrtok(NULL,";"), i++)
{
pApCliEntry = &pAd->ApCfg.ApCliTab[i];
KeyIdx = simple_strtol(macptr, 0, 10);
if((KeyIdx >= 1 ) && (KeyIdx <= 4))
pApCliEntry->DefaultKeyId = (UCHAR) (KeyIdx - 1);
else
pApCliEntry->DefaultKeyId = 0;
DBGPRINT(RT_DEBUG_TRACE, ("I/F(apcli%d) DefaultKeyID(0~3)=%d\n", i, pApCliEntry->DefaultKeyId));
}
}
/*ApCliKeyXType, ApCliKeyXStr*/
for (idx=0; idx<4; idx++)
{
snprintf(tok_str, sizeof(tok_str), "ApCliKey%dType", idx+1);
/*ApCliKey1Type*/
if(RTMPGetKeyParameter(tok_str, tmpbuf, 128, buffer, TRUE))
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); (macptr && i < MAX_APCLI_NUM); macptr = rstrtok(NULL,";"), i++)
{
KeyType[i] = simple_strtol(macptr, 0, 10);
}
snprintf(tok_str, sizeof(tok_str), "ApCliKey%dStr", idx+1);
/*ApCliKey1Str*/
if(RTMPGetKeyParameter(tok_str, tmpbuf, 512, buffer, FALSE))
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); (macptr && i < MAX_APCLI_NUM); macptr = rstrtok(NULL,";"), i++)
{
pApCliEntry = &pAd->ApCfg.ApCliTab[i];
KeyLen = strlen(macptr);
if(((KeyType[i] == 0) && (KeyLen != 10) && (KeyLen != 26)) ||
((KeyType[i] != 0) && (KeyLen != 5) && (KeyLen != 13)))
{
DBGPRINT(RT_DEBUG_ERROR, ("I/F(apcli%d) Key%dStr is Invalid key length!\n", i, idx+1));
}
else
{
if (RT_CfgSetWepKey(pAd, macptr, &pApCliEntry->SharedKey[idx], idx) != TRUE)
DBGPRINT(RT_DEBUG_ERROR, ("RT_CfgSetWepKey fail!\n"));
}
}
}
}
}
/* ApCliTxMode*/
if (RTMPGetKeyParameter("ApCliTxMode", tmpbuf, 25, buffer, TRUE))
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); (macptr && i < MAX_APCLI_NUM); macptr = rstrtok(NULL,";"), i++)
{
pApCliEntry = &pAd->ApCfg.ApCliTab[i];
pApCliEntry->DesiredTransmitSetting.field.FixedTxMode =
RT_CfgSetFixedTxPhyMode(macptr);
DBGPRINT(RT_DEBUG_TRACE, ("I/F(apcli%d) Tx Mode = %d\n", i,
pApCliEntry->DesiredTransmitSetting.field.FixedTxMode));
}
}
/* ApCliTxMcs*/
if (RTMPGetKeyParameter("ApCliTxMcs", tmpbuf, 50, buffer, TRUE))
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); (macptr && i < MAX_APCLI_NUM); macptr = rstrtok(NULL,";"), i++)
{
pApCliEntry = &pAd->ApCfg.ApCliTab[i];
pApCliEntry->DesiredTransmitSetting.field.MCS =
RT_CfgSetTxMCSProc(macptr, &pApCliEntry->bAutoTxRateSwitch);
DBGPRINT(RT_DEBUG_TRACE, ("I/F(apcli%d) Tx MCS = %s(%d)\n", i,
(pApCliEntry->DesiredTransmitSetting.field.MCS == MCS_AUTO ? "AUTO" : ""),
pApCliEntry->DesiredTransmitSetting.field.MCS));
}
}
#ifdef WSC_AP_SUPPORT
/* Wsc4digitPinCode = TRUE use 4-digit Pin code, otherwise 8-digit Pin code */
if (RTMPGetKeyParameter("ApCli_Wsc4digitPinCode", tmpbuf, 32, buffer, TRUE))
{
if (simple_strtol(macptr, 0, 10) != 0) //Enable
pAd->ApCfg.ApCliTab[0].WscControl.WscEnrollee4digitPinCode = TRUE;
else //Disable
pAd->ApCfg.ApCliTab[0].WscControl.WscEnrollee4digitPinCode = FALSE;
DBGPRINT(RT_DEBUG_TRACE, ("I/F(apcli%d) ApCli_Wsc4digitPinCode=%d\n", i, pAd->ApCfg.ApCliTab[0].WscControl.WscEnrollee4digitPinCode));
}
#endif /* WSC_AP_SUPPORT */
#ifdef UAPSD_SUPPORT
/*APSDCapable*/
if(RTMPGetKeyParameter("ApCliAPSDCapable", tmpbuf, 10, buffer, TRUE))
{
pAd->ApCfg.FlgApCliIsUapsdInfoUpdated = TRUE;
for (i = 0, macptr = rstrtok(tmpbuf,";");
(macptr && i < MAX_APCLI_NUM);
macptr = rstrtok(NULL,";"), i++)
{
pApCliEntry = &pAd->ApCfg.ApCliTab[i];
pApCliEntry->UapsdInfo.bAPSDCapable = \
(UCHAR) simple_strtol(macptr, 0, 10);
DBGPRINT(RT_DEBUG_ERROR, ("ApCliAPSDCapable[%d]=%d\n", i,
pApCliEntry->UapsdInfo.bAPSDCapable));
}
}
#endif /* UAPSD_SUPPORT */
}
#endif /* APCLI_SUPPORT */
static void rtmp_read_acl_parms_from_file(IN PRTMP_ADAPTER pAd, PSTRING tmpbuf, PSTRING buffer)
{
STRING tok_str[32];
PSTRING macptr;
INT i=0, j=0, idx;
UCHAR macAddress[MAC_ADDR_LEN];
memset(macAddress, 0, MAC_ADDR_LEN);
for (idx=0; idx<MAX_MBSSID_NUM(pAd); idx++)
{
memset(&pAd->ApCfg.MBSSID[idx].AccessControlList, 0, sizeof(RT_802_11_ACL));
/* AccessPolicyX*/
snprintf(tok_str, sizeof(tok_str), "AccessPolicy%d", idx);
if (RTMPGetKeyParameter(tok_str, tmpbuf, 10, buffer, TRUE))
{
switch (simple_strtol(tmpbuf, 0, 10))
{
case 1: /* Allow All, and the AccessControlList is positive now.*/
pAd->ApCfg.MBSSID[idx].AccessControlList.Policy = 1;
break;
case 2: /* Reject All, and the AccessControlList is negative now.*/
pAd->ApCfg.MBSSID[idx].AccessControlList.Policy = 2;
break;
case 0: /* Disable, don't care the AccessControlList.*/
default:
pAd->ApCfg.MBSSID[idx].AccessControlList.Policy = 0;
break;
}
DBGPRINT(RT_DEBUG_TRACE, ("%s=%ld\n", tok_str, pAd->ApCfg.MBSSID[idx].AccessControlList.Policy));
}
/* AccessControlListX*/
snprintf(tok_str, sizeof(tok_str), "AccessControlList%d", idx);
if (RTMPGetKeyParameter(tok_str, tmpbuf, MAX_PARAM_BUFFER_SIZE, buffer, TRUE))
{
for (i=0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
if (strlen(macptr) != 17) /* Mac address acceptable format 01:02:03:04:05:06 length 17*/
continue;
ASSERT(pAd->ApCfg.MBSSID[idx].AccessControlList.Num <= MAX_NUM_OF_ACL_LIST);
for (j=0; j<ETH_LENGTH_OF_ADDRESS; j++)
{
AtoH(macptr, &macAddress[j], 1);
macptr=macptr+3;
}
if (pAd->ApCfg.MBSSID[idx].AccessControlList.Num == MAX_NUM_OF_ACL_LIST)
{
DBGPRINT(RT_DEBUG_WARN, ("The AccessControlList is full, and no more entry can join the list!\n"));
DBGPRINT(RT_DEBUG_WARN, ("The last entry of ACL is %02x:%02x:%02x:%02x:%02x:%02x\n",
macAddress[0],macAddress[1],macAddress[2],macAddress[3],macAddress[4],macAddress[5]));
break;
}
pAd->ApCfg.MBSSID[idx].AccessControlList.Num++;
NdisMoveMemory(pAd->ApCfg.MBSSID[idx].AccessControlList.Entry[(pAd->ApCfg.MBSSID[idx].AccessControlList.Num - 1)].Addr, macAddress, ETH_LENGTH_OF_ADDRESS);
}
DBGPRINT(RT_DEBUG_TRACE, ("%s=Get %ld Mac Address\n", tok_str, pAd->ApCfg.MBSSID[idx].AccessControlList.Num));
}
}
}
/*
========================================================================
Routine Description:
In kernel mode read parameters from file
Arguments:
src the location of the file.
dest put the parameters to the destination.
Length size to read.
Return Value:
None
Note:
========================================================================
*/
static void rtmp_read_ap_wmm_parms_from_file(IN PRTMP_ADAPTER pAd, PSTRING tmpbuf, PSTRING buffer)
{
PSTRING macptr;
INT i=0;
/*WmmCapable*/
if(RTMPGetKeyParameter("WmmCapable", tmpbuf, 32, buffer, TRUE))
{
BOOLEAN bEnableWmm = FALSE;
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
if (i >= pAd->ApCfg.BssidNum)
{
break;
}
if(simple_strtol(macptr, 0, 10) != 0)
{
pAd->ApCfg.MBSSID[i].bWmmCapable = TRUE;
bEnableWmm = TRUE;
}
else
{
pAd->ApCfg.MBSSID[i].bWmmCapable = FALSE;
}
if (bEnableWmm)
{
pAd->CommonCfg.APEdcaParm.bValid = TRUE;
pAd->ApCfg.BssEdcaParm.bValid = TRUE;
}
else
{
pAd->CommonCfg.APEdcaParm.bValid = FALSE;
pAd->ApCfg.BssEdcaParm.bValid = FALSE;
}
pAd->ApCfg.MBSSID[i].bWmmCapableOrg = \
pAd->ApCfg.MBSSID[i].bWmmCapable;
DBGPRINT(RT_DEBUG_TRACE, ("I/F(ra%d) WmmCapable=%d\n", i, pAd->ApCfg.MBSSID[i].bWmmCapable));
}
}
/*DLSCapable*/
if(RTMPGetKeyParameter("DLSCapable", tmpbuf, 32, buffer, TRUE))
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
if (i >= pAd->ApCfg.BssidNum)
{
break;
}
if(simple_strtol(macptr, 0, 10) != 0) /*Enable*/
{
pAd->ApCfg.MBSSID[i].bDLSCapable = TRUE;
}
else /*Disable*/
{
pAd->ApCfg.MBSSID[i].bDLSCapable = FALSE;
}
DBGPRINT(RT_DEBUG_TRACE, ("I/F(ra%d) DLSCapable=%d\n", i, pAd->ApCfg.MBSSID[i].bDLSCapable));
}
}
/*APAifsn*/
if(RTMPGetKeyParameter("APAifsn", tmpbuf, 32, buffer, TRUE))
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
pAd->CommonCfg.APEdcaParm.Aifsn[i] = (UCHAR) simple_strtol(macptr, 0, 10);;
DBGPRINT(RT_DEBUG_TRACE, ("APAifsn[%d]=%d\n", i, pAd->CommonCfg.APEdcaParm.Aifsn[i]));
}
}
/*APCwmin*/
if(RTMPGetKeyParameter("APCwmin", tmpbuf, 32, buffer, TRUE))
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
pAd->CommonCfg.APEdcaParm.Cwmin[i] = (UCHAR) simple_strtol(macptr, 0, 10);;
DBGPRINT(RT_DEBUG_TRACE, ("APCwmin[%d]=%d\n", i, pAd->CommonCfg.APEdcaParm.Cwmin[i]));
}
}
/*APCwmax*/
if(RTMPGetKeyParameter("APCwmax", tmpbuf, 32, buffer, TRUE))
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
pAd->CommonCfg.APEdcaParm.Cwmax[i] = (UCHAR) simple_strtol(macptr, 0, 10);;
DBGPRINT(RT_DEBUG_TRACE, ("APCwmax[%d]=%d\n", i, pAd->CommonCfg.APEdcaParm.Cwmax[i]));
}
}
/*APTxop*/
if(RTMPGetKeyParameter("APTxop", tmpbuf, 32, buffer, TRUE))
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
pAd->CommonCfg.APEdcaParm.Txop[i] = (USHORT) simple_strtol(macptr, 0, 10);;
DBGPRINT(RT_DEBUG_TRACE, ("APTxop[%d]=%d\n", i, pAd->CommonCfg.APEdcaParm.Txop[i]));
}
}
/*APACM*/
if(RTMPGetKeyParameter("APACM", tmpbuf, 32, buffer, TRUE))
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
pAd->CommonCfg.APEdcaParm.bACM[i] = (BOOLEAN) simple_strtol(macptr, 0, 10);;
DBGPRINT(RT_DEBUG_TRACE, ("APACM[%d]=%d\n", i, pAd->CommonCfg.APEdcaParm.bACM[i]));
}
}
/*BSSAifsn*/
if(RTMPGetKeyParameter("BSSAifsn", tmpbuf, 32, buffer, TRUE))
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
pAd->ApCfg.BssEdcaParm.Aifsn[i] = (UCHAR) simple_strtol(macptr, 0, 10);;
DBGPRINT(RT_DEBUG_TRACE, ("BSSAifsn[%d]=%d\n", i, pAd->ApCfg.BssEdcaParm.Aifsn[i]));
}
}
/*BSSCwmin*/
if(RTMPGetKeyParameter("BSSCwmin", tmpbuf, 32, buffer, TRUE))
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
pAd->ApCfg.BssEdcaParm.Cwmin[i] = (UCHAR) simple_strtol(macptr, 0, 10);;
DBGPRINT(RT_DEBUG_TRACE, ("BSSCwmin[%d]=%d\n", i, pAd->ApCfg.BssEdcaParm.Cwmin[i]));
}
}
/*BSSCwmax*/
if(RTMPGetKeyParameter("BSSCwmax", tmpbuf, 32, buffer, TRUE))
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
pAd->ApCfg.BssEdcaParm.Cwmax[i] = (UCHAR) simple_strtol(macptr, 0, 10);;
DBGPRINT(RT_DEBUG_TRACE, ("BSSCwmax[%d]=%d\n", i, pAd->ApCfg.BssEdcaParm.Cwmax[i]));
}
}
/*BSSTxop*/
if(RTMPGetKeyParameter("BSSTxop", tmpbuf, 32, buffer, TRUE))
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
pAd->ApCfg.BssEdcaParm.Txop[i] = (USHORT) simple_strtol(macptr, 0, 10);;
DBGPRINT(RT_DEBUG_TRACE, ("BSSTxop[%d]=%d\n", i, pAd->ApCfg.BssEdcaParm.Txop[i]));
}
}
/*BSSACM*/
if(RTMPGetKeyParameter("BSSACM", tmpbuf, 32, buffer, TRUE))
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
pAd->ApCfg.BssEdcaParm.bACM[i] = (BOOLEAN) simple_strtol(macptr, 0, 10);;
DBGPRINT(RT_DEBUG_TRACE, ("BSSACM[%d]=%d\n", i, pAd->ApCfg.BssEdcaParm.bACM[i]));
}
}
/*AckPolicy*/
if(RTMPGetKeyParameter("AckPolicy", tmpbuf, 32, buffer, TRUE))
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
pAd->CommonCfg.AckPolicy[i] = (UCHAR) simple_strtol(macptr, 0, 10);;
DBGPRINT(RT_DEBUG_TRACE, ("AckPolicy[%d]=%d\n", i, pAd->CommonCfg.AckPolicy[i]));
}
}
#ifdef UAPSD_SUPPORT
/*APSDCapable*/
if(RTMPGetKeyParameter("APSDCapable", tmpbuf, 10, buffer, TRUE))
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
if (i < HW_BEACON_MAX_NUM)
{
pAd->ApCfg.MBSSID[i].UapsdInfo.bAPSDCapable = \
(UCHAR) simple_strtol(macptr, 0, 10);
DBGPRINT(RT_DEBUG_ERROR, ("APSDCapable[%d]=%d\n", i,
pAd->ApCfg.MBSSID[i].UapsdInfo.bAPSDCapable));
}
}
if (i == 1)
{
/*
Old format in UAPSD settings: only 1 parameter
i.e. UAPSD for all BSS is enabled or disabled.
*/
for(i=1; i<HW_BEACON_MAX_NUM; i++)
{
pAd->ApCfg.MBSSID[i].UapsdInfo.bAPSDCapable =
pAd->ApCfg.MBSSID[0].UapsdInfo.bAPSDCapable;
DBGPRINT(RT_DEBUG_ERROR, ("APSDCapable[%d]=%d\n", i,
pAd->ApCfg.MBSSID[i].UapsdInfo.bAPSDCapable));
}
}
#ifdef APCLI_SUPPORT
if (pAd->ApCfg.FlgApCliIsUapsdInfoUpdated == FALSE)
{
/*
Backward:
All UAPSD for AP Client interface is same as MBSS0
when we can not find "ApCliAPSDCapable".
When we find "ApCliAPSDCapable" hereafter, we will over-write.
*/
for(i=0; i<MAX_APCLI_NUM; i++)
{
pAd->ApCfg.ApCliTab[i].UapsdInfo.bAPSDCapable = \
pAd->ApCfg.MBSSID[0].UapsdInfo.bAPSDCapable;
DBGPRINT(RT_DEBUG_ERROR, ("default ApCliAPSDCapable[%d]=%d\n",
i, pAd->ApCfg.ApCliTab[i].UapsdInfo.bAPSDCapable));
}
}
#endif /* APCLI_SUPPORT */
}
#endif /* UAPSD_SUPPORT */
}
#ifdef DOT1X_SUPPORT
/*
========================================================================
Routine Description:
In kernel mode read parameters from file
Arguments:
src the location of the file.
dest put the parameters to the destination.
Length size to read.
Return Value:
None
Note:
========================================================================
*/
static void rtmp_read_radius_parms_from_file(IN PRTMP_ADAPTER pAd, PSTRING tmpbuf, PSTRING buffer)
{
STRING tok_str[16];
PSTRING macptr;
UINT32 ip_addr;
INT i=0;
BOOLEAN bUsePrevFormat = FALSE;
USHORT offset;
INT count[HW_BEACON_MAX_NUM];
/* own_ip_addr*/
if (RTMPGetKeyParameter("own_ip_addr", tmpbuf, 32, buffer, TRUE))
{
Set_OwnIPAddr_Proc(pAd, tmpbuf);
}
/* session_timeout_interval*/
if (RTMPGetKeyParameter("session_timeout_interval", tmpbuf, 32, buffer, TRUE))
{
pAd->ApCfg.session_timeout_interval = simple_strtol(tmpbuf, 0, 10);
DBGPRINT(RT_DEBUG_TRACE, ("session_timeout_interval=%d\n", pAd->ApCfg.session_timeout_interval));
}
/* quiet_interval*/
if (RTMPGetKeyParameter("quiet_interval", tmpbuf, 32, buffer, TRUE))
{
pAd->ApCfg.quiet_interval = simple_strtol(tmpbuf, 0, 10);
DBGPRINT(RT_DEBUG_TRACE, ("quiet_interval=%d\n", pAd->ApCfg.quiet_interval));
}
/* EAPifname*/
if (RTMPGetKeyParameter("EAPifname", tmpbuf, 256, buffer, TRUE))
{
Set_EAPIfName_Proc(pAd, tmpbuf);
}
/* PreAuthifname*/
if (RTMPGetKeyParameter("PreAuthifname", tmpbuf, 256, buffer, TRUE))
{
Set_PreAuthIfName_Proc(pAd, tmpbuf);
}
/*PreAuth*/
if(RTMPGetKeyParameter("PreAuth", tmpbuf, 10, buffer, TRUE))
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
if (i >= pAd->ApCfg.BssidNum)
break;
if(simple_strtol(macptr, 0, 10) != 0) /*Enable*/
pAd->ApCfg.MBSSID[i].PreAuth = TRUE;
else /*Disable*/
pAd->ApCfg.MBSSID[i].PreAuth = FALSE;
DBGPRINT(RT_DEBUG_TRACE, ("I/F(ra%d) PreAuth=%d\n", i, pAd->ApCfg.MBSSID[i].PreAuth));
}
}
/*IEEE8021X*/
if(RTMPGetKeyParameter("IEEE8021X", tmpbuf, 10, buffer, TRUE))
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
if (i >= pAd->ApCfg.BssidNum)
break;
if(simple_strtol(macptr, 0, 10) != 0) /*Enable*/
pAd->ApCfg.MBSSID[i].IEEE8021X = TRUE;
else /*Disable*/
pAd->ApCfg.MBSSID[i].IEEE8021X = FALSE;
DBGPRINT(RT_DEBUG_TRACE, ("IF(ra%d), IEEE8021X=%d\n", i, pAd->ApCfg.MBSSID[i].IEEE8021X));
}
}
/* RADIUS_Server*/
offset = 0;
/*if (RTMPGetKeyParameter("RADIUS_Server", tmpbuf, 256, buffer, TRUE))*/
while (RTMPGetKeyParameterWithOffset("RADIUS_Server", tmpbuf, &offset, 256, buffer, TRUE))
{
for (i=0, macptr = rstrtok(tmpbuf,";"); (macptr && i < MAX_MBSSID_NUM(pAd)); macptr = rstrtok(NULL,";"), i++)
{
if (rtinet_aton(macptr, &ip_addr) && pAd->ApCfg.MBSSID[i].radius_srv_num < MAX_RADIUS_SRV_NUM)
{
INT srv_idx = pAd->ApCfg.MBSSID[i].radius_srv_num;
pAd->ApCfg.MBSSID[i].radius_srv_info[srv_idx].radius_ip = ip_addr;
pAd->ApCfg.MBSSID[i].radius_srv_num++;
DBGPRINT(RT_DEBUG_TRACE, ("IF(ra%d), radius_ip(seq-%d)=%s(%x)\n", i, pAd->ApCfg.MBSSID[i].radius_srv_num, macptr, pAd->ApCfg.MBSSID[i].radius_srv_info[srv_idx].radius_ip));
}
}
}
/* RADIUS_Port*/
/*if (RTMPGetKeyParameter("RADIUS_Port", tmpbuf, 128, buffer, TRUE))*/
offset = 0;
memset(&count[0], 0, sizeof(count));
while (RTMPGetKeyParameterWithOffset("RADIUS_Port", tmpbuf, &offset, 128, buffer, TRUE))
{
for (i=0, macptr = rstrtok(tmpbuf,";"); (macptr && i < MAX_MBSSID_NUM(pAd)); macptr = rstrtok(NULL,";"), i++)
{
if (count[i] < pAd->ApCfg.MBSSID[i].radius_srv_num)
{
INT srv_idx = count[i];
pAd->ApCfg.MBSSID[i].radius_srv_info[srv_idx].radius_port = (UINT32) simple_strtol(macptr, 0, 10);
count[i] ++;
DBGPRINT(RT_DEBUG_TRACE, ("IF(ra%d), radius_port(seq-%d)=%d\n", i, count[i], pAd->ApCfg.MBSSID[i].radius_srv_info[srv_idx].radius_port));
}
}
}
/* RADIUS_Key*/
/*if (RTMPGetKeyParameter("RADIUS_Key", tmpbuf, 640, buffer, FALSE))*/
offset = 0;
memset(&count[0], 0, sizeof(count));
while (RTMPGetKeyParameterWithOffset("RADIUS_Key", tmpbuf, &offset, 640, buffer, FALSE))
{
if (strlen(tmpbuf) > 0)
bUsePrevFormat = TRUE;
for (i=0, macptr = rstrtok(tmpbuf,";"); (macptr && i < MAX_MBSSID_NUM(pAd)); macptr = rstrtok(NULL,";"), i++)
{
if (strlen(macptr) > 0 && (count[i] < pAd->ApCfg.MBSSID[i].radius_srv_num))
{
INT srv_idx = count[i];
pAd->ApCfg.MBSSID[i].radius_srv_info[srv_idx].radius_key_len = strlen(macptr);
NdisMoveMemory(pAd->ApCfg.MBSSID[i].radius_srv_info[srv_idx].radius_key, macptr, strlen(macptr));
count[i] ++;
DBGPRINT(RT_DEBUG_TRACE, ("IF(ra%d), radius_key(seq-%d)=%s, len=%d\n", i,
count[i],
pAd->ApCfg.MBSSID[i].radius_srv_info[srv_idx].radius_key,
pAd->ApCfg.MBSSID[i].radius_srv_info[srv_idx].radius_key_len));
}
}
}
/* NasIdX, X indicate the interface index(1~8) */
for (i = 0; i < pAd->ApCfg.BssidNum; i++)
{
snprintf(tok_str, sizeof(tok_str), "NasId%d", i + 1);
if (RTMPGetKeyParameter(tok_str, tmpbuf, 33, buffer, FALSE))
{
if (strlen(tmpbuf) > 0)
{
pAd->ApCfg.MBSSID[i].NasIdLen = strlen(tmpbuf);
NdisMoveMemory(pAd->ApCfg.MBSSID[i].NasId, tmpbuf, strlen(tmpbuf));
DBGPRINT(RT_DEBUG_TRACE, ("IF-ra%d NAS-ID=%s, len=%d\n", i,
pAd->ApCfg.MBSSID[i].NasId,
pAd->ApCfg.MBSSID[i].NasIdLen));
}
}
}
if (!bUsePrevFormat)
{
for (i = 0; i < MAX_MBSSID_NUM(pAd); i++)
{
INT srv_idx = 0;
snprintf(tok_str, sizeof(tok_str), "RADIUS_Key%d", i + 1);
/* RADIUS_KeyX (X=1~MAX_MBSSID_NUM)*/
/*if (RTMPGetKeyParameter(tok_str, tmpbuf, 128, buffer, FALSE)) */
offset = 0;
while (RTMPGetKeyParameterWithOffset(tok_str, tmpbuf, &offset, 128, buffer, FALSE))
{
if (strlen(tmpbuf) > 0 && (srv_idx < pAd->ApCfg.MBSSID[i].radius_srv_num))
{
pAd->ApCfg.MBSSID[i].radius_srv_info[srv_idx].radius_key_len = strlen(tmpbuf);
NdisMoveMemory(pAd->ApCfg.MBSSID[i].radius_srv_info[srv_idx].radius_key, tmpbuf, strlen(tmpbuf));
DBGPRINT(RT_DEBUG_TRACE, ("IF(ra%d), update radius_key(seq-%d)=%s, len=%d\n", i, srv_idx+1,
pAd->ApCfg.MBSSID[i].radius_srv_info[srv_idx].radius_key,
pAd->ApCfg.MBSSID[i].radius_srv_info[srv_idx].radius_key_len));
srv_idx ++;
}
}
}
}
}
#endif /* DOT1X_SUPPORT */
static int rtmp_parse_wpapsk_buffer_from_file(IN PRTMP_ADAPTER pAd,IN PSTRING buffer,IN INT BSSIdx)
{
PSTRING tmpbuf = buffer;
INT i = BSSIdx;
/*UCHAR keyMaterial[40];*/
ULONG len = strlen(tmpbuf);
int ret = 0;
DBGPRINT(RT_DEBUG_TRACE, ("I/F(ra%d) WPAPSK_KEY=%s\n", i, tmpbuf));
ret = RT_CfgSetWPAPSKKey(pAd, tmpbuf, len, (PUCHAR)pAd->ApCfg.MBSSID[i].Ssid, pAd->ApCfg.MBSSID[i].SsidLen, pAd->ApCfg.MBSSID[i].PMK);
if (ret == FALSE)
return FALSE;
#ifdef WSC_AP_SUPPORT
NdisZeroMemory(pAd->ApCfg.MBSSID[i].WscControl.WpaPsk, 64);
pAd->ApCfg.MBSSID[i].WscControl.WpaPskLen = 0;
if ((len >= 8) && (len <= 64))
{
NdisMoveMemory(pAd->ApCfg.MBSSID[i].WscControl.WpaPsk, tmpbuf, len);
pAd->ApCfg.MBSSID[i].WscControl.WpaPskLen = len;
}
#endif /* WSC_AP_SUPPORT */
return ret;
}
#endif /* CONFIG_AP_SUPPORT */
#ifdef CONFIG_STA_SUPPORT
static void rtmp_read_sta_wmm_parms_from_file(IN PRTMP_ADAPTER pAd, char *tmpbuf, char *buffer)
{
PSTRING macptr;
INT i=0;
BOOLEAN bWmmEnable = FALSE;
/*WmmCapable*/
if(RTMPGetKeyParameter("WmmCapable", tmpbuf, 32, buffer, TRUE))
{
if(simple_strtol(tmpbuf, 0, 10) != 0) /*Enable*/
{
pAd->CommonCfg.bWmmCapable = TRUE;
bWmmEnable = TRUE;
}
else /*Disable*/
{
pAd->CommonCfg.bWmmCapable = FALSE;
}
DBGPRINT(RT_DEBUG_TRACE, ("WmmCapable=%d\n", pAd->CommonCfg.bWmmCapable));
}
#ifdef QOS_DLS_SUPPORT
/*DLSCapable*/
if(RTMPGetKeyParameter("DLSCapable", tmpbuf, 32, buffer, TRUE))
{
if(simple_strtol(tmpbuf, 0, 10) != 0) /*Enable*/
{
pAd->CommonCfg.bDLSCapable = TRUE;
}
else /*Disable*/
{
pAd->CommonCfg.bDLSCapable = FALSE;
}
DBGPRINT(RT_DEBUG_TRACE, ("bDLSCapable=%d\n", pAd->CommonCfg.bDLSCapable));
}
#endif /* QOS_DLS_SUPPORT */
/*AckPolicy for AC_BK, AC_BE, AC_VI, AC_VO*/
if(RTMPGetKeyParameter("AckPolicy", tmpbuf, 32, buffer, TRUE))
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
pAd->CommonCfg.AckPolicy[i] = (UCHAR)simple_strtol(macptr, 0, 10);
DBGPRINT(RT_DEBUG_TRACE, ("AckPolicy[%d]=%d\n", i, pAd->CommonCfg.AckPolicy[i]));
}
}
#ifdef UAPSD_SUPPORT
if (bWmmEnable)
{
/*APSDCapable*/
if(RTMPGetKeyParameter("APSDCapable", tmpbuf, 10, buffer, TRUE))
{
if(simple_strtol(tmpbuf, 0, 10) != 0) /*Enable*/
pAd->StaCfg.UapsdInfo.bAPSDCapable = TRUE;
else
pAd->StaCfg.UapsdInfo.bAPSDCapable = FALSE;
DBGPRINT(RT_DEBUG_TRACE, ("APSDCapable=%d\n", pAd->StaCfg.UapsdInfo.bAPSDCapable));
}
/*MaxSPLength*/
if(RTMPGetKeyParameter("MaxSPLength", tmpbuf, 10, buffer, TRUE))
{
pAd->CommonCfg.MaxSPLength = simple_strtol(tmpbuf, 0, 10);
DBGPRINT(RT_DEBUG_TRACE, ("MaxSPLength=%d\n", pAd->CommonCfg.MaxSPLength));
}
/*APSDAC for AC_BE, AC_BK, AC_VI, AC_VO*/
if(RTMPGetKeyParameter("APSDAC", tmpbuf, 32, buffer, TRUE))
{
BOOLEAN apsd_ac[4];
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
apsd_ac[i] = (BOOLEAN)simple_strtol(macptr, 0, 10);
DBGPRINT(RT_DEBUG_TRACE, ("APSDAC%d %d\n", i, apsd_ac[i]));
}
pAd->CommonCfg.bAPSDAC_BE = apsd_ac[0];
pAd->CommonCfg.bAPSDAC_BK = apsd_ac[1];
pAd->CommonCfg.bAPSDAC_VI = apsd_ac[2];
pAd->CommonCfg.bAPSDAC_VO = apsd_ac[3];
pAd->CommonCfg.bACMAPSDTr[0] = apsd_ac[0];
pAd->CommonCfg.bACMAPSDTr[1] = apsd_ac[1];
pAd->CommonCfg.bACMAPSDTr[2] = apsd_ac[2];
pAd->CommonCfg.bACMAPSDTr[3] = apsd_ac[3];
}
}
#endif /* UAPSD_SUPPORT */
}
#ifdef XLINK_SUPPORT
static void rtmp_get_psp_xlink_mode_from_file(IN PRTMP_ADAPTER pAd, char *tmpbuf, char *buffer)
{
UINT32 Value = 0;
/* Xlink Mode*/
if (RTMPGetKeyParameter("PSP_XLINK_MODE", tmpbuf, 32, buffer, TRUE))
{
if(simple_strtol(tmpbuf, 0, 10) != 0) /* enable*/
{
pAd->StaCfg.PSPXlink = TRUE;
}
else /* disable*/
{
pAd->StaCfg.PSPXlink = FALSE;
}
if (pAd->StaCfg.PSPXlink)
Value = PSPXLINK;
else
Value = STANORMAL;
RTMP_IO_WRITE32(pAd, RX_FILTR_CFG, Value);
DBGPRINT(RT_DEBUG_TRACE, ("PSP_XLINK_MODE=%d\n", pAd->StaCfg.PSPXlink));
}
}
#endif /* XLINK_SUPPORT */
#endif /* CONFIG_STA_SUPPORT */
#ifdef DOT11_VHT_AC
static void VHTParametersHook(
IN RTMP_ADAPTER *pAd,
IN PSTRING pValueStr,
IN PSTRING pInput)
{
long Value;
/* Channel Width */
if (RTMPGetKeyParameter("VHT_BW", pValueStr, 25, pInput, TRUE))
{
Value = simple_strtol(pValueStr, 0, 10);
if (Value == VHT_BW_80)
pAd->CommonCfg.vht_bw = VHT_BW_80;
else
pAd->CommonCfg.vht_bw = VHT_BW_2040;
DBGPRINT(RT_DEBUG_TRACE, ("VHT: Channel Width = %s\n", (Value==VHT_BW_80) ? "80 MHz" : "20/40 MHz" ));
}
}
#endif /* DOT11_VHT_AC */
#ifdef CUSTOMER_DEMO
void demo_mode_cfg(RTMP_ADAPTER *pAd)
{
int IdBss, i;
UCHAR cfg_mode;
pAd->CommonCfg.Channel = 40;
for (i = 0; i < pAd->ApCfg.BssidNum; i++)
{
cfg_mode = 14;
pAd->ApCfg.MBSSID[i].PhyMode = cfgmode_2_wmode(cfg_mode);
DBGPRINT(RT_DEBUG_TRACE, ("BSS%d PhyMode=%d\n", i, pAd->ApCfg.MBSSID[i].PhyMode));
if (i == 0)
{
/* for first time, update all phy mode is same as ra0 */
for(IdBss=1; IdBss<pAd->ApCfg.BssidNum; IdBss++)
pAd->ApCfg.MBSSID[IdBss].PhyMode = pAd->ApCfg.MBSSID[0].PhyMode;
/* set mode for 1st time */
RT_CfgSetWirelessMode(pAd, "14");
}
else
RT_CfgSetMbssWirelessMode(pAd, "14");
}
DBGPRINT(RT_DEBUG_TRACE, ("PhyMode=%d\n", pAd->CommonCfg.PhyMode));
pAd->CommonCfg.RegTransmitSetting.field.BW = BW_40;
pAd->CommonCfg.RegTransmitSetting.field.EXTCHA = EXTCHA_BELOW;
pAd->CommonCfg.vht_bw = VHT_BW_80;
}
#endif /* CUSTOMER_DEMO */
#ifdef DOT11_N_SUPPORT
static void HTParametersHook(
IN PRTMP_ADAPTER pAd,
IN PSTRING pValueStr,
IN PSTRING pInput)
{
long Value;
#ifdef CONFIG_AP_SUPPORT
INT i=0;
PSTRING Bufptr;
#endif /* CONFIG_AP_SUPPORT */
if (RTMPGetKeyParameter("HT_PROTECT", pValueStr, 25, pInput, TRUE))
{
Value = simple_strtol(pValueStr, 0, 10);
if (Value == 0)
{
pAd->CommonCfg.bHTProtect = FALSE;
}
else
{
pAd->CommonCfg.bHTProtect = TRUE;
}
DBGPRINT(RT_DEBUG_TRACE, ("HT: Protection = %s\n", (Value==0) ? "Disable" : "Enable"));
}
if (RTMPGetKeyParameter("HT_MIMOPSMode", pValueStr, 25, pInput, TRUE))
{
Value = simple_strtol(pValueStr, 0, 10);
if (Value > MMPS_ENABLE)
{
pAd->CommonCfg.BACapability.field.MMPSmode = MMPS_ENABLE;
}
else
{
/*TODO: add mimo power saving mechanism*/
pAd->CommonCfg.BACapability.field.MMPSmode = MMPS_ENABLE;
/*pAd->CommonCfg.BACapability.field.MMPSmode = Value;*/
}
DBGPRINT(RT_DEBUG_TRACE, ("HT: MIMOPS Mode = %d\n", (INT) Value));
}
if (RTMPGetKeyParameter("HT_BADecline", pValueStr, 25, pInput, TRUE))
{
Value = simple_strtol(pValueStr, 0, 10);
if (Value == 0)
{
pAd->CommonCfg.bBADecline = FALSE;
}
else
{
pAd->CommonCfg.bBADecline = TRUE;
}
DBGPRINT(RT_DEBUG_TRACE, ("HT: BA Decline = %s\n", (Value==0) ? "Disable" : "Enable"));
}
if (RTMPGetKeyParameter("HT_AutoBA", pValueStr, 25, pInput, TRUE))
{
Value = simple_strtol(pValueStr, 0, 10);
if (Value == 0)
{
pAd->CommonCfg.BACapability.field.AutoBA = FALSE;
pAd->CommonCfg.BACapability.field.Policy = BA_NOTUSE;
}
else
{
pAd->CommonCfg.BACapability.field.AutoBA = TRUE;
pAd->CommonCfg.BACapability.field.Policy = IMMED_BA;
}
pAd->CommonCfg.REGBACapability.field.AutoBA = pAd->CommonCfg.BACapability.field.AutoBA;
pAd->CommonCfg.REGBACapability.field.Policy = pAd->CommonCfg.BACapability.field.Policy;
DBGPRINT(RT_DEBUG_TRACE, ("HT: Auto BA = %s\n", (Value==0) ? "Disable" : "Enable"));
}
/* Tx_+HTC frame*/
if (RTMPGetKeyParameter("HT_HTC", pValueStr, 25, pInput, TRUE))
{
Value = simple_strtol(pValueStr, 0, 10);
if (Value == 0)
{
pAd->HTCEnable = FALSE;
}
else
{
pAd->HTCEnable = TRUE;
}
DBGPRINT(RT_DEBUG_TRACE, ("HT: Tx +HTC frame = %s\n", (Value==0) ? "Disable" : "Enable"));
}
/* Reverse Direction Mechanism*/
if (RTMPGetKeyParameter("HT_RDG", pValueStr, 25, pInput, TRUE))
{
Value = simple_strtol(pValueStr, 0, 10);
if (Value == 0)
{
pAd->CommonCfg.bRdg = FALSE;
}
else
{
pAd->HTCEnable = TRUE;
pAd->CommonCfg.bRdg = TRUE;
}
DBGPRINT(RT_DEBUG_TRACE, ("HT: RDG = %s\n", (Value==0) ? "Disable" : "Enable(+HTC)"));
}
/* Tx A-MSUD ?*/
if (RTMPGetKeyParameter("HT_AMSDU", pValueStr, 25, pInput, TRUE))
{
Value = simple_strtol(pValueStr, 0, 10);
if (Value == 0)
{
pAd->CommonCfg.BACapability.field.AmsduEnable = FALSE;
}
else
{
pAd->CommonCfg.BACapability.field.AmsduEnable = TRUE;
}
DBGPRINT(RT_DEBUG_TRACE, ("HT: Tx A-MSDU = %s\n", (Value==0) ? "Disable" : "Enable"));
}
/* MPDU Density*/
if (RTMPGetKeyParameter("HT_MpduDensity", pValueStr, 25, pInput, TRUE))
{
Value = simple_strtol(pValueStr, 0, 10);
if (Value <=7 && Value >= 0)
{
pAd->CommonCfg.BACapability.field.MpduDensity = Value;
DBGPRINT(RT_DEBUG_TRACE, ("HT: MPDU Density = %d\n", (INT) Value));
}
else
{
pAd->CommonCfg.BACapability.field.MpduDensity = 4;
DBGPRINT(RT_DEBUG_TRACE, ("HT: MPDU Density = %d (Default)\n", 4));
}
}
/* Max Rx BA Window Size*/
if (RTMPGetKeyParameter("HT_BAWinSize", pValueStr, 25, pInput, TRUE))
{
Value = simple_strtol(pValueStr, 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;
DBGPRINT(RT_DEBUG_TRACE, ("HT: BA Windw Size = %d\n", (INT) Value));
}
else
{
pAd->CommonCfg.REGBACapability.field.RxBAWinLimit = 64;
pAd->CommonCfg.BACapability.field.RxBAWinLimit = 64;
DBGPRINT(RT_DEBUG_TRACE, ("HT: BA Windw Size = 64 (Defualt)\n"));
}
}
/* Guard Interval*/
if (RTMPGetKeyParameter("HT_GI", pValueStr, 25, pInput, TRUE))
{
Value = simple_strtol(pValueStr, 0, 10);
if (Value == GI_400)
{
pAd->CommonCfg.RegTransmitSetting.field.ShortGI = GI_400;
}
else
{
pAd->CommonCfg.RegTransmitSetting.field.ShortGI = GI_800;
}
DBGPRINT(RT_DEBUG_TRACE, ("HT: Guard Interval = %s\n", (Value==GI_400) ? "400" : "800" ));
}
/* HT Operation Mode : Mixed Mode , Green Field*/
if (RTMPGetKeyParameter("HT_OpMode", pValueStr, 25, pInput, TRUE))
{
Value = simple_strtol(pValueStr, 0, 10);
if (Value == HTMODE_GF)
{
pAd->CommonCfg.RegTransmitSetting.field.HTMODE = HTMODE_GF;
}
else
{
pAd->CommonCfg.RegTransmitSetting.field.HTMODE = HTMODE_MM;
}
DBGPRINT(RT_DEBUG_TRACE, ("HT: Operate Mode = %s\n", (Value==HTMODE_GF) ? "Green Field" : "Mixed Mode" ));
}
/* Fixed Tx mode : CCK, OFDM*/
if (RTMPGetKeyParameter("FixedTxMode", pValueStr, 25, pInput, TRUE))
{
#ifdef CONFIG_AP_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
{
for (i = 0, Bufptr = rstrtok(pValueStr,";"); (Bufptr && i < MAX_MBSSID_NUM(pAd)); Bufptr = rstrtok(NULL,";"), i++)
{
pAd->ApCfg.MBSSID[i].DesiredTransmitSetting.field.FixedTxMode =
RT_CfgSetFixedTxPhyMode(Bufptr);
DBGPRINT(RT_DEBUG_TRACE, ("(IF-ra%d) Fixed Tx Mode = %d\n", i,
pAd->ApCfg.MBSSID[i].DesiredTransmitSetting.field.FixedTxMode));
}
}
#endif /* CONFIG_AP_SUPPORT */
#ifdef CONFIG_STA_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_STA(pAd)
{
pAd->StaCfg.DesiredTransmitSetting.field.FixedTxMode =
RT_CfgSetFixedTxPhyMode(pValueStr);
DBGPRINT(RT_DEBUG_TRACE, ("Fixed Tx Mode = %d\n",
pAd->StaCfg.DesiredTransmitSetting.field.FixedTxMode));
}
#endif /* CONFIG_STA_SUPPORT */
}
/* Channel Width */
if (RTMPGetKeyParameter("HT_BW", pValueStr, 25, pInput, TRUE))
{
Value = simple_strtol(pValueStr, 0, 10);
if (Value == BW_40)
pAd->CommonCfg.RegTransmitSetting.field.BW = BW_40;
else
pAd->CommonCfg.RegTransmitSetting.field.BW = BW_20;
#ifdef MCAST_RATE_SPECIFIC
pAd->CommonCfg.MCastPhyMode.field.BW = pAd->CommonCfg.RegTransmitSetting.field.BW;
#endif /* MCAST_RATE_SPECIFIC */
DBGPRINT(RT_DEBUG_TRACE, ("HT: Channel Width = %s\n", (Value==BW_40) ? "40 MHz" : "20 MHz" ));
}
if (RTMPGetKeyParameter("HT_EXTCHA", pValueStr, 25, pInput, TRUE))
{
Value = simple_strtol(pValueStr, 0, 10);
if (Value == 0)
pAd->CommonCfg.RegTransmitSetting.field.EXTCHA = EXTCHA_BELOW;
else
pAd->CommonCfg.RegTransmitSetting.field.EXTCHA = EXTCHA_ABOVE;
DBGPRINT(RT_DEBUG_TRACE, ("HT: Ext Channel = %s\n", (Value==0) ? "BELOW" : "ABOVE" ));
}
/* MSC*/
if (RTMPGetKeyParameter("HT_MCS", pValueStr, 50, pInput, TRUE))
{
#ifdef CONFIG_AP_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
{
for (i = 0, Bufptr = rstrtok(pValueStr,";"); (Bufptr && i < MAX_MBSSID_NUM(pAd)); Bufptr = rstrtok(NULL,";"), i++)
{
Value = simple_strtol(Bufptr, 0, 10);
if ((Value >= 0 && Value <= 23) || (Value == 32))
{
pAd->ApCfg.MBSSID[i].DesiredTransmitSetting.field.MCS = Value;
}
else
{
pAd->ApCfg.MBSSID[i].DesiredTransmitSetting.field.MCS = MCS_AUTO;
}
DBGPRINT(RT_DEBUG_TRACE, ("(IF-ra%d) HT: MCS = %s(%d)\n", i,
(pAd->ApCfg.MBSSID[i].DesiredTransmitSetting.field.MCS == MCS_AUTO ? "AUTO" : "Fixed"),
pAd->ApCfg.MBSSID[i].DesiredTransmitSetting.field.MCS));
}
}
#endif /* CONFIG_AP_SUPPORT */
#ifdef CONFIG_STA_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_STA(pAd)
{
Value = simple_strtol(pValueStr, 0, 10);
if ((Value >= 0 && Value <= 23) || (Value == 32))
{
pAd->StaCfg.DesiredTransmitSetting.field.MCS = Value;
#ifdef P2P_SUPPORT
pAd->ApCfg.MBSSID[MAIN_MBSSID].DesiredTransmitSetting.field.MCS = Value;
#endif /* P2P_SUPPORT */
pAd->StaCfg.bAutoTxRateSwitch = FALSE;
DBGPRINT(RT_DEBUG_TRACE, ("HT: MCS = %d\n", pAd->StaCfg.DesiredTransmitSetting.field.MCS));
}
else
{
pAd->StaCfg.DesiredTransmitSetting.field.MCS = MCS_AUTO;
#ifdef P2P_SUPPORT
pAd->ApCfg.MBSSID[MAIN_MBSSID].DesiredTransmitSetting.field.MCS = MCS_AUTO;
#endif /* P2P_SUPPORT */
pAd->StaCfg.bAutoTxRateSwitch = TRUE;
DBGPRINT(RT_DEBUG_TRACE, ("HT: MCS = AUTO\n"));
}
}
#endif /* CONFIG_STA_SUPPORT */
}
/* STBC */
if (RTMPGetKeyParameter("HT_STBC", pValueStr, 25, pInput, TRUE))
{
Value = simple_strtol(pValueStr, 0, 10);
if (Value == STBC_USE)
{
pAd->CommonCfg.RegTransmitSetting.field.STBC = STBC_USE;
}
else
{
pAd->CommonCfg.RegTransmitSetting.field.STBC = STBC_NONE;
}
DBGPRINT(RT_DEBUG_TRACE, ("HT: STBC = %d\n", pAd->CommonCfg.RegTransmitSetting.field.STBC));
}
/* 40_Mhz_Intolerant*/
if (RTMPGetKeyParameter("HT_40MHZ_INTOLERANT", pValueStr, 25, pInput, TRUE))
{
Value = simple_strtol(pValueStr, 0, 10);
if (Value == 0)
{
pAd->CommonCfg.bForty_Mhz_Intolerant = FALSE;
}
else
{
pAd->CommonCfg.bForty_Mhz_Intolerant = TRUE;
}
DBGPRINT(RT_DEBUG_TRACE, ("HT: 40MHZ INTOLERANT = %d\n", pAd->CommonCfg.bForty_Mhz_Intolerant));
}
/*HT_TxStream*/
if(RTMPGetKeyParameter("HT_TxStream", pValueStr, 10, pInput, TRUE))
{
switch (simple_strtol(pValueStr, 0, 10))
{
case 1:
pAd->CommonCfg.TxStream = 1;
break;
case 2:
pAd->CommonCfg.TxStream = 2;
break;
case 3: /* 3*3*/
default:
pAd->CommonCfg.TxStream = 3;
if (pAd->MACVersion < RALINK_2883_VERSION)
pAd->CommonCfg.TxStream = 2; /* only 2 tx streams for RT2860 series*/
break;
}
DBGPRINT(RT_DEBUG_TRACE, ("HT: Tx Stream = %d\n", pAd->CommonCfg.TxStream));
}
/*HT_RxStream*/
if(RTMPGetKeyParameter("HT_RxStream", pValueStr, 10, pInput, TRUE))
{
switch (simple_strtol(pValueStr, 0, 10))
{
case 1:
pAd->CommonCfg.RxStream = 1;
break;
case 2:
pAd->CommonCfg.RxStream = 2;
break;
case 3:
default:
pAd->CommonCfg.RxStream = 3;
if (pAd->MACVersion < RALINK_2883_VERSION)
pAd->CommonCfg.RxStream = 2; /* only 2 rx streams for RT2860 series*/
break;
}
DBGPRINT(RT_DEBUG_TRACE, ("HT: Rx Stream = %d\n", pAd->CommonCfg.RxStream));
}
#ifdef GREENAP_SUPPORT
/*Green AP*/
if(RTMPGetKeyParameter("GreenAP", pValueStr, 10, pInput, TRUE))
{
Value = simple_strtol(pValueStr, 0, 10);
if (Value == 0)
{
pAd->ApCfg.bGreenAPEnable = FALSE;
}
else
{
pAd->ApCfg.bGreenAPEnable = TRUE;
}
DBGPRINT(RT_DEBUG_TRACE, ("HT: Green AP= %d\n", pAd->ApCfg.bGreenAPEnable));
}
#endif /* GREENAP_SUPPORT */
/* HT_DisallowTKIP*/
if (RTMPGetKeyParameter("HT_DisallowTKIP", pValueStr, 25, pInput, TRUE))
{
Value = simple_strtol(pValueStr, 0, 10);
if (Value == 1)
{
pAd->CommonCfg.HT_DisallowTKIP = TRUE;
}
else
{
pAd->CommonCfg.HT_DisallowTKIP = FALSE;
}
DBGPRINT(RT_DEBUG_TRACE, ("HT: Disallow TKIP mode = %s\n", (pAd->CommonCfg.HT_DisallowTKIP == TRUE) ? "ON" : "OFF" ));
}
#ifdef DOT11_N_SUPPORT
#ifdef DOT11N_DRAFT3
if (RTMPGetKeyParameter("OBSSScanParam", pValueStr, 32, pInput, TRUE))
{
int ObssScanValue, idx;
PSTRING macptr;
for (idx = 0, macptr = rstrtok(pValueStr,";"); macptr; macptr = rstrtok(NULL,";"), idx++)
{
ObssScanValue = simple_strtol(macptr, 0, 10);
switch (idx)
{
case 0:
if (ObssScanValue < 5 || ObssScanValue > 1000)
{
DBGPRINT(RT_DEBUG_ERROR, ("Invalid OBSSScanParam for Dot11OBssScanPassiveDwell(%d), should in range 5~1000\n", ObssScanValue));
}
else
{
pAd->CommonCfg.Dot11OBssScanPassiveDwell = ObssScanValue; /* Unit : TU. 5~1000*/
DBGPRINT(RT_DEBUG_TRACE, ("OBSSScanParam for Dot11OBssScanPassiveDwell=%d\n", ObssScanValue));
}
break;
case 1:
if (ObssScanValue < 10 || ObssScanValue > 1000)
{
DBGPRINT(RT_DEBUG_ERROR, ("Invalid OBSSScanParam for Dot11OBssScanActiveDwell(%d), should in range 10~1000\n", ObssScanValue));
}
else
{
pAd->CommonCfg.Dot11OBssScanActiveDwell = ObssScanValue; /* Unit : TU. 10~1000*/
DBGPRINT(RT_DEBUG_TRACE, ("OBSSScanParam for Dot11OBssScanActiveDwell=%d\n", ObssScanValue));
}
break;
case 2:
pAd->CommonCfg.Dot11BssWidthTriggerScanInt = ObssScanValue; /* Unit : Second*/
DBGPRINT(RT_DEBUG_TRACE, ("OBSSScanParam for Dot11BssWidthTriggerScanInt=%d\n", ObssScanValue));
break;
case 3:
if (ObssScanValue < 200 || ObssScanValue > 10000)
{
DBGPRINT(RT_DEBUG_ERROR, ("Invalid OBSSScanParam for Dot11OBssScanPassiveTotalPerChannel(%d), should in range 200~10000\n", ObssScanValue));
}
else
{
pAd->CommonCfg.Dot11OBssScanPassiveTotalPerChannel = ObssScanValue; /* Unit : TU. 200~10000*/
DBGPRINT(RT_DEBUG_TRACE, ("OBSSScanParam for Dot11OBssScanPassiveTotalPerChannel=%d\n", ObssScanValue));
}
break;
case 4:
if (ObssScanValue < 20 || ObssScanValue > 10000)
{
DBGPRINT(RT_DEBUG_ERROR, ("Invalid OBSSScanParam for Dot11OBssScanActiveTotalPerChannel(%d), should in range 20~10000\n", ObssScanValue));
}
else
{
pAd->CommonCfg.Dot11OBssScanActiveTotalPerChannel = ObssScanValue; /* Unit : TU. 20~10000*/
DBGPRINT(RT_DEBUG_TRACE, ("OBSSScanParam for Dot11OBssScanActiveTotalPerChannel=%d\n", ObssScanValue));
}
break;
case 5:
pAd->CommonCfg.Dot11BssWidthChanTranDelayFactor = ObssScanValue;
DBGPRINT(RT_DEBUG_TRACE, ("OBSSScanParam for Dot11BssWidthChanTranDelayFactor=%d\n", ObssScanValue));
break;
case 6:
pAd->CommonCfg.Dot11OBssScanActivityThre = ObssScanValue; /* Unit : percentage*/
DBGPRINT(RT_DEBUG_TRACE, ("OBSSScanParam for Dot11BssWidthChanTranDelayFactor=%d\n", ObssScanValue));
break;
}
}
if (idx != 7)
{
DBGPRINT(RT_DEBUG_ERROR, ("Wrong OBSSScanParamtetrs format in dat file!!!!! Use default value.\n"));
pAd->CommonCfg.Dot11OBssScanPassiveDwell = dot11OBSSScanPassiveDwell; /* Unit : TU. 5~1000*/
pAd->CommonCfg.Dot11OBssScanActiveDwell = dot11OBSSScanActiveDwell; /* Unit : TU. 10~1000*/
pAd->CommonCfg.Dot11BssWidthTriggerScanInt = dot11BSSWidthTriggerScanInterval; /* Unit : Second */
pAd->CommonCfg.Dot11OBssScanPassiveTotalPerChannel = dot11OBSSScanPassiveTotalPerChannel; /* Unit : TU. 200~10000*/
pAd->CommonCfg.Dot11OBssScanActiveTotalPerChannel = dot11OBSSScanActiveTotalPerChannel; /* Unit : TU. 20~10000*/
pAd->CommonCfg.Dot11BssWidthChanTranDelayFactor = dot11BSSWidthChannelTransactionDelayFactor;
pAd->CommonCfg.Dot11OBssScanActivityThre = dot11BSSScanActivityThreshold; /* Unit : percentage*/
}
pAd->CommonCfg.Dot11BssWidthChanTranDelay = (pAd->CommonCfg.Dot11BssWidthTriggerScanInt * pAd->CommonCfg.Dot11BssWidthChanTranDelayFactor);
DBGPRINT(RT_DEBUG_TRACE, ("OBSSScanParam for Dot11BssWidthChanTranDelay=%ld\n", pAd->CommonCfg.Dot11BssWidthChanTranDelay));
}
if (RTMPGetKeyParameter("HT_BSSCoexistence", pValueStr, 25, pInput, TRUE))
{
Value = simple_strtol(pValueStr, 0, 10);
pAd->CommonCfg.bBssCoexEnable = ((Value == 1) ? TRUE : FALSE);
DBGPRINT(RT_DEBUG_TRACE, ("HT: 20/40 BssCoexSupport = %s\n", (pAd->CommonCfg.bBssCoexEnable == TRUE) ? "ON" : "OFF" ));
}
if (RTMPGetKeyParameter("HT_BSSCoexApCntThr", pValueStr, 25, pInput, TRUE))
{
pAd->CommonCfg.BssCoexApCntThr = simple_strtol(pValueStr, 0, 10);;
DBGPRINT(RT_DEBUG_TRACE, ("HT: 20/40 BssCoexApCntThr = %d\n", pAd->CommonCfg.BssCoexApCntThr));
}
#endif /* DOT11N_DRAFT3 */
if (RTMPGetKeyParameter("BurstMode", pValueStr, 25, pInput, TRUE))
{
Value = simple_strtol(pValueStr, 0, 10);
pAd->CommonCfg.bRalinkBurstMode = ((Value == 1) ? 1 : 0);
DBGPRINT(RT_DEBUG_TRACE, ("HT: RaBurstMode= %d\n", pAd->CommonCfg.bRalinkBurstMode));
}
#endif /* DOT11_N_SUPPORT */
}
#endif /* DOT11_N_SUPPORT */
#ifdef CONFIG_STA_SUPPORT
void RTMPSetSTASSID(RTMP_ADAPTER *pAd, PSTRING SSID)
{
pAd->CommonCfg.SsidLen = (UCHAR) strlen(SSID);
NdisZeroMemory(pAd->CommonCfg.Ssid, NDIS_802_11_LENGTH_SSID);
NdisMoveMemory(pAd->CommonCfg.Ssid, SSID, pAd->CommonCfg.SsidLen);
pAd->CommonCfg.LastSsidLen= pAd->CommonCfg.SsidLen;
NdisZeroMemory(pAd->CommonCfg.LastSsid, NDIS_802_11_LENGTH_SSID);
NdisMoveMemory(pAd->CommonCfg.LastSsid, SSID, pAd->CommonCfg.LastSsidLen);
pAd->MlmeAux.AutoReconnectSsidLen = pAd->CommonCfg.SsidLen;
NdisZeroMemory(pAd->MlmeAux.AutoReconnectSsid, NDIS_802_11_LENGTH_SSID);
NdisMoveMemory(pAd->MlmeAux.AutoReconnectSsid, SSID, pAd->MlmeAux.AutoReconnectSsidLen);
pAd->MlmeAux.SsidLen = pAd->CommonCfg.SsidLen;
NdisZeroMemory(pAd->MlmeAux.Ssid, NDIS_802_11_LENGTH_SSID);
NdisMoveMemory(pAd->MlmeAux.Ssid, SSID, pAd->MlmeAux.SsidLen);
}
void RTMPSetSTAPassPhrase(RTMP_ADAPTER *pAd, PSTRING PassPh)
{
int ret = TRUE;
PassPh[strlen(PassPh)] = '\0'; /* make STA can process .$^& for WPAPSK input */
if ((pAd->StaCfg.AuthMode != Ndis802_11AuthModeWPAPSK) &&
(pAd->StaCfg.AuthMode != Ndis802_11AuthModeWPA2PSK) &&
(pAd->StaCfg.AuthMode != Ndis802_11AuthModeWPANone)
#ifdef WAPI_SUPPORT
&& (pAd->StaCfg.AuthMode != Ndis802_11AuthModeWAICERT)
&& (pAd->StaCfg.AuthMode != Ndis802_11AuthModeWAIPSK)
#endif /* WAPI_SUPPORT */
)
{
ret = FALSE;
}
else
{
ret = RT_CfgSetWPAPSKKey(pAd, PassPh, strlen(PassPh), (PUCHAR)pAd->CommonCfg.Ssid, pAd->CommonCfg.SsidLen, pAd->StaCfg.PMK);
}
if (ret == TRUE)
{
RTMPZeroMemory(pAd->StaCfg.WpaPassPhrase, 64);
RTMPMoveMemory(pAd->StaCfg.WpaPassPhrase, PassPh, strlen(PassPh));
pAd->StaCfg.WpaPassPhraseLen= strlen(PassPh);
if ((pAd->StaCfg.AuthMode == Ndis802_11AuthModeWPAPSK) ||
(pAd->StaCfg.AuthMode == Ndis802_11AuthModeWPA2PSK))
{
/* Start STA supplicant state machine*/
pAd->StaCfg.WpaState = SS_START;
}
else if (pAd->StaCfg.AuthMode == Ndis802_11AuthModeWPANone)
{
pAd->StaCfg.WpaState = SS_NOTUSE;
}
#ifdef WSC_STA_SUPPORT
NdisZeroMemory(pAd->StaCfg.WscControl.WpaPsk, 64);
pAd->StaCfg.WscControl.WpaPskLen = 0;
if ((strlen(PassPh) >= 8) && (strlen(PassPh) <= 64))
{
NdisMoveMemory(pAd->StaCfg.WscControl.WpaPsk, PassPh, strlen(PassPh));
pAd->StaCfg.WscControl.WpaPskLen = strlen(PassPh);
}
#endif /* WSC_STA_SUPPORT */
DBGPRINT(RT_DEBUG_TRACE, ("%s::(WPAPSK=%s)\n", __FUNCTION__, PassPh));
}
}
inline void RTMPSetSTACipherSuites(RTMP_ADAPTER *pAd, NDIS_802_11_ENCRYPTION_STATUS WepStatus)
{
/* Update all wepstatus related*/
pAd->StaCfg.PairCipher = WepStatus;
pAd->StaCfg.GroupCipher = WepStatus;
pAd->StaCfg.bMixCipher = FALSE;
}
#ifdef CREDENTIAL_STORE
/*RECOVER THE OLD CONNECT INFO */
NDIS_STATUS RecoverConnectInfo(
IN RTMP_ADAPTER *pAd)
{
INT idx;
char ssidStr[NDIS_802_11_LENGTH_SSID + 1];
NdisZeroMemory(&ssidStr[0], sizeof(ssidStr));
RTMP_SEM_LOCK(&pAd->StaCtIf.Lock);
if ((pAd->StaCtIf.Changeable== FALSE) || (pAd->StaCtIf.SsidLen > NDIS_802_11_LENGTH_SSID))
{
DBGPRINT(RT_DEBUG_TRACE, (" DRIVER INIT not need to RecoverConnectInfo() \n"));
RTMP_SEM_UNLOCK(&pAd->StaCtIf.Lock);
return 0;
}
DBGPRINT(RT_DEBUG_TRACE, ("-->RecoverConnectInfo()\n"));
NdisMoveMemory(ssidStr, pAd->StaCtIf.Ssid, pAd->StaCtIf.SsidLen);
RTMPSetSTASSID(pAd, &ssidStr[0]);
pAd->StaCfg.AuthMode = pAd->StaCtIf.AuthMode;
pAd->StaCfg.WepStatus = pAd->StaCtIf.WepStatus;
#ifdef WPA_SUPPLICANT_SUPPORT
pAd->StaCfg.IEEE8021X = pAd->StaCtIf.IEEE8021X;
pAd->StaCfg.DesireSharedKeyId = pAd->StaCtIf.DefaultKeyId;
#endif // WPA_SUPPLICANT_SUPPORT //
pAd->StaCfg.DefaultKeyId = pAd->StaCtIf.DefaultKeyId;
NdisMoveMemory( pAd->StaCfg.PMK, pAd->StaCtIf.PMK, 32);
RTMPMoveMemory(pAd->StaCfg.WpaPassPhrase, pAd->StaCtIf.WpaPassPhrase, pAd->StaCfg.WpaPassPhraseLen);
pAd->StaCfg.WpaPassPhraseLen = pAd->StaCtIf.WpaPassPhraseLen;
for (idx = 0; idx < 4; idx++)
{
NdisMoveMemory(&pAd->SharedKey[BSS0][idx], &pAd->StaCtIf.SharedKey[BSS0][idx], sizeof(CIPHER_KEY));
#ifdef WPA_SUPPLICANT_SUPPORT
NdisMoveMemory(&pAd->StaCfg.DesireSharedKey[idx], &pAd->StaCtIf.SharedKey[BSS0][idx], sizeof(CIPHER_KEY));
#endif // WPA_SUPPLICANT_SUPPORT //
}
if ((pAd->StaCfg.AuthMode == Ndis802_11AuthModeWPAPSK) ||
(pAd->StaCfg.AuthMode == Ndis802_11AuthModeWPA2PSK))
{
// Start STA supplicant state machine
pAd->StaCfg.WpaState = SS_START;
}
else if (pAd->StaCfg.AuthMode == Ndis802_11AuthModeWPANone)
{
pAd->StaCfg.WpaState = SS_NOTUSE;
}
RTMP_SEM_UNLOCK(&pAd->StaCtIf.Lock);
DBGPRINT(RT_DEBUG_TRACE, ("<--RecoverConnectInfo()\n"));
return 0;
}
/*STORE THE CONNECT INFO*/
NDIS_STATUS StoreConnectInfo(
IN RTMP_ADAPTER *pAd)
{
INT idx;
DBGPRINT(RT_DEBUG_TRACE, ("-->StoreConnectInfo()\n"));
RTMP_SEM_LOCK(&pAd->StaCtIf.Lock);
pAd->StaCtIf.Changeable = TRUE;
pAd->StaCtIf.SsidLen = pAd->CommonCfg.SsidLen;
NdisMoveMemory(pAd->StaCtIf.Ssid, pAd->CommonCfg.Ssid, pAd->CommonCfg.SsidLen);
pAd->StaCtIf.AuthMode = pAd->StaCfg.AuthMode;
pAd->StaCtIf.WepStatus = pAd->StaCfg.WepStatus;
pAd->StaCtIf.DefaultKeyId = pAd->StaCfg.DefaultKeyId;
#ifdef WPA_SUPPLICANT_SUPPORT
pAd->StaCtIf.DefaultKeyId = pAd->StaCfg.DesireSharedKeyId;
pAd->StaCtIf.IEEE8021X = pAd->StaCfg.IEEE8021X;
#endif // WPA_SUPPLICANT_SUPPORT //
NdisMoveMemory(pAd->StaCtIf.PMK, pAd->StaCfg.PMK, 32);
RTMPMoveMemory(pAd->StaCtIf.WpaPassPhrase, pAd->StaCfg.WpaPassPhrase, pAd->StaCfg.WpaPassPhraseLen);
pAd->StaCtIf.WpaPassPhraseLen = pAd->StaCfg.WpaPassPhraseLen;
for (idx = 0; idx < 4; idx++)
{
NdisMoveMemory(&pAd->StaCtIf.SharedKey[BSS0][idx], &pAd->SharedKey[BSS0][idx], sizeof(CIPHER_KEY));
}
RTMP_SEM_UNLOCK(&pAd->StaCtIf.Lock);
DBGPRINT(RT_DEBUG_TRACE, ("<--StoreConnectInfo()\n"));
return 0;
}
#endif /* CREDENTIAL_STORE */
#endif /* CONFIG_STA_SUPPORT */
void RTMPSetCountryCode(RTMP_ADAPTER *pAd, PSTRING CountryCode)
{
NdisMoveMemory(pAd->CommonCfg.CountryCode, CountryCode , 2);
pAd->CommonCfg.CountryCode[2] = ' ';
#ifdef CONFIG_STA_SUPPORT
#ifdef EXT_BUILD_CHANNEL_LIST
IF_DEV_CONFIG_OPMODE_ON_STA(pAd)
NdisMoveMemory(pAd->StaCfg.StaOriCountryCode, CountryCode , 2);
#endif /* EXT_BUILD_CHANNEL_LIST */
#endif /* CONFIG_STA_SUPPORT */
if (strlen((PSTRING) pAd->CommonCfg.CountryCode) != 0)
pAd->CommonCfg.bCountryFlag = TRUE;
DBGPRINT(RT_DEBUG_TRACE, ("CountryCode=%s\n", pAd->CommonCfg.CountryCode));
}
NDIS_STATUS RTMPSetProfileParameters(
IN RTMP_ADAPTER *pAd,
IN PSTRING pBuffer)
{
PSTRING tmpbuf;
ULONG RtsThresh;
ULONG FragThresh;
PSTRING macptr;
INT i = 0, retval;
/* tmpbuf = kmalloc(MAX_PARAM_BUFFER_SIZE, MEM_ALLOC_FLAG);*/
os_alloc_mem(NULL, (UCHAR **)&tmpbuf, MAX_PARAM_BUFFER_SIZE);
if(tmpbuf == NULL)
return NDIS_STATUS_FAILURE;
do
{
/* set file parameter to portcfg*/
if (RTMPGetKeyParameter("MacAddress", tmpbuf, 25, pBuffer, TRUE))
{
retval = RT_CfgSetMacAddress(pAd, tmpbuf);
if (retval)
DBGPRINT(RT_DEBUG_TRACE, ("MacAddress = %02x:%02x:%02x:%02x:%02x:%02x\n",
PRINT_MAC(pAd->CurrentAddress)));
}
/*CountryRegion*/
if(RTMPGetKeyParameter("CountryRegion", tmpbuf, 25, pBuffer, TRUE))
{
retval = RT_CfgSetCountryRegion(pAd, tmpbuf, BAND_24G);
DBGPRINT(RT_DEBUG_TRACE, ("CountryRegion=%d\n", pAd->CommonCfg.CountryRegion));
}
/*CountryRegionABand*/
if(RTMPGetKeyParameter("CountryRegionABand", tmpbuf, 25, pBuffer, TRUE))
{
retval = RT_CfgSetCountryRegion(pAd, tmpbuf, BAND_5G);
DBGPRINT(RT_DEBUG_TRACE, ("CountryRegionABand=%d\n", pAd->CommonCfg.CountryRegionForABand));
}
#ifdef RTMP_EFUSE_SUPPORT
/*EfuseBufferMode*/
if(RTMPGetKeyParameter("EfuseBufferMode", tmpbuf, 25, pBuffer, TRUE))
{
pAd->bEEPROMFile = (UCHAR) simple_strtol(tmpbuf, 0, 10);
DBGPRINT(RT_DEBUG_TRACE, ("EfuseBufferMode=%d\n", pAd->bUseEfuse));
}
#endif /* RTMP_EFUSE_SUPPORT */
/*CountryCode*/
if (pAd->CommonCfg.bCountryFlag == 0)
{
if(RTMPGetKeyParameter("CountryCode", tmpbuf, 25, pBuffer, TRUE))
RTMPSetCountryCode(pAd, tmpbuf);
}
#ifdef EXT_BUILD_CHANNEL_LIST
/*ChannelGeography*/
if(RTMPGetKeyParameter("ChannelGeography", tmpbuf, 25, pBuffer, TRUE))
{
UCHAR Geography = (UCHAR) simple_strtol(tmpbuf, 0, 10);
if (Geography <= BOTH)
{
pAd->CommonCfg.Geography = Geography;
pAd->CommonCfg.CountryCode[2] =
(pAd->CommonCfg.Geography == BOTH) ? ' ' : ((pAd->CommonCfg.Geography == IDOR) ? 'I' : 'O');
#ifdef CONFIG_STA_SUPPORT
#ifdef EXT_BUILD_CHANNEL_LIST
IF_DEV_CONFIG_OPMODE_ON_STA(pAd)
pAd->StaCfg.StaOriGeography = pAd->CommonCfg.Geography;
#endif /* EXT_BUILD_CHANNEL_LIST */
#endif /* CONFIG_STA_SUPPORT */
DBGPRINT(RT_DEBUG_TRACE, ("ChannelGeography=%d\n", pAd->CommonCfg.Geography));
}
}
else
{
pAd->CommonCfg.Geography = BOTH;
pAd->CommonCfg.CountryCode[2] = ' ';
}
#endif /* EXT_BUILD_CHANNEL_LIST */
#ifdef CONFIG_AP_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
{
#ifdef MBSS_SUPPORT
/*BSSIDNum; This must read first of other multiSSID field, so list this field first in configuration file*/
if(RTMPGetKeyParameter("BssidNum", tmpbuf, 25, pBuffer, TRUE))
{
pAd->ApCfg.BssidNum = (UCHAR) simple_strtol(tmpbuf, 0, 10);
if(pAd->ApCfg.BssidNum > MAX_MBSSID_NUM(pAd))
{
pAd->ApCfg.BssidNum = MAX_MBSSID_NUM(pAd);
DBGPRINT(RT_DEBUG_TRACE, ("BssidNum=%d(MAX_MBSSID_NUM is %d)\n", pAd->ApCfg.BssidNum,MAX_MBSSID_NUM(pAd)));
}
else
DBGPRINT(RT_DEBUG_TRACE, ("BssidNum=%d\n", pAd->ApCfg.BssidNum));
}
if (HW_BEACON_OFFSET > (HW_BEACON_MAX_SIZE(pAd) / pAd->ApCfg.BssidNum))
{
DBGPRINT(RT_DEBUG_OFF, ("mbss> fatal error! beacon offset is error in driver! "
"Please re-assign HW_BEACON_OFFSET!\n"));
}
#else
pAd->ApCfg.BssidNum = 1;
#endif /* MBSS_SUPPORT */
}
#endif /* CONFIG_AP_SUPPORT */
#ifdef CONFIG_AP_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
{
/* SSID*/
if (TRUE)
{
STRING tok_str[16];
UCHAR BssidCountSupposed = 0;
BOOLEAN bSSIDxIsUsed = FALSE;
//PRINT(RT_DEBUG_TRACE, ("pAd->ApCfg.BssidNum=%d\n", pAd->ApCfg.BssidNum));
for (i = 0; i < pAd->ApCfg.BssidNum; i++)
{
snprintf(tok_str, sizeof(tok_str), "SSID%d", i + 1);
if(RTMPGetKeyParameter(tok_str, tmpbuf, 33, pBuffer, FALSE))
{
NdisMoveMemory(pAd->ApCfg.MBSSID[i].Ssid, tmpbuf , strlen(tmpbuf));
pAd->ApCfg.MBSSID[i].Ssid[strlen(tmpbuf)] = '\0';
pAd->ApCfg.MBSSID[i].SsidLen = strlen((PSTRING) pAd->ApCfg.MBSSID[i].Ssid);
if (bSSIDxIsUsed == FALSE)
{
bSSIDxIsUsed = TRUE;
}
DBGPRINT(RT_DEBUG_TRACE, ("SSID[%d]=%s\n", i, pAd->ApCfg.MBSSID[i].Ssid));
}
}
if (bSSIDxIsUsed == FALSE)
{
if(RTMPGetKeyParameter("SSID", tmpbuf, 256, pBuffer, FALSE))
{
BssidCountSupposed = delimitcnt(tmpbuf, ";") + 1;
if (pAd->ApCfg.BssidNum != BssidCountSupposed)
{
DBGPRINT_ERR(("Your no. of SSIDs( = %d) does not match your BssidNum( = %d)!\n", BssidCountSupposed, pAd->ApCfg.BssidNum));
}
if (pAd->ApCfg.BssidNum > 1)
{
/* Anyway, we still do the legacy dissection of the whole SSID string.*/
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
int apidx = 0;
if (i < pAd->ApCfg.BssidNum)
{
apidx = i;
}
else
{
break;
}
NdisMoveMemory(pAd->ApCfg.MBSSID[apidx].Ssid, macptr , strlen(macptr));
pAd->ApCfg.MBSSID[apidx].Ssid[strlen(macptr)] = '\0';
pAd->ApCfg.MBSSID[apidx].SsidLen = strlen((PSTRING) pAd->ApCfg.MBSSID[apidx].Ssid);
DBGPRINT(RT_DEBUG_TRACE, ("SSID[%d]=%s\n", i, pAd->ApCfg.MBSSID[apidx].Ssid));
}
}
else
{
if ((strlen(tmpbuf) > 0) && (strlen(tmpbuf) <= 32))
{
NdisMoveMemory(pAd->ApCfg.MBSSID[BSS0].Ssid, tmpbuf , strlen(tmpbuf));
pAd->ApCfg.MBSSID[BSS0].Ssid[strlen(tmpbuf)] = '\0';
pAd->ApCfg.MBSSID[BSS0].SsidLen = strlen((PSTRING) pAd->ApCfg.MBSSID[BSS0].Ssid);
DBGPRINT(RT_DEBUG_TRACE, ("SSID=%s\n", pAd->ApCfg.MBSSID[BSS0].Ssid));
}
}
}
}
}
}
#endif /* CONFIG_AP_SUPPORT */
#ifdef CONFIG_STA_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_STA(pAd)
{
/*SSID*/
if (RTMPGetKeyParameter("SSID", tmpbuf, 256, pBuffer, FALSE))
{
if (strlen(tmpbuf) <= 32)
{
RTMPSetSTASSID(pAd, tmpbuf);
DBGPRINT(RT_DEBUG_TRACE, ("%s::(SSID=%s)\n", __FUNCTION__, tmpbuf));
}
}
}
#endif /* CONFIG_STA_SUPPORT */
#ifdef CONFIG_STA_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_STA(pAd)
{
/*NetworkType*/
if (RTMPGetKeyParameter("NetworkType", tmpbuf, 25, pBuffer, TRUE))
{
pAd->bConfigChanged = TRUE;
if (strcmp(tmpbuf, "Adhoc") == 0)
pAd->StaCfg.BssType = BSS_ADHOC;
else /*Default Infrastructure mode*/
pAd->StaCfg.BssType = BSS_INFRA;
/* Reset Ralink supplicant to not use, it will be set to start when UI set PMK key*/
pAd->StaCfg.WpaState = SS_NOTUSE;
DBGPRINT(RT_DEBUG_TRACE, ("%s::(NetworkType=%d)\n", __FUNCTION__, pAd->StaCfg.BssType));
}
}
#endif /* CONFIG_STA_SUPPORT */
/*Channel*/
if(RTMPGetKeyParameter("Channel", tmpbuf, 10, pBuffer, TRUE))
{
pAd->CommonCfg.Channel = (UCHAR) simple_strtol(tmpbuf, 0, 10);
DBGPRINT(RT_DEBUG_TRACE, ("Channel=%d\n", pAd->CommonCfg.Channel));
}
/*WirelessMode*/
/*Note: BssidNum must be put before WirelessMode in dat file*/
if(RTMPGetKeyParameter("WirelessMode", tmpbuf, 32, pBuffer, TRUE))
{
UCHAR cfg_mode;
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
cfg_mode = simple_strtol(macptr, 0, 10);
#ifdef CONFIG_AP_SUPPORT
#ifdef MBSS_SUPPORT
if (i >= pAd->ApCfg.BssidNum)
break;
pAd->ApCfg.MBSSID[i].PhyMode = cfgmode_2_wmode(cfg_mode);
DBGPRINT(RT_DEBUG_TRACE, ("BSS%d PhyMode=%d\n", i, pAd->ApCfg.MBSSID[i].PhyMode));
#endif /* MBSS_SUPPORT */
#endif /* CONFIG_AP_SUPPORT */
if (i == 0)
{
#ifdef CONFIG_AP_SUPPORT
#ifdef MBSS_SUPPORT
/* for first time, update all phy mode is same as ra0 */
{
UINT32 IdBss;
for(IdBss=1; IdBss<pAd->ApCfg.BssidNum; IdBss++)
pAd->ApCfg.MBSSID[IdBss].PhyMode = pAd->ApCfg.MBSSID[0].PhyMode;
}
#endif /* MBSS_SUPPORT */
#endif /* CONFIG_AP_SUPPORT */
/* set mode for 1st time */
RT_CfgSetWirelessMode(pAd, macptr);
}
#ifdef CONFIG_AP_SUPPORT
#ifdef MBSS_SUPPORT
else
RT_CfgSetMbssWirelessMode(pAd, macptr);
#endif /* MBSS_SUPPORT */
#endif /* CONFIG_AP_SUPPORT */
}
DBGPRINT(RT_DEBUG_TRACE, ("PhyMode=%d\n", pAd->CommonCfg.PhyMode));
}
/*BasicRate*/
if(RTMPGetKeyParameter("BasicRate", tmpbuf, 10, pBuffer, TRUE))
{
pAd->CommonCfg.BasicRateBitmap = (ULONG) simple_strtol(tmpbuf, 0, 10);
pAd->CommonCfg.BasicRateBitmapOld = (ULONG) simple_strtol(tmpbuf, 0, 10);
DBGPRINT(RT_DEBUG_TRACE, ("BasicRate=%ld\n", pAd->CommonCfg.BasicRateBitmap));
}
/*BeaconPeriod*/
if(RTMPGetKeyParameter("BeaconPeriod", tmpbuf, 10, pBuffer, TRUE))
{
USHORT bcn_val = (USHORT) simple_strtol(tmpbuf, 0, 10);
/* The acceptable is 20~1000 ms. Refer to WiFi test plan. */
if (bcn_val >= 20 && bcn_val <= 1000)
pAd->CommonCfg.BeaconPeriod = bcn_val;
else
pAd->CommonCfg.BeaconPeriod = 100; /* Default value*/
DBGPRINT(RT_DEBUG_TRACE, ("BeaconPeriod=%d\n", pAd->CommonCfg.BeaconPeriod));
}
#ifdef CONFIG_AP_SUPPORT
#ifdef DFS_SUPPORT
/*DFSIndoor*/
{
PRADAR_DETECT_STRUCT pRadarDetect = &pAd->CommonCfg.RadarDetect;
PDFS_PROGRAM_PARAM pDfsProgramParam = &pRadarDetect->DfsProgramParam;
if (RTMPGetKeyParameter("DfsIndoor", tmpbuf, 10, pBuffer, TRUE))
{
pAd->Dot11_H.bDFSIndoor = (USHORT) (simple_strtol(tmpbuf, 0, 10) != 0);
DBGPRINT(RT_DEBUG_TRACE, ("DfsIndoor=%d\n", pAd->Dot11_H.bDFSIndoor));
}
{
INT k=0;
/*SymRoundFromCfg*/
if (RTMPGetKeyParameter("SymRoundFromCfg", tmpbuf, 10, pBuffer, TRUE))
{
pRadarDetect->SymRoundFromCfg = (UCHAR) simple_strtol(tmpbuf, 0, 10);
pRadarDetect->SymRoundCfgValid = 1;
DBGPRINT(RT_DEBUG_TRACE, ("SymRoundFromCfg=%d\n", pRadarDetect->SymRoundFromCfg));
}
/*BusyIdleFromCfg*/
if (RTMPGetKeyParameter("BusyIdleFromCfg", tmpbuf, 10, pBuffer, TRUE))
{
pRadarDetect->BusyIdleFromCfg = (UCHAR) simple_strtol(tmpbuf, 0, 10);
pRadarDetect->BusyIdleCfgValid = 1;
DBGPRINT(RT_DEBUG_TRACE, ("BusyIdleFromCfg=%d\n", pRadarDetect->BusyIdleFromCfg));
}
/*DfsRssiHighFromCfg*/
if (RTMPGetKeyParameter("DfsRssiHighFromCfg", tmpbuf, 10, pBuffer, TRUE))
{
pRadarDetect->DfsRssiHighFromCfg = simple_strtol(tmpbuf, 0, 10);
pRadarDetect->DfsRssiHighCfgValid = 1;
DBGPRINT(RT_DEBUG_TRACE, ("DfsRssiHighFromCfg=%d\n", pRadarDetect->DfsRssiHighFromCfg));
}
/*DfsRssiLowFromCfg*/
if (RTMPGetKeyParameter("DfsRssiLowFromCfg", tmpbuf, 10, pBuffer, TRUE))
{
pRadarDetect->DfsRssiLowFromCfg = simple_strtol(tmpbuf, 0, 10);
pRadarDetect->DfsRssiLowCfgValid = 1;
DBGPRINT(RT_DEBUG_TRACE, ("DfsRssiLowFromCfg=%d\n", pRadarDetect->DfsRssiLowFromCfg));
}
/*DFSParamFromConfig*/
if (RTMPGetKeyParameter("DFSParamFromConfig", tmpbuf, 10, pBuffer, TRUE))
{
pRadarDetect->DFSParamFromConfig = (UCHAR) simple_strtol(tmpbuf, 0, 10);
DBGPRINT(RT_DEBUG_TRACE, ("DFSParamFromConfig=%d\n", pRadarDetect->DFSParamFromConfig));
}
/* DFSParam*/
for(k = 0; k < 4*pAd->chipCap.DfsEngineNum; k++)
{
STRING tok_str[32];
INT index ;
UINT8 DfsEngineNum = pAd->chipCap.DfsEngineNum;
index = (k%DfsEngineNum);
if (((k-k%DfsEngineNum)/DfsEngineNum) == 0)
snprintf(tok_str, sizeof(tok_str), "FCCParamCh%d", index);
else if (((k-k%DfsEngineNum)/DfsEngineNum) == 1)
snprintf(tok_str, sizeof(tok_str), "CEParamCh%d", index);
else if (((k-k%DfsEngineNum)/DfsEngineNum) == 2)
snprintf(tok_str, sizeof(tok_str), "JAPParamCh%d", index);
else if (((k-k%DfsEngineNum)/DfsEngineNum) == 3)
snprintf(tok_str, sizeof(tok_str), "JAPW53ParamCh%d", index);
if (RTMPGetKeyParameter(tok_str, tmpbuf, 128, pBuffer, TRUE))
{
ULONG DfsParam;
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
DfsParam = simple_strtol(macptr, 0, 10);
switch (i)
{
case 0:
pDfsProgramParam->NewDFSTableEntry[k].mode = DfsParam;
break;
case 1:
pDfsProgramParam->NewDFSTableEntry[k].avgLen = DfsParam;
pDfsProgramParam->NewDFSTableEntry[k].valid = 1;
break;
case 2:
pDfsProgramParam->NewDFSTableEntry[k].ELow = DfsParam;
break;
case 3:
pDfsProgramParam->NewDFSTableEntry[k].EHigh = DfsParam;
break;
case 4:
pDfsProgramParam->NewDFSTableEntry[k].WLow = DfsParam;
break;
case 5:
pDfsProgramParam->NewDFSTableEntry[k].WHigh = DfsParam;
break;
case 6:
pDfsProgramParam->NewDFSTableEntry[k].EpsilonW = DfsParam;
break;
case 7:
pDfsProgramParam->NewDFSTableEntry[k].TLow = DfsParam;
break;
case 8:
pDfsProgramParam->NewDFSTableEntry[k].THigh = DfsParam;
break;
case 9:
pDfsProgramParam->NewDFSTableEntry[k].EpsilonT = DfsParam;
break;
case 10:
pDfsProgramParam->NewDFSTableEntry[k].BLow = DfsParam;
break;
case 11:
pDfsProgramParam->NewDFSTableEntry[k].BHigh = DfsParam;
break;
default:
break;
}
}
}
}
}
}
#endif /* DFS_SUPPORT */
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
{
/*DtimPeriod*/
if(RTMPGetKeyParameter("DtimPeriod", tmpbuf, 10, pBuffer, TRUE))
{
pAd->ApCfg.DtimPeriod = (UCHAR) simple_strtol(tmpbuf, 0, 10);
DBGPRINT(RT_DEBUG_TRACE, ("DtimPeriod=%d\n", pAd->ApCfg.DtimPeriod));
}
}
#endif /* CONFIG_AP_SUPPORT */
/*TxPower*/
if(RTMPGetKeyParameter("TxPower", tmpbuf, 10, pBuffer, TRUE))
{
pAd->CommonCfg.TxPowerPercentage = (ULONG) simple_strtol(tmpbuf, 0, 10);
#ifdef CONFIG_STA_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_STA(pAd)
pAd->CommonCfg.TxPowerDefault = pAd->CommonCfg.TxPowerPercentage;
#endif /* CONFIG_STA_SUPPORT */
DBGPRINT(RT_DEBUG_TRACE, ("TxPower=%ld\n", pAd->CommonCfg.TxPowerPercentage));
}
/*BGProtection*/
if(RTMPGetKeyParameter("BGProtection", tmpbuf, 10, pBuffer, TRUE))
{
/*#if 0 #ifndef WIFI_TEST*/
/* pAd->CommonCfg.UseBGProtection = 2; disable b/g protection for throughput test*/
/*#else*/
switch (simple_strtol(tmpbuf, 0, 10))
{
case 1: /*Always On*/
pAd->CommonCfg.UseBGProtection = 1;
break;
case 2: /*Always OFF*/
pAd->CommonCfg.UseBGProtection = 2;
break;
case 0: /*AUTO*/
default:
pAd->CommonCfg.UseBGProtection = 0;
break;
}
/*#endif*/
DBGPRINT(RT_DEBUG_TRACE, ("BGProtection=%ld\n", pAd->CommonCfg.UseBGProtection));
}
#ifdef CONFIG_AP_SUPPORT
/*OLBCDetection*/
if(RTMPGetKeyParameter("DisableOLBC", tmpbuf, 10, pBuffer, TRUE))
{
switch (simple_strtol(tmpbuf, 0, 10))
{
case 1: /*disable OLBC Detection*/
pAd->CommonCfg.DisableOLBCDetect = 1;
break;
case 0: /*enable OLBC Detection*/
pAd->CommonCfg.DisableOLBCDetect = 0;
break;
default:
pAd->CommonCfg.DisableOLBCDetect= 0;
break;
}
DBGPRINT(RT_DEBUG_TRACE, ("OLBCDetection=%ld\n", pAd->CommonCfg.DisableOLBCDetect));
}
#endif /* CONFIG_AP_SUPPORT */
/*TxPreamble*/
if(RTMPGetKeyParameter("TxPreamble", tmpbuf, 10, pBuffer, TRUE))
{
switch (simple_strtol(tmpbuf, 0, 10))
{
case Rt802_11PreambleShort:
pAd->CommonCfg.TxPreamble = Rt802_11PreambleShort;
break;
case Rt802_11PreambleLong:
default:
pAd->CommonCfg.TxPreamble = Rt802_11PreambleLong;
break;
}
DBGPRINT(RT_DEBUG_TRACE, ("TxPreamble=%ld\n", pAd->CommonCfg.TxPreamble));
}
/*RTSThreshold*/
if(RTMPGetKeyParameter("RTSThreshold", tmpbuf, 10, pBuffer, TRUE))
{
RtsThresh = simple_strtol(tmpbuf, 0, 10);
if( (RtsThresh >= 1) && (RtsThresh <= MAX_RTS_THRESHOLD) )
pAd->CommonCfg.RtsThreshold = (USHORT)RtsThresh;
else
pAd->CommonCfg.RtsThreshold = MAX_RTS_THRESHOLD;
DBGPRINT(RT_DEBUG_TRACE, ("RTSThreshold=%d\n", pAd->CommonCfg.RtsThreshold));
}
/*FragThreshold*/
if(RTMPGetKeyParameter("FragThreshold", tmpbuf, 10, pBuffer, TRUE))
{
FragThresh = simple_strtol(tmpbuf, 0, 10);
pAd->CommonCfg.bUseZeroToDisableFragment = FALSE;
if (FragThresh > MAX_FRAG_THRESHOLD || FragThresh < MIN_FRAG_THRESHOLD)
{ /*illegal FragThresh so we set it to default*/
pAd->CommonCfg.FragmentThreshold = MAX_FRAG_THRESHOLD;
pAd->CommonCfg.bUseZeroToDisableFragment = TRUE;
}
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;
}
/*pAd->CommonCfg.AllowFragSize = (pAd->CommonCfg.FragmentThreshold) - LENGTH_802_11 - LENGTH_CRC;*/
DBGPRINT(RT_DEBUG_TRACE, ("FragThreshold=%d\n", pAd->CommonCfg.FragmentThreshold));
}
/*TxBurst*/
if(RTMPGetKeyParameter("TxBurst", tmpbuf, 10, pBuffer, TRUE))
{
/*#ifdef WIFI_TEST*/
/* pAd->CommonCfg.bEnableTxBurst = FALSE;*/
/*#else*/
if(simple_strtol(tmpbuf, 0, 10) != 0) /*Enable*/
pAd->CommonCfg.bEnableTxBurst = TRUE;
else /*Disable*/
pAd->CommonCfg.bEnableTxBurst = FALSE;
/*#endif*/
DBGPRINT(RT_DEBUG_TRACE, ("TxBurst=%d\n", pAd->CommonCfg.bEnableTxBurst));
}
#ifdef AGGREGATION_SUPPORT
/*PktAggregate*/
if(RTMPGetKeyParameter("PktAggregate", tmpbuf, 10, pBuffer, TRUE))
{
if(simple_strtol(tmpbuf, 0, 10) != 0) /*Enable*/
pAd->CommonCfg.bAggregationCapable = TRUE;
else /*Disable*/
pAd->CommonCfg.bAggregationCapable = FALSE;
#ifdef PIGGYBACK_SUPPORT
pAd->CommonCfg.bPiggyBackCapable = pAd->CommonCfg.bAggregationCapable;
#endif /* PIGGYBACK_SUPPORT */
DBGPRINT(RT_DEBUG_TRACE, ("PktAggregate=%d\n", pAd->CommonCfg.bAggregationCapable));
}
#else
pAd->CommonCfg.bAggregationCapable = FALSE;
pAd->CommonCfg.bPiggyBackCapable = FALSE;
#endif /* AGGREGATION_SUPPORT */
/* WmmCapable*/
#ifdef CONFIG_AP_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
rtmp_read_ap_wmm_parms_from_file(pAd, tmpbuf, pBuffer);
#endif /* CONFIG_AP_SUPPORT */
#ifdef CONFIG_STA_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_STA(pAd)
{
rtmp_read_sta_wmm_parms_from_file(pAd, tmpbuf, pBuffer);
#ifdef XLINK_SUPPORT
rtmp_get_psp_xlink_mode_from_file(pAd, tmpbuf, pBuffer);
#endif /* XLINK_SUPPORT */
}
#endif /* CONFIG_STA_SUPPORT */
#if defined(P2P_SUPPORT) || defined(CONFIG_AP_SUPPORT)
/* IdleTimeout & StationKeepAlive shall be supported in P2P mode,
so moved out from CONFIG_AP_SUPPORT block
*/
/* IdleTimeout*/
if(RTMPGetKeyParameter("IdleTimeout", tmpbuf, 10, pBuffer, TRUE))
{
ApCfg_Set_IdleTimeout_Proc(pAd, tmpbuf);
}
/*StationKeepAlive*/
if(RTMPGetKeyParameter("StationKeepAlive", tmpbuf, 32, pBuffer, TRUE))
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
int apidx = i;
if (i >= pAd->ApCfg.BssidNum)
break;
pAd->ApCfg.MBSSID[apidx].StationKeepAliveTime = simple_strtol(macptr, 0, 10);
DBGPRINT(RT_DEBUG_TRACE, ("I/F(ra%d) StationKeepAliveTime=%d\n", i, pAd->ApCfg.MBSSID[apidx].StationKeepAliveTime));
}
}
#endif /* defined(P2P_SUPPORT) || defined(CONFIG_AP_SUPPORT) */
#ifdef CONFIG_AP_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
{
/* MaxStaNum*/
if (RTMPGetKeyParameter("MaxStaNum", tmpbuf, 32, pBuffer, TRUE))
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
if (i >= pAd->ApCfg.BssidNum)
break;
ApCfg_Set_MaxStaNum_Proc(pAd, i, macptr);
}
}
/*NoForwarding*/
if(RTMPGetKeyParameter("NoForwarding", tmpbuf, 32, pBuffer, TRUE))
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
if (i >= pAd->ApCfg.BssidNum)
break;
if(simple_strtol(macptr, 0, 10) != 0) /*Enable*/
pAd->ApCfg.MBSSID[i].IsolateInterStaTraffic = TRUE;
else /*Disable*/
pAd->ApCfg.MBSSID[i].IsolateInterStaTraffic = FALSE;
DBGPRINT(RT_DEBUG_TRACE, ("I/F(ra%d) NoForwarding=%ld\n", i, pAd->ApCfg.MBSSID[i].IsolateInterStaTraffic));
}
}
/*NoForwardingBTNBSSID*/
if(RTMPGetKeyParameter("NoForwardingBTNBSSID", tmpbuf, 10, pBuffer, TRUE))
{
if(simple_strtol(tmpbuf, 0, 10) != 0) /*Enable*/
pAd->ApCfg.IsolateInterStaTrafficBTNBSSID = TRUE;
else /*Disable*/
pAd->ApCfg.IsolateInterStaTrafficBTNBSSID = FALSE;
DBGPRINT(RT_DEBUG_TRACE, ("NoForwardingBTNBSSID=%ld\n", pAd->ApCfg.IsolateInterStaTrafficBTNBSSID));
}
/*HideSSID*/
if(RTMPGetKeyParameter("HideSSID", tmpbuf, 32, pBuffer, TRUE))
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
int apidx = i;
if (i >= pAd->ApCfg.BssidNum)
break;
if(simple_strtol(macptr, 0, 10) != 0) /*Enable*/
{
pAd->ApCfg.MBSSID[apidx].bHideSsid = TRUE;
#ifdef WSC_V2_SUPPORT
pAd->ApCfg.MBSSID[apidx].WscControl.WscV2Info.bWpsEnable = FALSE;
#endif /* WSC_V2_SUPPORT */
}
else /*Disable*/
pAd->ApCfg.MBSSID[apidx].bHideSsid = FALSE;
DBGPRINT(RT_DEBUG_TRACE, ("I/F(ra%d) HideSSID=%d\n", i, pAd->ApCfg.MBSSID[apidx].bHideSsid));
}
}
/*AutoChannelSelect*/
if(RTMPGetKeyParameter("AutoChannelSelect", tmpbuf, 10, pBuffer, TRUE))
{
if(simple_strtol(tmpbuf, 0, 10) != 0) /*Enable*/
{
ChannelSel_Alg SelAlg=(ChannelSel_Alg)simple_strtol(tmpbuf, 0, 10);
if (SelAlg > 2 || SelAlg < 0)
{
pAd->ApCfg.bAutoChannelAtBootup = FALSE;
}
else /*Enable*/
{
pAd->ApCfg.bAutoChannelAtBootup = TRUE;
pAd->ApCfg.AutoChannelAlg = SelAlg;
}
}
else /*Disable*/
pAd->ApCfg.bAutoChannelAtBootup = FALSE;
DBGPRINT(RT_DEBUG_TRACE, ("AutoChannelAtBootup=%d\n", pAd->ApCfg.bAutoChannelAtBootup));
}
/*AutoChannelSkipList*/
if (RTMPGetKeyParameter("AutoChannelSkipList", tmpbuf, 50, pBuffer, FALSE))
{
pAd->ApCfg.AutoChannelSkipListNum = delimitcnt(tmpbuf, ";") + 1;
if ( pAd->ApCfg.AutoChannelSkipListNum > 10 )
{
DBGPRINT(RT_DEBUG_TRACE, ("Your no. of AutoChannelSkipList( %d ) is larger than 10 (boundary)\n",pAd->ApCfg.AutoChannelSkipListNum));
pAd->ApCfg.AutoChannelSkipListNum = 10;
}
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr ; macptr = rstrtok(NULL,";"), i++)
{
if (i < pAd->ApCfg.AutoChannelSkipListNum )
{
pAd->ApCfg.AutoChannelSkipList[i] = simple_strtol(macptr, 0, 10);
DBGPRINT(RT_DEBUG_TRACE, (" AutoChannelSkipList[%d]= %d \n", i, pAd->ApCfg.AutoChannelSkipList[i]));
}
else
{
break;
}
}
}
#ifdef AP_SCAN_SUPPORT
/*ACSCheckTime*/
if (RTMPGetKeyParameter("ACSCheckTime", tmpbuf, 32, pBuffer, TRUE))
{
UINT8 Hour = simple_strtol(tmpbuf, 0, 10);
pAd->ApCfg.ACSCheckTime = Hour*3600; /* Hour to second */
DBGPRINT(RT_DEBUG_TRACE, ("ACSCheckTime = %u (hour) \n", Hour));
}
#endif /* AP_SCAN_SUPPORT */
}
#endif /* CONFIG_AP_SUPPORT */
/*ShortSlot*/
if(RTMPGetKeyParameter("ShortSlot", tmpbuf, 10, pBuffer, TRUE))
{
RT_CfgSetShortSlot(pAd, tmpbuf);
DBGPRINT(RT_DEBUG_TRACE, ("ShortSlot=%d\n", pAd->CommonCfg.bUseShortSlotTime));
}
#ifdef TXBF_SUPPORT
if (pAd->chipCap.FlgHwTxBfCap)
{
#if defined(CONFIG_AP_SUPPORT) || defined(STA_ITXBF_SUPPORT)
/*ITxBfEn*/
if(RTMPGetKeyParameter("ITxBfEn", tmpbuf, 32, pBuffer, TRUE))
{
pAd->CommonCfg.RegTransmitSetting.field.ITxBfEn = (simple_strtol(tmpbuf, 0, 10) != 0);
DBGPRINT(RT_DEBUG_TRACE, ("ITxBfEn = %d\n", pAd->CommonCfg.RegTransmitSetting.field.ITxBfEn));
rtmp_asic_set_bf(pAd);
}
/* ITxBfTimeout */
if(RTMPGetKeyParameter("ITxBfTimeout", tmpbuf, 32, pBuffer, TRUE))
{
pAd->CommonCfg.ITxBfTimeout = simple_strtol(tmpbuf, 0, 10);
DBGPRINT(RT_DEBUG_TRACE, ("ITxBfTimeout = %ld\n", pAd->CommonCfg.ITxBfTimeout));
}
#endif /* defined(CONFIG_AP_SUPPORT) || defined(STA_ITXBF_SUPPORT) */
/* ETxBfEnCond*/
if(RTMPGetKeyParameter("ETxBfEnCond", tmpbuf, 32, pBuffer, TRUE))
{
pAd->CommonCfg.ETxBfEnCond = simple_strtol(tmpbuf, 0, 10);
DBGPRINT(RT_DEBUG_TRACE, ("ETxBfEnCond = %ld\n", pAd->CommonCfg.ETxBfEnCond));
if (pAd->CommonCfg.ETxBfEnCond)
{
pAd->CommonCfg.RegTransmitSetting.field.TxBF = TRUE;
}
else
{
pAd->CommonCfg.RegTransmitSetting.field.TxBF = FALSE;
}
rtmp_asic_set_bf(pAd);
}
/* ETxBfTimeout*/
if(RTMPGetKeyParameter("ETxBfTimeout", tmpbuf, 32, pBuffer, TRUE))
{
pAd->CommonCfg.ETxBfTimeout = simple_strtol(tmpbuf, 0, 10);
DBGPRINT(RT_DEBUG_TRACE, ("ETxBfTimeout = %ld\n", pAd->CommonCfg.ETxBfTimeout));
}
/* ETxBfNoncompress*/
if(RTMPGetKeyParameter("ETxBfNoncompress", tmpbuf, 32, pBuffer, TRUE))
{
pAd->CommonCfg.ETxBfNoncompress = simple_strtol(tmpbuf, 0, 10);
DBGPRINT(RT_DEBUG_TRACE, ("ETxBfNoncompress = %d\n", pAd->CommonCfg.ETxBfNoncompress));
}
/* ETxBfIncapable */
if(RTMPGetKeyParameter("ETxBfIncapable", tmpbuf, 32, pBuffer, TRUE))
{
pAd->CommonCfg.ETxBfIncapable = simple_strtol(tmpbuf, 0, 10);
DBGPRINT(RT_DEBUG_TRACE, ("ETxBfIncapable = %d\n", pAd->CommonCfg.ETxBfIncapable));
}
}
#endif /* TXBF_SUPPORT */
#ifdef PRE_ANT_SWITCH
/*PreAntSwitch*/
if(RTMPGetKeyParameter("PreAntSwitch", tmpbuf, 32, pBuffer, TRUE))
{
pAd->CommonCfg.PreAntSwitch = (simple_strtol(tmpbuf, 0, 10) != 0);
DBGPRINT(RT_DEBUG_TRACE, ("PreAntSwitch = %d\n", pAd->CommonCfg.PreAntSwitch));
}
#endif /* PRE_ANT_SWITCH */
#ifdef STREAM_MODE_SUPPORT
/* StreamMode*/
if (pAd->chipCap.FlgHwStreamMode)
{
if(RTMPGetKeyParameter("StreamMode", tmpbuf, 32, pBuffer, TRUE))
{
pAd->CommonCfg.StreamMode = (simple_strtol(tmpbuf, 0, 10) & 0x03);
DBGPRINT(RT_DEBUG_TRACE, ("StreamMode= %d\n", pAd->CommonCfg.StreamMode));
}
/* StreamModeMac*/
for (i = 0; i < STREAM_MODE_STA_NUM; i++)
{
STRING tok_str[32];
sprintf(tok_str, "StreamModeMac%d", i);
if (RTMPGetKeyParameter(tok_str, tmpbuf, MAX_PARAM_BUFFER_SIZE, pBuffer, TRUE))
{
int j;
if(strlen(tmpbuf) != 17) /*Mac address acceptable format 01:02:03:04:05:06 length 17*/
continue;
for (j=0; j<ETH_LENGTH_OF_ADDRESS; j++)
{
AtoH(tmpbuf, &pAd->CommonCfg.StreamModeMac[i][j], 1);
tmpbuf=tmpbuf+3;
}
}
}
if (NdisEqualMemory(ZERO_MAC_ADDR, &pAd->CommonCfg.StreamModeMac[0][0], MAC_ADDR_LEN))
{
/* set default broadcast mac to entry 0 if user not set it */
NdisMoveMemory(&pAd->CommonCfg.StreamModeMac[0][0], BROADCAST_ADDR, MAC_ADDR_LEN);
}
}
#endif /* STREAM_MODE_SUPPORT */
#ifdef DBG_CTRL_SUPPORT
/*DebugFlags*/
if(RTMPGetKeyParameter("DebugFlags", tmpbuf, 32, pBuffer, TRUE))
{
pAd->CommonCfg.DebugFlags = simple_strtol(tmpbuf, 0, 16);
DBGPRINT(RT_DEBUG_TRACE, ("DebugFlags = 0x%02lx\n", pAd->CommonCfg.DebugFlags));
}
#endif /* DBG_CTRL_SUPPORT */
/*IEEE80211H*/
if(RTMPGetKeyParameter("IEEE80211H", tmpbuf, 10, pBuffer, TRUE))
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
if(simple_strtol(macptr, 0, 10) != 0) /*Enable*/
pAd->CommonCfg.bIEEE80211H = TRUE;
else /*Disable*/
pAd->CommonCfg.bIEEE80211H = FALSE;
DBGPRINT(RT_DEBUG_TRACE, ("IEEE80211H=%d\n", pAd->CommonCfg.bIEEE80211H));
}
}
#ifdef DFS_SUPPORT
{
/*CSPeriod*/
if(RTMPGetKeyParameter("CSPeriod", tmpbuf, 10, pBuffer, TRUE))
{
if(simple_strtol(tmpbuf, 0, 10) != 0)
pAd->Dot11_H.CSPeriod = simple_strtol(tmpbuf, 0, 10);
else
pAd->Dot11_H.CSPeriod = 0;
DBGPRINT(RT_DEBUG_TRACE, ("CSPeriod=%d\n", pAd->Dot11_H.CSPeriod));
}
}
#endif /* DFS_SUPPORT */
/*RDRegion*/
if(RTMPGetKeyParameter("RDRegion", tmpbuf, 128, pBuffer, TRUE))
{
if ((strncmp(tmpbuf, "JAP_W53", 7) == 0) || (strncmp(tmpbuf, "jap_w53", 7) == 0))
{
pAd->CommonCfg.RDDurRegion = JAP_W53;
/*pRadarDetect->DfsSessionTime = 15;*/
}
else if ((strncmp(tmpbuf, "JAP_W56", 7) == 0) || (strncmp(tmpbuf, "jap_w56", 7) == 0))
{
pAd->CommonCfg.RDDurRegion = JAP_W56;
/*pRadarDetect->DfsSessionTime = 13;*/
}
else if ((strncmp(tmpbuf, "JAP", 3) == 0) || (strncmp(tmpbuf, "jap", 3) == 0))
{
pAd->CommonCfg.RDDurRegion = JAP;
/*pRadarDetect->DfsSessionTime = 5;*/
}
else if ((strncmp(tmpbuf, "FCC", 3) == 0) || (strncmp(tmpbuf, "fcc", 3) == 0))
{
pAd->CommonCfg.RDDurRegion = FCC;
/*pRadarDetect->DfsSessionTime = 5;*/
}
else if ((strncmp(tmpbuf, "CE", 2) == 0) || (strncmp(tmpbuf, "ce", 2) == 0))
{
pAd->CommonCfg.RDDurRegion = CE;
/*pRadarDetect->DfsSessionTime = 13;*/
}
else
{
pAd->CommonCfg.RDDurRegion = CE;
/*pRadarDetect->DfsSessionTime = 13;*/
}
DBGPRINT(RT_DEBUG_TRACE, ("RDRegion=%d\n", pAd->CommonCfg.RDDurRegion));
}
else
{
pAd->CommonCfg.RDDurRegion = CE;
/*pRadarDetect->DfsSessionTime = 13;*/
}
#ifdef SYSTEM_LOG_SUPPORT
/*WirelessEvent*/
if(RTMPGetKeyParameter("WirelessEvent", tmpbuf, 10, pBuffer, TRUE))
{
BOOLEAN FlgIsWEntSup = FALSE;
if(simple_strtol(tmpbuf, 0, 10) != 0)
FlgIsWEntSup = TRUE;
RtmpOsWlanEventSet(pAd, &pAd->CommonCfg.bWirelessEvent, FlgIsWEntSup);
DBGPRINT(RT_DEBUG_TRACE, ("WirelessEvent=%d\n", pAd->CommonCfg.bWirelessEvent));
}
#endif /* SYSTEM_LOG_SUPPORT */
/*AuthMode*/
if(RTMPGetKeyParameter("AuthMode", tmpbuf, 128, pBuffer, TRUE))
{
#ifdef CONFIG_AP_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); (macptr && i < pAd->ApCfg.BssidNum); macptr = rstrtok(NULL,";"), i++)
{
ApCfg_Set_AuthMode_Proc(pAd, i, macptr);
}
}
#endif /* CONFIG_AP_SUPPORT */
#ifdef CONFIG_STA_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_STA(pAd)
{
if ((strcmp(tmpbuf, "WEPAUTO") == 0) || (strcmp(tmpbuf, "wepauto") == 0))
pAd->StaCfg.AuthMode = Ndis802_11AuthModeAutoSwitch;
else if ((strcmp(tmpbuf, "SHARED") == 0) || (strcmp(tmpbuf, "shared") == 0))
pAd->StaCfg.AuthMode = Ndis802_11AuthModeShared;
else if ((strcmp(tmpbuf, "WPAPSK") == 0) || (strcmp(tmpbuf, "wpapsk") == 0))
pAd->StaCfg.AuthMode = Ndis802_11AuthModeWPAPSK;
else if ((strcmp(tmpbuf, "WPANONE") == 0) || (strcmp(tmpbuf, "wpanone") == 0))
pAd->StaCfg.AuthMode = Ndis802_11AuthModeWPANone;
else if ((strcmp(tmpbuf, "WPA2PSK") == 0) || (strcmp(tmpbuf, "wpa2psk") == 0))
pAd->StaCfg.AuthMode = Ndis802_11AuthModeWPA2PSK;
#ifdef WPA_SUPPLICANT_SUPPORT
else if ((strcmp(tmpbuf, "WPA") == 0) || (strcmp(tmpbuf, "wpa") == 0))
pAd->StaCfg.AuthMode = Ndis802_11AuthModeWPA;
else if ((strcmp(tmpbuf, "WPA2") == 0) || (strcmp(tmpbuf, "wpa2") == 0))
pAd->StaCfg.AuthMode = Ndis802_11AuthModeWPA2;
#endif /* WPA_SUPPLICANT_SUPPORT */
#ifdef WAPI_SUPPORT
else if ((strcmp(tmpbuf, "WAICERT") == 0) || (strcmp(tmpbuf, "waicert") == 0))
pAd->StaCfg.AuthMode = Ndis802_11AuthModeWAICERT;
else if ((strcmp(tmpbuf, "WAIPSK") == 0) || (strcmp(tmpbuf, "waipsk") == 0))
pAd->StaCfg.AuthMode = Ndis802_11AuthModeWAIPSK;
#endif /* WAPI_SUPPORT */
else
pAd->StaCfg.AuthMode = Ndis802_11AuthModeOpen;
pAd->StaCfg.PortSecured = WPA_802_1X_PORT_NOT_SECURED;
DBGPRINT(RT_DEBUG_TRACE, ("%s::(AuthMode=%d)\n", __FUNCTION__, pAd->StaCfg.AuthMode));
}
#endif /* CONFIG_STA_SUPPORT */
}
/*EncrypType*/
if(RTMPGetKeyParameter("EncrypType", tmpbuf, 128, pBuffer, TRUE))
{
#ifdef CONFIG_AP_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
{
/*
We need to reset the WepStatus of all interfaces as 1 (Ndis802_11WEPDisabled) first.
Or it may have problem when some interface enabled but didn't configure it.
*/
for ( i= 0; i<pAd->ApCfg.BssidNum; i++)
pAd->ApCfg.MBSSID[i].WepStatus = Ndis802_11WEPDisabled;
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
int apidx;
if (i<pAd->ApCfg.BssidNum)
{
apidx = i;
}
else
{
break;
}
if ((strncmp(macptr, "NONE", 4) == 0) || (strncmp(macptr, "none", 4) == 0))
pAd->ApCfg.MBSSID[apidx].WepStatus = Ndis802_11WEPDisabled;
else if ((strncmp(macptr, "WEP", 3) == 0) || (strncmp(macptr, "wep", 3) == 0))
pAd->ApCfg.MBSSID[apidx].WepStatus = Ndis802_11WEPEnabled;
else if ((strncmp(macptr, "TKIPAES", 7) == 0) || (strncmp(macptr, "tkipaes", 7) == 0))
pAd->ApCfg.MBSSID[apidx].WepStatus = Ndis802_11Encryption4Enabled;
else if ((strncmp(macptr, "TKIP", 4) == 0) || (strncmp(macptr, "tkip", 4) == 0))
pAd->ApCfg.MBSSID[apidx].WepStatus = Ndis802_11Encryption2Enabled;
else if ((strncmp(macptr, "AES", 3) == 0) || (strncmp(macptr, "aes", 3) == 0))
pAd->ApCfg.MBSSID[apidx].WepStatus = Ndis802_11Encryption3Enabled;
#ifdef WAPI_SUPPORT
else if ((strncmp(macptr, "SMS4", 4) == 0) || (strncmp(macptr, "sms4", 4) == 0))
pAd->ApCfg.MBSSID[apidx].WepStatus = Ndis802_11EncryptionSMS4Enabled;
#endif /* WAPI_SUPPORT */
else
pAd->ApCfg.MBSSID[apidx].WepStatus = Ndis802_11WEPDisabled;
/* decide the group key encryption type*/
if (pAd->ApCfg.MBSSID[apidx].WepStatus == Ndis802_11Encryption4Enabled)
pAd->ApCfg.MBSSID[apidx].GroupKeyWepStatus = Ndis802_11Encryption2Enabled;
else
pAd->ApCfg.MBSSID[apidx].GroupKeyWepStatus = pAd->ApCfg.MBSSID[apidx].WepStatus;
/* move to ap.c::APStartUp to process*/
/*RTMPMakeRSNIE(pAd, pAd->ApCfg.MBSSID[apidx].AuthMode, pAd->ApCfg.MBSSID[apidx].WepStatus, apidx);*/
DBGPRINT(RT_DEBUG_TRACE, ("I/F(ra%d) EncrypType=%d\n", i, pAd->ApCfg.MBSSID[apidx].WepStatus));
}
}
#endif /* CONFIG_AP_SUPPORT */
#ifdef CONFIG_STA_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_STA(pAd)
{
if ((strcmp(tmpbuf, "WEP") == 0) || (strcmp(tmpbuf, "wep") == 0))
pAd->StaCfg.WepStatus = Ndis802_11WEPEnabled;
else if ((strcmp(tmpbuf, "TKIP") == 0) || (strcmp(tmpbuf, "tkip") == 0))
pAd->StaCfg.WepStatus = Ndis802_11Encryption2Enabled;
else if ((strcmp(tmpbuf, "AES") == 0) || (strcmp(tmpbuf, "aes") == 0))
pAd->StaCfg.WepStatus = Ndis802_11Encryption3Enabled;
#ifdef WAPI_SUPPORT
else if ((strcmp(tmpbuf, "SMS4") == 0) || (strcmp(tmpbuf, "sms4") == 0))
pAd->StaCfg.WepStatus = Ndis802_11EncryptionSMS4Enabled;
#endif /* WAPI_SUPPORT */
else
pAd->StaCfg.WepStatus = Ndis802_11WEPDisabled;
RTMPSetSTACipherSuites(pAd, pAd->StaCfg.WepStatus);
/*RTMPMakeRSNIE(pAd, pAd->StaCfg.AuthMode, pAd->StaCfg.WepStatus, 0);*/
DBGPRINT(RT_DEBUG_TRACE, ("%s::(EncrypType=%d)\n", __FUNCTION__, pAd->StaCfg.WepStatus));
}
#endif /* CONFIG_STA_SUPPORT */
}
#ifdef CONFIG_AP_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
{
/* WpaMixPairCipher*/
if(RTMPGetKeyParameter("WpaMixPairCipher", tmpbuf, 256, pBuffer, TRUE))
{
/*
In WPA-WPA2 mix mode, it provides a more flexible cipher combination.
- WPA-AES and WPA2-TKIP
- WPA-AES and WPA2-TKIPAES
- WPA-TKIP and WPA2-AES
- WPA-TKIP and WPA2-TKIPAES
- WPA-TKIPAES and WPA2-AES
- WPA-TKIPAES and WPA2-TKIP
- WPA-TKIPAES and WPA2-TKIPAES (default)
*/
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
if (pAd->ApCfg.MBSSID[i].AuthMode != Ndis802_11AuthModeWPA1WPA2 &&
pAd->ApCfg.MBSSID[i].AuthMode != Ndis802_11AuthModeWPA1PSKWPA2PSK)
continue;
if (pAd->ApCfg.MBSSID[i].WepStatus != Ndis802_11Encryption4Enabled)
continue;
if ((strncmp(macptr, "WPA_AES_WPA2_TKIPAES", 20) == 0) || (strncmp(macptr, "wpa_aes_wpa2_tkipaes", 20) == 0))
pAd->ApCfg.MBSSID[i].WpaMixPairCipher = WPA_AES_WPA2_TKIPAES;
else if ((strncmp(macptr, "WPA_AES_WPA2_TKIP", 17) == 0) || (strncmp(macptr, "wpa_aes_wpa2_tkip", 17) == 0))
pAd->ApCfg.MBSSID[i].WpaMixPairCipher = WPA_AES_WPA2_TKIP;
else if ((strncmp(macptr, "WPA_TKIP_WPA2_AES", 17) == 0) || (strncmp(macptr, "wpa_tkip_wpa2_aes", 17) == 0))
pAd->ApCfg.MBSSID[i].WpaMixPairCipher = WPA_TKIP_WPA2_AES;
else if ((strncmp(macptr, "WPA_TKIP_WPA2_TKIPAES", 21) == 0) || (strncmp(macptr, "wpa_tkip_wpa2_tkipaes", 21) == 0))
pAd->ApCfg.MBSSID[i].WpaMixPairCipher = WPA_TKIP_WPA2_TKIPAES;
else if ((strncmp(macptr, "WPA_TKIPAES_WPA2_AES", 20) == 0) || (strncmp(macptr, "wpa_tkipaes_wpa2_aes", 20) == 0))
pAd->ApCfg.MBSSID[i].WpaMixPairCipher = WPA_TKIPAES_WPA2_AES;
else if ((strncmp(macptr, "WPA_TKIPAES_WPA2_TKIPAES", 24) == 0) || (strncmp(macptr, "wpa_tkipaes_wpa2_tkipaes", 24) == 0))
pAd->ApCfg.MBSSID[i].WpaMixPairCipher = WPA_TKIPAES_WPA2_TKIPAES;
else if ((strncmp(macptr, "WPA_TKIPAES_WPA2_TKIP", 21) == 0) || (strncmp(macptr, "wpa_tkipaes_wpa2_tkip", 21) == 0))
pAd->ApCfg.MBSSID[i].WpaMixPairCipher = WPA_TKIPAES_WPA2_TKIP;
else /*Default*/
pAd->ApCfg.MBSSID[i].WpaMixPairCipher = WPA_TKIPAES_WPA2_TKIPAES;
DBGPRINT(RT_DEBUG_OFF, ("I/F(ra%d) MixWPACipher=0x%02x\n", i, pAd->ApCfg.MBSSID[i].WpaMixPairCipher));
}
}
/*RekeyMethod*/
if(RTMPGetKeyParameter("RekeyMethod", tmpbuf, 128, pBuffer, TRUE))
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
PRT_WPA_REKEY pRekeyInfo = &pAd->ApCfg.MBSSID[i].WPAREKEY;
if ((strcmp(macptr, "TIME") == 0) || (strcmp(macptr, "time") == 0))
pRekeyInfo->ReKeyMethod = TIME_REKEY;
else if ((strcmp(macptr, "PKT") == 0) || (strcmp(macptr, "pkt") == 0))
pRekeyInfo->ReKeyMethod = PKT_REKEY;
else if ((strcmp(macptr, "DISABLE") == 0) || (strcmp(macptr, "disable") == 0))
pRekeyInfo->ReKeyMethod = DISABLE_REKEY;
else
pRekeyInfo->ReKeyMethod = DISABLE_REKEY;
DBGPRINT(RT_DEBUG_TRACE, ("I/F(ra%d) ReKeyMethod=%ld\n", i, pRekeyInfo->ReKeyMethod));
}
/* Apply to remaining MBSS*/
if (i == 1)
{
for (i = 1; i < pAd->ApCfg.BssidNum; i++)
{
pAd->ApCfg.MBSSID[i].WPAREKEY.ReKeyMethod =
pAd->ApCfg.MBSSID[0].WPAREKEY.ReKeyMethod;
DBGPRINT(RT_DEBUG_TRACE, ("I/F(ra%d) ReKeyMethod=%ld\n",
i, pAd->ApCfg.MBSSID[i].WPAREKEY.ReKeyMethod));
}
}
}
/*RekeyInterval*/
if(RTMPGetKeyParameter("RekeyInterval", tmpbuf, 255, pBuffer, TRUE))
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
ULONG value_interval;
PRT_WPA_REKEY pRekeyInfo = &pAd->ApCfg.MBSSID[i].WPAREKEY;
value_interval = simple_strtol(macptr, 0, 10);
if((value_interval >= 10) && (value_interval < MAX_REKEY_INTER))
pRekeyInfo->ReKeyInterval = value_interval;
else /*Default*/
pRekeyInfo->ReKeyInterval = 3600;
DBGPRINT(RT_DEBUG_TRACE, ("I/F(ra%d) ReKeyInterval=%ld\n",
i, pRekeyInfo->ReKeyInterval));
}
/* Apply to remaining MBSS*/
if (i == 1)
{
for (i = 1; i < pAd->ApCfg.BssidNum; i++)
{
pAd->ApCfg.MBSSID[i].WPAREKEY.ReKeyInterval =
pAd->ApCfg.MBSSID[0].WPAREKEY.ReKeyInterval;
DBGPRINT(RT_DEBUG_TRACE, ("I/F(ra%d) ReKeyInterval=%ld\n",
i, pAd->ApCfg.MBSSID[i].WPAREKEY.ReKeyInterval));
}
}
}
/*PMKCachePeriod*/
if(RTMPGetKeyParameter("PMKCachePeriod", tmpbuf, 255, pBuffer, TRUE))
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
pAd->ApCfg.MBSSID[i].PMKCachePeriod =
simple_strtol(macptr, 0, 10) * 60 * OS_HZ;
DBGPRINT(RT_DEBUG_TRACE, ("I/F(ra%d) PMKCachePeriod=%ld\n",
i, pAd->ApCfg.MBSSID[i].PMKCachePeriod));
}
/* Apply to remaining MBSS*/
if (i == 1)
{
for (i = 1; i < pAd->ApCfg.BssidNum; i++)
{
pAd->ApCfg.MBSSID[i].PMKCachePeriod =
pAd->ApCfg.MBSSID[0].PMKCachePeriod;
DBGPRINT(RT_DEBUG_TRACE, ("I/F(ra%d) PMKCachePeriod=%ld\n",
i, pAd->ApCfg.MBSSID[i].PMKCachePeriod));
}
}
}
/*WPAPSK_KEY*/
if(TRUE)
{
STRING tok_str[16];
BOOLEAN bWPAPSKxIsUsed = FALSE;
//DBGPRINT(RT_DEBUG_TRACE, ("pAd->ApCfg.BssidNum=%d\n", pAd->ApCfg.BssidNum));
for (i = 0; i < pAd->ApCfg.BssidNum; i++)
{
snprintf(tok_str, sizeof(tok_str), "WPAPSK%d", i + 1);
if(RTMPGetKeyParameter(tok_str, tmpbuf, 65, pBuffer, FALSE))
{
rtmp_parse_wpapsk_buffer_from_file(pAd, tmpbuf, i);
if (bWPAPSKxIsUsed == FALSE)
{
bWPAPSKxIsUsed = TRUE;
}
}
}
if (bWPAPSKxIsUsed == FALSE)
{
if (RTMPGetKeyParameter("WPAPSK", tmpbuf, 512, pBuffer, FALSE))
{
if (pAd->ApCfg.BssidNum == 1)
{
rtmp_parse_wpapsk_buffer_from_file(pAd, tmpbuf, BSS0);
}
else
{
/* Anyway, we still do the legacy dissection of the whole WPAPSK passphrase.*/
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
rtmp_parse_wpapsk_buffer_from_file(pAd, macptr, i);
}
}
}
}
#ifdef DBG
for (i = 0; i < pAd->ApCfg.BssidNum; i++)
{
int j;
DBGPRINT(RT_DEBUG_TRACE, ("I/F(ra%d) WPAPSK Key => \n", i));
for (j = 0; j < 32; j++)
{
DBGPRINT(RT_DEBUG_TRACE, ("%02x:", pAd->ApCfg.MBSSID[i].PMK[j]));
if ((j%16) == 15)
DBGPRINT(RT_DEBUG_TRACE, ("\n"));
}
DBGPRINT(RT_DEBUG_TRACE, ("\n"));
}
#endif
}
}
#endif /* CONFIG_AP_SUPPORT */
#ifdef CONFIG_STA_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_STA(pAd)
{
if(RTMPGetKeyParameter("WPAPSK", tmpbuf, 512, pBuffer, FALSE))
RTMPSetSTAPassPhrase(pAd, tmpbuf);
}
#endif /* CONFIG_STA_SUPPORT */
/*DefaultKeyID, KeyType, KeyStr*/
rtmp_read_key_parms_from_file(pAd, tmpbuf, pBuffer);
#ifdef WAPI_SUPPORT
rtmp_read_wapi_parms_from_file(pAd, tmpbuf, pBuffer);
#endif /* WAPI_SUPPORT */
#ifdef CONFIG_AP_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
{
/*Access Control List*/
rtmp_read_acl_parms_from_file(pAd, tmpbuf, pBuffer);
#ifdef APCLI_SUPPORT
rtmp_read_ap_client_from_file(pAd, tmpbuf, pBuffer);
#endif /* APCLI_SUPPORT */
#ifdef IGMP_SNOOP_SUPPORT
/* Igmp Snooping information*/
rtmp_read_igmp_snoop_from_file(pAd, tmpbuf, pBuffer);
#endif /* IGMP_SNOOP_SUPPORT */
#ifdef DOT1X_SUPPORT
rtmp_read_radius_parms_from_file(pAd, tmpbuf, pBuffer);
#endif /* DOT1X_SUPPORT */
#ifdef IDS_SUPPORT
rtmp_read_ids_from_file(pAd, tmpbuf, pBuffer);
#endif /* IDS_SUPPORT */
rtmp_read_multest_from_file(pAd, tmpbuf, pBuffer);
}
#endif /* CONFIG_AP_SUPPORT */
#ifdef DOT11_N_SUPPORT
HTParametersHook(pAd, tmpbuf, pBuffer);
#endif /* DOT11_N_SUPPORT */
#ifdef DOT11_VHT_AC
VHTParametersHook(pAd, tmpbuf, pBuffer);
#endif /* DOT11_VHT_AC */
#ifdef CONFIG_AP_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
{
#ifdef WSC_AP_SUPPORT
STRING tok_str[16] = {0};
for (i = 0; i < pAd->ApCfg.BssidNum; i++)
{
snprintf(tok_str, sizeof(tok_str), "WscDefaultSSID%d", i + 1);
if(RTMPGetKeyParameter(tok_str, tmpbuf, 33, pBuffer, FALSE))
{
NdisZeroMemory(&pAd->ApCfg.MBSSID[i].WscControl.WscDefaultSsid, sizeof(NDIS_802_11_SSID));
NdisMoveMemory(pAd->ApCfg.MBSSID[i].WscControl.WscDefaultSsid.Ssid, tmpbuf , strlen(tmpbuf));
pAd->ApCfg.MBSSID[i].WscControl.WscDefaultSsid.SsidLength = strlen(tmpbuf);
DBGPRINT(RT_DEBUG_TRACE, ("WscDefaultSSID[%d]=%s\n", i, pAd->ApCfg.MBSSID[i].WscControl.WscDefaultSsid.Ssid));
}
}
/*WscConfMode*/
if(RTMPGetKeyParameter("WscConfMode", tmpbuf, 10, pBuffer, TRUE))
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
INT WscConfMode = simple_strtol(macptr, 0, 10);
if (i >= pAd->ApCfg.BssidNum)
break;
if (WscConfMode > 0 && WscConfMode < 8)
{
pAd->ApCfg.MBSSID[i].WscControl.WscConfMode = WscConfMode;
}
else
{
pAd->ApCfg.MBSSID[i].WscControl.WscConfMode = WSC_DISABLE;
}
DBGPRINT(RT_DEBUG_TRACE, ("I/F(ra%d) WscConfMode=%d\n", i, pAd->ApCfg.MBSSID[i].WscControl.WscConfMode));
}
}
/*WscConfStatus*/
if(RTMPGetKeyParameter("WscConfStatus", tmpbuf, 10, pBuffer, TRUE))
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
if (i >= pAd->ApCfg.BssidNum)
break;
pAd->ApCfg.MBSSID[i].WscControl.WscConfStatus = (INT) simple_strtol(macptr, 0, 10);
DBGPRINT(RT_DEBUG_TRACE, ("I/F(ra%d) WscConfStatus=%d\n", i, pAd->ApCfg.MBSSID[i].WscControl.WscConfStatus));
}
}
/*WscConfMethods*/
if(RTMPGetKeyParameter("WscConfMethods", tmpbuf, 32, pBuffer, TRUE))
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
if (i >= pAd->ApCfg.BssidNum)
break;
pAd->ApCfg.MBSSID[i].WscControl.WscConfigMethods = (USHORT)simple_strtol(macptr, 0, 16);
DBGPRINT(RT_DEBUG_TRACE, ("I/F(ra%d) WscConfMethods=0x%x\n", i, pAd->ApCfg.MBSSID[i].WscControl.WscConfigMethods));
}
}
/*WscKeyASCII (0:Hex, 1:ASCII(random length), others: ASCII length, default 8)*/
if (RTMPGetKeyParameter("WscKeyASCII", tmpbuf, 10, pBuffer, TRUE))
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
INT Value;
if (i >= pAd->ApCfg.BssidNum)
break;
Value = (INT) simple_strtol(tmpbuf, 0, 10);
if(Value==0 || Value==1)
pAd->ApCfg.MBSSID[i].WscControl.WscKeyASCII = Value;
else if(Value >= 8 && Value <=63)
pAd->ApCfg.MBSSID[i].WscControl.WscKeyASCII = Value;
else
pAd->ApCfg.MBSSID[i].WscControl.WscKeyASCII = 8;
DBGPRINT(RT_DEBUG_WARN, ("WscKeyASCII=%d\n", pAd->ApCfg.MBSSID[i].WscControl.WscKeyASCII));
}
}
if (RTMPGetKeyParameter("WscSecurityMode", tmpbuf, 50, pBuffer, TRUE))
{
for (i= 0; i<pAd->ApCfg.BssidNum; i++)
pAd->ApCfg.MBSSID[i].WscSecurityMode = WPAPSKTKIP;
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
INT tmpMode = 0;
if (i >= pAd->ApCfg.BssidNum)
break;
tmpMode = (INT) simple_strtol(macptr, 0, 10);
if (tmpMode <= WPAPSKTKIP)
pAd->ApCfg.MBSSID[i].WscSecurityMode = tmpMode;
DBGPRINT(RT_DEBUG_TRACE, ("RTMPSetProfileParameters I/F(ra%d) WscSecurityMode=%d\n",
i, pAd->ApCfg.MBSSID[i].WscSecurityMode));
}
}
/* WCNTest*/
if(RTMPGetKeyParameter("WCNTest", tmpbuf, 10, pBuffer, TRUE))
{
BOOLEAN bEn = FALSE;
if ((strncmp(tmpbuf, "0", 1) == 0))
bEn = FALSE;
else
bEn = TRUE;
for (i = 0; i < pAd->ApCfg.BssidNum; i++)
{
pAd->ApCfg.MBSSID[i].WscControl.bWCNTest = bEn;
}
DBGPRINT(RT_DEBUG_TRACE, ("WCNTest=%d\n", bEn));
}
/*WSC UUID Str*/
for (i = 0; i < pAd->ApCfg.BssidNum; i++)
{
PWSC_CTRL pWpsCtrl = &pAd->ApCfg.MBSSID[i].WscControl;
snprintf(tok_str, sizeof(tok_str), "WSC_UUID_Str%d", i + 1);
if(RTMPGetKeyParameter(tok_str, tmpbuf, 40, pBuffer, FALSE))
{
NdisMoveMemory(&pWpsCtrl->Wsc_Uuid_Str[0], tmpbuf , strlen(tmpbuf));
DBGPRINT(RT_DEBUG_TRACE, ("UUID_Str[%d]=%s\n", i+1, pWpsCtrl->Wsc_Uuid_Str));
}
}
/*WSC UUID Hex*/
for (i = 0; i < pAd->ApCfg.BssidNum; i++)
{
PWSC_CTRL pWpsCtrl = &pAd->ApCfg.MBSSID[i].WscControl;
snprintf(tok_str, sizeof(tok_str), "WSC_UUID_E%d", i + 1);
if(RTMPGetKeyParameter(tok_str, tmpbuf, 40, pBuffer, FALSE))
{
AtoH(tmpbuf, &pWpsCtrl->Wsc_Uuid_E[0], UUID_LEN_HEX);
DBGPRINT(RT_DEBUG_TRACE, ("Wsc_Uuid_E[%d]", i+1));
hex_dump("", &pWpsCtrl->Wsc_Uuid_E[0], UUID_LEN_HEX);
}
}
#endif /* WSC_AP_SUPPORT */
}
#endif /* CONFIG_AP_SUPPORT */
#ifdef CARRIER_DETECTION_SUPPORT
/*CarrierDetect*/
if(RTMPGetKeyParameter("CarrierDetect", tmpbuf, 128, pBuffer, TRUE))
{
if ((strncmp(tmpbuf, "0", 1) == 0))
pAd->CommonCfg.CarrierDetect.Enable = FALSE;
else if ((strncmp(tmpbuf, "1", 1) == 0))
pAd->CommonCfg.CarrierDetect.Enable = TRUE;
else
pAd->CommonCfg.CarrierDetect.Enable = FALSE;
DBGPRINT(RT_DEBUG_TRACE, ("CarrierDetect.Enable=%d\n", pAd->CommonCfg.CarrierDetect.Enable));
}
else
pAd->CommonCfg.CarrierDetect.Enable = FALSE;
#endif /* CARRIER_DETECTION_SUPPORT */
#ifdef CONFIG_STA_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_STA(pAd)
{
/*PSMode*/
if (RTMPGetKeyParameter("PSMode", tmpbuf, 10, pBuffer, TRUE))
{
if (pAd->StaCfg.BssType == BSS_INFRA)
{
if ((strcmp(tmpbuf, "MAX_PSP") == 0) || (strcmp(tmpbuf, "max_psp") == 0))
{
/*
do NOT turn on PSM bit here, wait until MlmeCheckForPsmChange()
to exclude certain situations
*/
/* MlmeSetPsm(pAd, PWR_SAVE);*/
OPSTATUS_SET_FLAG(pAd, fOP_STATUS_RECEIVE_DTIM);
if (pAd->StaCfg.bWindowsACCAMEnable == FALSE)
pAd->StaCfg.WindowsPowerMode = Ndis802_11PowerModeMAX_PSP;
pAd->StaCfg.WindowsBatteryPowerMode = Ndis802_11PowerModeMAX_PSP;
pAd->StaCfg.DefaultListenCount = 5;
}
else if ((strcmp(tmpbuf, "Fast_PSP") == 0) || (strcmp(tmpbuf, "fast_psp") == 0)
|| (strcmp(tmpbuf, "FAST_PSP") == 0))
{
/* do NOT turn on PSM bit here, wait until MlmeCheckForPsmChange()*/
/* to exclude certain situations.*/
OPSTATUS_SET_FLAG(pAd, fOP_STATUS_RECEIVE_DTIM);
if (pAd->StaCfg.bWindowsACCAMEnable == FALSE)
pAd->StaCfg.WindowsPowerMode = Ndis802_11PowerModeFast_PSP;
pAd->StaCfg.WindowsBatteryPowerMode = Ndis802_11PowerModeFast_PSP;
pAd->StaCfg.DefaultListenCount = 3;
}
else if ((strcmp(tmpbuf, "Legacy_PSP") == 0) || (strcmp(tmpbuf, "legacy_psp") == 0)
|| (strcmp(tmpbuf, "LEGACY_PSP") == 0))
{
/* do NOT turn on PSM bit here, wait until MlmeCheckForPsmChange()*/
/* to exclude certain situations.*/
OPSTATUS_SET_FLAG(pAd, fOP_STATUS_RECEIVE_DTIM);
if (pAd->StaCfg.bWindowsACCAMEnable == FALSE)
pAd->StaCfg.WindowsPowerMode = Ndis802_11PowerModeLegacy_PSP;
pAd->StaCfg.WindowsBatteryPowerMode = Ndis802_11PowerModeLegacy_PSP;
pAd->StaCfg.DefaultListenCount = 3;
#ifdef DOT11Z_TDLS_SUPPORT
pAd->StaCfg.DefaultListenCount = 1;
#endif /* DOT11Z_TDLS_SUPPORT */
}
else
{ /*Default Ndis802_11PowerModeCAM*/
/* clear PSM bit immediately*/
RTMP_SET_PSM_BIT(pAd, PWR_ACTIVE);
OPSTATUS_SET_FLAG(pAd, fOP_STATUS_RECEIVE_DTIM);
if (pAd->StaCfg.bWindowsACCAMEnable == FALSE)
pAd->StaCfg.WindowsPowerMode = Ndis802_11PowerModeCAM;
pAd->StaCfg.WindowsBatteryPowerMode = Ndis802_11PowerModeCAM;
}
DBGPRINT(RT_DEBUG_TRACE, ("PSMode=%ld\n", pAd->StaCfg.WindowsPowerMode));
}
}
/* AutoRoaming by RSSI*/
if (RTMPGetKeyParameter("AutoRoaming", tmpbuf, 32, pBuffer, TRUE))
{
if (simple_strtol(tmpbuf, 0, 10) == 0)
pAd->StaCfg.bAutoRoaming = FALSE;
else
pAd->StaCfg.bAutoRoaming = TRUE;
DBGPRINT(RT_DEBUG_TRACE, ("AutoRoaming=%d\n", pAd->StaCfg.bAutoRoaming));
}
/* RoamThreshold*/
if (RTMPGetKeyParameter("RoamThreshold", tmpbuf, 32, pBuffer, TRUE))
{
long lInfo = simple_strtol(tmpbuf, 0, 10);
if (lInfo > 90 || lInfo < 60)
pAd->StaCfg.dBmToRoam = -70;
else
pAd->StaCfg.dBmToRoam = (CHAR)(-1)*lInfo;
DBGPRINT(RT_DEBUG_TRACE, ("RoamThreshold=%d dBm\n", pAd->StaCfg.dBmToRoam));
}
if(RTMPGetKeyParameter("TGnWifiTest", tmpbuf, 10, pBuffer, TRUE))
{
if(simple_strtol(tmpbuf, 0, 10) == 0)
pAd->StaCfg.bTGnWifiTest = FALSE;
else
pAd->StaCfg.bTGnWifiTest = TRUE;
DBGPRINT(RT_DEBUG_TRACE, ("TGnWifiTest=%d\n", pAd->StaCfg.bTGnWifiTest));
}
/* Beacon Lost Time*/
if (RTMPGetKeyParameter("BeaconLostTime", tmpbuf, 32, pBuffer, TRUE))
{
ULONG lInfo = (ULONG)simple_strtol(tmpbuf, 0, 10);
if ((lInfo != 0) && (lInfo <= 60))
pAd->StaCfg.BeaconLostTime = (lInfo * OS_HZ);
DBGPRINT(RT_DEBUG_TRACE, ("BeaconLostTime=%ld \n", pAd->StaCfg.BeaconLostTime));
}
/* Auto Connet Setting if no SSID */
if (RTMPGetKeyParameter("AutoConnect", tmpbuf, 32, pBuffer, TRUE))
{
if (simple_strtol(tmpbuf, 0, 10) == 0)
pAd->StaCfg.bAutoConnectIfNoSSID = FALSE;
else
pAd->StaCfg.bAutoConnectIfNoSSID = TRUE;
}
#ifdef DOT11Z_TDLS_SUPPORT
if(RTMPGetKeyParameter("TDLSCapable", tmpbuf, 32, pBuffer, TRUE))
{
if(simple_strtol(tmpbuf, 0, 10) != 0) /*Enable*/
{
pAd->StaCfg.TdlsInfo.bTDLSCapable = TRUE;
}
else /*Disable*/
{
pAd->StaCfg.TdlsInfo.bTDLSCapable = FALSE;
}
DBGPRINT(RT_DEBUG_TRACE, ("bTDLSCapable=%d\n", pAd->StaCfg.TdlsInfo.bTDLSCapable));
}
#ifdef TDLS_AUTOLINK_SUPPORT
if (RTMPGetKeyParameter("TDLS_AutoLink", tmpbuf, 32, pBuffer, TRUE))
{
if (simple_strtol(tmpbuf, 0, 10) != 0) //Enable
{
pAd->StaCfg.TdlsInfo.TdlsAutoLink = TRUE;
}
else //Disable
{
pAd->StaCfg.TdlsInfo.TdlsAutoLink = FALSE;
}
DBGPRINT(RT_DEBUG_TRACE, ("TdlsAutoLink=%d\n", pAd->StaCfg.TdlsInfo.TdlsAutoLink));
}
#endif /* TDLS_AUTOLINK_SUPPORT */
if (RTMPGetKeyParameter("TDLS_SwitchChSupp", tmpbuf, 32, pBuffer, TRUE))
{
if (simple_strtol(tmpbuf, 0, 10) != 0) //Enable
{
pAd->StaCfg.TdlsInfo.TdlsChSwitchSupp = TRUE;
}
else //Disable
{
pAd->StaCfg.TdlsInfo.TdlsChSwitchSupp = FALSE;
}
DBGPRINT(RT_DEBUG_TRACE, ("TdlsSwitchChSupp=%d\n", pAd->StaCfg.TdlsInfo.TdlsChSwitchSupp));
}
if (RTMPGetKeyParameter("TDLS_PsmSupp", tmpbuf, 32, pBuffer, TRUE))
{
if (simple_strtol(tmpbuf, 0, 10) != 0) //Enable
{
pAd->StaCfg.TdlsInfo.TdlsPsmSupp = TRUE;
}
else //Disable
{
pAd->StaCfg.TdlsInfo.TdlsPsmSupp = FALSE;
}
DBGPRINT(RT_DEBUG_TRACE, ("TdlsPsmSupp=%d\n", pAd->StaCfg.TdlsInfo.TdlsPsmSupp));
}
//APSDAC for AC_BE, AC_BK, AC_VI, AC_VO
if (RTMPGetKeyParameter("TDLS_APSDAC", tmpbuf, 32, pBuffer, TRUE))
{
BOOLEAN FlgIsAcUapsdEnabled[4];
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
FlgIsAcUapsdEnabled[i] = (BOOLEAN)simple_strtol(macptr, 0, 10);
DBGPRINT(RT_DEBUG_TRACE, ("TDLS APSDAC%d %d\n", i, FlgIsAcUapsdEnabled[i]));
}
pAd->CommonCfg.TDLS_bAPSDAC_BE = FlgIsAcUapsdEnabled[0];
pAd->CommonCfg.TDLS_bAPSDAC_BK = FlgIsAcUapsdEnabled[1];
pAd->CommonCfg.TDLS_bAPSDAC_VI = FlgIsAcUapsdEnabled[2];
pAd->CommonCfg.TDLS_bAPSDAC_VO = FlgIsAcUapsdEnabled[3];
}
//MaxSPLength
if (RTMPGetKeyParameter("TDLS_MaxSPLength", tmpbuf, 10, pBuffer, TRUE))
{
pAd->CommonCfg.TDLS_MaxSPLength = simple_strtol(tmpbuf, 0, 10);
DBGPRINT(RT_DEBUG_TRACE, ("TDLS MaxSPLength=%d\n", pAd->CommonCfg.TDLS_MaxSPLength));
}
#endif /* DOT11Z_TDLS_SUPPORT */
/* FastConnect*/
if(RTMPGetKeyParameter("FastConnect", tmpbuf, 32, pBuffer, TRUE))
{
if (simple_strtol(tmpbuf, 0, 10) == 0)
pAd->StaCfg.bFastConnect = FALSE;
else
pAd->StaCfg.bFastConnect = TRUE;
DBGPRINT(RT_DEBUG_TRACE, ("FastConnect=%d\n", pAd->StaCfg.bFastConnect));
}
}
#endif /* CONFIG_STA_SUPPORT */
#ifdef CONFIG_AP_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
{
#ifdef MCAST_RATE_SPECIFIC
/* McastPhyMode*/
if (RTMPGetKeyParameter("McastPhyMode", tmpbuf, 32, pBuffer, TRUE))
{
UCHAR PhyMode = simple_strtol(tmpbuf, 0, 10);
pAd->CommonCfg.MCastPhyMode.field.BW = pAd->CommonCfg.RegTransmitSetting.field.BW;
switch (PhyMode)
{
case MCAST_DISABLE: /* disable*/
NdisMoveMemory(&pAd->CommonCfg.MCastPhyMode,
&pAd->MacTab.Content[MCAST_WCID].HTPhyMode, sizeof(HTTRANSMIT_SETTING));
break;
case MCAST_CCK: /* CCK*/
pAd->CommonCfg.MCastPhyMode.field.MODE = MODE_CCK;
pAd->CommonCfg.MCastPhyMode.field.BW = BW_20;
break;
case MCAST_OFDM: /* OFDM*/
pAd->CommonCfg.MCastPhyMode.field.MODE = MODE_OFDM;
break;
#ifdef DOT11_N_SUPPORT
case MCAST_HTMIX: /* HTMIX*/
pAd->CommonCfg.MCastPhyMode.field.MODE = MODE_HTMIX;
break;
#endif /* DOT11_N_SUPPORT */
default:
DBGPRINT(RT_DEBUG_OFF, ("unknow Muticast PhyMode %d.\n", PhyMode));
DBGPRINT(RT_DEBUG_OFF, ("0:Disable 1:CCK, 2:OFDM, 3:HTMIX.\n"));
break;
}
}
else
NdisMoveMemory(&pAd->CommonCfg.MCastPhyMode,
&pAd->MacTab.Content[MCAST_WCID].HTPhyMode, sizeof(HTTRANSMIT_SETTING));
/* McastMcs*/
if (RTMPGetKeyParameter("McastMcs", tmpbuf, 32, pBuffer, TRUE))
{
UCHAR Mcs = simple_strtol(tmpbuf, 0, 10);
switch(pAd->CommonCfg.MCastPhyMode.field.MODE)
{
case MODE_CCK:
if ((Mcs <= 3) || (Mcs >= 8 && Mcs <= 11))
pAd->CommonCfg.MCastPhyMode.field.MCS = Mcs;
else
DBGPRINT(RT_DEBUG_OFF, ("MCS must in range of 0 ~ 3 and 8 ~ 11 for CCK Mode.\n"));
break;
case MODE_OFDM:
if (Mcs > 7)
DBGPRINT(RT_DEBUG_OFF, ("MCS must in range from 0 to 7 for CCK Mode.\n"));
else
pAd->CommonCfg.MCastPhyMode.field.MCS = Mcs;
break;
default:
pAd->CommonCfg.MCastPhyMode.field.MCS = Mcs;
break;
}
}
else
pAd->CommonCfg.MCastPhyMode.field.MCS = 0;
#endif /* MCAST_RATE_SPECIFIC */
}
#endif /* CONFIG_AP_SUPPORT */
#ifdef WSC_INCLUDED
rtmp_read_wsc_user_parms_from_file(pAd, tmpbuf, pBuffer);
/* Wsc4digitPinCode = TRUE use 4-digit Pin code, otherwise 8-digit Pin code */
if (RTMPGetKeyParameter("Wsc4digitPinCode", tmpbuf, 32, pBuffer, TRUE))
{
#ifdef CONFIG_AP_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
if (i >= pAd->ApCfg.BssidNum)
break;
if (simple_strtol(macptr, 0, 10) != 0) //Enable
pAd->ApCfg.MBSSID[i].WscControl.WscEnrollee4digitPinCode = TRUE;
else //Disable
pAd->ApCfg.MBSSID[i].WscControl.WscEnrollee4digitPinCode = FALSE;
DBGPRINT(RT_DEBUG_TRACE, ("I/F(ra%d) Wsc4digitPinCode=%d\n", i, pAd->ApCfg.MBSSID[i].WscControl.WscEnrollee4digitPinCode));
}
}
#endif // CONFIG_AP_SUPPORT //
#ifdef CONFIG_STA_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_STA(pAd)
{
if (simple_strtol(tmpbuf, 0, 10) != 0) //Enable
pAd->StaCfg.WscControl.WscEnrollee4digitPinCode = TRUE;
else //Disable
pAd->StaCfg.WscControl.WscEnrollee4digitPinCode = FALSE;
DBGPRINT(RT_DEBUG_TRACE, ("Wsc4digitPinCode=%d\n", pAd->StaCfg.WscControl.WscEnrollee4digitPinCode));
}
#endif // CONFIG_STA_SUPPORT //
}
if (RTMPGetKeyParameter("WscVendorPinCode", tmpbuf, 256, pBuffer, TRUE))
{
PWSC_CTRL pWscContrl;
int bSetOk;
#ifdef CONFIG_AP_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
{
pWscContrl = &pAd->ApCfg.MBSSID[BSS0].WscControl;
}
#endif /* CONFIG_AP_SUPPORT */
#ifdef CONFIG_STA_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_STA(pAd)
{
pWscContrl = &pAd->StaCfg.WscControl;
}
#endif /* CONFIG_STA_SUPPORT */
bSetOk = RT_CfgSetWscPinCode(pAd, tmpbuf, pWscContrl);
if (bSetOk)
DBGPRINT(RT_DEBUG_TRACE, ("%s - WscVendorPinCode= (%d)\n", __FUNCTION__, bSetOk));
else
DBGPRINT(RT_DEBUG_ERROR, ("%s - WscVendorPinCode: invalid pin code(%s)\n", __FUNCTION__, tmpbuf));
}
#ifdef WSC_V2_SUPPORT
if (RTMPGetKeyParameter("WscV2Support", tmpbuf, 32, pBuffer, TRUE))
{
UCHAR bEnable;
#ifdef CONFIG_AP_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_AP(pAd)
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); macptr; macptr = rstrtok(NULL,";"), i++)
{
if (i >= pAd->ApCfg.BssidNum)
break;
bEnable = (UCHAR)simple_strtol(macptr, 0, 10);
pAd->ApCfg.MBSSID[i].WscControl.WscV2Info.bEnableWpsV2 = bEnable;
DBGPRINT(RT_DEBUG_TRACE, ("I/F(ra%d) WscV2Support=%d\n", i, bEnable));
}
}
#endif /* CONFIG_AP_SUPPORT */
#ifdef CONFIG_STA_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_STA(pAd)
{
bEnable = (UCHAR)simple_strtol(tmpbuf, 0, 10);
pAd->StaCfg.WscControl.WscV2Info.bEnableWpsV2 = bEnable;
DBGPRINT(RT_DEBUG_TRACE, ("%s - WscV2Support= (%d)\n", __FUNCTION__, bEnable));
}
#endif /* CONFIG_STA_SUPPORT */
}
#endif /* WSC_V2_SUPPORT */
#endif /* WSC_INCLUDED */
#ifdef CONFIG_AP_SUPPORT
#endif /* CONFIG_AP_SUPPORT */
#ifdef CONFIG_AP_SUPPORT
/* EntryLifeCheck is used to check */
if (RTMPGetKeyParameter("EntryLifeCheck", tmpbuf, 256, pBuffer, TRUE))
{
long LifeCheckCnt = simple_strtol(tmpbuf, 0, 10);
if ((LifeCheckCnt <= 65535) && (LifeCheckCnt != 0))
pAd->ApCfg.EntryLifeCheck = LifeCheckCnt;
else
pAd->ApCfg.EntryLifeCheck = MAC_ENTRY_LIFE_CHECK_CNT;
DBGPRINT(RT_DEBUG_ERROR, ("EntryLifeCheck=%ld\n", pAd->ApCfg.EntryLifeCheck));
}
#endif /* CONFIG_AP_SUPPORT */
#ifdef SINGLE_SKU
if(RTMPGetKeyParameter("AntGain", tmpbuf, 10, pBuffer, TRUE))
{
UCHAR AntGain = simple_strtol(tmpbuf, 0, 10);
pAd->CommonCfg.AntGain= AntGain;
DBGPRINT(RT_DEBUG_TRACE, ("AntGain=%d\n", pAd->CommonCfg.AntGain));
}
if(RTMPGetKeyParameter("BandedgeDelta", tmpbuf, 10, pBuffer, TRUE))
{
UCHAR Bandedge = simple_strtol(tmpbuf, 0, 10);
pAd->CommonCfg.BandedgeDelta = Bandedge;
DBGPRINT(RT_DEBUG_TRACE, ("BandedgeDelta=%d\n", pAd->CommonCfg.BandedgeDelta));
}
#endif /* SINGLE_SKU */
#ifdef P2P_SUPPORT
IF_DEV_CONFIG_OPMODE_ON_STA(pAd)
{
if(RTMPGetKeyParameter("P2P_GOIntent", tmpbuf, 10, pBuffer, TRUE))
{
pAd->P2pCfg.GoIntentIdx = simple_strtol(tmpbuf, 0, 10);
DBGPRINT(RT_DEBUG_ERROR, ("P2P_GOIntent=%d\n", pAd->P2pCfg.GoIntentIdx));
}
if(RTMPGetKeyParameter("P2P_DevName", tmpbuf, 32, pBuffer, TRUE))
{
if ((strlen(tmpbuf) <= 32)
)
{
pAd->P2pCfg.DeviceNameLen = (UCHAR) strlen(tmpbuf);
NdisZeroMemory(pAd->P2pCfg.DeviceName, 32);
NdisMoveMemory(pAd->P2pCfg.DeviceName, tmpbuf, pAd->P2pCfg.DeviceNameLen);
DBGPRINT(RT_DEBUG_TRACE, ("%s():P2P_DevName=%s\n", __FUNCTION__, tmpbuf));
}
}
if(RTMPGetKeyParameter("P2P_ListChannel", tmpbuf, 10, pBuffer, TRUE))
{
pAd->P2pCfg.ListenChannel = simple_strtol(tmpbuf, 0, 10);
DBGPRINT(RT_DEBUG_ERROR, ("P2P_ListChannel=%d\n", pAd->P2pCfg.ListenChannel));
}
if(RTMPGetKeyParameter("P2P_OpChannel", tmpbuf, 10, pBuffer, TRUE))
{
pAd->P2pCfg.GroupChannel = simple_strtol(tmpbuf, 0, 10);
DBGPRINT(RT_DEBUG_ERROR, ("P2P_OpChannel=%d\n", pAd->P2pCfg.GroupChannel));
}
if(RTMPGetKeyParameter("P2P_WscCfgMethod", tmpbuf, 10, pBuffer, TRUE))
{
UCHAR CfgMethod = simple_strtol(tmpbuf, 0, 10);
if (pAd->P2pCfg.WscMode == WSC_PIN_MODE)
{
if (CfgMethod == P2P_REG_CM_DISPLAY)
pAd->P2pCfg.DefaultConfigMethod = P2P_REG_CM_DISPLAY;
else if (CfgMethod == P2P_REG_CM_KEYPAD)
pAd->P2pCfg.DefaultConfigMethod = P2P_REG_CM_KEYPAD;
}
else if (pAd->P2pCfg.WscMode == WSC_PBC_MODE)
{
pAd->P2pCfg.DefaultConfigMethod = P2P_REG_CM_PBC;
}
DBGPRINT(RT_DEBUG_ERROR, ("P2P_WscCfgMethod=%d\n", pAd->P2pCfg.DefaultConfigMethod));
}
if(RTMPGetKeyParameter("P2P_ExtListenEnable", tmpbuf, 10, pBuffer, TRUE))
{
UINT32 ExtList = simple_strtol(tmpbuf, 0, 10);
if (ExtList == 0)
pAd->P2pCfg.bExtListen = FALSE;
else if (ExtList == 1)
pAd->P2pCfg.bExtListen = TRUE;
DBGPRINT(RT_DEBUG_ERROR, ("P2P_ExtListen=%d\n", pAd->P2pCfg.bExtListen));
}
if(RTMPGetKeyParameter("P2P_ExtListenPrd", tmpbuf, 10, pBuffer, TRUE))
{
pAd->P2pCfg.ExtListenPeriod = simple_strtol(tmpbuf, 0, 10);
DBGPRINT(RT_DEBUG_ERROR, ("P2P_ExtListenPrd=%d\n", pAd->P2pCfg.ExtListenPeriod));
}
if(RTMPGetKeyParameter("P2P_ExtenListenInv", tmpbuf, 10, pBuffer, TRUE))
{
pAd->P2pCfg.ExtListenInterval = simple_strtol(tmpbuf, 0, 10);
DBGPRINT(RT_DEBUG_ERROR, ("P2P_ExtenListenInv=%d\n", pAd->P2pCfg.ExtListenInterval));
}
if(RTMPGetKeyParameter("P2P_IntraBss", tmpbuf, 10, pBuffer, TRUE))
{
UINT32 IntraBss = simple_strtol(tmpbuf, 0, 10);
if (IntraBss == 0)
pAd->P2pCfg.bIntraBss = FALSE;
else if (IntraBss == 1)
pAd->P2pCfg.bIntraBss = TRUE;
DBGPRINT(RT_DEBUG_ERROR, ("P2P_IntraBss=%d\n", pAd->P2pCfg.bIntraBss));
}
if(RTMPGetKeyParameter("P2P_NoACnt", tmpbuf, 10, pBuffer, TRUE))
{
pAd->P2pCfg.GONoASchedule.Count = simple_strtol(tmpbuf, 0, 10);
DBGPRINT(RT_DEBUG_ERROR, ("P2P_NoACnt=%d\n", pAd->P2pCfg.GONoASchedule.Count));
}
if(RTMPGetKeyParameter("P2P_NoADuration", tmpbuf, 10, pBuffer, TRUE))
{
pAd->P2pCfg.GONoASchedule.Duration = simple_strtol(tmpbuf, 0, 10);
DBGPRINT(RT_DEBUG_ERROR, ("P2P_NoADuration=%ld\n", pAd->P2pCfg.GONoASchedule.Duration));
}
if(RTMPGetKeyParameter("P2P_NoAInv", tmpbuf, 10, pBuffer, TRUE))
{
pAd->P2pCfg.GONoASchedule.Interval = simple_strtol(tmpbuf, 0, 10);
DBGPRINT(RT_DEBUG_ERROR, ("P2P_NoAInv=%d\n", pAd->P2pCfg.GONoASchedule.Interval));
}
if(RTMPGetKeyParameter("P2P_MaxEntry", tmpbuf, 10, pBuffer, TRUE))
{
pAd->P2pCfg.p2pMaxEntry= simple_strtol(tmpbuf, 0, 10);
DBGPRINT(RT_DEBUG_ERROR, ("P2P_MaxEntry=%d\n", pAd->P2pCfg.p2pMaxEntry));
}
}
#endif /* P2P_SUPPORT */
#if (defined(WOW_SUPPORT) && defined(RTMP_MAC_USB)) || defined(NEW_WOW_SUPPORT)
/* set GPIO pin for wake-up signal */
if (RTMPGetKeyParameter("WOW_GPIO", tmpbuf, 10, pBuffer, TRUE))
Set_WOW_GPIO(pAd, tmpbuf);
/* set WOW enable/disable */
if (RTMPGetKeyParameter("WOW_Enable", tmpbuf, 10, pBuffer, TRUE))
Set_WOW_Enable(pAd, tmpbuf);
/* set delay time for WOW really enable */
if (RTMPGetKeyParameter("WOW_Delay", tmpbuf, 10, pBuffer, TRUE))
Set_WOW_Delay(pAd, tmpbuf);
/* set GPIO pulse hold time */
if (RTMPGetKeyParameter("WOW_Hold", tmpbuf, 10, pBuffer, TRUE))
Set_WOW_Hold(pAd, tmpbuf);
/* set wakeup signal type */
if (RTMPGetKeyParameter("WOW_InBand", tmpbuf, 10, pBuffer, TRUE))
Set_WOW_InBand(pAd, tmpbuf);
#endif /* (defined(WOW_SUPPORT) && defined(RTMP_MAC_USB)) || defined(NEW_WOW_SUPPORT) */
#ifdef MICROWAVE_OVEN_SUPPORT
if (RTMPGetKeyParameter("MO_FalseCCATh", tmpbuf, 10, pBuffer, TRUE))
{
Set_MO_FalseCCATh_Proc(pAd, tmpbuf);
}
#endif /* MICROWAVE_OVEN_SUPPORT */
}while(0);
#ifdef CUSTOMER_DEMO
demo_mode_cfg(pAd);
#endif /* CUSTOMER_DEMO */
os_free_mem(NULL, tmpbuf);
return NDIS_STATUS_SUCCESS;
}
#ifdef MULTIPLE_CARD_SUPPORT
/* record whether the card in the card list is used in the card file*/
UINT8 MC_CardUsed[MAX_NUM_OF_MULTIPLE_CARD];
/* record used card mac address in the card list*/
static UINT8 MC_CardMac[MAX_NUM_OF_MULTIPLE_CARD][6];
/*
========================================================================
Routine Description:
Get card profile path.
Arguments:
pAd
Return Value:
TRUE - Find a card profile
FALSE - use default profile
Note:
========================================================================
*/
BOOLEAN RTMP_CardInfoRead(
IN PRTMP_ADAPTER pAd)
{
#define MC_SELECT_CARDID 0 /* use CARD ID (0 ~ 31) to identify different cards */
#define MC_SELECT_MAC 1 /* use CARD MAC to identify different cards */
#define MC_SELECT_CARDTYPE 2 /* use CARD type (abgn or bgn) to identify different cards */
#define LETTER_CASE_TRANSLATE(txt_p, card_id) \
{ UINT32 _len; char _char; \
for(_len=0; _len<strlen(card_id); _len++) { \
_char = *(txt_p + _len); \
if (('A' <= _char) && (_char <= 'Z')) \
*(txt_p+_len) = 'a'+(_char-'A'); \
} }
RTMP_OS_FD srcf;
INT retval;
PSTRING buffer, tmpbuf;
STRING card_id_buf[30], RFIC_word[30];
BOOLEAN flg_match_ok = FALSE;
INT32 card_select_method;
INT32 card_free_id, card_nouse_id, card_same_mac_id, card_match_id;
EEPROM_ANTENNA_STRUC antenna;
USHORT addr01, addr23, addr45;
UINT8 mac[6];
UINT32 data, card_index;
UCHAR *start_ptr;
RTMP_OS_FS_INFO osFSInfo;
/* init*/
os_alloc_mem(NULL, (UCHAR **)&buffer, MAX_INI_BUFFER_SIZE);
if (buffer == NULL)
return FALSE;
os_alloc_mem(NULL, (UCHAR **)&tmpbuf, MAX_PARAM_BUFFER_SIZE);
if(tmpbuf == NULL)
{
os_free_mem(NULL, buffer);
return NDIS_STATUS_FAILURE;
}
/* get RF IC type*/
RTMP_IO_READ32(pAd, E2PROM_CSR, &data);
RT28xx_EEPROM_READ16(pAd, EEPROM_NIC1_OFFSET, antenna.word);
if ((antenna.field.RfIcType == RFIC_2850) ||
(antenna.field.RfIcType == RFIC_2750) ||
(antenna.field.RfIcType == RFIC_2853) ||
(antenna.field.RfIcType == RFIC_3853) ||
(antenna.field.RfIcType == RFIC_5592))
{
/* ABGN card */
strcpy(RFIC_word, "abgn");
}
else
{
/* BGN card */
strcpy(RFIC_word, "bgn");
}
/* get MAC address*/
RT28xx_EEPROM_READ16(pAd, 0x04, addr01);
RT28xx_EEPROM_READ16(pAd, 0x06, addr23);
RT28xx_EEPROM_READ16(pAd, 0x08, addr45);
mac[0] = (UCHAR)(addr01 & 0xff);
mac[1] = (UCHAR)(addr01 >> 8);
mac[2] = (UCHAR)(addr23 & 0xff);
mac[3] = (UCHAR)(addr23 >> 8);
mac[4] = (UCHAR)(addr45 & 0xff);
mac[5] = (UCHAR)(addr45 >> 8);
DBGPRINT(RT_DEBUG_TRACE, ("mac addr=%02x:%02x:%02x:%02x:%02x:%02x!\n", PRINT_MAC(mac)));
RtmpOSFSInfoChange(&osFSInfo, TRUE);
/* open card information file*/
srcf = RtmpOSFileOpen(CARD_INFO_PATH, O_RDONLY, 0);
if (IS_FILE_OPEN_ERR(srcf))
{
/* card information file does not exist */
DBGPRINT(RT_DEBUG_TRACE,
("--> Error opening %s\n", CARD_INFO_PATH));
goto free_resource;
}
/* card information file exists so reading the card information */
memset(buffer, 0x00, MAX_INI_BUFFER_SIZE);
retval = RtmpOSFileRead(srcf, buffer, MAX_INI_BUFFER_SIZE);
if (retval < 0)
{
/* read fail */
DBGPRINT(RT_DEBUG_TRACE,
("--> Read %s error %d\n", CARD_INFO_PATH, -retval));
}
else
{
/* get card selection method */
memset(tmpbuf, 0x00, MAX_PARAM_BUFFER_SIZE);
card_select_method = MC_SELECT_CARDTYPE; /* default*/
if (RTMPGetKeyParameter("SELECT", tmpbuf, 256, buffer, TRUE))
{
if (strcmp(tmpbuf, "CARDID") == 0)
card_select_method = MC_SELECT_CARDID;
else if (strcmp(tmpbuf, "MAC") == 0)
card_select_method = MC_SELECT_MAC;
else if (strcmp(tmpbuf, "CARDTYPE") == 0)
card_select_method = MC_SELECT_CARDTYPE;
}
DBGPRINT(RT_DEBUG_TRACE,
("MC> Card Selection = %d\n", card_select_method));
/* init*/
card_free_id = -1;
card_nouse_id = -1;
card_same_mac_id = -1;
card_match_id = -1;
/* search current card information records*/
for(card_index=0;
card_index<MAX_NUM_OF_MULTIPLE_CARD;
card_index++)
{
if ((*(UINT32 *)&MC_CardMac[card_index][0] == 0) &&
(*(UINT16 *)&MC_CardMac[card_index][4] == 0))
{
/* MAC is all-0 so the entry is available*/
MC_CardUsed[card_index] = 0;
if (card_free_id < 0)
card_free_id = card_index; /* 1st free entry*/
}
else
{
if (memcmp(MC_CardMac[card_index], mac, 6) == 0)
{
/* we find the entry with same MAC*/
if (card_same_mac_id < 0)
card_same_mac_id = card_index; /* 1st same entry*/
}
else
{
/* MAC is not all-0 but used flag == 0*/
if ((MC_CardUsed[card_index] == 0) &&
(card_nouse_id < 0))
{
card_nouse_id = card_index; /* 1st available entry*/
}
}
}
}
DBGPRINT(RT_DEBUG_TRACE,
("MC> Free = %d, Same = %d, NOUSE = %d\n",
card_free_id, card_same_mac_id, card_nouse_id));
if ((card_same_mac_id >= 0) &&
((card_select_method == MC_SELECT_CARDID) ||
(card_select_method == MC_SELECT_CARDTYPE)))
{
/* same MAC entry is found*/
card_match_id = card_same_mac_id;
if (card_select_method == MC_SELECT_CARDTYPE)
{
/* for CARDTYPE*/
snprintf(card_id_buf, sizeof(card_id_buf), "%02dCARDTYPE%s",
card_match_id, RFIC_word);
if ((start_ptr = (PUCHAR)rtstrstruncasecmp(buffer, card_id_buf)) != NULL)
{
/* we found the card ID*/
LETTER_CASE_TRANSLATE(start_ptr, card_id_buf);
}
}
}
else
{
/* the card is 1st plug-in, try to find the match card profile*/
switch(card_select_method)
{
case MC_SELECT_CARDID: /* CARDID*/
default:
if (card_free_id >= 0)
card_match_id = card_free_id;
else
card_match_id = card_nouse_id;
break;
case MC_SELECT_MAC: /* MAC*/
snprintf(card_id_buf, sizeof(card_id_buf), "MAC%02x:%02x:%02x:%02x:%02x:%02x",
mac[0], mac[1], mac[2],
mac[3], mac[4], mac[5]);
/* try to find the key word in the card file */
if ((start_ptr = (PUCHAR)rtstrstruncasecmp(buffer, card_id_buf)) != NULL)
{
LETTER_CASE_TRANSLATE(start_ptr, card_id_buf);
/* get the row ID (2 ASCII characters) */
start_ptr -= 2;
card_id_buf[0] = *(start_ptr);
card_id_buf[1] = *(start_ptr+1);
card_id_buf[2] = 0x00;
card_match_id = simple_strtol(card_id_buf, 0, 10);
}
break;
case MC_SELECT_CARDTYPE: /* CARDTYPE*/
card_nouse_id = -1;
for(card_index=0;
card_index<MAX_NUM_OF_MULTIPLE_CARD;
card_index++)
{
snprintf(card_id_buf, sizeof(card_id_buf), "%02dCARDTYPE%s",
card_index, RFIC_word);
if ((start_ptr = (PUCHAR)rtstrstruncasecmp(buffer,
card_id_buf)) != NULL)
{
LETTER_CASE_TRANSLATE(start_ptr, card_id_buf);
if (MC_CardUsed[card_index] == 0)
{
/* current the card profile is not used */
if ((*(UINT32 *)&MC_CardMac[card_index][0] == 0) &&
(*(UINT16 *)&MC_CardMac[card_index][4] == 0))
{
/* find it and no previous card use it*/
card_match_id = card_index;
break;
}
else
{
/* ever a card use it*/
if (card_nouse_id < 0)
card_nouse_id = card_index;
}
}
}
}
/* if not find a free one, use the available one*/
if (card_match_id < 0)
card_match_id = card_nouse_id;
break;
}
}
if (card_match_id >= 0)
{
/* make up search keyword*/
switch(card_select_method)
{
case MC_SELECT_CARDID: /* CARDID*/
snprintf(card_id_buf, sizeof(card_id_buf), "%02dCARDID", card_match_id);
break;
case MC_SELECT_MAC: /* MAC*/
snprintf(card_id_buf, sizeof(card_id_buf),
"%02dmac%02x:%02x:%02x:%02x:%02x:%02x",
card_match_id,
mac[0], mac[1], mac[2],
mac[3], mac[4], mac[5]);
break;
case MC_SELECT_CARDTYPE: /* CARDTYPE*/
default:
snprintf(card_id_buf, sizeof(card_id_buf), "%02dcardtype%s",
card_match_id, RFIC_word);
break;
}
DBGPRINT(RT_DEBUG_TRACE, ("Search Keyword = %s\n", card_id_buf));
/* read card file path*/
if (RTMPGetKeyParameter(card_id_buf, tmpbuf, 256, buffer, TRUE))
{
if (strlen(tmpbuf) < sizeof(pAd->MC_FileName))
{
/* backup card information*/
pAd->MC_RowID = card_match_id; /* base 0 */
MC_CardUsed[card_match_id] = 1;
memcpy(MC_CardMac[card_match_id], mac, sizeof(mac));
/* backup card file path*/
NdisMoveMemory(pAd->MC_FileName, tmpbuf , strlen(tmpbuf));
pAd->MC_FileName[strlen(tmpbuf)] = '\0';
flg_match_ok = TRUE;
DBGPRINT(RT_DEBUG_TRACE,
("Card Profile Name = %s\n", pAd->MC_FileName));
}
else
{
DBGPRINT(RT_DEBUG_ERROR,
("Card Profile Name length too large!\n"));
}
}
else
{
DBGPRINT(RT_DEBUG_ERROR,
("Can not find search key word in card.dat!\n"));
}
if ((flg_match_ok != TRUE) &&
(card_match_id < MAX_NUM_OF_MULTIPLE_CARD))
{
MC_CardUsed[card_match_id] = 0;
memset(MC_CardMac[card_match_id], 0, sizeof(mac));
}
} /* if (card_match_id >= 0)*/
}
/* close file*/
retval = RtmpOSFileClose(srcf);
free_resource:
RtmpOSFSInfoChange(&osFSInfo, FALSE);
/* kfree(buffer);*/
/* kfree(tmpbuf);*/
os_free_mem(NULL, buffer);
os_free_mem(NULL, tmpbuf);
return flg_match_ok;
}
#endif /* MULTIPLE_CARD_SUPPORT */
#ifdef WSC_INCLUDED
void rtmp_read_wsc_user_parms(
PWSC_CTRL pWscControl,
STRING *tmpbuf,
STRING *buffer)
{
if(RTMPGetKeyParameter("WscManufacturer", tmpbuf, WSC_MANUFACTURE_LEN, buffer,TRUE))
{
NdisZeroMemory(pWscControl->RegData.SelfInfo.Manufacturer, WSC_MANUFACTURE_LEN);
NdisMoveMemory(pWscControl->RegData.SelfInfo.Manufacturer, tmpbuf, strlen(tmpbuf));
if(pWscControl->RegData.SelfInfo.Manufacturer[0] != 0x00)
RTMP_SET_FLAG(pWscControl, 0x01);
}
/*WSC_User_ModelName*/
if(RTMPGetKeyParameter("WscModelName", tmpbuf, WSC_MODELNAME_LEN, buffer,TRUE))
{
NdisZeroMemory(pWscControl->RegData.SelfInfo.ModelName, WSC_MODELNAME_LEN);
NdisMoveMemory(pWscControl->RegData.SelfInfo.ModelName, tmpbuf, strlen(tmpbuf));
if(pWscControl->RegData.SelfInfo.ModelName[0] != 0x00)
RTMP_SET_FLAG(pWscControl, 0x02);
}
/*WSC_User_DeviceName*/
if(RTMPGetKeyParameter("WscDeviceName", tmpbuf, WSC_DEVICENAME_LEN, buffer,TRUE))
{
NdisZeroMemory(pWscControl->RegData.SelfInfo.DeviceName, WSC_DEVICENAME_LEN);
NdisMoveMemory(pWscControl->RegData.SelfInfo.DeviceName, tmpbuf, strlen(tmpbuf));
if(pWscControl->RegData.SelfInfo.DeviceName[0] != 0x00)
RTMP_SET_FLAG(pWscControl, 0x04);
}
/*WSC_User_ModelNumber*/
if(RTMPGetKeyParameter("WscModelNumber", tmpbuf, WSC_MODELNUNBER_LEN, buffer,TRUE))
{
NdisZeroMemory(pWscControl->RegData.SelfInfo.ModelNumber, WSC_MODELNUNBER_LEN);
NdisMoveMemory(pWscControl->RegData.SelfInfo.ModelNumber, tmpbuf, strlen(tmpbuf));
if(pWscControl->RegData.SelfInfo.ModelNumber[0] != 0x00)
RTMP_SET_FLAG(pWscControl, 0x08);
}
/*WSC_User_SerialNumber*/
if(RTMPGetKeyParameter("WscSerialNumber", tmpbuf, WSC_SERIALNUNBER_LEN, buffer,TRUE))
{
NdisZeroMemory(pWscControl->RegData.SelfInfo.SerialNumber, WSC_SERIALNUNBER_LEN);
NdisMoveMemory(pWscControl->RegData.SelfInfo.SerialNumber, tmpbuf, strlen(tmpbuf));
if(pWscControl->RegData.SelfInfo.SerialNumber[0] != 0x00)
RTMP_SET_FLAG(pWscControl, 0x10);
}
}
void rtmp_read_wsc_user_parms_from_file(IN PRTMP_ADAPTER pAd, char *tmpbuf, char *buffer)
{
PWSC_CTRL pWscControl;
#ifdef WSC_AP_SUPPORT
int i=0;
for(i = 0; i < MAX_MBSSID_NUM(pAd); i++)
{
pWscControl = &pAd->ApCfg.MBSSID[i].WscControl;
rtmp_read_wsc_user_parms(pWscControl, tmpbuf, buffer);
}
#ifdef APCLI_SUPPORT
pWscControl = &pAd->ApCfg.ApCliTab[0].WscControl;
rtmp_read_wsc_user_parms(pWscControl, tmpbuf, buffer);
#endif /* APCLI_SUPPORT */
#endif /* WSC_AP_SUPPORT */
#ifdef WSC_STA_SUPPORT
pWscControl = &pAd->StaCfg.WscControl;
rtmp_read_wsc_user_parms(pWscControl, tmpbuf, buffer);
#endif /* WSC_STA_SUPPORT */
}
#endif/*WSC_INCLUDED*/
VOID rtmp_read_multest_from_file(
IN PRTMP_ADAPTER pAd,
IN PSTRING tmpbuf,
IN PSTRING buffer)
{
PSTRING macptr;
INT i=0, j;
STRING tok_str[16];
BOOLEAN bUsePrevFormat = FALSE;
UCHAR macAddress[MAC_ADDR_LEN];
UCHAR keyMaterial[40];
UCHAR KeyLen, CipherAlg = CIPHER_NONE, KeyIdx;
PRT_802_11_WDS_ENTRY pWdsEntry;
/*WdsPhyMode */
if (RTMPGetKeyParameter("WdsPhyMode", tmpbuf, MAX_PARAM_BUFFER_SIZE, buffer, TRUE))
{
for (i=0, macptr = rstrtok(tmpbuf,";"); (macptr && i < MAX_WDS_ENTRY); macptr = rstrtok(NULL,";"), i++)
{
if ((strncmp(macptr, "CCK", 3) == 0) || (strncmp(macptr, "cck", 3) == 0))
pAd->MulTestTab.WdsEntry[i].PhyMode = MODE_CCK;
else if ((strncmp(macptr, "OFDM", 4) == 0) || (strncmp(macptr, "ofdm", 4) == 0))
pAd->MulTestTab.WdsEntry[i].PhyMode = MODE_OFDM;
#ifdef DOT11_N_SUPPORT
else if ((strncmp(macptr, "HTMIX", 5) == 0) || (strncmp(macptr, "htmix", 5) == 0))
pAd->MulTestTab.WdsEntry[i].PhyMode = MODE_HTMIX;
else if ((strncmp(macptr, "GREENFIELD", 10) == 0) || (strncmp(macptr, "greenfield", 10) == 0))
pAd->MulTestTab.WdsEntry[i].PhyMode = MODE_HTGREENFIELD;
#endif /* DOT11_N_SUPPORT */
else
pAd->MulTestTab.WdsEntry[i].PhyMode = 0xff;
DBGPRINT(RT_DEBUG_TRACE, ("If/wds%d - WdsPhyMode=%d\n", i, pAd->MulTestTab.WdsEntry[i].PhyMode));
}
}
/*WdsList */
if (RTMPGetKeyParameter("WdsList", tmpbuf, MAX_PARAM_BUFFER_SIZE, buffer, TRUE))
{
for (i=0, macptr = rstrtok(tmpbuf,";"); (macptr && i < MAX_WDS_ENTRY); macptr = rstrtok(NULL,";"), i++)
{
if(strlen(macptr) != 17) /*Mac address acceptable format 01:02:03:04:05:06 length 17 */
continue;
if(strcmp(macptr,"00:00:00:00:00:00") == 0)
continue;
if(i >= MAX_WDS_ENTRY)
break;
for (j=0; j<ETH_LENGTH_OF_ADDRESS; j++)
{
AtoH(macptr, &macAddress[j], 1);
macptr=macptr+3;
}
{
INT iii;
LONG WdsTabIdx = -1;
for (iii = 0; iii < MAX_WDS_ENTRY; iii++)
{
if (pAd->MulTestTab.WdsEntry[iii].Valid == FALSE)
{
pAd->MulTestTab.WdsEntry[iii].Valid = TRUE;
pAd->MulTestTab.Size ++;
COPY_MAC_ADDR(pAd->MulTestTab.WdsEntry[iii].PeerWdsAddr, macAddress);
WdsTabIdx = iii;
break;
}
else if (MAC_ADDR_EQUAL(pAd->MulTestTab.WdsEntry[iii].PeerWdsAddr, macAddress))
{
WdsTabIdx = iii;
break;
}
}
if (iii == MAX_WDS_ENTRY)
DBGPRINT(RT_DEBUG_ERROR, ("%s: Unable to allocate MulTestEntry.\n", __FUNCTION__));
}
}
}
/*WdsEncrypType */
if (RTMPGetKeyParameter("WdsEncrypType", tmpbuf, 128, buffer, TRUE))
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); (macptr && i < MAX_WDS_ENTRY); macptr = rstrtok(NULL,";"), i++)
{
if ((strncmp(macptr, "NONE", 4) == 0) || (strncmp(macptr, "none", 4) == 0))
pAd->MulTestTab.WdsEntry[i].WepStatus = Ndis802_11WEPDisabled;
else if ((strncmp(macptr, "WEP", 3) == 0) || (strncmp(macptr, "wep", 3) == 0))
pAd->MulTestTab.WdsEntry[i].WepStatus = Ndis802_11WEPEnabled;
else if ((strncmp(macptr, "TKIP", 4) == 0) || (strncmp(macptr, "tkip", 4) == 0))
pAd->MulTestTab.WdsEntry[i].WepStatus = Ndis802_11Encryption2Enabled;
else if ((strncmp(macptr, "AES", 3) == 0) || (strncmp(macptr, "aes", 3) == 0))
pAd->MulTestTab.WdsEntry[i].WepStatus = Ndis802_11Encryption3Enabled;
#ifdef WAPI_SUPPORT
else if ((strncmp(macptr, "SMS4", 4) == 0) || (strncmp(macptr, "sms4", 4) == 0))
pAd->MulTestTab.WdsEntry[i].WepStatus = Ndis802_11EncryptionSMS4Enabled;
#endif /* WAPI_SUPPORT */
else
pAd->MulTestTab.WdsEntry[i].WepStatus = Ndis802_11WEPDisabled;
DBGPRINT(RT_DEBUG_TRACE, ("WdsEncrypType[%d]=%d(%s)\n", i, pAd->MulTestTab.WdsEntry[i].WepStatus, GetEncryptType(pAd->MulTestTab.WdsEntry[i].WepStatus)));
}
/* Previous WDS only supports single encryption type. */
/* For backward compatible, other wds link encryption type shall be the same with the first. */
if (i == 1)
{
for (j = 1; j < MAX_WDS_ENTRY; j++)
{
pAd->MulTestTab.WdsEntry[j].WepStatus = pAd->MulTestTab.WdsEntry[0].WepStatus;
DBGPRINT(RT_DEBUG_TRACE, ("@WdsEncrypType[%d]=%d(%s)\n", j, pAd->MulTestTab.WdsEntry[i].WepStatus, GetEncryptType(pAd->MulTestTab.WdsEntry[i].WepStatus)));
}
}
}
/* WdsKey */
/* This is a previous parameter and it only stores WPA key material, not WEP key */
if (RTMPGetKeyParameter("WdsKey", tmpbuf, 255, buffer, FALSE))
{
for (i = 0; i < MAX_WDS_ENTRY; i++)
NdisZeroMemory(&pAd->MulTestTab.WdsEntry[i].WdsKey, sizeof(CIPHER_KEY));
if (strlen(tmpbuf) > 0)
bUsePrevFormat = TRUE;
/* check if the wds-0 link key material is valid */
if (((pAd->MulTestTab.WdsEntry[0].WepStatus == Ndis802_11Encryption2Enabled)
|| (pAd->MulTestTab.WdsEntry[0].WepStatus == Ndis802_11Encryption3Enabled))
&& (strlen(tmpbuf) >= 8) && (strlen(tmpbuf) <= 64))
{
RT_CfgSetWPAPSKKey(pAd, tmpbuf, strlen(tmpbuf), (PUCHAR)RALINK_PASSPHRASE, sizeof(RALINK_PASSPHRASE), keyMaterial);
if (pAd->MulTestTab.WdsEntry[0].WepStatus == Ndis802_11Encryption3Enabled)
pAd->MulTestTab.WdsEntry[0].WdsKey.CipherAlg = CIPHER_AES;
else
pAd->MulTestTab.WdsEntry[0].WdsKey.CipherAlg = CIPHER_TKIP;
NdisMoveMemory(&pAd->MulTestTab.WdsEntry[0].WdsKey.Key, keyMaterial, 16);
pAd->MulTestTab.WdsEntry[0].WdsKey.KeyLen = 16;
NdisMoveMemory(&pAd->MulTestTab.WdsEntry[0].WdsKey.RxMic, keyMaterial+16, 8);
NdisMoveMemory(&pAd->MulTestTab.WdsEntry[0].WdsKey.TxMic, keyMaterial+16, 8);
}
/* Previous WDS only supports single key-material. */
/* For backward compatible, other wds link key-material shall be the same with the first. */
if (pAd->MulTestTab.WdsEntry[0].WdsKey.KeyLen == 16)
{
for (j = 1; j < MAX_WDS_ENTRY; j++)
{
NdisMoveMemory(&pAd->MulTestTab.WdsEntry[j].WdsKey, &pAd->MulTestTab.WdsEntry[0].WdsKey, sizeof(CIPHER_KEY));
}
}
}
/* The parameters can provide different key information for each WDS-Link */
/* no matter WEP or WPA */
if (!bUsePrevFormat)
{
for (i = 0; i < MAX_WDS_ENTRY; i++)
{
AP_WDS_KeyNameMakeUp(tok_str, sizeof(tok_str), i);
/* WdsXKey (X=0~MAX_WDS_ENTRY-1) */
if (RTMPGetKeyParameter(tok_str, tmpbuf, 128, buffer, FALSE))
{
if (pAd->MulTestTab.WdsEntry[i].WepStatus == Ndis802_11Encryption1Enabled)
{
/* Ascii type */
if (strlen(tmpbuf) == 5 || strlen(tmpbuf) == 13)
{
KeyLen = strlen(tmpbuf);
pAd->MulTestTab.WdsEntry[i].WdsKey.KeyLen = KeyLen;
NdisMoveMemory(pAd->MulTestTab.WdsEntry[i].WdsKey.Key, tmpbuf, KeyLen);
if (KeyLen == 5)
CipherAlg = CIPHER_WEP64;
else
CipherAlg = CIPHER_WEP128;
pAd->MulTestTab.WdsEntry[i].WdsKey.CipherAlg = CipherAlg;
DBGPRINT(RT_DEBUG_TRACE, ("IF/wds%d Key=%s ,type=Ascii, CipherAlg(%s)\n", i, tmpbuf, (CipherAlg == CIPHER_WEP64 ? "wep64" : "wep128")));
}
/* Hex type */
else if (strlen(tmpbuf) == 10 || strlen(tmpbuf) == 26)
{
KeyLen = strlen(tmpbuf);
pAd->MulTestTab.WdsEntry[i].WdsKey.KeyLen = KeyLen / 2;
AtoH(tmpbuf, pAd->MulTestTab.WdsEntry[i].WdsKey.Key, KeyLen / 2);
if (KeyLen == 10)
CipherAlg = CIPHER_WEP64;
else
CipherAlg = CIPHER_WEP128;
pAd->MulTestTab.WdsEntry[i].WdsKey.CipherAlg = CipherAlg;
DBGPRINT(RT_DEBUG_TRACE, ("IF/wds%d Key=%s ,type=Hex, CipherAlg(%s)\n", i, tmpbuf, (CipherAlg == CIPHER_WEP64 ? "wep64" : "wep128")));
}
/* Invalid type */
else
{
pAd->MulTestTab.WdsEntry[i].WepStatus = Ndis802_11EncryptionDisabled;
NdisZeroMemory(&pAd->MulTestTab.WdsEntry[i].WdsKey, sizeof(CIPHER_KEY));
DBGPRINT(RT_DEBUG_TRACE, ("IF/wds%d has invalid key for WEP, reset encryption to OPEN\n", i));
}
}
else if ((pAd->MulTestTab.WdsEntry[i].WepStatus == Ndis802_11Encryption2Enabled)
|| (pAd->MulTestTab.WdsEntry[i].WepStatus == Ndis802_11Encryption3Enabled)
#ifdef WAPI_SUPPORT
|| (pAd->MulTestTab.WdsEntry[i].WepStatus == Ndis802_11EncryptionSMS4Enabled)
#endif /* WAPI_SUPPORT */
)
{
if ((strlen(tmpbuf) >= 8) && (strlen(tmpbuf) <= 64))
{
RT_CfgSetWPAPSKKey(pAd, tmpbuf, strlen(tmpbuf), (PUCHAR) RALINK_PASSPHRASE, sizeof(RALINK_PASSPHRASE), keyMaterial);
if (pAd->MulTestTab.WdsEntry[i].WepStatus == Ndis802_11Encryption3Enabled)
{
pAd->MulTestTab.WdsEntry[i].WdsKey.CipherAlg = CIPHER_AES;
CipherAlg = CIPHER_AES;
}
#ifdef WAPI_SUPPORT
else if (pAd->MulTestTab.WdsEntry[i].WepStatus == Ndis802_11EncryptionSMS4Enabled)
{
pAd->MulTestTab.WdsEntry[i].WdsKey.CipherAlg = CIPHER_SMS4;
CipherAlg = CIPHER_SMS4;
}
#endif /* WAPI_SUPPORT */
else
{
pAd->MulTestTab.WdsEntry[i].WdsKey.CipherAlg = CIPHER_TKIP;
CipherAlg = CIPHER_TKIP;
}
NdisMoveMemory(&pAd->MulTestTab.WdsEntry[i].WdsKey.Key, keyMaterial, 16);
pAd->MulTestTab.WdsEntry[i].WdsKey.KeyLen = 16;
NdisMoveMemory(&pAd->MulTestTab.WdsEntry[i].WdsKey.RxMic, keyMaterial+16, 8);
NdisMoveMemory(&pAd->MulTestTab.WdsEntry[i].WdsKey.TxMic, keyMaterial+16, 8);
DBGPRINT(RT_DEBUG_TRACE, ("IF/wds%d Key=%s, CipherAlg(%s)\n", i, tmpbuf, (CipherAlg == CIPHER_AES ? "AES" : "TKIP")));
}
else
{
DBGPRINT(RT_DEBUG_TRACE, ("IF/wds%d has invalid key for WPA, reset encryption to OPEN\n", i));
pAd->MulTestTab.WdsEntry[i].WepStatus = Ndis802_11EncryptionDisabled;
NdisZeroMemory(&pAd->MulTestTab.WdsEntry[i].WdsKey, sizeof(CIPHER_KEY));
}
}
else
{
pAd->MulTestTab.WdsEntry[i].WepStatus = Ndis802_11EncryptionDisabled;
NdisZeroMemory(&pAd->MulTestTab.WdsEntry[i].WdsKey, sizeof(CIPHER_KEY));
}
}
}
}
/* WdsDefaultKeyID */
if(RTMPGetKeyParameter("WdsDefaultKeyID", tmpbuf, 10, buffer, TRUE))
{
for (i = 0, macptr = rstrtok(tmpbuf,";"); (macptr && i < MAX_WDS_ENTRY); macptr = rstrtok(NULL,";"), i++)
{
KeyIdx = (UCHAR) simple_strtol(macptr, 0, 10);
if((KeyIdx >= 1 ) && (KeyIdx <= 4))
pAd->MulTestTab.WdsEntry[i].KeyIdx = (UCHAR) (KeyIdx - 1);
else
pAd->MulTestTab.WdsEntry[i].KeyIdx = 0;
if ((pAd->MulTestTab.WdsEntry[i].WepStatus == Ndis802_11Encryption2Enabled)
|| (pAd->MulTestTab.WdsEntry[i].WepStatus == Ndis802_11Encryption3Enabled))
pAd->MulTestTab.WdsEntry[i].KeyIdx = 0;
DBGPRINT(RT_DEBUG_TRACE, ("IF/wds%d - WdsDefaultKeyID(0~3)=%d\n", i, pAd->MulTestTab.WdsEntry[i].KeyIdx));
}
}
}
#ifdef SINGLE_SKU_V2
NDIS_STATUS RTMPSetSingleSKUParameters(
IN RTMP_ADAPTER *pAd)
{
PSTRING buffer;
PSTRING readline, token;
RTMP_OS_FD srcf;
INT retval;
PSTRING ptr;
int index, i;
CH_POWER *StartCh = NULL;
UCHAR MaxPwr;
UCHAR channel, *temp;
RTMP_OS_FS_INFO osFSInfo;
DlListInit(&pAd->SingleSkuPwrList);
/* init*/
os_alloc_mem(NULL, (UCHAR **)&buffer, MAX_INI_BUFFER_SIZE);
if (buffer == NULL)
return FALSE;
RtmpOSFSInfoChange(&osFSInfo, TRUE);
/* open card information file*/
srcf = RtmpOSFileOpen(SINGLE_SKU_TABLE_FILE_NAME, O_RDONLY, 0);
if (IS_FILE_OPEN_ERR(srcf))
{
/* card information file does not exist */
DBGPRINT(RT_DEBUG_TRACE,
("--> Error opening %s\n", SINGLE_SKU_TABLE_FILE_NAME));
goto free_resource;
}
#ifdef RTMP_INTERNAL_TX_ALC
if (pAd->TxPowerCtrl.bInternalTxALC != TRUE)
#endif /* RTMP_INTERNAL_TX_ALC */
MT7601_InitPAModeTable(pAd);
/* card information file exists so reading the card information */
NdisZeroMemory(buffer, MAX_INI_BUFFER_SIZE);
retval = RtmpOSFileRead(srcf, buffer, MAX_INI_BUFFER_SIZE);
if (retval < 0)
{
/* read fail */
DBGPRINT(RT_DEBUG_TRACE,("--> Read %s error %d\n", SINGLE_SKU_TABLE_FILE_NAME, -retval));
}
else
{
for ( readline = ptr = buffer, index=0; (ptr = strchr(readline, '\n')) != NULL; readline = ptr + 1, index++ )
{
*ptr = '\0';
if ( readline[0] == '#' )
continue;
if ( !strncmp(readline, "ch", 2) )
{
CH_POWER *pwr;
os_alloc_mem(NULL, (UCHAR **)&pwr, sizeof(*pwr));
NdisZeroMemory(pwr, sizeof(*pwr));
token= rstrtok(readline +2 ," ");
channel = simple_strtol(token, 0, 10);
pwr->StartChannel = channel;
for ( i= 0 ; i < SINGLE_SKU_TABLE_CCK_LENGTH ; i++ )
{
token = rstrtok(NULL ," ");
if ( token == NULL )
break;
pwr->PwrCCK[i] = simple_strtol(token, 0, 10) * 2;
}
for ( i= 0 ; i < SINGLE_SKU_TABLE_OFDM_LENGTH ; i++ )
{
token = rstrtok(NULL ," ");
if ( token == NULL )
break;
pwr->PwrOFDM[i] = simple_strtol(token, 0, 10) *2;
}
for ( i= 0 ; i < SINGLE_SKU_TABLE_HT_LENGTH ; i++ )
{
token = rstrtok(NULL ," ");
if ( token == NULL )
break;
pwr->PwrHT20[i] = simple_strtol(token, 0, 10) *2;
}
for ( i= 0 ; i < SINGLE_SKU_TABLE_HT_LENGTH ; i++ )
{
token = rstrtok(NULL ," ");
if ( token == NULL )
break;
pwr->PwrHT40[i] = simple_strtol(token, 0, 10) *2;
}
if ( StartCh == NULL )
{
StartCh = pwr;
DlListAddTail(&pAd->SingleSkuPwrList, &pwr->List);
}
else
{
BOOLEAN isSame = TRUE;
for ( i= 0 ; i < SINGLE_SKU_TABLE_CCK_LENGTH ; i++ )
{
if ( StartCh->PwrCCK[i] != pwr->PwrCCK[i] )
{
isSame = FALSE;
break;
}
}
if ( isSame == TRUE )
{
for ( i= 0 ; i < SINGLE_SKU_TABLE_OFDM_LENGTH ; i++ )
{
if ( StartCh->PwrOFDM[i] != pwr->PwrOFDM[i] )
{
isSame = FALSE;
break;
}
}
}
if ( isSame == TRUE )
{
for ( i= 0 ; i < SINGLE_SKU_TABLE_HT_LENGTH ; i++ )
{
if ( StartCh->PwrHT20[i] != pwr->PwrHT20[i] )
{
isSame = FALSE;
break;
}
}
}
if ( isSame == TRUE )
{
for ( i= 0 ; i < SINGLE_SKU_TABLE_HT_LENGTH ; i++ )
{
if ( StartCh->PwrHT40[i] != pwr->PwrHT40[i] )
{
isSame = FALSE;
break;
}
}
}
if ( isSame == TRUE )
{
os_free_mem(NULL, pwr);
}
else
{
StartCh = pwr;
DlListAddTail(&pAd->SingleSkuPwrList, &StartCh->List);
pwr = NULL;
}
}
StartCh->num ++;
os_alloc_mem(pAd, (PUCHAR *)&temp, StartCh->num);
if ( StartCh->Channel != NULL )
{
NdisMoveMemory(temp, StartCh->Channel, StartCh->num-1);
os_free_mem(pAd, StartCh->Channel);
}
StartCh->Channel = temp;
StartCh->Channel[StartCh->num-1] = channel;
}
}
}
{
CH_POWER *ch, *ch_temp;
DlListForEachSafe(ch, ch_temp, &pAd->SingleSkuPwrList, CH_POWER, List)
{
int i;
DBGPRINT(RT_DEBUG_TRACE,("start ch = %d, ch->num = %d\n", ch->StartChannel, ch->num));
DBGPRINT(RT_DEBUG_TRACE, ("Channel: "));
for ( i = 0 ; i < ch->num ; i++ )
DBGPRINT(RT_DEBUG_TRACE,("%d ", ch->Channel[i]));
DBGPRINT(RT_DEBUG_TRACE,("\n"));
DBGPRINT(RT_DEBUG_TRACE, ("CCK: "));
for ( i= 0 ; i < SINGLE_SKU_TABLE_CCK_LENGTH ; i++ )
{
DBGPRINT(RT_DEBUG_TRACE,("%d ", ch->PwrCCK[i]));
}
DBGPRINT(RT_DEBUG_TRACE,("\n"));
DBGPRINT(RT_DEBUG_TRACE, ("OFDM: "));
for ( i= 0 ; i < SINGLE_SKU_TABLE_OFDM_LENGTH ; i++ )
{
DBGPRINT(RT_DEBUG_TRACE,("%d ", ch->PwrOFDM[i]));
}
DBGPRINT(RT_DEBUG_TRACE,("\n"));
DBGPRINT(RT_DEBUG_TRACE, ("HT20: "));
for ( i= 0 ; i < SINGLE_SKU_TABLE_HT_LENGTH ; i++ )
{
DBGPRINT(RT_DEBUG_TRACE, ("%d ", ch->PwrHT20[i]));
}
DBGPRINT(RT_DEBUG_TRACE,("\n"));
DBGPRINT(RT_DEBUG_TRACE, ("HT40: "));
for ( i= 0 ; i < SINGLE_SKU_TABLE_HT_LENGTH ; i++ )
{
DBGPRINT(RT_DEBUG_TRACE,("%d ", ch->PwrHT40[i]));
}
DBGPRINT(RT_DEBUG_TRACE,("\n"));
}
}
/* close file*/
retval = RtmpOSFileClose(srcf);
free_resource:
RtmpOSFSInfoChange(&osFSInfo, FALSE);
os_free_mem(NULL, buffer);
}
UCHAR GetSkuChannelBasePwr(
IN PRTMP_ADAPTER pAd,
IN UCHAR channel)
{
CH_POWER *ch, *ch_temp;
UCHAR start_ch;
UCHAR base_pwr = pAd->DefaultTargetPwr;
UINT8 i, j;
DlListForEachSafe(ch, ch_temp, &pAd->SingleSkuPwrList, CH_POWER, List)
{
start_ch = ch->StartChannel;
if ( channel >= start_ch )
{
for ( j = 0; j < ch->num; j++ )
{
if ( channel == ch->Channel[j] )
{
for ( i= 0 ; i < SINGLE_SKU_TABLE_CCK_LENGTH ; i++ )
{
if ( base_pwr > ch->PwrCCK[i] )
base_pwr = ch->PwrCCK[i];
}
for ( i= 0 ; i < SINGLE_SKU_TABLE_OFDM_LENGTH ; i++ )
{
if ( base_pwr > ch->PwrOFDM[i] )
base_pwr = ch->PwrOFDM[i];
}
for ( i= 0 ; i < SINGLE_SKU_TABLE_HT_LENGTH ; i++ )
{
if ( base_pwr > ch->PwrHT20[i] )
base_pwr = ch->PwrHT20[i];
}
if (pAd->CommonCfg.BBPCurrentBW == BW_40)
{
for ( i= 0 ; i < SINGLE_SKU_TABLE_HT_LENGTH ; i++ )
{
if ( ch->PwrHT40[i] == 0 )
break;
if ( base_pwr > ch->PwrHT40[i] )
base_pwr = ch->PwrHT40[i];
}
}
break;
}
}
}
}
return base_pwr;
}
#define SKU_PHYMODE_CCK_1M_2M 0
#define SKU_PHYMODE_CCK_5M_11M 1
#define SKU_PHYMODE_OFDM_6M_9M 2
#define SKU_PHYMODE_OFDM_12M_18M 3
#define SKU_PHYMODE_OFDM_24M_36M 4
#define SKU_PHYMODE_OFDM_48M_54M 5
#define SKU_PHYMODE_HT_MCS0_MCS1 6
#define SKU_PHYMODE_HT_MCS2_MCS3 7
#define SKU_PHYMODE_HT_MCS4_MCS5 8
#define SKU_PHYMODE_HT_MCS6_MCS7 9
#define SKU_PHYMODE_HT_MCS8_MCS9 10
#define SKU_PHYMODE_HT_MCS10_MCS11 11
#define SKU_PHYMODE_HT_MCS12_MCS13 12
#define SKU_PHYMODE_HT_MCS14_MCS15 13
#define SKU_PHYMODE_STBC_MCS0_MCS1 14
#define SKU_PHYMODE_STBC_MCS2_MCS3 15
#define SKU_PHYMODE_STBC_MCS4_MCS5 16
#define SKU_PHYMODE_STBC_MCS6_MCS7 17
VOID InitSkuRateDiffTable(
IN PRTMP_ADAPTER pAd )
{
USHORT i, value;
CHAR BasePwr, Pwr;
RT28xx_EEPROM_READ16(pAd, EEPROM_TXPOWER_BYRATE_20MHZ_2_4G + 4, value);
BasePwr = (value >> 8) & 0xFF;
BasePwr = (BasePwr > 0x1F ) ? BasePwr - 0x40: BasePwr;
for ( i = 0 ; i < 9; i++ )
{
RT28xx_EEPROM_READ16(pAd, EEPROM_TXPOWER_BYRATE_20MHZ_2_4G + i*2, value);
Pwr = value & 0xFF ;
Pwr = (Pwr > 0x1F ) ? Pwr - 0x40: Pwr;
pAd->SingleSkuRatePwrDiff[i *2] = Pwr - BasePwr;
Pwr = (value >> 8) & 0xFF;
Pwr = (Pwr > 0x1F ) ? Pwr - 0x40: Pwr;
pAd->SingleSkuRatePwrDiff[i *2 + 1] = Pwr - BasePwr;
}
}
INT32 GetSkuPAModePwr(
IN PRTMP_ADAPTER pAd,
IN UCHAR PAMode)
{
INT32 pa_mode_pwr = 0;
switch ( PAMode )
{
case SKU_PHYMODE_CCK_1M_2M:
pa_mode_pwr = RF_PA_MODE_CCK_1M;
break;
case SKU_PHYMODE_CCK_5M_11M:
pa_mode_pwr = RF_PA_MODE_CCK_5M;
break;
case SKU_PHYMODE_OFDM_6M_9M:
pa_mode_pwr = RF_PA_MODE_OFDM_6M;
break;
case SKU_PHYMODE_OFDM_12M_18M:
pa_mode_pwr = RF_PA_MODE_OFDM_12M;
break;
case SKU_PHYMODE_OFDM_24M_36M:
pa_mode_pwr = RF_PA_MODE_OFDM_24M;
break;
case SKU_PHYMODE_OFDM_48M_54M:
pa_mode_pwr = RF_PA_MODE_OFDM_48M;
break;
case SKU_PHYMODE_HT_MCS0_MCS1:
case SKU_PHYMODE_STBC_MCS0_MCS1:
pa_mode_pwr = RF_PA_MODE_HT_MCS0;
break;
case SKU_PHYMODE_HT_MCS2_MCS3:
case SKU_PHYMODE_STBC_MCS2_MCS3:
pa_mode_pwr = RF_PA_MODE_HT_MCS2;
break;
case SKU_PHYMODE_HT_MCS4_MCS5:
case SKU_PHYMODE_STBC_MCS4_MCS5:
pa_mode_pwr = RF_PA_MODE_HT_MCS4;
break;
case SKU_PHYMODE_HT_MCS6_MCS7:
case SKU_PHYMODE_STBC_MCS6_MCS7:
pa_mode_pwr = RF_PA_MODE_HT_MCS6;
break;
case SKU_PHYMODE_HT_MCS8_MCS9:
pa_mode_pwr = RF_PA_MODE_HT_MCS8;
break;
case SKU_PHYMODE_HT_MCS10_MCS11:
pa_mode_pwr = RF_PA_MODE_HT_MCS10;
break;
case SKU_PHYMODE_HT_MCS12_MCS13:
pa_mode_pwr = RF_PA_MODE_HT_MCS12;
break;
case SKU_PHYMODE_HT_MCS14_MCS15:
pa_mode_pwr = RF_PA_MODE_HT_MCS14;
break;
default:
break;
}
return pa_mode_pwr;
}
UCHAR GetSkuRatePwr(
IN PRTMP_ADAPTER pAd,
IN CHAR phymode,
IN UCHAR channel,
IN UCHAR bw)
{
UINT8 i;
CH_POWER *ch, *ch_temp;
UCHAR start_ch;
UCHAR rate_pwr = pAd->DefaultTargetPwr;
UCHAR max_pwr;
INT32 pwr_diff;
DlListForEachSafe(ch, ch_temp, &pAd->SingleSkuPwrList, CH_POWER, List)
{
start_ch = ch->StartChannel;
if ( channel >= start_ch )
{
for ( i = 0; i < ch->num; i++ )
{
if ( channel == ch->Channel[i] )
{
switch ( phymode )
{
case SKU_PHYMODE_CCK_1M_2M:
rate_pwr = ch->PwrCCK[0];
break;
case SKU_PHYMODE_CCK_5M_11M:
rate_pwr = ch->PwrCCK[2];
break;
case SKU_PHYMODE_OFDM_6M_9M:
rate_pwr = ch->PwrOFDM[0];
break;
case SKU_PHYMODE_OFDM_12M_18M:
rate_pwr = ch->PwrOFDM[2];
break;
case SKU_PHYMODE_OFDM_24M_36M:
rate_pwr = ch->PwrOFDM[4];
break;
case SKU_PHYMODE_OFDM_48M_54M:
rate_pwr = ch->PwrOFDM[6];
break;
case SKU_PHYMODE_HT_MCS0_MCS1:
case SKU_PHYMODE_STBC_MCS0_MCS1:
if ( bw == BW_20 )
rate_pwr = ch->PwrHT20[0];
else if ( bw == BW_40 )
rate_pwr = ch->PwrHT40[0];
break;
case SKU_PHYMODE_HT_MCS2_MCS3:
case SKU_PHYMODE_STBC_MCS2_MCS3:
if ( bw == BW_20 )
rate_pwr = ch->PwrHT20[2];
else if ( bw == BW_40 )
rate_pwr = ch->PwrHT40[2];
break;
case SKU_PHYMODE_HT_MCS4_MCS5:
case SKU_PHYMODE_STBC_MCS4_MCS5:
if ( bw == BW_20 )
rate_pwr = ch->PwrHT20[4];
else if ( bw == BW_40 )
rate_pwr = ch->PwrHT40[4];
break;
case SKU_PHYMODE_HT_MCS6_MCS7:
case SKU_PHYMODE_STBC_MCS6_MCS7:
if ( bw == BW_20 )
rate_pwr = ch->PwrHT20[6];
else if ( bw == BW_40 )
rate_pwr = ch->PwrHT40[6];
break;
case SKU_PHYMODE_HT_MCS8_MCS9:
if ( bw == BW_20 )
rate_pwr = ch->PwrHT20[8];
else if ( bw == BW_40 )
rate_pwr = ch->PwrHT40[8];
break;
case SKU_PHYMODE_HT_MCS10_MCS11:
if ( bw == BW_20 )
rate_pwr = ch->PwrHT20[10];
else if ( bw == BW_40 )
rate_pwr = ch->PwrHT40[10];
break;
case SKU_PHYMODE_HT_MCS12_MCS13:
if ( bw == BW_20 )
rate_pwr = ch->PwrHT20[12];
else if ( bw == BW_40 )
rate_pwr = ch->PwrHT40[12];
break;
case SKU_PHYMODE_HT_MCS14_MCS15:
if ( bw == BW_20 )
rate_pwr = ch->PwrHT20[14];
else if ( bw == BW_40 )
rate_pwr = ch->PwrHT40[14];
break;
default:
break;
}
break;
}
}
}
}
pwr_diff = GetSkuPAModePwr(pAd, phymode) + (pAd->SingleSkuRatePwrDiff[phymode] << 12) + 2048;
pwr_diff = pwr_diff >> 12;
max_pwr = pAd->DefaultTargetPwr + pwr_diff;
if ( rate_pwr > max_pwr )
rate_pwr = max_pwr;
return rate_pwr;
}
VOID UpdateSkuRatePwr(
IN PRTMP_ADAPTER pAd,
IN UCHAR channel,
IN UCHAR bw,
IN CHAR base_pwr)
{
INT32 sku_rate_pwr;
INT32 rate_pwr;
INT32 mcs_digital_pwr, pa_mode_pwr, diff_pwr;
UINT32 data, Adata, Gdata;
UCHAR BBPR4, BBPR178;
UCHAR i;
CHAR rate_table[18];
printk("channel = %d, bw = %d\n", channel, bw);
for ( i = 0 ; i < 18; i++ )
{
sku_rate_pwr = GetSkuRatePwr(pAd, i, channel, bw);
printk("sku_rate_pwr = %d", sku_rate_pwr);
sku_rate_pwr = sku_rate_pwr << 12; // sku_rate_power * 4096
printk("\tsku_rate_pwr = %d\n", sku_rate_pwr);
if ( i < SKU_PHYMODE_CCK_5M_11M )
{
RTMP_BBP_IO_READ8_BY_REG_ID(pAd, BBP_R4, &BBPR4);
RTMP_BBP_IO_READ8_BY_REG_ID(pAd, BBP_R178, &BBPR178);
if ( BBPR4 & 0x20 )
{
if ( BBPR178 == 0 )
{
mcs_digital_pwr = 9830; // 8192 * 1.2
}
else
{
mcs_digital_pwr = 18022; // 8192 * 2.2
}
}
else
{
if ( BBPR178 == 0 )
{
mcs_digital_pwr = 24576; // 8192 * 3
}
else
{
mcs_digital_pwr = 819; /// 8192 * 0.1
}
}
}
else
{
mcs_digital_pwr = 0;
}
pa_mode_pwr = GetSkuPAModePwr(pAd, i);
printk("base_pwr = %d", base_pwr);
rate_pwr = base_pwr << 12;
printk("\t base_pwr = %d\n", rate_pwr);
printk("mcs_digital_pwr = %d\n", mcs_digital_pwr);
printk("pa_mode_pwr = %d\n", pa_mode_pwr);
rate_pwr = rate_pwr + mcs_digital_pwr + pa_mode_pwr;
printk("rate_pwr = %d\n", rate_pwr);
diff_pwr = sku_rate_pwr - rate_pwr;
printk("diff_pwr = %d", diff_pwr);
diff_pwr = diff_pwr >> 12;
printk("\tdiff_pwr = %d\n", diff_pwr);
rate_table[i] = diff_pwr -1;
}
for ( i = 0 ; i < 5; i++ )
{
data = 0;
Adata = 0;
Gdata = 0;
data = (rate_table[i*4] & 0x3F )+ ((rate_table[i*4 + 1] &0x3F) << 8);
Adata = ((rate_table[i*4] + pAd->chipCap.Apwrdelta ) & 0x3F )+ ( ((rate_table[i*4 + 1] + pAd->chipCap.Apwrdelta) & 0x3F) << 8);
Gdata = ((rate_table[i*4] + pAd->chipCap.Gpwrdelta ) & 0x3F ) + ( ((rate_table[i*4 + 1] + pAd->chipCap.Gpwrdelta) & 0x3F) << 8);
if ( i != 4 )
{
data |= ((rate_table[i*4 + 2] &0x3F) << 16 )+ ((rate_table[i*4 + 3] & 0x3F) << 24);
Adata |= ( ((rate_table[i*4 + 2] + pAd->chipCap.Apwrdelta ) & 0x3F) << 16) + ( ((rate_table[i*4 + 3] + pAd->chipCap.Apwrdelta) & 0x3F) << 24);
Gdata |= ( ((rate_table[i*4 + 2] + pAd->chipCap.Gpwrdelta ) & 0x3F) << 16) + ( ((rate_table[i*4 + 3] + pAd->chipCap.Gpwrdelta) & 0x3F) << 24);
}
/* For 20M/40M Power Delta issue */
pAd->Tx20MPwrCfgABand[i] = data;
pAd->Tx20MPwrCfgGBand[i] = data;
pAd->Tx40MPwrCfgABand[i] = Adata;
pAd->Tx40MPwrCfgGBand[i] = Gdata;
RTMP_IO_WRITE32(pAd, TX_PWR_CFG_0 + i*4, data);
DBGPRINT_RAW(RT_DEBUG_TRACE, ("20MHz BW, 2.4G band-%08x, Adata = %08x, Gdata = %08x \n", data, Adata, Gdata));
}
/* Extra set MAC registers to compensate Tx power if any */
RTMP_CHIP_ASIC_EXTRA_POWER_OVER_MAC(pAd);
}
#endif /* SINGLE_SKU_V2 */