Commit 4e1efd6e authored by Jesper Juhl's avatar Jesper Juhl Committed by Greg Kroah-Hartman

staging, vt6656/wpactl.c: A basic style cleanup

This patch cleans up the coding style in
drivers/staging/vt6656/wpactl.c to closer match the generally accepted
kernel CodingStyle. It is by no means a "make it perfect" patch, but
it does get the file a fair bit closer to matching the accepted style
(whomever was involved in the evolution of this file seriously need to
configure their editors to maintain a consistent style - it was a
mess).

Besides pure style cleanups I also took the liberty of removing some
pointless parens, some unneeded casts and removing some commented out code
(it was obviously not used and git has it if it's ever needed in the
future).
Signed-off-by: default avatarJesper Juhl <jj@chaosbits.net>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 08afcf9c
...@@ -46,23 +46,18 @@ ...@@ -46,23 +46,18 @@
#define VIAWGET_WPA_MAX_BUF_SIZE 1024 #define VIAWGET_WPA_MAX_BUF_SIZE 1024
static const int frequency_list[] = { static const int frequency_list[] = {
2412, 2417, 2422, 2427, 2432, 2437, 2442, 2412, 2417, 2422, 2427, 2432, 2437, 2442,
2447, 2452, 2457, 2462, 2467, 2472, 2484 2447, 2452, 2457, 2462, 2467, 2472, 2484
}; };
/*--------------------- Static Classes ----------------------------*/ /*--------------------- Static Classes ----------------------------*/
/*--------------------- Static Variables --------------------------*/ /*--------------------- Static Variables --------------------------*/
//static int msglevel =MSG_LEVEL_DEBUG; static int msglevel = MSG_LEVEL_INFO;
static int msglevel =MSG_LEVEL_INFO;
/*--------------------- Static Functions --------------------------*/ /*--------------------- Static Functions --------------------------*/
/*--------------------- Export Variables --------------------------*/ /*--------------------- Export Variables --------------------------*/
static void wpadev_setup(struct net_device *dev) static void wpadev_setup(struct net_device *dev)
{ {
...@@ -72,9 +67,9 @@ static void wpadev_setup(struct net_device *dev) ...@@ -72,9 +67,9 @@ static void wpadev_setup(struct net_device *dev)
dev->addr_len = ETH_ALEN; dev->addr_len = ETH_ALEN;
dev->tx_queue_len = 1000; dev->tx_queue_len = 1000;
memset(dev->broadcast,0xFF, ETH_ALEN); memset(dev->broadcast, 0xFF, ETH_ALEN);
dev->flags = IFF_BROADCAST|IFF_MULTICAST; dev->flags = IFF_BROADCAST | IFF_MULTICAST;
} }
/* /*
...@@ -90,45 +85,43 @@ static void wpadev_setup(struct net_device *dev) ...@@ -90,45 +85,43 @@ static void wpadev_setup(struct net_device *dev)
* Return Value: * Return Value:
* *
*/ */
static int wpa_init_wpadev(PSDevice pDevice) static int wpa_init_wpadev(PSDevice pDevice)
{ {
PSDevice wpadev_priv; PSDevice wpadev_priv;
struct net_device *dev = pDevice->dev; struct net_device *dev = pDevice->dev;
int ret=0; int ret = 0;
pDevice->wpadev = alloc_netdev(sizeof(PSDevice), "vntwpa", wpadev_setup); pDevice->wpadev = alloc_netdev(sizeof(PSDevice), "vntwpa", wpadev_setup);
if (pDevice->wpadev == NULL) if (pDevice->wpadev == NULL)
return -ENOMEM; return -ENOMEM;
wpadev_priv = netdev_priv(pDevice->wpadev); wpadev_priv = netdev_priv(pDevice->wpadev);
*wpadev_priv = *pDevice; *wpadev_priv = *pDevice;
memcpy(pDevice->wpadev->dev_addr, dev->dev_addr, ETH_ALEN); memcpy(pDevice->wpadev->dev_addr, dev->dev_addr, ETH_ALEN);
pDevice->wpadev->base_addr = dev->base_addr; pDevice->wpadev->base_addr = dev->base_addr;
pDevice->wpadev->irq = dev->irq; pDevice->wpadev->irq = dev->irq;
pDevice->wpadev->mem_start = dev->mem_start; pDevice->wpadev->mem_start = dev->mem_start;
pDevice->wpadev->mem_end = dev->mem_end; pDevice->wpadev->mem_end = dev->mem_end;
ret = register_netdev(pDevice->wpadev); ret = register_netdev(pDevice->wpadev);
if (ret) { if (ret) {
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "%s: register_netdev(WPA) failed!\n", DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "%s: register_netdev(WPA) failed!\n",
dev->name); dev->name);
free_netdev(pDevice->wpadev); free_netdev(pDevice->wpadev);
return -1; return -1;
} }
if (pDevice->skb == NULL) { if (pDevice->skb == NULL) {
pDevice->skb = dev_alloc_skb((int)pDevice->rx_buf_sz); pDevice->skb = dev_alloc_skb((int)pDevice->rx_buf_sz);
if (pDevice->skb == NULL) if (pDevice->skb == NULL)
return -ENOMEM; return -ENOMEM;
} }
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "%s: Registered netdev %s for WPA management\n", DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "%s: Registered netdev %s for WPA management\n",
dev->name, pDevice->wpadev->name); dev->name, pDevice->wpadev->name);
return 0; return 0;
} }
/* /*
* Description: * Description:
* unregister net_device (wpadev) * unregister net_device (wpadev)
...@@ -141,29 +134,24 @@ static int wpa_init_wpadev(PSDevice pDevice) ...@@ -141,29 +134,24 @@ static int wpa_init_wpadev(PSDevice pDevice)
* Return Value: * Return Value:
* *
*/ */
static int wpa_release_wpadev(PSDevice pDevice) static int wpa_release_wpadev(PSDevice pDevice)
{ {
if (pDevice->skb) { if (pDevice->skb) {
dev_kfree_skb(pDevice->skb); dev_kfree_skb(pDevice->skb);
pDevice->skb = NULL; pDevice->skb = NULL;
} }
if (pDevice->wpadev) { if (pDevice->wpadev) {
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "%s: Netdevice %s unregistered\n", DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "%s: Netdevice %s unregistered\n",
pDevice->dev->name, pDevice->wpadev->name); pDevice->dev->name, pDevice->wpadev->name);
unregister_netdev(pDevice->wpadev); unregister_netdev(pDevice->wpadev);
free_netdev(pDevice->wpadev); free_netdev(pDevice->wpadev);
pDevice->wpadev = NULL; pDevice->wpadev = NULL;
} }
return 0; return 0;
} }
/* /*
* Description: * Description:
* Set enable/disable dev for wpa supplicant deamon * Set enable/disable dev for wpa supplicant deamon
...@@ -177,13 +165,11 @@ static int wpa_release_wpadev(PSDevice pDevice) ...@@ -177,13 +165,11 @@ static int wpa_release_wpadev(PSDevice pDevice)
* Return Value: * Return Value:
* *
*/ */
int wpa_set_wpadev(PSDevice pDevice, int val) int wpa_set_wpadev(PSDevice pDevice, int val)
{ {
if (val) if (val)
return wpa_init_wpadev(pDevice); return wpa_init_wpadev(pDevice);
else return wpa_release_wpadev(pDevice);
return wpa_release_wpadev(pDevice);
} }
/* /*
...@@ -199,245 +185,217 @@ int wpa_set_wpadev(PSDevice pDevice, int val) ...@@ -199,245 +185,217 @@ int wpa_set_wpadev(PSDevice pDevice, int val)
* Return Value: * Return Value:
* *
*/ */
int wpa_set_keys(PSDevice pDevice, void *ctx, BOOL fcpfkernel) int wpa_set_keys(PSDevice pDevice, void *ctx, BOOL fcpfkernel)
{ {
struct viawget_wpa_param *param=ctx; struct viawget_wpa_param *param = ctx;
PSMgmtObject pMgmt = &(pDevice->sMgmtObj); PSMgmtObject pMgmt = &pDevice->sMgmtObj;
DWORD dwKeyIndex = 0; DWORD dwKeyIndex = 0;
BYTE abyKey[MAX_KEY_LEN]; BYTE abyKey[MAX_KEY_LEN];
BYTE abySeq[MAX_KEY_LEN]; BYTE abySeq[MAX_KEY_LEN];
QWORD KeyRSC; QWORD KeyRSC;
// NDIS_802_11_KEY_RSC KeyRSC; BYTE byKeyDecMode = KEY_CTL_WEP;
BYTE byKeyDecMode = KEY_CTL_WEP;
int ret = 0; int ret = 0;
int uu, ii; int uu;
int ii;
if (param->u.wpa_key.alg_name > WPA_ALG_CCMP) if (param->u.wpa_key.alg_name > WPA_ALG_CCMP)
return -EINVAL; return -EINVAL;
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "param->u.wpa_key.alg_name = %d \n", param->u.wpa_key.alg_name); DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "param->u.wpa_key.alg_name = %d \n",
param->u.wpa_key.alg_name);
if (param->u.wpa_key.alg_name == WPA_ALG_NONE) { if (param->u.wpa_key.alg_name == WPA_ALG_NONE) {
pDevice->eEncryptionStatus = Ndis802_11EncryptionDisabled; pDevice->eEncryptionStatus = Ndis802_11EncryptionDisabled;
pDevice->bEncryptionEnable = FALSE; pDevice->bEncryptionEnable = FALSE;
pDevice->byKeyIndex = 0; pDevice->byKeyIndex = 0;
pDevice->bTransmitKey = FALSE; pDevice->bTransmitKey = FALSE;
for (uu=0; uu<MAX_KEY_TABLE; uu++) { for (uu=0; uu<MAX_KEY_TABLE; uu++) {
MACvDisableKeyEntry(pDevice, uu); MACvDisableKeyEntry(pDevice, uu);
} }
return ret; return ret;
} }
if (param->u.wpa_key.key && param->u.wpa_key.key_len > sizeof(abyKey)) if (param->u.wpa_key.key && param->u.wpa_key.key_len > sizeof(abyKey))
return -EINVAL; return -EINVAL;
spin_unlock_irq(&pDevice->lock); spin_unlock_irq(&pDevice->lock);
if(param->u.wpa_key.key && fcpfkernel) { if (param->u.wpa_key.key && fcpfkernel) {
memcpy(&abyKey[0], param->u.wpa_key.key, param->u.wpa_key.key_len); memcpy(&abyKey[0], param->u.wpa_key.key, param->u.wpa_key.key_len);
} } else {
else { if (param->u.wpa_key.key &&
if (param->u.wpa_key.key && copy_from_user(&abyKey[0], param->u.wpa_key.key,
copy_from_user(&abyKey[0], param->u.wpa_key.key, param->u.wpa_key.key_len)) { param->u.wpa_key.key_len)) {
spin_lock_irq(&pDevice->lock); spin_lock_irq(&pDevice->lock);
return -EINVAL; return -EINVAL;
}
} }
} spin_lock_irq(&pDevice->lock);
spin_lock_irq(&pDevice->lock);
dwKeyIndex = (DWORD)(param->u.wpa_key.key_index); dwKeyIndex = (DWORD)(param->u.wpa_key.key_index);
if (param->u.wpa_key.alg_name == WPA_ALG_WEP) { if (param->u.wpa_key.alg_name == WPA_ALG_WEP) {
if (dwKeyIndex > 3) { if (dwKeyIndex > 3) {
return -EINVAL; return -EINVAL;
} } else {
else { if (param->u.wpa_key.set_tx) {
if (param->u.wpa_key.set_tx) { pDevice->byKeyIndex = (BYTE)dwKeyIndex;
pDevice->byKeyIndex = (BYTE)dwKeyIndex; pDevice->bTransmitKey = TRUE;
pDevice->bTransmitKey = TRUE; dwKeyIndex |= (1 << 31);
dwKeyIndex |= (1 << 31); }
} KeybSetDefaultKey( pDevice,
KeybSetDefaultKey( pDevice, &(pDevice->sKey),
&(pDevice->sKey), dwKeyIndex & ~(BIT30 | USE_KEYRSC),
dwKeyIndex & ~(BIT30 | USE_KEYRSC), param->u.wpa_key.key_len,
param->u.wpa_key.key_len, NULL,
NULL, abyKey,
abyKey, KEY_CTL_WEP
KEY_CTL_WEP );
);
}
} pDevice->eEncryptionStatus = Ndis802_11Encryption1Enabled;
pDevice->eEncryptionStatus = Ndis802_11Encryption1Enabled; pDevice->bEncryptionEnable = TRUE;
pDevice->bEncryptionEnable = TRUE; return ret;
return ret;
} }
if (param->u.wpa_key.seq && param->u.wpa_key.seq_len > sizeof(abySeq)) if (param->u.wpa_key.seq && param->u.wpa_key.seq_len > sizeof(abySeq))
return -EINVAL; return -EINVAL;
spin_unlock_irq(&pDevice->lock); spin_unlock_irq(&pDevice->lock);
if(param->u.wpa_key.seq && fcpfkernel) { if (param->u.wpa_key.seq && fcpfkernel) {
memcpy(&abySeq[0], param->u.wpa_key.seq, param->u.wpa_key.seq_len); memcpy(&abySeq[0], param->u.wpa_key.seq, param->u.wpa_key.seq_len);
} } else {
else { if (param->u.wpa_key.seq &&
if (param->u.wpa_key.seq && copy_from_user(&abySeq[0], param->u.wpa_key.seq,
copy_from_user(&abySeq[0], param->u.wpa_key.seq, param->u.wpa_key.seq_len)) { param->u.wpa_key.seq_len)) {
spin_lock_irq(&pDevice->lock); spin_lock_irq(&pDevice->lock);
return -EINVAL; return -EINVAL;
} }
} }
spin_lock_irq(&pDevice->lock); spin_lock_irq(&pDevice->lock);
if (param->u.wpa_key.seq_len > 0) { if (param->u.wpa_key.seq_len > 0) {
for (ii = 0 ; ii < param->u.wpa_key.seq_len ; ii++) { for (ii = 0 ; ii < param->u.wpa_key.seq_len ; ii++) {
if (ii < 4) if (ii < 4)
LODWORD(KeyRSC) |= (abySeq[ii] << (ii * 8)); LODWORD(KeyRSC) |= (abySeq[ii] << (ii * 8));
else else
HIDWORD(KeyRSC) |= (abySeq[ii] << ((ii-4) * 8)); HIDWORD(KeyRSC) |= (abySeq[ii] << ((ii-4) * 8));
//KeyRSC |= (abySeq[ii] << (ii * 8));
} }
dwKeyIndex |= 1 << 29; dwKeyIndex |= 1 << 29;
} }
if (param->u.wpa_key.key_index >= MAX_GROUP_KEY) { if (param->u.wpa_key.key_index >= MAX_GROUP_KEY) {
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "return dwKeyIndex > 3\n"); DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "return dwKeyIndex > 3\n");
return -EINVAL; return -EINVAL;
} }
if (param->u.wpa_key.alg_name == WPA_ALG_TKIP) { if (param->u.wpa_key.alg_name == WPA_ALG_TKIP) {
pDevice->eEncryptionStatus = Ndis802_11Encryption2Enabled; pDevice->eEncryptionStatus = Ndis802_11Encryption2Enabled;
} }
if (param->u.wpa_key.alg_name == WPA_ALG_CCMP) { if (param->u.wpa_key.alg_name == WPA_ALG_CCMP) {
pDevice->eEncryptionStatus = Ndis802_11Encryption3Enabled; pDevice->eEncryptionStatus = Ndis802_11Encryption3Enabled;
} }
if (param->u.wpa_key.set_tx) if (param->u.wpa_key.set_tx)
dwKeyIndex |= (1 << 31); dwKeyIndex |= (1 << 31);
if (pDevice->eEncryptionStatus == Ndis802_11Encryption3Enabled) if (pDevice->eEncryptionStatus == Ndis802_11Encryption3Enabled)
byKeyDecMode = KEY_CTL_CCMP; byKeyDecMode = KEY_CTL_CCMP;
else if (pDevice->eEncryptionStatus == Ndis802_11Encryption2Enabled) else if (pDevice->eEncryptionStatus == Ndis802_11Encryption2Enabled)
byKeyDecMode = KEY_CTL_TKIP; byKeyDecMode = KEY_CTL_TKIP;
else else
byKeyDecMode = KEY_CTL_WEP; byKeyDecMode = KEY_CTL_WEP;
// Fix HCT test that set 256 bits KEY and Ndis802_11Encryption3Enabled // Fix HCT test that set 256 bits KEY and Ndis802_11Encryption3Enabled
if (pDevice->eEncryptionStatus == Ndis802_11Encryption3Enabled) { if (pDevice->eEncryptionStatus == Ndis802_11Encryption3Enabled) {
if (param->u.wpa_key.key_len == MAX_KEY_LEN) if (param->u.wpa_key.key_len == MAX_KEY_LEN)
byKeyDecMode = KEY_CTL_TKIP; byKeyDecMode = KEY_CTL_TKIP;
else if (param->u.wpa_key.key_len == WLAN_WEP40_KEYLEN) else if (param->u.wpa_key.key_len == WLAN_WEP40_KEYLEN)
byKeyDecMode = KEY_CTL_WEP; byKeyDecMode = KEY_CTL_WEP;
else if (param->u.wpa_key.key_len == WLAN_WEP104_KEYLEN) else if (param->u.wpa_key.key_len == WLAN_WEP104_KEYLEN)
byKeyDecMode = KEY_CTL_WEP; byKeyDecMode = KEY_CTL_WEP;
} else if (pDevice->eEncryptionStatus == Ndis802_11Encryption2Enabled) { } else if (pDevice->eEncryptionStatus == Ndis802_11Encryption2Enabled) {
if (param->u.wpa_key.key_len == WLAN_WEP40_KEYLEN) if (param->u.wpa_key.key_len == WLAN_WEP40_KEYLEN)
byKeyDecMode = KEY_CTL_WEP; byKeyDecMode = KEY_CTL_WEP;
else if (param->u.wpa_key.key_len == WLAN_WEP104_KEYLEN) else if (param->u.wpa_key.key_len == WLAN_WEP104_KEYLEN)
byKeyDecMode = KEY_CTL_WEP; byKeyDecMode = KEY_CTL_WEP;
} }
// Check TKIP key length
if ((byKeyDecMode == KEY_CTL_TKIP) &&
(param->u.wpa_key.key_len != MAX_KEY_LEN)) {
// TKIP Key must be 256 bits
//DBG_PRN_WLAN03(("return NDIS_STATUS_INVALID_DATA - TKIP Key must be 256 bits\n"));
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "return- TKIP Key must be 256 bits!\n");
return -EINVAL;
}
// Check AES key length
if ((byKeyDecMode == KEY_CTL_CCMP) &&
(param->u.wpa_key.key_len != AES_KEY_LEN)) {
// AES Key must be 128 bits
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "return - AES Key must be 128 bits\n");
return -EINVAL;
}
if (is_broadcast_ether_addr(&param->addr[0]) || (param->addr == NULL)) { // Check TKIP key length
/* if broadcast, set the key as every key entry's group key */ if ((byKeyDecMode == KEY_CTL_TKIP) &&
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "Groupe Key Assign.\n"); (param->u.wpa_key.key_len != MAX_KEY_LEN)) {
// TKIP Key must be 256 bits
if ((KeybSetAllGroupKey(pDevice, DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "return- TKIP Key must be 256 bits!\n");
&(pDevice->sKey), return -EINVAL;
dwKeyIndex,
param->u.wpa_key.key_len,
(PQWORD) &(KeyRSC),
(PBYTE)abyKey,
byKeyDecMode
) == TRUE) &&
(KeybSetDefaultKey(pDevice,
&(pDevice->sKey),
dwKeyIndex,
param->u.wpa_key.key_len,
(PQWORD) &(KeyRSC),
(PBYTE)abyKey,
byKeyDecMode
) == TRUE) ) {
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "GROUP Key Assign.\n");
} else {
//DBG_PRN_WLAN03(("return NDIS_STATUS_INVALID_DATA -KeybSetDefaultKey Fail.0\n"));
return -EINVAL;
}
} else {
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "Pairwise Key Assign.\n");
// BSSID not 0xffffffffffff
// Pairwise Key can't be WEP
if (byKeyDecMode == KEY_CTL_WEP) {
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "Pairwise Key can't be WEP\n");
return -EINVAL;
}
dwKeyIndex |= (1 << 30); // set pairwise key
if (pMgmt->eConfigMode == WMAC_CONFIG_IBSS_STA) {
//DBG_PRN_WLAN03(("return NDIS_STATUS_INVALID_DATA - WMAC_CONFIG_IBSS_STA\n"));
return -EINVAL;
}
if (KeybSetKey(pDevice,
&(pDevice->sKey),
&param->addr[0],
dwKeyIndex,
param->u.wpa_key.key_len,
(PQWORD) &(KeyRSC),
(PBYTE)abyKey,
byKeyDecMode
) == TRUE) {
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "Pairwise Key Set\n");
} else {
// Key Table Full
if (!compare_ether_addr(&param->addr[0], pDevice->abyBSSID)) {
//DBG_PRN_WLAN03(("return NDIS_STATUS_INVALID_DATA -Key Table Full.2\n"));
return -EINVAL;
} else {
// Save Key and configure just before associate/reassociate to BSSID
// we do not implement now
return -EINVAL;
}
}
} // BSSID not 0xffffffffffff
if ((ret == 0) && ((param->u.wpa_key.set_tx) != 0)) {
pDevice->byKeyIndex = (BYTE)param->u.wpa_key.key_index;
pDevice->bTransmitKey = TRUE;
} }
pDevice->bEncryptionEnable = TRUE; // Check AES key length
if ((byKeyDecMode == KEY_CTL_CCMP) &&
(param->u.wpa_key.key_len != AES_KEY_LEN)) {
// AES Key must be 128 bits
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "return - AES Key must be 128 bits\n");
return -EINVAL;
}
/* if (is_broadcast_ether_addr(&param->addr[0]) || (param->addr == NULL)) {
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO " key=%x-%x-%x-%x-%x-xxxxx \n", /* if broadcast, set the key as every key entry's group key */
pMgmt->sNodeDBTable[iNodeIndex].abyWepKey[byKeyIndex][0], DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "Groupe Key Assign.\n");
pMgmt->sNodeDBTable[iNodeIndex].abyWepKey[byKeyIndex][1],
pMgmt->sNodeDBTable[iNodeIndex].abyWepKey[byKeyIndex][2], if ((KeybSetAllGroupKey(pDevice, &(pDevice->sKey), dwKeyIndex,
pMgmt->sNodeDBTable[iNodeIndex].abyWepKey[byKeyIndex][3], param->u.wpa_key.key_len,
pMgmt->sNodeDBTable[iNodeIndex].abyWepKey[byKeyIndex][4] (PQWORD) &(KeyRSC),
); (PBYTE)abyKey,
*/ byKeyDecMode
) == TRUE) &&
(KeybSetDefaultKey(pDevice,
&(pDevice->sKey),
dwKeyIndex,
param->u.wpa_key.key_len,
(PQWORD) &(KeyRSC),
(PBYTE)abyKey,
byKeyDecMode
) == TRUE) ) {
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "GROUP Key Assign.\n");
} else {
return -EINVAL;
}
} else {
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "Pairwise Key Assign.\n");
// BSSID not 0xffffffffffff
// Pairwise Key can't be WEP
if (byKeyDecMode == KEY_CTL_WEP) {
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "Pairwise Key can't be WEP\n");
return -EINVAL;
}
dwKeyIndex |= (1 << 30); // set pairwise key
if (pMgmt->eConfigMode == WMAC_CONFIG_IBSS_STA) {
//DBG_PRN_WLAN03(("return NDIS_STATUS_INVALID_DATA - WMAC_CONFIG_IBSS_STA\n"));
return -EINVAL;
}
if (KeybSetKey(pDevice, &(pDevice->sKey), &param->addr[0],
dwKeyIndex, param->u.wpa_key.key_len,
(PQWORD) &(KeyRSC), (PBYTE)abyKey, byKeyDecMode
) == TRUE) {
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "Pairwise Key Set\n");
} else {
// Key Table Full
if (!compare_ether_addr(&param->addr[0], pDevice->abyBSSID)) {
//DBG_PRN_WLAN03(("return NDIS_STATUS_INVALID_DATA -Key Table Full.2\n"));
return -EINVAL;
} else {
// Save Key and configure just before associate/reassociate to BSSID
// we do not implement now
return -EINVAL;
}
}
} // BSSID not 0xffffffffffff
if ((ret == 0) && ((param->u.wpa_key.set_tx) != 0)) {
pDevice->byKeyIndex = (BYTE)param->u.wpa_key.key_index;
pDevice->bTransmitKey = TRUE;
}
pDevice->bEncryptionEnable = TRUE;
return ret; return ret;
} }
...@@ -454,23 +412,17 @@ int wpa_set_wpadev(PSDevice pDevice, int val) ...@@ -454,23 +412,17 @@ int wpa_set_wpadev(PSDevice pDevice, int val)
* Return Value: * Return Value:
* *
*/ */
static int wpa_set_wpa(PSDevice pDevice, struct viawget_wpa_param *param)
static int wpa_set_wpa(PSDevice pDevice,
struct viawget_wpa_param *param)
{ {
PSMgmtObject pMgmt = &pDevice->sMgmtObj;
PSMgmtObject pMgmt = &(pDevice->sMgmtObj);
int ret = 0; int ret = 0;
pMgmt->eAuthenMode = WMAC_AUTH_OPEN; pMgmt->eAuthenMode = WMAC_AUTH_OPEN;
pMgmt->bShareKeyAlgorithm = FALSE; pMgmt->bShareKeyAlgorithm = FALSE;
return ret; return ret;
} }
/* /*
* Description: * Description:
* set disassociate * set disassociate
...@@ -484,25 +436,21 @@ static int wpa_set_wpa(PSDevice pDevice, ...@@ -484,25 +436,21 @@ static int wpa_set_wpa(PSDevice pDevice,
* Return Value: * Return Value:
* *
*/ */
static int wpa_set_disassociate(PSDevice pDevice, struct viawget_wpa_param *param)
static int wpa_set_disassociate(PSDevice pDevice,
struct viawget_wpa_param *param)
{ {
PSMgmtObject pMgmt = &(pDevice->sMgmtObj); PSMgmtObject pMgmt = &pDevice->sMgmtObj;
int ret = 0; int ret = 0;
spin_lock_irq(&pDevice->lock); spin_lock_irq(&pDevice->lock);
if (pDevice->bLinkPass) { if (pDevice->bLinkPass) {
if (!memcmp(param->addr, pMgmt->abyCurrBSSID, 6)) if (!memcmp(param->addr, pMgmt->abyCurrBSSID, 6))
bScheduleCommand((void *) pDevice, WLAN_CMD_DISASSOCIATE, NULL); bScheduleCommand((void *)pDevice, WLAN_CMD_DISASSOCIATE, NULL);
} }
spin_unlock_irq(&pDevice->lock); spin_unlock_irq(&pDevice->lock);
return ret; return ret;
} }
/* /*
* Description: * Description:
* enable scan process * enable scan process
...@@ -516,36 +464,30 @@ static int wpa_set_disassociate(PSDevice pDevice, ...@@ -516,36 +464,30 @@ static int wpa_set_disassociate(PSDevice pDevice,
* Return Value: * Return Value:
* *
*/ */
static int wpa_set_scan(PSDevice pDevice, struct viawget_wpa_param *param)
static int wpa_set_scan(PSDevice pDevice,
struct viawget_wpa_param *param)
{ {
int ret = 0; int ret = 0;
/**set ap_scan=1&&scan_ssid=1 under hidden ssid mode**/ /**set ap_scan=1&&scan_ssid=1 under hidden ssid mode**/
PSMgmtObject pMgmt = &(pDevice->sMgmtObj); PSMgmtObject pMgmt = &pDevice->sMgmtObj;
PWLAN_IE_SSID pItemSSID; PWLAN_IE_SSID pItemSSID;
printk("wpa_set_scan-->desired [ssid=%s,ssid_len=%d]\n", printk("wpa_set_scan-->desired [ssid=%s,ssid_len=%d]\n",
param->u.scan_req.ssid,param->u.scan_req.ssid_len); param->u.scan_req.ssid,param->u.scan_req.ssid_len);
// Set the SSID // Set the SSID
memset(pMgmt->abyDesireSSID, 0, WLAN_IEHDR_LEN + WLAN_SSID_MAXLEN + 1); memset(pMgmt->abyDesireSSID, 0, WLAN_IEHDR_LEN + WLAN_SSID_MAXLEN + 1);
pItemSSID = (PWLAN_IE_SSID)pMgmt->abyDesireSSID; pItemSSID = (PWLAN_IE_SSID)pMgmt->abyDesireSSID;
pItemSSID->byElementID = WLAN_EID_SSID; pItemSSID->byElementID = WLAN_EID_SSID;
memcpy(pItemSSID->abySSID, param->u.scan_req.ssid, param->u.scan_req.ssid_len); memcpy(pItemSSID->abySSID, param->u.scan_req.ssid, param->u.scan_req.ssid_len);
pItemSSID->len = param->u.scan_req.ssid_len; pItemSSID->len = param->u.scan_req.ssid_len;
spin_lock_irq(&pDevice->lock);
BSSvClearBSSList((void *) pDevice, pDevice->bLinkPass);
/* bScheduleCommand((void *) pDevice, WLAN_CMD_BSSID_SCAN, NULL); */
bScheduleCommand((void *) pDevice,
WLAN_CMD_BSSID_SCAN,
pMgmt->abyDesireSSID);
spin_unlock_irq(&pDevice->lock);
return ret;
}
spin_lock_irq(&pDevice->lock);
BSSvClearBSSList((void *) pDevice, pDevice->bLinkPass);
bScheduleCommand((void *) pDevice, WLAN_CMD_BSSID_SCAN,
pMgmt->abyDesireSSID);
spin_unlock_irq(&pDevice->lock);
return ret;
}
/* /*
* Description: * Description:
...@@ -560,19 +502,15 @@ pItemSSID->len = param->u.scan_req.ssid_len; ...@@ -560,19 +502,15 @@ pItemSSID->len = param->u.scan_req.ssid_len;
* Return Value: * Return Value:
* *
*/ */
static int wpa_get_bssid(PSDevice pDevice, struct viawget_wpa_param *param)
static int wpa_get_bssid(PSDevice pDevice,
struct viawget_wpa_param *param)
{ {
PSMgmtObject pMgmt = &(pDevice->sMgmtObj); PSMgmtObject pMgmt = &pDevice->sMgmtObj;
int ret = 0; int ret = 0;
memcpy(param->u.wpa_associate.bssid, pMgmt->abyCurrBSSID , 6); memcpy(param->u.wpa_associate.bssid, pMgmt->abyCurrBSSID, 6);
return ret; return ret;
} }
/* /*
* Description: * Description:
* get bssid * get bssid
...@@ -586,24 +524,20 @@ static int wpa_get_bssid(PSDevice pDevice, ...@@ -586,24 +524,20 @@ static int wpa_get_bssid(PSDevice pDevice,
* Return Value: * Return Value:
* *
*/ */
static int wpa_get_ssid(PSDevice pDevice, struct viawget_wpa_param *param)
static int wpa_get_ssid(PSDevice pDevice,
struct viawget_wpa_param *param)
{ {
PSMgmtObject pMgmt = &(pDevice->sMgmtObj); PSMgmtObject pMgmt = &pDevice->sMgmtObj;
PWLAN_IE_SSID pItemSSID; PWLAN_IE_SSID pItemSSID;
int ret = 0; int ret = 0;
pItemSSID = (PWLAN_IE_SSID)pMgmt->abyCurrSSID; pItemSSID = (PWLAN_IE_SSID)pMgmt->abyCurrSSID;
memcpy(param->u.wpa_associate.ssid, pItemSSID->abySSID , pItemSSID->len); memcpy(param->u.wpa_associate.ssid, pItemSSID->abySSID, pItemSSID->len);
param->u.wpa_associate.ssid_len = pItemSSID->len; param->u.wpa_associate.ssid_len = pItemSSID->len;
return ret; return ret;
} }
/* /*
* Description: * Description:
* get scan results * get scan results
...@@ -617,135 +551,114 @@ static int wpa_get_ssid(PSDevice pDevice, ...@@ -617,135 +551,114 @@ static int wpa_get_ssid(PSDevice pDevice,
* Return Value: * Return Value:
* *
*/ */
static int wpa_get_scan(PSDevice pDevice, struct viawget_wpa_param *param)
static int wpa_get_scan(PSDevice pDevice,
struct viawget_wpa_param *param)
{ {
struct viawget_scan_result *scan_buf; struct viawget_scan_result *scan_buf;
PSMgmtObject pMgmt = &(pDevice->sMgmtObj); PSMgmtObject pMgmt = &pDevice->sMgmtObj;
PWLAN_IE_SSID pItemSSID; PWLAN_IE_SSID pItemSSID;
PKnownBSS pBSS; PKnownBSS pBSS;
PBYTE pBuf; PBYTE pBuf;
int ret = 0; int ret = 0;
u16 count = 0; u16 count = 0;
u16 ii, jj; u16 ii;
long ldBm;//James //add u16 jj;
long ldBm; //James //add
//******mike:bubble sort by stronger RSSI*****// //******mike:bubble sort by stronger RSSI*****//
PBYTE ptempBSS;
PBYTE ptempBSS; ptempBSS = kmalloc(sizeof(KnownBSS), GFP_ATOMIC);
if (ptempBSS == NULL) {
printk("bubble sort kmalloc memory fail@@@\n");
ret = -ENOMEM;
return ret;
}
ptempBSS = kmalloc(sizeof(KnownBSS), (int)GFP_ATOMIC); for (ii = 0; ii < MAX_BSS_NUM; ii++) {
for (jj = 0; jj < MAX_BSS_NUM - ii - 1; jj++) {
if (ptempBSS == NULL) { if ((pMgmt->sBSSList[jj].bActive != TRUE)
|| ((pMgmt->sBSSList[jj].uRSSI > pMgmt->sBSSList[jj + 1].uRSSI)
printk("bubble sort kmalloc memory fail@@@\n"); && (pMgmt->sBSSList[jj + 1].bActive != FALSE))) {
memcpy(ptempBSS,&pMgmt->sBSSList[jj], sizeof(KnownBSS));
ret = -ENOMEM; memcpy(&pMgmt->sBSSList[jj], &pMgmt->sBSSList[jj + 1],
sizeof(KnownBSS));
return ret; memcpy(&pMgmt->sBSSList[jj + 1], ptempBSS, sizeof(KnownBSS));
}
} }
}
for (ii = 0; ii < MAX_BSS_NUM; ii++) { kfree(ptempBSS);
for (jj = 0; jj < MAX_BSS_NUM - ii - 1; jj++) {
if ((pMgmt->sBSSList[jj].bActive != TRUE) ||
((pMgmt->sBSSList[jj].uRSSI>pMgmt->sBSSList[jj+1].uRSSI) &&(pMgmt->sBSSList[jj+1].bActive!=FALSE))) {
memcpy(ptempBSS,&pMgmt->sBSSList[jj],sizeof(KnownBSS));
memcpy(&pMgmt->sBSSList[jj],&pMgmt->sBSSList[jj+1],sizeof(KnownBSS));
memcpy(&pMgmt->sBSSList[jj+1],ptempBSS,sizeof(KnownBSS));
}
}
}
kfree(ptempBSS);
// printk("bubble sort result:\n");
count = 0; count = 0;
pBSS = &(pMgmt->sBSSList[0]); pBSS = &(pMgmt->sBSSList[0]);
for (ii = 0; ii < MAX_BSS_NUM; ii++) { for (ii = 0; ii < MAX_BSS_NUM; ii++) {
pBSS = &(pMgmt->sBSSList[ii]); pBSS = &(pMgmt->sBSSList[ii]);
if (!pBSS->bActive) if (!pBSS->bActive)
continue; continue;
count++; count++;
} }
pBuf = kcalloc(count, sizeof(struct viawget_scan_result), (int)GFP_ATOMIC); pBuf = kcalloc(count, sizeof(struct viawget_scan_result), GFP_ATOMIC);
if (pBuf == NULL) { if (pBuf == NULL) {
ret = -ENOMEM; ret = -ENOMEM;
return ret; return ret;
} }
scan_buf = (struct viawget_scan_result *)pBuf; scan_buf = (struct viawget_scan_result *)pBuf;
pBSS = &(pMgmt->sBSSList[0]); pBSS = &(pMgmt->sBSSList[0]);
for (ii = 0, jj = 0; ii < MAX_BSS_NUM ; ii++) { for (ii = 0, jj = 0; ii < MAX_BSS_NUM; ii++) {
pBSS = &(pMgmt->sBSSList[ii]); pBSS = &(pMgmt->sBSSList[ii]);
if (pBSS->bActive) { if (pBSS->bActive) {
if (jj >= count) if (jj >= count)
break; break;
memcpy(scan_buf->bssid, pBSS->abyBSSID, WLAN_BSSID_LEN); memcpy(scan_buf->bssid, pBSS->abyBSSID, WLAN_BSSID_LEN);
pItemSSID = (PWLAN_IE_SSID)pBSS->abySSID; pItemSSID = (PWLAN_IE_SSID)pBSS->abySSID;
memcpy(scan_buf->ssid, pItemSSID->abySSID, pItemSSID->len); memcpy(scan_buf->ssid, pItemSSID->abySSID, pItemSSID->len);
scan_buf->ssid_len = pItemSSID->len; scan_buf->ssid_len = pItemSSID->len;
scan_buf->freq = frequency_list[pBSS->uChannel-1]; scan_buf->freq = frequency_list[pBSS->uChannel-1];
scan_buf->caps = pBSS->wCapInfo; //DavidWang for sharemode scan_buf->caps = pBSS->wCapInfo; // DavidWang for sharemode
RFvRSSITodBm(pDevice, (BYTE)(pBSS->uRSSI), &ldBm); RFvRSSITodBm(pDevice, (BYTE)(pBSS->uRSSI), &ldBm);
if(-ldBm<50){ if (-ldBm < 50)
scan_buf->qual = 100; scan_buf->qual = 100;
}else if(-ldBm > 90) { else if (-ldBm > 90)
scan_buf->qual = 0; scan_buf->qual = 0;
}else { else
scan_buf->qual=(40-(-ldBm-50))*100/40; scan_buf->qual=(40-(-ldBm-50))*100/40;
}
//James //James
//scan_buf->caps = pBSS->wCapInfo; //scan_buf->caps = pBSS->wCapInfo;
//scan_buf->qual = //scan_buf->qual =
scan_buf->noise = 0; scan_buf->noise = 0;
scan_buf->level = ldBm; scan_buf->level = ldBm;
//scan_buf->maxrate = //scan_buf->maxrate =
if (pBSS->wWPALen != 0) { if (pBSS->wWPALen != 0) {
scan_buf->wpa_ie_len = pBSS->wWPALen; scan_buf->wpa_ie_len = pBSS->wWPALen;
memcpy(scan_buf->wpa_ie, pBSS->byWPAIE, pBSS->wWPALen); memcpy(scan_buf->wpa_ie, pBSS->byWPAIE, pBSS->wWPALen);
} }
if (pBSS->wRSNLen != 0) { if (pBSS->wRSNLen != 0) {
scan_buf->rsn_ie_len = pBSS->wRSNLen; scan_buf->rsn_ie_len = pBSS->wRSNLen;
memcpy(scan_buf->rsn_ie, pBSS->byRSNIE, pBSS->wRSNLen); memcpy(scan_buf->rsn_ie, pBSS->byRSNIE, pBSS->wRSNLen);
} }
scan_buf = (struct viawget_scan_result *)((PBYTE)scan_buf + sizeof(struct viawget_scan_result)); scan_buf = (struct viawget_scan_result *)((PBYTE)scan_buf + sizeof(struct viawget_scan_result));
jj ++; jj ++;
} }
} }
if (jj < count) if (jj < count)
count = jj; count = jj;
if (copy_to_user(param->u.scan_results.buf, pBuf, sizeof(struct viawget_scan_result) * count)) { if (copy_to_user(param->u.scan_results.buf, pBuf, sizeof(struct viawget_scan_result) * count))
ret = -EFAULT; ret = -EFAULT;
}
param->u.scan_results.scan_count = count; param->u.scan_results.scan_count = count;
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO " param->u.scan_results.scan_count = %d\n", count) DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO " param->u.scan_results.scan_count = %d\n", count);
kfree(pBuf); kfree(pBuf);
return ret; return ret;
} }
/* /*
* Description: * Description:
* set associate with AP * set associate with AP
...@@ -759,25 +672,23 @@ static int wpa_get_scan(PSDevice pDevice, ...@@ -759,25 +672,23 @@ static int wpa_get_scan(PSDevice pDevice,
* Return Value: * Return Value:
* *
*/ */
static int wpa_set_associate(PSDevice pDevice, struct viawget_wpa_param *param)
static int wpa_set_associate(PSDevice pDevice,
struct viawget_wpa_param *param)
{ {
PSMgmtObject pMgmt = &(pDevice->sMgmtObj); PSMgmtObject pMgmt = &pDevice->sMgmtObj;
PWLAN_IE_SSID pItemSSID; PWLAN_IE_SSID pItemSSID;
BYTE abyNullAddr[] = {0x00, 0x00, 0x00, 0x00, 0x00, 0x00}; BYTE abyNullAddr[] = {0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
BYTE abyWPAIE[64]; BYTE abyWPAIE[64];
int ret = 0; int ret = 0;
BOOL bwepEnabled=FALSE; BOOL bwepEnabled=FALSE;
// set key type & algorithm // set key type & algorithm
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "pairwise_suite = %d\n", param->u.wpa_associate.pairwise_suite); DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "pairwise_suite = %d\n", param->u.wpa_associate.pairwise_suite);
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "group_suite = %d\n", param->u.wpa_associate.group_suite); DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "group_suite = %d\n", param->u.wpa_associate.group_suite);
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "key_mgmt_suite = %d\n", param->u.wpa_associate.key_mgmt_suite); DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "key_mgmt_suite = %d\n", param->u.wpa_associate.key_mgmt_suite);
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "auth_alg = %d\n", param->u.wpa_associate.auth_alg); DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "auth_alg = %d\n", param->u.wpa_associate.auth_alg);
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "mode = %d\n", param->u.wpa_associate.mode); DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "mode = %d\n", param->u.wpa_associate.mode);
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "wpa_ie_len = %d\n", param->u.wpa_associate.wpa_ie_len); DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "wpa_ie_len = %d\n", param->u.wpa_associate.wpa_ie_len);
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "Roaming dBm = %d\n", param->u.wpa_associate.roam_dbm); //Davidwang DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "Roaming dBm = %d\n", param->u.wpa_associate.roam_dbm); // Davidwang
if (param->u.wpa_associate.wpa_ie) { if (param->u.wpa_associate.wpa_ie) {
if (param->u.wpa_associate.wpa_ie_len > sizeof(abyWPAIE)) if (param->u.wpa_associate.wpa_ie_len > sizeof(abyWPAIE))
...@@ -789,25 +700,25 @@ static int wpa_set_associate(PSDevice pDevice, ...@@ -789,25 +700,25 @@ static int wpa_set_associate(PSDevice pDevice,
} }
if (param->u.wpa_associate.mode == 1) if (param->u.wpa_associate.mode == 1)
pMgmt->eConfigMode = WMAC_CONFIG_IBSS_STA; pMgmt->eConfigMode = WMAC_CONFIG_IBSS_STA;
else else
pMgmt->eConfigMode = WMAC_CONFIG_ESS_STA; pMgmt->eConfigMode = WMAC_CONFIG_ESS_STA;
// set bssid // set bssid
if (memcmp(param->u.wpa_associate.bssid, &abyNullAddr[0], 6) != 0) if (memcmp(param->u.wpa_associate.bssid, &abyNullAddr[0], 6) != 0)
memcpy(pMgmt->abyDesireBSSID, param->u.wpa_associate.bssid, 6); memcpy(pMgmt->abyDesireBSSID, param->u.wpa_associate.bssid, 6);
// set ssid // set ssid
memset(pMgmt->abyDesireSSID, 0, WLAN_IEHDR_LEN + WLAN_SSID_MAXLEN + 1); memset(pMgmt->abyDesireSSID, 0, WLAN_IEHDR_LEN + WLAN_SSID_MAXLEN + 1);
pItemSSID = (PWLAN_IE_SSID)pMgmt->abyDesireSSID; pItemSSID = (PWLAN_IE_SSID)pMgmt->abyDesireSSID;
pItemSSID->byElementID = WLAN_EID_SSID; pItemSSID->byElementID = WLAN_EID_SSID;
pItemSSID->len = param->u.wpa_associate.ssid_len; pItemSSID->len = param->u.wpa_associate.ssid_len;
memcpy(pItemSSID->abySSID, param->u.wpa_associate.ssid, pItemSSID->len); memcpy(pItemSSID->abySSID, param->u.wpa_associate.ssid, pItemSSID->len);
if (param->u.wpa_associate.wpa_ie_len == 0) { if (param->u.wpa_associate.wpa_ie_len == 0) {
if (param->u.wpa_associate.auth_alg & AUTH_ALG_SHARED_KEY) if (param->u.wpa_associate.auth_alg & AUTH_ALG_SHARED_KEY)
pMgmt->eAuthenMode = WMAC_AUTH_SHAREKEY; pMgmt->eAuthenMode = WMAC_AUTH_SHAREKEY;
else else
pMgmt->eAuthenMode = WMAC_AUTH_OPEN; pMgmt->eAuthenMode = WMAC_AUTH_OPEN;
} else if (abyWPAIE[0] == RSN_INFO_ELEM) { } else if (abyWPAIE[0] == RSN_INFO_ELEM) {
if (param->u.wpa_associate.key_mgmt_suite == KEY_MGMT_PSK) if (param->u.wpa_associate.key_mgmt_suite == KEY_MGMT_PSK)
pMgmt->eAuthenMode = WMAC_AUTH_WPA2PSK; pMgmt->eAuthenMode = WMAC_AUTH_WPA2PSK;
...@@ -817,9 +728,9 @@ static int wpa_set_associate(PSDevice pDevice, ...@@ -817,9 +728,9 @@ static int wpa_set_associate(PSDevice pDevice,
if (param->u.wpa_associate.key_mgmt_suite == KEY_MGMT_WPA_NONE) if (param->u.wpa_associate.key_mgmt_suite == KEY_MGMT_WPA_NONE)
pMgmt->eAuthenMode = WMAC_AUTH_WPANONE; pMgmt->eAuthenMode = WMAC_AUTH_WPANONE;
else if (param->u.wpa_associate.key_mgmt_suite == KEY_MGMT_PSK) else if (param->u.wpa_associate.key_mgmt_suite == KEY_MGMT_PSK)
pMgmt->eAuthenMode = WMAC_AUTH_WPAPSK; pMgmt->eAuthenMode = WMAC_AUTH_WPAPSK;
else else
pMgmt->eAuthenMode = WMAC_AUTH_WPA; pMgmt->eAuthenMode = WMAC_AUTH_WPA;
} }
switch (param->u.wpa_associate.pairwise_suite) { switch (param->u.wpa_associate.pairwise_suite) {
...@@ -833,7 +744,6 @@ static int wpa_set_associate(PSDevice pDevice, ...@@ -833,7 +744,6 @@ static int wpa_set_associate(PSDevice pDevice,
case CIPHER_WEP104: case CIPHER_WEP104:
pDevice->eEncryptionStatus = Ndis802_11Encryption1Enabled; pDevice->eEncryptionStatus = Ndis802_11Encryption1Enabled;
bwepEnabled = TRUE; bwepEnabled = TRUE;
// printk("****************wpa_set_associate:set CIPHER_WEP40_104\n");
break; break;
case CIPHER_NONE: case CIPHER_NONE:
if (param->u.wpa_associate.group_suite == CIPHER_CCMP) if (param->u.wpa_associate.group_suite == CIPHER_CCMP)
...@@ -845,70 +755,64 @@ static int wpa_set_associate(PSDevice pDevice, ...@@ -845,70 +755,64 @@ static int wpa_set_associate(PSDevice pDevice,
pDevice->eEncryptionStatus = Ndis802_11EncryptionDisabled; pDevice->eEncryptionStatus = Ndis802_11EncryptionDisabled;
} }
pMgmt->Roam_dbm = param->u.wpa_associate.roam_dbm; pMgmt->Roam_dbm = param->u.wpa_associate.roam_dbm;
// if ((pMgmt->Roam_dbm > 40)&&(pMgmt->Roam_dbm<80)) if (pMgmt->eAuthenMode == WMAC_AUTH_SHAREKEY) { // @wep-sharekey
// pDevice->bEnableRoaming = TRUE; pDevice->eEncryptionStatus = Ndis802_11Encryption1Enabled;
pMgmt->bShareKeyAlgorithm = TRUE;
if (pMgmt->eAuthenMode == WMAC_AUTH_SHAREKEY) { //@wep-sharekey } else if (pMgmt->eAuthenMode == WMAC_AUTH_OPEN) {
pDevice->eEncryptionStatus = Ndis802_11Encryption1Enabled; if(bwepEnabled==TRUE) { //@open-wep
pMgmt->bShareKeyAlgorithm = TRUE; pDevice->eEncryptionStatus = Ndis802_11Encryption1Enabled;
} } else {
else if (pMgmt->eAuthenMode == WMAC_AUTH_OPEN) { // @only open
if(bwepEnabled==TRUE) { //@open-wep pDevice->eEncryptionStatus = Ndis802_11EncryptionDisabled;
pDevice->eEncryptionStatus = Ndis802_11Encryption1Enabled;
}
else { //@only open
pDevice->eEncryptionStatus = Ndis802_11EncryptionDisabled;
} }
} }
//mike save old encryption status // mike save old encryption status
pDevice->eOldEncryptionStatus = pDevice->eEncryptionStatus; pDevice->eOldEncryptionStatus = pDevice->eEncryptionStatus;
if (pDevice->eEncryptionStatus != Ndis802_11EncryptionDisabled) if (pDevice->eEncryptionStatus != Ndis802_11EncryptionDisabled)
pDevice->bEncryptionEnable = TRUE; pDevice->bEncryptionEnable = TRUE;
else else
pDevice->bEncryptionEnable = FALSE; pDevice->bEncryptionEnable = FALSE;
if ((pMgmt->eAuthenMode == WMAC_AUTH_SHAREKEY) ||
((pMgmt->eAuthenMode == WMAC_AUTH_OPEN) && (bwepEnabled==TRUE))) {
//mike re-comment:open-wep && sharekey-wep needn't do initial key!!
}
else
KeyvInitTable(pDevice,&pDevice->sKey);
spin_lock_irq(&pDevice->lock); if ((pMgmt->eAuthenMode == WMAC_AUTH_SHAREKEY) ||
pDevice->bLinkPass = FALSE; ((pMgmt->eAuthenMode == WMAC_AUTH_OPEN) && (bwepEnabled==TRUE))) {
ControlvMaskByte(pDevice,MESSAGE_REQUEST_MACREG,MAC_REG_PAPEDELAY,LEDSTS_STS,LEDSTS_SLOW); // mike re-comment:open-wep && sharekey-wep needn't do initial key!!
memset(pMgmt->abyCurrBSSID, 0, 6); } else {
pMgmt->eCurrState = WMAC_STATE_IDLE; KeyvInitTable(pDevice,&pDevice->sKey);
netif_stop_queue(pDevice->dev); }
/*******search if ap_scan=2 ,which is associating request in hidden ssid mode ****/ spin_lock_irq(&pDevice->lock);
{ pDevice->bLinkPass = FALSE;
PKnownBSS pCurr = NULL; ControlvMaskByte(pDevice, MESSAGE_REQUEST_MACREG, MAC_REG_PAPEDELAY, LEDSTS_STS, LEDSTS_SLOW);
pCurr = BSSpSearchBSSList(pDevice, memset(pMgmt->abyCurrBSSID, 0, 6);
pMgmt->abyDesireBSSID, pMgmt->eCurrState = WMAC_STATE_IDLE;
pMgmt->abyDesireSSID, netif_stop_queue(pDevice->dev);
pDevice->eConfigPHYMode
); /******* search if ap_scan=2, which is associating request in hidden ssid mode ****/
{
if (pCurr == NULL){ PKnownBSS pCurr = NULL;
printk("wpa_set_associate---->hidden mode site survey before associate.......\n"); pCurr = BSSpSearchBSSList(pDevice,
bScheduleCommand((void *) pDevice, pMgmt->abyDesireBSSID,
WLAN_CMD_BSSID_SCAN, pMgmt->abyDesireSSID,
pMgmt->abyDesireSSID); pDevice->eConfigPHYMode
} );
}
if (pCurr == NULL){
printk("wpa_set_associate---->hidden mode site survey before associate.......\n");
bScheduleCommand((void *)pDevice,
WLAN_CMD_BSSID_SCAN,
pMgmt->abyDesireSSID);
}
}
/****************************************************************/ /****************************************************************/
bScheduleCommand((void *) pDevice, WLAN_CMD_SSID, NULL); bScheduleCommand((void *)pDevice, WLAN_CMD_SSID, NULL);
spin_unlock_irq(&pDevice->lock); spin_unlock_irq(&pDevice->lock);
return ret; return ret;
} }
/* /*
* Description: * Description:
* wpa_ioctl main function supported for wpa supplicant * wpa_ioctl main function supported for wpa supplicant
...@@ -922,7 +826,6 @@ static int wpa_set_associate(PSDevice pDevice, ...@@ -922,7 +826,6 @@ static int wpa_set_associate(PSDevice pDevice,
* Return Value: * Return Value:
* *
*/ */
int wpa_ioctl(PSDevice pDevice, struct iw_point *p) int wpa_ioctl(PSDevice pDevice, struct iw_point *p)
{ {
struct viawget_wpa_param *param; struct viawget_wpa_param *param;
...@@ -930,10 +833,10 @@ int wpa_ioctl(PSDevice pDevice, struct iw_point *p) ...@@ -930,10 +833,10 @@ int wpa_ioctl(PSDevice pDevice, struct iw_point *p)
int wpa_ioctl = 0; int wpa_ioctl = 0;
if (p->length < sizeof(struct viawget_wpa_param) || if (p->length < sizeof(struct viawget_wpa_param) ||
p->length > VIAWGET_WPA_MAX_BUF_SIZE || !p->pointer) p->length > VIAWGET_WPA_MAX_BUF_SIZE || !p->pointer)
return -EINVAL; return -EINVAL;
param = kmalloc((int)p->length, (int)GFP_KERNEL); param = kmalloc((int)p->length, GFP_KERNEL);
if (param == NULL) if (param == NULL)
return -ENOMEM; return -ENOMEM;
...@@ -944,63 +847,62 @@ int wpa_ioctl(PSDevice pDevice, struct iw_point *p) ...@@ -944,63 +847,62 @@ int wpa_ioctl(PSDevice pDevice, struct iw_point *p)
switch (param->cmd) { switch (param->cmd) {
case VIAWGET_SET_WPA: case VIAWGET_SET_WPA:
ret = wpa_set_wpa(pDevice, param); ret = wpa_set_wpa(pDevice, param);
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "VIAWGET_SET_WPA \n"); DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "VIAWGET_SET_WPA \n");
break; break;
case VIAWGET_SET_KEY: case VIAWGET_SET_KEY:
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "VIAWGET_SET_KEY \n"); DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "VIAWGET_SET_KEY \n");
spin_lock_irq(&pDevice->lock); spin_lock_irq(&pDevice->lock);
ret = wpa_set_keys(pDevice, param, FALSE); ret = wpa_set_keys(pDevice, param, FALSE);
spin_unlock_irq(&pDevice->lock); spin_unlock_irq(&pDevice->lock);
break; break;
case VIAWGET_SET_SCAN: case VIAWGET_SET_SCAN:
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "VIAWGET_SET_SCAN \n"); DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "VIAWGET_SET_SCAN \n");
ret = wpa_set_scan(pDevice, param); ret = wpa_set_scan(pDevice, param);
break; break;
case VIAWGET_GET_SCAN: case VIAWGET_GET_SCAN:
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "VIAWGET_GET_SCAN\n"); DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "VIAWGET_GET_SCAN\n");
ret = wpa_get_scan(pDevice, param); ret = wpa_get_scan(pDevice, param);
wpa_ioctl = 1; wpa_ioctl = 1;
break; break;
case VIAWGET_GET_SSID: case VIAWGET_GET_SSID:
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "VIAWGET_GET_SSID \n"); DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "VIAWGET_GET_SSID \n");
ret = wpa_get_ssid(pDevice, param); ret = wpa_get_ssid(pDevice, param);
wpa_ioctl = 1; wpa_ioctl = 1;
break; break;
case VIAWGET_GET_BSSID: case VIAWGET_GET_BSSID:
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "VIAWGET_GET_BSSID \n"); DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "VIAWGET_GET_BSSID \n");
ret = wpa_get_bssid(pDevice, param); ret = wpa_get_bssid(pDevice, param);
wpa_ioctl = 1; wpa_ioctl = 1;
break; break;
case VIAWGET_SET_ASSOCIATE: case VIAWGET_SET_ASSOCIATE:
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "VIAWGET_SET_ASSOCIATE \n"); DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "VIAWGET_SET_ASSOCIATE \n");
ret = wpa_set_associate(pDevice, param); ret = wpa_set_associate(pDevice, param);
break; break;
case VIAWGET_SET_DISASSOCIATE: case VIAWGET_SET_DISASSOCIATE:
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "VIAWGET_SET_DISASSOCIATE \n"); DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "VIAWGET_SET_DISASSOCIATE \n");
ret = wpa_set_disassociate(pDevice, param); ret = wpa_set_disassociate(pDevice, param);
break; break;
case VIAWGET_SET_DROP_UNENCRYPT: case VIAWGET_SET_DROP_UNENCRYPT:
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "VIAWGET_SET_DROP_UNENCRYPT \n"); DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "VIAWGET_SET_DROP_UNENCRYPT \n");
break; break;
case VIAWGET_SET_DEAUTHENTICATE: case VIAWGET_SET_DEAUTHENTICATE:
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "VIAWGET_SET_DEAUTHENTICATE \n"); DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "VIAWGET_SET_DEAUTHENTICATE \n");
break; break;
default: default:
DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "wpa_ioctl: unknown cmd=%d\n", DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "wpa_ioctl: unknown cmd=%d\n",
param->cmd); param->cmd);
return -EOPNOTSUPP; return -EOPNOTSUPP;
break;
} }
if ((ret == 0) && wpa_ioctl) { if ((ret == 0) && wpa_ioctl) {
...@@ -1012,7 +914,5 @@ int wpa_ioctl(PSDevice pDevice, struct iw_point *p) ...@@ -1012,7 +914,5 @@ int wpa_ioctl(PSDevice pDevice, struct iw_point *p)
out: out:
kfree(param); kfree(param);
return ret; return ret;
} }
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment