Commit 98b89847 authored by Leo Kim's avatar Leo Kim Committed by Greg Kroah-Hartman

staging: wilc1000: linux_wlan.c: clean up comments

There are over-commenting in the linux_wlan.c file and most of them
are not helpful to explain what the code does and generate 80 ending
line over warnings. So, all of comments and commented codes are removed in
this patch. Comment will be added if necessary with the preferred Linux style.
Signed-off-by: default avatarLeo Kim <leo.kim@atmel.com>
Signed-off-by: default avatarGlen Lee <glen.lee@atmel.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 20fa54e4
...@@ -78,12 +78,6 @@ static struct notifier_block g_dev_notifier = { ...@@ -78,12 +78,6 @@ static struct notifier_block g_dev_notifier = {
#define IRQ_WAIT 1 #define IRQ_WAIT 1
#define IRQ_NO_WAIT 0 #define IRQ_NO_WAIT 0
/*
* to sync between mac_close and module exit.
* don't initialize or de-initialize from init/deinitlocks
* to be initialized from module wilc_netdev_init and
* deinitialized from mdoule_exit
*/
static struct semaphore close_exit_sync; static struct semaphore close_exit_sync;
static int wlan_deinit_locks(struct net_device *dev); static int wlan_deinit_locks(struct net_device *dev);
...@@ -99,11 +93,6 @@ int mac_close(struct net_device *ndev); ...@@ -99,11 +93,6 @@ int mac_close(struct net_device *ndev);
static struct net_device_stats *mac_stats(struct net_device *dev); static struct net_device_stats *mac_stats(struct net_device *dev);
static int mac_ioctl(struct net_device *ndev, struct ifreq *req, int cmd); static int mac_ioctl(struct net_device *ndev, struct ifreq *req, int cmd);
static void wilc_set_multicast_list(struct net_device *dev); static void wilc_set_multicast_list(struct net_device *dev);
/*
* for now - in frmw_to_linux there should be private data to be passed to it
* and this data should be pointer to net device
*/
struct wilc *g_linux_wlan; struct wilc *g_linux_wlan;
bool bEnablePS = true; bool bEnablePS = true;
...@@ -156,15 +145,14 @@ static int dev_state_ev_handler(struct notifier_block *this, unsigned long event ...@@ -156,15 +145,14 @@ static int dev_state_ev_handler(struct notifier_block *this, unsigned long event
return NOTIFY_DONE; return NOTIFY_DONE;
} }
PRINT_INFO(GENERIC_DBG, "dev_state_ev_handler +++\n"); /* tony */ PRINT_INFO(GENERIC_DBG, "dev_state_ev_handler +++\n");
switch (event) { switch (event) {
case NETDEV_UP: case NETDEV_UP:
PRINT_D(GENERIC_DBG, "dev_state_ev_handler event=NETDEV_UP %p\n", dev); /* tony */ PRINT_D(GENERIC_DBG, "dev_state_ev_handler event=NETDEV_UP %p\n", dev);
PRINT_INFO(GENERIC_DBG, "\n ============== IP Address Obtained ===============\n\n"); PRINT_INFO(GENERIC_DBG, "\n ============== IP Address Obtained ===============\n\n");
/*If we are in station mode or client mode*/
if (nic->iftype == STATION_MODE || nic->iftype == CLIENT_MODE) { if (nic->iftype == STATION_MODE || nic->iftype == CLIENT_MODE) {
hif_drv->IFC_UP = 1; hif_drv->IFC_UP = 1;
g_obtainingIP = false; g_obtainingIP = false;
...@@ -186,7 +174,7 @@ static int dev_state_ev_handler(struct notifier_block *this, unsigned long event ...@@ -186,7 +174,7 @@ static int dev_state_ev_handler(struct notifier_block *this, unsigned long event
break; break;
case NETDEV_DOWN: case NETDEV_DOWN:
PRINT_D(GENERIC_DBG, "dev_state_ev_handler event=NETDEV_DOWN %p\n", dev); /* tony */ PRINT_D(GENERIC_DBG, "dev_state_ev_handler event=NETDEV_DOWN %p\n", dev);
PRINT_INFO(GENERIC_DBG, "\n ============== IP Address Released ===============\n\n"); PRINT_INFO(GENERIC_DBG, "\n ============== IP Address Released ===============\n\n");
if (nic->iftype == STATION_MODE || nic->iftype == CLIENT_MODE) { if (nic->iftype == STATION_MODE || nic->iftype == CLIENT_MODE) {
...@@ -211,7 +199,7 @@ static int dev_state_ev_handler(struct notifier_block *this, unsigned long event ...@@ -211,7 +199,7 @@ static int dev_state_ev_handler(struct notifier_block *this, unsigned long event
break; break;
default: default:
PRINT_INFO(GENERIC_DBG, "dev_state_ev_handler event=default\n"); /* tony */ PRINT_INFO(GENERIC_DBG, "dev_state_ev_handler event=default\n");
PRINT_INFO(GENERIC_DBG, "[%s] unknown dev event: %lu\n", dev_iface->ifa_label, event); PRINT_INFO(GENERIC_DBG, "[%s] unknown dev event: %lu\n", dev_iface->ifa_label, event);
break; break;
...@@ -231,7 +219,6 @@ static irqreturn_t isr_uh_routine(int irq, void *user_data) ...@@ -231,7 +219,6 @@ static irqreturn_t isr_uh_routine(int irq, void *user_data)
wilc = nic->wilc; wilc = nic->wilc;
PRINT_D(INT_DBG, "Interrupt received UH\n"); PRINT_D(INT_DBG, "Interrupt received UH\n");
/*While mac is closing cacncel the handling of any interrupts received*/
if (wilc->close) { if (wilc->close) {
PRINT_ER("Driver is CLOSING: Can't handle UH interrupt\n"); PRINT_ER("Driver is CLOSING: Can't handle UH interrupt\n");
return IRQ_HANDLED; return IRQ_HANDLED;
...@@ -248,7 +235,6 @@ irqreturn_t isr_bh_routine(int irq, void *userdata) ...@@ -248,7 +235,6 @@ irqreturn_t isr_bh_routine(int irq, void *userdata)
nic = netdev_priv(userdata); nic = netdev_priv(userdata);
wilc = nic->wilc; wilc = nic->wilc;
/*While mac is closing cacncel the handling of any interrupts received*/
if (wilc->close) { if (wilc->close) {
PRINT_ER("Driver is CLOSING: Can't handle BH interrupt\n"); PRINT_ER("Driver is CLOSING: Can't handle BH interrupt\n");
return IRQ_HANDLED; return IRQ_HANDLED;
...@@ -270,8 +256,6 @@ static int init_irq(struct net_device *dev) ...@@ -270,8 +256,6 @@ static int init_irq(struct net_device *dev)
nic = netdev_priv(dev); nic = netdev_priv(dev);
wl = nic->wilc; wl = nic->wilc;
/*initialize GPIO and register IRQ num*/
/*GPIO request*/
if ((gpio_request(GPIO_NUM, "WILC_INTR") == 0) && if ((gpio_request(GPIO_NUM, "WILC_INTR") == 0) &&
(gpio_direction_input(GPIO_NUM) == 0)) { (gpio_direction_input(GPIO_NUM) == 0)) {
wl->dev_irq_num = gpio_to_irq(GPIO_NUM); wl->dev_irq_num = gpio_to_irq(GPIO_NUM);
...@@ -281,7 +265,7 @@ static int init_irq(struct net_device *dev) ...@@ -281,7 +265,7 @@ static int init_irq(struct net_device *dev)
} }
if ((ret != -1) && (request_threaded_irq(wl->dev_irq_num, isr_uh_routine, isr_bh_routine, if ((ret != -1) && (request_threaded_irq(wl->dev_irq_num, isr_uh_routine, isr_bh_routine,
IRQF_TRIGGER_LOW | IRQF_ONESHOT, /*Without IRQF_ONESHOT the uh will remain kicked in and dont gave a chance to bh*/ IRQF_TRIGGER_LOW | IRQF_ONESHOT,
"WILC_IRQ", dev)) < 0) { "WILC_IRQ", dev)) < 0) {
PRINT_ER("Failed to request IRQ for GPIO: %d\n", GPIO_NUM); PRINT_ER("Failed to request IRQ for GPIO: %d\n", GPIO_NUM);
ret = -1; ret = -1;
...@@ -303,7 +287,6 @@ static void deinit_irq(struct net_device *dev) ...@@ -303,7 +287,6 @@ static void deinit_irq(struct net_device *dev)
wilc = nic->wilc; wilc = nic->wilc;
#if (defined WILC_SPI) || (defined WILC_SDIO_IRQ_GPIO) #if (defined WILC_SPI) || (defined WILC_SDIO_IRQ_GPIO)
/* Deintialize IRQ */
if (&wilc->dev_irq_num != 0) { if (&wilc->dev_irq_num != 0) {
free_irq(wilc->dev_irq_num, wilc); free_irq(wilc->dev_irq_num, wilc);
...@@ -312,9 +295,6 @@ static void deinit_irq(struct net_device *dev) ...@@ -312,9 +295,6 @@ static void deinit_irq(struct net_device *dev)
#endif #endif
} }
/*
* OS functions
*/
void linux_wlan_dbg(u8 *buff) void linux_wlan_dbg(u8 *buff)
{ {
PRINT_D(INIT_DBG, "%d\n", *buff); PRINT_D(INIT_DBG, "%d\n", *buff);
...@@ -334,9 +314,6 @@ int linux_wlan_lock_timeout(void *vp, u32 timeout) ...@@ -334,9 +314,6 @@ int linux_wlan_lock_timeout(void *vp, u32 timeout)
void linux_wlan_mac_indicate(struct wilc *wilc, int flag) void linux_wlan_mac_indicate(struct wilc *wilc, int flag)
{ {
/*I have to do it that way becuase there is no mean to encapsulate device pointer
* as a parameter
*/
int status; int status;
if (flag == WILC_MAC_INDICATE_STATUS) { if (flag == WILC_MAC_INDICATE_STATUS) {
...@@ -348,7 +325,7 @@ void linux_wlan_mac_indicate(struct wilc *wilc, int flag) ...@@ -348,7 +325,7 @@ void linux_wlan_mac_indicate(struct wilc *wilc, int flag)
wilc->mac_status = status; wilc->mac_status = status;
} }
if (wilc->mac_status == WILC_MAC_STATUS_CONNECT) { /* Connect */ if (wilc->mac_status == WILC_MAC_STATUS_CONNECT) {
} }
} else if (flag == WILC_MAC_INDICATE_SCAN) { } else if (flag == WILC_MAC_INDICATE_SCAN) {
PRINT_D(GENERIC_DBG, "Scanning ...\n"); PRINT_D(GENERIC_DBG, "Scanning ...\n");
...@@ -402,7 +379,6 @@ int linux_wlan_set_bssid(struct net_device *wilc_netdev, u8 *pBSSID) ...@@ -402,7 +379,6 @@ int linux_wlan_set_bssid(struct net_device *wilc_netdev, u8 *pBSSID)
return ret; return ret;
} }
/*Function to get number of connected interfaces*/
int linux_wlan_get_num_conn_ifcs(void) int linux_wlan_get_num_conn_ifcs(void)
{ {
u8 i = 0; u8 i = 0;
...@@ -436,16 +412,13 @@ static int linux_wlan_txq_task(void *vp) ...@@ -436,16 +412,13 @@ static int linux_wlan_txq_task(void *vp)
nic = netdev_priv(dev); nic = netdev_priv(dev);
wl = nic->wilc; wl = nic->wilc;
/* inform wilc1000_wlan_init that TXQ task is started. */
up(&wl->txq_thread_started); up(&wl->txq_thread_started);
while (1) { while (1) {
PRINT_D(TX_DBG, "txq_task Taking a nap :)\n"); PRINT_D(TX_DBG, "txq_task Taking a nap :)\n");
down(&wl->txq_event); down(&wl->txq_event);
/* wait_for_completion(&pd->txq_event); */
PRINT_D(TX_DBG, "txq_task Who waked me up :$\n"); PRINT_D(TX_DBG, "txq_task Who waked me up :$\n");
if (wl->close) { if (wl->close) {
/*Unlock the mutex in the mac_close function to indicate the exiting of the TX thread */
up(&wl->txq_thread_started); up(&wl->txq_thread_started);
while (!kthread_should_stop()) while (!kthread_should_stop())
...@@ -460,23 +433,19 @@ static int linux_wlan_txq_task(void *vp) ...@@ -460,23 +433,19 @@ static int linux_wlan_txq_task(void *vp)
#else #else
do { do {
ret = wilc_wlan_handle_txq(dev, &txq_count); ret = wilc_wlan_handle_txq(dev, &txq_count);
if (txq_count < FLOW_CONTROL_LOWER_THRESHOLD /* && netif_queue_stopped(pd->wilc_netdev)*/) { if (txq_count < FLOW_CONTROL_LOWER_THRESHOLD) {
PRINT_D(TX_DBG, "Waking up queue\n"); PRINT_D(TX_DBG, "Waking up queue\n");
/* netif_wake_queue(pd->wilc_netdev); */
if (netif_queue_stopped(wl->vif[0].ndev)) if (netif_queue_stopped(wl->vif[0].ndev))
netif_wake_queue(wl->vif[0].ndev); netif_wake_queue(wl->vif[0].ndev);
if (netif_queue_stopped(wl->vif[1].ndev)) if (netif_queue_stopped(wl->vif[1].ndev))
netif_wake_queue(wl->vif[1].ndev); netif_wake_queue(wl->vif[1].ndev);
} }
if (ret == WILC_TX_ERR_NO_BUF) { /* failed to allocate buffers in chip. */ if (ret == WILC_TX_ERR_NO_BUF) {
do { do {
/* Back off from sending packets for some time. */
/* schedule_timeout will allow RX task to run and free buffers.*/
/* set_current_state(TASK_UNINTERRUPTIBLE); */
/* timeout = schedule_timeout(timeout); */
msleep(TX_BACKOFF_WEIGHT_UNIT_MS << backoff_weight); msleep(TX_BACKOFF_WEIGHT_UNIT_MS << backoff_weight);
} while (/*timeout*/ 0); } while (0);
backoff_weight += TX_BACKOFF_WEIGHT_INCR_STEP; backoff_weight += TX_BACKOFF_WEIGHT_INCR_STEP;
if (backoff_weight > TX_BACKOFF_WEIGHT_MAX) if (backoff_weight > TX_BACKOFF_WEIGHT_MAX)
backoff_weight = TX_BACKOFF_WEIGHT_MAX; backoff_weight = TX_BACKOFF_WEIGHT_MAX;
...@@ -487,8 +456,7 @@ static int linux_wlan_txq_task(void *vp) ...@@ -487,8 +456,7 @@ static int linux_wlan_txq_task(void *vp)
backoff_weight = TX_BACKOFF_WEIGHT_MIN; backoff_weight = TX_BACKOFF_WEIGHT_MIN;
} }
} }
/*TODO: drop packets after a certain time/number of retry count. */ } while (ret == WILC_TX_ERR_NO_BUF && !wl->close);
} while (ret == WILC_TX_ERR_NO_BUF && !wl->close); /* retry sending packets if no more buffers in chip. */
#endif #endif
} }
return 0; return 0;
...@@ -530,9 +498,6 @@ int linux_wlan_get_firmware(struct net_device *dev) ...@@ -530,9 +498,6 @@ int linux_wlan_get_firmware(struct net_device *dev)
goto _fail_; goto _fail_;
} }
/* the firmare should be located in /lib/firmware in
* root file system with the name specified above */
#ifdef WILC_SDIO #ifdef WILC_SDIO
if (request_firmware(&wilc_firmware, firmware, &wilc->wilc_sdio_func->dev) != 0) { if (request_firmware(&wilc_firmware, firmware, &wilc->wilc_sdio_func->dev) != 0) {
PRINT_ER("%s - firmare not available\n", firmware); PRINT_ER("%s - firmare not available\n", firmware);
...@@ -562,7 +527,6 @@ static int linux_wlan_start_firmware(struct net_device *dev) ...@@ -562,7 +527,6 @@ static int linux_wlan_start_firmware(struct net_device *dev)
nic = netdev_priv(dev); nic = netdev_priv(dev);
wilc = nic->wilc; wilc = nic->wilc;
/* start firmware */
PRINT_D(INIT_DBG, "Starting Firmware ...\n"); PRINT_D(INIT_DBG, "Starting Firmware ...\n");
ret = wilc_wlan_start(); ret = wilc_wlan_start();
if (ret < 0) { if (ret < 0) {
...@@ -570,17 +534,12 @@ static int linux_wlan_start_firmware(struct net_device *dev) ...@@ -570,17 +534,12 @@ static int linux_wlan_start_firmware(struct net_device *dev)
goto _fail_; goto _fail_;
} }
/* wait for mac ready */
PRINT_D(INIT_DBG, "Waiting for Firmware to get ready ...\n"); PRINT_D(INIT_DBG, "Waiting for Firmware to get ready ...\n");
ret = linux_wlan_lock_timeout(&wilc->sync_event, 5000); ret = linux_wlan_lock_timeout(&wilc->sync_event, 5000);
if (ret) { if (ret) {
PRINT_D(INIT_DBG, "Firmware start timed out"); PRINT_D(INIT_DBG, "Firmware start timed out");
goto _fail_; goto _fail_;
} }
/*
* TODO: Driver shouoldn't wait forever for firmware to get started -
* in case of timeout this should be handled properly
*/
PRINT_D(INIT_DBG, "Firmware successfully started\n"); PRINT_D(INIT_DBG, "Firmware successfully started\n");
_fail_: _fail_:
...@@ -600,16 +559,12 @@ static int linux_wlan_firmware_download(struct net_device *dev) ...@@ -600,16 +559,12 @@ static int linux_wlan_firmware_download(struct net_device *dev)
ret = -ENOBUFS; ret = -ENOBUFS;
goto _FAIL_; goto _FAIL_;
} }
/**
* do the firmware download
**/
PRINT_D(INIT_DBG, "Downloading Firmware ...\n"); PRINT_D(INIT_DBG, "Downloading Firmware ...\n");
ret = wilc_wlan_firmware_download(wilc->firmware->data, ret = wilc_wlan_firmware_download(wilc->firmware->data,
wilc->firmware->size); wilc->firmware->size);
if (ret < 0) if (ret < 0)
goto _FAIL_; goto _FAIL_;
/* Freeing FW buffer */
PRINT_D(INIT_DBG, "Freeing FW buffer ...\n"); PRINT_D(INIT_DBG, "Freeing FW buffer ...\n");
PRINT_D(INIT_DBG, "Releasing firmware\n"); PRINT_D(INIT_DBG, "Releasing firmware\n");
release_firmware(wilc->firmware); release_firmware(wilc->firmware);
...@@ -620,7 +575,6 @@ static int linux_wlan_firmware_download(struct net_device *dev) ...@@ -620,7 +575,6 @@ static int linux_wlan_firmware_download(struct net_device *dev)
return ret; return ret;
} }
/* startup configuration - could be changed later using iconfig*/
static int linux_wlan_init_test_config(struct net_device *dev, struct wilc *p_nic) static int linux_wlan_init_test_config(struct net_device *dev, struct wilc *p_nic)
{ {
unsigned char c_val[64]; unsigned char c_val[64];
...@@ -644,7 +598,6 @@ static int linux_wlan_init_test_config(struct net_device *dev, struct wilc *p_ni ...@@ -644,7 +598,6 @@ static int linux_wlan_init_test_config(struct net_device *dev, struct wilc *p_ni
if (!wilc_wlan_cfg_set(1, WID_SET_DRV_HANDLER, c_val, 4, 0, 0)) if (!wilc_wlan_cfg_set(1, WID_SET_DRV_HANDLER, c_val, 4, 0, 0))
goto _fail_; goto _fail_;
/*to tell fw that we are going to use PC test - WILC specific*/
c_val[0] = 0; c_val[0] = 0;
if (!wilc_wlan_cfg_set(0, WID_PC_TEST_MODE, c_val, 1, 0, 0)) if (!wilc_wlan_cfg_set(0, WID_PC_TEST_MODE, c_val, 1, 0, 0))
goto _fail_; goto _fail_;
...@@ -653,7 +606,6 @@ static int linux_wlan_init_test_config(struct net_device *dev, struct wilc *p_ni ...@@ -653,7 +606,6 @@ static int linux_wlan_init_test_config(struct net_device *dev, struct wilc *p_ni
if (!wilc_wlan_cfg_set(0, WID_BSS_TYPE, c_val, 1, 0, 0)) if (!wilc_wlan_cfg_set(0, WID_BSS_TYPE, c_val, 1, 0, 0))
goto _fail_; goto _fail_;
/* c_val[0] = RATE_AUTO; */
c_val[0] = RATE_AUTO; c_val[0] = RATE_AUTO;
if (!wilc_wlan_cfg_set(0, WID_CURRENT_TX_RATE, c_val, 1, 0, 0)) if (!wilc_wlan_cfg_set(0, WID_CURRENT_TX_RATE, c_val, 1, 0, 0))
goto _fail_; goto _fail_;
...@@ -682,7 +634,7 @@ static int linux_wlan_init_test_config(struct net_device *dev, struct wilc *p_ni ...@@ -682,7 +634,7 @@ static int linux_wlan_init_test_config(struct net_device *dev, struct wilc *p_ni
if (!wilc_wlan_cfg_set(0, WID_SITE_SURVEY, c_val, 1, 0, 0)) if (!wilc_wlan_cfg_set(0, WID_SITE_SURVEY, c_val, 1, 0, 0))
goto _fail_; goto _fail_;
*((int *)c_val) = 0xffff; /* Never use RTS-CTS */ *((int *)c_val) = 0xffff;
if (!wilc_wlan_cfg_set(0, WID_RTS_THRESHOLD, c_val, 2, 0, 0)) if (!wilc_wlan_cfg_set(0, WID_RTS_THRESHOLD, c_val, 2, 0, 0))
goto _fail_; goto _fail_;
...@@ -690,13 +642,6 @@ static int linux_wlan_init_test_config(struct net_device *dev, struct wilc *p_ni ...@@ -690,13 +642,6 @@ static int linux_wlan_init_test_config(struct net_device *dev, struct wilc *p_ni
if (!wilc_wlan_cfg_set(0, WID_FRAG_THRESHOLD, c_val, 2, 0, 0)) if (!wilc_wlan_cfg_set(0, WID_FRAG_THRESHOLD, c_val, 2, 0, 0))
goto _fail_; goto _fail_;
/* SSID */
/* -------------------------------------------------------------- */
/* Configuration : String with length less than 32 bytes */
/* Values to set : Any string with length less than 32 bytes */
/* ( In BSS Station Set SSID to "" (null string) */
/* to enable Broadcast SSID suppport ) */
/* -------------------------------------------------------------- */
c_val[0] = 0; c_val[0] = 0;
if (!wilc_wlan_cfg_set(0, WID_BCAST_SSID, c_val, 1, 0, 0)) if (!wilc_wlan_cfg_set(0, WID_BCAST_SSID, c_val, 1, 0, 0))
goto _fail_; goto _fail_;
...@@ -709,7 +654,7 @@ static int linux_wlan_init_test_config(struct net_device *dev, struct wilc *p_ni ...@@ -709,7 +654,7 @@ static int linux_wlan_init_test_config(struct net_device *dev, struct wilc *p_ni
if (!wilc_wlan_cfg_set(0, WID_POWER_MANAGEMENT, c_val, 1, 0, 0)) if (!wilc_wlan_cfg_set(0, WID_POWER_MANAGEMENT, c_val, 1, 0, 0))
goto _fail_; goto _fail_;
c_val[0] = NO_ENCRYPT; /* NO_ENCRYPT, 0x79 */ c_val[0] = NO_ENCRYPT;
if (!wilc_wlan_cfg_set(0, WID_11I_MODE, c_val, 1, 0, 0)) if (!wilc_wlan_cfg_set(0, WID_11I_MODE, c_val, 1, 0, 0))
goto _fail_; goto _fail_;
...@@ -717,43 +662,18 @@ static int linux_wlan_init_test_config(struct net_device *dev, struct wilc *p_ni ...@@ -717,43 +662,18 @@ static int linux_wlan_init_test_config(struct net_device *dev, struct wilc *p_ni
if (!wilc_wlan_cfg_set(0, WID_AUTH_TYPE, c_val, 1, 0, 0)) if (!wilc_wlan_cfg_set(0, WID_AUTH_TYPE, c_val, 1, 0, 0))
goto _fail_; goto _fail_;
/* WEP/802 11I Configuration */
/* ------------------------------------------------------------------ */
/* Configuration : WEP Key */
/* Values (0x) : 5 byte for WEP40 and 13 bytes for WEP104 */
/* In case more than 5 bytes are passed on for WEP 40 */
/* only first 5 bytes will be used as the key */
/* ------------------------------------------------------------------ */
strcpy(c_val, "123456790abcdef1234567890"); strcpy(c_val, "123456790abcdef1234567890");
if (!wilc_wlan_cfg_set(0, WID_WEP_KEY_VALUE, c_val, (strlen(c_val) + 1), 0, 0)) if (!wilc_wlan_cfg_set(0, WID_WEP_KEY_VALUE, c_val, (strlen(c_val) + 1), 0, 0))
goto _fail_; goto _fail_;
/* WEP/802 11I Configuration */
/* ------------------------------------------------------------------ */
/* Configuration : AES/TKIP WPA/RSNA Pre-Shared Key */
/* Values to set : Any string with length greater than equal to 8 bytes */
/* and less than 64 bytes */
/* ------------------------------------------------------------------ */
strcpy(c_val, "12345678"); strcpy(c_val, "12345678");
if (!wilc_wlan_cfg_set(0, WID_11I_PSK, c_val, (strlen(c_val)), 0, 0)) if (!wilc_wlan_cfg_set(0, WID_11I_PSK, c_val, (strlen(c_val)), 0, 0))
goto _fail_; goto _fail_;
/* IEEE802.1X Key Configuration */
/* ------------------------------------------------------------------ */
/* Configuration : Radius Server Access Secret Key */
/* Values to set : Any string with length greater than equal to 8 bytes */
/* and less than 65 bytes */
/* ------------------------------------------------------------------ */
strcpy(c_val, "password"); strcpy(c_val, "password");
if (!wilc_wlan_cfg_set(0, WID_1X_KEY, c_val, (strlen(c_val) + 1), 0, 0)) if (!wilc_wlan_cfg_set(0, WID_1X_KEY, c_val, (strlen(c_val) + 1), 0, 0))
goto _fail_; goto _fail_;
/* IEEE802.1X Server Address Configuration */
/* ------------------------------------------------------------------ */
/* Configuration : Radius Server IP Address */
/* Values to set : Any valid IP Address */
/* ------------------------------------------------------------------ */
c_val[0] = 192; c_val[0] = 192;
c_val[1] = 168; c_val[1] = 168;
c_val[2] = 1; c_val[2] = 1;
...@@ -785,12 +705,6 @@ static int linux_wlan_init_test_config(struct net_device *dev, struct wilc *p_ni ...@@ -785,12 +705,6 @@ static int linux_wlan_init_test_config(struct net_device *dev, struct wilc *p_ni
if (!wilc_wlan_cfg_set(0, WID_TX_POWER_LEVEL_11B, c_val, 1, 0, 0)) if (!wilc_wlan_cfg_set(0, WID_TX_POWER_LEVEL_11B, c_val, 1, 0, 0))
goto _fail_; goto _fail_;
/* Beacon Interval */
/* -------------------------------------------------------------------- */
/* Configuration : Sets the beacon interval value */
/* Values to set : Any 16-bit value */
/* -------------------------------------------------------------------- */
*((int *)c_val) = 100; *((int *)c_val) = 100;
if (!wilc_wlan_cfg_set(0, WID_BEACON_INTERVAL, c_val, 2, 0, 0)) if (!wilc_wlan_cfg_set(0, WID_BEACON_INTERVAL, c_val, 2, 0, 0))
goto _fail_; goto _fail_;
...@@ -799,20 +713,10 @@ static int linux_wlan_init_test_config(struct net_device *dev, struct wilc *p_ni ...@@ -799,20 +713,10 @@ static int linux_wlan_init_test_config(struct net_device *dev, struct wilc *p_ni
if (!wilc_wlan_cfg_set(0, WID_REKEY_POLICY, c_val, 1, 0, 0)) if (!wilc_wlan_cfg_set(0, WID_REKEY_POLICY, c_val, 1, 0, 0))
goto _fail_; goto _fail_;
/* Rekey Time (s) (Used only when the Rekey policy is 2 or 4) */
/* -------------------------------------------------------------------- */
/* Configuration : Sets the Rekey Time (s) */
/* Values to set : 32-bit value */
/* -------------------------------------------------------------------- */
*((int *)c_val) = 84600; *((int *)c_val) = 84600;
if (!wilc_wlan_cfg_set(0, WID_REKEY_PERIOD, c_val, 4, 0, 0)) if (!wilc_wlan_cfg_set(0, WID_REKEY_PERIOD, c_val, 4, 0, 0))
goto _fail_; goto _fail_;
/* Rekey Packet Count (in 1000s; used when Rekey Policy is 3) */
/* -------------------------------------------------------------------- */
/* Configuration : Sets Rekey Group Packet count */
/* Values to set : 32-bit Value */
/* -------------------------------------------------------------------- */
*((int *)c_val) = 500; *((int *)c_val) = 500;
if (!wilc_wlan_cfg_set(0, WID_REKEY_PACKET_COUNT, c_val, 4, 0, 0)) if (!wilc_wlan_cfg_set(0, WID_REKEY_PACKET_COUNT, c_val, 4, 0, 0))
goto _fail_; goto _fail_;
...@@ -825,7 +729,7 @@ static int linux_wlan_init_test_config(struct net_device *dev, struct wilc *p_ni ...@@ -825,7 +729,7 @@ static int linux_wlan_init_test_config(struct net_device *dev, struct wilc *p_ni
if (!wilc_wlan_cfg_set(0, WID_11N_ERP_PROT_TYPE, c_val, 1, 0, 0)) if (!wilc_wlan_cfg_set(0, WID_11N_ERP_PROT_TYPE, c_val, 1, 0, 0))
goto _fail_; goto _fail_;
c_val[0] = 1; /* Enable N */ c_val[0] = 1;
if (!wilc_wlan_cfg_set(0, WID_11N_ENABLE, c_val, 1, 0, 0)) if (!wilc_wlan_cfg_set(0, WID_11N_ENABLE, c_val, 1, 0, 0))
goto _fail_; goto _fail_;
...@@ -833,7 +737,7 @@ static int linux_wlan_init_test_config(struct net_device *dev, struct wilc *p_ni ...@@ -833,7 +737,7 @@ static int linux_wlan_init_test_config(struct net_device *dev, struct wilc *p_ni
if (!wilc_wlan_cfg_set(0, WID_11N_OPERATING_MODE, c_val, 1, 0, 0)) if (!wilc_wlan_cfg_set(0, WID_11N_OPERATING_MODE, c_val, 1, 0, 0))
goto _fail_; goto _fail_;
c_val[0] = 1; /* TXOP Prot disable in N mode: No RTS-CTS on TX A-MPDUs to save air-time. */ c_val[0] = 1;
if (!wilc_wlan_cfg_set(0, WID_11N_TXOP_PROT_DISABLE, c_val, 1, 0, 0)) if (!wilc_wlan_cfg_set(0, WID_11N_TXOP_PROT_DISABLE, c_val, 1, 0, 0))
goto _fail_; goto _fail_;
...@@ -842,9 +746,6 @@ static int linux_wlan_init_test_config(struct net_device *dev, struct wilc *p_ni ...@@ -842,9 +746,6 @@ static int linux_wlan_init_test_config(struct net_device *dev, struct wilc *p_ni
if (!wilc_wlan_cfg_set(0, WID_MAC_ADDR, c_val, 6, 0, 0)) if (!wilc_wlan_cfg_set(0, WID_MAC_ADDR, c_val, 6, 0, 0))
goto _fail_; goto _fail_;
/**
* AP only
**/
c_val[0] = DETECT_PROTECT_REPORT; c_val[0] = DETECT_PROTECT_REPORT;
if (!wilc_wlan_cfg_set(0, WID_11N_OBSS_NONHT_DETECTION, c_val, 1, 0, 0)) if (!wilc_wlan_cfg_set(0, WID_11N_OBSS_NONHT_DETECTION, c_val, 1, 0, 0))
goto _fail_; goto _fail_;
...@@ -865,7 +766,7 @@ static int linux_wlan_init_test_config(struct net_device *dev, struct wilc *p_ni ...@@ -865,7 +766,7 @@ static int linux_wlan_init_test_config(struct net_device *dev, struct wilc *p_ni
if (!wilc_wlan_cfg_set(0, WID_11N_CURRENT_TX_MCS, c_val, 1, 0, 0)) if (!wilc_wlan_cfg_set(0, WID_11N_CURRENT_TX_MCS, c_val, 1, 0, 0))
goto _fail_; goto _fail_;
c_val[0] = 1; /* Enable N with immediate block ack. */ c_val[0] = 1;
if (!wilc_wlan_cfg_set(0, WID_11N_IMMEDIATE_BA_ENABLED, c_val, 1, 1, 1)) if (!wilc_wlan_cfg_set(0, WID_11N_IMMEDIATE_BA_ENABLED, c_val, 1, 1, 1))
goto _fail_; goto _fail_;
...@@ -875,7 +776,6 @@ static int linux_wlan_init_test_config(struct net_device *dev, struct wilc *p_ni ...@@ -875,7 +776,6 @@ static int linux_wlan_init_test_config(struct net_device *dev, struct wilc *p_ni
return -1; return -1;
} }
/**************************/
void wilc1000_wlan_deinit(struct net_device *dev) void wilc1000_wlan_deinit(struct net_device *dev)
{ {
perInterface_wlan_t *nic; perInterface_wlan_t *nic;
...@@ -893,7 +793,6 @@ void wilc1000_wlan_deinit(struct net_device *dev) ...@@ -893,7 +793,6 @@ void wilc1000_wlan_deinit(struct net_device *dev)
netdev_info(dev, "Deinitializing wilc1000...\n"); netdev_info(dev, "Deinitializing wilc1000...\n");
#if defined(PLAT_ALLWINNER_A20) || defined(PLAT_ALLWINNER_A23) || defined(PLAT_ALLWINNER_A31) #if defined(PLAT_ALLWINNER_A20) || defined(PLAT_ALLWINNER_A23) || defined(PLAT_ALLWINNER_A31)
/* johnny : remove */
PRINT_D(INIT_DBG, "skip wilc_bus_set_default_speed\n"); PRINT_D(INIT_DBG, "skip wilc_bus_set_default_speed\n");
#else #else
wilc_bus_set_default_speed(); wilc_bus_set_default_speed();
...@@ -928,11 +827,9 @@ void wilc1000_wlan_deinit(struct net_device *dev) ...@@ -928,11 +827,9 @@ void wilc1000_wlan_deinit(struct net_device *dev)
#endif #endif
#endif #endif
/*De-Initialize locks*/
PRINT_D(INIT_DBG, "Deinitializing Locks\n"); PRINT_D(INIT_DBG, "Deinitializing Locks\n");
wlan_deinit_locks(dev); wlan_deinit_locks(dev);
/* announce that wilc1000 is not initialized */
wl->initialized = false; wl->initialized = false;
PRINT_D(INIT_DBG, "wilc1000 deinitialization Done\n"); PRINT_D(INIT_DBG, "wilc1000 deinitialization Done\n");
...@@ -1021,8 +918,6 @@ int wlan_initialize_threads(struct net_device *dev) ...@@ -1021,8 +918,6 @@ int wlan_initialize_threads(struct net_device *dev)
wilc = nic->wilc; wilc = nic->wilc;
PRINT_D(INIT_DBG, "Initializing Threads ...\n"); PRINT_D(INIT_DBG, "Initializing Threads ...\n");
/* create tx task */
PRINT_D(INIT_DBG, "Creating kthread for transmission\n"); PRINT_D(INIT_DBG, "Creating kthread for transmission\n");
wilc->txq_thread = kthread_run(linux_wlan_txq_task, (void *)dev, wilc->txq_thread = kthread_run(linux_wlan_txq_task, (void *)dev,
"K_TXQ_TASK"); "K_TXQ_TASK");
...@@ -1031,13 +926,11 @@ int wlan_initialize_threads(struct net_device *dev) ...@@ -1031,13 +926,11 @@ int wlan_initialize_threads(struct net_device *dev)
ret = -ENOBUFS; ret = -ENOBUFS;
goto _fail_2; goto _fail_2;
} }
/* wait for TXQ task to start. */
down(&wilc->txq_thread_started); down(&wilc->txq_thread_started);
return 0; return 0;
_fail_2: _fail_2:
/*De-Initialize 2nd thread*/
wilc->close = 0; wilc->close = 0;
return ret; return ret;
} }
...@@ -1113,7 +1006,6 @@ int wilc1000_wlan_init(struct net_device *dev, perInterface_wlan_t *p_nic) ...@@ -1113,7 +1006,6 @@ int wilc1000_wlan_init(struct net_device *dev, perInterface_wlan_t *p_nic)
goto _fail_irq_enable_; goto _fail_irq_enable_;
} }
/*Download firmware*/
ret = linux_wlan_firmware_download(dev); ret = linux_wlan_firmware_download(dev);
if (ret < 0) { if (ret < 0) {
PRINT_ER("Failed to download firmware\n"); PRINT_ER("Failed to download firmware\n");
...@@ -1121,7 +1013,6 @@ int wilc1000_wlan_init(struct net_device *dev, perInterface_wlan_t *p_nic) ...@@ -1121,7 +1013,6 @@ int wilc1000_wlan_init(struct net_device *dev, perInterface_wlan_t *p_nic)
goto _fail_irq_enable_; goto _fail_irq_enable_;
} }
/* Start firmware*/
ret = linux_wlan_start_firmware(dev); ret = linux_wlan_start_firmware(dev);
if (ret < 0) { if (ret < 0) {
PRINT_ER("Failed to start firmware\n"); PRINT_ER("Failed to start firmware\n");
...@@ -1141,7 +1032,6 @@ int wilc1000_wlan_init(struct net_device *dev, perInterface_wlan_t *p_nic) ...@@ -1141,7 +1032,6 @@ int wilc1000_wlan_init(struct net_device *dev, perInterface_wlan_t *p_nic)
Firmware_ver[size] = '\0'; Firmware_ver[size] = '\0';
PRINT_D(INIT_DBG, "***** Firmware Ver = %s *******\n", Firmware_ver); PRINT_D(INIT_DBG, "***** Firmware Ver = %s *******\n", Firmware_ver);
} }
/* Initialize firmware with default configuration */
ret = linux_wlan_init_test_config(dev, wl); ret = linux_wlan_init_test_config(dev, wl);
if (ret < 0) { if (ret < 0) {
...@@ -1151,7 +1041,7 @@ int wilc1000_wlan_init(struct net_device *dev, perInterface_wlan_t *p_nic) ...@@ -1151,7 +1041,7 @@ int wilc1000_wlan_init(struct net_device *dev, perInterface_wlan_t *p_nic)
} }
wl->initialized = true; wl->initialized = true;
return 0; /*success*/ return 0;
_fail_fw_start_: _fail_fw_start_:
wilc_wlan_stop(); wilc_wlan_stop();
...@@ -1177,26 +1067,18 @@ int wilc1000_wlan_init(struct net_device *dev, perInterface_wlan_t *p_nic) ...@@ -1177,26 +1067,18 @@ int wilc1000_wlan_init(struct net_device *dev, perInterface_wlan_t *p_nic)
return ret; return ret;
} }
/*
* - this function will be called automatically by OS when module inserted.
*/
int mac_init_fn(struct net_device *ndev) int mac_init_fn(struct net_device *ndev)
{ {
/*Why we do this !!!*/ netif_start_queue(ndev);
netif_start_queue(ndev); /* ma */ netif_stop_queue(ndev);
netif_stop_queue(ndev); /* ma */
return 0; return 0;
} }
/* This fn is called, when this device is setup using ifconfig */
int mac_open(struct net_device *ndev) int mac_open(struct net_device *ndev)
{ {
perInterface_wlan_t *nic; perInterface_wlan_t *nic;
/*No need for setting mac address here anymore,*/
/*Just set it in init_test_config()*/
unsigned char mac_add[ETH_ALEN] = {0}; unsigned char mac_add[ETH_ALEN] = {0};
int ret = 0; int ret = 0;
int i = 0; int i = 0;
...@@ -1223,7 +1105,6 @@ int mac_open(struct net_device *ndev) ...@@ -1223,7 +1105,6 @@ int mac_open(struct net_device *ndev)
return ret; return ret;
} }
/*initialize platform*/
PRINT_D(INIT_DBG, "*** re-init ***\n"); PRINT_D(INIT_DBG, "*** re-init ***\n");
ret = wilc1000_wlan_init(ndev, nic); ret = wilc1000_wlan_init(ndev, nic);
if (ret < 0) { if (ret < 0) {
...@@ -1237,7 +1118,6 @@ int mac_open(struct net_device *ndev) ...@@ -1237,7 +1118,6 @@ int mac_open(struct net_device *ndev)
host_int_get_MacAddress(priv->hWILCWFIDrv, mac_add); host_int_get_MacAddress(priv->hWILCWFIDrv, mac_add);
PRINT_D(INIT_DBG, "Mac address: %pM\n", mac_add); PRINT_D(INIT_DBG, "Mac address: %pM\n", mac_add);
/* loop through the NUM of supported devices and set the MAC address */
for (i = 0; i < wl->vif_num; i++) { for (i = 0; i < wl->vif_num; i++) {
if (ndev == wl->vif[i].ndev) { if (ndev == wl->vif[i].ndev) {
memcpy(wl->vif[i].src_addr, mac_add, ETH_ALEN); memcpy(wl->vif[i].src_addr, mac_add, ETH_ALEN);
...@@ -1246,7 +1126,6 @@ int mac_open(struct net_device *ndev) ...@@ -1246,7 +1126,6 @@ int mac_open(struct net_device *ndev)
} }
} }
/* TODO: get MAC address whenever the source is EPROM - hardcoded and copy it to ndev*/
memcpy(ndev->dev_addr, wl->vif[i].src_addr, ETH_ALEN); memcpy(ndev->dev_addr, wl->vif[i].src_addr, ETH_ALEN);
if (!is_valid_ether_addr(ndev->dev_addr)) { if (!is_valid_ether_addr(ndev->dev_addr)) {
...@@ -1277,7 +1156,6 @@ struct net_device_stats *mac_stats(struct net_device *dev) ...@@ -1277,7 +1156,6 @@ struct net_device_stats *mac_stats(struct net_device *dev)
return &nic->netstats; return &nic->netstats;
} }
/* Setup the multicast filter */
static void wilc_set_multicast_list(struct net_device *dev) static void wilc_set_multicast_list(struct net_device *dev)
{ {
struct netdev_hw_addr *ha; struct netdev_hw_addr *ha;
...@@ -1294,30 +1172,22 @@ static void wilc_set_multicast_list(struct net_device *dev) ...@@ -1294,30 +1172,22 @@ static void wilc_set_multicast_list(struct net_device *dev)
PRINT_D(INIT_DBG, "Setting Multicast List with count = %d.\n", dev->mc.count); PRINT_D(INIT_DBG, "Setting Multicast List with count = %d.\n", dev->mc.count);
if (dev->flags & IFF_PROMISC) { if (dev->flags & IFF_PROMISC) {
/* Normally, we should configure the chip to retrive all packets
* but we don't wanna support this right now */
/* TODO: add promiscuous mode support */
PRINT_D(INIT_DBG, "Set promiscuous mode ON, retrive all packets\n"); PRINT_D(INIT_DBG, "Set promiscuous mode ON, retrive all packets\n");
return; return;
} }
/* If there's more addresses than we handle, get all multicast
* packets and sort them out in software. */
if ((dev->flags & IFF_ALLMULTI) || (dev->mc.count) > WILC_MULTICAST_TABLE_SIZE) { if ((dev->flags & IFF_ALLMULTI) || (dev->mc.count) > WILC_MULTICAST_TABLE_SIZE) {
PRINT_D(INIT_DBG, "Disable multicast filter, retrive all multicast packets\n"); PRINT_D(INIT_DBG, "Disable multicast filter, retrive all multicast packets\n");
/* get all multicast packets */
host_int_setup_multicast_filter(hif_drv, false, 0); host_int_setup_multicast_filter(hif_drv, false, 0);
return; return;
} }
/* No multicast? Just get our own stuff */
if ((dev->mc.count) == 0) { if ((dev->mc.count) == 0) {
PRINT_D(INIT_DBG, "Enable multicast filter, retrive directed packets only.\n"); PRINT_D(INIT_DBG, "Enable multicast filter, retrive directed packets only.\n");
host_int_setup_multicast_filter(hif_drv, true, 0); host_int_setup_multicast_filter(hif_drv, true, 0);
return; return;
} }
/* Store all of the multicast addresses in the hardware filter */
netdev_for_each_mc_addr(ha, dev) netdev_for_each_mc_addr(ha, dev)
{ {
memcpy(multicast_mac_addr_list[i], ha->addr, ETH_ALEN); memcpy(multicast_mac_addr_list[i], ha->addr, ETH_ALEN);
...@@ -1344,7 +1214,6 @@ static void linux_wlan_tx_complete(void *priv, int status) ...@@ -1344,7 +1214,6 @@ static void linux_wlan_tx_complete(void *priv, int status)
PRINT_D(TX_DBG, "Packet sent successfully - Size = %d - Address = %p - SKB = %p\n", pv_data->size, pv_data->buff, pv_data->skb); PRINT_D(TX_DBG, "Packet sent successfully - Size = %d - Address = %p - SKB = %p\n", pv_data->size, pv_data->buff, pv_data->skb);
else else
PRINT_D(TX_DBG, "Couldn't send packet - Size = %d - Address = %p - SKB = %p\n", pv_data->size, pv_data->buff, pv_data->skb); PRINT_D(TX_DBG, "Couldn't send packet - Size = %d - Address = %p - SKB = %p\n", pv_data->size, pv_data->buff, pv_data->skb);
/* Free the SK Buffer, its work is done */
dev_kfree_skb(pv_data->skb); dev_kfree_skb(pv_data->skb);
kfree(pv_data); kfree(pv_data);
} }
...@@ -1364,7 +1233,6 @@ int mac_xmit(struct sk_buff *skb, struct net_device *ndev) ...@@ -1364,7 +1233,6 @@ int mac_xmit(struct sk_buff *skb, struct net_device *ndev)
PRINT_D(TX_DBG, "Sending packet just received from TCP/IP\n"); PRINT_D(TX_DBG, "Sending packet just received from TCP/IP\n");
/* Stop the network interface queue */
if (skb->dev != ndev) { if (skb->dev != ndev) {
PRINT_ER("Packet not destined to this device\n"); PRINT_ER("Packet not destined to this device\n");
return 0; return 0;
...@@ -1386,7 +1254,6 @@ int mac_xmit(struct sk_buff *skb, struct net_device *ndev) ...@@ -1386,7 +1254,6 @@ int mac_xmit(struct sk_buff *skb, struct net_device *ndev)
if (eth_h->h_proto == 0x8e88) if (eth_h->h_proto == 0x8e88)
PRINT_D(INIT_DBG, "EAPOL transmitted\n"); PRINT_D(INIT_DBG, "EAPOL transmitted\n");
/*get source and dest ip addresses*/
ih = (struct iphdr *)(skb->data + sizeof(struct ethhdr)); ih = (struct iphdr *)(skb->data + sizeof(struct ethhdr));
pu8UdpBuffer = (char *)ih + sizeof(struct iphdr); pu8UdpBuffer = (char *)ih + sizeof(struct iphdr);
...@@ -1394,12 +1261,6 @@ int mac_xmit(struct sk_buff *skb, struct net_device *ndev) ...@@ -1394,12 +1261,6 @@ int mac_xmit(struct sk_buff *skb, struct net_device *ndev)
PRINT_D(GENERIC_DBG, "DHCP Message transmitted, type:%x %x %x\n", pu8UdpBuffer[248], pu8UdpBuffer[249], pu8UdpBuffer[250]); PRINT_D(GENERIC_DBG, "DHCP Message transmitted, type:%x %x %x\n", pu8UdpBuffer[248], pu8UdpBuffer[249], pu8UdpBuffer[250]);
PRINT_D(TX_DBG, "Sending packet - Size = %d - Address = %p - SKB = %p\n", tx_data->size, tx_data->buff, tx_data->skb); PRINT_D(TX_DBG, "Sending packet - Size = %d - Address = %p - SKB = %p\n", tx_data->size, tx_data->buff, tx_data->skb);
/* Send packet to MAC HW - for now the tx_complete function will be just status
* indicator. still not sure if I need to suspend host transmission till the tx_complete
* function called or not?
* allocated buffer will be freed in tx_complete function.
*/
PRINT_D(TX_DBG, "Adding tx packet to TX Queue\n"); PRINT_D(TX_DBG, "Adding tx packet to TX Queue\n");
nic->netstats.tx_packets++; nic->netstats.tx_packets++;
nic->netstats.tx_bytes += tx_data->size; nic->netstats.tx_bytes += tx_data->size;
...@@ -1461,7 +1322,6 @@ int mac_close(struct net_device *ndev) ...@@ -1461,7 +1322,6 @@ int mac_close(struct net_device *ndev)
} }
if (nic->wilc_netdev) { if (nic->wilc_netdev) {
/* Stop the network interface queue */
netif_stop_queue(nic->wilc_netdev); netif_stop_queue(nic->wilc_netdev);
wilc_deinit_host_int(nic->wilc_netdev); wilc_deinit_host_int(nic->wilc_netdev);
...@@ -1490,7 +1350,6 @@ int mac_ioctl(struct net_device *ndev, struct ifreq *req, int cmd) ...@@ -1490,7 +1350,6 @@ int mac_ioctl(struct net_device *ndev, struct ifreq *req, int cmd)
s32 s32Error = 0; s32 s32Error = 0;
struct wilc *wilc; struct wilc *wilc;
/* struct iwreq *wrq = (struct iwreq *) req; // tony moved to case SIOCSIWPRIV */
nic = netdev_priv(ndev); nic = netdev_priv(ndev);
wilc = nic->wilc; wilc = nic->wilc;
...@@ -1498,10 +1357,9 @@ int mac_ioctl(struct net_device *ndev, struct ifreq *req, int cmd) ...@@ -1498,10 +1357,9 @@ int mac_ioctl(struct net_device *ndev, struct ifreq *req, int cmd)
return 0; return 0;
switch (cmd) { switch (cmd) {
/* ]] 2013-06-24 */
case SIOCSIWPRIV: case SIOCSIWPRIV:
{ {
struct iwreq *wrq = (struct iwreq *) req; /* added by tony */ struct iwreq *wrq = (struct iwreq *) req;
size = wrq->u.data.length; size = wrq->u.data.length;
...@@ -1517,7 +1375,6 @@ int mac_ioctl(struct net_device *ndev, struct ifreq *req, int cmd) ...@@ -1517,7 +1375,6 @@ int mac_ioctl(struct net_device *ndev, struct ifreq *req, int cmd)
PRINT_ER("Failed to send get rssi param's message queue "); PRINT_ER("Failed to send get rssi param's message queue ");
PRINT_INFO(GENERIC_DBG, "RSSI :%d\n", rssi); PRINT_INFO(GENERIC_DBG, "RSSI :%d\n", rssi);
/*Rounding up the rssi negative value*/
rssi += 5; rssi += 5;
snprintf(buff, size, "rssi %d", rssi); snprintf(buff, size, "rssi %d", rssi);
...@@ -1567,7 +1424,6 @@ void frmw_to_linux(struct wilc *wilc, u8 *buff, u32 size, u32 pkt_offset) ...@@ -1567,7 +1424,6 @@ void frmw_to_linux(struct wilc *wilc, u8 *buff, u32 size, u32 pkt_offset)
frame_len = size; frame_len = size;
buff_to_send = buff; buff_to_send = buff;
/* Need to send the packet up to the host, allocate a skb buffer */
skb = dev_alloc_skb(frame_len); skb = dev_alloc_skb(frame_len);
if (!skb) { if (!skb) {
PRINT_ER("Low memory - packet droped\n"); PRINT_ER("Low memory - packet droped\n");
...@@ -1581,23 +1437,9 @@ void frmw_to_linux(struct wilc *wilc, u8 *buff, u32 size, u32 pkt_offset) ...@@ -1581,23 +1437,9 @@ void frmw_to_linux(struct wilc *wilc, u8 *buff, u32 size, u32 pkt_offset)
if (!skb->dev) if (!skb->dev)
PRINT_ER("skb->dev is NULL\n"); PRINT_ER("skb->dev is NULL\n");
/*
* for(i=0;i<40;i++)
* {
* if(i<frame_len)
* WILC_PRINTF("buff_to_send[%d]=%2x\n",i,buff_to_send[i]);
*
* }*/
/* skb_put(skb, frame_len); */
memcpy(skb_put(skb, frame_len), buff_to_send, frame_len); memcpy(skb_put(skb, frame_len), buff_to_send, frame_len);
/* WILC_PRINTF("After MEM_CPY\n"); */
/* nic = netdev_priv(wilc_netdev); */
skb->protocol = eth_type_trans(skb, wilc_netdev); skb->protocol = eth_type_trans(skb, wilc_netdev);
/* Send the packet to the stack by giving it to the bridge */
nic->netstats.rx_packets++; nic->netstats.rx_packets++;
nic->netstats.rx_bytes += frame_len; nic->netstats.rx_bytes += frame_len;
skb->ip_summed = CHECKSUM_UNNECESSARY; skb->ip_summed = CHECKSUM_UNNECESSARY;
...@@ -1611,8 +1453,6 @@ void WILC_WFI_mgmt_rx(struct wilc *wilc, u8 *buff, u32 size) ...@@ -1611,8 +1453,6 @@ void WILC_WFI_mgmt_rx(struct wilc *wilc, u8 *buff, u32 size)
int i = 0; int i = 0;
perInterface_wlan_t *nic; perInterface_wlan_t *nic;
/*Pass the frame on the monitor interface, if any.*/
/*Otherwise, pass it on p2p0 netdev, if registered on it*/
for (i = 0; i < wilc->vif_num; i++) { for (i = 0; i < wilc->vif_num; i++) {
nic = netdev_priv(wilc->vif[i].ndev); nic = netdev_priv(wilc->vif[i].ndev);
if (nic->monitor_flag) { if (nic->monitor_flag) {
...@@ -1621,7 +1461,7 @@ void WILC_WFI_mgmt_rx(struct wilc *wilc, u8 *buff, u32 size) ...@@ -1621,7 +1461,7 @@ void WILC_WFI_mgmt_rx(struct wilc *wilc, u8 *buff, u32 size)
} }
} }
nic = netdev_priv(wilc->vif[1].ndev); /* p2p0 */ nic = netdev_priv(wilc->vif[1].ndev);
if ((buff[0] == nic->g_struct_frame_reg[0].frame_type && nic->g_struct_frame_reg[0].reg) || if ((buff[0] == nic->g_struct_frame_reg[0].frame_type && nic->g_struct_frame_reg[0].reg) ||
(buff[0] == nic->g_struct_frame_reg[1].frame_type && nic->g_struct_frame_reg[1].reg)) (buff[0] == nic->g_struct_frame_reg[1].frame_type && nic->g_struct_frame_reg[1].reg))
WILC_WFI_p2p_rx(wilc->vif[1].ndev, buff, size); WILC_WFI_p2p_rx(wilc->vif[1].ndev, buff, size);
...@@ -1676,7 +1516,6 @@ int wilc_netdev_init(struct wilc **wilc) ...@@ -1676,7 +1516,6 @@ int wilc_netdev_init(struct wilc **wilc)
sema_init(&close_exit_sync, 0); sema_init(&close_exit_sync, 0);
/*create the common structure*/
g_linux_wlan = kzalloc(sizeof(*g_linux_wlan), GFP_KERNEL); g_linux_wlan = kzalloc(sizeof(*g_linux_wlan), GFP_KERNEL);
if (!g_linux_wlan) if (!g_linux_wlan)
return -ENOMEM; return -ENOMEM;
...@@ -1686,7 +1525,6 @@ int wilc_netdev_init(struct wilc **wilc) ...@@ -1686,7 +1525,6 @@ int wilc_netdev_init(struct wilc **wilc)
register_inetaddr_notifier(&g_dev_notifier); register_inetaddr_notifier(&g_dev_notifier);
for (i = 0; i < NUM_CONCURRENT_IFC; i++) { for (i = 0; i < NUM_CONCURRENT_IFC; i++) {
/*allocate first ethernet device with perinterface_wlan_t as its private data*/
ndev = alloc_etherdev(sizeof(perInterface_wlan_t)); ndev = alloc_etherdev(sizeof(perInterface_wlan_t));
if (!ndev) { if (!ndev) {
PRINT_ER("Failed to allocate ethernet dev\n"); PRINT_ER("Failed to allocate ethernet dev\n");
...@@ -1696,13 +1534,12 @@ int wilc_netdev_init(struct wilc **wilc) ...@@ -1696,13 +1534,12 @@ int wilc_netdev_init(struct wilc **wilc)
nic = netdev_priv(ndev); nic = netdev_priv(ndev);
memset(nic, 0, sizeof(perInterface_wlan_t)); memset(nic, 0, sizeof(perInterface_wlan_t));
/*Name the Devices*/
if (i == 0) { if (i == 0) {
#if defined(NM73131) /* tony, 2012-09-20 */ #if defined(NM73131)
strcpy(ndev->name, "wilc_eth%d"); strcpy(ndev->name, "wilc_eth%d");
#elif defined(PLAT_CLM9722) /* rachel */ #elif defined(PLAT_CLM9722)
strcpy(ndev->name, "eth%d"); strcpy(ndev->name, "eth%d");
#else /* PANDA_BOARD, PLAT_ALLWINNER_A10, PLAT_ALLWINNER_A20, PLAT_ALLWINNER_A31, PLAT_AML8726_M3 or PLAT_WMS8304 */ #else
strcpy(ndev->name, "wlan%d"); strcpy(ndev->name, "wlan%d");
#endif #endif
} else } else
...@@ -1717,11 +1554,9 @@ int wilc_netdev_init(struct wilc **wilc) ...@@ -1717,11 +1554,9 @@ int wilc_netdev_init(struct wilc **wilc)
{ {
struct wireless_dev *wdev; struct wireless_dev *wdev;
/*Register WiFi*/
wdev = wilc_create_wiphy(ndev); wdev = wilc_create_wiphy(ndev);
#ifdef WILC_SDIO #ifdef WILC_SDIO
/* set netdev, tony */
SET_NETDEV_DEV(ndev, &local_sdio_func->dev); SET_NETDEV_DEV(ndev, &local_sdio_func->dev);
#endif #endif
...@@ -1730,7 +1565,6 @@ int wilc_netdev_init(struct wilc **wilc) ...@@ -1730,7 +1565,6 @@ int wilc_netdev_init(struct wilc **wilc)
return -1; return -1;
} }
/*linking the wireless_dev structure with the netdevice*/
nic->wilc_netdev->ieee80211_ptr = wdev; nic->wilc_netdev->ieee80211_ptr = wdev;
nic->wilc_netdev->ml_priv = nic; nic->wilc_netdev->ml_priv = nic;
wdev->netdev = nic->wilc_netdev; wdev->netdev = nic->wilc_netdev;
...@@ -1742,7 +1576,7 @@ int wilc_netdev_init(struct wilc **wilc) ...@@ -1742,7 +1576,7 @@ int wilc_netdev_init(struct wilc **wilc)
if (register_netdev(ndev)) { if (register_netdev(ndev)) {
PRINT_ER("Device couldn't be registered - %s\n", ndev->name); PRINT_ER("Device couldn't be registered - %s\n", ndev->name);
return -1; /* ERROR */ return -1;
} }
nic->iftype = STATION_MODE; nic->iftype = STATION_MODE;
...@@ -1752,7 +1586,7 @@ int wilc_netdev_init(struct wilc **wilc) ...@@ -1752,7 +1586,7 @@ int wilc_netdev_init(struct wilc **wilc)
#ifndef WILC_SDIO #ifndef WILC_SDIO
if (!linux_spi_init(&g_linux_wlan->wilc_spidev)) { if (!linux_spi_init(&g_linux_wlan->wilc_spidev)) {
PRINT_ER("Can't initialize SPI\n"); PRINT_ER("Can't initialize SPI\n");
return -1; /* ERROR */ return -1;
} }
g_linux_wlan->wilc_spidev = wilc_spi_dev; g_linux_wlan->wilc_spidev = wilc_spi_dev;
#else #else
...@@ -1762,7 +1596,6 @@ int wilc_netdev_init(struct wilc **wilc) ...@@ -1762,7 +1596,6 @@ int wilc_netdev_init(struct wilc **wilc)
return 0; return 0;
} }
/*The 1st function called after module inserted*/
static int __init init_wilc_driver(void) static int __init init_wilc_driver(void)
{ {
#ifdef WILC_SPI #ifdef WILC_SPI
......
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