mirror of
https://github.com/torvalds/linux.git
synced 2024-11-18 10:01:43 +00:00
Libertas: cfg80211 support
Holger Schurig's patch (https://patchwork.kernel.org/patch/64286/) is rebased to latest wireless-testing tree. (Includes patches from me originally posted as "libertas: fix build error due to undefined symbol" and "libertas: unmangle capability value". -- JWL) Signed-off-by: Amitkumar Karwar <akarwar@marvell.com> Signed-off-by: Kiran Divekar <dkiran@marvell.com> Tested-by: Amitkumar Karwar <akarwar@marvell.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
This commit is contained in:
parent
f90754c15f
commit
e86dc1ca46
@ -1,4 +1,3 @@
|
|||||||
libertas-y += assoc.o
|
|
||||||
libertas-y += cfg.o
|
libertas-y += cfg.o
|
||||||
libertas-y += cmd.o
|
libertas-y += cmd.o
|
||||||
libertas-y += cmdresp.o
|
libertas-y += cmdresp.o
|
||||||
@ -6,9 +5,7 @@ libertas-y += debugfs.o
|
|||||||
libertas-y += ethtool.o
|
libertas-y += ethtool.o
|
||||||
libertas-y += main.o
|
libertas-y += main.o
|
||||||
libertas-y += rx.o
|
libertas-y += rx.o
|
||||||
libertas-y += scan.o
|
|
||||||
libertas-y += tx.o
|
libertas-y += tx.o
|
||||||
libertas-y += wext.o
|
|
||||||
libertas-$(CONFIG_LIBERTAS_MESH) += mesh.o
|
libertas-$(CONFIG_LIBERTAS_MESH) += mesh.o
|
||||||
|
|
||||||
usb8xxx-objs += if_usb.o
|
usb8xxx-objs += if_usb.o
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -1,155 +0,0 @@
|
|||||||
/* Copyright (C) 2006, Red Hat, Inc. */
|
|
||||||
|
|
||||||
#ifndef _LBS_ASSOC_H_
|
|
||||||
#define _LBS_ASSOC_H_
|
|
||||||
|
|
||||||
|
|
||||||
#include "defs.h"
|
|
||||||
#include "host.h"
|
|
||||||
|
|
||||||
|
|
||||||
struct lbs_private;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* In theory, the IE is limited to the IE length, 255,
|
|
||||||
* but in practice 64 bytes are enough.
|
|
||||||
*/
|
|
||||||
#define MAX_WPA_IE_LEN 64
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
struct lbs_802_11_security {
|
|
||||||
u8 WPAenabled;
|
|
||||||
u8 WPA2enabled;
|
|
||||||
u8 wep_enabled;
|
|
||||||
u8 auth_mode;
|
|
||||||
u32 key_mgmt;
|
|
||||||
};
|
|
||||||
|
|
||||||
/** Current Basic Service Set State Structure */
|
|
||||||
struct current_bss_params {
|
|
||||||
/** bssid */
|
|
||||||
u8 bssid[ETH_ALEN];
|
|
||||||
/** ssid */
|
|
||||||
u8 ssid[IEEE80211_MAX_SSID_LEN + 1];
|
|
||||||
u8 ssid_len;
|
|
||||||
|
|
||||||
/** band */
|
|
||||||
u8 band;
|
|
||||||
/** channel is directly in priv->channel */
|
|
||||||
/** zero-terminated array of supported data rates */
|
|
||||||
u8 rates[MAX_RATES + 1];
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Structure used to store information for each beacon/probe response
|
|
||||||
*/
|
|
||||||
struct bss_descriptor {
|
|
||||||
u8 bssid[ETH_ALEN];
|
|
||||||
|
|
||||||
u8 ssid[IEEE80211_MAX_SSID_LEN + 1];
|
|
||||||
u8 ssid_len;
|
|
||||||
|
|
||||||
u16 capability;
|
|
||||||
u32 rssi;
|
|
||||||
u32 channel;
|
|
||||||
u16 beaconperiod;
|
|
||||||
__le16 atimwindow;
|
|
||||||
|
|
||||||
/* IW_MODE_AUTO, IW_MODE_ADHOC, IW_MODE_INFRA */
|
|
||||||
u8 mode;
|
|
||||||
|
|
||||||
/* zero-terminated array of supported data rates */
|
|
||||||
u8 rates[MAX_RATES + 1];
|
|
||||||
|
|
||||||
unsigned long last_scanned;
|
|
||||||
|
|
||||||
union ieee_phy_param_set phy;
|
|
||||||
union ieee_ss_param_set ss;
|
|
||||||
|
|
||||||
u8 wpa_ie[MAX_WPA_IE_LEN];
|
|
||||||
size_t wpa_ie_len;
|
|
||||||
u8 rsn_ie[MAX_WPA_IE_LEN];
|
|
||||||
size_t rsn_ie_len;
|
|
||||||
|
|
||||||
u8 mesh;
|
|
||||||
|
|
||||||
struct list_head list;
|
|
||||||
};
|
|
||||||
|
|
||||||
/** Association request
|
|
||||||
*
|
|
||||||
* Encapsulates all the options that describe a specific assocation request
|
|
||||||
* or configuration of the wireless card's radio, mode, and security settings.
|
|
||||||
*/
|
|
||||||
struct assoc_request {
|
|
||||||
#define ASSOC_FLAG_SSID 1
|
|
||||||
#define ASSOC_FLAG_CHANNEL 2
|
|
||||||
#define ASSOC_FLAG_BAND 3
|
|
||||||
#define ASSOC_FLAG_MODE 4
|
|
||||||
#define ASSOC_FLAG_BSSID 5
|
|
||||||
#define ASSOC_FLAG_WEP_KEYS 6
|
|
||||||
#define ASSOC_FLAG_WEP_TX_KEYIDX 7
|
|
||||||
#define ASSOC_FLAG_WPA_MCAST_KEY 8
|
|
||||||
#define ASSOC_FLAG_WPA_UCAST_KEY 9
|
|
||||||
#define ASSOC_FLAG_SECINFO 10
|
|
||||||
#define ASSOC_FLAG_WPA_IE 11
|
|
||||||
unsigned long flags;
|
|
||||||
|
|
||||||
u8 ssid[IEEE80211_MAX_SSID_LEN + 1];
|
|
||||||
u8 ssid_len;
|
|
||||||
u8 channel;
|
|
||||||
u8 band;
|
|
||||||
u8 mode;
|
|
||||||
u8 bssid[ETH_ALEN] __attribute__ ((aligned (2)));
|
|
||||||
|
|
||||||
/** WEP keys */
|
|
||||||
struct enc_key wep_keys[4];
|
|
||||||
u16 wep_tx_keyidx;
|
|
||||||
|
|
||||||
/** WPA keys */
|
|
||||||
struct enc_key wpa_mcast_key;
|
|
||||||
struct enc_key wpa_unicast_key;
|
|
||||||
|
|
||||||
struct lbs_802_11_security secinfo;
|
|
||||||
|
|
||||||
/** WPA Information Elements*/
|
|
||||||
u8 wpa_ie[MAX_WPA_IE_LEN];
|
|
||||||
u8 wpa_ie_len;
|
|
||||||
|
|
||||||
/* BSS to associate with for infrastructure of Ad-Hoc join */
|
|
||||||
struct bss_descriptor bss;
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
extern u8 lbs_bg_rates[MAX_RATES];
|
|
||||||
|
|
||||||
void lbs_association_worker(struct work_struct *work);
|
|
||||||
struct assoc_request *lbs_get_association_request(struct lbs_private *priv);
|
|
||||||
|
|
||||||
int lbs_adhoc_stop(struct lbs_private *priv);
|
|
||||||
|
|
||||||
int lbs_cmd_80211_deauthenticate(struct lbs_private *priv,
|
|
||||||
u8 bssid[ETH_ALEN], u16 reason);
|
|
||||||
|
|
||||||
int lbs_cmd_802_11_rssi(struct lbs_private *priv,
|
|
||||||
struct cmd_ds_command *cmd);
|
|
||||||
int lbs_ret_802_11_rssi(struct lbs_private *priv,
|
|
||||||
struct cmd_ds_command *resp);
|
|
||||||
|
|
||||||
int lbs_cmd_bcn_ctrl(struct lbs_private *priv,
|
|
||||||
struct cmd_ds_command *cmd,
|
|
||||||
u16 cmd_action);
|
|
||||||
int lbs_ret_802_11_bcn_ctrl(struct lbs_private *priv,
|
|
||||||
struct cmd_ds_command *resp);
|
|
||||||
|
|
||||||
int lbs_cmd_802_11_set_wep(struct lbs_private *priv, uint16_t cmd_action,
|
|
||||||
struct assoc_request *assoc);
|
|
||||||
|
|
||||||
int lbs_cmd_802_11_enable_rsn(struct lbs_private *priv, uint16_t cmd_action,
|
|
||||||
uint16_t *enable);
|
|
||||||
|
|
||||||
int lbs_cmd_802_11_key_material(struct lbs_private *priv, uint16_t cmd_action,
|
|
||||||
struct assoc_request *assoc);
|
|
||||||
|
|
||||||
#endif /* _LBS_ASSOC_H */
|
|
File diff suppressed because it is too large
Load Diff
@ -1,16 +1,22 @@
|
|||||||
#ifndef __LBS_CFG80211_H__
|
#ifndef __LBS_CFG80211_H__
|
||||||
#define __LBS_CFG80211_H__
|
#define __LBS_CFG80211_H__
|
||||||
|
|
||||||
#include "dev.h"
|
struct device;
|
||||||
|
struct lbs_private;
|
||||||
|
|
||||||
struct wireless_dev *lbs_cfg_alloc(struct device *dev);
|
struct wireless_dev *lbs_cfg_alloc(struct device *dev);
|
||||||
int lbs_cfg_register(struct lbs_private *priv);
|
int lbs_cfg_register(struct lbs_private *priv);
|
||||||
void lbs_cfg_free(struct lbs_private *priv);
|
void lbs_cfg_free(struct lbs_private *priv);
|
||||||
|
|
||||||
int lbs_send_specific_ssid_scan(struct lbs_private *priv, u8 *ssid,
|
/* All of those are TODOs: */
|
||||||
u8 ssid_len);
|
#define lbs_cmd_802_11_rssi(priv, cmdptr) (0)
|
||||||
int lbs_scan_networks(struct lbs_private *priv, int full_scan);
|
#define lbs_ret_802_11_rssi(priv, resp) (0)
|
||||||
void lbs_cfg_scan_worker(struct work_struct *work);
|
#define lbs_cmd_bcn_ctrl(priv, cmdptr, cmd_action) (0)
|
||||||
|
#define lbs_ret_802_11_bcn_ctrl(priv, resp) (0)
|
||||||
|
|
||||||
|
void lbs_send_disconnect_notification(struct lbs_private *priv);
|
||||||
|
void lbs_send_mic_failureevent(struct lbs_private *priv, u32 event);
|
||||||
|
|
||||||
|
void lbs_scan_deinit(struct lbs_private *priv);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -7,13 +7,8 @@
|
|||||||
#include <linux/sched.h>
|
#include <linux/sched.h>
|
||||||
#include <linux/slab.h>
|
#include <linux/slab.h>
|
||||||
|
|
||||||
#include "host.h"
|
|
||||||
#include "decl.h"
|
#include "decl.h"
|
||||||
#include "defs.h"
|
#include "cfg.h"
|
||||||
#include "dev.h"
|
|
||||||
#include "assoc.h"
|
|
||||||
#include "wext.h"
|
|
||||||
#include "scan.h"
|
|
||||||
#include "cmd.h"
|
#include "cmd.h"
|
||||||
|
|
||||||
|
|
||||||
@ -177,11 +172,6 @@ int lbs_update_hw_spec(struct lbs_private *priv)
|
|||||||
if (priv->mesh_dev)
|
if (priv->mesh_dev)
|
||||||
memcpy(priv->mesh_dev->dev_addr, priv->current_addr, ETH_ALEN);
|
memcpy(priv->mesh_dev->dev_addr, priv->current_addr, ETH_ALEN);
|
||||||
|
|
||||||
if (lbs_set_regiontable(priv, priv->regioncode, 0)) {
|
|
||||||
ret = -1;
|
|
||||||
goto out;
|
|
||||||
}
|
|
||||||
|
|
||||||
out:
|
out:
|
||||||
lbs_deb_leave(LBS_DEB_CMD);
|
lbs_deb_leave(LBS_DEB_CMD);
|
||||||
return ret;
|
return ret;
|
||||||
@ -1325,6 +1315,15 @@ int lbs_execute_next_command(struct lbs_private *priv)
|
|||||||
* check if in power save mode, if yes, put the device back
|
* check if in power save mode, if yes, put the device back
|
||||||
* to PS mode
|
* to PS mode
|
||||||
*/
|
*/
|
||||||
|
#ifdef TODO
|
||||||
|
/*
|
||||||
|
* This was the old code for libertas+wext. Someone that
|
||||||
|
* understands this beast should re-code it in a sane way.
|
||||||
|
*
|
||||||
|
* I actually don't understand why this is related to WPA
|
||||||
|
* and to connection status, shouldn't powering should be
|
||||||
|
* independ of such things?
|
||||||
|
*/
|
||||||
if ((priv->psmode != LBS802_11POWERMODECAM) &&
|
if ((priv->psmode != LBS802_11POWERMODECAM) &&
|
||||||
(priv->psstate == PS_STATE_FULL_POWER) &&
|
(priv->psstate == PS_STATE_FULL_POWER) &&
|
||||||
((priv->connect_status == LBS_CONNECTED) ||
|
((priv->connect_status == LBS_CONNECTED) ||
|
||||||
@ -1346,6 +1345,7 @@ int lbs_execute_next_command(struct lbs_private *priv)
|
|||||||
lbs_ps_sleep(priv, 0);
|
lbs_ps_sleep(priv, 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = 0;
|
ret = 0;
|
||||||
|
@ -5,18 +5,10 @@
|
|||||||
#include <linux/slab.h>
|
#include <linux/slab.h>
|
||||||
#include <linux/delay.h>
|
#include <linux/delay.h>
|
||||||
#include <linux/sched.h>
|
#include <linux/sched.h>
|
||||||
#include <linux/if_arp.h>
|
|
||||||
#include <linux/netdevice.h>
|
|
||||||
#include <asm/unaligned.h>
|
#include <asm/unaligned.h>
|
||||||
#include <net/iw_handler.h>
|
#include <net/cfg80211.h>
|
||||||
|
|
||||||
#include "host.h"
|
#include "cfg.h"
|
||||||
#include "decl.h"
|
|
||||||
#include "cmd.h"
|
|
||||||
#include "defs.h"
|
|
||||||
#include "dev.h"
|
|
||||||
#include "assoc.h"
|
|
||||||
#include "wext.h"
|
|
||||||
#include "cmd.h"
|
#include "cmd.h"
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -50,23 +42,8 @@ void lbs_mac_event_disconnected(struct lbs_private *priv)
|
|||||||
priv->currenttxskb = NULL;
|
priv->currenttxskb = NULL;
|
||||||
priv->tx_pending_len = 0;
|
priv->tx_pending_len = 0;
|
||||||
|
|
||||||
/* reset SNR/NF/RSSI values */
|
|
||||||
memset(priv->SNR, 0x00, sizeof(priv->SNR));
|
|
||||||
memset(priv->NF, 0x00, sizeof(priv->NF));
|
|
||||||
memset(priv->RSSI, 0x00, sizeof(priv->RSSI));
|
|
||||||
memset(priv->rawSNR, 0x00, sizeof(priv->rawSNR));
|
|
||||||
memset(priv->rawNF, 0x00, sizeof(priv->rawNF));
|
|
||||||
priv->nextSNRNF = 0;
|
|
||||||
priv->numSNRNF = 0;
|
|
||||||
priv->connect_status = LBS_DISCONNECTED;
|
priv->connect_status = LBS_DISCONNECTED;
|
||||||
|
|
||||||
/* Clear out associated SSID and BSSID since connection is
|
|
||||||
* no longer valid.
|
|
||||||
*/
|
|
||||||
memset(&priv->curbssparams.bssid, 0, ETH_ALEN);
|
|
||||||
memset(&priv->curbssparams.ssid, 0, IEEE80211_MAX_SSID_LEN);
|
|
||||||
priv->curbssparams.ssid_len = 0;
|
|
||||||
|
|
||||||
if (priv->psstate != PS_STATE_FULL_POWER) {
|
if (priv->psstate != PS_STATE_FULL_POWER) {
|
||||||
/* make firmware to exit PS mode */
|
/* make firmware to exit PS mode */
|
||||||
lbs_deb_cmd("disconnected, so exit PS mode\n");
|
lbs_deb_cmd("disconnected, so exit PS mode\n");
|
||||||
@ -262,7 +239,7 @@ int lbs_process_command_response(struct lbs_private *priv, u8 *data, u32 len)
|
|||||||
* ad-hoc mode. It takes place in
|
* ad-hoc mode. It takes place in
|
||||||
* lbs_execute_next_command().
|
* lbs_execute_next_command().
|
||||||
*/
|
*/
|
||||||
if (priv->mode == IW_MODE_ADHOC &&
|
if (priv->wdev->iftype == NL80211_IFTYPE_MONITOR &&
|
||||||
action == CMD_SUBCMD_ENTER_PS)
|
action == CMD_SUBCMD_ENTER_PS)
|
||||||
priv->psmode = LBS802_11POWERMODECAM;
|
priv->psmode = LBS802_11POWERMODECAM;
|
||||||
} else if (action == CMD_SUBCMD_ENTER_PS) {
|
} else if (action == CMD_SUBCMD_ENTER_PS) {
|
||||||
|
@ -1,18 +1,13 @@
|
|||||||
#include <linux/module.h>
|
|
||||||
#include <linux/dcache.h>
|
#include <linux/dcache.h>
|
||||||
#include <linux/debugfs.h>
|
#include <linux/debugfs.h>
|
||||||
#include <linux/delay.h>
|
#include <linux/delay.h>
|
||||||
#include <linux/mm.h>
|
#include <linux/mm.h>
|
||||||
#include <linux/string.h>
|
#include <linux/string.h>
|
||||||
#include <linux/slab.h>
|
#include <linux/slab.h>
|
||||||
#include <net/iw_handler.h>
|
|
||||||
#include <net/lib80211.h>
|
|
||||||
|
|
||||||
#include "dev.h"
|
|
||||||
#include "decl.h"
|
#include "decl.h"
|
||||||
#include "host.h"
|
|
||||||
#include "debugfs.h"
|
|
||||||
#include "cmd.h"
|
#include "cmd.h"
|
||||||
|
#include "debugfs.h"
|
||||||
|
|
||||||
static struct dentry *lbs_dir;
|
static struct dentry *lbs_dir;
|
||||||
static char *szStates[] = {
|
static char *szStates[] = {
|
||||||
@ -60,51 +55,6 @@ static ssize_t lbs_dev_info(struct file *file, char __user *userbuf,
|
|||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static ssize_t lbs_getscantable(struct file *file, char __user *userbuf,
|
|
||||||
size_t count, loff_t *ppos)
|
|
||||||
{
|
|
||||||
struct lbs_private *priv = file->private_data;
|
|
||||||
size_t pos = 0;
|
|
||||||
int numscansdone = 0, res;
|
|
||||||
unsigned long addr = get_zeroed_page(GFP_KERNEL);
|
|
||||||
char *buf = (char *)addr;
|
|
||||||
DECLARE_SSID_BUF(ssid);
|
|
||||||
struct bss_descriptor * iter_bss;
|
|
||||||
if (!buf)
|
|
||||||
return -ENOMEM;
|
|
||||||
|
|
||||||
pos += snprintf(buf+pos, len-pos,
|
|
||||||
"# | ch | rssi | bssid | cap | Qual | SSID\n");
|
|
||||||
|
|
||||||
mutex_lock(&priv->lock);
|
|
||||||
list_for_each_entry (iter_bss, &priv->network_list, list) {
|
|
||||||
u16 ibss = (iter_bss->capability & WLAN_CAPABILITY_IBSS);
|
|
||||||
u16 privacy = (iter_bss->capability & WLAN_CAPABILITY_PRIVACY);
|
|
||||||
u16 spectrum_mgmt = (iter_bss->capability & WLAN_CAPABILITY_SPECTRUM_MGMT);
|
|
||||||
|
|
||||||
pos += snprintf(buf+pos, len-pos, "%02u| %03d | %04d | %pM |",
|
|
||||||
numscansdone, iter_bss->channel, iter_bss->rssi,
|
|
||||||
iter_bss->bssid);
|
|
||||||
pos += snprintf(buf+pos, len-pos, " %04x-", iter_bss->capability);
|
|
||||||
pos += snprintf(buf+pos, len-pos, "%c%c%c |",
|
|
||||||
ibss ? 'A' : 'I', privacy ? 'P' : ' ',
|
|
||||||
spectrum_mgmt ? 'S' : ' ');
|
|
||||||
pos += snprintf(buf+pos, len-pos, " %04d |", SCAN_RSSI(iter_bss->rssi));
|
|
||||||
pos += snprintf(buf+pos, len-pos, " %s\n",
|
|
||||||
print_ssid(ssid, iter_bss->ssid,
|
|
||||||
iter_bss->ssid_len));
|
|
||||||
|
|
||||||
numscansdone++;
|
|
||||||
}
|
|
||||||
mutex_unlock(&priv->lock);
|
|
||||||
|
|
||||||
res = simple_read_from_buffer(userbuf, count, ppos, buf, pos);
|
|
||||||
|
|
||||||
free_page(addr);
|
|
||||||
return res;
|
|
||||||
}
|
|
||||||
|
|
||||||
static ssize_t lbs_sleepparams_write(struct file *file,
|
static ssize_t lbs_sleepparams_write(struct file *file,
|
||||||
const char __user *user_buf, size_t count,
|
const char __user *user_buf, size_t count,
|
||||||
loff_t *ppos)
|
loff_t *ppos)
|
||||||
@ -723,8 +673,6 @@ struct lbs_debugfs_files {
|
|||||||
|
|
||||||
static const struct lbs_debugfs_files debugfs_files[] = {
|
static const struct lbs_debugfs_files debugfs_files[] = {
|
||||||
{ "info", 0444, FOPS(lbs_dev_info, write_file_dummy), },
|
{ "info", 0444, FOPS(lbs_dev_info, write_file_dummy), },
|
||||||
{ "getscantable", 0444, FOPS(lbs_getscantable,
|
|
||||||
write_file_dummy), },
|
|
||||||
{ "sleepparams", 0644, FOPS(lbs_sleepparams_read,
|
{ "sleepparams", 0644, FOPS(lbs_sleepparams_read,
|
||||||
lbs_sleepparams_write), },
|
lbs_sleepparams_write), },
|
||||||
};
|
};
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* This file contains declaration referring to
|
* This file contains declaration referring to
|
||||||
* functions defined in other source files
|
* functions defined in other source files
|
||||||
@ -34,6 +35,8 @@ int lbs_start_card(struct lbs_private *priv);
|
|||||||
void lbs_stop_card(struct lbs_private *priv);
|
void lbs_stop_card(struct lbs_private *priv);
|
||||||
void lbs_host_to_card_done(struct lbs_private *priv);
|
void lbs_host_to_card_done(struct lbs_private *priv);
|
||||||
|
|
||||||
|
int lbs_rtap_supported(struct lbs_private *priv);
|
||||||
|
|
||||||
int lbs_set_mac_address(struct net_device *dev, void *addr);
|
int lbs_set_mac_address(struct net_device *dev, void *addr);
|
||||||
void lbs_set_multicast_list(struct net_device *dev);
|
void lbs_set_multicast_list(struct net_device *dev);
|
||||||
|
|
||||||
|
@ -7,8 +7,8 @@
|
|||||||
#define _LBS_DEV_H_
|
#define _LBS_DEV_H_
|
||||||
|
|
||||||
#include "mesh.h"
|
#include "mesh.h"
|
||||||
#include "scan.h"
|
#include "defs.h"
|
||||||
#include "assoc.h"
|
#include "host.h"
|
||||||
|
|
||||||
#include <linux/kfifo.h>
|
#include <linux/kfifo.h>
|
||||||
|
|
||||||
@ -29,7 +29,6 @@ struct lbs_private {
|
|||||||
/* Basic networking */
|
/* Basic networking */
|
||||||
struct net_device *dev;
|
struct net_device *dev;
|
||||||
u32 connect_status;
|
u32 connect_status;
|
||||||
int infra_open;
|
|
||||||
struct work_struct mcast_work;
|
struct work_struct mcast_work;
|
||||||
u32 nr_of_multicastmacaddr;
|
u32 nr_of_multicastmacaddr;
|
||||||
u8 multicastlist[MRVDRV_MAX_MULTICAST_LIST_SIZE][ETH_ALEN];
|
u8 multicastlist[MRVDRV_MAX_MULTICAST_LIST_SIZE][ETH_ALEN];
|
||||||
@ -37,6 +36,9 @@ struct lbs_private {
|
|||||||
/* CFG80211 */
|
/* CFG80211 */
|
||||||
struct wireless_dev *wdev;
|
struct wireless_dev *wdev;
|
||||||
bool wiphy_registered;
|
bool wiphy_registered;
|
||||||
|
struct cfg80211_scan_request *scan_req;
|
||||||
|
u8 assoc_bss[ETH_ALEN];
|
||||||
|
u8 disassoc_reason;
|
||||||
|
|
||||||
/* Mesh */
|
/* Mesh */
|
||||||
struct net_device *mesh_dev; /* Virtual device */
|
struct net_device *mesh_dev; /* Virtual device */
|
||||||
@ -49,10 +51,6 @@ struct lbs_private {
|
|||||||
u8 mesh_ssid_len;
|
u8 mesh_ssid_len;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Monitor mode */
|
|
||||||
struct net_device *rtap_net_dev;
|
|
||||||
u32 monitormode;
|
|
||||||
|
|
||||||
/* Debugfs */
|
/* Debugfs */
|
||||||
struct dentry *debugfs_dir;
|
struct dentry *debugfs_dir;
|
||||||
struct dentry *debugfs_debug;
|
struct dentry *debugfs_debug;
|
||||||
@ -133,14 +131,10 @@ struct lbs_private {
|
|||||||
struct workqueue_struct *work_thread;
|
struct workqueue_struct *work_thread;
|
||||||
|
|
||||||
/** Encryption stuff */
|
/** Encryption stuff */
|
||||||
struct lbs_802_11_security secinfo;
|
|
||||||
struct enc_key wpa_mcast_key;
|
|
||||||
struct enc_key wpa_unicast_key;
|
|
||||||
u8 wpa_ie[MAX_WPA_IE_LEN];
|
|
||||||
u8 wpa_ie_len;
|
|
||||||
u16 wep_tx_keyidx;
|
|
||||||
struct enc_key wep_keys[4];
|
|
||||||
u8 authtype_auto;
|
u8 authtype_auto;
|
||||||
|
u8 wep_tx_key;
|
||||||
|
u8 wep_key[4][WLAN_KEY_LEN_WEP104];
|
||||||
|
u8 wep_key_len[4];
|
||||||
|
|
||||||
/* Wake On LAN */
|
/* Wake On LAN */
|
||||||
uint32_t wol_criteria;
|
uint32_t wol_criteria;
|
||||||
@ -161,6 +155,7 @@ struct lbs_private {
|
|||||||
/* NIC/link operation characteristics */
|
/* NIC/link operation characteristics */
|
||||||
u16 mac_control;
|
u16 mac_control;
|
||||||
u8 radio_on;
|
u8 radio_on;
|
||||||
|
u8 cur_rate;
|
||||||
u8 channel;
|
u8 channel;
|
||||||
s16 txpower_cur;
|
s16 txpower_cur;
|
||||||
s16 txpower_min;
|
s16 txpower_min;
|
||||||
@ -169,42 +164,6 @@ struct lbs_private {
|
|||||||
/** Scanning */
|
/** Scanning */
|
||||||
struct delayed_work scan_work;
|
struct delayed_work scan_work;
|
||||||
int scan_channel;
|
int scan_channel;
|
||||||
/* remember which channel was scanned last, != 0 if currently scanning */
|
|
||||||
u8 scan_ssid[IEEE80211_MAX_SSID_LEN + 1];
|
|
||||||
u8 scan_ssid_len;
|
|
||||||
|
|
||||||
/* Associating */
|
|
||||||
struct delayed_work assoc_work;
|
|
||||||
struct current_bss_params curbssparams;
|
|
||||||
u8 mode;
|
|
||||||
struct list_head network_list;
|
|
||||||
struct list_head network_free_list;
|
|
||||||
struct bss_descriptor *networks;
|
|
||||||
struct assoc_request * pending_assoc_req;
|
|
||||||
struct assoc_request * in_progress_assoc_req;
|
|
||||||
uint16_t enablehwauto;
|
|
||||||
|
|
||||||
/* ADHOC */
|
|
||||||
u16 beacon_period;
|
|
||||||
u8 beacon_enable;
|
|
||||||
u8 adhoccreate;
|
|
||||||
|
|
||||||
/* WEXT */
|
|
||||||
char name[DEV_NAME_LEN];
|
|
||||||
u8 nodename[16];
|
|
||||||
struct iw_statistics wstats;
|
|
||||||
u8 cur_rate;
|
|
||||||
#define MAX_REGION_CHANNEL_NUM 2
|
|
||||||
struct region_channel region_channel[MAX_REGION_CHANNEL_NUM];
|
|
||||||
|
|
||||||
/** Requested Signal Strength*/
|
|
||||||
u16 SNR[MAX_TYPE_B][MAX_TYPE_AVG];
|
|
||||||
u16 NF[MAX_TYPE_B][MAX_TYPE_AVG];
|
|
||||||
u8 RSSI[MAX_TYPE_B][MAX_TYPE_AVG];
|
|
||||||
u8 rawSNR[DEFAULT_DATA_AVG_FACTOR];
|
|
||||||
u8 rawNF[DEFAULT_DATA_AVG_FACTOR];
|
|
||||||
u16 nextSNRNF;
|
|
||||||
u16 numSNRNF;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
extern struct cmd_confirm_sleep confirm_sleep;
|
extern struct cmd_confirm_sleep confirm_sleep;
|
||||||
|
@ -2,13 +2,8 @@
|
|||||||
#include <linux/ethtool.h>
|
#include <linux/ethtool.h>
|
||||||
#include <linux/delay.h>
|
#include <linux/delay.h>
|
||||||
|
|
||||||
#include "host.h"
|
|
||||||
#include "decl.h"
|
#include "decl.h"
|
||||||
#include "defs.h"
|
|
||||||
#include "dev.h"
|
|
||||||
#include "wext.h"
|
|
||||||
#include "cmd.h"
|
#include "cmd.h"
|
||||||
#include "mesh.h"
|
|
||||||
|
|
||||||
|
|
||||||
static void lbs_ethtool_get_drvinfo(struct net_device *dev,
|
static void lbs_ethtool_get_drvinfo(struct net_device *dev,
|
||||||
|
@ -11,20 +11,14 @@
|
|||||||
#include <linux/if_arp.h>
|
#include <linux/if_arp.h>
|
||||||
#include <linux/kthread.h>
|
#include <linux/kthread.h>
|
||||||
#include <linux/kfifo.h>
|
#include <linux/kfifo.h>
|
||||||
#include <linux/stddef.h>
|
|
||||||
#include <linux/ieee80211.h>
|
|
||||||
#include <linux/slab.h>
|
#include <linux/slab.h>
|
||||||
#include <net/iw_handler.h>
|
|
||||||
#include <net/cfg80211.h>
|
#include <net/cfg80211.h>
|
||||||
|
|
||||||
#include "host.h"
|
#include "host.h"
|
||||||
#include "decl.h"
|
#include "decl.h"
|
||||||
#include "dev.h"
|
#include "dev.h"
|
||||||
#include "wext.h"
|
|
||||||
#include "cfg.h"
|
#include "cfg.h"
|
||||||
#include "debugfs.h"
|
#include "debugfs.h"
|
||||||
#include "scan.h"
|
|
||||||
#include "assoc.h"
|
|
||||||
#include "cmd.h"
|
#include "cmd.h"
|
||||||
|
|
||||||
#define DRIVER_RELEASE_VERSION "323.p0"
|
#define DRIVER_RELEASE_VERSION "323.p0"
|
||||||
@ -96,72 +90,6 @@ u8 lbs_data_rate_to_fw_index(u32 rate)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static int lbs_add_rtap(struct lbs_private *priv);
|
|
||||||
static void lbs_remove_rtap(struct lbs_private *priv);
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get function for sysfs attribute rtap
|
|
||||||
*/
|
|
||||||
static ssize_t lbs_rtap_get(struct device *dev,
|
|
||||||
struct device_attribute *attr, char * buf)
|
|
||||||
{
|
|
||||||
struct lbs_private *priv = to_net_dev(dev)->ml_priv;
|
|
||||||
return snprintf(buf, 5, "0x%X\n", priv->monitormode);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Set function for sysfs attribute rtap
|
|
||||||
*/
|
|
||||||
static ssize_t lbs_rtap_set(struct device *dev,
|
|
||||||
struct device_attribute *attr, const char * buf, size_t count)
|
|
||||||
{
|
|
||||||
int monitor_mode;
|
|
||||||
struct lbs_private *priv = to_net_dev(dev)->ml_priv;
|
|
||||||
|
|
||||||
sscanf(buf, "%x", &monitor_mode);
|
|
||||||
if (monitor_mode) {
|
|
||||||
if (priv->monitormode == monitor_mode)
|
|
||||||
return strlen(buf);
|
|
||||||
if (!priv->monitormode) {
|
|
||||||
if (priv->infra_open || lbs_mesh_open(priv))
|
|
||||||
return -EBUSY;
|
|
||||||
if (priv->mode == IW_MODE_INFRA)
|
|
||||||
lbs_cmd_80211_deauthenticate(priv,
|
|
||||||
priv->curbssparams.bssid,
|
|
||||||
WLAN_REASON_DEAUTH_LEAVING);
|
|
||||||
else if (priv->mode == IW_MODE_ADHOC)
|
|
||||||
lbs_adhoc_stop(priv);
|
|
||||||
lbs_add_rtap(priv);
|
|
||||||
}
|
|
||||||
priv->monitormode = monitor_mode;
|
|
||||||
} else {
|
|
||||||
if (!priv->monitormode)
|
|
||||||
return strlen(buf);
|
|
||||||
priv->monitormode = 0;
|
|
||||||
lbs_remove_rtap(priv);
|
|
||||||
|
|
||||||
if (priv->currenttxskb) {
|
|
||||||
dev_kfree_skb_any(priv->currenttxskb);
|
|
||||||
priv->currenttxskb = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Wake queues, command thread, etc. */
|
|
||||||
lbs_host_to_card_done(priv);
|
|
||||||
}
|
|
||||||
|
|
||||||
lbs_prepare_and_send_command(priv,
|
|
||||||
CMD_802_11_MONITOR_MODE, CMD_ACT_SET,
|
|
||||||
CMD_OPTION_WAITFORRSP, 0, &priv->monitormode);
|
|
||||||
return strlen(buf);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* lbs_rtap attribute to be exported per ethX interface
|
|
||||||
* through sysfs (/sys/class/net/ethX/lbs_rtap)
|
|
||||||
*/
|
|
||||||
static DEVICE_ATTR(lbs_rtap, 0644, lbs_rtap_get, lbs_rtap_set );
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief This function opens the ethX interface
|
* @brief This function opens the ethX interface
|
||||||
*
|
*
|
||||||
@ -177,13 +105,6 @@ static int lbs_dev_open(struct net_device *dev)
|
|||||||
|
|
||||||
spin_lock_irq(&priv->driver_lock);
|
spin_lock_irq(&priv->driver_lock);
|
||||||
|
|
||||||
if (priv->monitormode) {
|
|
||||||
ret = -EBUSY;
|
|
||||||
goto out;
|
|
||||||
}
|
|
||||||
|
|
||||||
priv->infra_open = 1;
|
|
||||||
|
|
||||||
if (priv->connect_status == LBS_CONNECTED)
|
if (priv->connect_status == LBS_CONNECTED)
|
||||||
netif_carrier_on(dev);
|
netif_carrier_on(dev);
|
||||||
else
|
else
|
||||||
@ -191,7 +112,6 @@ static int lbs_dev_open(struct net_device *dev)
|
|||||||
|
|
||||||
if (!priv->tx_pending_len)
|
if (!priv->tx_pending_len)
|
||||||
netif_wake_queue(dev);
|
netif_wake_queue(dev);
|
||||||
out:
|
|
||||||
|
|
||||||
spin_unlock_irq(&priv->driver_lock);
|
spin_unlock_irq(&priv->driver_lock);
|
||||||
lbs_deb_leave_args(LBS_DEB_NET, "ret %d", ret);
|
lbs_deb_leave_args(LBS_DEB_NET, "ret %d", ret);
|
||||||
@ -211,7 +131,6 @@ static int lbs_eth_stop(struct net_device *dev)
|
|||||||
lbs_deb_enter(LBS_DEB_NET);
|
lbs_deb_enter(LBS_DEB_NET);
|
||||||
|
|
||||||
spin_lock_irq(&priv->driver_lock);
|
spin_lock_irq(&priv->driver_lock);
|
||||||
priv->infra_open = 0;
|
|
||||||
netif_stop_queue(dev);
|
netif_stop_queue(dev);
|
||||||
spin_unlock_irq(&priv->driver_lock);
|
spin_unlock_irq(&priv->driver_lock);
|
||||||
|
|
||||||
@ -822,37 +741,16 @@ int lbs_exit_auto_deep_sleep(struct lbs_private *priv)
|
|||||||
|
|
||||||
static int lbs_init_adapter(struct lbs_private *priv)
|
static int lbs_init_adapter(struct lbs_private *priv)
|
||||||
{
|
{
|
||||||
size_t bufsize;
|
int ret;
|
||||||
int i, ret = 0;
|
|
||||||
|
|
||||||
lbs_deb_enter(LBS_DEB_MAIN);
|
lbs_deb_enter(LBS_DEB_MAIN);
|
||||||
|
|
||||||
/* Allocate buffer to store the BSSID list */
|
|
||||||
bufsize = MAX_NETWORK_COUNT * sizeof(struct bss_descriptor);
|
|
||||||
priv->networks = kzalloc(bufsize, GFP_KERNEL);
|
|
||||||
if (!priv->networks) {
|
|
||||||
lbs_pr_err("Out of memory allocating beacons\n");
|
|
||||||
ret = -1;
|
|
||||||
goto out;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Initialize scan result lists */
|
|
||||||
INIT_LIST_HEAD(&priv->network_free_list);
|
|
||||||
INIT_LIST_HEAD(&priv->network_list);
|
|
||||||
for (i = 0; i < MAX_NETWORK_COUNT; i++) {
|
|
||||||
list_add_tail(&priv->networks[i].list,
|
|
||||||
&priv->network_free_list);
|
|
||||||
}
|
|
||||||
|
|
||||||
memset(priv->current_addr, 0xff, ETH_ALEN);
|
memset(priv->current_addr, 0xff, ETH_ALEN);
|
||||||
|
|
||||||
priv->connect_status = LBS_DISCONNECTED;
|
priv->connect_status = LBS_DISCONNECTED;
|
||||||
priv->secinfo.auth_mode = IW_AUTH_ALG_OPEN_SYSTEM;
|
|
||||||
priv->mode = IW_MODE_INFRA;
|
|
||||||
priv->channel = DEFAULT_AD_HOC_CHANNEL;
|
priv->channel = DEFAULT_AD_HOC_CHANNEL;
|
||||||
priv->mac_control = CMD_ACT_MAC_RX_ON | CMD_ACT_MAC_TX_ON;
|
priv->mac_control = CMD_ACT_MAC_RX_ON | CMD_ACT_MAC_TX_ON;
|
||||||
priv->radio_on = 1;
|
priv->radio_on = 1;
|
||||||
priv->enablehwauto = 1;
|
|
||||||
priv->psmode = LBS802_11POWERMODECAM;
|
priv->psmode = LBS802_11POWERMODECAM;
|
||||||
priv->psstate = PS_STATE_FULL_POWER;
|
priv->psstate = PS_STATE_FULL_POWER;
|
||||||
priv->is_deep_sleep = 0;
|
priv->is_deep_sleep = 0;
|
||||||
@ -907,8 +805,6 @@ static void lbs_free_adapter(struct lbs_private *priv)
|
|||||||
kfifo_free(&priv->event_fifo);
|
kfifo_free(&priv->event_fifo);
|
||||||
del_timer(&priv->command_timer);
|
del_timer(&priv->command_timer);
|
||||||
del_timer(&priv->auto_deepsleep_timer);
|
del_timer(&priv->auto_deepsleep_timer);
|
||||||
kfree(priv->networks);
|
|
||||||
priv->networks = NULL;
|
|
||||||
|
|
||||||
lbs_deb_leave(LBS_DEB_MAIN);
|
lbs_deb_leave(LBS_DEB_MAIN);
|
||||||
}
|
}
|
||||||
@ -945,7 +841,7 @@ struct lbs_private *lbs_add_card(void *card, struct device *dmdev)
|
|||||||
lbs_pr_err("cfg80211 init failed\n");
|
lbs_pr_err("cfg80211 init failed\n");
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
/* TODO? */
|
|
||||||
wdev->iftype = NL80211_IFTYPE_STATION;
|
wdev->iftype = NL80211_IFTYPE_STATION;
|
||||||
priv = wdev_priv(wdev);
|
priv = wdev_priv(wdev);
|
||||||
priv->wdev = wdev;
|
priv->wdev = wdev;
|
||||||
@ -955,7 +851,6 @@ struct lbs_private *lbs_add_card(void *card, struct device *dmdev)
|
|||||||
goto err_wdev;
|
goto err_wdev;
|
||||||
}
|
}
|
||||||
|
|
||||||
//TODO? dev = alloc_netdev_mq(0, "wlan%d", ether_setup, IWM_TX_QUEUES);
|
|
||||||
dev = alloc_netdev(0, "wlan%d", ether_setup);
|
dev = alloc_netdev(0, "wlan%d", ether_setup);
|
||||||
if (!dev) {
|
if (!dev) {
|
||||||
dev_err(dmdev, "no memory for network device instance\n");
|
dev_err(dmdev, "no memory for network device instance\n");
|
||||||
@ -971,20 +866,10 @@ struct lbs_private *lbs_add_card(void *card, struct device *dmdev)
|
|||||||
dev->netdev_ops = &lbs_netdev_ops;
|
dev->netdev_ops = &lbs_netdev_ops;
|
||||||
dev->watchdog_timeo = 5 * HZ;
|
dev->watchdog_timeo = 5 * HZ;
|
||||||
dev->ethtool_ops = &lbs_ethtool_ops;
|
dev->ethtool_ops = &lbs_ethtool_ops;
|
||||||
#ifdef WIRELESS_EXT
|
|
||||||
dev->wireless_handlers = &lbs_handler_def;
|
|
||||||
#endif
|
|
||||||
dev->flags |= IFF_BROADCAST | IFF_MULTICAST;
|
dev->flags |= IFF_BROADCAST | IFF_MULTICAST;
|
||||||
|
|
||||||
|
|
||||||
// TODO: kzalloc + iwm_init_default_profile(iwm, iwm->umac_profile); ??
|
|
||||||
|
|
||||||
|
|
||||||
priv->card = card;
|
priv->card = card;
|
||||||
priv->infra_open = 0;
|
|
||||||
|
|
||||||
|
|
||||||
priv->rtap_net_dev = NULL;
|
|
||||||
strcpy(dev->name, "wlan%d");
|
strcpy(dev->name, "wlan%d");
|
||||||
|
|
||||||
lbs_deb_thread("Starting main thread...\n");
|
lbs_deb_thread("Starting main thread...\n");
|
||||||
@ -996,8 +881,6 @@ struct lbs_private *lbs_add_card(void *card, struct device *dmdev)
|
|||||||
}
|
}
|
||||||
|
|
||||||
priv->work_thread = create_singlethread_workqueue("lbs_worker");
|
priv->work_thread = create_singlethread_workqueue("lbs_worker");
|
||||||
INIT_DELAYED_WORK(&priv->assoc_work, lbs_association_worker);
|
|
||||||
INIT_DELAYED_WORK(&priv->scan_work, lbs_scan_worker);
|
|
||||||
INIT_WORK(&priv->mcast_work, lbs_set_mcast_worker);
|
INIT_WORK(&priv->mcast_work, lbs_set_mcast_worker);
|
||||||
|
|
||||||
priv->wol_criteria = 0xffffffff;
|
priv->wol_criteria = 0xffffffff;
|
||||||
@ -1031,12 +914,10 @@ void lbs_remove_card(struct lbs_private *priv)
|
|||||||
lbs_deb_enter(LBS_DEB_MAIN);
|
lbs_deb_enter(LBS_DEB_MAIN);
|
||||||
|
|
||||||
lbs_remove_mesh(priv);
|
lbs_remove_mesh(priv);
|
||||||
lbs_remove_rtap(priv);
|
lbs_scan_deinit(priv);
|
||||||
|
|
||||||
dev = priv->dev;
|
dev = priv->dev;
|
||||||
|
|
||||||
cancel_delayed_work_sync(&priv->scan_work);
|
|
||||||
cancel_delayed_work_sync(&priv->assoc_work);
|
|
||||||
cancel_work_sync(&priv->mcast_work);
|
cancel_work_sync(&priv->mcast_work);
|
||||||
|
|
||||||
/* worker thread destruction blocks on the in-flight command which
|
/* worker thread destruction blocks on the in-flight command which
|
||||||
@ -1077,7 +958,7 @@ void lbs_remove_card(struct lbs_private *priv)
|
|||||||
EXPORT_SYMBOL_GPL(lbs_remove_card);
|
EXPORT_SYMBOL_GPL(lbs_remove_card);
|
||||||
|
|
||||||
|
|
||||||
static int lbs_rtap_supported(struct lbs_private *priv)
|
int lbs_rtap_supported(struct lbs_private *priv)
|
||||||
{
|
{
|
||||||
if (MRVL_FW_MAJOR_REV(priv->fwrelease) == MRVL_FW_V5)
|
if (MRVL_FW_MAJOR_REV(priv->fwrelease) == MRVL_FW_V5)
|
||||||
return 1;
|
return 1;
|
||||||
@ -1109,16 +990,6 @@ int lbs_start_card(struct lbs_private *priv)
|
|||||||
|
|
||||||
lbs_init_mesh(priv);
|
lbs_init_mesh(priv);
|
||||||
|
|
||||||
/*
|
|
||||||
* While rtap isn't related to mesh, only mesh-enabled
|
|
||||||
* firmware implements the rtap functionality via
|
|
||||||
* CMD_802_11_MONITOR_MODE.
|
|
||||||
*/
|
|
||||||
if (lbs_rtap_supported(priv)) {
|
|
||||||
if (device_create_file(&dev->dev, &dev_attr_lbs_rtap))
|
|
||||||
lbs_pr_err("cannot register lbs_rtap attribute\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
lbs_debugfs_init_one(priv, dev);
|
lbs_debugfs_init_one(priv, dev);
|
||||||
|
|
||||||
lbs_pr_info("%s: Marvell WLAN 802.11 adapter\n", dev->name);
|
lbs_pr_info("%s: Marvell WLAN 802.11 adapter\n", dev->name);
|
||||||
@ -1150,9 +1021,6 @@ void lbs_stop_card(struct lbs_private *priv)
|
|||||||
lbs_debugfs_remove_one(priv);
|
lbs_debugfs_remove_one(priv);
|
||||||
lbs_deinit_mesh(priv);
|
lbs_deinit_mesh(priv);
|
||||||
|
|
||||||
if (lbs_rtap_supported(priv))
|
|
||||||
device_remove_file(&dev->dev, &dev_attr_lbs_rtap);
|
|
||||||
|
|
||||||
/* Delete the timeout of the currently processing command */
|
/* Delete the timeout of the currently processing command */
|
||||||
del_timer_sync(&priv->command_timer);
|
del_timer_sync(&priv->command_timer);
|
||||||
del_timer_sync(&priv->auto_deepsleep_timer);
|
del_timer_sync(&priv->auto_deepsleep_timer);
|
||||||
@ -1239,87 +1107,6 @@ static void __exit lbs_exit_module(void)
|
|||||||
lbs_deb_leave(LBS_DEB_MAIN);
|
lbs_deb_leave(LBS_DEB_MAIN);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* rtap interface support fuctions
|
|
||||||
*/
|
|
||||||
|
|
||||||
static int lbs_rtap_open(struct net_device *dev)
|
|
||||||
{
|
|
||||||
/* Yes, _stop_ the queue. Because we don't support injection */
|
|
||||||
lbs_deb_enter(LBS_DEB_MAIN);
|
|
||||||
netif_carrier_off(dev);
|
|
||||||
netif_stop_queue(dev);
|
|
||||||
lbs_deb_leave(LBS_DEB_LEAVE);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int lbs_rtap_stop(struct net_device *dev)
|
|
||||||
{
|
|
||||||
lbs_deb_enter(LBS_DEB_MAIN);
|
|
||||||
lbs_deb_leave(LBS_DEB_MAIN);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static netdev_tx_t lbs_rtap_hard_start_xmit(struct sk_buff *skb,
|
|
||||||
struct net_device *dev)
|
|
||||||
{
|
|
||||||
netif_stop_queue(dev);
|
|
||||||
return NETDEV_TX_BUSY;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void lbs_remove_rtap(struct lbs_private *priv)
|
|
||||||
{
|
|
||||||
lbs_deb_enter(LBS_DEB_MAIN);
|
|
||||||
if (priv->rtap_net_dev == NULL)
|
|
||||||
goto out;
|
|
||||||
unregister_netdev(priv->rtap_net_dev);
|
|
||||||
free_netdev(priv->rtap_net_dev);
|
|
||||||
priv->rtap_net_dev = NULL;
|
|
||||||
out:
|
|
||||||
lbs_deb_leave(LBS_DEB_MAIN);
|
|
||||||
}
|
|
||||||
|
|
||||||
static const struct net_device_ops rtap_netdev_ops = {
|
|
||||||
.ndo_open = lbs_rtap_open,
|
|
||||||
.ndo_stop = lbs_rtap_stop,
|
|
||||||
.ndo_start_xmit = lbs_rtap_hard_start_xmit,
|
|
||||||
};
|
|
||||||
|
|
||||||
static int lbs_add_rtap(struct lbs_private *priv)
|
|
||||||
{
|
|
||||||
int ret = 0;
|
|
||||||
struct net_device *rtap_dev;
|
|
||||||
|
|
||||||
lbs_deb_enter(LBS_DEB_MAIN);
|
|
||||||
if (priv->rtap_net_dev) {
|
|
||||||
ret = -EPERM;
|
|
||||||
goto out;
|
|
||||||
}
|
|
||||||
|
|
||||||
rtap_dev = alloc_netdev(0, "rtap%d", ether_setup);
|
|
||||||
if (rtap_dev == NULL) {
|
|
||||||
ret = -ENOMEM;
|
|
||||||
goto out;
|
|
||||||
}
|
|
||||||
|
|
||||||
memcpy(rtap_dev->dev_addr, priv->current_addr, ETH_ALEN);
|
|
||||||
rtap_dev->type = ARPHRD_IEEE80211_RADIOTAP;
|
|
||||||
rtap_dev->netdev_ops = &rtap_netdev_ops;
|
|
||||||
rtap_dev->ml_priv = priv;
|
|
||||||
SET_NETDEV_DEV(rtap_dev, priv->dev->dev.parent);
|
|
||||||
|
|
||||||
ret = register_netdev(rtap_dev);
|
|
||||||
if (ret) {
|
|
||||||
free_netdev(rtap_dev);
|
|
||||||
goto out;
|
|
||||||
}
|
|
||||||
priv->rtap_net_dev = rtap_dev;
|
|
||||||
|
|
||||||
out:
|
|
||||||
lbs_deb_leave_args(LBS_DEB_MAIN, "ret %d", ret);
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
module_init(lbs_init_module);
|
module_init(lbs_init_module);
|
||||||
module_exit(lbs_exit_module);
|
module_exit(lbs_exit_module);
|
||||||
|
|
||||||
|
@ -5,6 +5,7 @@
|
|||||||
#include <linux/if_arp.h>
|
#include <linux/if_arp.h>
|
||||||
#include <linux/kthread.h>
|
#include <linux/kthread.h>
|
||||||
#include <linux/kfifo.h>
|
#include <linux/kfifo.h>
|
||||||
|
#include <net/cfg80211.h>
|
||||||
|
|
||||||
#include "mesh.h"
|
#include "mesh.h"
|
||||||
#include "decl.h"
|
#include "decl.h"
|
||||||
@ -314,7 +315,7 @@ static int lbs_mesh_dev_open(struct net_device *dev)
|
|||||||
|
|
||||||
spin_lock_irq(&priv->driver_lock);
|
spin_lock_irq(&priv->driver_lock);
|
||||||
|
|
||||||
if (priv->monitormode) {
|
if (priv->wdev->iftype == NL80211_IFTYPE_MONITOR) {
|
||||||
ret = -EBUSY;
|
ret = -EBUSY;
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
@ -369,9 +370,6 @@ int lbs_add_mesh(struct lbs_private *priv)
|
|||||||
|
|
||||||
SET_NETDEV_DEV(priv->mesh_dev, priv->dev->dev.parent);
|
SET_NETDEV_DEV(priv->mesh_dev, priv->dev->dev.parent);
|
||||||
|
|
||||||
#ifdef WIRELESS_EXT
|
|
||||||
mesh_dev->wireless_handlers = &mesh_handler_def;
|
|
||||||
#endif
|
|
||||||
mesh_dev->flags |= IFF_BROADCAST | IFF_MULTICAST;
|
mesh_dev->flags |= IFF_BROADCAST | IFF_MULTICAST;
|
||||||
/* Register virtual mesh interface */
|
/* Register virtual mesh interface */
|
||||||
ret = register_netdev(mesh_dev);
|
ret = register_netdev(mesh_dev);
|
||||||
|
@ -70,11 +70,6 @@ void lbs_persist_config_init(struct net_device *net);
|
|||||||
void lbs_persist_config_remove(struct net_device *net);
|
void lbs_persist_config_remove(struct net_device *net);
|
||||||
|
|
||||||
|
|
||||||
/* WEXT handler */
|
|
||||||
|
|
||||||
extern struct iw_handler_def mesh_handler_def;
|
|
||||||
|
|
||||||
|
|
||||||
/* Ethtool statistics */
|
/* Ethtool statistics */
|
||||||
|
|
||||||
struct ethtool_stats;
|
struct ethtool_stats;
|
||||||
|
@ -4,12 +4,13 @@
|
|||||||
#include <linux/etherdevice.h>
|
#include <linux/etherdevice.h>
|
||||||
#include <linux/slab.h>
|
#include <linux/slab.h>
|
||||||
#include <linux/types.h>
|
#include <linux/types.h>
|
||||||
|
#include <net/cfg80211.h>
|
||||||
|
|
||||||
|
#include "defs.h"
|
||||||
#include "host.h"
|
#include "host.h"
|
||||||
#include "radiotap.h"
|
#include "radiotap.h"
|
||||||
#include "decl.h"
|
#include "decl.h"
|
||||||
#include "dev.h"
|
#include "dev.h"
|
||||||
#include "wext.h"
|
|
||||||
|
|
||||||
struct eth803hdr {
|
struct eth803hdr {
|
||||||
u8 dest_addr[6];
|
u8 dest_addr[6];
|
||||||
@ -38,98 +39,6 @@ struct rx80211packethdr {
|
|||||||
static int process_rxed_802_11_packet(struct lbs_private *priv,
|
static int process_rxed_802_11_packet(struct lbs_private *priv,
|
||||||
struct sk_buff *skb);
|
struct sk_buff *skb);
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief This function computes the avgSNR .
|
|
||||||
*
|
|
||||||
* @param priv A pointer to struct lbs_private structure
|
|
||||||
* @return avgSNR
|
|
||||||
*/
|
|
||||||
static u8 lbs_getavgsnr(struct lbs_private *priv)
|
|
||||||
{
|
|
||||||
u8 i;
|
|
||||||
u16 temp = 0;
|
|
||||||
if (priv->numSNRNF == 0)
|
|
||||||
return 0;
|
|
||||||
for (i = 0; i < priv->numSNRNF; i++)
|
|
||||||
temp += priv->rawSNR[i];
|
|
||||||
return (u8) (temp / priv->numSNRNF);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief This function computes the AvgNF
|
|
||||||
*
|
|
||||||
* @param priv A pointer to struct lbs_private structure
|
|
||||||
* @return AvgNF
|
|
||||||
*/
|
|
||||||
static u8 lbs_getavgnf(struct lbs_private *priv)
|
|
||||||
{
|
|
||||||
u8 i;
|
|
||||||
u16 temp = 0;
|
|
||||||
if (priv->numSNRNF == 0)
|
|
||||||
return 0;
|
|
||||||
for (i = 0; i < priv->numSNRNF; i++)
|
|
||||||
temp += priv->rawNF[i];
|
|
||||||
return (u8) (temp / priv->numSNRNF);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief This function save the raw SNR/NF to our internel buffer
|
|
||||||
*
|
|
||||||
* @param priv A pointer to struct lbs_private structure
|
|
||||||
* @param prxpd A pointer to rxpd structure of received packet
|
|
||||||
* @return n/a
|
|
||||||
*/
|
|
||||||
static void lbs_save_rawSNRNF(struct lbs_private *priv, struct rxpd *p_rx_pd)
|
|
||||||
{
|
|
||||||
if (priv->numSNRNF < DEFAULT_DATA_AVG_FACTOR)
|
|
||||||
priv->numSNRNF++;
|
|
||||||
priv->rawSNR[priv->nextSNRNF] = p_rx_pd->snr;
|
|
||||||
priv->rawNF[priv->nextSNRNF] = p_rx_pd->nf;
|
|
||||||
priv->nextSNRNF++;
|
|
||||||
if (priv->nextSNRNF >= DEFAULT_DATA_AVG_FACTOR)
|
|
||||||
priv->nextSNRNF = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief This function computes the RSSI in received packet.
|
|
||||||
*
|
|
||||||
* @param priv A pointer to struct lbs_private structure
|
|
||||||
* @param prxpd A pointer to rxpd structure of received packet
|
|
||||||
* @return n/a
|
|
||||||
*/
|
|
||||||
static void lbs_compute_rssi(struct lbs_private *priv, struct rxpd *p_rx_pd)
|
|
||||||
{
|
|
||||||
|
|
||||||
lbs_deb_enter(LBS_DEB_RX);
|
|
||||||
|
|
||||||
lbs_deb_rx("rxpd: SNR %d, NF %d\n", p_rx_pd->snr, p_rx_pd->nf);
|
|
||||||
lbs_deb_rx("before computing SNR: SNR-avg = %d, NF-avg = %d\n",
|
|
||||||
priv->SNR[TYPE_RXPD][TYPE_AVG] / AVG_SCALE,
|
|
||||||
priv->NF[TYPE_RXPD][TYPE_AVG] / AVG_SCALE);
|
|
||||||
|
|
||||||
priv->SNR[TYPE_RXPD][TYPE_NOAVG] = p_rx_pd->snr;
|
|
||||||
priv->NF[TYPE_RXPD][TYPE_NOAVG] = p_rx_pd->nf;
|
|
||||||
lbs_save_rawSNRNF(priv, p_rx_pd);
|
|
||||||
|
|
||||||
priv->SNR[TYPE_RXPD][TYPE_AVG] = lbs_getavgsnr(priv) * AVG_SCALE;
|
|
||||||
priv->NF[TYPE_RXPD][TYPE_AVG] = lbs_getavgnf(priv) * AVG_SCALE;
|
|
||||||
lbs_deb_rx("after computing SNR: SNR-avg = %d, NF-avg = %d\n",
|
|
||||||
priv->SNR[TYPE_RXPD][TYPE_AVG] / AVG_SCALE,
|
|
||||||
priv->NF[TYPE_RXPD][TYPE_AVG] / AVG_SCALE);
|
|
||||||
|
|
||||||
priv->RSSI[TYPE_RXPD][TYPE_NOAVG] =
|
|
||||||
CAL_RSSI(priv->SNR[TYPE_RXPD][TYPE_NOAVG],
|
|
||||||
priv->NF[TYPE_RXPD][TYPE_NOAVG]);
|
|
||||||
|
|
||||||
priv->RSSI[TYPE_RXPD][TYPE_AVG] =
|
|
||||||
CAL_RSSI(priv->SNR[TYPE_RXPD][TYPE_AVG] / AVG_SCALE,
|
|
||||||
priv->NF[TYPE_RXPD][TYPE_AVG] / AVG_SCALE);
|
|
||||||
|
|
||||||
lbs_deb_leave(LBS_DEB_RX);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief This function processes received packet and forwards it
|
* @brief This function processes received packet and forwards it
|
||||||
* to kernel/upper layer
|
* to kernel/upper layer
|
||||||
@ -154,7 +63,7 @@ int lbs_process_rxed_packet(struct lbs_private *priv, struct sk_buff *skb)
|
|||||||
|
|
||||||
skb->ip_summed = CHECKSUM_NONE;
|
skb->ip_summed = CHECKSUM_NONE;
|
||||||
|
|
||||||
if (priv->monitormode)
|
if (priv->wdev->iftype == NL80211_IFTYPE_MONITOR)
|
||||||
return process_rxed_802_11_packet(priv, skb);
|
return process_rxed_802_11_packet(priv, skb);
|
||||||
|
|
||||||
p_rx_pd = (struct rxpd *) skb->data;
|
p_rx_pd = (struct rxpd *) skb->data;
|
||||||
@ -225,13 +134,7 @@ int lbs_process_rxed_packet(struct lbs_private *priv, struct sk_buff *skb)
|
|||||||
*/
|
*/
|
||||||
skb_pull(skb, hdrchop);
|
skb_pull(skb, hdrchop);
|
||||||
|
|
||||||
/* Take the data rate from the rxpd structure
|
priv->cur_rate = lbs_fw_index_to_data_rate(p_rx_pd->rx_rate);
|
||||||
* only if the rate is auto
|
|
||||||
*/
|
|
||||||
if (priv->enablehwauto)
|
|
||||||
priv->cur_rate = lbs_fw_index_to_data_rate(p_rx_pd->rx_rate);
|
|
||||||
|
|
||||||
lbs_compute_rssi(priv, p_rx_pd);
|
|
||||||
|
|
||||||
lbs_deb_rx("rx data: size of actual packet %d\n", skb->len);
|
lbs_deb_rx("rx data: size of actual packet %d\n", skb->len);
|
||||||
dev->stats.rx_bytes += skb->len;
|
dev->stats.rx_bytes += skb->len;
|
||||||
@ -352,20 +255,18 @@ static int process_rxed_802_11_packet(struct lbs_private *priv,
|
|||||||
pradiotap_hdr = (void *)skb_push(skb, sizeof(struct rx_radiotap_hdr));
|
pradiotap_hdr = (void *)skb_push(skb, sizeof(struct rx_radiotap_hdr));
|
||||||
memcpy(pradiotap_hdr, &radiotap_hdr, sizeof(struct rx_radiotap_hdr));
|
memcpy(pradiotap_hdr, &radiotap_hdr, sizeof(struct rx_radiotap_hdr));
|
||||||
|
|
||||||
/* Take the data rate from the rxpd structure
|
priv->cur_rate = lbs_fw_index_to_data_rate(prxpd->rx_rate);
|
||||||
* only if the rate is auto
|
|
||||||
*/
|
|
||||||
if (priv->enablehwauto)
|
|
||||||
priv->cur_rate = lbs_fw_index_to_data_rate(prxpd->rx_rate);
|
|
||||||
|
|
||||||
lbs_compute_rssi(priv, prxpd);
|
|
||||||
|
|
||||||
lbs_deb_rx("rx data: size of actual packet %d\n", skb->len);
|
lbs_deb_rx("rx data: size of actual packet %d\n", skb->len);
|
||||||
dev->stats.rx_bytes += skb->len;
|
dev->stats.rx_bytes += skb->len;
|
||||||
dev->stats.rx_packets++;
|
dev->stats.rx_packets++;
|
||||||
|
|
||||||
skb->protocol = eth_type_trans(skb, priv->rtap_net_dev);
|
skb->protocol = eth_type_trans(skb, priv->dev);
|
||||||
netif_rx(skb);
|
|
||||||
|
if (in_interrupt())
|
||||||
|
netif_rx(skb);
|
||||||
|
else
|
||||||
|
netif_rx_ni(skb);
|
||||||
|
|
||||||
ret = 0;
|
ret = 0;
|
||||||
|
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -1,63 +0,0 @@
|
|||||||
/**
|
|
||||||
* Interface for the wlan network scan routines
|
|
||||||
*
|
|
||||||
* Driver interface functions and type declarations for the scan module
|
|
||||||
* implemented in scan.c.
|
|
||||||
*/
|
|
||||||
#ifndef _LBS_SCAN_H
|
|
||||||
#define _LBS_SCAN_H
|
|
||||||
|
|
||||||
#include <net/iw_handler.h>
|
|
||||||
|
|
||||||
struct lbs_private;
|
|
||||||
|
|
||||||
#define MAX_NETWORK_COUNT 128
|
|
||||||
|
|
||||||
/** Chan-freq-TxPower mapping table*/
|
|
||||||
struct chan_freq_power {
|
|
||||||
/** channel Number */
|
|
||||||
u16 channel;
|
|
||||||
/** frequency of this channel */
|
|
||||||
u32 freq;
|
|
||||||
/** Max allowed Tx power level */
|
|
||||||
u16 maxtxpower;
|
|
||||||
/** TRUE:channel unsupported; FLASE:supported*/
|
|
||||||
u8 unsupported;
|
|
||||||
};
|
|
||||||
|
|
||||||
/** region-band mapping table*/
|
|
||||||
struct region_channel {
|
|
||||||
/** TRUE if this entry is valid */
|
|
||||||
u8 valid;
|
|
||||||
/** region code for US, Japan ... */
|
|
||||||
u8 region;
|
|
||||||
/** band B/G/A, used for BAND_CONFIG cmd */
|
|
||||||
u8 band;
|
|
||||||
/** Actual No. of elements in the array below */
|
|
||||||
u8 nrcfp;
|
|
||||||
/** chan-freq-txpower mapping table*/
|
|
||||||
struct chan_freq_power *CFP;
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Maximum number of channels that can be sent in a setuserscan ioctl
|
|
||||||
*/
|
|
||||||
#define LBS_IOCTL_USER_SCAN_CHAN_MAX 50
|
|
||||||
|
|
||||||
int lbs_ssid_cmp(u8 *ssid1, u8 ssid1_len, u8 *ssid2, u8 ssid2_len);
|
|
||||||
|
|
||||||
int lbs_set_regiontable(struct lbs_private *priv, u8 region, u8 band);
|
|
||||||
|
|
||||||
int lbs_send_specific_ssid_scan(struct lbs_private *priv, u8 *ssid,
|
|
||||||
u8 ssid_len);
|
|
||||||
|
|
||||||
int lbs_get_scan(struct net_device *dev, struct iw_request_info *info,
|
|
||||||
struct iw_point *dwrq, char *extra);
|
|
||||||
int lbs_set_scan(struct net_device *dev, struct iw_request_info *info,
|
|
||||||
union iwreq_data *wrqu, char *extra);
|
|
||||||
|
|
||||||
int lbs_scan_networks(struct lbs_private *priv, int full_scan);
|
|
||||||
|
|
||||||
void lbs_scan_worker(struct work_struct *work);
|
|
||||||
|
|
||||||
#endif
|
|
@ -4,13 +4,13 @@
|
|||||||
#include <linux/netdevice.h>
|
#include <linux/netdevice.h>
|
||||||
#include <linux/etherdevice.h>
|
#include <linux/etherdevice.h>
|
||||||
#include <linux/sched.h>
|
#include <linux/sched.h>
|
||||||
|
#include <net/cfg80211.h>
|
||||||
|
|
||||||
#include "host.h"
|
#include "host.h"
|
||||||
#include "radiotap.h"
|
#include "radiotap.h"
|
||||||
#include "decl.h"
|
#include "decl.h"
|
||||||
#include "defs.h"
|
#include "defs.h"
|
||||||
#include "dev.h"
|
#include "dev.h"
|
||||||
#include "wext.h"
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief This function converts Tx/Rx rates from IEEE80211_RADIOTAP_RATE
|
* @brief This function converts Tx/Rx rates from IEEE80211_RADIOTAP_RATE
|
||||||
@ -111,7 +111,7 @@ netdev_tx_t lbs_hard_start_xmit(struct sk_buff *skb, struct net_device *dev)
|
|||||||
p802x_hdr = skb->data;
|
p802x_hdr = skb->data;
|
||||||
pkt_len = skb->len;
|
pkt_len = skb->len;
|
||||||
|
|
||||||
if (dev == priv->rtap_net_dev) {
|
if (priv->wdev->iftype == NL80211_IFTYPE_MONITOR) {
|
||||||
struct tx_radiotap_hdr *rtap_hdr = (void *)skb->data;
|
struct tx_radiotap_hdr *rtap_hdr = (void *)skb->data;
|
||||||
|
|
||||||
/* set txpd fields from the radiotap header */
|
/* set txpd fields from the radiotap header */
|
||||||
@ -147,7 +147,7 @@ netdev_tx_t lbs_hard_start_xmit(struct sk_buff *skb, struct net_device *dev)
|
|||||||
dev->stats.tx_packets++;
|
dev->stats.tx_packets++;
|
||||||
dev->stats.tx_bytes += skb->len;
|
dev->stats.tx_bytes += skb->len;
|
||||||
|
|
||||||
if (priv->monitormode) {
|
if (priv->wdev->iftype == NL80211_IFTYPE_MONITOR) {
|
||||||
/* Keep the skb to echo it back once Tx feedback is
|
/* Keep the skb to echo it back once Tx feedback is
|
||||||
received from FW */
|
received from FW */
|
||||||
skb_orphan(skb);
|
skb_orphan(skb);
|
||||||
@ -158,6 +158,7 @@ netdev_tx_t lbs_hard_start_xmit(struct sk_buff *skb, struct net_device *dev)
|
|||||||
free:
|
free:
|
||||||
dev_kfree_skb_any(skb);
|
dev_kfree_skb_any(skb);
|
||||||
}
|
}
|
||||||
|
|
||||||
unlock:
|
unlock:
|
||||||
spin_unlock_irqrestore(&priv->driver_lock, flags);
|
spin_unlock_irqrestore(&priv->driver_lock, flags);
|
||||||
wake_up(&priv->waitq);
|
wake_up(&priv->waitq);
|
||||||
@ -179,7 +180,8 @@ void lbs_send_tx_feedback(struct lbs_private *priv, u32 try_count)
|
|||||||
{
|
{
|
||||||
struct tx_radiotap_hdr *radiotap_hdr;
|
struct tx_radiotap_hdr *radiotap_hdr;
|
||||||
|
|
||||||
if (!priv->monitormode || priv->currenttxskb == NULL)
|
if (!priv->wdev->iftype == NL80211_IFTYPE_MONITOR ||
|
||||||
|
priv->currenttxskb == NULL)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
radiotap_hdr = (struct tx_radiotap_hdr *)priv->currenttxskb->data;
|
radiotap_hdr = (struct tx_radiotap_hdr *)priv->currenttxskb->data;
|
||||||
@ -188,7 +190,7 @@ void lbs_send_tx_feedback(struct lbs_private *priv, u32 try_count)
|
|||||||
(1 + priv->txretrycount - try_count) : 0;
|
(1 + priv->txretrycount - try_count) : 0;
|
||||||
|
|
||||||
priv->currenttxskb->protocol = eth_type_trans(priv->currenttxskb,
|
priv->currenttxskb->protocol = eth_type_trans(priv->currenttxskb,
|
||||||
priv->rtap_net_dev);
|
priv->dev);
|
||||||
netif_rx(priv->currenttxskb);
|
netif_rx(priv->currenttxskb);
|
||||||
|
|
||||||
priv->currenttxskb = NULL;
|
priv->currenttxskb = NULL;
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -1,17 +0,0 @@
|
|||||||
/**
|
|
||||||
* This file contains definition for IOCTL call.
|
|
||||||
*/
|
|
||||||
#ifndef _LBS_WEXT_H_
|
|
||||||
#define _LBS_WEXT_H_
|
|
||||||
|
|
||||||
void lbs_send_disconnect_notification(struct lbs_private *priv);
|
|
||||||
void lbs_send_mic_failureevent(struct lbs_private *priv, u32 event);
|
|
||||||
|
|
||||||
struct chan_freq_power *lbs_find_cfp_by_band_and_channel(
|
|
||||||
struct lbs_private *priv,
|
|
||||||
u8 band,
|
|
||||||
u16 channel);
|
|
||||||
|
|
||||||
extern struct iw_handler_def lbs_handler_def;
|
|
||||||
|
|
||||||
#endif
|
|
Loading…
Reference in New Issue
Block a user