mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-01 10:43:43 +00:00
Staging driver updates for 5.19-rc1
Here is the big set of staging driver updates for 5.19-rc1. Lots of forward progress happened this development cycle, one driver (wfx wireless driver) got merged into the real portion of the kernel, and another one (unisys) was removed as no one is around anymore to take care of it and no one has the hardware. Combined with loads of tiny driver cleanups overall we removed 13k lines of code from the tree, a nice improvement. Other than the wfx and unisys driver changes the major points of this merge is: - r8188eu driver cleanups. So many cleanups. It's amazing just how many things have been cleaned up here, and yet, how many remain to go. Lots of work happened here, and it doesn't look to slow down any time soon. - other wifi driver cleanups. Not as many as the r8188eu driver, but still pretty impressive from a janitorial point of view. - bcm2853 driver cleanups - other very minor driver cleanups All of these have been in the linux-next tree for weeks with no reported issues. Note, you will have a merge conflict in the drivers/net/wireless/silabs/wfx/sta.c file, please just take the change that came in from the wifi tree. We thought as I had pulled the same merge point from the wifi developers this type of conflict wouldn't have happened, but for some reason git flags it as something to pay attention to and couldn't resolve it itself. Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org> -----BEGIN PGP SIGNATURE----- iG0EABECAC0WIQT0tgzFv3jCIUoxPcsxR9QN2y37KQUCYpnfqA8cZ3JlZ0Brcm9h aC5jb20ACgkQMUfUDdst+ynbFQCfbr7wdJYsNfVd0nXlDUw9EQtbhR8AoM5Y31Ni hBJs6fa/HMGfLnrmN2Xi =BQyT -----END PGP SIGNATURE----- Merge tag 'staging-5.19-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/staging Pull staging driver updates from Greg KH: "Here is the big set of staging driver updates for 5.19-rc1. Lots of forward progress happened this development cycle, one driver (wfx wireless driver) got merged into the real portion of the kernel, and another one (unisys) was removed as no one is around anymore to take care of it and no one has the hardware. Combined with loads of tiny driver cleanups overall we removed 13k lines of code from the tree, a nice improvement. Other than the wfx and unisys driver changes the major points of this merge is: - r8188eu driver cleanups. So many cleanups. It's amazing just how many things have been cleaned up here, and yet, how many remain to go. Lots of work happened here, and it doesn't look to slow down any time soon. - other wifi driver cleanups. Not as many as the r8188eu driver, but still pretty impressive from a janitorial point of view. - bcm2853 driver cleanups - other very minor driver cleanups All of these have been in the linux-next tree for weeks with no reported issues" * tag 'staging-5.19-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/staging: (363 commits) staging: r8188eu: remove include/rtw_debug.h staging: r8188eu: prevent ->Ssid overflow in rtw_wx_set_scan() staging: r8188eu: delete rtw_wx_read/write32() staging: r8188eu: Remove multiple assignments staging: r8188eu: add check for kzalloc staging: r8188eu: fix warnings in rtw_wlan_util staging: r8188eu: fix warnings in rtw_pwrctrl staging: r8188eu: fix warnings in rtw_p2p staging: rtl8712: fix uninit-value in r871xu_drv_init() staging: rtl8712: fix uninit-value in usb_read8() and friends staging: rtl8712: add error handler in r8712_usbctrl_vendorreq() staging: r8188eu: remove _drv_ defines from include/rtw_debug.h staging: vc04_services: remove unused macro staging: rtl8192u: remove null check after call container_of() staging: rtl8192e: remove null check after call container_of() staging: ks7010: remove null check after call container_of() staging: r8188eu: remove HW_VAR_AC_PARAM_BE from SetHwReg8188EU() staging: r8188eu: assoc_rsp and assoc_rsp_len are not used staging: r8188eu: last_rx_mgnt_pkts is set but not used staging: r8188eu: simplify error handling in recv_func_prehandle ...
This commit is contained in:
commit
4ad680f083
10
MAINTAINERS
10
MAINTAINERS
@ -20378,14 +20378,6 @@ F: drivers/cdrom/cdrom.c
|
||||
F: include/linux/cdrom.h
|
||||
F: include/uapi/linux/cdrom.h
|
||||
|
||||
UNISYS S-PAR DRIVERS
|
||||
M: David Kershner <david.kershner@unisys.com>
|
||||
L: sparmaintainer@unisys.com (Unisys internal)
|
||||
S: Supported
|
||||
F: drivers/staging/unisys/
|
||||
F: drivers/visorbus/
|
||||
F: include/linux/visorbus.h
|
||||
|
||||
UNIVERSAL FLASH STORAGE HOST CONTROLLER DRIVER
|
||||
R: Alim Akhtar <alim.akhtar@samsung.com>
|
||||
R: Avri Altman <avri.altman@wdc.com>
|
||||
@ -21204,7 +21196,7 @@ L: linux-kernel@vger.kernel.org
|
||||
S: Maintained
|
||||
T: git git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/char-misc.git
|
||||
F: Documentation/driver-api/vme.rst
|
||||
F: drivers/staging/vme/
|
||||
F: drivers/staging/vme_user/
|
||||
F: drivers/vme/
|
||||
F: include/linux/vme*
|
||||
|
||||
|
@ -225,8 +225,6 @@ source "drivers/mux/Kconfig"
|
||||
|
||||
source "drivers/opp/Kconfig"
|
||||
|
||||
source "drivers/visorbus/Kconfig"
|
||||
|
||||
source "drivers/siox/Kconfig"
|
||||
|
||||
source "drivers/slimbus/Kconfig"
|
||||
|
@ -181,7 +181,6 @@ obj-$(CONFIG_FPGA) += fpga/
|
||||
obj-$(CONFIG_FSI) += fsi/
|
||||
obj-$(CONFIG_TEE) += tee/
|
||||
obj-$(CONFIG_MULTIPLEXER) += mux/
|
||||
obj-$(CONFIG_UNISYS_VISORBUS) += visorbus/
|
||||
obj-$(CONFIG_SIOX) += siox/
|
||||
obj-$(CONFIG_GNSS) += gnss/
|
||||
obj-$(CONFIG_INTERCONNECT) += interconnect/
|
||||
|
@ -280,7 +280,7 @@ int wfx_hif_stop_scan(struct wfx_vif *wvif)
|
||||
}
|
||||
|
||||
int wfx_hif_join(struct wfx_vif *wvif, const struct ieee80211_bss_conf *conf,
|
||||
struct ieee80211_channel *channel, const u8 *ssid, int ssidlen)
|
||||
struct ieee80211_channel *channel, const u8 *ssid, int ssid_len)
|
||||
{
|
||||
int ret;
|
||||
struct wfx_hif_msg *hif;
|
||||
@ -288,8 +288,8 @@ int wfx_hif_join(struct wfx_vif *wvif, const struct ieee80211_bss_conf *conf,
|
||||
|
||||
WARN_ON(!conf->beacon_int);
|
||||
WARN_ON(!conf->basic_rates);
|
||||
WARN_ON(sizeof(body->ssid) < ssidlen);
|
||||
WARN(!conf->ibss_joined && !ssidlen, "joining an unknown BSS");
|
||||
WARN_ON(sizeof(body->ssid) < ssid_len);
|
||||
WARN(!conf->ibss_joined && !ssid_len, "joining an unknown BSS");
|
||||
if (!hif)
|
||||
return -ENOMEM;
|
||||
body->infrastructure_bss_mode = !conf->ibss_joined;
|
||||
@ -300,8 +300,8 @@ int wfx_hif_join(struct wfx_vif *wvif, const struct ieee80211_bss_conf *conf,
|
||||
body->basic_rate_set = cpu_to_le32(wfx_rate_mask_to_hw(wvif->wdev, conf->basic_rates));
|
||||
memcpy(body->bssid, conf->bssid, sizeof(body->bssid));
|
||||
if (ssid) {
|
||||
body->ssid_length = cpu_to_le32(ssidlen);
|
||||
memcpy(body->ssid, ssid, ssidlen);
|
||||
body->ssid_length = cpu_to_le32(ssid_len);
|
||||
memcpy(body->ssid, ssid, ssid_len);
|
||||
}
|
||||
wfx_fill_header(hif, wvif->id, HIF_REQ_ID_JOIN, sizeof(*body));
|
||||
ret = wfx_cmd_send(wvif->wdev, hif, NULL, 0, false);
|
||||
|
@ -170,7 +170,7 @@ bool wfx_api_older_than(struct wfx_dev *wdev, int major, int minor)
|
||||
*
|
||||
* The PDS file is an array of Time-Length-Value structs.
|
||||
*/
|
||||
int wfx_send_pds(struct wfx_dev *wdev, u8 *buf, size_t len)
|
||||
int wfx_send_pds(struct wfx_dev *wdev, u8 *buf, size_t len)
|
||||
{
|
||||
int ret, chunk_type, chunk_len, chunk_num = 0;
|
||||
|
||||
|
@ -409,8 +409,8 @@ static void wfx_join(struct wfx_vif *wvif)
|
||||
struct ieee80211_bss_conf *conf = &vif->bss_conf;
|
||||
struct cfg80211_bss *bss = NULL;
|
||||
u8 ssid[IEEE80211_MAX_SSID_LEN];
|
||||
const u8 *ssidie = NULL;
|
||||
int ssidlen = 0;
|
||||
const u8 *ssid_ie = NULL;
|
||||
int ssid_len = 0;
|
||||
int ret;
|
||||
|
||||
wfx_tx_lock_flush(wvif->wdev);
|
||||
@ -422,21 +422,21 @@ static void wfx_join(struct wfx_vif *wvif)
|
||||
return;
|
||||
}
|
||||
|
||||
rcu_read_lock(); /* protect ssidie */
|
||||
rcu_read_lock(); /* protect ssid_ie */
|
||||
if (bss)
|
||||
ssidie = ieee80211_bss_get_ie(bss, WLAN_EID_SSID);
|
||||
if (ssidie) {
|
||||
ssidlen = ssidie[1];
|
||||
if (ssidlen > IEEE80211_MAX_SSID_LEN)
|
||||
ssidlen = IEEE80211_MAX_SSID_LEN;
|
||||
memcpy(ssid, &ssidie[2], ssidlen);
|
||||
ssid_ie = ieee80211_bss_get_ie(bss, WLAN_EID_SSID);
|
||||
if (ssid_ie) {
|
||||
ssid_len = ssid_ie[1];
|
||||
if (ssid_len > IEEE80211_MAX_SSID_LEN)
|
||||
ssid_len = IEEE80211_MAX_SSID_LEN;
|
||||
memcpy(ssid, &ssid_ie[2], ssid_len);
|
||||
}
|
||||
rcu_read_unlock();
|
||||
|
||||
cfg80211_put_bss(wvif->wdev->hw->wiphy, bss);
|
||||
|
||||
wvif->join_in_progress = true;
|
||||
ret = wfx_hif_join(wvif, conf, wvif->channel, ssid, ssidlen);
|
||||
ret = wfx_hif_join(wvif, conf, wvif->channel, ssid, ssid_len);
|
||||
if (ret) {
|
||||
ieee80211_connection_loss(vif);
|
||||
wfx_reset(wvif);
|
||||
|
@ -64,8 +64,6 @@ source "drivers/staging/gdm724x/Kconfig"
|
||||
|
||||
source "drivers/staging/fwserial/Kconfig"
|
||||
|
||||
source "drivers/staging/unisys/Kconfig"
|
||||
|
||||
source "drivers/staging/clocking-wizard/Kconfig"
|
||||
|
||||
source "drivers/staging/fbtft/Kconfig"
|
||||
@ -86,5 +84,6 @@ source "drivers/staging/fieldbus/Kconfig"
|
||||
|
||||
source "drivers/staging/qlge/Kconfig"
|
||||
|
||||
source "drivers/staging/vme_user/Kconfig"
|
||||
|
||||
endif # STAGING
|
||||
|
@ -14,7 +14,7 @@ obj-$(CONFIG_OCTEON_ETHERNET) += octeon/
|
||||
obj-$(CONFIG_OCTEON_USB) += octeon-usb/
|
||||
obj-$(CONFIG_VT6655) += vt6655/
|
||||
obj-$(CONFIG_VT6656) += vt6656/
|
||||
obj-$(CONFIG_VME_BUS) += vme/
|
||||
obj-$(CONFIG_VME_BUS) += vme_user/
|
||||
obj-$(CONFIG_IIO) += iio/
|
||||
obj-$(CONFIG_FB_SM750) += sm750fb/
|
||||
obj-$(CONFIG_USB_EMXX) += emxx_udc/
|
||||
@ -22,7 +22,6 @@ obj-$(CONFIG_MFD_NVEC) += nvec/
|
||||
obj-$(CONFIG_STAGING_BOARD) += board/
|
||||
obj-$(CONFIG_LTE_GDM724X) += gdm724x/
|
||||
obj-$(CONFIG_FIREWIRE_SERIAL) += fwserial/
|
||||
obj-$(CONFIG_UNISYSSPAR) += unisys/
|
||||
obj-$(CONFIG_COMMON_CLK_XLNX_CLKWZRD) += clocking-wizard/
|
||||
obj-$(CONFIG_FB_TFT) += fbtft/
|
||||
obj-$(CONFIG_MOST) += most/
|
||||
|
@ -1384,7 +1384,7 @@ anybuss_host_common_probe(struct device *dev,
|
||||
goto err_device;
|
||||
return cd;
|
||||
err_device:
|
||||
device_unregister(&cd->client->dev);
|
||||
put_device(&cd->client->dev);
|
||||
err_kthread:
|
||||
kthread_stop(cd->qthread);
|
||||
err_reset:
|
||||
|
@ -445,7 +445,7 @@ static int __maybe_unused arche_apb_ctrl_suspend(struct device *dev)
|
||||
static int __maybe_unused arche_apb_ctrl_resume(struct device *dev)
|
||||
{
|
||||
/*
|
||||
* Atleast for ES2 we have to meet the delay requirement between
|
||||
* At least for ES2 we have to meet the delay requirement between
|
||||
* unipro switch and AP bridge init, depending on whether bridge is in
|
||||
* OFF state or standby state.
|
||||
*
|
||||
|
@ -591,7 +591,7 @@ static __maybe_unused int arche_platform_suspend(struct device *dev)
|
||||
static __maybe_unused int arche_platform_resume(struct device *dev)
|
||||
{
|
||||
/*
|
||||
* Atleast for ES2 we have to meet the delay requirement between
|
||||
* At least for ES2 we have to meet the delay requirement between
|
||||
* unipro switch and AP bridge init, depending on whether bridge is in
|
||||
* OFF state or standby state.
|
||||
*
|
||||
|
@ -497,7 +497,7 @@ static int gbcodec_prepare(struct snd_pcm_substream *substream,
|
||||
struct snd_soc_dai *dai)
|
||||
{
|
||||
int ret;
|
||||
struct gbaudio_module_info *module;
|
||||
struct gbaudio_module_info *module = NULL, *iter;
|
||||
struct gbaudio_data_connection *data;
|
||||
struct gb_bundle *bundle;
|
||||
struct gbaudio_codec_info *codec = dev_get_drvdata(dai->dev);
|
||||
@ -511,11 +511,13 @@ static int gbcodec_prepare(struct snd_pcm_substream *substream,
|
||||
return -ENODEV;
|
||||
}
|
||||
|
||||
list_for_each_entry(module, &codec->module_list, list) {
|
||||
list_for_each_entry(iter, &codec->module_list, list) {
|
||||
/* find the dai */
|
||||
data = find_data(module, dai->id);
|
||||
if (data)
|
||||
data = find_data(iter, dai->id);
|
||||
if (data) {
|
||||
module = iter;
|
||||
break;
|
||||
}
|
||||
}
|
||||
if (!data) {
|
||||
dev_err(dai->dev, "DATA connection missing\n");
|
||||
@ -563,7 +565,7 @@ static int gbcodec_mute_stream(struct snd_soc_dai *dai, int mute, int stream)
|
||||
{
|
||||
int ret;
|
||||
struct gbaudio_data_connection *data;
|
||||
struct gbaudio_module_info *module;
|
||||
struct gbaudio_module_info *module = NULL, *iter;
|
||||
struct gb_bundle *bundle;
|
||||
struct gbaudio_codec_info *codec = dev_get_drvdata(dai->dev);
|
||||
struct gbaudio_stream_params *params;
|
||||
@ -592,15 +594,17 @@ static int gbcodec_mute_stream(struct snd_soc_dai *dai, int mute, int stream)
|
||||
return ret;
|
||||
}
|
||||
|
||||
list_for_each_entry(module, &codec->module_list, list) {
|
||||
list_for_each_entry(iter, &codec->module_list, list) {
|
||||
/* find the dai */
|
||||
data = find_data(module, dai->id);
|
||||
if (data)
|
||||
data = find_data(iter, dai->id);
|
||||
if (data) {
|
||||
module = iter;
|
||||
break;
|
||||
}
|
||||
}
|
||||
if (!data) {
|
||||
dev_err(dai->dev, "%s:%s DATA connection missing\n",
|
||||
dai->name, module->name);
|
||||
dev_err(dai->dev, "%s DATA connection missing\n",
|
||||
dai->name);
|
||||
mutex_unlock(&codec->lock);
|
||||
return -ENODEV;
|
||||
}
|
||||
@ -1027,12 +1031,6 @@ static int gbcodec_probe(struct snd_soc_component *comp)
|
||||
return 0;
|
||||
}
|
||||
|
||||
static void gbcodec_remove(struct snd_soc_component *comp)
|
||||
{
|
||||
/* Empty function for now */
|
||||
return;
|
||||
}
|
||||
|
||||
static int gbcodec_write(struct snd_soc_component *comp, unsigned int reg,
|
||||
unsigned int value)
|
||||
{
|
||||
@ -1047,8 +1045,6 @@ static unsigned int gbcodec_read(struct snd_soc_component *comp,
|
||||
|
||||
static const struct snd_soc_component_driver soc_codec_dev_gbaudio = {
|
||||
.probe = gbcodec_probe,
|
||||
.remove = gbcodec_remove,
|
||||
|
||||
.read = gbcodec_read,
|
||||
.write = gbcodec_write,
|
||||
};
|
||||
|
@ -297,7 +297,6 @@ static int gb_pwm_probe(struct gbphy_device *gbphy_dev,
|
||||
|
||||
pwm->dev = &gbphy_dev->dev;
|
||||
pwm->ops = &gb_pwm_ops;
|
||||
pwm->base = -1; /* Allocate base dynamically */
|
||||
pwm->npwm = pwmc->pwm_max + 1;
|
||||
|
||||
ret = pwmchip_add(pwm);
|
||||
|
@ -533,7 +533,7 @@ static int log_results(struct loopback_test *t)
|
||||
|
||||
fd = open(file_name, O_WRONLY | O_CREAT | O_APPEND, 0644);
|
||||
if (fd < 0) {
|
||||
fprintf(stderr, "unable to open %s for appendation\n", file_name);
|
||||
fprintf(stderr, "unable to open %s for appending\n", file_name);
|
||||
abort();
|
||||
}
|
||||
|
||||
|
@ -499,7 +499,6 @@ static int ad2s1210_read_raw(struct iio_dev *indio_dev,
|
||||
ret = IIO_VAL_INT;
|
||||
break;
|
||||
case IIO_ANGL_VEL:
|
||||
negative = st->rx[0] & 0x80;
|
||||
vel = be16_to_cpup((__be16 *)st->rx);
|
||||
vel >>= 16 - st->resolution;
|
||||
if (vel & 0x8000) {
|
||||
|
@ -84,10 +84,6 @@ static void ks_wlan_hw_wakeup_task(struct work_struct *work)
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
/* power save */
|
||||
if (atomic_read(&priv->sme_task.count) > 0)
|
||||
tasklet_enable(&priv->sme_task);
|
||||
}
|
||||
|
||||
static void ks_wlan_do_power_save(struct ks_wlan_private *priv)
|
||||
@ -2200,10 +2196,11 @@ static void hostif_sme_execute(struct ks_wlan_private *priv, int event)
|
||||
}
|
||||
}
|
||||
|
||||
static
|
||||
void hostif_sme_task(struct tasklet_struct *t)
|
||||
static void hostif_sme_work(struct work_struct *work)
|
||||
{
|
||||
struct ks_wlan_private *priv = from_tasklet(priv, t, sme_task);
|
||||
struct ks_wlan_private *priv;
|
||||
|
||||
priv = container_of(work, struct ks_wlan_private, sme_work);
|
||||
|
||||
if (priv->dev_state < DEVICE_STATE_BOOT)
|
||||
return;
|
||||
@ -2214,7 +2211,7 @@ void hostif_sme_task(struct tasklet_struct *t)
|
||||
hostif_sme_execute(priv, priv->sme_i.event_buff[priv->sme_i.qhead]);
|
||||
inc_smeqhead(priv);
|
||||
if (cnt_smeqbody(priv) > 0)
|
||||
tasklet_schedule(&priv->sme_task);
|
||||
schedule_work(&priv->sme_work);
|
||||
}
|
||||
|
||||
/* send to Station Management Entity module */
|
||||
@ -2229,7 +2226,7 @@ void hostif_sme_enqueue(struct ks_wlan_private *priv, u16 event)
|
||||
netdev_err(priv->net_dev, "sme queue buffer overflow\n");
|
||||
}
|
||||
|
||||
tasklet_schedule(&priv->sme_task);
|
||||
schedule_work(&priv->sme_work);
|
||||
}
|
||||
|
||||
static inline void hostif_aplist_init(struct ks_wlan_private *priv)
|
||||
@ -2254,7 +2251,7 @@ static inline void hostif_sme_init(struct ks_wlan_private *priv)
|
||||
priv->sme_i.qtail = 0;
|
||||
spin_lock_init(&priv->sme_i.sme_spin);
|
||||
priv->sme_i.sme_flag = 0;
|
||||
tasklet_setup(&priv->sme_task, hostif_sme_task);
|
||||
INIT_WORK(&priv->sme_work, hostif_sme_work);
|
||||
}
|
||||
|
||||
static inline void hostif_wpa_init(struct ks_wlan_private *priv)
|
||||
@ -2312,5 +2309,5 @@ int hostif_init(struct ks_wlan_private *priv)
|
||||
|
||||
void hostif_exit(struct ks_wlan_private *priv)
|
||||
{
|
||||
tasklet_kill(&priv->sme_task);
|
||||
cancel_work_sync(&priv->sme_work);
|
||||
}
|
||||
|
@ -449,7 +449,7 @@ struct ks_wlan_private {
|
||||
struct sme_info sme_i;
|
||||
u8 *rxp;
|
||||
unsigned int rx_size;
|
||||
struct tasklet_struct sme_task;
|
||||
struct work_struct sme_work;
|
||||
struct work_struct wakeup_work;
|
||||
int scan_ind_count;
|
||||
|
||||
|
@ -45,9 +45,6 @@ MODULE_PARM_DESC(fcnt, "Num of frames per sub-buffer for sync channels as a powe
|
||||
|
||||
static DEFINE_SPINLOCK(dim_lock);
|
||||
|
||||
static void dim2_tasklet_fn(unsigned long data);
|
||||
static DECLARE_TASKLET_OLD(dim2_tasklet, dim2_tasklet_fn);
|
||||
|
||||
/**
|
||||
* struct hdm_channel - private structure to keep channel specific data
|
||||
* @name: channel name
|
||||
@ -361,15 +358,9 @@ static irqreturn_t dim2_mlb_isr(int irq, void *_dev)
|
||||
return IRQ_HANDLED;
|
||||
}
|
||||
|
||||
/**
|
||||
* dim2_tasklet_fn - tasklet function
|
||||
* @data: private data
|
||||
*
|
||||
* Service each initialized channel, if needed
|
||||
*/
|
||||
static void dim2_tasklet_fn(unsigned long data)
|
||||
static irqreturn_t dim2_task_irq(int irq, void *_dev)
|
||||
{
|
||||
struct dim2_hdm *dev = (struct dim2_hdm *)data;
|
||||
struct dim2_hdm *dev = _dev;
|
||||
unsigned long flags;
|
||||
int ch_idx;
|
||||
|
||||
@ -385,6 +376,8 @@ static void dim2_tasklet_fn(unsigned long data)
|
||||
while (!try_start_dim_transfer(dev->hch + ch_idx))
|
||||
continue;
|
||||
}
|
||||
|
||||
return IRQ_HANDLED;
|
||||
}
|
||||
|
||||
/**
|
||||
@ -392,8 +385,8 @@ static void dim2_tasklet_fn(unsigned long data)
|
||||
* @irq: irq number
|
||||
* @_dev: private data
|
||||
*
|
||||
* Acknowledge the interrupt and schedule a tasklet to service channels.
|
||||
* Return IRQ_HANDLED.
|
||||
* Acknowledge the interrupt and service each initialized channel,
|
||||
* if needed, in task context.
|
||||
*/
|
||||
static irqreturn_t dim2_ahb_isr(int irq, void *_dev)
|
||||
{
|
||||
@ -405,9 +398,7 @@ static irqreturn_t dim2_ahb_isr(int irq, void *_dev)
|
||||
dim_service_ahb_int_irq(get_active_channels(dev, buffer));
|
||||
spin_unlock_irqrestore(&dim_lock, flags);
|
||||
|
||||
dim2_tasklet.data = (unsigned long)dev;
|
||||
tasklet_schedule(&dim2_tasklet);
|
||||
return IRQ_HANDLED;
|
||||
return IRQ_WAKE_THREAD;
|
||||
}
|
||||
|
||||
/**
|
||||
@ -654,14 +645,12 @@ static int poison_channel(struct most_interface *most_iface, int ch_idx)
|
||||
if (!hdm_ch->is_initialized)
|
||||
return -EPERM;
|
||||
|
||||
tasklet_disable(&dim2_tasklet);
|
||||
spin_lock_irqsave(&dim_lock, flags);
|
||||
hal_ret = dim_destroy_channel(&hdm_ch->ch);
|
||||
hdm_ch->is_initialized = false;
|
||||
if (ch_idx == dev->atx_idx)
|
||||
dev->atx_idx = -1;
|
||||
spin_unlock_irqrestore(&dim_lock, flags);
|
||||
tasklet_enable(&dim2_tasklet);
|
||||
if (hal_ret != DIM_NO_ERROR) {
|
||||
pr_err("HAL Failed to close channel %s\n", hdm_ch->name);
|
||||
ret = -EFAULT;
|
||||
@ -821,8 +810,8 @@ static int dim2_probe(struct platform_device *pdev)
|
||||
goto err_shutdown_dim;
|
||||
}
|
||||
|
||||
ret = devm_request_irq(&pdev->dev, irq, dim2_ahb_isr, 0,
|
||||
"dim2_ahb0_int", dev);
|
||||
ret = devm_request_threaded_irq(&pdev->dev, irq, dim2_ahb_isr,
|
||||
dim2_task_irq, 0, "dim2_ahb0_int", dev);
|
||||
if (ret) {
|
||||
dev_err(&pdev->dev, "failed to request ahb0_int irq %d\n", irq);
|
||||
goto err_shutdown_dim;
|
||||
|
@ -2072,6 +2072,7 @@ struct qlge_adapter *netdev_to_qdev(struct net_device *ndev)
|
||||
|
||||
return ndev_priv->qdev;
|
||||
}
|
||||
|
||||
/*
|
||||
* The main Adapter structure definition.
|
||||
* This structure has all fields relevant to the hardware.
|
||||
|
@ -188,7 +188,6 @@ void expire_timeout_chk(struct adapter *padapter)
|
||||
spin_lock_bh(&pstapriv->auth_list_lock);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
spin_unlock_bh(&pstapriv->auth_list_lock);
|
||||
|
||||
@ -381,7 +380,6 @@ void add_RATid(struct adapter *padapter, struct sta_info *psta, u8 rssi_level)
|
||||
/* set ra_id, init_rate */
|
||||
psta->raid = raid;
|
||||
psta->init_rate = init_rate;
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
@ -455,7 +453,6 @@ void update_bmc_sta(struct adapter *padapter)
|
||||
spin_lock_bh(&psta->lock);
|
||||
psta->state = _FW_LINKED;
|
||||
spin_unlock_bh(&psta->lock);
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -53,7 +53,8 @@ static unsigned char *__nat25_find_pppoe_tag(struct pppoe_hdr *ph, unsigned shor
|
||||
unsigned char *cur_ptr, *start_ptr;
|
||||
unsigned short tagLen, tagType;
|
||||
|
||||
start_ptr = cur_ptr = (unsigned char *)ph->tag;
|
||||
start_ptr = (unsigned char *)ph->tag;
|
||||
cur_ptr = (unsigned char *)ph->tag;
|
||||
while ((cur_ptr - start_ptr) < ntohs(ph->length)) {
|
||||
/* prevent un-alignment access */
|
||||
tagType = (unsigned short)((cur_ptr[0] << 8) + cur_ptr[1]);
|
||||
@ -87,19 +88,19 @@ static int skb_pull_and_merge(struct sk_buff *skb, unsigned char *src, int len)
|
||||
int tail_len;
|
||||
unsigned long end, tail;
|
||||
|
||||
if ((src+len) > skb_tail_pointer(skb) || skb->len < len)
|
||||
if ((src + len) > skb_tail_pointer(skb) || skb->len < len)
|
||||
return -1;
|
||||
|
||||
tail = (unsigned long)skb_tail_pointer(skb);
|
||||
end = (unsigned long)src+len;
|
||||
end = (unsigned long)src + len;
|
||||
if (tail < end)
|
||||
return -1;
|
||||
|
||||
tail_len = (int)(tail-end);
|
||||
tail_len = (int)(tail - end);
|
||||
if (tail_len > 0)
|
||||
memmove(src, src+len, tail_len);
|
||||
memmove(src, src + len, tail_len);
|
||||
|
||||
skb_trim(skb, skb->len-len);
|
||||
skb_trim(skb, skb->len - len);
|
||||
return 0;
|
||||
}
|
||||
|
||||
@ -117,7 +118,7 @@ static void __nat25_generate_ipv4_network_addr(unsigned char *networkAddr,
|
||||
memset(networkAddr, 0, MAX_NETWORK_ADDR_LEN);
|
||||
|
||||
networkAddr[0] = NAT25_IPV4;
|
||||
memcpy(networkAddr+7, (unsigned char *)ipAddr, 4);
|
||||
memcpy(networkAddr + 7, (unsigned char *)ipAddr, 4);
|
||||
}
|
||||
|
||||
static void __nat25_generate_pppoe_network_addr(unsigned char *networkAddr,
|
||||
@ -126,8 +127,8 @@ static void __nat25_generate_pppoe_network_addr(unsigned char *networkAddr,
|
||||
memset(networkAddr, 0, MAX_NETWORK_ADDR_LEN);
|
||||
|
||||
networkAddr[0] = NAT25_PPPOE;
|
||||
memcpy(networkAddr+1, (unsigned char *)sid, 2);
|
||||
memcpy(networkAddr+3, (unsigned char *)ac_mac, 6);
|
||||
memcpy(networkAddr + 1, (unsigned char *)sid, 2);
|
||||
memcpy(networkAddr + 3, (unsigned char *)ac_mac, 6);
|
||||
}
|
||||
|
||||
static void __nat25_generate_ipv6_network_addr(unsigned char *networkAddr,
|
||||
@ -136,17 +137,17 @@ static void __nat25_generate_ipv6_network_addr(unsigned char *networkAddr,
|
||||
memset(networkAddr, 0, MAX_NETWORK_ADDR_LEN);
|
||||
|
||||
networkAddr[0] = NAT25_IPV6;
|
||||
memcpy(networkAddr+1, (unsigned char *)ipAddr, 16);
|
||||
memcpy(networkAddr + 1, (unsigned char *)ipAddr, 16);
|
||||
}
|
||||
|
||||
static unsigned char *scan_tlv(unsigned char *data, int len, unsigned char tag, unsigned char len8b)
|
||||
{
|
||||
while (len > 0) {
|
||||
if (*data == tag && *(data+1) == len8b && len >= len8b*8)
|
||||
return data+2;
|
||||
if (*data == tag && *(data + 1) == len8b && len >= len8b * 8)
|
||||
return data + 2;
|
||||
|
||||
len -= (*(data+1))*8;
|
||||
data += (*(data+1))*8;
|
||||
len -= (*(data + 1)) * 8;
|
||||
data += (*(data + 1)) * 8;
|
||||
}
|
||||
return NULL;
|
||||
}
|
||||
@ -158,7 +159,7 @@ static int update_nd_link_layer_addr(unsigned char *data, int len, unsigned char
|
||||
|
||||
if (icmphdr->icmp6_type == NDISC_ROUTER_SOLICITATION) {
|
||||
if (len >= 8) {
|
||||
mac = scan_tlv(&data[8], len-8, 1, 1);
|
||||
mac = scan_tlv(&data[8], len - 8, 1, 1);
|
||||
if (mac) {
|
||||
memcpy(mac, replace_mac, 6);
|
||||
return 1;
|
||||
@ -166,7 +167,7 @@ static int update_nd_link_layer_addr(unsigned char *data, int len, unsigned char
|
||||
}
|
||||
} else if (icmphdr->icmp6_type == NDISC_ROUTER_ADVERTISEMENT) {
|
||||
if (len >= 16) {
|
||||
mac = scan_tlv(&data[16], len-16, 1, 1);
|
||||
mac = scan_tlv(&data[16], len - 16, 1, 1);
|
||||
if (mac) {
|
||||
memcpy(mac, replace_mac, 6);
|
||||
return 1;
|
||||
@ -174,7 +175,7 @@ static int update_nd_link_layer_addr(unsigned char *data, int len, unsigned char
|
||||
}
|
||||
} else if (icmphdr->icmp6_type == NDISC_NEIGHBOUR_SOLICITATION) {
|
||||
if (len >= 24) {
|
||||
mac = scan_tlv(&data[24], len-24, 1, 1);
|
||||
mac = scan_tlv(&data[24], len - 24, 1, 1);
|
||||
if (mac) {
|
||||
memcpy(mac, replace_mac, 6);
|
||||
return 1;
|
||||
@ -182,7 +183,7 @@ static int update_nd_link_layer_addr(unsigned char *data, int len, unsigned char
|
||||
}
|
||||
} else if (icmphdr->icmp6_type == NDISC_NEIGHBOUR_ADVERTISEMENT) {
|
||||
if (len >= 24) {
|
||||
mac = scan_tlv(&data[24], len-24, 2, 1);
|
||||
mac = scan_tlv(&data[24], len - 24, 2, 1);
|
||||
if (mac) {
|
||||
memcpy(mac, replace_mac, 6);
|
||||
return 1;
|
||||
@ -190,7 +191,7 @@ static int update_nd_link_layer_addr(unsigned char *data, int len, unsigned char
|
||||
}
|
||||
} else if (icmphdr->icmp6_type == NDISC_REDIRECT) {
|
||||
if (len >= 40) {
|
||||
mac = scan_tlv(&data[40], len-40, 2, 1);
|
||||
mac = scan_tlv(&data[40], len - 40, 2, 1);
|
||||
if (mac) {
|
||||
memcpy(mac, replace_mac, 6);
|
||||
return 1;
|
||||
@ -313,6 +314,7 @@ void nat25_db_cleanup(struct adapter *priv)
|
||||
|
||||
for (i = 0; i < NAT25_HASH_SIZE; i++) {
|
||||
struct nat25_network_db_entry *f;
|
||||
|
||||
f = priv->nethash[i];
|
||||
while (f) {
|
||||
struct nat25_network_db_entry *g;
|
||||
@ -339,12 +341,12 @@ void nat25_db_expire(struct adapter *priv)
|
||||
|
||||
for (i = 0; i < NAT25_HASH_SIZE; i++) {
|
||||
struct nat25_network_db_entry *f;
|
||||
f = priv->nethash[i];
|
||||
|
||||
f = priv->nethash[i];
|
||||
while (f) {
|
||||
struct nat25_network_db_entry *g;
|
||||
g = f->next_hash;
|
||||
|
||||
g = f->next_hash;
|
||||
if (__nat25_has_expired(f)) {
|
||||
if (atomic_dec_and_test(&f->use_count)) {
|
||||
if (priv->scdb_entry == f) {
|
||||
@ -396,7 +398,7 @@ int nat25_db_handle(struct adapter *priv, struct sk_buff *skb, int method)
|
||||
tmp = be32_to_cpu(iph->saddr);
|
||||
__nat25_generate_ipv4_network_addr(networkAddr, &tmp);
|
||||
/* record source IP address and , source mac address into db */
|
||||
__nat25_db_network_insert(priv, skb->data+ETH_ALEN, networkAddr);
|
||||
__nat25_db_network_insert(priv, skb->data + ETH_ALEN, networkAddr);
|
||||
return 0;
|
||||
default:
|
||||
return -1;
|
||||
@ -421,7 +423,7 @@ int nat25_db_handle(struct adapter *priv, struct sk_buff *skb, int method)
|
||||
arp_ptr += arp->ar_hln;
|
||||
sender = (unsigned int *)arp_ptr;
|
||||
__nat25_generate_ipv4_network_addr(networkAddr, sender);
|
||||
__nat25_db_network_insert(priv, skb->data+ETH_ALEN, networkAddr);
|
||||
__nat25_db_network_insert(priv, skb->data + ETH_ALEN, networkAddr);
|
||||
return 0;
|
||||
default:
|
||||
return -1;
|
||||
@ -432,7 +434,7 @@ int nat25_db_handle(struct adapter *priv, struct sk_buff *skb, int method)
|
||||
/* Handle PPPoE frame */
|
||||
/*---------------------------------------------------*/
|
||||
struct pppoe_hdr *ph = (struct pppoe_hdr *)(skb->data + ETH_HLEN);
|
||||
unsigned short *pMagic;
|
||||
__be16 *pMagic;
|
||||
|
||||
switch (method) {
|
||||
case NAT25_CHECK:
|
||||
@ -458,22 +460,22 @@ int nat25_db_handle(struct adapter *priv, struct sk_buff *skb, int method)
|
||||
sizeof(tag_buf))
|
||||
return -1;
|
||||
|
||||
memcpy(tag->tag_data+MAGIC_CODE_LEN+RTL_RELAY_TAG_LEN,
|
||||
memcpy(tag->tag_data + MAGIC_CODE_LEN + RTL_RELAY_TAG_LEN,
|
||||
pOldTag->tag_data, old_tag_len);
|
||||
|
||||
if (skb_pull_and_merge(skb, (unsigned char *)pOldTag, TAG_HDR_LEN+old_tag_len) < 0)
|
||||
if (skb_pull_and_merge(skb, (unsigned char *)pOldTag, TAG_HDR_LEN + old_tag_len) < 0)
|
||||
return -1;
|
||||
|
||||
ph->length = htons(ntohs(ph->length)-TAG_HDR_LEN-old_tag_len);
|
||||
ph->length = htons(ntohs(ph->length) - TAG_HDR_LEN - old_tag_len);
|
||||
}
|
||||
|
||||
tag->tag_type = PTT_RELAY_SID;
|
||||
tag->tag_len = htons(MAGIC_CODE_LEN+RTL_RELAY_TAG_LEN+old_tag_len);
|
||||
tag->tag_len = htons(MAGIC_CODE_LEN + RTL_RELAY_TAG_LEN + old_tag_len);
|
||||
|
||||
/* insert the magic_code+client mac in relay tag */
|
||||
pMagic = (unsigned short *)tag->tag_data;
|
||||
pMagic = (__be16 *)tag->tag_data;
|
||||
*pMagic = htons(MAGIC_CODE);
|
||||
memcpy(tag->tag_data+MAGIC_CODE_LEN, skb->data+ETH_ALEN, ETH_ALEN);
|
||||
memcpy(tag->tag_data + MAGIC_CODE_LEN, skb->data + ETH_ALEN, ETH_ALEN);
|
||||
|
||||
/* Add relay tag */
|
||||
if (__nat25_add_pppoe_tag(skb, tag) < 0)
|
||||
@ -486,7 +488,7 @@ int nat25_db_handle(struct adapter *priv, struct sk_buff *skb, int method)
|
||||
return -2;
|
||||
|
||||
if (priv->pppoe_connection_in_progress == 0)
|
||||
memcpy(priv->pppoe_addr, skb->data+ETH_ALEN, ETH_ALEN);
|
||||
memcpy(priv->pppoe_addr, skb->data + ETH_ALEN, ETH_ALEN);
|
||||
|
||||
priv->pppoe_connection_in_progress = WAIT_TIME_PPPOE;
|
||||
}
|
||||
@ -496,11 +498,11 @@ int nat25_db_handle(struct adapter *priv, struct sk_buff *skb, int method)
|
||||
} else { /* session phase */
|
||||
__nat25_generate_pppoe_network_addr(networkAddr, skb->data, &ph->sid);
|
||||
|
||||
__nat25_db_network_insert(priv, skb->data+ETH_ALEN, networkAddr);
|
||||
__nat25_db_network_insert(priv, skb->data + ETH_ALEN, networkAddr);
|
||||
|
||||
if (!priv->ethBrExtInfo.addPPPoETag &&
|
||||
priv->pppoe_connection_in_progress &&
|
||||
!memcmp(skb->data+ETH_ALEN, priv->pppoe_addr, ETH_ALEN))
|
||||
!memcmp(skb->data + ETH_ALEN, priv->pppoe_addr, ETH_ALEN))
|
||||
priv->pppoe_connection_in_progress = 0;
|
||||
}
|
||||
return 0;
|
||||
@ -548,7 +550,7 @@ int nat25_db_handle(struct adapter *priv, struct sk_buff *skb, int method)
|
||||
case NAT25_INSERT:
|
||||
if (memcmp(&iph->saddr, "\x0\x0\x0\x0\x0\x0\x0\x0\x0\x0\x0\x0\x0\x0\x0\x0", 16)) {
|
||||
__nat25_generate_ipv6_network_addr(networkAddr, (unsigned int *)&iph->saddr);
|
||||
__nat25_db_network_insert(priv, skb->data+ETH_ALEN, networkAddr);
|
||||
__nat25_db_network_insert(priv, skb->data + ETH_ALEN, networkAddr);
|
||||
|
||||
if (iph->nexthdr == IPPROTO_ICMPV6 &&
|
||||
skb->len > (ETH_HLEN + sizeof(*iph) + 4)) {
|
||||
@ -557,9 +559,11 @@ int nat25_db_handle(struct adapter *priv, struct sk_buff *skb, int method)
|
||||
struct icmp6hdr *hdr = (struct icmp6hdr *)(skb->data + ETH_HLEN + sizeof(*iph));
|
||||
hdr->icmp6_cksum = 0;
|
||||
hdr->icmp6_cksum = csum_ipv6_magic(&iph->saddr, &iph->daddr,
|
||||
iph->payload_len,
|
||||
be16_to_cpu(iph->payload_len),
|
||||
IPPROTO_ICMPV6,
|
||||
csum_partial((__u8 *)hdr, iph->payload_len, 0));
|
||||
csum_partial((__u8 *)hdr,
|
||||
be16_to_cpu(iph->payload_len),
|
||||
0));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -11,14 +11,54 @@
|
||||
#include "../include/rtw_mlme_ext.h"
|
||||
#include "../include/rtl8188e_dm.h"
|
||||
|
||||
/*
|
||||
Caller and the rtw_cmd_thread can protect cmd_q by spin_lock.
|
||||
No irqsave is necessary.
|
||||
*/
|
||||
/* Caller and the rtw_cmd_thread can protect cmd_q by spin_lock.
|
||||
* No irqsave is necessary.
|
||||
*/
|
||||
|
||||
static int _rtw_init_cmd_priv(struct cmd_priv *pcmdpriv)
|
||||
static void c2h_wk_callback(struct work_struct *work);
|
||||
|
||||
void rtw_free_evt_priv(struct evt_priv *pevtpriv)
|
||||
{
|
||||
int res = _SUCCESS;
|
||||
cancel_work_sync(&pevtpriv->c2h_wk);
|
||||
while (pevtpriv->c2h_wk_alive)
|
||||
msleep(10);
|
||||
|
||||
while (!rtw_cbuf_empty(pevtpriv->c2h_queue)) {
|
||||
void *c2h = rtw_cbuf_pop(pevtpriv->c2h_queue);
|
||||
if (c2h && c2h != (void *)pevtpriv)
|
||||
kfree(c2h);
|
||||
}
|
||||
}
|
||||
|
||||
/* Calling Context:
|
||||
*
|
||||
* rtw_enqueue_cmd can only be called between kernel thread,
|
||||
* since only spin_lock is used.
|
||||
*
|
||||
* ISR/Call-Back functions can't call this sub-function.
|
||||
*/
|
||||
|
||||
static int _rtw_enqueue_cmd(struct __queue *queue, struct cmd_obj *obj)
|
||||
{
|
||||
unsigned long flags;
|
||||
|
||||
if (!obj)
|
||||
goto exit;
|
||||
|
||||
spin_lock_irqsave(&queue->lock, flags);
|
||||
|
||||
list_add_tail(&obj->list, &queue->queue);
|
||||
|
||||
spin_unlock_irqrestore(&queue->lock, flags);
|
||||
|
||||
exit:
|
||||
|
||||
return _SUCCESS;
|
||||
}
|
||||
|
||||
u32 rtw_init_cmd_priv(struct cmd_priv *pcmdpriv)
|
||||
{
|
||||
u32 res = _SUCCESS;
|
||||
|
||||
init_completion(&pcmdpriv->enqueue_cmd);
|
||||
/* sema_init(&(pcmdpriv->cmd_done_sema), 0); */
|
||||
@ -57,11 +97,9 @@ static int _rtw_init_cmd_priv(struct cmd_priv *pcmdpriv)
|
||||
return res;
|
||||
}
|
||||
|
||||
static void c2h_wk_callback(struct work_struct *work);
|
||||
|
||||
static int _rtw_init_evt_priv(struct evt_priv *pevtpriv)
|
||||
u32 rtw_init_evt_priv(struct evt_priv *pevtpriv)
|
||||
{
|
||||
int res = _SUCCESS;
|
||||
u32 res = _SUCCESS;
|
||||
|
||||
/* allocate DMA-able/Non-Page memory for cmd_buf and rsp_buf */
|
||||
atomic_set(&pevtpriv->event_seq, 0);
|
||||
@ -69,98 +107,18 @@ static int _rtw_init_evt_priv(struct evt_priv *pevtpriv)
|
||||
INIT_WORK(&pevtpriv->c2h_wk, c2h_wk_callback);
|
||||
pevtpriv->c2h_wk_alive = false;
|
||||
pevtpriv->c2h_queue = rtw_cbuf_alloc(C2H_QUEUE_MAX_LEN + 1);
|
||||
|
||||
return res;
|
||||
}
|
||||
|
||||
void rtw_free_evt_priv(struct evt_priv *pevtpriv)
|
||||
{
|
||||
cancel_work_sync(&pevtpriv->c2h_wk);
|
||||
while (pevtpriv->c2h_wk_alive)
|
||||
msleep(10);
|
||||
|
||||
while (!rtw_cbuf_empty(pevtpriv->c2h_queue)) {
|
||||
void *c2h = rtw_cbuf_pop(pevtpriv->c2h_queue);
|
||||
if (c2h && c2h != (void *)pevtpriv)
|
||||
kfree(c2h);
|
||||
}
|
||||
}
|
||||
|
||||
static void _rtw_free_cmd_priv(struct cmd_priv *pcmdpriv)
|
||||
{
|
||||
if (pcmdpriv) {
|
||||
kfree(pcmdpriv->cmd_allocated_buf);
|
||||
kfree(pcmdpriv->rsp_allocated_buf);
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
Calling Context:
|
||||
|
||||
rtw_enqueue_cmd can only be called between kernel thread,
|
||||
since only spin_lock is used.
|
||||
|
||||
ISR/Call-Back functions can't call this sub-function.
|
||||
|
||||
*/
|
||||
|
||||
static int _rtw_enqueue_cmd(struct __queue *queue, struct cmd_obj *obj)
|
||||
{
|
||||
unsigned long flags;
|
||||
|
||||
if (!obj)
|
||||
goto exit;
|
||||
|
||||
spin_lock_irqsave(&queue->lock, flags);
|
||||
|
||||
list_add_tail(&obj->list, &queue->queue);
|
||||
|
||||
spin_unlock_irqrestore(&queue->lock, flags);
|
||||
|
||||
exit:
|
||||
|
||||
return _SUCCESS;
|
||||
}
|
||||
|
||||
static struct cmd_obj *_rtw_dequeue_cmd(struct __queue *queue)
|
||||
{
|
||||
struct cmd_obj *obj;
|
||||
unsigned long flags;
|
||||
|
||||
spin_lock_irqsave(&queue->lock, flags);
|
||||
if (list_empty(&queue->queue)) {
|
||||
obj = NULL;
|
||||
} else {
|
||||
obj = container_of((&queue->queue)->next, struct cmd_obj, list);
|
||||
list_del_init(&obj->list);
|
||||
}
|
||||
|
||||
spin_unlock_irqrestore(&queue->lock, flags);
|
||||
|
||||
return obj;
|
||||
}
|
||||
|
||||
u32 rtw_init_cmd_priv(struct cmd_priv *pcmdpriv)
|
||||
{
|
||||
u32 res;
|
||||
|
||||
res = _rtw_init_cmd_priv(pcmdpriv);
|
||||
|
||||
return res;
|
||||
}
|
||||
|
||||
u32 rtw_init_evt_priv(struct evt_priv *pevtpriv)
|
||||
{
|
||||
int res;
|
||||
|
||||
res = _rtw_init_evt_priv(pevtpriv);
|
||||
if (!pevtpriv->c2h_queue)
|
||||
res = _FAIL;
|
||||
|
||||
return res;
|
||||
}
|
||||
|
||||
void rtw_free_cmd_priv(struct cmd_priv *pcmdpriv)
|
||||
{
|
||||
_rtw_free_cmd_priv(pcmdpriv);
|
||||
if (pcmdpriv) {
|
||||
kfree(pcmdpriv->cmd_allocated_buf);
|
||||
kfree(pcmdpriv->rsp_allocated_buf);
|
||||
}
|
||||
}
|
||||
|
||||
static int rtw_cmd_filter(struct cmd_priv *pcmdpriv, struct cmd_obj *cmd_obj)
|
||||
@ -187,7 +145,7 @@ u32 rtw_enqueue_cmd(struct cmd_priv *pcmdpriv, struct cmd_obj *cmd_obj)
|
||||
cmd_obj->padapter = padapter;
|
||||
|
||||
res = rtw_cmd_filter(pcmdpriv, cmd_obj);
|
||||
if (_FAIL == res) {
|
||||
if (res == _FAIL) {
|
||||
rtw_free_cmd_obj(cmd_obj);
|
||||
goto exit;
|
||||
}
|
||||
@ -204,11 +162,21 @@ u32 rtw_enqueue_cmd(struct cmd_priv *pcmdpriv, struct cmd_obj *cmd_obj)
|
||||
|
||||
struct cmd_obj *rtw_dequeue_cmd(struct cmd_priv *pcmdpriv)
|
||||
{
|
||||
struct cmd_obj *cmd_obj;
|
||||
struct cmd_obj *obj;
|
||||
struct __queue *queue = &pcmdpriv->cmd_queue;
|
||||
unsigned long flags;
|
||||
|
||||
cmd_obj = _rtw_dequeue_cmd(&pcmdpriv->cmd_queue);
|
||||
spin_lock_irqsave(&queue->lock, flags);
|
||||
if (list_empty(&queue->queue)) {
|
||||
obj = NULL;
|
||||
} else {
|
||||
obj = container_of((&queue->queue)->next, struct cmd_obj, list);
|
||||
list_del_init(&obj->list);
|
||||
}
|
||||
|
||||
return cmd_obj;
|
||||
spin_unlock_irqrestore(&queue->lock, flags);
|
||||
|
||||
return obj;
|
||||
}
|
||||
|
||||
void rtw_free_cmd_obj(struct cmd_obj *pcmd)
|
||||
@ -258,12 +226,12 @@ int rtw_cmd_thread(void *context)
|
||||
if (!pcmd)
|
||||
continue;
|
||||
|
||||
if (_FAIL == rtw_cmd_filter(pcmdpriv, pcmd)) {
|
||||
if (rtw_cmd_filter(pcmdpriv, pcmd) == _FAIL) {
|
||||
pcmd->res = H2C_DROPPED;
|
||||
goto post_process;
|
||||
}
|
||||
|
||||
pcmd->cmdsz = _RND4((pcmd->cmdsz));/* _RND4 */
|
||||
pcmd->cmdsz = round_up(pcmd->cmdsz, 4);
|
||||
|
||||
memcpy(pcmdbuf, pcmd->parmbuf, pcmd->cmdsz);
|
||||
|
||||
@ -291,7 +259,7 @@ int rtw_cmd_thread(void *context)
|
||||
rtw_free_cmd_obj(pcmd);
|
||||
else
|
||||
/* todo: !!! fill rsp_buf to pcmd->rsp if (pcmd->rsp!= NULL) */
|
||||
pcmd_callback(pcmd->padapter, pcmd);/* need conider that free cmd_obj in rtw_cmd_callback */
|
||||
pcmd_callback(pcmd->padapter, pcmd);/* need consider that free cmd_obj in rtw_cmd_callback */
|
||||
} else {
|
||||
rtw_free_cmd_obj(pcmd);
|
||||
}
|
||||
@ -316,11 +284,10 @@ int rtw_cmd_thread(void *context)
|
||||
return 0;
|
||||
}
|
||||
|
||||
/*
|
||||
rtw_sitesurvey_cmd(~)
|
||||
### NOTE:#### (!!!!)
|
||||
MUST TAKE CARE THAT BEFORE CALLING THIS FUNC, YOU SHOULD HAVE LOCKED pmlmepriv->lock
|
||||
*/
|
||||
/* rtw_sitesurvey_cmd(~)
|
||||
* ### NOTE:#### (!!!!)
|
||||
* MUST TAKE CARE THAT BEFORE CALLING THIS FUNC, YOU SHOULD HAVE LOCKED pmlmepriv->lock
|
||||
*/
|
||||
u8 rtw_sitesurvey_cmd(struct adapter *padapter, struct ndis_802_11_ssid *ssid, int ssid_num,
|
||||
struct rtw_ieee80211_channel *ch, int ch_num)
|
||||
{
|
||||
@ -330,19 +297,17 @@ u8 rtw_sitesurvey_cmd(struct adapter *padapter, struct ndis_802_11_ssid *ssid,
|
||||
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
|
||||
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
|
||||
|
||||
if (check_fwstate(pmlmepriv, _FW_LINKED)) {
|
||||
if (check_fwstate(pmlmepriv, _FW_LINKED))
|
||||
rtw_lps_ctrl_wk_cmd(padapter, LPS_CTRL_SCAN, 1);
|
||||
}
|
||||
|
||||
if (check_fwstate(pmlmepriv, _FW_LINKED)) {
|
||||
if (check_fwstate(pmlmepriv, _FW_LINKED))
|
||||
p2p_ps_wk_cmd(padapter, P2P_PS_SCAN, 1);
|
||||
}
|
||||
|
||||
ph2c = kzalloc(sizeof(struct cmd_obj), GFP_ATOMIC);
|
||||
ph2c = kzalloc(sizeof(*ph2c), GFP_ATOMIC);
|
||||
if (!ph2c)
|
||||
return _FAIL;
|
||||
|
||||
psurveyPara = kzalloc(sizeof(struct sitesurvey_parm), GFP_ATOMIC);
|
||||
psurveyPara = kzalloc(sizeof(*psurveyPara), GFP_ATOMIC);
|
||||
if (!psurveyPara) {
|
||||
kfree(ph2c);
|
||||
return _FAIL;
|
||||
@ -403,13 +368,13 @@ u8 rtw_setdatarate_cmd(struct adapter *padapter, u8 *rateset)
|
||||
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
|
||||
u8 res = _SUCCESS;
|
||||
|
||||
ph2c = kzalloc(sizeof(struct cmd_obj), GFP_ATOMIC);
|
||||
ph2c = kzalloc(sizeof(*ph2c), GFP_ATOMIC);
|
||||
if (!ph2c) {
|
||||
res = _FAIL;
|
||||
goto exit;
|
||||
}
|
||||
|
||||
pbsetdataratepara = kzalloc(sizeof(struct setdatarate_parm), GFP_ATOMIC);
|
||||
pbsetdataratepara = kzalloc(sizeof(*pbsetdataratepara), GFP_ATOMIC);
|
||||
if (!pbsetdataratepara) {
|
||||
kfree(ph2c);
|
||||
res = _FAIL;
|
||||
@ -442,7 +407,7 @@ u8 rtw_createbss_cmd(struct adapter *padapter)
|
||||
|
||||
rtw_led_control(padapter, LED_CTL_START_TO_LINK);
|
||||
|
||||
pcmd = kzalloc(sizeof(struct cmd_obj), GFP_ATOMIC);
|
||||
pcmd = kzalloc(sizeof(*pcmd), GFP_ATOMIC);
|
||||
if (!pcmd) {
|
||||
res = _FAIL;
|
||||
goto exit;
|
||||
@ -479,7 +444,7 @@ u8 rtw_joinbss_cmd(struct adapter *padapter, struct wlan_network *pnetwork)
|
||||
|
||||
rtw_led_control(padapter, LED_CTL_START_TO_LINK);
|
||||
|
||||
pcmd = kzalloc(sizeof(struct cmd_obj), GFP_ATOMIC);
|
||||
pcmd = kzalloc(sizeof(*pcmd), GFP_ATOMIC);
|
||||
if (!pcmd) {
|
||||
res = _FAIL;
|
||||
goto exit;
|
||||
@ -516,15 +481,14 @@ u8 rtw_joinbss_cmd(struct adapter *padapter, struct wlan_network *pnetwork)
|
||||
|
||||
psecuritypriv->authenticator_ie[0] = (unsigned char)psecnetwork->IELength;
|
||||
|
||||
if (psecnetwork->IELength - 12 < 255) {
|
||||
if (psecnetwork->IELength - 12 < 255)
|
||||
memcpy(&psecuritypriv->authenticator_ie[1], &psecnetwork->IEs[12], psecnetwork->IELength - 12);
|
||||
} else {
|
||||
else
|
||||
memcpy(&psecuritypriv->authenticator_ie[1], &psecnetwork->IEs[12], 255);
|
||||
}
|
||||
|
||||
psecnetwork->IELength = 0;
|
||||
/* Added by Albert 2009/02/18 */
|
||||
/* If the the driver wants to use the bssid to create the connection. */
|
||||
/* If the driver wants to use the bssid to create the connection. */
|
||||
/* If not, we have to copy the connecting AP's MAC address to it so that */
|
||||
/* the driver just has the bssid information for PMKIDList searching. */
|
||||
|
||||
@ -550,9 +514,9 @@ u8 rtw_joinbss_cmd(struct adapter *padapter, struct wlan_network *pnetwork)
|
||||
|
||||
phtpriv->ht_option = false;
|
||||
if (pregistrypriv->ht_enable) {
|
||||
/* Added by Albert 2010/06/23 */
|
||||
/* For the WEP mode, we will use the bg mode to do the connection to avoid some IOT issue. */
|
||||
/* Especially for Realtek 8192u SoftAP. */
|
||||
/* Added by Albert 2010/06/23 */
|
||||
/* For the WEP mode, we will use the bg mode to do the connection to avoid some IOT issue. */
|
||||
/* Especially for Realtek 8192u SoftAP. */
|
||||
if ((padapter->securitypriv.dot11PrivacyAlgrthm != _WEP40_) &&
|
||||
(padapter->securitypriv.dot11PrivacyAlgrthm != _WEP104_) &&
|
||||
(padapter->securitypriv.dot11PrivacyAlgrthm != _TKIP_)) {
|
||||
@ -611,7 +575,7 @@ u8 rtw_disassoc_cmd(struct adapter *padapter, u32 deauth_timeout_ms, bool enqueu
|
||||
res = rtw_enqueue_cmd(cmdpriv, cmdobj);
|
||||
} else {
|
||||
/* no need to enqueue, do the cmd hdl directly and free cmd parameter */
|
||||
if (H2C_SUCCESS != disconnect_hdl(padapter, (u8 *)param))
|
||||
if (disconnect_hdl(padapter, (u8 *)param) != H2C_SUCCESS)
|
||||
res = _FAIL;
|
||||
kfree(param);
|
||||
}
|
||||
@ -629,12 +593,12 @@ u8 rtw_setopmode_cmd(struct adapter *padapter, enum ndis_802_11_network_infra n
|
||||
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
|
||||
u8 res = _SUCCESS;
|
||||
|
||||
ph2c = kzalloc(sizeof(struct cmd_obj), GFP_KERNEL);
|
||||
ph2c = kzalloc(sizeof(*ph2c), GFP_KERNEL);
|
||||
if (!ph2c) {
|
||||
res = false;
|
||||
goto exit;
|
||||
}
|
||||
psetop = kzalloc(sizeof(struct setopmode_parm), GFP_KERNEL);
|
||||
psetop = kzalloc(sizeof(*psetop), GFP_KERNEL);
|
||||
|
||||
if (!psetop) {
|
||||
kfree(ph2c);
|
||||
@ -664,20 +628,20 @@ u8 rtw_setstakey_cmd(struct adapter *padapter, u8 *psta, u8 unicast_key)
|
||||
struct sta_info *sta = (struct sta_info *)psta;
|
||||
u8 res = _SUCCESS;
|
||||
|
||||
ph2c = kzalloc(sizeof(struct cmd_obj), GFP_KERNEL);
|
||||
ph2c = kzalloc(sizeof(*ph2c), GFP_KERNEL);
|
||||
if (!ph2c) {
|
||||
res = _FAIL;
|
||||
goto exit;
|
||||
}
|
||||
|
||||
psetstakey_para = kzalloc(sizeof(struct set_stakey_parm), GFP_KERNEL);
|
||||
psetstakey_para = kzalloc(sizeof(*psetstakey_para), GFP_KERNEL);
|
||||
if (!psetstakey_para) {
|
||||
kfree(ph2c);
|
||||
res = _FAIL;
|
||||
goto exit;
|
||||
}
|
||||
|
||||
psetstakey_rsp = kzalloc(sizeof(struct set_stakey_rsp), GFP_KERNEL);
|
||||
psetstakey_rsp = kzalloc(sizeof(*psetstakey_rsp), GFP_KERNEL);
|
||||
if (!psetstakey_rsp) {
|
||||
kfree(ph2c);
|
||||
kfree(psetstakey_para);
|
||||
@ -723,13 +687,13 @@ u8 rtw_clearstakey_cmd(struct adapter *padapter, u8 *psta, u8 entry, u8 enqueue)
|
||||
if (!enqueue) {
|
||||
clear_cam_entry(padapter, entry);
|
||||
} else {
|
||||
ph2c = kzalloc(sizeof(struct cmd_obj), GFP_ATOMIC);
|
||||
ph2c = kzalloc(sizeof(*ph2c), GFP_ATOMIC);
|
||||
if (!ph2c) {
|
||||
res = _FAIL;
|
||||
goto exit;
|
||||
}
|
||||
|
||||
psetstakey_para = kzalloc(sizeof(struct set_stakey_parm),
|
||||
psetstakey_para = kzalloc(sizeof(*psetstakey_para),
|
||||
GFP_ATOMIC);
|
||||
if (!psetstakey_para) {
|
||||
kfree(ph2c);
|
||||
@ -737,7 +701,7 @@ u8 rtw_clearstakey_cmd(struct adapter *padapter, u8 *psta, u8 entry, u8 enqueue)
|
||||
goto exit;
|
||||
}
|
||||
|
||||
psetstakey_rsp = kzalloc(sizeof(struct set_stakey_rsp),
|
||||
psetstakey_rsp = kzalloc(sizeof(*psetstakey_rsp),
|
||||
GFP_ATOMIC);
|
||||
if (!psetstakey_rsp) {
|
||||
kfree(ph2c);
|
||||
@ -770,13 +734,13 @@ u8 rtw_addbareq_cmd(struct adapter *padapter, u8 tid, u8 *addr)
|
||||
struct addBaReq_parm *paddbareq_parm;
|
||||
u8 res = _SUCCESS;
|
||||
|
||||
ph2c = kzalloc(sizeof(struct cmd_obj), GFP_ATOMIC);
|
||||
ph2c = kzalloc(sizeof(*ph2c), GFP_ATOMIC);
|
||||
if (!ph2c) {
|
||||
res = _FAIL;
|
||||
goto exit;
|
||||
}
|
||||
|
||||
paddbareq_parm = kzalloc(sizeof(struct addBaReq_parm), GFP_ATOMIC);
|
||||
paddbareq_parm = kzalloc(sizeof(*paddbareq_parm), GFP_ATOMIC);
|
||||
if (!paddbareq_parm) {
|
||||
kfree(ph2c);
|
||||
res = _FAIL;
|
||||
@ -803,13 +767,13 @@ u8 rtw_dynamic_chk_wk_cmd(struct adapter *padapter)
|
||||
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
|
||||
u8 res = _SUCCESS;
|
||||
|
||||
ph2c = kzalloc(sizeof(struct cmd_obj), GFP_ATOMIC);
|
||||
ph2c = kzalloc(sizeof(*ph2c), GFP_ATOMIC);
|
||||
if (!ph2c) {
|
||||
res = _FAIL;
|
||||
goto exit;
|
||||
}
|
||||
|
||||
pdrvextra_cmd_parm = kzalloc(sizeof(struct drvextra_cmd_parm), GFP_ATOMIC);
|
||||
pdrvextra_cmd_parm = kzalloc(sizeof(*pdrvextra_cmd_parm), GFP_ATOMIC);
|
||||
if (!pdrvextra_cmd_parm) {
|
||||
kfree(ph2c);
|
||||
res = _FAIL;
|
||||
@ -844,7 +808,7 @@ u8 rtw_set_chplan_cmd(struct adapter *padapter, u8 chplan)
|
||||
}
|
||||
|
||||
/* prepare cmd parameter */
|
||||
setChannelPlan_param = kzalloc(sizeof(struct SetChannelPlan_param),
|
||||
setChannelPlan_param = kzalloc(sizeof(*setChannelPlan_param),
|
||||
GFP_KERNEL);
|
||||
if (!setChannelPlan_param) {
|
||||
res = _FAIL;
|
||||
@ -853,7 +817,7 @@ u8 rtw_set_chplan_cmd(struct adapter *padapter, u8 chplan)
|
||||
setChannelPlan_param->channel_plan = chplan;
|
||||
|
||||
/* need enqueue, prepare cmd_obj and enqueue */
|
||||
pcmdobj = kzalloc(sizeof(struct cmd_obj), GFP_KERNEL);
|
||||
pcmdobj = kzalloc(sizeof(*pcmdobj), GFP_KERNEL);
|
||||
if (!pcmdobj) {
|
||||
kfree(setChannelPlan_param);
|
||||
res = _FAIL;
|
||||
@ -983,12 +947,12 @@ static void lps_ctrl_wk_hdl(struct adapter *padapter, u8 lps_ctrl_type)
|
||||
mstatus = 1;/* connect */
|
||||
/* Reset LPS Setting */
|
||||
padapter->pwrctrlpriv.LpsIdleCount = 0;
|
||||
SetHwReg8188EU(padapter, HW_VAR_H2C_FW_JOINBSSRPT, (u8 *)(&mstatus));
|
||||
rtl8188e_set_FwJoinBssReport_cmd(padapter, mstatus);
|
||||
break;
|
||||
case LPS_CTRL_DISCONNECT:
|
||||
mstatus = 0;/* disconnect */
|
||||
LPS_Leave(padapter);
|
||||
SetHwReg8188EU(padapter, HW_VAR_H2C_FW_JOINBSSRPT, (u8 *)(&mstatus));
|
||||
rtl8188e_set_FwJoinBssReport_cmd(padapter, mstatus);
|
||||
break;
|
||||
case LPS_CTRL_SPECIAL_PACKET:
|
||||
pwrpriv->DelayLPSLastTimeStamp = jiffies;
|
||||
@ -1012,16 +976,16 @@ u8 rtw_lps_ctrl_wk_cmd(struct adapter *padapter, u8 lps_ctrl_type, u8 enqueue)
|
||||
u8 res = _SUCCESS;
|
||||
|
||||
/* if (!pwrctrlpriv->bLeisurePs) */
|
||||
/* return res; */
|
||||
/* return res; */
|
||||
|
||||
if (enqueue) {
|
||||
ph2c = kzalloc(sizeof(struct cmd_obj), GFP_ATOMIC);
|
||||
ph2c = kzalloc(sizeof(*ph2c), GFP_ATOMIC);
|
||||
if (!ph2c) {
|
||||
res = _FAIL;
|
||||
goto exit;
|
||||
}
|
||||
|
||||
pdrvextra_cmd_parm = kzalloc(sizeof(struct drvextra_cmd_parm),
|
||||
pdrvextra_cmd_parm = kzalloc(sizeof(*pdrvextra_cmd_parm),
|
||||
GFP_ATOMIC);
|
||||
if (!pdrvextra_cmd_parm) {
|
||||
kfree(ph2c);
|
||||
@ -1047,7 +1011,10 @@ u8 rtw_lps_ctrl_wk_cmd(struct adapter *padapter, u8 lps_ctrl_type, u8 enqueue)
|
||||
|
||||
static void rpt_timer_setting_wk_hdl(struct adapter *padapter, u16 min_time)
|
||||
{
|
||||
SetHwReg8188EU(padapter, HW_VAR_RPT_TIMER_SETTING, (u8 *)(&min_time));
|
||||
struct hal_data_8188e *haldata = &padapter->haldata;
|
||||
struct odm_dm_struct *odmpriv = &haldata->odmpriv;
|
||||
|
||||
ODM_RA_Set_TxRPT_Time(odmpriv, min_time);
|
||||
}
|
||||
|
||||
u8 rtw_rpt_timer_cfg_cmd(struct adapter *padapter, u16 min_time)
|
||||
@ -1058,13 +1025,13 @@ u8 rtw_rpt_timer_cfg_cmd(struct adapter *padapter, u16 min_time)
|
||||
|
||||
u8 res = _SUCCESS;
|
||||
|
||||
ph2c = kzalloc(sizeof(struct cmd_obj), GFP_ATOMIC);
|
||||
ph2c = kzalloc(sizeof(*ph2c), GFP_ATOMIC);
|
||||
if (!ph2c) {
|
||||
res = _FAIL;
|
||||
goto exit;
|
||||
}
|
||||
|
||||
pdrvextra_cmd_parm = kzalloc(sizeof(struct drvextra_cmd_parm),
|
||||
pdrvextra_cmd_parm = kzalloc(sizeof(*pdrvextra_cmd_parm),
|
||||
GFP_ATOMIC);
|
||||
if (!pdrvextra_cmd_parm) {
|
||||
kfree(ph2c);
|
||||
@ -1084,7 +1051,20 @@ u8 rtw_rpt_timer_cfg_cmd(struct adapter *padapter, u16 min_time)
|
||||
|
||||
static void antenna_select_wk_hdl(struct adapter *padapter, u8 antenna)
|
||||
{
|
||||
SetHwReg8188EU(padapter, HW_VAR_ANTENNA_DIVERSITY_SELECT, (u8 *)(&antenna));
|
||||
struct hal_data_8188e *haldata = &padapter->haldata;
|
||||
|
||||
/* switch current antenna to optimum antenna */
|
||||
if (haldata->CurAntenna != antenna) {
|
||||
ODM_UpdateRxIdleAnt_88E(&haldata->odmpriv, antenna == 2 ? MAIN_ANT : AUX_ANT);
|
||||
haldata->CurAntenna = antenna;
|
||||
}
|
||||
}
|
||||
|
||||
static bool rtw_antenna_diversity(struct adapter *adapter)
|
||||
{
|
||||
struct hal_data_8188e *haldata = &adapter->haldata;
|
||||
|
||||
return haldata->AntDivCfg != 0;
|
||||
}
|
||||
|
||||
u8 rtw_antenna_select_cmd(struct adapter *padapter, u8 antenna, u8 enqueue)
|
||||
@ -1092,21 +1072,19 @@ u8 rtw_antenna_select_cmd(struct adapter *padapter, u8 antenna, u8 enqueue)
|
||||
struct cmd_obj *ph2c;
|
||||
struct drvextra_cmd_parm *pdrvextra_cmd_parm;
|
||||
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
|
||||
u8 support_ant_div;
|
||||
u8 res = _SUCCESS;
|
||||
|
||||
GetHalDefVar8188EUsb(padapter, HAL_DEF_IS_SUPPORT_ANT_DIV, &support_ant_div);
|
||||
if (!support_ant_div)
|
||||
if (!rtw_antenna_diversity(padapter))
|
||||
return res;
|
||||
|
||||
if (enqueue) {
|
||||
ph2c = kzalloc(sizeof(struct cmd_obj), GFP_KERNEL);
|
||||
ph2c = kzalloc(sizeof(*ph2c), GFP_KERNEL);
|
||||
if (!ph2c) {
|
||||
res = _FAIL;
|
||||
goto exit;
|
||||
}
|
||||
|
||||
pdrvextra_cmd_parm = kzalloc(sizeof(struct drvextra_cmd_parm),
|
||||
pdrvextra_cmd_parm = kzalloc(sizeof(*pdrvextra_cmd_parm),
|
||||
GFP_KERNEL);
|
||||
if (!pdrvextra_cmd_parm) {
|
||||
kfree(ph2c);
|
||||
@ -1139,13 +1117,13 @@ u8 p2p_protocol_wk_cmd(struct adapter *padapter, int intCmdType)
|
||||
if (rtw_p2p_chk_state(pwdinfo, P2P_STATE_NONE))
|
||||
return res;
|
||||
|
||||
ph2c = kzalloc(sizeof(struct cmd_obj), GFP_ATOMIC);
|
||||
ph2c = kzalloc(sizeof(*ph2c), GFP_ATOMIC);
|
||||
if (!ph2c) {
|
||||
res = _FAIL;
|
||||
goto exit;
|
||||
}
|
||||
|
||||
pdrvextra_cmd_parm = kzalloc(sizeof(struct drvextra_cmd_parm), GFP_ATOMIC);
|
||||
pdrvextra_cmd_parm = kzalloc(sizeof(*pdrvextra_cmd_parm), GFP_ATOMIC);
|
||||
if (!pdrvextra_cmd_parm) {
|
||||
kfree(ph2c);
|
||||
res = _FAIL;
|
||||
@ -1153,8 +1131,8 @@ u8 p2p_protocol_wk_cmd(struct adapter *padapter, int intCmdType)
|
||||
}
|
||||
|
||||
pdrvextra_cmd_parm->ec_id = P2P_PROTO_WK_CID;
|
||||
pdrvextra_cmd_parm->type_size = intCmdType; /* As the command tppe. */
|
||||
pdrvextra_cmd_parm->pbuf = NULL; /* Must be NULL here */
|
||||
pdrvextra_cmd_parm->type_size = intCmdType; /* As the command type. */
|
||||
pdrvextra_cmd_parm->pbuf = NULL; /* Must be NULL here */
|
||||
|
||||
init_h2fwcmd_w_parm_no_rsp(ph2c, pdrvextra_cmd_parm, GEN_CMD_CODE(_Set_Drv_Extra));
|
||||
|
||||
@ -1173,13 +1151,13 @@ u8 rtw_ps_cmd(struct adapter *padapter)
|
||||
|
||||
u8 res = _SUCCESS;
|
||||
|
||||
ppscmd = kzalloc(sizeof(struct cmd_obj), GFP_ATOMIC);
|
||||
ppscmd = kzalloc(sizeof(*ppscmd), GFP_ATOMIC);
|
||||
if (!ppscmd) {
|
||||
res = _FAIL;
|
||||
goto exit;
|
||||
}
|
||||
|
||||
pdrvextra_cmd_parm = kzalloc(sizeof(struct drvextra_cmd_parm), GFP_ATOMIC);
|
||||
pdrvextra_cmd_parm = kzalloc(sizeof(*pdrvextra_cmd_parm), GFP_ATOMIC);
|
||||
if (!pdrvextra_cmd_parm) {
|
||||
kfree(ppscmd);
|
||||
res = _FAIL;
|
||||
@ -1197,6 +1175,11 @@ u8 rtw_ps_cmd(struct adapter *padapter)
|
||||
return res;
|
||||
}
|
||||
|
||||
static bool rtw_is_hi_queue_empty(struct adapter *adapter)
|
||||
{
|
||||
return (rtw_read32(adapter, REG_HGQ_INFORMATION) & 0x0000ff00) == 0;
|
||||
}
|
||||
|
||||
static void rtw_chk_hi_queue_hdl(struct adapter *padapter)
|
||||
{
|
||||
int cnt = 0;
|
||||
@ -1208,12 +1191,7 @@ static void rtw_chk_hi_queue_hdl(struct adapter *padapter)
|
||||
return;
|
||||
|
||||
if (psta_bmc->sleepq_len == 0) {
|
||||
u8 val = 0;
|
||||
|
||||
/* while ((rtw_read32(padapter, 0x414)&0x00ffff00)!= 0) */
|
||||
/* while ((rtw_read32(padapter, 0x414)&0x0000ff00)!= 0) */
|
||||
|
||||
GetHwReg8188EU(padapter, HW_VAR_CHK_HI_QUEUE_EMPTY, &val);
|
||||
bool val = rtw_is_hi_queue_empty(padapter);
|
||||
|
||||
while (!val) {
|
||||
msleep(100);
|
||||
@ -1223,7 +1201,7 @@ static void rtw_chk_hi_queue_hdl(struct adapter *padapter)
|
||||
if (cnt > 10)
|
||||
break;
|
||||
|
||||
GetHwReg8188EU(padapter, HW_VAR_CHK_HI_QUEUE_EMPTY, &val);
|
||||
val = rtw_is_hi_queue_empty(padapter);
|
||||
}
|
||||
|
||||
if (cnt <= 10) {
|
||||
@ -1244,13 +1222,13 @@ u8 rtw_chk_hi_queue_cmd(struct adapter *padapter)
|
||||
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
|
||||
u8 res = _SUCCESS;
|
||||
|
||||
ph2c = kzalloc(sizeof(struct cmd_obj), GFP_ATOMIC);
|
||||
ph2c = kzalloc(sizeof(*ph2c), GFP_ATOMIC);
|
||||
if (!ph2c) {
|
||||
res = _FAIL;
|
||||
goto exit;
|
||||
}
|
||||
|
||||
pdrvextra_cmd_parm = kzalloc(sizeof(struct drvextra_cmd_parm), GFP_ATOMIC);
|
||||
pdrvextra_cmd_parm = kzalloc(sizeof(*pdrvextra_cmd_parm), GFP_ATOMIC);
|
||||
if (!pdrvextra_cmd_parm) {
|
||||
kfree(ph2c);
|
||||
res = _FAIL;
|
||||
@ -1275,13 +1253,13 @@ u8 rtw_c2h_wk_cmd(struct adapter *padapter, u8 *c2h_evt)
|
||||
struct cmd_priv *pcmdpriv = &padapter->cmdpriv;
|
||||
u8 res = _SUCCESS;
|
||||
|
||||
ph2c = kzalloc(sizeof(struct cmd_obj), GFP_ATOMIC);
|
||||
ph2c = kzalloc(sizeof(*ph2c), GFP_ATOMIC);
|
||||
if (!ph2c) {
|
||||
res = _FAIL;
|
||||
goto exit;
|
||||
}
|
||||
|
||||
pdrvextra_cmd_parm = kzalloc(sizeof(struct drvextra_cmd_parm), GFP_ATOMIC);
|
||||
pdrvextra_cmd_parm = kzalloc(sizeof(*pdrvextra_cmd_parm), GFP_ATOMIC);
|
||||
if (!pdrvextra_cmd_parm) {
|
||||
kfree(ph2c);
|
||||
res = _FAIL;
|
||||
@ -1380,8 +1358,8 @@ u8 rtw_drvextra_cmd_hdl(struct adapter *padapter, unsigned char *pbuf)
|
||||
p2p_ps_wk_hdl(padapter, pdrvextra_cmd->type_size);
|
||||
break;
|
||||
case P2P_PROTO_WK_CID:
|
||||
/* Commented by Albert 2011/07/01 */
|
||||
/* I used the type_size as the type command */
|
||||
/* Commented by Albert 2011/07/01 */
|
||||
/* I used the type_size as the type command */
|
||||
p2p_protocol_wk_hdl(padapter, pdrvextra_cmd->type_size);
|
||||
break;
|
||||
case CHECK_HIQ_WK_CID:
|
||||
@ -1404,11 +1382,8 @@ void rtw_survey_cmd_callback(struct adapter *padapter, struct cmd_obj *pcmd)
|
||||
{
|
||||
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
|
||||
|
||||
if (pcmd->res == H2C_DROPPED) {
|
||||
if (pcmd->res != H2C_SUCCESS) {
|
||||
/* TODO: cancel timer and do timeout handler directly... */
|
||||
/* need to make timeout handlerOS independent */
|
||||
_set_timer(&pmlmepriv->scan_to_timer, 1);
|
||||
} else if (pcmd->res != H2C_SUCCESS) {
|
||||
_set_timer(&pmlmepriv->scan_to_timer, 1);
|
||||
}
|
||||
|
||||
@ -1416,6 +1391,7 @@ void rtw_survey_cmd_callback(struct adapter *padapter, struct cmd_obj *pcmd)
|
||||
rtw_free_cmd_obj(pcmd);
|
||||
|
||||
}
|
||||
|
||||
void rtw_disassoc_cmd_callback(struct adapter *padapter, struct cmd_obj *pcmd)
|
||||
{
|
||||
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
|
||||
@ -1426,8 +1402,10 @@ void rtw_disassoc_cmd_callback(struct adapter *padapter, struct cmd_obj *pcmd)
|
||||
spin_unlock_bh(&pmlmepriv->lock);
|
||||
|
||||
return;
|
||||
} else /* clear bridge database */
|
||||
nat25_db_cleanup(padapter);
|
||||
}
|
||||
|
||||
/* clear bridge database */
|
||||
nat25_db_cleanup(padapter);
|
||||
|
||||
/* free cmd */
|
||||
rtw_free_cmd_obj(pcmd);
|
||||
@ -1437,11 +1415,8 @@ void rtw_joinbss_cmd_callback(struct adapter *padapter, struct cmd_obj *pcmd)
|
||||
{
|
||||
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
|
||||
|
||||
if (pcmd->res == H2C_DROPPED) {
|
||||
if (pcmd->res != H2C_SUCCESS) {
|
||||
/* TODO: cancel timer and do timeout handler directly... */
|
||||
/* need to make timeout handlerOS independent */
|
||||
_set_timer(&pmlmepriv->assoc_timer, 1);
|
||||
} else if (pcmd->res != H2C_SUCCESS) {
|
||||
_set_timer(&pmlmepriv->assoc_timer, 1);
|
||||
}
|
||||
|
||||
@ -1474,7 +1449,7 @@ void rtw_createbss_cmd_callback(struct adapter *padapter, struct cmd_obj *pcmd)
|
||||
rtw_indicate_connect(padapter);
|
||||
} else {
|
||||
|
||||
pwlan = _rtw_alloc_network(pmlmepriv);
|
||||
pwlan = rtw_alloc_network(pmlmepriv);
|
||||
spin_lock_bh(&pmlmepriv->scanned_queue.lock);
|
||||
if (!pwlan) {
|
||||
pwlan = rtw_get_oldest_wlan_network(&pmlmepriv->scanned_queue);
|
||||
|
@ -4,51 +4,43 @@
|
||||
#include <linux/firmware.h>
|
||||
#include "../include/rtw_fw.h"
|
||||
|
||||
#define MAX_REG_BOLCK_SIZE 196
|
||||
#define MAX_REG_BLOCK_SIZE 196
|
||||
#define FW_8188E_START_ADDRESS 0x1000
|
||||
#define MAX_PAGE_SIZE 4096
|
||||
|
||||
#define IS_FW_HEADER_EXIST(_fwhdr) \
|
||||
((le16_to_cpu(_fwhdr->Signature) & 0xFFF0) == 0x92C0 || \
|
||||
(le16_to_cpu(_fwhdr->Signature) & 0xFFF0) == 0x88C0 || \
|
||||
(le16_to_cpu(_fwhdr->Signature) & 0xFFF0) == 0x2300 || \
|
||||
(le16_to_cpu(_fwhdr->Signature) & 0xFFF0) == 0x88E0)
|
||||
|
||||
/* This structure must be careful with byte-ordering */
|
||||
((le16_to_cpu(_fwhdr->signature) & 0xFFF0) == 0x92C0 || \
|
||||
(le16_to_cpu(_fwhdr->signature) & 0xFFF0) == 0x88C0 || \
|
||||
(le16_to_cpu(_fwhdr->signature) & 0xFFF0) == 0x2300 || \
|
||||
(le16_to_cpu(_fwhdr->signature) & 0xFFF0) == 0x88E0)
|
||||
|
||||
struct rt_firmware_hdr {
|
||||
/* 8-byte alinment required */
|
||||
/* LONG WORD 0 ---- */
|
||||
__le16 Signature; /* 92C0: test chip; 92C,
|
||||
* 88C0: test chip; 88C1: MP A-cut;
|
||||
* 92C1: MP A-cut */
|
||||
u8 Category; /* AP/NIC and USB/PCI */
|
||||
u8 Function; /* Reserved for different FW function
|
||||
* indcation, for further use when
|
||||
* driver needs to download different
|
||||
* FW for different conditions */
|
||||
__le16 Version; /* FW Version */
|
||||
u8 Subversion; /* FW Subversion, default 0x00 */
|
||||
u16 Rsvd1;
|
||||
|
||||
/* LONG WORD 1 ---- */
|
||||
u8 Month; /* Release time Month field */
|
||||
u8 Date; /* Release time Date field */
|
||||
u8 Hour; /* Release time Hour field */
|
||||
u8 Minute; /* Release time Minute field */
|
||||
__le16 RamCodeSize; /* The size of RAM code */
|
||||
u8 Foundry;
|
||||
u8 Rsvd2;
|
||||
|
||||
/* LONG WORD 2 ---- */
|
||||
__le32 SvnIdx; /* The SVN entry index */
|
||||
u32 Rsvd3;
|
||||
|
||||
/* LONG WORD 3 ---- */
|
||||
u32 Rsvd4;
|
||||
u32 Rsvd5;
|
||||
__le16 signature; /* 92C0: test chip; 92C,
|
||||
* 88C0: test chip; 88C1: MP A-cut;
|
||||
* 92C1: MP A-cut */
|
||||
u8 category; /* AP/NIC and USB/PCI */
|
||||
u8 function; /* Reserved for different FW function
|
||||
* indcation, for further use when
|
||||
* driver needs to download different
|
||||
* FW for different conditions */
|
||||
__le16 version; /* FW Version */
|
||||
u8 subversion; /* FW Subversion, default 0x00 */
|
||||
u8 rsvd1;
|
||||
u8 month; /* Release time Month field */
|
||||
u8 date; /* Release time Date field */
|
||||
u8 hour; /* Release time Hour field */
|
||||
u8 minute; /* Release time Minute field */
|
||||
__le16 ramcodesize; /* The size of RAM code */
|
||||
u8 foundry;
|
||||
u8 rsvd2;
|
||||
__le32 svnidx; /* The SVN entry index */
|
||||
__le32 rsvd3;
|
||||
__le32 rsvd4;
|
||||
__le32 rsvd5;
|
||||
};
|
||||
|
||||
static_assert(sizeof(struct rt_firmware_hdr) == 32);
|
||||
|
||||
static void fw_download_enable(struct adapter *padapter, bool enable)
|
||||
{
|
||||
u8 tmp;
|
||||
@ -71,53 +63,55 @@ static void fw_download_enable(struct adapter *padapter, bool enable)
|
||||
}
|
||||
}
|
||||
|
||||
static int block_write(struct adapter *padapter, void *buffer, u32 buffSize)
|
||||
static int block_write(struct adapter *padapter, u8 *buffer, u32 size)
|
||||
{
|
||||
int ret = _SUCCESS;
|
||||
u32 blockSize_p1 = 4; /* (Default) Phase #1 : PCI muse use 4-byte write to download FW */
|
||||
u32 blockSize_p2 = 8; /* Phase #2 : Use 8-byte, if Phase#1 use big size to write FW. */
|
||||
u32 blockSize_p3 = 1; /* Phase #3 : Use 1-byte, the remnant of FW image. */
|
||||
u32 blockCount_p1 = 0, blockCount_p2 = 0, blockCount_p3 = 0;
|
||||
u32 remainSize_p1 = 0, remainSize_p2 = 0;
|
||||
u8 *bufferPtr = (u8 *)buffer;
|
||||
u32 i = 0, offset = 0;
|
||||
u32 blocks, block_size, remain;
|
||||
u32 i, offset, addr;
|
||||
u8 *data;
|
||||
|
||||
blockSize_p1 = MAX_REG_BOLCK_SIZE;
|
||||
block_size = MAX_REG_BLOCK_SIZE;
|
||||
|
||||
/* 3 Phase #1 */
|
||||
blockCount_p1 = buffSize / blockSize_p1;
|
||||
remainSize_p1 = buffSize % blockSize_p1;
|
||||
blocks = size / block_size;
|
||||
remain = size % block_size;
|
||||
|
||||
for (i = 0; i < blockCount_p1; i++) {
|
||||
ret = rtw_writeN(padapter, (FW_8188E_START_ADDRESS + i * blockSize_p1), blockSize_p1, (bufferPtr + i * blockSize_p1));
|
||||
for (i = 0; i < blocks; i++) {
|
||||
addr = FW_8188E_START_ADDRESS + i * block_size;
|
||||
data = buffer + i * block_size;
|
||||
|
||||
ret = rtw_writeN(padapter, addr, block_size, data);
|
||||
if (ret == _FAIL)
|
||||
goto exit;
|
||||
}
|
||||
|
||||
/* 3 Phase #2 */
|
||||
if (remainSize_p1) {
|
||||
offset = blockCount_p1 * blockSize_p1;
|
||||
if (remain) {
|
||||
offset = blocks * block_size;
|
||||
block_size = 8;
|
||||
|
||||
blockCount_p2 = remainSize_p1 / blockSize_p2;
|
||||
remainSize_p2 = remainSize_p1 % blockSize_p2;
|
||||
blocks = remain / block_size;
|
||||
remain = remain % block_size;
|
||||
|
||||
for (i = 0; i < blockCount_p2; i++) {
|
||||
ret = rtw_writeN(padapter, (FW_8188E_START_ADDRESS + offset + i * blockSize_p2), blockSize_p2, (bufferPtr + offset + i * blockSize_p2));
|
||||
for (i = 0; i < blocks; i++) {
|
||||
addr = FW_8188E_START_ADDRESS + offset + i * block_size;
|
||||
data = buffer + offset + i * block_size;
|
||||
|
||||
ret = rtw_writeN(padapter, addr, block_size, data);
|
||||
if (ret == _FAIL)
|
||||
goto exit;
|
||||
}
|
||||
}
|
||||
|
||||
/* 3 Phase #3 */
|
||||
if (remainSize_p2) {
|
||||
offset = (blockCount_p1 * blockSize_p1) + (blockCount_p2 * blockSize_p2);
|
||||
if (remain) {
|
||||
offset += blocks * block_size;
|
||||
|
||||
blockCount_p3 = remainSize_p2 / blockSize_p3;
|
||||
/* block size 1 */
|
||||
blocks = remain;
|
||||
|
||||
for (i = 0; i < blockCount_p3; i++) {
|
||||
ret = rtw_write8(padapter, (FW_8188E_START_ADDRESS + offset + i), *(bufferPtr + offset + i));
|
||||
for (i = 0; i < blocks; i++) {
|
||||
addr = FW_8188E_START_ADDRESS + offset + i;
|
||||
data = buffer + offset + i;
|
||||
|
||||
ret = rtw_write8(padapter, addr, *data);
|
||||
if (ret == _FAIL)
|
||||
goto exit;
|
||||
}
|
||||
@ -127,7 +121,7 @@ static int block_write(struct adapter *padapter, void *buffer, u32 buffSize)
|
||||
return ret;
|
||||
}
|
||||
|
||||
static int page_write(struct adapter *padapter, u32 page, void *buffer, u32 size)
|
||||
static int page_write(struct adapter *padapter, u32 page, u8 *buffer, u32 size)
|
||||
{
|
||||
u8 value8;
|
||||
u8 u8Page = (u8)(page & 0x07);
|
||||
@ -138,21 +132,20 @@ static int page_write(struct adapter *padapter, u32 page, void *buffer, u32 size
|
||||
return block_write(padapter, buffer, size);
|
||||
}
|
||||
|
||||
static int write_fw(struct adapter *padapter, void *buffer, u32 size)
|
||||
static int write_fw(struct adapter *padapter, u8 *buffer, u32 size)
|
||||
{
|
||||
/* Since we need dynamic decide method of dwonload fw, so we call this function to get chip version. */
|
||||
/* We can remove _ReadChipVersion from ReadpadapterInfo8192C later. */
|
||||
int ret = _SUCCESS;
|
||||
u32 pageNums, remainSize;
|
||||
u32 page, offset;
|
||||
u8 *bufferPtr = (u8 *)buffer;
|
||||
|
||||
pageNums = size / MAX_PAGE_SIZE;
|
||||
remainSize = size % MAX_PAGE_SIZE;
|
||||
|
||||
for (page = 0; page < pageNums; page++) {
|
||||
offset = page * MAX_PAGE_SIZE;
|
||||
ret = page_write(padapter, page, bufferPtr + offset, MAX_PAGE_SIZE);
|
||||
ret = page_write(padapter, page, buffer + offset, MAX_PAGE_SIZE);
|
||||
|
||||
if (ret == _FAIL)
|
||||
goto exit;
|
||||
@ -160,7 +153,7 @@ static int write_fw(struct adapter *padapter, void *buffer, u32 size)
|
||||
if (remainSize) {
|
||||
offset = pageNums * MAX_PAGE_SIZE;
|
||||
page = pageNums;
|
||||
ret = page_write(padapter, page, bufferPtr + offset, remainSize);
|
||||
ret = page_write(padapter, page, buffer + offset, remainSize);
|
||||
|
||||
if (ret == _FAIL)
|
||||
goto exit;
|
||||
@ -247,14 +240,12 @@ int rtl8188e_firmware_download(struct adapter *padapter)
|
||||
{
|
||||
int ret = _SUCCESS;
|
||||
u8 write_fw_retry = 0;
|
||||
u32 fwdl_start_time;
|
||||
unsigned long fwdl_timeout;
|
||||
struct dvobj_priv *dvobj = adapter_to_dvobj(padapter);
|
||||
struct device *device = dvobj_to_dev(dvobj);
|
||||
struct rt_firmware_hdr *fwhdr = NULL;
|
||||
u16 fw_version, fw_subversion, fw_signature;
|
||||
u8 *fw_data;
|
||||
u32 fw_size;
|
||||
static int log_version;
|
||||
|
||||
if (!dvobj->firmware.data)
|
||||
ret = load_firmware(&dvobj->firmware, device);
|
||||
@ -265,21 +256,15 @@ int rtl8188e_firmware_download(struct adapter *padapter)
|
||||
fw_data = dvobj->firmware.data;
|
||||
fw_size = dvobj->firmware.size;
|
||||
|
||||
/* To Check Fw header. Added by tynli. 2009.12.04. */
|
||||
fwhdr = (struct rt_firmware_hdr *)dvobj->firmware.data;
|
||||
|
||||
fw_version = le16_to_cpu(fwhdr->Version);
|
||||
fw_subversion = fwhdr->Subversion;
|
||||
fw_signature = le16_to_cpu(fwhdr->Signature);
|
||||
|
||||
if (!log_version++)
|
||||
pr_info("%sFirmware Version %d, SubVersion %d, Signature 0x%x\n",
|
||||
DRIVER_PREFIX, fw_version, fw_subversion, fw_signature);
|
||||
|
||||
if (IS_FW_HEADER_EXIST(fwhdr)) {
|
||||
/* Shift 32 bytes for FW header */
|
||||
fw_data = fw_data + 32;
|
||||
fw_size = fw_size - 32;
|
||||
pr_info_once("R8188EU: Firmware Version %d, SubVersion %d, Signature 0x%x\n",
|
||||
le16_to_cpu(fwhdr->version), fwhdr->subversion,
|
||||
le16_to_cpu(fwhdr->signature));
|
||||
|
||||
fw_data = fw_data + sizeof(struct rt_firmware_hdr);
|
||||
fw_size = fw_size - sizeof(struct rt_firmware_hdr);
|
||||
}
|
||||
|
||||
/* Suggested by Filen. If 8051 is running in RAM code, driver should inform Fw to reset by itself, */
|
||||
@ -290,7 +275,7 @@ int rtl8188e_firmware_download(struct adapter *padapter)
|
||||
}
|
||||
|
||||
fw_download_enable(padapter, true);
|
||||
fwdl_start_time = jiffies;
|
||||
fwdl_timeout = jiffies + msecs_to_jiffies(500);
|
||||
while (1) {
|
||||
/* reset the FWDL chksum */
|
||||
rtw_write8(padapter, REG_MCUFWDL, rtw_read8(padapter, REG_MCUFWDL) | FWDL_CHKSUM_RPT);
|
||||
@ -298,7 +283,7 @@ int rtl8188e_firmware_download(struct adapter *padapter)
|
||||
ret = write_fw(padapter, fw_data, fw_size);
|
||||
|
||||
if (ret == _SUCCESS ||
|
||||
(rtw_get_passing_time_ms(fwdl_start_time) > 500 && write_fw_retry++ >= 3))
|
||||
(time_after(jiffies, fwdl_timeout) && write_fw_retry++ >= 3))
|
||||
break;
|
||||
}
|
||||
fw_download_enable(padapter, false);
|
||||
|
@ -97,16 +97,15 @@ bool rtw_is_cckratesonly_included(u8 *rate)
|
||||
|
||||
int rtw_check_network_type(unsigned char *rate, int ratelen, int channel)
|
||||
{
|
||||
if (channel > 14) {
|
||||
if (channel > 14)
|
||||
return WIRELESS_INVALID;
|
||||
} else { /* could be pure B, pure G, or B/G */
|
||||
if (rtw_is_cckratesonly_included(rate))
|
||||
return WIRELESS_11B;
|
||||
else if (rtw_is_cckrates_included(rate))
|
||||
return WIRELESS_11BG;
|
||||
else
|
||||
return WIRELESS_11G;
|
||||
}
|
||||
/* could be pure B, pure G, or B/G */
|
||||
if (rtw_is_cckratesonly_included(rate))
|
||||
return WIRELESS_11B;
|
||||
else if (rtw_is_cckrates_included(rate))
|
||||
return WIRELESS_11BG;
|
||||
else
|
||||
return WIRELESS_11G;
|
||||
}
|
||||
|
||||
u8 *rtw_set_fixed_ie(unsigned char *pbuf, unsigned int len, unsigned char *source,
|
||||
@ -160,11 +159,10 @@ u8 *rtw_get_ie(u8 *pbuf, int index, int *len, int limit)
|
||||
if (*p == index) {
|
||||
*len = *(p + 1);
|
||||
return p;
|
||||
} else {
|
||||
tmp = *(p + 1);
|
||||
p += (tmp + 2);
|
||||
i += (tmp + 2);
|
||||
}
|
||||
tmp = *(p + 1);
|
||||
p += (tmp + 2);
|
||||
i += (tmp + 2);
|
||||
if (i >= limit)
|
||||
break;
|
||||
}
|
||||
@ -295,10 +293,9 @@ unsigned char *rtw_get_wpa_ie(unsigned char *pie, int *wpa_ie_len, int limit)
|
||||
goto check_next_ie;
|
||||
*wpa_ie_len = *(pbuf + 1);
|
||||
return pbuf;
|
||||
} else {
|
||||
*wpa_ie_len = 0;
|
||||
return NULL;
|
||||
}
|
||||
*wpa_ie_len = 0;
|
||||
return NULL;
|
||||
|
||||
check_next_ie:
|
||||
limit_new = limit - (pbuf - pie) - 2 - len;
|
||||
@ -558,9 +555,8 @@ u8 *rtw_get_wps_ie(u8 *in_ie, uint in_len, u8 *wps_ie, uint *wps_ielen)
|
||||
cnt += in_ie[cnt + 1] + 2;
|
||||
|
||||
break;
|
||||
} else {
|
||||
cnt += in_ie[cnt + 1] + 2; /* goto next */
|
||||
}
|
||||
cnt += in_ie[cnt + 1] + 2; /* goto next */
|
||||
}
|
||||
return wpsie_ptr;
|
||||
}
|
||||
@ -604,9 +600,8 @@ u8 *rtw_get_wps_attr(u8 *wps_ie, uint wps_ielen, u16 target_attr_id, u8 *buf_att
|
||||
if (len_attr)
|
||||
*len_attr = attr_len;
|
||||
break;
|
||||
} else {
|
||||
attr_ptr += attr_len; /* goto next */
|
||||
}
|
||||
attr_ptr += attr_len; /* goto next */
|
||||
}
|
||||
return target_attr_ptr;
|
||||
}
|
||||
@ -901,9 +896,8 @@ u8 *rtw_get_p2p_ie(u8 *in_ie, int in_len, u8 *p2p_ie, uint *p2p_ielen)
|
||||
if (p2p_ielen)
|
||||
*p2p_ielen = in_ie[cnt + 1] + 2;
|
||||
return p2p_ie_ptr;
|
||||
} else {
|
||||
cnt += in_ie[cnt + 1] + 2; /* goto next */
|
||||
}
|
||||
cnt += in_ie[cnt + 1] + 2; /* goto next */
|
||||
}
|
||||
return NULL;
|
||||
}
|
||||
@ -948,9 +942,8 @@ u8 *rtw_get_p2p_attr(u8 *p2p_ie, uint p2p_ielen, u8 target_attr_id, u8 *buf_attr
|
||||
if (len_attr)
|
||||
*len_attr = attr_len;
|
||||
break;
|
||||
} else {
|
||||
attr_ptr += attr_len; /* goto next */
|
||||
}
|
||||
attr_ptr += attr_len; /* goto next */
|
||||
}
|
||||
return target_attr_ptr;
|
||||
}
|
||||
@ -1058,7 +1051,7 @@ static int rtw_get_cipher_info(struct wlan_network *pnetwork)
|
||||
pbuf = rtw_get_wpa_ie(&pnetwork->network.IEs[12], &wpa_ielen, pnetwork->network.IELength - 12);
|
||||
|
||||
if (pbuf && (wpa_ielen > 0)) {
|
||||
if (_SUCCESS == rtw_parse_wpa_ie(pbuf, wpa_ielen + 2, &group_cipher, &pairwise_cipher, &is8021x)) {
|
||||
if (rtw_parse_wpa_ie(pbuf, wpa_ielen + 2, &group_cipher, &pairwise_cipher, &is8021x) == _SUCCESS) {
|
||||
pnetwork->BcnInfo.pairwise_cipher = pairwise_cipher;
|
||||
pnetwork->BcnInfo.group_cipher = group_cipher;
|
||||
pnetwork->BcnInfo.is_8021x = is8021x;
|
||||
@ -1068,7 +1061,7 @@ static int rtw_get_cipher_info(struct wlan_network *pnetwork)
|
||||
pbuf = rtw_get_wpa2_ie(&pnetwork->network.IEs[12], &wpa_ielen, pnetwork->network.IELength - 12);
|
||||
|
||||
if (pbuf && (wpa_ielen > 0)) {
|
||||
if (_SUCCESS == rtw_parse_wpa2_ie(pbuf, wpa_ielen + 2, &group_cipher, &pairwise_cipher, &is8021x)) {
|
||||
if (rtw_parse_wpa2_ie(pbuf, wpa_ielen + 2, &group_cipher, &pairwise_cipher, &is8021x) == _SUCCESS) {
|
||||
pnetwork->BcnInfo.pairwise_cipher = pairwise_cipher;
|
||||
pnetwork->BcnInfo.group_cipher = group_cipher;
|
||||
pnetwork->BcnInfo.is_8021x = is8021x;
|
||||
|
@ -44,7 +44,7 @@ u8 rtw_do_join(struct adapter *padapter)
|
||||
pmlmepriv->to_roaming > 0) {
|
||||
/* submit site_survey_cmd */
|
||||
ret = rtw_sitesurvey_cmd(padapter, &pmlmepriv->assoc_ssid, 1, NULL, 0);
|
||||
if (_SUCCESS != ret)
|
||||
if (ret != _SUCCESS)
|
||||
pmlmepriv->to_join = false;
|
||||
} else {
|
||||
pmlmepriv->to_join = false;
|
||||
@ -91,7 +91,7 @@ u8 rtw_do_join(struct adapter *padapter)
|
||||
if (!pmlmepriv->LinkDetectInfo.bBusyTraffic ||
|
||||
pmlmepriv->to_roaming > 0) {
|
||||
ret = rtw_sitesurvey_cmd(padapter, &pmlmepriv->assoc_ssid, 1, NULL, 0);
|
||||
if (_SUCCESS != ret)
|
||||
if (ret != _SUCCESS)
|
||||
pmlmepriv->to_join = false;
|
||||
} else {
|
||||
ret = _FAIL;
|
||||
|
@ -57,10 +57,10 @@ int rtw_IOL_append_cmds(struct xmit_frame *xmit_frame, u8 *IOL_cmds, u32 cmd_len
|
||||
|
||||
bool rtw_IOL_applied(struct adapter *adapter)
|
||||
{
|
||||
if (1 == adapter->registrypriv.fw_iol)
|
||||
if (adapter->registrypriv.fw_iol == 1)
|
||||
return true;
|
||||
|
||||
if ((2 == adapter->registrypriv.fw_iol) &&
|
||||
if ((adapter->registrypriv.fw_iol == 2) &&
|
||||
(adapter_to_dvobj(adapter)->pusbdev->speed != USB_SPEED_HIGH))
|
||||
return true;
|
||||
|
||||
|
@ -110,7 +110,7 @@ static void blink_work(struct work_struct *work)
|
||||
pLed->bLedLinkBlinkInProgress = true;
|
||||
pLed->CurrLedState = LED_BLINK_NORMAL;
|
||||
schedule_delayed_work(&pLed->blink_work, LED_BLINK_LINK_INTVL);
|
||||
} else if (!check_fwstate(pmlmepriv, _FW_LINKED)) {
|
||||
} else {
|
||||
pLed->bLedNoLinkBlinkInProgress = true;
|
||||
pLed->CurrLedState = LED_BLINK_SLOWLY;
|
||||
schedule_delayed_work(&pLed->blink_work, LED_BLINK_NO_LINK_INTVL);
|
||||
@ -131,7 +131,7 @@ static void blink_work(struct work_struct *work)
|
||||
pLed->bLedLinkBlinkInProgress = true;
|
||||
pLed->CurrLedState = LED_BLINK_NORMAL;
|
||||
schedule_delayed_work(&pLed->blink_work, LED_BLINK_LINK_INTVL);
|
||||
} else if (!check_fwstate(pmlmepriv, _FW_LINKED)) {
|
||||
} else {
|
||||
pLed->bLedNoLinkBlinkInProgress = true;
|
||||
pLed->CurrLedState = LED_BLINK_SLOWLY;
|
||||
schedule_delayed_work(&pLed->blink_work, LED_BLINK_NO_LINK_INTVL);
|
||||
@ -278,7 +278,7 @@ void rtw_led_control(struct adapter *padapter, enum LED_CTL_MODE LedAction)
|
||||
else
|
||||
pLed->BlinkingLedState = RTW_LED_ON;
|
||||
schedule_delayed_work(&pLed->blink_work, LED_BLINK_SCAN_INTVL);
|
||||
}
|
||||
}
|
||||
break;
|
||||
case LED_CTL_TX:
|
||||
case LED_CTL_RX:
|
||||
@ -304,7 +304,7 @@ void rtw_led_control(struct adapter *padapter, enum LED_CTL_MODE LedAction)
|
||||
}
|
||||
break;
|
||||
case LED_CTL_START_WPS: /* wait until xinpin finish */
|
||||
if (!pLed->bLedWPSBlinkInProgress) {
|
||||
if (!pLed->bLedWPSBlinkInProgress) {
|
||||
if (pLed->bLedNoLinkBlinkInProgress) {
|
||||
cancel_delayed_work(&pLed->blink_work);
|
||||
pLed->bLedNoLinkBlinkInProgress = false;
|
||||
@ -328,7 +328,7 @@ void rtw_led_control(struct adapter *padapter, enum LED_CTL_MODE LedAction)
|
||||
else
|
||||
pLed->BlinkingLedState = RTW_LED_ON;
|
||||
schedule_delayed_work(&pLed->blink_work, LED_BLINK_SCAN_INTVL);
|
||||
}
|
||||
}
|
||||
break;
|
||||
case LED_CTL_STOP_WPS:
|
||||
if (pLed->bLedNoLinkBlinkInProgress) {
|
||||
|
@ -16,7 +16,6 @@
|
||||
#include "../include/usb_osintf.h"
|
||||
#include "../include/rtl8188e_dm.h"
|
||||
|
||||
extern unsigned char MCS_rate_2R[16];
|
||||
extern unsigned char MCS_rate_1R[16];
|
||||
|
||||
void rtw_set_roaming(struct adapter *adapter, u8 to_roaming)
|
||||
@ -31,60 +30,6 @@ u8 rtw_to_roaming(struct adapter *adapter)
|
||||
return adapter->mlmepriv.to_roaming;
|
||||
}
|
||||
|
||||
int _rtw_init_mlme_priv(struct adapter *padapter)
|
||||
{
|
||||
int i;
|
||||
u8 *pbuf;
|
||||
struct wlan_network *pnetwork;
|
||||
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
|
||||
int res = _SUCCESS;
|
||||
|
||||
/* We don't need to memset padapter->XXX to zero, because adapter is allocated by vzalloc(). */
|
||||
|
||||
pmlmepriv->nic_hdl = (u8 *)padapter;
|
||||
|
||||
pmlmepriv->pscanned = NULL;
|
||||
pmlmepriv->fw_state = 0;
|
||||
pmlmepriv->cur_network.network.InfrastructureMode = Ndis802_11AutoUnknown;
|
||||
pmlmepriv->scan_mode = SCAN_ACTIVE;/* 1: active, 0: pasive. Maybe someday we should rename this varable to "active_mode" (Jeff) */
|
||||
|
||||
spin_lock_init(&pmlmepriv->lock);
|
||||
rtw_init_queue(&pmlmepriv->free_bss_pool);
|
||||
rtw_init_queue(&pmlmepriv->scanned_queue);
|
||||
|
||||
set_scanned_network_val(pmlmepriv, 0);
|
||||
|
||||
memset(&pmlmepriv->assoc_ssid, 0, sizeof(struct ndis_802_11_ssid));
|
||||
|
||||
pbuf = vzalloc(MAX_BSS_CNT * (sizeof(struct wlan_network)));
|
||||
|
||||
if (!pbuf) {
|
||||
res = _FAIL;
|
||||
goto exit;
|
||||
}
|
||||
pmlmepriv->free_bss_buf = pbuf;
|
||||
|
||||
pnetwork = (struct wlan_network *)pbuf;
|
||||
|
||||
for (i = 0; i < MAX_BSS_CNT; i++) {
|
||||
INIT_LIST_HEAD(&pnetwork->list);
|
||||
|
||||
list_add_tail(&pnetwork->list, &pmlmepriv->free_bss_pool.queue);
|
||||
|
||||
pnetwork++;
|
||||
}
|
||||
|
||||
/* allocate DMA-able/Non-Page memory for cmd_buf and rsp_buf */
|
||||
|
||||
rtw_clear_scan_deny(padapter);
|
||||
|
||||
rtw_init_mlme_timer(padapter);
|
||||
|
||||
exit:
|
||||
|
||||
return res;
|
||||
}
|
||||
|
||||
static void rtw_free_mlme_ie_data(u8 **ppie, u32 *plen)
|
||||
{
|
||||
kfree(*ppie);
|
||||
@ -95,7 +40,6 @@ static void rtw_free_mlme_ie_data(u8 **ppie, u32 *plen)
|
||||
void rtw_free_mlme_priv_ie_data(struct mlme_priv *pmlmepriv)
|
||||
{
|
||||
kfree(pmlmepriv->assoc_req);
|
||||
kfree(pmlmepriv->assoc_rsp);
|
||||
rtw_free_mlme_ie_data(&pmlmepriv->wps_beacon_ie, &pmlmepriv->wps_beacon_ie_len);
|
||||
rtw_free_mlme_ie_data(&pmlmepriv->wps_probe_req_ie, &pmlmepriv->wps_probe_req_ie_len);
|
||||
rtw_free_mlme_ie_data(&pmlmepriv->wps_probe_resp_ie, &pmlmepriv->wps_probe_resp_ie_len);
|
||||
@ -108,49 +52,6 @@ void rtw_free_mlme_priv_ie_data(struct mlme_priv *pmlmepriv)
|
||||
rtw_free_mlme_ie_data(&pmlmepriv->p2p_assoc_req_ie, &pmlmepriv->p2p_assoc_req_ie_len);
|
||||
}
|
||||
|
||||
void _rtw_free_mlme_priv(struct mlme_priv *pmlmepriv)
|
||||
{
|
||||
|
||||
rtw_free_mlme_priv_ie_data(pmlmepriv);
|
||||
|
||||
if (pmlmepriv) {
|
||||
vfree(pmlmepriv->free_bss_buf);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
struct wlan_network *_rtw_alloc_network(struct mlme_priv *pmlmepriv)/* _queue *free_queue) */
|
||||
{
|
||||
struct wlan_network *pnetwork;
|
||||
struct __queue *free_queue = &pmlmepriv->free_bss_pool;
|
||||
struct list_head *plist = NULL;
|
||||
|
||||
spin_lock_bh(&free_queue->lock);
|
||||
|
||||
if (list_empty(&free_queue->queue)) {
|
||||
pnetwork = NULL;
|
||||
goto exit;
|
||||
}
|
||||
plist = (&free_queue->queue)->next;
|
||||
|
||||
pnetwork = container_of(plist, struct wlan_network, list);
|
||||
|
||||
list_del_init(&pnetwork->list);
|
||||
|
||||
pnetwork->network_type = 0;
|
||||
pnetwork->fixed = false;
|
||||
pnetwork->last_scanned = jiffies;
|
||||
pnetwork->aid = 0;
|
||||
pnetwork->join_res = 0;
|
||||
|
||||
pmlmepriv->num_of_scanned++;
|
||||
|
||||
exit:
|
||||
spin_unlock_bh(&free_queue->lock);
|
||||
|
||||
return pnetwork;
|
||||
}
|
||||
|
||||
void _rtw_free_network(struct mlme_priv *pmlmepriv, struct wlan_network *pnetwork, u8 isfreeall)
|
||||
{
|
||||
u32 curr_time, delta_time;
|
||||
@ -194,7 +95,7 @@ void _rtw_free_network_nolock(struct mlme_priv *pmlmepriv, struct wlan_network *
|
||||
/*
|
||||
return the wlan_network with the matching addr
|
||||
|
||||
Shall be calle under atomic context... to avoid possible racing condition...
|
||||
Shall be called under atomic context... to avoid possible racing condition...
|
||||
*/
|
||||
struct wlan_network *_rtw_find_network(struct __queue *scanned_queue, u8 *addr)
|
||||
{
|
||||
@ -291,23 +192,92 @@ u8 *rtw_get_beacon_interval_from_ie(u8 *ie)
|
||||
|
||||
int rtw_init_mlme_priv(struct adapter *padapter)/* struct mlme_priv *pmlmepriv) */
|
||||
{
|
||||
int res;
|
||||
int i;
|
||||
u8 *pbuf;
|
||||
struct wlan_network *pnetwork;
|
||||
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
|
||||
int res = _SUCCESS;
|
||||
|
||||
res = _rtw_init_mlme_priv(padapter);/* (pmlmepriv); */
|
||||
/* We don't need to memset padapter->XXX to zero, because adapter is allocated by vzalloc(). */
|
||||
|
||||
pmlmepriv->nic_hdl = (u8 *)padapter;
|
||||
|
||||
pmlmepriv->pscanned = NULL;
|
||||
pmlmepriv->fw_state = 0;
|
||||
pmlmepriv->cur_network.network.InfrastructureMode = Ndis802_11AutoUnknown;
|
||||
pmlmepriv->scan_mode = SCAN_ACTIVE;/* 1: active, 0: pasive. Maybe someday we should rename this varable to "active_mode" (Jeff) */
|
||||
|
||||
spin_lock_init(&pmlmepriv->lock);
|
||||
rtw_init_queue(&pmlmepriv->free_bss_pool);
|
||||
rtw_init_queue(&pmlmepriv->scanned_queue);
|
||||
|
||||
set_scanned_network_val(pmlmepriv, 0);
|
||||
|
||||
memset(&pmlmepriv->assoc_ssid, 0, sizeof(struct ndis_802_11_ssid));
|
||||
|
||||
pbuf = vzalloc(MAX_BSS_CNT * (sizeof(struct wlan_network)));
|
||||
|
||||
if (!pbuf) {
|
||||
res = _FAIL;
|
||||
goto exit;
|
||||
}
|
||||
pmlmepriv->free_bss_buf = pbuf;
|
||||
|
||||
pnetwork = (struct wlan_network *)pbuf;
|
||||
|
||||
for (i = 0; i < MAX_BSS_CNT; i++) {
|
||||
INIT_LIST_HEAD(&pnetwork->list);
|
||||
|
||||
list_add_tail(&pnetwork->list, &pmlmepriv->free_bss_pool.queue);
|
||||
|
||||
pnetwork++;
|
||||
}
|
||||
|
||||
/* allocate DMA-able/Non-Page memory for cmd_buf and rsp_buf */
|
||||
|
||||
rtw_clear_scan_deny(padapter);
|
||||
|
||||
rtw_init_mlme_timer(padapter);
|
||||
|
||||
exit:
|
||||
|
||||
return res;
|
||||
}
|
||||
|
||||
void rtw_free_mlme_priv(struct mlme_priv *pmlmepriv)
|
||||
{
|
||||
_rtw_free_mlme_priv(pmlmepriv);
|
||||
rtw_free_mlme_priv_ie_data(pmlmepriv);
|
||||
vfree(pmlmepriv->free_bss_buf);
|
||||
}
|
||||
|
||||
static struct wlan_network *rtw_alloc_network(struct mlme_priv *pmlmepriv)
|
||||
struct wlan_network *rtw_alloc_network(struct mlme_priv *pmlmepriv)
|
||||
{
|
||||
struct wlan_network *pnetwork;
|
||||
struct __queue *free_queue = &pmlmepriv->free_bss_pool;
|
||||
struct list_head *plist = NULL;
|
||||
|
||||
pnetwork = _rtw_alloc_network(pmlmepriv);
|
||||
spin_lock_bh(&free_queue->lock);
|
||||
|
||||
if (list_empty(&free_queue->queue)) {
|
||||
pnetwork = NULL;
|
||||
goto exit;
|
||||
}
|
||||
plist = (&free_queue->queue)->next;
|
||||
|
||||
pnetwork = container_of(plist, struct wlan_network, list);
|
||||
|
||||
list_del_init(&pnetwork->list);
|
||||
|
||||
pnetwork->network_type = 0;
|
||||
pnetwork->fixed = false;
|
||||
pnetwork->last_scanned = jiffies;
|
||||
pnetwork->aid = 0;
|
||||
pnetwork->join_res = 0;
|
||||
|
||||
pmlmepriv->num_of_scanned++;
|
||||
|
||||
exit:
|
||||
spin_unlock_bh(&free_queue->lock);
|
||||
|
||||
return pnetwork;
|
||||
}
|
||||
@ -330,7 +300,7 @@ void rtw_free_network_queue(struct adapter *dev, u8 isfreeall)
|
||||
/*
|
||||
return the wlan_network with the matching addr
|
||||
|
||||
Shall be calle under atomic context... to avoid possible racing condition...
|
||||
Shall be called under atomic context... to avoid possible racing condition...
|
||||
*/
|
||||
struct wlan_network *rtw_find_network(struct __queue *scanned_queue, u8 *addr)
|
||||
{
|
||||
@ -465,6 +435,13 @@ static void update_current_network(struct adapter *adapter, struct wlan_bssid_ex
|
||||
|
||||
}
|
||||
|
||||
u8 rtw_current_antenna(struct adapter *adapter)
|
||||
{
|
||||
struct hal_data_8188e *haldata = &adapter->haldata;
|
||||
|
||||
return haldata->CurAntenna;
|
||||
}
|
||||
|
||||
/*
|
||||
Caller must hold pmlmepriv->lock first.
|
||||
*/
|
||||
@ -498,7 +475,8 @@ void rtw_update_scanned_network(struct adapter *adapter, struct wlan_bssid_ex *t
|
||||
/* If there are no more slots, expire the oldest */
|
||||
pnetwork = oldest;
|
||||
|
||||
GetHalDefVar8188EUsb(adapter, HAL_DEF_CURRENT_ANTENNA, &target->PhyInfo.Optimum_antenna);
|
||||
target->PhyInfo.Optimum_antenna = rtw_current_antenna(adapter);
|
||||
|
||||
memcpy(&pnetwork->network, target, get_wlan_bssid_ex_sz(target));
|
||||
/* variable initialize */
|
||||
pnetwork->fixed = false;
|
||||
@ -521,7 +499,7 @@ void rtw_update_scanned_network(struct adapter *adapter, struct wlan_bssid_ex *t
|
||||
|
||||
bssid_ex_sz = get_wlan_bssid_ex_sz(target);
|
||||
target->Length = bssid_ex_sz;
|
||||
GetHalDefVar8188EUsb(adapter, HAL_DEF_CURRENT_ANTENNA, &target->PhyInfo.Optimum_antenna);
|
||||
target->PhyInfo.Optimum_antenna = rtw_current_antenna(adapter);
|
||||
memcpy(&pnetwork->network, target, bssid_ex_sz);
|
||||
|
||||
pnetwork->last_scanned = jiffies;
|
||||
@ -567,8 +545,8 @@ static void rtw_add_network(struct adapter *adapter,
|
||||
|
||||
/* select the desired network based on the capability of the (i)bss. */
|
||||
/* check items: (1) security */
|
||||
/* (2) network_type */
|
||||
/* (3) WMM */
|
||||
/* (2) network_type */
|
||||
/* (3) WMM */
|
||||
/* (4) HT */
|
||||
/* (5) others */
|
||||
static bool rtw_is_desired_network(struct adapter *adapter, struct wlan_network *pnetwork)
|
||||
@ -715,15 +693,12 @@ void rtw_surveydone_event_callback(struct adapter *adapter, u8 *pbuf)
|
||||
set_fwstate(pmlmepriv, _FW_UNDER_LINKING);
|
||||
pmlmepriv->to_join = false;
|
||||
s_ret = rtw_select_and_join_from_scanned_queue(pmlmepriv);
|
||||
if (_SUCCESS == s_ret) {
|
||||
_set_timer(&pmlmepriv->assoc_timer, MAX_JOIN_TIMEOUT);
|
||||
} else if (s_ret == 2) { /* there is no need to wait for join */
|
||||
_clr_fwstate_(pmlmepriv, _FW_UNDER_LINKING);
|
||||
rtw_indicate_connect(adapter);
|
||||
if (s_ret == _SUCCESS) {
|
||||
_set_timer(&pmlmepriv->assoc_timer, MAX_JOIN_TIMEOUT);
|
||||
} else {
|
||||
if (rtw_to_roaming(adapter) != 0) {
|
||||
if (--pmlmepriv->to_roaming == 0 ||
|
||||
_SUCCESS != rtw_sitesurvey_cmd(adapter, &pmlmepriv->assoc_ssid, 1, NULL, 0)) {
|
||||
rtw_sitesurvey_cmd(adapter, &pmlmepriv->assoc_ssid, 1, NULL, 0) != _SUCCESS) {
|
||||
rtw_set_roaming(adapter, 0);
|
||||
rtw_free_assoc_resources(adapter, 1);
|
||||
rtw_indicate_disconnect(adapter);
|
||||
@ -748,14 +723,6 @@ void rtw_surveydone_event_callback(struct adapter *adapter, u8 *pbuf)
|
||||
rtw_os_xmit_schedule(adapter);
|
||||
}
|
||||
|
||||
void rtw_dummy_event_callback(struct adapter *adapter, u8 *pbuf)
|
||||
{
|
||||
}
|
||||
|
||||
void rtw_fwdbg_event_callback(struct adapter *adapter, u8 *pbuf)
|
||||
{
|
||||
}
|
||||
|
||||
static void free_scanqueue(struct mlme_priv *pmlmepriv)
|
||||
{
|
||||
struct __queue *free_queue = &pmlmepriv->free_bss_pool;
|
||||
@ -911,9 +878,8 @@ static struct sta_info *rtw_joinbss_update_stainfo(struct adapter *padapter, str
|
||||
memset((u8 *)&psta->dot11txpn, 0, sizeof(union pn48));
|
||||
memset((u8 *)&psta->dot11rxpn, 0, sizeof(union pn48));
|
||||
}
|
||||
/* Commented by Albert 2012/07/21 */
|
||||
/* When doing the WPS, the wps_ie_len won't equal to 0 */
|
||||
/* And the Wi-Fi driver shouldn't allow the data packet to be tramsmitted. */
|
||||
/* When doing the WPS, the wps_ie_len won't equal to 0 */
|
||||
/* And the Wi-Fi driver shouldn't allow the data packet to be transmitted. */
|
||||
if (padapter->securitypriv.wps_ie_len != 0) {
|
||||
psta->ieee8021x_blocked = true;
|
||||
padapter->securitypriv.wps_ie_len = 0;
|
||||
@ -1071,8 +1037,10 @@ void rtw_joinbss_event_prehandle(struct adapter *adapter, u8 *pbuf)
|
||||
rtw_indicate_connect(adapter);
|
||||
}
|
||||
|
||||
spin_unlock_bh(&pmlmepriv->lock);
|
||||
/* s5. Cancel assoc_timer */
|
||||
del_timer_sync(&pmlmepriv->assoc_timer);
|
||||
spin_lock_bh(&pmlmepriv->lock);
|
||||
} else {
|
||||
spin_unlock_bh(&pmlmepriv->scanned_queue.lock);
|
||||
goto ignore_joinbss_callback;
|
||||
@ -1105,6 +1073,11 @@ void rtw_joinbss_event_callback(struct adapter *adapter, u8 *pbuf)
|
||||
|
||||
}
|
||||
|
||||
void rtw_set_max_rpt_macid(struct adapter *adapter, u8 macid)
|
||||
{
|
||||
rtw_write8(adapter, REG_TX_RPT_CTRL + 1, macid + 1);
|
||||
}
|
||||
|
||||
static u8 search_max_mac_id(struct adapter *padapter)
|
||||
{
|
||||
u8 mac_id;
|
||||
@ -1141,7 +1114,8 @@ void rtw_sta_media_status_rpt(struct adapter *adapter, struct sta_info *psta,
|
||||
return;
|
||||
|
||||
macid = search_max_mac_id(adapter);
|
||||
SetHwReg8188EU(adapter, HW_VAR_TX_RPT_MAX_MACID, (u8 *)&macid);
|
||||
rtw_set_max_rpt_macid(adapter, macid);
|
||||
|
||||
/* MACID|OPMODE:1 connect */
|
||||
media_status_rpt = (u16)((psta->mac_id << 8) | mstatus);
|
||||
SetHwReg8188EU(adapter, HW_VAR_H2C_MEDIA_STATUS_RPT, (u8 *)&media_status_rpt);
|
||||
@ -1299,7 +1273,7 @@ void rtw_stadel_event_callback(struct adapter *adapter, u8 *pbuf)
|
||||
}
|
||||
|
||||
/*
|
||||
* _rtw_join_timeout_handler - Timeout/faliure handler for CMD JoinBss
|
||||
* _rtw_join_timeout_handler - Timeout/failure handler for CMD JoinBss
|
||||
* @adapter: pointer to struct adapter structure
|
||||
*/
|
||||
void _rtw_join_timeout_handler (struct adapter *adapter)
|
||||
@ -1310,7 +1284,7 @@ void _rtw_join_timeout_handler (struct adapter *adapter)
|
||||
if (adapter->bDriverStopped || adapter->bSurpriseRemoved)
|
||||
return;
|
||||
|
||||
spin_lock_bh(&pmlmepriv->lock);
|
||||
spin_lock_irq(&pmlmepriv->lock);
|
||||
|
||||
if (rtw_to_roaming(adapter) > 0) { /* join timeout caused by roaming */
|
||||
while (1) {
|
||||
@ -1329,12 +1303,12 @@ void _rtw_join_timeout_handler (struct adapter *adapter)
|
||||
rtw_indicate_disconnect(adapter);
|
||||
free_scanqueue(pmlmepriv);/* */
|
||||
}
|
||||
spin_unlock_bh(&pmlmepriv->lock);
|
||||
spin_unlock_irq(&pmlmepriv->lock);
|
||||
|
||||
}
|
||||
|
||||
/*
|
||||
* rtw_scan_timeout_handler - Timeout/Faliure handler for CMD SiteSurvey
|
||||
* rtw_scan_timeout_handler - Timeout/Failure handler for CMD SiteSurvey
|
||||
* @adapter: pointer to struct adapter structure
|
||||
*/
|
||||
void rtw_scan_timeout_handler (struct adapter *adapter)
|
||||
@ -1414,6 +1388,7 @@ static int rtw_check_join_candidate(struct mlme_priv *pmlmepriv
|
||||
{
|
||||
int updated = false;
|
||||
struct adapter *adapter = container_of(pmlmepriv, struct adapter, mlmepriv);
|
||||
unsigned long scan_res_expire;
|
||||
|
||||
/* check bssid, if needed */
|
||||
if (pmlmepriv->assoc_by_bssid) {
|
||||
@ -1431,8 +1406,9 @@ static int rtw_check_join_candidate(struct mlme_priv *pmlmepriv
|
||||
if (!rtw_is_desired_network(adapter, competitor))
|
||||
goto exit;
|
||||
|
||||
scan_res_expire = competitor->last_scanned + msecs_to_jiffies(RTW_SCAN_RESULT_EXPIRE);
|
||||
if (rtw_to_roaming(adapter) > 0) {
|
||||
if (rtw_get_passing_time_ms((u32)competitor->last_scanned) >= RTW_SCAN_RESULT_EXPIRE ||
|
||||
if (time_after(jiffies, scan_res_expire) ||
|
||||
!is_same_ess(&competitor->network, &pmlmepriv->cur_network.network))
|
||||
goto exit;
|
||||
}
|
||||
@ -1461,7 +1437,6 @@ int rtw_select_and_join_from_scanned_queue(struct mlme_priv *pmlmepriv)
|
||||
struct __queue *queue = &pmlmepriv->scanned_queue;
|
||||
struct wlan_network *pnetwork = NULL;
|
||||
struct wlan_network *candidate = NULL;
|
||||
u8 supp_ant_div = false;
|
||||
|
||||
spin_lock_bh(&pmlmepriv->scanned_queue.lock);
|
||||
phead = get_list_head(queue);
|
||||
@ -1488,12 +1463,6 @@ int rtw_select_and_join_from_scanned_queue(struct mlme_priv *pmlmepriv)
|
||||
rtw_free_assoc_resources(adapter, 0);
|
||||
}
|
||||
|
||||
GetHalDefVar8188EUsb(adapter, HAL_DEF_IS_SUPPORT_ANT_DIV, &supp_ant_div);
|
||||
if (supp_ant_div) {
|
||||
u8 cur_ant;
|
||||
GetHalDefVar8188EUsb(adapter, HAL_DEF_CURRENT_ANTENNA, &cur_ant);
|
||||
}
|
||||
|
||||
ret = rtw_joinbss_cmd(adapter, candidate);
|
||||
|
||||
exit:
|
||||
@ -1509,13 +1478,13 @@ int rtw_set_auth(struct adapter *adapter, struct security_priv *psecuritypriv)
|
||||
struct cmd_priv *pcmdpriv = &adapter->cmdpriv;
|
||||
int res = _SUCCESS;
|
||||
|
||||
pcmd = kzalloc(sizeof(struct cmd_obj), GFP_KERNEL);
|
||||
pcmd = kzalloc(sizeof(*pcmd), GFP_KERNEL);
|
||||
if (!pcmd) {
|
||||
res = _FAIL; /* try again */
|
||||
goto exit;
|
||||
}
|
||||
|
||||
psetauthparm = kzalloc(sizeof(struct setauth_parm), GFP_KERNEL);
|
||||
psetauthparm = kzalloc(sizeof(*psetauthparm), GFP_KERNEL);
|
||||
if (!psetauthparm) {
|
||||
kfree(pcmd);
|
||||
res = _FAIL;
|
||||
@ -1627,39 +1596,23 @@ int rtw_restruct_wmm_ie(struct adapter *adapter, u8 *in_ie, u8 *out_ie, uint in_
|
||||
return ielength;
|
||||
}
|
||||
|
||||
/* */
|
||||
/* Ported from 8185: IsInPreAuthKeyList(). (Renamed from SecIsInPreAuthKeyList(), 2006-10-13.) */
|
||||
/* Added by Annie, 2006-05-07. */
|
||||
/* */
|
||||
/* Search by BSSID, */
|
||||
/* Return Value: */
|
||||
/* -1 :if there is no pre-auth key in the table */
|
||||
/* >= 0 :if there is pre-auth key, and return the entry id */
|
||||
/* -1 :if there is no pre-auth key in the table */
|
||||
/* >= 0 :if there is pre-auth key, and return the entry id */
|
||||
/* */
|
||||
/* */
|
||||
|
||||
static int SecIsInPMKIDList(struct adapter *Adapter, u8 *bssid)
|
||||
{
|
||||
struct security_priv *psecuritypriv = &Adapter->securitypriv;
|
||||
int i = 0;
|
||||
struct security_priv *p = &Adapter->securitypriv;
|
||||
int i;
|
||||
|
||||
do {
|
||||
if ((psecuritypriv->PMKIDList[i].bUsed) &&
|
||||
(!memcmp(psecuritypriv->PMKIDList[i].Bssid, bssid, ETH_ALEN))) {
|
||||
break;
|
||||
} else {
|
||||
i++;
|
||||
/* continue; */
|
||||
}
|
||||
|
||||
} while (i < NUM_PMKID_CACHE);
|
||||
|
||||
if (i == NUM_PMKID_CACHE) {
|
||||
i = -1;/* Could not find. */
|
||||
} else {
|
||||
/* There is one Pre-Authentication Key for the specific BSSID. */
|
||||
}
|
||||
return i;
|
||||
for (i = 0; i < NUM_PMKID_CACHE; i++)
|
||||
if (p->PMKIDList[i].bUsed && !memcmp(p->PMKIDList[i].Bssid, bssid, ETH_ALEN))
|
||||
return i;
|
||||
return -1;
|
||||
}
|
||||
|
||||
/* */
|
||||
@ -1796,10 +1749,23 @@ void rtw_update_registrypriv_dev_network(struct adapter *adapter)
|
||||
|
||||
}
|
||||
|
||||
static void rtw_set_threshold(struct adapter *adapter)
|
||||
{
|
||||
struct mlme_priv *mlmepriv = &adapter->mlmepriv;
|
||||
struct ht_priv *htpriv = &mlmepriv->htpriv;
|
||||
|
||||
if (htpriv->ht_option && adapter->registrypriv.wifi_spec != 1) {
|
||||
/* validate usb rx aggregation, use init value. */
|
||||
rtw_write8(adapter, REG_RXDMA_AGG_PG_TH, USB_RXAGG_PAGE_COUNT);
|
||||
} else {
|
||||
/* invalidate usb rx aggregation */
|
||||
rtw_write8(adapter, REG_RXDMA_AGG_PG_TH, 1);
|
||||
}
|
||||
}
|
||||
|
||||
/* the function is at passive_level */
|
||||
void rtw_joinbss_reset(struct adapter *padapter)
|
||||
{
|
||||
u8 threshold;
|
||||
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
|
||||
struct ht_priv *phtpriv = &pmlmepriv->htpriv;
|
||||
|
||||
@ -1810,18 +1776,7 @@ void rtw_joinbss_reset(struct adapter *padapter)
|
||||
|
||||
phtpriv->ampdu_enable = false;/* reset to disabled */
|
||||
|
||||
/* TH = 1 => means that invalidate usb rx aggregation */
|
||||
/* TH = 0 => means that validate usb rx aggregation, use init value. */
|
||||
if (phtpriv->ht_option) {
|
||||
if (padapter->registrypriv.wifi_spec == 1)
|
||||
threshold = 1;
|
||||
else
|
||||
threshold = 0;
|
||||
SetHwReg8188EU(padapter, HW_VAR_RXDMA_AGG_PG_TH, (u8 *)(&threshold));
|
||||
} else {
|
||||
threshold = 1;
|
||||
SetHwReg8188EU(padapter, HW_VAR_RXDMA_AGG_PG_TH, (u8 *)(&threshold));
|
||||
}
|
||||
rtw_set_threshold(padapter);
|
||||
}
|
||||
|
||||
/* the function is >= passive_level */
|
||||
@ -1984,7 +1939,7 @@ void rtw_issue_addbareq_cmd(struct adapter *padapter, struct xmit_frame *pxmitfr
|
||||
issued = (phtpriv->agg_enable_bitmap >> priority) & 0x1;
|
||||
issued |= (phtpriv->candidate_tid_bitmap >> priority) & 0x1;
|
||||
|
||||
if (0 == issued) {
|
||||
if (issued == 0) {
|
||||
psta->htpriv.candidate_tid_bitmap |= BIT((u8)priority);
|
||||
rtw_addbareq_cmd(padapter, (u8)priority, pattrib->ra);
|
||||
}
|
||||
@ -2011,19 +1966,19 @@ void _rtw_roaming(struct adapter *padapter, struct wlan_network *tgt_network)
|
||||
else
|
||||
pnetwork = &pmlmepriv->cur_network;
|
||||
|
||||
if (0 < rtw_to_roaming(padapter)) {
|
||||
if (rtw_to_roaming(padapter) > 0) {
|
||||
memcpy(&pmlmepriv->assoc_ssid, &pnetwork->network.Ssid, sizeof(struct ndis_802_11_ssid));
|
||||
|
||||
pmlmepriv->assoc_by_bssid = false;
|
||||
|
||||
while (1) {
|
||||
do_join_r = rtw_do_join(padapter);
|
||||
if (_SUCCESS == do_join_r) {
|
||||
if (do_join_r == _SUCCESS) {
|
||||
break;
|
||||
} else {
|
||||
pmlmepriv->to_roaming--;
|
||||
|
||||
if (0 < pmlmepriv->to_roaming) {
|
||||
if (pmlmepriv->to_roaming > 0) {
|
||||
continue;
|
||||
} else {
|
||||
rtw_indicate_disconnect(padapter);
|
||||
|
File diff suppressed because it is too large
Load Diff
@ -111,7 +111,7 @@ static void issue_group_disc_req(struct wifidirect_info *pwdinfo, u8 *da)
|
||||
struct xmit_frame *pmgntframe;
|
||||
struct pkt_attrib *pattrib;
|
||||
unsigned char *pframe;
|
||||
struct rtw_ieee80211_hdr *pwlanhdr;
|
||||
struct ieee80211_hdr *pwlanhdr;
|
||||
__le16 *fctrl;
|
||||
struct adapter *padapter = pwdinfo->padapter;
|
||||
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
|
||||
@ -132,9 +132,9 @@ static void issue_group_disc_req(struct wifidirect_info *pwdinfo, u8 *da)
|
||||
memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
|
||||
|
||||
pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
|
||||
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
|
||||
pwlanhdr = (struct ieee80211_hdr *)pframe;
|
||||
|
||||
fctrl = &pwlanhdr->frame_ctl;
|
||||
fctrl = &pwlanhdr->frame_control;
|
||||
*(fctrl) = 0;
|
||||
|
||||
memcpy(pwlanhdr->addr1, da, ETH_ALEN);
|
||||
@ -145,8 +145,8 @@ static void issue_group_disc_req(struct wifidirect_info *pwdinfo, u8 *da)
|
||||
pmlmeext->mgnt_seq++;
|
||||
SetFrameSubType(pframe, WIFI_ACTION);
|
||||
|
||||
pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
|
||||
pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
|
||||
pframe += sizeof(struct ieee80211_hdr_3addr);
|
||||
pattrib->pktlen = sizeof(struct ieee80211_hdr_3addr);
|
||||
|
||||
/* Build P2P action frame header */
|
||||
pframe = rtw_set_fixed_ie(pframe, 1, &category, &pattrib->pktlen);
|
||||
@ -166,12 +166,12 @@ static void issue_p2p_devdisc_resp(struct wifidirect_info *pwdinfo, u8 *da, u8 s
|
||||
struct xmit_frame *pmgntframe;
|
||||
struct pkt_attrib *pattrib;
|
||||
unsigned char *pframe;
|
||||
struct rtw_ieee80211_hdr *pwlanhdr;
|
||||
struct ieee80211_hdr *pwlanhdr;
|
||||
__le16 *fctrl;
|
||||
struct adapter *padapter = pwdinfo->padapter;
|
||||
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
|
||||
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
|
||||
unsigned char category = RTW_WLAN_CATEGORY_PUBLIC;
|
||||
unsigned char category = WLAN_CATEGORY_PUBLIC;
|
||||
u8 action = P2P_PUB_ACTION_ACTION;
|
||||
__be32 p2poui = cpu_to_be32(P2POUI);
|
||||
u8 oui_subtype = P2P_DEVDISC_RESP;
|
||||
@ -189,9 +189,9 @@ static void issue_p2p_devdisc_resp(struct wifidirect_info *pwdinfo, u8 *da, u8 s
|
||||
memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
|
||||
|
||||
pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
|
||||
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
|
||||
pwlanhdr = (struct ieee80211_hdr *)pframe;
|
||||
|
||||
fctrl = &pwlanhdr->frame_ctl;
|
||||
fctrl = &pwlanhdr->frame_control;
|
||||
*(fctrl) = 0;
|
||||
|
||||
memcpy(pwlanhdr->addr1, da, ETH_ALEN);
|
||||
@ -202,8 +202,8 @@ static void issue_p2p_devdisc_resp(struct wifidirect_info *pwdinfo, u8 *da, u8 s
|
||||
pmlmeext->mgnt_seq++;
|
||||
SetFrameSubType(pframe, WIFI_ACTION);
|
||||
|
||||
pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
|
||||
pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
|
||||
pframe += sizeof(struct ieee80211_hdr_3addr);
|
||||
pattrib->pktlen = sizeof(struct ieee80211_hdr_3addr);
|
||||
|
||||
/* Build P2P public action frame header */
|
||||
pframe = rtw_set_fixed_ie(pframe, 1, &category, &pattrib->pktlen);
|
||||
@ -233,7 +233,7 @@ static void issue_p2p_devdisc_resp(struct wifidirect_info *pwdinfo, u8 *da, u8 s
|
||||
static void issue_p2p_provision_resp(struct wifidirect_info *pwdinfo, u8 *raddr, u8 *frame_body, u16 config_method)
|
||||
{
|
||||
struct adapter *padapter = pwdinfo->padapter;
|
||||
unsigned char category = RTW_WLAN_CATEGORY_PUBLIC;
|
||||
unsigned char category = WLAN_CATEGORY_PUBLIC;
|
||||
u8 action = P2P_PUB_ACTION_ACTION;
|
||||
u8 dialogToken = frame_body[7]; /* The Dialog Token of provisioning discovery request frame. */
|
||||
__be32 p2poui = cpu_to_be32(P2POUI);
|
||||
@ -243,7 +243,7 @@ static void issue_p2p_provision_resp(struct wifidirect_info *pwdinfo, u8 *raddr,
|
||||
struct xmit_frame *pmgntframe;
|
||||
struct pkt_attrib *pattrib;
|
||||
unsigned char *pframe;
|
||||
struct rtw_ieee80211_hdr *pwlanhdr;
|
||||
struct ieee80211_hdr *pwlanhdr;
|
||||
__le16 *fctrl;
|
||||
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
|
||||
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
|
||||
@ -259,9 +259,9 @@ static void issue_p2p_provision_resp(struct wifidirect_info *pwdinfo, u8 *raddr,
|
||||
memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
|
||||
|
||||
pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
|
||||
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
|
||||
pwlanhdr = (struct ieee80211_hdr *)pframe;
|
||||
|
||||
fctrl = &pwlanhdr->frame_ctl;
|
||||
fctrl = &pwlanhdr->frame_control;
|
||||
*(fctrl) = 0;
|
||||
|
||||
memcpy(pwlanhdr->addr1, raddr, ETH_ALEN);
|
||||
@ -272,8 +272,8 @@ static void issue_p2p_provision_resp(struct wifidirect_info *pwdinfo, u8 *raddr,
|
||||
pmlmeext->mgnt_seq++;
|
||||
SetFrameSubType(pframe, WIFI_ACTION);
|
||||
|
||||
pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
|
||||
pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
|
||||
pframe += sizeof(struct ieee80211_hdr_3addr);
|
||||
pattrib->pktlen = sizeof(struct ieee80211_hdr_3addr);
|
||||
|
||||
pframe = rtw_set_fixed_ie(pframe, 1, &category, &pattrib->pktlen);
|
||||
pframe = rtw_set_fixed_ie(pframe, 1, &action, &pattrib->pktlen);
|
||||
@ -311,7 +311,7 @@ static void issue_p2p_presence_resp(struct wifidirect_info *pwdinfo, u8 *da, u8
|
||||
struct xmit_frame *pmgntframe;
|
||||
struct pkt_attrib *pattrib;
|
||||
unsigned char *pframe;
|
||||
struct rtw_ieee80211_hdr *pwlanhdr;
|
||||
struct ieee80211_hdr *pwlanhdr;
|
||||
__le16 *fctrl;
|
||||
struct adapter *padapter = pwdinfo->padapter;
|
||||
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
|
||||
@ -334,9 +334,9 @@ static void issue_p2p_presence_resp(struct wifidirect_info *pwdinfo, u8 *da, u8
|
||||
memset(pmgntframe->buf_addr, 0, WLANHDR_OFFSET + TXDESC_OFFSET);
|
||||
|
||||
pframe = (u8 *)(pmgntframe->buf_addr) + TXDESC_OFFSET;
|
||||
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
|
||||
pwlanhdr = (struct ieee80211_hdr *)pframe;
|
||||
|
||||
fctrl = &pwlanhdr->frame_ctl;
|
||||
fctrl = &pwlanhdr->frame_control;
|
||||
*(fctrl) = 0;
|
||||
|
||||
memcpy(pwlanhdr->addr1, da, ETH_ALEN);
|
||||
@ -347,8 +347,8 @@ static void issue_p2p_presence_resp(struct wifidirect_info *pwdinfo, u8 *da, u8
|
||||
pmlmeext->mgnt_seq++;
|
||||
SetFrameSubType(pframe, WIFI_ACTION);
|
||||
|
||||
pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
|
||||
pattrib->pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
|
||||
pframe += sizeof(struct ieee80211_hdr_3addr);
|
||||
pattrib->pktlen = sizeof(struct ieee80211_hdr_3addr);
|
||||
|
||||
/* Build P2P action frame header */
|
||||
pframe = rtw_set_fixed_ie(pframe, 1, &category, &pattrib->pktlen);
|
||||
@ -872,7 +872,7 @@ u32 process_assoc_req_p2p_ie(struct wifidirect_info *pwdinfo, u8 *pframe, uint l
|
||||
}
|
||||
|
||||
psta->dev_name_len = 0;
|
||||
if (WPS_ATTR_DEVICE_NAME == be16_to_cpu(*(__be16 *)pattr_content)) {
|
||||
if (be16_to_cpu(*(__be16 *)pattr_content) == WPS_ATTR_DEVICE_NAME) {
|
||||
dev_name_len = be16_to_cpu(*(__be16 *)(pattr_content + 2));
|
||||
|
||||
psta->dev_name_len = (sizeof(psta->dev_name) < dev_name_len) ? sizeof(psta->dev_name) : dev_name_len;
|
||||
@ -900,7 +900,7 @@ u32 process_p2p_devdisc_req(struct wifidirect_info *pwdinfo, u8 *pframe, uint le
|
||||
u8 *p2p_ie;
|
||||
u32 p2p_ielen = 0;
|
||||
|
||||
frame_body = (unsigned char *)(pframe + sizeof(struct rtw_ieee80211_hdr_3addr));
|
||||
frame_body = (unsigned char *)(pframe + sizeof(struct ieee80211_hdr_3addr));
|
||||
|
||||
dialogToken = frame_body[7];
|
||||
status = P2P_STATUS_FAIL_UNKNOWN_P2PGROUP;
|
||||
@ -951,7 +951,7 @@ u32 process_p2p_devdisc_req(struct wifidirect_info *pwdinfo, u8 *pframe, uint le
|
||||
/* issue Device Discoverability Response */
|
||||
issue_p2p_devdisc_resp(pwdinfo, GetAddr2Ptr(pframe), status, dialogToken);
|
||||
|
||||
return (status == P2P_STATUS_SUCCESS) ? true : false;
|
||||
return status == P2P_STATUS_SUCCESS;
|
||||
}
|
||||
|
||||
u32 process_p2p_devdisc_resp(struct wifidirect_info *pwdinfo, u8 *pframe, uint len)
|
||||
@ -967,7 +967,7 @@ u8 process_p2p_provdisc_req(struct wifidirect_info *pwdinfo, u8 *pframe, uint l
|
||||
u16 uconfig_method = 0;
|
||||
__be16 be_tmp;
|
||||
|
||||
frame_body = (pframe + sizeof(struct rtw_ieee80211_hdr_3addr));
|
||||
frame_body = (pframe + sizeof(struct ieee80211_hdr_3addr));
|
||||
|
||||
wpsie = rtw_get_wps_ie(frame_body + _PUBLIC_ACTION_IE_OFFSET_, len - _PUBLIC_ACTION_IE_OFFSET_, NULL, &wps_ielen);
|
||||
if (wpsie) {
|
||||
@ -1213,7 +1213,7 @@ u8 process_p2p_group_negotation_resp(struct wifidirect_info *pwdinfo, u8 *pframe
|
||||
if (attr_content == P2P_STATUS_SUCCESS) {
|
||||
/* Do nothing. */
|
||||
} else {
|
||||
if (P2P_STATUS_FAIL_INFO_UNAVAILABLE == attr_content) {
|
||||
if (attr_content == P2P_STATUS_FAIL_INFO_UNAVAILABLE) {
|
||||
rtw_p2p_set_state(pwdinfo, P2P_STATE_RX_INFOR_NOREADY);
|
||||
} else {
|
||||
rtw_p2p_set_state(pwdinfo, P2P_STATE_GONEGO_FAIL);
|
||||
@ -1401,7 +1401,7 @@ u8 process_p2p_presence_req(struct wifidirect_info *pwdinfo, u8 *pframe, uint le
|
||||
u8 dialogToken = 0;
|
||||
u8 status = P2P_STATUS_SUCCESS;
|
||||
|
||||
frame_body = (unsigned char *)(pframe + sizeof(struct rtw_ieee80211_hdr_3addr));
|
||||
frame_body = (unsigned char *)(pframe + sizeof(struct ieee80211_hdr_3addr));
|
||||
|
||||
dialogToken = frame_body[6];
|
||||
|
||||
@ -1602,7 +1602,7 @@ void p2p_ps_wk_hdl(struct adapter *padapter, u8 p2p_ps_state)
|
||||
case P2P_PS_DISABLE:
|
||||
pwdinfo->p2p_ps_state = p2p_ps_state;
|
||||
|
||||
SetHwReg8188EU(padapter, HW_VAR_H2C_FW_P2P_PS_OFFLOAD, (u8 *)(&p2p_ps_state));
|
||||
rtl8188e_set_p2p_ps_offload_cmd(padapter, p2p_ps_state);
|
||||
|
||||
pwdinfo->noa_index = 0;
|
||||
pwdinfo->ctwindow = 0;
|
||||
@ -1612,7 +1612,7 @@ void p2p_ps_wk_hdl(struct adapter *padapter, u8 p2p_ps_state)
|
||||
if (padapter->pwrctrlpriv.bFwCurrentInPSMode) {
|
||||
if (pwrpriv->smart_ps == 0) {
|
||||
pwrpriv->smart_ps = 2;
|
||||
SetHwReg8188EU(padapter, HW_VAR_H2C_FW_PWRMODE, (u8 *)(&padapter->pwrctrlpriv.pwr_mode));
|
||||
rtw_set_firmware_ps_mode(padapter, pwrpriv->pwr_mode);
|
||||
}
|
||||
}
|
||||
break;
|
||||
@ -1623,10 +1623,10 @@ void p2p_ps_wk_hdl(struct adapter *padapter, u8 p2p_ps_state)
|
||||
if (pwdinfo->ctwindow > 0) {
|
||||
if (pwrpriv->smart_ps != 0) {
|
||||
pwrpriv->smart_ps = 0;
|
||||
SetHwReg8188EU(padapter, HW_VAR_H2C_FW_PWRMODE, (u8 *)(&padapter->pwrctrlpriv.pwr_mode));
|
||||
rtw_set_firmware_ps_mode(padapter, pwrpriv->pwr_mode);
|
||||
}
|
||||
}
|
||||
SetHwReg8188EU(padapter, HW_VAR_H2C_FW_P2P_PS_OFFLOAD, (u8 *)(&p2p_ps_state));
|
||||
rtl8188e_set_p2p_ps_offload_cmd(padapter, p2p_ps_state);
|
||||
}
|
||||
break;
|
||||
case P2P_PS_SCAN:
|
||||
@ -1634,7 +1634,7 @@ void p2p_ps_wk_hdl(struct adapter *padapter, u8 p2p_ps_state)
|
||||
case P2P_PS_ALLSTASLEEP:
|
||||
if (pwdinfo->p2p_ps_mode > P2P_PS_NONE) {
|
||||
pwdinfo->p2p_ps_state = p2p_ps_state;
|
||||
SetHwReg8188EU(padapter, HW_VAR_H2C_FW_P2P_PS_OFFLOAD, (u8 *)(&p2p_ps_state));
|
||||
rtl8188e_set_p2p_ps_offload_cmd(padapter, p2p_ps_state);
|
||||
}
|
||||
break;
|
||||
default:
|
||||
@ -1891,7 +1891,7 @@ int rtw_p2p_enable(struct adapter *padapter, enum P2P_ROLE role)
|
||||
|
||||
if (role == P2P_ROLE_DEVICE || role == P2P_ROLE_CLIENT || role == P2P_ROLE_GO) {
|
||||
/* leave IPS/Autosuspend */
|
||||
if (_FAIL == rtw_pwr_wakeup(padapter)) {
|
||||
if (rtw_pwr_wakeup(padapter) == _FAIL) {
|
||||
ret = _FAIL;
|
||||
goto exit;
|
||||
}
|
||||
@ -1905,7 +1905,7 @@ int rtw_p2p_enable(struct adapter *padapter, enum P2P_ROLE role)
|
||||
init_wifidirect_info(padapter, role);
|
||||
|
||||
} else if (role == P2P_ROLE_DISABLE) {
|
||||
if (_FAIL == rtw_pwr_wakeup(padapter)) {
|
||||
if (rtw_pwr_wakeup(padapter) == _FAIL) {
|
||||
ret = _FAIL;
|
||||
goto exit;
|
||||
}
|
||||
|
@ -59,7 +59,7 @@ int ips_leave(struct adapter *padapter)
|
||||
pwrpriv->rf_pwrstate = rf_on;
|
||||
}
|
||||
|
||||
if ((_WEP40_ == psecuritypriv->dot11PrivacyAlgrthm) || (_WEP104_ == psecuritypriv->dot11PrivacyAlgrthm)) {
|
||||
if ((psecuritypriv->dot11PrivacyAlgrthm == _WEP40_) || (psecuritypriv->dot11PrivacyAlgrthm == _WEP104_)) {
|
||||
set_channel_bwmode(padapter, padapter->mlmeextpriv.cur_channel, HAL_PRIME_CHNL_OFFSET_DONT_CARE, HT_CHANNEL_WIDTH_20);
|
||||
for (keyid = 0; keyid < 4; keyid++) {
|
||||
if (pmlmepriv->key_mask & BIT(keyid)) {
|
||||
@ -133,9 +133,8 @@ void rtw_ps_processor(struct adapter *padapter)
|
||||
if (!rtw_pwr_unassociated_idle(padapter))
|
||||
goto exit;
|
||||
|
||||
if ((pwrpriv->rf_pwrstate == rf_on) && ((pwrpriv->pwr_state_check_cnts % 4) == 0)) {
|
||||
if (pwrpriv->rf_pwrstate == rf_on) {
|
||||
pwrpriv->change_rfpwrstate = rf_off;
|
||||
|
||||
ips_enter(padapter);
|
||||
}
|
||||
exit:
|
||||
@ -177,6 +176,19 @@ static bool PS_RDY_CHECK(struct adapter *padapter)
|
||||
return true;
|
||||
}
|
||||
|
||||
void rtw_set_firmware_ps_mode(struct adapter *adapter, u8 mode)
|
||||
{
|
||||
struct hal_data_8188e *haldata = &adapter->haldata;
|
||||
struct odm_dm_struct *odmpriv = &haldata->odmpriv;
|
||||
|
||||
/* Force leave RF low power mode for 1T1R to prevent
|
||||
* conflicting setting in firmware power saving sequence.
|
||||
*/
|
||||
if (mode != PS_MODE_ACTIVE)
|
||||
ODM_RF_Saving(odmpriv, true);
|
||||
rtl8188e_set_FwPwrMode_cmd(adapter, mode);
|
||||
}
|
||||
|
||||
void rtw_set_ps_mode(struct adapter *padapter, u8 ps_mode, u8 smart_ps, u8 bcn_ant_mode)
|
||||
{
|
||||
struct pwrctrl_priv *pwrpriv = &padapter->pwrctrlpriv;
|
||||
@ -186,7 +198,7 @@ void rtw_set_ps_mode(struct adapter *padapter, u8 ps_mode, u8 smart_ps, u8 bcn_a
|
||||
return;
|
||||
|
||||
if (pwrpriv->pwr_mode == ps_mode) {
|
||||
if (PS_MODE_ACTIVE == ps_mode)
|
||||
if (ps_mode == PS_MODE_ACTIVE)
|
||||
return;
|
||||
|
||||
if ((pwrpriv->smart_ps == smart_ps) &&
|
||||
@ -194,11 +206,10 @@ void rtw_set_ps_mode(struct adapter *padapter, u8 ps_mode, u8 smart_ps, u8 bcn_a
|
||||
return;
|
||||
}
|
||||
|
||||
/* if (pwrpriv->pwr_mode == PS_MODE_ACTIVE) */
|
||||
if (ps_mode == PS_MODE_ACTIVE) {
|
||||
if (pwdinfo->opp_ps == 0) {
|
||||
pwrpriv->pwr_mode = ps_mode;
|
||||
SetHwReg8188EU(padapter, HW_VAR_H2C_FW_PWRMODE, (u8 *)(&ps_mode));
|
||||
rtw_set_firmware_ps_mode(padapter, ps_mode);
|
||||
pwrpriv->bFwCurrentInPSMode = false;
|
||||
}
|
||||
} else {
|
||||
@ -207,14 +218,28 @@ void rtw_set_ps_mode(struct adapter *padapter, u8 ps_mode, u8 smart_ps, u8 bcn_a
|
||||
pwrpriv->pwr_mode = ps_mode;
|
||||
pwrpriv->smart_ps = smart_ps;
|
||||
pwrpriv->bcn_ant_mode = bcn_ant_mode;
|
||||
SetHwReg8188EU(padapter, HW_VAR_H2C_FW_PWRMODE, (u8 *)(&ps_mode));
|
||||
rtw_set_firmware_ps_mode(padapter, ps_mode);
|
||||
|
||||
/* Set CTWindow after LPS */
|
||||
if (pwdinfo->opp_ps == 1)
|
||||
p2p_ps_wk_cmd(padapter, P2P_PS_ENABLE, 0);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
static bool lps_rf_on(struct adapter *adapter)
|
||||
{
|
||||
/* When we halt NIC, we should check if FW LPS is leave. */
|
||||
if (adapter->pwrctrlpriv.rf_pwrstate == rf_off) {
|
||||
/* If it is in HW/SW Radio OFF or IPS state, we do not check Fw LPS Leave, */
|
||||
/* because Fw is unload. */
|
||||
return true;
|
||||
}
|
||||
|
||||
if (rtw_read32(adapter, REG_RCR) & 0x00070000)
|
||||
return false;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
/*
|
||||
@ -223,16 +248,13 @@ void rtw_set_ps_mode(struct adapter *padapter, u8 ps_mode, u8 smart_ps, u8 bcn_a
|
||||
* -1: Timeout
|
||||
* -2: Other error
|
||||
*/
|
||||
s32 LPS_RF_ON_check(struct adapter *padapter, u32 delay_ms)
|
||||
static s32 LPS_RF_ON_check(struct adapter *padapter, u32 delay_ms)
|
||||
{
|
||||
u32 start_time;
|
||||
u8 bAwake = false;
|
||||
unsigned long timeout = jiffies + msecs_to_jiffies(delay_ms);
|
||||
s32 err = 0;
|
||||
|
||||
start_time = jiffies;
|
||||
while (1) {
|
||||
GetHwReg8188EU(padapter, HW_VAR_FWLPS_RF_ON, &bAwake);
|
||||
if (bAwake)
|
||||
if (lps_rf_on(padapter))
|
||||
break;
|
||||
|
||||
if (padapter->bSurpriseRemoved) {
|
||||
@ -240,7 +262,7 @@ s32 LPS_RF_ON_check(struct adapter *padapter, u32 delay_ms)
|
||||
break;
|
||||
}
|
||||
|
||||
if (rtw_get_passing_time_ms(start_time) > delay_ms) {
|
||||
if (time_after(jiffies, timeout)) {
|
||||
err = -1;
|
||||
break;
|
||||
}
|
||||
@ -329,13 +351,12 @@ void rtw_init_pwrctrl_priv(struct adapter *padapter)
|
||||
pwrctrlpriv->ips_mode_req = padapter->registrypriv.ips_mode;
|
||||
|
||||
pwrctrlpriv->pwr_state_check_interval = RTW_PWR_STATE_CHK_INTERVAL;
|
||||
pwrctrlpriv->pwr_state_check_cnts = 0;
|
||||
pwrctrlpriv->bInSuspend = false;
|
||||
pwrctrlpriv->bkeepfwalive = false;
|
||||
|
||||
pwrctrlpriv->LpsIdleCount = 0;
|
||||
pwrctrlpriv->power_mgnt = padapter->registrypriv.power_mgnt;/* PS_MODE_MIN; */
|
||||
pwrctrlpriv->bLeisurePs = (PS_MODE_ACTIVE != pwrctrlpriv->power_mgnt) ? true : false;
|
||||
pwrctrlpriv->bLeisurePs = pwrctrlpriv->power_mgnt != PS_MODE_ACTIVE;
|
||||
|
||||
pwrctrlpriv->bFwCurrentInPSMode = false;
|
||||
|
||||
@ -346,58 +367,38 @@ void rtw_init_pwrctrl_priv(struct adapter *padapter)
|
||||
timer_setup(&pwrctrlpriv->pwr_state_check_timer, pwr_state_check_handler, 0);
|
||||
}
|
||||
|
||||
/*
|
||||
* rtw_pwr_wakeup - Wake the NIC up from: 1)IPS. 2)USB autosuspend
|
||||
* @adapter: pointer to struct adapter structure
|
||||
* @ips_deffer_ms: the ms wiil prevent from falling into IPS after wakeup
|
||||
* Return _SUCCESS or _FAIL
|
||||
*/
|
||||
|
||||
int _rtw_pwr_wakeup(struct adapter *padapter, u32 ips_deffer_ms, const char *caller)
|
||||
/* Wake the NIC up from: 1)IPS 2)USB autosuspend */
|
||||
int rtw_pwr_wakeup(struct adapter *padapter)
|
||||
{
|
||||
struct pwrctrl_priv *pwrpriv = &padapter->pwrctrlpriv;
|
||||
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
|
||||
unsigned long timeout = jiffies + msecs_to_jiffies(3000);
|
||||
unsigned long deny_time;
|
||||
int ret = _SUCCESS;
|
||||
u32 start = jiffies;
|
||||
|
||||
if (pwrpriv->ips_deny_time < jiffies + rtw_ms_to_systime(ips_deffer_ms))
|
||||
pwrpriv->ips_deny_time = jiffies + rtw_ms_to_systime(ips_deffer_ms);
|
||||
|
||||
if (pwrpriv->ps_processing) {
|
||||
while (pwrpriv->ps_processing && rtw_get_passing_time_ms(start) <= 3000)
|
||||
msleep(10);
|
||||
}
|
||||
|
||||
/* System suspend is not allowed to wakeup */
|
||||
if (pwrpriv->bInSuspend) {
|
||||
while (pwrpriv->bInSuspend &&
|
||||
(rtw_get_passing_time_ms(start) <= 3000 ||
|
||||
(rtw_get_passing_time_ms(start) <= 500)))
|
||||
msleep(10);
|
||||
}
|
||||
while (pwrpriv->ps_processing && time_before(jiffies, timeout))
|
||||
msleep(10);
|
||||
|
||||
/* I think this should be check in IPS, LPS, autosuspend functions... */
|
||||
if (check_fwstate(pmlmepriv, _FW_LINKED)) {
|
||||
ret = _SUCCESS;
|
||||
goto exit;
|
||||
}
|
||||
if (rf_off == pwrpriv->rf_pwrstate) {
|
||||
if (_FAIL == ips_leave(padapter)) {
|
||||
ret = _FAIL;
|
||||
goto exit;
|
||||
}
|
||||
|
||||
if (pwrpriv->rf_pwrstate == rf_off && ips_leave(padapter) == _FAIL) {
|
||||
ret = _FAIL;
|
||||
goto exit;
|
||||
}
|
||||
|
||||
/* TODO: the following checking need to be merged... */
|
||||
if (padapter->bDriverStopped || !padapter->bup ||
|
||||
!padapter->hw_init_completed) {
|
||||
ret = false;
|
||||
if (padapter->bDriverStopped || !padapter->bup || !padapter->hw_init_completed) {
|
||||
ret = _FAIL;
|
||||
goto exit;
|
||||
}
|
||||
|
||||
exit:
|
||||
if (pwrpriv->ips_deny_time < jiffies + rtw_ms_to_systime(ips_deffer_ms))
|
||||
pwrpriv->ips_deny_time = jiffies + rtw_ms_to_systime(ips_deffer_ms);
|
||||
deny_time = jiffies + msecs_to_jiffies(RTW_PWR_STATE_CHK_INTERVAL);
|
||||
if (time_before(pwrpriv->ips_deny_time, deny_time))
|
||||
pwrpriv->ips_deny_time = deny_time;
|
||||
return ret;
|
||||
}
|
||||
|
||||
@ -408,12 +409,12 @@ int rtw_pm_set_lps(struct adapter *padapter, u8 mode)
|
||||
|
||||
if (mode < PS_MODE_NUM) {
|
||||
if (pwrctrlpriv->power_mgnt != mode) {
|
||||
if (PS_MODE_ACTIVE == mode)
|
||||
if (mode == PS_MODE_ACTIVE)
|
||||
LeaveAllPowerSaveMode(padapter);
|
||||
else
|
||||
pwrctrlpriv->LpsIdleCount = 2;
|
||||
pwrctrlpriv->power_mgnt = mode;
|
||||
pwrctrlpriv->bLeisurePs = (PS_MODE_ACTIVE != pwrctrlpriv->power_mgnt) ? true : false;
|
||||
pwrctrlpriv->bLeisurePs = pwrctrlpriv->power_mgnt != PS_MODE_ACTIVE;
|
||||
}
|
||||
} else {
|
||||
ret = -EINVAL;
|
||||
@ -431,7 +432,7 @@ int rtw_pm_set_ips(struct adapter *padapter, u8 mode)
|
||||
return 0;
|
||||
} else if (mode == IPS_NONE) {
|
||||
rtw_ips_mode_req(pwrctrlpriv, mode);
|
||||
if ((padapter->bSurpriseRemoved == 0) && (_FAIL == rtw_pwr_wakeup(padapter)))
|
||||
if ((padapter->bSurpriseRemoved == 0) && (rtw_pwr_wakeup(padapter) == _FAIL))
|
||||
return -EFAULT;
|
||||
} else {
|
||||
return -EINVAL;
|
||||
|
@ -71,7 +71,6 @@ int _rtw_init_recv_priv(struct recv_priv *precvpriv, struct adapter *padapter)
|
||||
|
||||
list_add_tail(&precvframe->list, &precvpriv->free_recv_queue.queue);
|
||||
|
||||
precvframe->pkt_newalloc = NULL;
|
||||
precvframe->pkt = NULL;
|
||||
|
||||
precvframe->len = 0;
|
||||
@ -81,8 +80,6 @@ int _rtw_init_recv_priv(struct recv_priv *precvpriv, struct adapter *padapter)
|
||||
}
|
||||
precvpriv->rx_pending_cnt = 1;
|
||||
|
||||
sema_init(&precvpriv->allrxreturnevt, 0);
|
||||
|
||||
res = rtl8188eu_init_recv_priv(padapter);
|
||||
|
||||
timer_setup(&precvpriv->signal_stat_timer, rtw_signal_stat_timer_hdl, 0);
|
||||
@ -749,6 +746,7 @@ static int sta2ap_data_frame(struct adapter *adapter,
|
||||
struct sta_priv *pstapriv = &adapter->stapriv;
|
||||
struct mlme_priv *pmlmepriv = &adapter->mlmepriv;
|
||||
u8 *ptr = precv_frame->rx_data;
|
||||
__le16 fc = *(__le16 *)ptr;
|
||||
unsigned char *mybssid = get_bssid(pmlmepriv);
|
||||
int ret = _SUCCESS;
|
||||
|
||||
@ -769,9 +767,8 @@ static int sta2ap_data_frame(struct adapter *adapter,
|
||||
|
||||
process_pwrbit_data(adapter, precv_frame);
|
||||
|
||||
if ((GetFrameSubType(ptr) & WIFI_QOS_DATA_TYPE) == WIFI_QOS_DATA_TYPE) {
|
||||
if (ieee80211_is_data_qos(fc))
|
||||
process_wmmps_data(adapter, precv_frame);
|
||||
}
|
||||
|
||||
if (GetFrameSubType(ptr) & BIT(6)) {
|
||||
/* No data, will not indicate to upper layer, temporily count it here */
|
||||
@ -795,143 +792,135 @@ static int sta2ap_data_frame(struct adapter *adapter,
|
||||
return ret;
|
||||
}
|
||||
|
||||
static int validate_recv_ctrl_frame(struct adapter *padapter,
|
||||
struct recv_frame *precv_frame)
|
||||
static void validate_recv_ctrl_frame(struct adapter *padapter,
|
||||
struct recv_frame *precv_frame)
|
||||
{
|
||||
struct rx_pkt_attrib *pattrib = &precv_frame->attrib;
|
||||
struct sta_priv *pstapriv = &padapter->stapriv;
|
||||
u8 *pframe = precv_frame->rx_data;
|
||||
/* uint len = precv_frame->len; */
|
||||
|
||||
if (GetFrameType(pframe) != WIFI_CTRL_TYPE)
|
||||
return _FAIL;
|
||||
struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)precv_frame->rx_data;
|
||||
struct ieee80211_pspoll *pspoll = (struct ieee80211_pspoll *)hdr;
|
||||
u8 wmmps_ac;
|
||||
struct sta_info *psta;
|
||||
|
||||
/* receive the frames that ra(a1) is my address */
|
||||
if (memcmp(GetAddr1Ptr(pframe), myid(&padapter->eeprompriv), ETH_ALEN))
|
||||
return _FAIL;
|
||||
if (memcmp(hdr->addr1, myid(&padapter->eeprompriv), ETH_ALEN))
|
||||
return;
|
||||
|
||||
/* only handle ps-poll */
|
||||
if (GetFrameSubType(pframe) == WIFI_PSPOLL) {
|
||||
u16 aid;
|
||||
u8 wmmps_ac = 0;
|
||||
struct sta_info *psta = NULL;
|
||||
if (!ieee80211_is_pspoll(hdr->frame_control))
|
||||
return;
|
||||
|
||||
aid = GetAid(pframe);
|
||||
psta = rtw_get_stainfo(pstapriv, GetAddr2Ptr(pframe));
|
||||
psta = rtw_get_stainfo(pstapriv, hdr->addr2);
|
||||
if (!psta || psta->aid != (le16_to_cpu(pspoll->aid) & 0x3FFF))
|
||||
return;
|
||||
|
||||
if (!psta || psta->aid != aid)
|
||||
return _FAIL;
|
||||
/* for rx pkt statistics */
|
||||
psta->sta_stats.rx_ctrl_pkts++;
|
||||
|
||||
/* for rx pkt statistics */
|
||||
psta->sta_stats.rx_ctrl_pkts++;
|
||||
|
||||
switch (pattrib->priority) {
|
||||
case 1:
|
||||
case 2:
|
||||
wmmps_ac = psta->uapsd_bk & BIT(0);
|
||||
break;
|
||||
case 4:
|
||||
case 5:
|
||||
wmmps_ac = psta->uapsd_vi & BIT(0);
|
||||
break;
|
||||
case 6:
|
||||
case 7:
|
||||
wmmps_ac = psta->uapsd_vo & BIT(0);
|
||||
break;
|
||||
case 0:
|
||||
case 3:
|
||||
default:
|
||||
wmmps_ac = psta->uapsd_be & BIT(0);
|
||||
break;
|
||||
}
|
||||
|
||||
if (wmmps_ac)
|
||||
return _FAIL;
|
||||
|
||||
if (psta->state & WIFI_STA_ALIVE_CHK_STATE) {
|
||||
psta->expire_to = pstapriv->expire_to;
|
||||
psta->state ^= WIFI_STA_ALIVE_CHK_STATE;
|
||||
}
|
||||
|
||||
if ((psta->state & WIFI_SLEEP_STATE) && (pstapriv->sta_dz_bitmap & BIT(psta->aid))) {
|
||||
struct list_head *xmitframe_plist, *xmitframe_phead;
|
||||
struct xmit_frame *pxmitframe = NULL;
|
||||
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
|
||||
|
||||
spin_lock_bh(&pxmitpriv->lock);
|
||||
|
||||
xmitframe_phead = get_list_head(&psta->sleep_q);
|
||||
xmitframe_plist = xmitframe_phead->next;
|
||||
|
||||
if (xmitframe_phead != xmitframe_plist) {
|
||||
pxmitframe = container_of(xmitframe_plist, struct xmit_frame, list);
|
||||
|
||||
xmitframe_plist = xmitframe_plist->next;
|
||||
|
||||
list_del_init(&pxmitframe->list);
|
||||
|
||||
psta->sleepq_len--;
|
||||
|
||||
if (psta->sleepq_len > 0)
|
||||
pxmitframe->attrib.mdata = 1;
|
||||
else
|
||||
pxmitframe->attrib.mdata = 0;
|
||||
|
||||
pxmitframe->attrib.triggered = 1;
|
||||
|
||||
if (psta->sleepq_len == 0) {
|
||||
pstapriv->tim_bitmap &= ~BIT(psta->aid);
|
||||
|
||||
/* upate BCN for TIM IE */
|
||||
/* update_BCNTIM(padapter); */
|
||||
update_beacon(padapter, _TIM_IE_, NULL, false);
|
||||
}
|
||||
} else {
|
||||
if (pstapriv->tim_bitmap & BIT(psta->aid)) {
|
||||
if (psta->sleepq_len == 0)
|
||||
/* issue nulldata with More data bit = 0 to indicate we have no buffered packets */
|
||||
issue_nulldata(padapter, psta->hwaddr, 0, 0, 0);
|
||||
else
|
||||
psta->sleepq_len = 0;
|
||||
|
||||
pstapriv->tim_bitmap &= ~BIT(psta->aid);
|
||||
|
||||
/* upate BCN for TIM IE */
|
||||
/* update_BCNTIM(padapter); */
|
||||
update_beacon(padapter, _TIM_IE_, NULL, false);
|
||||
}
|
||||
}
|
||||
spin_unlock_bh(&pxmitpriv->lock);
|
||||
}
|
||||
switch (pattrib->priority) {
|
||||
case 1:
|
||||
case 2:
|
||||
wmmps_ac = psta->uapsd_bk & BIT(0);
|
||||
break;
|
||||
case 4:
|
||||
case 5:
|
||||
wmmps_ac = psta->uapsd_vi & BIT(0);
|
||||
break;
|
||||
case 6:
|
||||
case 7:
|
||||
wmmps_ac = psta->uapsd_vo & BIT(0);
|
||||
break;
|
||||
case 0:
|
||||
case 3:
|
||||
default:
|
||||
wmmps_ac = psta->uapsd_be & BIT(0);
|
||||
break;
|
||||
}
|
||||
|
||||
return _FAIL;
|
||||
if (wmmps_ac)
|
||||
return;
|
||||
|
||||
if (psta->state & WIFI_STA_ALIVE_CHK_STATE) {
|
||||
psta->expire_to = pstapriv->expire_to;
|
||||
psta->state ^= WIFI_STA_ALIVE_CHK_STATE;
|
||||
}
|
||||
|
||||
if ((psta->state & WIFI_SLEEP_STATE) && (pstapriv->sta_dz_bitmap & BIT(psta->aid))) {
|
||||
struct list_head *xmitframe_plist, *xmitframe_phead;
|
||||
struct xmit_frame *pxmitframe = NULL;
|
||||
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
|
||||
|
||||
spin_lock_bh(&pxmitpriv->lock);
|
||||
|
||||
xmitframe_phead = get_list_head(&psta->sleep_q);
|
||||
xmitframe_plist = xmitframe_phead->next;
|
||||
|
||||
if (xmitframe_phead != xmitframe_plist) {
|
||||
pxmitframe = container_of(xmitframe_plist, struct xmit_frame, list);
|
||||
|
||||
xmitframe_plist = xmitframe_plist->next;
|
||||
|
||||
list_del_init(&pxmitframe->list);
|
||||
|
||||
psta->sleepq_len--;
|
||||
|
||||
if (psta->sleepq_len > 0)
|
||||
pxmitframe->attrib.mdata = 1;
|
||||
else
|
||||
pxmitframe->attrib.mdata = 0;
|
||||
|
||||
pxmitframe->attrib.triggered = 1;
|
||||
|
||||
if (psta->sleepq_len == 0) {
|
||||
pstapriv->tim_bitmap &= ~BIT(psta->aid);
|
||||
|
||||
/* upate BCN for TIM IE */
|
||||
/* update_BCNTIM(padapter); */
|
||||
update_beacon(padapter, _TIM_IE_, NULL, false);
|
||||
}
|
||||
} else {
|
||||
if (pstapriv->tim_bitmap & BIT(psta->aid)) {
|
||||
if (psta->sleepq_len == 0)
|
||||
/* issue nulldata with More data bit = 0 to indicate we have no buffered packets */
|
||||
issue_nulldata(padapter, psta->hwaddr, 0, 0, 0);
|
||||
else
|
||||
psta->sleepq_len = 0;
|
||||
|
||||
pstapriv->tim_bitmap &= ~BIT(psta->aid);
|
||||
|
||||
/* upate BCN for TIM IE */
|
||||
/* update_BCNTIM(padapter); */
|
||||
update_beacon(padapter, _TIM_IE_, NULL, false);
|
||||
}
|
||||
}
|
||||
spin_unlock_bh(&pxmitpriv->lock);
|
||||
}
|
||||
}
|
||||
|
||||
struct recv_frame *recvframe_chk_defrag(struct adapter *padapter, struct recv_frame *precv_frame);
|
||||
|
||||
static int validate_recv_mgnt_frame(struct adapter *padapter,
|
||||
struct recv_frame *precv_frame)
|
||||
static void validate_recv_mgnt_frame(struct adapter *padapter,
|
||||
struct recv_frame *precv_frame)
|
||||
{
|
||||
struct sta_info *psta;
|
||||
struct ieee80211_hdr *hdr;
|
||||
|
||||
precv_frame = recvframe_chk_defrag(padapter, precv_frame);
|
||||
if (!precv_frame)
|
||||
return _SUCCESS;
|
||||
return;
|
||||
|
||||
/* for rx pkt statistics */
|
||||
psta = rtw_get_stainfo(&padapter->stapriv, GetAddr2Ptr(precv_frame->rx_data));
|
||||
hdr = (struct ieee80211_hdr *)precv_frame->rx_data;
|
||||
psta = rtw_get_stainfo(&padapter->stapriv, hdr->addr2);
|
||||
if (psta) {
|
||||
psta->sta_stats.rx_mgnt_pkts++;
|
||||
if (GetFrameSubType(precv_frame->rx_data) == WIFI_BEACON) {
|
||||
if (ieee80211_is_beacon(hdr->frame_control))
|
||||
psta->sta_stats.rx_beacon_pkts++;
|
||||
} else if (GetFrameSubType(precv_frame->rx_data) == WIFI_PROBEREQ) {
|
||||
else if (ieee80211_is_probe_req(hdr->frame_control))
|
||||
psta->sta_stats.rx_probereq_pkts++;
|
||||
} else if (GetFrameSubType(precv_frame->rx_data) == WIFI_PROBERSP) {
|
||||
if (!memcmp(padapter->eeprompriv.mac_addr, GetAddr1Ptr(precv_frame->rx_data), ETH_ALEN))
|
||||
else if (ieee80211_is_probe_resp(hdr->frame_control)) {
|
||||
if (!memcmp(padapter->eeprompriv.mac_addr, hdr->addr1, ETH_ALEN))
|
||||
psta->sta_stats.rx_probersp_pkts++;
|
||||
else if (is_broadcast_mac_addr(GetAddr1Ptr(precv_frame->rx_data)) ||
|
||||
is_multicast_mac_addr(GetAddr1Ptr(precv_frame->rx_data)))
|
||||
else if (is_broadcast_mac_addr(hdr->addr1) || is_multicast_mac_addr(hdr->addr1))
|
||||
psta->sta_stats.rx_probersp_bm_pkts++;
|
||||
else
|
||||
psta->sta_stats.rx_probersp_uo_pkts++;
|
||||
@ -939,72 +928,44 @@ static int validate_recv_mgnt_frame(struct adapter *padapter,
|
||||
}
|
||||
|
||||
mgt_dispatcher(padapter, precv_frame);
|
||||
|
||||
return _SUCCESS;
|
||||
}
|
||||
|
||||
static int validate_recv_data_frame(struct adapter *adapter,
|
||||
struct recv_frame *precv_frame)
|
||||
{
|
||||
u8 bretry;
|
||||
u8 *psa, *pda, *pbssid;
|
||||
struct sta_info *psta = NULL;
|
||||
u8 *ptr = precv_frame->rx_data;
|
||||
struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)precv_frame->rx_data;
|
||||
struct rx_pkt_attrib *pattrib = &precv_frame->attrib;
|
||||
struct security_priv *psecuritypriv = &adapter->securitypriv;
|
||||
int ret = _SUCCESS;
|
||||
int ret;
|
||||
|
||||
bretry = GetRetry(ptr);
|
||||
pda = get_da(ptr);
|
||||
psa = get_sa(ptr);
|
||||
pbssid = get_hdr_bssid(ptr);
|
||||
memcpy(pattrib->dst, ieee80211_get_DA(hdr), ETH_ALEN);
|
||||
memcpy(pattrib->src, ieee80211_get_SA(hdr), ETH_ALEN);
|
||||
|
||||
if (!pbssid) {
|
||||
ret = _FAIL;
|
||||
goto exit;
|
||||
}
|
||||
/* address4 is used only if both to_ds and from_ds are set */
|
||||
if (ieee80211_has_a4(hdr->frame_control))
|
||||
return _FAIL;
|
||||
|
||||
memcpy(pattrib->dst, pda, ETH_ALEN);
|
||||
memcpy(pattrib->src, psa, ETH_ALEN);
|
||||
memcpy(pattrib->ra, hdr->addr1, ETH_ALEN);
|
||||
memcpy(pattrib->ta, hdr->addr2, ETH_ALEN);
|
||||
|
||||
memcpy(pattrib->bssid, pbssid, ETH_ALEN);
|
||||
|
||||
switch (pattrib->to_fr_ds) {
|
||||
case 0:
|
||||
memcpy(pattrib->ra, pda, ETH_ALEN);
|
||||
memcpy(pattrib->ta, psa, ETH_ALEN);
|
||||
ret = sta2sta_data_frame(adapter, precv_frame, &psta);
|
||||
break;
|
||||
case 1:
|
||||
memcpy(pattrib->ra, pda, ETH_ALEN);
|
||||
memcpy(pattrib->ta, pbssid, ETH_ALEN);
|
||||
if (ieee80211_has_fromds(hdr->frame_control)) {
|
||||
memcpy(pattrib->bssid, hdr->addr2, ETH_ALEN);
|
||||
ret = ap2sta_data_frame(adapter, precv_frame, &psta);
|
||||
break;
|
||||
case 2:
|
||||
memcpy(pattrib->ra, pbssid, ETH_ALEN);
|
||||
memcpy(pattrib->ta, psa, ETH_ALEN);
|
||||
} else if (ieee80211_has_tods(hdr->frame_control)) {
|
||||
memcpy(pattrib->bssid, hdr->addr1, ETH_ALEN);
|
||||
ret = sta2ap_data_frame(adapter, precv_frame, &psta);
|
||||
break;
|
||||
case 3:
|
||||
memcpy(pattrib->ra, GetAddr1Ptr(ptr), ETH_ALEN);
|
||||
memcpy(pattrib->ta, GetAddr2Ptr(ptr), ETH_ALEN);
|
||||
ret = _FAIL;
|
||||
break;
|
||||
default:
|
||||
ret = _FAIL;
|
||||
break;
|
||||
} else {
|
||||
memcpy(pattrib->bssid, hdr->addr3, ETH_ALEN);
|
||||
ret = sta2sta_data_frame(adapter, precv_frame, &psta);
|
||||
}
|
||||
|
||||
if (ret == _FAIL) {
|
||||
goto exit;
|
||||
} else if (ret == RTW_RX_HANDLED) {
|
||||
goto exit;
|
||||
}
|
||||
if (ret == _FAIL || ret == RTW_RX_HANDLED)
|
||||
return ret;
|
||||
|
||||
if (!psta) {
|
||||
ret = _FAIL;
|
||||
goto exit;
|
||||
}
|
||||
if (!psta)
|
||||
return _FAIL;
|
||||
|
||||
/* psta->rssi = prxcmd->rssi; */
|
||||
/* psta->signal_quality = prxcmd->sq; */
|
||||
@ -1014,16 +975,16 @@ static int validate_recv_data_frame(struct adapter *adapter,
|
||||
pattrib->ack_policy = 0;
|
||||
/* parsing QC field */
|
||||
if (pattrib->qos) {
|
||||
pattrib->priority = GetPriority((ptr + 24));
|
||||
pattrib->priority = ieee80211_get_tid(hdr);
|
||||
pattrib->ack_policy = GetAckpolicy((ptr + 24));
|
||||
pattrib->amsdu = GetAMsdu((ptr + 24));
|
||||
pattrib->hdrlen = pattrib->to_fr_ds == 3 ? 32 : 26;
|
||||
pattrib->hdrlen = 26;
|
||||
|
||||
if (pattrib->priority != 0 && pattrib->priority != 3)
|
||||
adapter->recvpriv.bIsAnyNonBEPkts = true;
|
||||
} else {
|
||||
pattrib->priority = 0;
|
||||
pattrib->hdrlen = pattrib->to_fr_ds == 3 ? 30 : 24;
|
||||
pattrib->hdrlen = 24;
|
||||
}
|
||||
|
||||
if (pattrib->order)/* HT-CTRL 11n */
|
||||
@ -1032,10 +993,9 @@ static int validate_recv_data_frame(struct adapter *adapter,
|
||||
precv_frame->preorder_ctrl = &psta->recvreorder_ctrl[pattrib->priority];
|
||||
|
||||
/* decache, drop duplicate recv packets */
|
||||
if (recv_decache(precv_frame, bretry, &psta->sta_recvpriv.rxcache) == _FAIL) {
|
||||
ret = _FAIL;
|
||||
goto exit;
|
||||
}
|
||||
if (recv_decache(precv_frame, ieee80211_has_retry(hdr->frame_control),
|
||||
&psta->sta_recvpriv.rxcache) == _FAIL)
|
||||
return _FAIL;
|
||||
|
||||
if (pattrib->privacy) {
|
||||
GET_ENCRY_ALGO(psecuritypriv, psta, pattrib->encrypt, is_multicast_ether_addr(pattrib->ra));
|
||||
@ -1047,9 +1007,7 @@ static int validate_recv_data_frame(struct adapter *adapter,
|
||||
pattrib->icv_len = 0;
|
||||
}
|
||||
|
||||
exit:
|
||||
|
||||
return ret;
|
||||
return _SUCCESS;
|
||||
}
|
||||
|
||||
static int validate_recv_frame(struct adapter *adapter, struct recv_frame *precv_frame)
|
||||
@ -1059,11 +1017,8 @@ static int validate_recv_frame(struct adapter *adapter, struct recv_frame *precv
|
||||
/* then call check if rx seq/frag. duplicated. */
|
||||
|
||||
int retval = _FAIL;
|
||||
u8 bDumpRxPkt;
|
||||
struct rx_pkt_attrib *pattrib = &precv_frame->attrib;
|
||||
u8 *ptr = precv_frame->rx_data;
|
||||
__le16 fc = *(__le16 *)ptr;
|
||||
u8 ver = (unsigned char)(*ptr) & 0x3;
|
||||
struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)precv_frame->rx_data;
|
||||
struct mlme_ext_priv *pmlmeext = &adapter->mlmeextpriv;
|
||||
|
||||
if (pmlmeext->sitesurvey_res.state == SCAN_PROCESS) {
|
||||
@ -1072,32 +1027,26 @@ static int validate_recv_frame(struct adapter *adapter, struct recv_frame *precv
|
||||
pmlmeext->channel_set[ch_set_idx].rx_count++;
|
||||
}
|
||||
|
||||
/* add version chk */
|
||||
if (ver != 0)
|
||||
if ((hdr->frame_control & cpu_to_le16(IEEE80211_FCTL_VERS)) != 0)
|
||||
return _FAIL;
|
||||
|
||||
pattrib->to_fr_ds = get_tofr_ds(ptr);
|
||||
pattrib->frag_num = le16_to_cpu(hdr->seq_ctrl) & IEEE80211_SCTL_FRAG;
|
||||
pattrib->seq_num = IEEE80211_SEQ_TO_SN(le16_to_cpu(hdr->seq_ctrl));
|
||||
|
||||
pattrib->frag_num = GetFragNum(ptr);
|
||||
pattrib->seq_num = GetSequence(ptr);
|
||||
|
||||
pattrib->pw_save = GetPwrMgt(ptr);
|
||||
pattrib->mfrag = ieee80211_has_morefrags(fc);
|
||||
pattrib->mdata = ieee80211_has_moredata(fc);
|
||||
pattrib->privacy = ieee80211_has_protected(fc);
|
||||
pattrib->order = ieee80211_has_order(fc);
|
||||
|
||||
/* Dump rx packets */
|
||||
GetHalDefVar8188EUsb(adapter, HAL_DEF_DBG_DUMP_RXPKT, &bDumpRxPkt);
|
||||
pattrib->pw_save = ieee80211_has_pm(hdr->frame_control);
|
||||
pattrib->mfrag = ieee80211_has_morefrags(hdr->frame_control);
|
||||
pattrib->mdata = ieee80211_has_moredata(hdr->frame_control);
|
||||
pattrib->privacy = ieee80211_has_protected(hdr->frame_control);
|
||||
pattrib->order = ieee80211_has_order(hdr->frame_control);
|
||||
|
||||
/* We return _SUCCESS only for data frames. */
|
||||
if (ieee80211_is_mgmt(fc))
|
||||
if (ieee80211_is_mgmt(hdr->frame_control))
|
||||
validate_recv_mgnt_frame(adapter, precv_frame);
|
||||
else if (ieee80211_is_ctl(fc))
|
||||
else if (ieee80211_is_ctl(hdr->frame_control))
|
||||
validate_recv_ctrl_frame(adapter, precv_frame);
|
||||
else if (ieee80211_is_data(fc)) {
|
||||
else if (ieee80211_is_data(hdr->frame_control)) {
|
||||
rtw_led_control(adapter, LED_CTL_RX);
|
||||
pattrib->qos = ieee80211_is_data_qos(fc);
|
||||
pattrib->qos = ieee80211_is_data_qos(hdr->frame_control);
|
||||
retval = validate_recv_data_frame(adapter, precv_frame);
|
||||
if (retval == _FAIL) {
|
||||
struct recv_priv *precvpriv = &adapter->recvpriv;
|
||||
@ -1284,8 +1233,9 @@ struct recv_frame *recvframe_chk_defrag(struct adapter *padapter, struct recv_fr
|
||||
psta_addr = pfhdr->attrib.ta;
|
||||
psta = rtw_get_stainfo(pstapriv, psta_addr);
|
||||
if (!psta) {
|
||||
u8 type = GetFrameType(pfhdr->rx_data);
|
||||
if (type != WIFI_DATA_TYPE) {
|
||||
__le16 fc = *(__le16 *)pfhdr->rx_data;
|
||||
|
||||
if (ieee80211_is_data(fc)) {
|
||||
psta = rtw_get_bcmc_stainfo(padapter);
|
||||
pdefrag_q = &psta->sta_recvpriv.defrag_q;
|
||||
} else {
|
||||
@ -1723,12 +1673,9 @@ static int recv_func_prehandle(struct adapter *padapter, struct recv_frame *rfra
|
||||
|
||||
/* check the frame crtl field and decache */
|
||||
ret = validate_recv_frame(padapter, rframe);
|
||||
if (ret != _SUCCESS) {
|
||||
if (ret != _SUCCESS)
|
||||
rtw_free_recvframe(rframe, pfree_recv_queue);/* free this recv_frame */
|
||||
goto exit;
|
||||
}
|
||||
|
||||
exit:
|
||||
return ret;
|
||||
}
|
||||
|
||||
|
@ -63,7 +63,7 @@ void rtw_wep_encrypt(struct adapter *padapter, struct xmit_frame *pxmitframe)
|
||||
arc4_crypt(ctx, payload + length, crc.f1, 4);
|
||||
|
||||
pframe += pxmitpriv->frag_len;
|
||||
pframe = (u8 *)RND4((size_t)(pframe));
|
||||
pframe = PTR_ALIGN(pframe, 4);
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -504,7 +504,7 @@ u32 rtw_tkip_encrypt(struct adapter *padapter, struct xmit_frame *pxmitframe)
|
||||
arc4_crypt(ctx, payload + length, crc.f1, 4);
|
||||
|
||||
pframe += pxmitpriv->frag_len;
|
||||
pframe = (u8 *)RND4((size_t)(pframe));
|
||||
pframe = PTR_ALIGN(pframe, 4);
|
||||
}
|
||||
}
|
||||
} else {
|
||||
@ -1133,7 +1133,7 @@ u32 rtw_aes_encrypt(struct adapter *padapter, struct xmit_frame *pxmitframe)
|
||||
|
||||
aes_cipher(prwskey, pattrib->hdrlen, pframe, length);
|
||||
pframe += pxmitpriv->frag_len;
|
||||
pframe = (u8 *)RND4((size_t)(pframe));
|
||||
pframe = PTR_ALIGN(pframe, 4);
|
||||
}
|
||||
}
|
||||
} else {
|
||||
|
@ -470,9 +470,9 @@ u8 rtw_access_ctrl(struct adapter *padapter, u8 *mac_addr)
|
||||
spin_unlock_bh(&pacl_node_q->lock);
|
||||
|
||||
if (pacl_list->mode == 1)/* accept unless in deny list */
|
||||
res = (match) ? false : true;
|
||||
res = !match;
|
||||
else if (pacl_list->mode == 2)/* deny unless in accept list */
|
||||
res = (match) ? true : false;
|
||||
res = match;
|
||||
else
|
||||
res = true;
|
||||
|
||||
|
@ -276,14 +276,6 @@ void Restore_DM_Func_Flag(struct adapter *padapter)
|
||||
SetHwReg8188EU(padapter, HW_VAR_DM_FUNC_OP, (u8 *)(&saveflag));
|
||||
}
|
||||
|
||||
void Switch_DM_Func(struct adapter *padapter, u32 mode, u8 enable)
|
||||
{
|
||||
if (enable)
|
||||
SetHwReg8188EU(padapter, HW_VAR_DM_FUNC_SET, (u8 *)(&mode));
|
||||
else
|
||||
SetHwReg8188EU(padapter, HW_VAR_DM_FUNC_CLR, (u8 *)(&mode));
|
||||
}
|
||||
|
||||
void Set_MSR(struct adapter *padapter, u8 type)
|
||||
{
|
||||
u8 val8;
|
||||
@ -511,6 +503,31 @@ int WMM_param_handler(struct adapter *padapter, struct ndis_802_11_var_ie *pIE)
|
||||
return true;
|
||||
}
|
||||
|
||||
static void set_acm_ctrl(struct adapter *adapter, u8 acm_mask)
|
||||
{
|
||||
u8 acmctrl = rtw_read8(adapter, REG_ACMHWCTRL);
|
||||
|
||||
if (acm_mask > 1)
|
||||
acmctrl = acmctrl | 0x1;
|
||||
|
||||
if (acm_mask & BIT(3))
|
||||
acmctrl |= ACMHW_VOQEN;
|
||||
else
|
||||
acmctrl &= (~ACMHW_VOQEN);
|
||||
|
||||
if (acm_mask & BIT(2))
|
||||
acmctrl |= ACMHW_VIQEN;
|
||||
else
|
||||
acmctrl &= (~ACMHW_VIQEN);
|
||||
|
||||
if (acm_mask & BIT(1))
|
||||
acmctrl |= ACMHW_BEQEN;
|
||||
else
|
||||
acmctrl &= (~ACMHW_BEQEN);
|
||||
|
||||
rtw_write8(adapter, REG_ACMHWCTRL, acmctrl);
|
||||
}
|
||||
|
||||
void WMMOnAssocRsp(struct adapter *padapter)
|
||||
{
|
||||
u8 ACI, ACM, AIFS, ECWMin, ECWMax, aSifsTime;
|
||||
@ -522,6 +539,7 @@ void WMMOnAssocRsp(struct adapter *padapter)
|
||||
struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
|
||||
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
|
||||
struct registry_priv *pregpriv = &padapter->registrypriv;
|
||||
struct hal_data_8188e *haldata = &padapter->haldata;
|
||||
|
||||
if (pmlmeinfo->WMM_enable == 0) {
|
||||
padapter->mlmepriv.acm_mask = 0;
|
||||
@ -550,7 +568,8 @@ void WMMOnAssocRsp(struct adapter *padapter)
|
||||
|
||||
switch (ACI) {
|
||||
case 0x0:
|
||||
SetHwReg8188EU(padapter, HW_VAR_AC_PARAM_BE, (u8 *)(&acParm));
|
||||
haldata->AcParam_BE = acParm;
|
||||
rtw_write32(padapter, REG_EDCA_BE_PARAM, acParm);
|
||||
acm_mask |= (ACM ? BIT(1) : 0);
|
||||
edca[XMIT_BE_QUEUE] = acParm;
|
||||
break;
|
||||
@ -572,7 +591,7 @@ void WMMOnAssocRsp(struct adapter *padapter)
|
||||
}
|
||||
|
||||
if (padapter->registrypriv.acm_method == 1)
|
||||
SetHwReg8188EU(padapter, HW_VAR_ACM_CTRL, (u8 *)(&acm_mask));
|
||||
set_acm_ctrl(padapter, acm_mask);
|
||||
else
|
||||
padapter->mlmepriv.acm_mask = acm_mask;
|
||||
|
||||
@ -743,6 +762,35 @@ void HT_info_handler(struct adapter *padapter, struct ndis_802_11_var_ie *pIE)
|
||||
memcpy(&pmlmeinfo->HT_info, pIE->data, pIE->Length);
|
||||
}
|
||||
|
||||
static void set_min_ampdu_spacing(struct adapter *adapter, u8 spacing)
|
||||
{
|
||||
u8 sec_spacing;
|
||||
|
||||
if (spacing <= 7) {
|
||||
switch (adapter->securitypriv.dot11PrivacyAlgrthm) {
|
||||
case _NO_PRIVACY_:
|
||||
case _AES_:
|
||||
sec_spacing = 0;
|
||||
break;
|
||||
case _WEP40_:
|
||||
case _WEP104_:
|
||||
case _TKIP_:
|
||||
case _TKIP_WTMIC_:
|
||||
sec_spacing = 6;
|
||||
break;
|
||||
default:
|
||||
sec_spacing = 7;
|
||||
break;
|
||||
}
|
||||
|
||||
if (spacing < sec_spacing)
|
||||
spacing = sec_spacing;
|
||||
|
||||
rtw_write8(adapter, REG_AMPDU_MIN_SPACE,
|
||||
(rtw_read8(adapter, REG_AMPDU_MIN_SPACE) & 0xf8) | spacing);
|
||||
}
|
||||
}
|
||||
|
||||
void HTOnAssocRsp(struct adapter *padapter)
|
||||
{
|
||||
unsigned char max_AMPDU_len;
|
||||
@ -767,7 +815,7 @@ void HTOnAssocRsp(struct adapter *padapter)
|
||||
|
||||
min_MPDU_spacing = (pmlmeinfo->HT_caps.u.HT_cap_element.AMPDU_para & 0x1c) >> 2;
|
||||
|
||||
SetHwReg8188EU(padapter, HW_VAR_AMPDU_MIN_SPACE, (u8 *)(&min_MPDU_spacing));
|
||||
set_min_ampdu_spacing(padapter, min_MPDU_spacing);
|
||||
|
||||
SetHwReg8188EU(padapter, HW_VAR_AMPDU_FACTOR, (u8 *)(&max_AMPDU_len));
|
||||
}
|
||||
@ -846,7 +894,7 @@ int rtw_check_bcn_info(struct adapter *Adapter, u8 *pframe, u32 packet_len)
|
||||
if (!is_client_associated_to_ap(Adapter))
|
||||
return true;
|
||||
|
||||
len = packet_len - sizeof(struct rtw_ieee80211_hdr_3addr);
|
||||
len = packet_len - sizeof(struct ieee80211_hdr_3addr);
|
||||
|
||||
if (len > MAX_IE_SZ)
|
||||
return _FAIL;
|
||||
@ -867,7 +915,7 @@ int rtw_check_bcn_info(struct adapter *Adapter, u8 *pframe, u32 packet_len)
|
||||
|
||||
/* below is to copy the information element */
|
||||
bssid->IELength = len;
|
||||
memcpy(bssid->IEs, (pframe + sizeof(struct rtw_ieee80211_hdr_3addr)), bssid->IELength);
|
||||
memcpy(bssid->IEs, (pframe + sizeof(struct ieee80211_hdr_3addr)), bssid->IELength);
|
||||
|
||||
/* check bw and channel offset */
|
||||
/* parsing HT_CAP_IE */
|
||||
@ -916,7 +964,7 @@ int rtw_check_bcn_info(struct adapter *Adapter, u8 *pframe, u32 packet_len)
|
||||
else
|
||||
hidden_ssid = false;
|
||||
|
||||
if ((NULL != p) && (false == hidden_ssid && (*(p + 1)))) {
|
||||
if (p && (!hidden_ssid && (*(p + 1)))) {
|
||||
memcpy(bssid->Ssid.Ssid, (p + 2), *(p + 1));
|
||||
bssid->Ssid.SsidLength = *(p + 1);
|
||||
} else {
|
||||
@ -1275,14 +1323,10 @@ void update_IOT_info(struct adapter *padapter)
|
||||
case HT_IOT_PEER_RALINK:
|
||||
pmlmeinfo->turboMode_cts2self = 0;
|
||||
pmlmeinfo->turboMode_rtsen = 1;
|
||||
/* disable high power */
|
||||
Switch_DM_Func(padapter, (~DYNAMIC_BB_DYNAMIC_TXPWR), false);
|
||||
break;
|
||||
case HT_IOT_PEER_REALTEK:
|
||||
/* rtw_write16(padapter, 0x4cc, 0xffff); */
|
||||
/* rtw_write16(padapter, 0x546, 0x01c0); */
|
||||
/* disable high power */
|
||||
Switch_DM_Func(padapter, (~DYNAMIC_BB_DYNAMIC_TXPWR), false);
|
||||
break;
|
||||
default:
|
||||
pmlmeinfo->turboMode_cts2self = 0;
|
||||
@ -1291,26 +1335,36 @@ void update_IOT_info(struct adapter *padapter)
|
||||
}
|
||||
}
|
||||
|
||||
static void set_ack_preamble(struct adapter *adapter, bool short_preamble)
|
||||
{
|
||||
struct hal_data_8188e *haldata = &adapter->haldata;
|
||||
u8 val8;
|
||||
|
||||
/* Joseph marked out for Netgear 3500 TKIP channel 7 issue.(Temporarily) */
|
||||
val8 = haldata->nCur40MhzPrimeSC << 5;
|
||||
if (short_preamble)
|
||||
val8 |= 0x80;
|
||||
|
||||
rtw_write8(adapter, REG_RRSR + 2, val8);
|
||||
};
|
||||
|
||||
void update_capinfo(struct adapter *Adapter, u16 updateCap)
|
||||
{
|
||||
struct mlme_ext_priv *pmlmeext = &Adapter->mlmeextpriv;
|
||||
struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
|
||||
bool ShortPreamble;
|
||||
|
||||
/* Check preamble mode, 2005.01.06, by rcnjko. */
|
||||
/* Mark to update preamble value forever, 2008.03.18 by lanhsin */
|
||||
|
||||
if (updateCap & cShortPreamble) { /* Short Preamble */
|
||||
if (pmlmeinfo->preamble_mode != PREAMBLE_SHORT) { /* PREAMBLE_LONG or PREAMBLE_AUTO */
|
||||
ShortPreamble = true;
|
||||
pmlmeinfo->preamble_mode = PREAMBLE_SHORT;
|
||||
SetHwReg8188EU(Adapter, HW_VAR_ACK_PREAMBLE, (u8 *)&ShortPreamble);
|
||||
set_ack_preamble(Adapter, true);
|
||||
}
|
||||
} else { /* Long Preamble */
|
||||
if (pmlmeinfo->preamble_mode != PREAMBLE_LONG) { /* PREAMBLE_SHORT or PREAMBLE_AUTO */
|
||||
ShortPreamble = false;
|
||||
pmlmeinfo->preamble_mode = PREAMBLE_LONG;
|
||||
SetHwReg8188EU(Adapter, HW_VAR_ACK_PREAMBLE, (u8 *)&ShortPreamble);
|
||||
set_ack_preamble(Adapter, false);
|
||||
}
|
||||
}
|
||||
|
||||
@ -1338,7 +1392,6 @@ void update_capinfo(struct adapter *Adapter, u16 updateCap)
|
||||
void update_wireless_mode(struct adapter *padapter)
|
||||
{
|
||||
int ratelen, network_type = 0;
|
||||
u32 SIFS_Timer;
|
||||
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
|
||||
struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
|
||||
struct wlan_bssid_ex *cur_network = &pmlmeinfo->network;
|
||||
@ -1365,10 +1418,12 @@ void update_wireless_mode(struct adapter *padapter)
|
||||
|
||||
pmlmeext->cur_wireless_mode = network_type & padapter->registrypriv.wireless_mode;
|
||||
|
||||
SIFS_Timer = 0x0a0a0808;/* 0x0808 -> for CCK, 0x0a0a -> for OFDM */
|
||||
/* change this value if having IOT issues. */
|
||||
|
||||
SetHwReg8188EU(padapter, HW_VAR_RESP_SIFS, (u8 *)&SIFS_Timer);
|
||||
/* RESP_SIFS for CCK */
|
||||
rtw_write8(padapter, REG_R2T_SIFS, 0x08);
|
||||
rtw_write8(padapter, REG_R2T_SIFS + 1, 0x08);
|
||||
/* RESP_SIFS for OFDM */
|
||||
rtw_write8(padapter, REG_T2T_SIFS, 0x0a);
|
||||
rtw_write8(padapter, REG_T2T_SIFS + 1, 0x0a);
|
||||
|
||||
if (pmlmeext->cur_wireless_mode & WIRELESS_11B)
|
||||
update_mgnt_tx_rate(padapter, IEEE80211_CCK_RATE_1MB);
|
||||
@ -1411,34 +1466,12 @@ int update_sta_support_rate(struct adapter *padapter, u8 *pvar_ie, uint var_ie_l
|
||||
return _SUCCESS;
|
||||
}
|
||||
|
||||
void process_addba_req(struct adapter *padapter, u8 *paddba_req, u8 *addr)
|
||||
{
|
||||
struct sta_info *psta;
|
||||
u16 tid;
|
||||
u16 param;
|
||||
struct recv_reorder_ctrl *preorder_ctrl;
|
||||
struct sta_priv *pstapriv = &padapter->stapriv;
|
||||
struct ADDBA_request *preq = (struct ADDBA_request *)paddba_req;
|
||||
struct mlme_ext_priv *pmlmeext = &padapter->mlmeextpriv;
|
||||
struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
|
||||
|
||||
psta = rtw_get_stainfo(pstapriv, addr);
|
||||
|
||||
if (psta) {
|
||||
param = le16_to_cpu(preq->BA_para_set);
|
||||
tid = (param >> 2) & 0x0f;
|
||||
preorder_ctrl = &psta->recvreorder_ctrl[tid];
|
||||
preorder_ctrl->indicate_seq = 0xffff;
|
||||
preorder_ctrl->enable = (pmlmeinfo->bAcceptAddbaReq) ? true : false;
|
||||
}
|
||||
}
|
||||
|
||||
void update_TSF(struct mlme_ext_priv *pmlmeext, u8 *pframe, uint len)
|
||||
{
|
||||
u8 *pIE;
|
||||
__le32 *pbuf;
|
||||
|
||||
pIE = pframe + sizeof(struct rtw_ieee80211_hdr_3addr);
|
||||
pIE = pframe + sizeof(struct ieee80211_hdr_3addr);
|
||||
pbuf = (__le32 *)pIE;
|
||||
|
||||
pmlmeext->TSFValue = le32_to_cpu(*(pbuf + 1));
|
||||
|
@ -52,8 +52,8 @@ s32 _rtw_init_xmit_priv(struct xmit_priv *pxmitpriv, struct adapter *padapter)
|
||||
sema_init(&pxmitpriv->terminate_xmitthread_sema, 0);
|
||||
|
||||
/*
|
||||
Please insert all the queue initializaiton using rtw_init_queue below
|
||||
*/
|
||||
* Please insert all the queue initializaiton using rtw_init_queue below
|
||||
*/
|
||||
|
||||
pxmitpriv->adapter = padapter;
|
||||
|
||||
@ -66,10 +66,10 @@ s32 _rtw_init_xmit_priv(struct xmit_priv *pxmitpriv, struct adapter *padapter)
|
||||
rtw_init_queue(&pxmitpriv->free_xmit_queue);
|
||||
|
||||
/*
|
||||
Please allocate memory with the sz = (struct xmit_frame) * NR_XMITFRAME,
|
||||
and initialize free_xmit_frame below.
|
||||
Please also apply free_txobj to link_up all the xmit_frames...
|
||||
*/
|
||||
* Please allocate memory with the sz = (struct xmit_frame) * NR_XMITFRAME,
|
||||
* and initialize free_xmit_frame below.
|
||||
* Please also apply free_txobj to link_up all the xmit_frames...
|
||||
*/
|
||||
|
||||
pxmitpriv->pallocated_frame_buf = vzalloc(NR_XMITFRAME * sizeof(struct xmit_frame) + 4);
|
||||
|
||||
@ -178,7 +178,12 @@ s32 _rtw_init_xmit_priv(struct xmit_priv *pxmitpriv, struct adapter *padapter)
|
||||
|
||||
pxmitpriv->free_xmit_extbuf_cnt = num_xmit_extbuf;
|
||||
|
||||
rtw_alloc_hwxmits(padapter);
|
||||
res = rtw_alloc_hwxmits(padapter);
|
||||
if (res) {
|
||||
res = _FAIL;
|
||||
goto exit;
|
||||
}
|
||||
|
||||
rtw_init_hwxmits(pxmitpriv->hwxmits, pxmitpriv->hwxmit_entry);
|
||||
|
||||
for (i = 0; i < 4; i++)
|
||||
@ -399,7 +404,7 @@ static void set_qos(struct pkt_file *ppktfile, struct pkt_attrib *pattrib)
|
||||
|
||||
pattrib->priority = user_prio;
|
||||
pattrib->hdrlen = WLAN_HDR_A3_QOS_LEN;
|
||||
pattrib->subtype = WIFI_QOS_DATA_TYPE;
|
||||
pattrib->subtype = IEEE80211_STYPE_QOS_DATA | IEEE80211_FTYPE_DATA;
|
||||
}
|
||||
|
||||
static s32 update_attrib(struct adapter *padapter, struct sk_buff *pkt, struct pkt_attrib *pattrib)
|
||||
@ -448,14 +453,12 @@ static s32 update_attrib(struct adapter *padapter, struct sk_buff *pkt, struct p
|
||||
_rtw_pktfile_read(&pktfile, &tmp[0], 24);
|
||||
pattrib->dhcp_pkt = 0;
|
||||
if (pktfile.pkt_len > 282) {/* MINIMUM_DHCP_PACKET_SIZE) { */
|
||||
if (ETH_P_IP == pattrib->ether_type) {/* IP header */
|
||||
if (((tmp[21] == 68) && (tmp[23] == 67)) ||
|
||||
((tmp[21] == 67) && (tmp[23] == 68))) {
|
||||
/* 68 : UDP BOOTP client */
|
||||
/* 67 : UDP BOOTP server */
|
||||
/* Use low rate to send DHCP packet. */
|
||||
pattrib->dhcp_pkt = 1;
|
||||
}
|
||||
if (((tmp[21] == 68) && (tmp[23] == 67)) ||
|
||||
((tmp[21] == 67) && (tmp[23] == 68))) {
|
||||
/* 68 : UDP BOOTP client */
|
||||
/* 67 : UDP BOOTP server */
|
||||
/* Use low rate to send DHCP packet. */
|
||||
pattrib->dhcp_pkt = 1;
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -497,7 +500,7 @@ static s32 update_attrib(struct adapter *padapter, struct sk_buff *pkt, struct p
|
||||
pattrib->pkt_hdrlen = ETH_HLEN;/* pattrib->ether_type == 0x8100) ? (14 + 4): 14; vlan tag */
|
||||
|
||||
pattrib->hdrlen = WLAN_HDR_A3_LEN;
|
||||
pattrib->subtype = WIFI_DATA_TYPE;
|
||||
pattrib->subtype = IEEE80211_FTYPE_DATA;
|
||||
pattrib->priority = 0;
|
||||
|
||||
if (check_fwstate(pmlmepriv, WIFI_AP_STATE | WIFI_ADHOC_STATE | WIFI_ADHOC_MASTER_STATE)) {
|
||||
@ -642,7 +645,7 @@ static s32 xmitframe_addmic(struct adapter *padapter, struct xmit_frame *pxmitfr
|
||||
payload = pframe;
|
||||
|
||||
for (curfragnum = 0; curfragnum < pattrib->nr_frags; curfragnum++) {
|
||||
payload = (u8 *)RND4((size_t)(payload));
|
||||
payload = PTR_ALIGN(payload, 4);
|
||||
|
||||
payload = payload + pattrib->hdrlen + pattrib->iv_len;
|
||||
if ((curfragnum + 1) == pattrib->nr_frags) {
|
||||
@ -696,13 +699,13 @@ s32 rtw_make_wlanhdr(struct adapter *padapter, u8 *hdr, struct pkt_attrib *pattr
|
||||
{
|
||||
u16 *qc;
|
||||
|
||||
struct rtw_ieee80211_hdr *pwlanhdr = (struct rtw_ieee80211_hdr *)hdr;
|
||||
struct ieee80211_hdr *pwlanhdr = (struct ieee80211_hdr *)hdr;
|
||||
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
|
||||
struct qos_priv *pqospriv = &pmlmepriv->qospriv;
|
||||
u8 qos_option = false;
|
||||
|
||||
int res = _SUCCESS;
|
||||
__le16 *fctrl = &pwlanhdr->frame_ctl;
|
||||
__le16 *fctrl = &pwlanhdr->frame_control;
|
||||
|
||||
struct sta_info *psta;
|
||||
|
||||
@ -717,7 +720,7 @@ s32 rtw_make_wlanhdr(struct adapter *padapter, u8 *hdr, struct pkt_attrib *pattr
|
||||
|
||||
SetFrameSubType(fctrl, pattrib->subtype);
|
||||
|
||||
if (pattrib->subtype & WIFI_DATA_TYPE) {
|
||||
if (pattrib->subtype & IEEE80211_FTYPE_DATA) {
|
||||
if (check_fwstate(pmlmepriv, WIFI_STATION_STATE)) {
|
||||
/* to_ds = 1, fr_ds = 0; */
|
||||
/* Data transfer to AP */
|
||||
@ -853,22 +856,19 @@ s32 rtw_txframes_sta_ac_pending(struct adapter *padapter, struct pkt_attrib *pat
|
||||
}
|
||||
|
||||
/*
|
||||
|
||||
This sub-routine will perform all the following:
|
||||
|
||||
1. remove 802.3 header.
|
||||
2. create wlan_header, based on the info in pxmitframe
|
||||
3. append sta's iv/ext-iv
|
||||
4. append LLC
|
||||
5. move frag chunk from pframe to pxmitframe->mem
|
||||
6. apply sw-encrypt, if necessary.
|
||||
|
||||
*/
|
||||
* This sub-routine will perform all the following:
|
||||
*
|
||||
* 1. remove 802.3 header.
|
||||
* 2. create wlan_header, based on the info in pxmitframe
|
||||
* 3. append sta's iv/ext-iv
|
||||
* 4. append LLC
|
||||
* 5. move frag chunk from pframe to pxmitframe->mem
|
||||
* 6. apply sw-encrypt, if necessary.
|
||||
*/
|
||||
s32 rtw_xmitframe_coalesce(struct adapter *padapter, struct sk_buff *pkt, struct xmit_frame *pxmitframe)
|
||||
{
|
||||
struct pkt_file pktfile;
|
||||
s32 frg_inx, frg_len, mpdu_len, llc_sz, mem_sz;
|
||||
size_t addr;
|
||||
u8 *pframe, *mem_start;
|
||||
u8 hw_hdr_offset;
|
||||
struct sta_info *psta;
|
||||
@ -985,9 +985,7 @@ s32 rtw_xmitframe_coalesce(struct adapter *padapter, struct sk_buff *pkt, struct
|
||||
break;
|
||||
}
|
||||
|
||||
addr = (size_t)(pframe);
|
||||
|
||||
mem_start = (unsigned char *)RND4(addr) + hw_hdr_offset;
|
||||
mem_start = PTR_ALIGN(pframe, 4) + hw_hdr_offset;
|
||||
memcpy(mem_start, pbuf_start + hw_hdr_offset, pattrib->hdrlen);
|
||||
}
|
||||
|
||||
@ -1210,24 +1208,22 @@ s32 rtw_free_xmitbuf(struct xmit_priv *pxmitpriv, struct xmit_buf *pxmitbuf)
|
||||
}
|
||||
|
||||
/*
|
||||
Calling context:
|
||||
1. OS_TXENTRY
|
||||
2. RXENTRY (rx_thread or RX_ISR/RX_CallBack)
|
||||
|
||||
If we turn on USE_RXTHREAD, then, no need for critical section.
|
||||
Otherwise, we must use _enter/_exit critical to protect free_xmit_queue...
|
||||
|
||||
Must be very very cautious...
|
||||
|
||||
*/
|
||||
|
||||
* Calling context:
|
||||
* 1. OS_TXENTRY
|
||||
* 2. RXENTRY (rx_thread or RX_ISR/RX_CallBack)
|
||||
*
|
||||
* If we turn on USE_RXTHREAD, then, no need for critical section.
|
||||
* Otherwise, we must use _enter/_exit critical to protect free_xmit_queue...
|
||||
*
|
||||
* Must be very very cautious...
|
||||
*/
|
||||
struct xmit_frame *rtw_alloc_xmitframe(struct xmit_priv *pxmitpriv)/* _queue *pfree_xmit_queue) */
|
||||
{
|
||||
/*
|
||||
Please remember to use all the osdep_service api,
|
||||
and lock/unlock or _enter/_exit critical to protect
|
||||
pfree_xmit_queue
|
||||
*/
|
||||
* Please remember to use all the osdep_service api,
|
||||
* and lock/unlock or _enter/_exit critical to protect
|
||||
* pfree_xmit_queue
|
||||
*/
|
||||
|
||||
struct xmit_frame *pxframe = NULL;
|
||||
struct list_head *plist, *phead;
|
||||
@ -1474,7 +1470,7 @@ s32 rtw_xmit_classifier(struct adapter *padapter, struct xmit_frame *pxmitframe)
|
||||
return res;
|
||||
}
|
||||
|
||||
void rtw_alloc_hwxmits(struct adapter *padapter)
|
||||
int rtw_alloc_hwxmits(struct adapter *padapter)
|
||||
{
|
||||
struct hw_xmit *hwxmits;
|
||||
struct xmit_priv *pxmitpriv = &padapter->xmitpriv;
|
||||
@ -1482,6 +1478,8 @@ void rtw_alloc_hwxmits(struct adapter *padapter)
|
||||
pxmitpriv->hwxmit_entry = HWXMIT_ENTRY;
|
||||
|
||||
pxmitpriv->hwxmits = kzalloc(sizeof(struct hw_xmit) * pxmitpriv->hwxmit_entry, GFP_KERNEL);
|
||||
if (!pxmitpriv->hwxmits)
|
||||
return -ENOMEM;
|
||||
|
||||
hwxmits = pxmitpriv->hwxmits;
|
||||
|
||||
@ -1498,6 +1496,8 @@ void rtw_alloc_hwxmits(struct adapter *padapter)
|
||||
hwxmits[3] .sta_queue = &pxmitpriv->bk_pending;
|
||||
} else {
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
void rtw_free_hwxmits(struct adapter *padapter)
|
||||
|
@ -170,7 +170,7 @@ enum HAL_STATUS ODM_ReadAndConfig_AGC_TAB_1T_8188E(struct odm_dm_struct *dm_odm)
|
||||
{
|
||||
u32 hex = 0;
|
||||
u32 i = 0;
|
||||
u32 arraylen = sizeof(array_agc_tab_1t_8188e) / sizeof(u32);
|
||||
u32 arraylen = ARRAY_SIZE(array_agc_tab_1t_8188e);
|
||||
u32 *array = array_agc_tab_1t_8188e;
|
||||
bool biol = false;
|
||||
struct adapter *adapter = dm_odm->Adapter;
|
||||
@ -446,7 +446,7 @@ enum HAL_STATUS ODM_ReadAndConfig_PHY_REG_1T_8188E(struct odm_dm_struct *dm_odm)
|
||||
{
|
||||
u32 hex = 0;
|
||||
u32 i = 0;
|
||||
u32 arraylen = sizeof(array_phy_reg_1t_8188e) / sizeof(u32);
|
||||
u32 arraylen = ARRAY_SIZE(array_phy_reg_1t_8188e);
|
||||
u32 *array = array_phy_reg_1t_8188e;
|
||||
bool biol = false;
|
||||
struct adapter *adapter = dm_odm->Adapter;
|
||||
@ -651,7 +651,7 @@ void ODM_ReadAndConfig_PHY_REG_PG_8188E(struct odm_dm_struct *dm_odm)
|
||||
{
|
||||
u32 hex;
|
||||
u32 i = 0;
|
||||
u32 arraylen = sizeof(array_phy_reg_pg_8188e) / sizeof(u32);
|
||||
u32 arraylen = ARRAY_SIZE(array_phy_reg_pg_8188e);
|
||||
u32 *array = array_phy_reg_pg_8188e;
|
||||
|
||||
hex = ODM_ITRF_USB << 8;
|
||||
|
@ -132,7 +132,7 @@ enum HAL_STATUS ODM_ReadAndConfig_MAC_REG_8188E(struct odm_dm_struct *dm_odm)
|
||||
|
||||
u32 hex = 0;
|
||||
u32 i;
|
||||
u32 array_len = sizeof(array_MAC_REG_8188E) / sizeof(u32);
|
||||
u32 array_len = ARRAY_SIZE(array_MAC_REG_8188E);
|
||||
u32 *array = array_MAC_REG_8188E;
|
||||
bool biol = false;
|
||||
|
||||
|
@ -138,7 +138,7 @@ enum HAL_STATUS ODM_ReadAndConfig_RadioA_1T_8188E(struct odm_dm_struct *pDM_Odm)
|
||||
|
||||
u32 hex = 0;
|
||||
u32 i = 0;
|
||||
u32 ArrayLen = sizeof(Array_RadioA_1T_8188E) / sizeof(u32);
|
||||
u32 ArrayLen = ARRAY_SIZE(Array_RadioA_1T_8188E);
|
||||
u32 *Array = Array_RadioA_1T_8188E;
|
||||
bool biol = false;
|
||||
struct adapter *Adapter = pDM_Odm->Adapter;
|
||||
|
@ -1,30 +1,8 @@
|
||||
// SPDX-License-Identifier: GPL-2.0
|
||||
/* Copyright(c) 2007 - 2011 Realtek Corporation. */
|
||||
|
||||
/*++
|
||||
|
||||
Module Name:
|
||||
HalPwrSeqCmd.c
|
||||
|
||||
Abstract:
|
||||
Implement HW Power sequence configuration CMD handling routine for Realtek devices.
|
||||
|
||||
Major Change History:
|
||||
When Who What
|
||||
---------- --------------- -------------------------------
|
||||
2011-10-26 Lucas Modify to be compatible with SD4-CE driver.
|
||||
2011-07-07 Roger Create.
|
||||
|
||||
--*/
|
||||
|
||||
#include "../include/HalPwrSeqCmd.h"
|
||||
|
||||
/* Description: */
|
||||
/* This routine deals with the Power Configuration CMDs parsing
|
||||
* for RTL8723/RTL8188E Series IC.
|
||||
* Assumption:
|
||||
* We should follow specific format which was released from HW SD.
|
||||
*/
|
||||
u8 HalPwrSeqCmdParsing(struct adapter *padapter, struct wl_pwr_cfg pwrseqcmd[])
|
||||
{
|
||||
struct wl_pwr_cfg pwrcfgcmd = {0};
|
||||
|
@ -44,7 +44,7 @@ void dump_chip_info(struct HAL_VERSION chip_vers)
|
||||
|
||||
cnt += sprintf((buf + cnt), "1T1R_");
|
||||
|
||||
cnt += sprintf((buf + cnt), "RomVer(%d)\n", chip_vers.ROMVer);
|
||||
cnt += sprintf((buf + cnt), "RomVer(%d)\n", 0);
|
||||
|
||||
pr_info("%s", buf);
|
||||
}
|
||||
@ -267,7 +267,7 @@ static void three_out_pipe(struct adapter *adapter, bool wifi_cfg)
|
||||
bool Hal_MappingOutPipe(struct adapter *adapter, u8 numoutpipe)
|
||||
{
|
||||
struct registry_priv *pregistrypriv = &adapter->registrypriv;
|
||||
bool wifi_cfg = (pregistrypriv->wifi_spec) ? true : false;
|
||||
bool wifi_cfg = pregistrypriv->wifi_spec;
|
||||
bool result = true;
|
||||
|
||||
switch (numoutpipe) {
|
||||
|
@ -65,13 +65,13 @@ static void odm_RxPhyStatus92CSeries_Parsing(struct odm_dm_struct *dm_odm,
|
||||
|
||||
struct phy_status_rpt *pPhyStaRpt = (struct phy_status_rpt *)pPhyStatus;
|
||||
|
||||
isCCKrate = ((pPktinfo->Rate >= DESC92C_RATE1M) && (pPktinfo->Rate <= DESC92C_RATE11M)) ? true : false;
|
||||
isCCKrate = pPktinfo->Rate >= DESC92C_RATE1M && pPktinfo->Rate <= DESC92C_RATE11M;
|
||||
|
||||
if (isCCKrate) {
|
||||
u8 cck_agc_rpt;
|
||||
|
||||
/* (1)Hardware does not provide RSSI for CCK */
|
||||
/* (2)PWDB, Average PWDB cacluated by hardware (for rate adaptive) */
|
||||
/* (2)PWDB, Average PWDB calculated by hardware (for rate adaptive) */
|
||||
|
||||
cck_highpwr = dm_odm->bCckHighPower;
|
||||
|
||||
@ -170,7 +170,7 @@ static void odm_RxPhyStatus92CSeries_Parsing(struct odm_dm_struct *dm_odm,
|
||||
/* Get Rx snr value in DB */
|
||||
dm_odm->PhyDbgInfo.RxSNRdB[i] = (s32)(pPhyStaRpt->path_rxsnr[i] / 2);
|
||||
}
|
||||
/* (2)PWDB, Average PWDB cacluated by hardware (for rate adaptive) */
|
||||
/* (2)PWDB, Average PWDB calculated by hardware (for rate adaptive) */
|
||||
rx_pwr_all = (((pPhyStaRpt->cck_sig_qual_ofdm_pwdb_all) >> 1) & 0x7f) - 110;
|
||||
|
||||
PWDB_ALL = odm_QueryRxPwrPercentage(rx_pwr_all);
|
||||
@ -234,7 +234,7 @@ static void odm_Process_RSSIForDM(struct odm_dm_struct *dm_odm,
|
||||
if ((!pPktinfo->bPacketMatchBSSID))
|
||||
return;
|
||||
|
||||
isCCKrate = ((pPktinfo->Rate >= DESC92C_RATE1M) && (pPktinfo->Rate <= DESC92C_RATE11M)) ? true : false;
|
||||
isCCKrate = pPktinfo->Rate >= DESC92C_RATE1M && pPktinfo->Rate <= DESC92C_RATE11M;
|
||||
|
||||
/* Smart Antenna Debug Message------------------ */
|
||||
if ((dm_odm->AntDivType == CG_TRX_HW_ANTDIV) || (dm_odm->AntDivType == CGCS_RX_HW_ANTDIV)) {
|
||||
|
@ -199,16 +199,16 @@ void rtl8188e_set_FwMediaStatus_cmd(struct adapter *adapt, __le16 mstatus_rpt)
|
||||
|
||||
static void ConstructBeacon(struct adapter *adapt, u8 *pframe, u32 *pLength)
|
||||
{
|
||||
struct rtw_ieee80211_hdr *pwlanhdr;
|
||||
struct ieee80211_hdr *pwlanhdr;
|
||||
__le16 *fctrl;
|
||||
u32 rate_len, pktlen;
|
||||
struct mlme_ext_priv *pmlmeext = &adapt->mlmeextpriv;
|
||||
struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
|
||||
struct wlan_bssid_ex *cur_network = &pmlmeinfo->network;
|
||||
|
||||
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
|
||||
pwlanhdr = (struct ieee80211_hdr *)pframe;
|
||||
|
||||
fctrl = &pwlanhdr->frame_ctl;
|
||||
fctrl = &pwlanhdr->frame_control;
|
||||
*(fctrl) = 0;
|
||||
|
||||
eth_broadcast_addr(pwlanhdr->addr1);
|
||||
@ -218,8 +218,8 @@ static void ConstructBeacon(struct adapter *adapt, u8 *pframe, u32 *pLength)
|
||||
SetSeqNum(pwlanhdr, 0/*pmlmeext->mgnt_seq*/);
|
||||
SetFrameSubType(pframe, WIFI_BEACON);
|
||||
|
||||
pframe += sizeof(struct rtw_ieee80211_hdr_3addr);
|
||||
pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
|
||||
pframe += sizeof(struct ieee80211_hdr_3addr);
|
||||
pktlen = sizeof(struct ieee80211_hdr_3addr);
|
||||
|
||||
/* timestamp will be inserted by hardware */
|
||||
pframe += 8;
|
||||
@ -281,15 +281,15 @@ static void ConstructBeacon(struct adapter *adapt, u8 *pframe, u32 *pLength)
|
||||
|
||||
static void ConstructPSPoll(struct adapter *adapt, u8 *pframe, u32 *pLength)
|
||||
{
|
||||
struct rtw_ieee80211_hdr *pwlanhdr;
|
||||
struct ieee80211_hdr *pwlanhdr;
|
||||
struct mlme_ext_priv *pmlmeext = &adapt->mlmeextpriv;
|
||||
struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
|
||||
__le16 *fctrl;
|
||||
|
||||
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
|
||||
pwlanhdr = (struct ieee80211_hdr *)pframe;
|
||||
|
||||
/* Frame control. */
|
||||
fctrl = &pwlanhdr->frame_ctl;
|
||||
fctrl = &pwlanhdr->frame_control;
|
||||
*(fctrl) = 0;
|
||||
SetPwrMgt(fctrl);
|
||||
SetFrameSubType(pframe, WIFI_PSPOLL);
|
||||
@ -314,7 +314,7 @@ static void ConstructNullFunctionData(struct adapter *adapt, u8 *pframe,
|
||||
u8 bEosp,
|
||||
u8 bForcePowerSave)
|
||||
{
|
||||
struct rtw_ieee80211_hdr *pwlanhdr;
|
||||
struct ieee80211_hdr *pwlanhdr;
|
||||
__le16 *fctrl;
|
||||
u32 pktlen;
|
||||
struct mlme_priv *pmlmepriv = &adapt->mlmepriv;
|
||||
@ -322,9 +322,9 @@ static void ConstructNullFunctionData(struct adapter *adapt, u8 *pframe,
|
||||
struct mlme_ext_priv *pmlmeext = &adapt->mlmeextpriv;
|
||||
struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
|
||||
|
||||
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
|
||||
pwlanhdr = (struct ieee80211_hdr *)pframe;
|
||||
|
||||
fctrl = &pwlanhdr->frame_ctl;
|
||||
fctrl = &pwlanhdr->frame_control;
|
||||
*(fctrl) = 0;
|
||||
if (bForcePowerSave)
|
||||
SetPwrMgt(fctrl);
|
||||
@ -353,19 +353,19 @@ static void ConstructNullFunctionData(struct adapter *adapt, u8 *pframe,
|
||||
SetSeqNum(pwlanhdr, 0);
|
||||
|
||||
if (bQoS) {
|
||||
struct rtw_ieee80211_hdr_3addr_qos *pwlanqoshdr;
|
||||
struct ieee80211_qos_hdr *pwlanqoshdr;
|
||||
|
||||
SetFrameSubType(pframe, WIFI_QOS_DATA_NULL);
|
||||
|
||||
pwlanqoshdr = (struct rtw_ieee80211_hdr_3addr_qos *)pframe;
|
||||
SetPriority(&pwlanqoshdr->qc, AC);
|
||||
SetEOSP(&pwlanqoshdr->qc, bEosp);
|
||||
pwlanqoshdr = (struct ieee80211_qos_hdr *)pframe;
|
||||
SetPriority(&pwlanqoshdr->qos_ctrl, AC);
|
||||
SetEOSP(&pwlanqoshdr->qos_ctrl, bEosp);
|
||||
|
||||
pktlen = sizeof(struct rtw_ieee80211_hdr_3addr_qos);
|
||||
pktlen = sizeof(struct ieee80211_qos_hdr);
|
||||
} else {
|
||||
SetFrameSubType(pframe, WIFI_DATA_NULL);
|
||||
|
||||
pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
|
||||
pktlen = sizeof(struct ieee80211_qos_hdr);
|
||||
}
|
||||
|
||||
*pLength = pktlen;
|
||||
@ -373,7 +373,7 @@ static void ConstructNullFunctionData(struct adapter *adapt, u8 *pframe,
|
||||
|
||||
static void ConstructProbeRsp(struct adapter *adapt, u8 *pframe, u32 *pLength, u8 *StaAddr, bool bHideSSID)
|
||||
{
|
||||
struct rtw_ieee80211_hdr *pwlanhdr;
|
||||
struct ieee80211_hdr *pwlanhdr;
|
||||
__le16 *fctrl;
|
||||
u8 *mac, *bssid;
|
||||
u32 pktlen;
|
||||
@ -381,12 +381,12 @@ static void ConstructProbeRsp(struct adapter *adapt, u8 *pframe, u32 *pLength, u
|
||||
struct mlme_ext_info *pmlmeinfo = &pmlmeext->mlmext_info;
|
||||
struct wlan_bssid_ex *cur_network = &pmlmeinfo->network;
|
||||
|
||||
pwlanhdr = (struct rtw_ieee80211_hdr *)pframe;
|
||||
pwlanhdr = (struct ieee80211_hdr *)pframe;
|
||||
|
||||
mac = myid(&adapt->eeprompriv);
|
||||
bssid = cur_network->MacAddress;
|
||||
|
||||
fctrl = &pwlanhdr->frame_ctl;
|
||||
fctrl = &pwlanhdr->frame_control;
|
||||
*(fctrl) = 0;
|
||||
memcpy(pwlanhdr->addr1, StaAddr, ETH_ALEN);
|
||||
memcpy(pwlanhdr->addr2, mac, ETH_ALEN);
|
||||
@ -395,7 +395,7 @@ static void ConstructProbeRsp(struct adapter *adapt, u8 *pframe, u32 *pLength, u
|
||||
SetSeqNum(pwlanhdr, 0);
|
||||
SetFrameSubType(fctrl, WIFI_PROBERSP);
|
||||
|
||||
pktlen = sizeof(struct rtw_ieee80211_hdr_3addr);
|
||||
pktlen = sizeof(struct ieee80211_hdr_3addr);
|
||||
pframe += pktlen;
|
||||
|
||||
if (cur_network->IELength > MAX_IE_SZ)
|
||||
@ -557,8 +557,7 @@ void rtl8188e_set_FwJoinBssReport_cmd(struct adapter *adapt, u8 mstatus)
|
||||
rtw_write8(adapt, REG_FWHW_TXQ_CTRL + 2, (haldata->RegFwHwTxQCtrl & (~BIT(6))));
|
||||
haldata->RegFwHwTxQCtrl &= (~BIT(6));
|
||||
|
||||
/* Clear beacon valid check bit. */
|
||||
SetHwReg8188EU(adapt, HW_VAR_BCN_VALID, NULL);
|
||||
clear_beacon_valid_bit(adapt);
|
||||
DLBcnCount = 0;
|
||||
poll = 0;
|
||||
do {
|
||||
@ -569,7 +568,7 @@ void rtl8188e_set_FwJoinBssReport_cmd(struct adapter *adapt, u8 mstatus)
|
||||
yield();
|
||||
/* mdelay(10); */
|
||||
/* check rsvd page download OK. */
|
||||
GetHwReg8188EU(adapt, HW_VAR_BCN_VALID, (u8 *)(&bcn_valid));
|
||||
bcn_valid = get_beacon_valid_bit(adapt);
|
||||
poll++;
|
||||
} while (!bcn_valid && (poll % 10) != 0 && !adapt->bSurpriseRemoved && !adapt->bDriverStopped);
|
||||
} while (!bcn_valid && DLBcnCount <= 100 && !adapt->bSurpriseRemoved && !adapt->bDriverStopped);
|
||||
@ -597,7 +596,7 @@ void rtl8188e_set_FwJoinBssReport_cmd(struct adapter *adapt, u8 mstatus)
|
||||
|
||||
/* Update RSVD page location H2C to Fw. */
|
||||
if (bcn_valid)
|
||||
SetHwReg8188EU(adapt, HW_VAR_BCN_VALID, NULL);
|
||||
clear_beacon_valid_bit(adapt);
|
||||
|
||||
/* Do not enable HW DMA BCN or it will cause Pcie interface hang by timing issue. 2011.11.24. by tynli. */
|
||||
/* Clear CR[8] or beacon packet will not be send to TxBuf anymore. */
|
||||
|
@ -33,17 +33,16 @@ static s32 iol_execute(struct adapter *padapter, u8 control)
|
||||
{
|
||||
s32 status = _FAIL;
|
||||
u8 reg_0x88 = 0;
|
||||
u32 start = 0, passing_time = 0;
|
||||
unsigned long timeout;
|
||||
|
||||
control = control & 0x0f;
|
||||
reg_0x88 = rtw_read8(padapter, REG_HMEBOX_E0);
|
||||
rtw_write8(padapter, REG_HMEBOX_E0, reg_0x88 | control);
|
||||
|
||||
start = jiffies;
|
||||
timeout = jiffies + msecs_to_jiffies(1000);
|
||||
while ((reg_0x88 = rtw_read8(padapter, REG_HMEBOX_E0)) & control &&
|
||||
(passing_time = rtw_get_passing_time_ms(start)) < 1000) {
|
||||
time_before(jiffies, timeout))
|
||||
;
|
||||
}
|
||||
|
||||
reg_0x88 = rtw_read8(padapter, REG_HMEBOX_E0);
|
||||
status = (reg_0x88 & control) ? _FAIL : _SUCCESS;
|
||||
@ -187,8 +186,8 @@ static void efuse_read_phymap_from_txpktbuf(
|
||||
u16 *size /* for efuse content: the max byte to read. will update to byte read */
|
||||
)
|
||||
{
|
||||
unsigned long timeout;
|
||||
u16 dbg_addr = 0;
|
||||
u32 start = 0, passing_time = 0;
|
||||
__le32 lo32 = 0, hi32 = 0;
|
||||
u16 len = 0, count = 0;
|
||||
int i = 0;
|
||||
@ -207,9 +206,8 @@ static void efuse_read_phymap_from_txpktbuf(
|
||||
rtw_write16(adapter, REG_PKTBUF_DBG_ADDR, dbg_addr + i);
|
||||
|
||||
rtw_write8(adapter, REG_TXPKTBUF_DBG, 0);
|
||||
start = jiffies;
|
||||
while (!rtw_read8(adapter, REG_TXPKTBUF_DBG) &&
|
||||
(passing_time = rtw_get_passing_time_ms(start)) < 1000)
|
||||
timeout = jiffies + msecs_to_jiffies(1000);
|
||||
while (!rtw_read8(adapter, REG_TXPKTBUF_DBG) && time_before(jiffies, timeout))
|
||||
rtw_usleep_os(100);
|
||||
|
||||
/* data from EEPROM needs to be in LE */
|
||||
@ -505,7 +503,6 @@ void rtl8188e_read_chip_version(struct adapter *padapter)
|
||||
|
||||
ChipVersion.VendorType = ((value32 & VENDOR_ID) ? CHIP_VENDOR_UMC : CHIP_VENDOR_TSMC);
|
||||
ChipVersion.CUTVersion = (value32 & CHIP_VER_RTL_MASK) >> CHIP_VER_RTL_SHIFT; /* IC version (CUT) */
|
||||
ChipVersion.ROMVer = 0; /* ROM code version. */
|
||||
|
||||
dump_chip_info(ChipVersion);
|
||||
|
||||
|
@ -378,10 +378,10 @@ phy_InitBBRFRegisterDefinition(
|
||||
/* Tx AGC Gain Stage (same for all path. Should we remove this?) */
|
||||
pHalData->PHYRegDef.rfTxGainStage = rFPGA0_TxGainStage; /* Tx gain stage */
|
||||
|
||||
/* Tranceiver A~D HSSI Parameter-1 */
|
||||
/* Transceiver A~D HSSI Parameter-1 */
|
||||
pHalData->PHYRegDef.rfHSSIPara1 = rFPGA0_XA_HSSIParameter1; /* wire control parameter1 */
|
||||
|
||||
/* Tranceiver A~D HSSI Parameter-2 */
|
||||
/* Transceiver A~D HSSI Parameter-2 */
|
||||
pHalData->PHYRegDef.rfHSSIPara2 = rFPGA0_XA_HSSIParameter2; /* wire control parameter2 */
|
||||
|
||||
/* RF switch Control */
|
||||
@ -405,10 +405,10 @@ phy_InitBBRFRegisterDefinition(
|
||||
/* Tx AFE control 2 */
|
||||
pHalData->PHYRegDef.rfTxAFE = rOFDM0_XATxAFE;
|
||||
|
||||
/* Tranceiver LSSI Readback SI mode */
|
||||
/* Transceiver LSSI Readback SI mode */
|
||||
pHalData->PHYRegDef.rfLSSIReadBack = rFPGA0_XA_LSSIReadBack;
|
||||
|
||||
/* Tranceiver LSSI Readback PI mode */
|
||||
/* Transceiver LSSI Readback PI mode */
|
||||
pHalData->PHYRegDef.rfLSSIReadBackPi = TransceiverA_HSPI_Readback;
|
||||
}
|
||||
|
||||
|
@ -113,12 +113,13 @@ void update_recvframe_phyinfo_88e(struct recv_frame *precvframe, struct phy_stat
|
||||
struct hal_data_8188e *pHalData = &padapter->haldata;
|
||||
struct phy_info *pPHYInfo = &pattrib->phy_info;
|
||||
u8 *wlanhdr = precvframe->rx_data;
|
||||
__le16 fc = *(__le16 *)wlanhdr;
|
||||
struct odm_per_pkt_info pkt_info;
|
||||
u8 *sa = NULL;
|
||||
struct sta_priv *pstapriv;
|
||||
struct sta_info *psta;
|
||||
|
||||
pkt_info.bPacketMatchBSSID = ((!IsFrameTypeCtrl(wlanhdr)) &&
|
||||
pkt_info.bPacketMatchBSSID = ((!ieee80211_is_ctl(fc)) &&
|
||||
!pattrib->icv_err && !pattrib->crc_err &&
|
||||
!memcmp(get_hdr_bssid(wlanhdr),
|
||||
get_bssid(&padapter->mlmepriv), ETH_ALEN));
|
||||
@ -127,9 +128,7 @@ void update_recvframe_phyinfo_88e(struct recv_frame *precvframe, struct phy_stat
|
||||
(!memcmp(get_da(wlanhdr),
|
||||
myid(&padapter->eeprompriv), ETH_ALEN));
|
||||
|
||||
pkt_info.bPacketBeacon = pkt_info.bPacketMatchBSSID &&
|
||||
(GetFrameSubType(wlanhdr) == WIFI_BEACON);
|
||||
|
||||
pkt_info.bPacketBeacon = pkt_info.bPacketMatchBSSID && ieee80211_is_beacon(fc);
|
||||
if (pkt_info.bPacketBeacon) {
|
||||
if (check_fwstate(&padapter->mlmepriv, WIFI_STATION_STATE))
|
||||
sa = padapter->mlmepriv.cur_network.network.MacAddress;
|
||||
|
@ -347,7 +347,7 @@ static s32 rtw_dump_xframe(struct adapter *adapt, struct xmit_frame *pxmitframe)
|
||||
|
||||
mem_addr += w_sz;
|
||||
|
||||
mem_addr = (u8 *)RND4(((size_t)(mem_addr)));
|
||||
mem_addr = PTR_ALIGN(mem_addr, 4);
|
||||
}
|
||||
|
||||
rtw_free_xmitframe(pxmitpriv, pxmitframe);
|
||||
@ -437,7 +437,7 @@ bool rtl8188eu_xmitframe_complete(struct adapter *adapt, struct xmit_priv *pxmit
|
||||
pfirstframe = pxmitframe;
|
||||
len = xmitframe_need_length(pfirstframe) + TXDESC_SIZE + (pfirstframe->pkt_offset * PACKET_OFFSET_SZ);
|
||||
pbuf_tail = len;
|
||||
pbuf = _RND8(pbuf_tail);
|
||||
pbuf = round_up(pbuf_tail, 8);
|
||||
|
||||
/* check pkt amount in one bulk */
|
||||
desc_cnt = 0;
|
||||
@ -488,7 +488,7 @@ bool rtl8188eu_xmitframe_complete(struct adapter *adapt, struct xmit_priv *pxmit
|
||||
|
||||
len = xmitframe_need_length(pxmitframe) + TXDESC_SIZE + (pxmitframe->pkt_offset * PACKET_OFFSET_SZ);
|
||||
|
||||
if (_RND8(pbuf + len) > MAX_XMITBUF_SZ) {
|
||||
if (pbuf + len > MAX_XMITBUF_SZ) {
|
||||
pxmitframe->agg_num = 1;
|
||||
pxmitframe->pkt_offset = 1;
|
||||
break;
|
||||
@ -511,7 +511,7 @@ bool rtl8188eu_xmitframe_complete(struct adapter *adapt, struct xmit_priv *pxmit
|
||||
|
||||
/* handle pointer and stop condition */
|
||||
pbuf_tail = pbuf + len;
|
||||
pbuf = _RND8(pbuf_tail);
|
||||
pbuf = round_up(pbuf_tail, 8);
|
||||
|
||||
pfirstframe->agg_num++;
|
||||
if (MAX_TX_AGG_PACKET_NUMBER == pfirstframe->agg_num)
|
||||
|
@ -123,7 +123,7 @@ static void _InitQueueReservedPage(struct adapter *Adapter)
|
||||
if (haldata->OutEpQueueSel & TX_SELE_LQ)
|
||||
numLQ = 0x1C;
|
||||
|
||||
/* NOTE: This step shall be proceed before writting REG_RQPN. */
|
||||
/* NOTE: This step shall be proceed before writing REG_RQPN. */
|
||||
if (haldata->OutEpQueueSel & TX_SELE_NQ)
|
||||
numNQ = 0x1C;
|
||||
value8 = (u8)_NPQ(numNQ);
|
||||
@ -539,10 +539,6 @@ u32 rtl8188eu_hal_init(struct adapter *Adapter)
|
||||
/* Save target channel */
|
||||
haldata->CurrentChannel = 6;/* default set to 6 */
|
||||
|
||||
if (pwrctrlpriv->reg_rfoff) {
|
||||
pwrctrlpriv->rf_pwrstate = rf_off;
|
||||
}
|
||||
|
||||
/* 2010/08/09 MH We need to check if we need to turnon or off RF after detecting */
|
||||
/* HW GPIO pin. Before PHY_RFConfig8192C. */
|
||||
/* 2010/08/26 MH If Efuse does not support sective suspend then disable the function. */
|
||||
@ -942,17 +938,6 @@ static void hw_var_set_opmode(struct adapter *Adapter, u8 *val)
|
||||
}
|
||||
}
|
||||
|
||||
static void hw_var_set_bssid(struct adapter *Adapter, u8 *val)
|
||||
{
|
||||
u8 idx = 0;
|
||||
u32 reg_bssid;
|
||||
|
||||
reg_bssid = REG_BSSID;
|
||||
|
||||
for (idx = 0; idx < 6; idx++)
|
||||
rtw_write8(Adapter, (reg_bssid + idx), val[idx]);
|
||||
}
|
||||
|
||||
void SetHwReg8188EU(struct adapter *Adapter, u8 variable, u8 *val)
|
||||
{
|
||||
struct hal_data_8188e *haldata = &Adapter->haldata;
|
||||
@ -963,9 +948,6 @@ void SetHwReg8188EU(struct adapter *Adapter, u8 variable, u8 *val)
|
||||
case HW_VAR_SET_OPMODE:
|
||||
hw_var_set_opmode(Adapter, val);
|
||||
break;
|
||||
case HW_VAR_BSSID:
|
||||
hw_var_set_bssid(Adapter, val);
|
||||
break;
|
||||
case HW_VAR_BASIC_RATE:
|
||||
{
|
||||
u16 BrateCfg = 0;
|
||||
@ -1024,17 +1006,6 @@ void SetHwReg8188EU(struct adapter *Adapter, u8 variable, u8 *val)
|
||||
ResumeTxBeacon(Adapter);
|
||||
}
|
||||
break;
|
||||
case HW_VAR_MLME_DISCONNECT:
|
||||
/* Set RCR to not to receive data frame when NO LINK state */
|
||||
/* reject all data frames */
|
||||
rtw_write16(Adapter, REG_RXFLTMAP2, 0x00);
|
||||
|
||||
/* reset TSF */
|
||||
rtw_write8(Adapter, REG_DUAL_TSF_RST, (BIT(0) | BIT(1)));
|
||||
|
||||
/* disable update TSF */
|
||||
rtw_write8(Adapter, REG_BCN_CTRL, rtw_read8(Adapter, REG_BCN_CTRL) | BIT(4));
|
||||
break;
|
||||
case HW_VAR_MLME_SITESURVEY:
|
||||
if (*((u8 *)val)) { /* under sitesurvey */
|
||||
/* config RCR to receive different BSSID & not to receive data frame */
|
||||
@ -1065,36 +1036,6 @@ void SetHwReg8188EU(struct adapter *Adapter, u8 variable, u8 *val)
|
||||
rtw_write32(Adapter, REG_RCR, rtw_read32(Adapter, REG_RCR) | RCR_CBSSID_BCN);
|
||||
}
|
||||
break;
|
||||
case HW_VAR_MLME_JOIN:
|
||||
{
|
||||
u8 RetryLimit = 0x30;
|
||||
u8 type = *((u8 *)val);
|
||||
struct mlme_priv *pmlmepriv = &Adapter->mlmepriv;
|
||||
|
||||
if (type == 0) { /* prepare to join */
|
||||
/* enable to rx data frame.Accept all data frame */
|
||||
rtw_write16(Adapter, REG_RXFLTMAP2, 0xFFFF);
|
||||
|
||||
rtw_write32(Adapter, REG_RCR, rtw_read32(Adapter, REG_RCR) | RCR_CBSSID_DATA | RCR_CBSSID_BCN);
|
||||
|
||||
if (check_fwstate(pmlmepriv, WIFI_STATION_STATE))
|
||||
RetryLimit = 48;
|
||||
else /* Ad-hoc Mode */
|
||||
RetryLimit = 0x7;
|
||||
} else if (type == 1) {
|
||||
/* joinbss_event call back when join res < 0 */
|
||||
rtw_write16(Adapter, REG_RXFLTMAP2, 0x00);
|
||||
} else if (type == 2) {
|
||||
/* sta add event call back */
|
||||
/* enable update TSF */
|
||||
rtw_write8(Adapter, REG_BCN_CTRL, rtw_read8(Adapter, REG_BCN_CTRL) & (~BIT(4)));
|
||||
|
||||
if (check_fwstate(pmlmepriv, WIFI_ADHOC_STATE | WIFI_ADHOC_MASTER_STATE))
|
||||
RetryLimit = 0x7;
|
||||
}
|
||||
rtw_write16(Adapter, REG_RL, RetryLimit << RETRY_LIMIT_SHORT_SHIFT | RetryLimit << RETRY_LIMIT_LONG_SHIFT);
|
||||
}
|
||||
break;
|
||||
case HW_VAR_SLOT_TIME:
|
||||
{
|
||||
u8 u1bAIFS, aSifsTime;
|
||||
@ -1119,26 +1060,6 @@ void SetHwReg8188EU(struct adapter *Adapter, u8 variable, u8 *val)
|
||||
}
|
||||
}
|
||||
break;
|
||||
case HW_VAR_RESP_SIFS:
|
||||
/* RESP_SIFS for CCK */
|
||||
rtw_write8(Adapter, REG_R2T_SIFS, val[0]); /* SIFS_T2T_CCK (0x08) */
|
||||
rtw_write8(Adapter, REG_R2T_SIFS + 1, val[1]); /* SIFS_R2T_CCK(0x08) */
|
||||
/* RESP_SIFS for OFDM */
|
||||
rtw_write8(Adapter, REG_T2T_SIFS, val[2]); /* SIFS_T2T_OFDM (0x0a) */
|
||||
rtw_write8(Adapter, REG_T2T_SIFS + 1, val[3]); /* SIFS_R2T_OFDM(0x0a) */
|
||||
break;
|
||||
case HW_VAR_ACK_PREAMBLE:
|
||||
{
|
||||
u8 regTmp;
|
||||
u8 bShortPreamble = *((bool *)val);
|
||||
/* Joseph marked out for Netgear 3500 TKIP channel 7 issue.(Temporarily) */
|
||||
regTmp = (haldata->nCur40MhzPrimeSC) << 5;
|
||||
if (bShortPreamble)
|
||||
regTmp |= 0x80;
|
||||
|
||||
rtw_write8(Adapter, REG_RRSR + 2, regTmp);
|
||||
}
|
||||
break;
|
||||
case HW_VAR_DM_FLAG:
|
||||
podmpriv->SupportAbility = *((u8 *)val);
|
||||
break;
|
||||
@ -1148,73 +1069,11 @@ void SetHwReg8188EU(struct adapter *Adapter, u8 variable, u8 *val)
|
||||
else
|
||||
podmpriv->SupportAbility = podmpriv->BK_SupportAbility;
|
||||
break;
|
||||
case HW_VAR_DM_FUNC_SET:
|
||||
if (*((u32 *)val) == DYNAMIC_ALL_FUNC_ENABLE) {
|
||||
podmpriv->SupportAbility = pdmpriv->InitODMFlag;
|
||||
} else {
|
||||
podmpriv->SupportAbility |= *((u32 *)val);
|
||||
}
|
||||
case HW_VAR_DM_FUNC_RESET:
|
||||
podmpriv->SupportAbility = pdmpriv->InitODMFlag;
|
||||
break;
|
||||
case HW_VAR_DM_FUNC_CLR:
|
||||
podmpriv->SupportAbility &= *((u32 *)val);
|
||||
break;
|
||||
case HW_VAR_AC_PARAM_BE:
|
||||
haldata->AcParam_BE = ((u32 *)(val))[0];
|
||||
rtw_write32(Adapter, REG_EDCA_BE_PARAM, ((u32 *)(val))[0]);
|
||||
break;
|
||||
case HW_VAR_ACM_CTRL:
|
||||
{
|
||||
u8 acm_ctrl = *((u8 *)val);
|
||||
u8 AcmCtrl = rtw_read8(Adapter, REG_ACMHWCTRL);
|
||||
|
||||
if (acm_ctrl > 1)
|
||||
AcmCtrl = AcmCtrl | 0x1;
|
||||
|
||||
if (acm_ctrl & BIT(3))
|
||||
AcmCtrl |= AcmHw_VoqEn;
|
||||
else
|
||||
AcmCtrl &= (~AcmHw_VoqEn);
|
||||
|
||||
if (acm_ctrl & BIT(2))
|
||||
AcmCtrl |= AcmHw_ViqEn;
|
||||
else
|
||||
AcmCtrl &= (~AcmHw_ViqEn);
|
||||
|
||||
if (acm_ctrl & BIT(1))
|
||||
AcmCtrl |= AcmHw_BeqEn;
|
||||
else
|
||||
AcmCtrl &= (~AcmHw_BeqEn);
|
||||
|
||||
rtw_write8(Adapter, REG_ACMHWCTRL, AcmCtrl);
|
||||
}
|
||||
break;
|
||||
case HW_VAR_AMPDU_MIN_SPACE:
|
||||
{
|
||||
u8 MinSpacingToSet;
|
||||
u8 SecMinSpace;
|
||||
|
||||
MinSpacingToSet = *((u8 *)val);
|
||||
if (MinSpacingToSet <= 7) {
|
||||
switch (Adapter->securitypriv.dot11PrivacyAlgrthm) {
|
||||
case _NO_PRIVACY_:
|
||||
case _AES_:
|
||||
SecMinSpace = 0;
|
||||
break;
|
||||
case _WEP40_:
|
||||
case _WEP104_:
|
||||
case _TKIP_:
|
||||
case _TKIP_WTMIC_:
|
||||
SecMinSpace = 6;
|
||||
break;
|
||||
default:
|
||||
SecMinSpace = 7;
|
||||
break;
|
||||
}
|
||||
if (MinSpacingToSet < SecMinSpace)
|
||||
MinSpacingToSet = SecMinSpace;
|
||||
rtw_write8(Adapter, REG_AMPDU_MIN_SPACE, (rtw_read8(Adapter, REG_AMPDU_MIN_SPACE) & 0xf8) | MinSpacingToSet);
|
||||
}
|
||||
}
|
||||
podmpriv->SupportAbility = 0;
|
||||
break;
|
||||
case HW_VAR_AMPDU_FACTOR:
|
||||
{
|
||||
@ -1242,221 +1101,15 @@ void SetHwReg8188EU(struct adapter *Adapter, u8 variable, u8 *val)
|
||||
}
|
||||
}
|
||||
break;
|
||||
case HW_VAR_RXDMA_AGG_PG_TH:
|
||||
{
|
||||
u8 threshold = *((u8 *)val);
|
||||
if (threshold == 0)
|
||||
threshold = USB_RXAGG_PAGE_COUNT;
|
||||
rtw_write8(Adapter, REG_RXDMA_AGG_PG_TH, threshold);
|
||||
}
|
||||
break;
|
||||
case HW_VAR_H2C_FW_PWRMODE:
|
||||
{
|
||||
u8 psmode = (*(u8 *)val);
|
||||
|
||||
/* Forece leave RF low power mode for 1T1R to prevent conficting setting in Fw power */
|
||||
/* saving sequence. 2010.06.07. Added by tynli. Suggested by SD3 yschang. */
|
||||
if (psmode != PS_MODE_ACTIVE)
|
||||
ODM_RF_Saving(podmpriv, true);
|
||||
rtl8188e_set_FwPwrMode_cmd(Adapter, psmode);
|
||||
}
|
||||
break;
|
||||
case HW_VAR_H2C_FW_JOINBSSRPT:
|
||||
{
|
||||
u8 mstatus = (*(u8 *)val);
|
||||
rtl8188e_set_FwJoinBssReport_cmd(Adapter, mstatus);
|
||||
}
|
||||
break;
|
||||
case HW_VAR_H2C_FW_P2P_PS_OFFLOAD:
|
||||
{
|
||||
u8 p2p_ps_state = (*(u8 *)val);
|
||||
rtl8188e_set_p2p_ps_offload_cmd(Adapter, p2p_ps_state);
|
||||
}
|
||||
break;
|
||||
case HW_VAR_INITIAL_GAIN:
|
||||
{
|
||||
struct rtw_dig *pDigTable = &podmpriv->DM_DigTable;
|
||||
u32 rx_gain = ((u32 *)(val))[0];
|
||||
|
||||
if (rx_gain == 0xff) {/* restore rx gain */
|
||||
ODM_Write_DIG(podmpriv, pDigTable->BackupIGValue);
|
||||
} else {
|
||||
pDigTable->BackupIGValue = pDigTable->CurIGValue;
|
||||
ODM_Write_DIG(podmpriv, rx_gain);
|
||||
}
|
||||
}
|
||||
break;
|
||||
case HW_VAR_RPT_TIMER_SETTING:
|
||||
{
|
||||
u16 min_rpt_time = (*(u16 *)val);
|
||||
ODM_RA_Set_TxRPT_Time(podmpriv, min_rpt_time);
|
||||
}
|
||||
break;
|
||||
case HW_VAR_ANTENNA_DIVERSITY_SELECT:
|
||||
{
|
||||
u8 Optimum_antenna = (*(u8 *)val);
|
||||
u8 Ant;
|
||||
/* switch antenna to Optimum_antenna */
|
||||
if (haldata->CurAntenna != Optimum_antenna) {
|
||||
Ant = (Optimum_antenna == 2) ? MAIN_ANT : AUX_ANT;
|
||||
ODM_UpdateRxIdleAnt_88E(&haldata->odmpriv, Ant);
|
||||
|
||||
haldata->CurAntenna = Optimum_antenna;
|
||||
}
|
||||
}
|
||||
break;
|
||||
case HW_VAR_FIFO_CLEARN_UP:
|
||||
{
|
||||
struct pwrctrl_priv *pwrpriv = &Adapter->pwrctrlpriv;
|
||||
u8 trycnt = 100;
|
||||
|
||||
/* pause tx */
|
||||
rtw_write8(Adapter, REG_TXPAUSE, 0xff);
|
||||
|
||||
/* keep sn */
|
||||
Adapter->xmitpriv.nqos_ssn = rtw_read16(Adapter, REG_NQOS_SEQ);
|
||||
|
||||
if (!pwrpriv->bkeepfwalive) {
|
||||
/* RX DMA stop */
|
||||
rtw_write32(Adapter, REG_RXPKT_NUM, (rtw_read32(Adapter, REG_RXPKT_NUM) | RW_RELEASE_EN));
|
||||
do {
|
||||
if (!(rtw_read32(Adapter, REG_RXPKT_NUM) & RXDMA_IDLE))
|
||||
break;
|
||||
} while (trycnt--);
|
||||
|
||||
/* RQPN Load 0 */
|
||||
rtw_write16(Adapter, REG_RQPN_NPQ, 0x0);
|
||||
rtw_write32(Adapter, REG_RQPN, 0x80000000);
|
||||
mdelay(10);
|
||||
}
|
||||
}
|
||||
break;
|
||||
case HW_VAR_TX_RPT_MAX_MACID:
|
||||
{
|
||||
u8 maxMacid = *val;
|
||||
rtw_write8(Adapter, REG_TX_RPT_CTRL + 1, maxMacid + 1);
|
||||
}
|
||||
break;
|
||||
case HW_VAR_H2C_MEDIA_STATUS_RPT:
|
||||
rtl8188e_set_FwMediaStatus_cmd(Adapter, (*(__le16 *)val));
|
||||
break;
|
||||
case HW_VAR_BCN_VALID:
|
||||
/* BCN_VALID, BIT(16) of REG_TDECTRL = BIT(0) of REG_TDECTRL+2, write 1 to clear, Clear by sw */
|
||||
rtw_write8(Adapter, REG_TDECTRL + 2, rtw_read8(Adapter, REG_TDECTRL + 2) | BIT(0));
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
void GetHwReg8188EU(struct adapter *Adapter, u8 variable, u8 *val)
|
||||
{
|
||||
struct hal_data_8188e *haldata = &Adapter->haldata;
|
||||
struct odm_dm_struct *podmpriv = &haldata->odmpriv;
|
||||
|
||||
switch (variable) {
|
||||
case HW_VAR_BCN_VALID:
|
||||
/* BCN_VALID, BIT(16) of REG_TDECTRL = BIT(0) of REG_TDECTRL+2 */
|
||||
val[0] = (BIT(0) & rtw_read8(Adapter, REG_TDECTRL + 2)) ? true : false;
|
||||
break;
|
||||
case HW_VAR_DM_FLAG:
|
||||
val[0] = podmpriv->SupportAbility;
|
||||
break;
|
||||
case HW_VAR_FWLPS_RF_ON:
|
||||
{
|
||||
/* When we halt NIC, we should check if FW LPS is leave. */
|
||||
if (Adapter->pwrctrlpriv.rf_pwrstate == rf_off) {
|
||||
/* If it is in HW/SW Radio OFF or IPS state, we do not check Fw LPS Leave, */
|
||||
/* because Fw is unload. */
|
||||
val[0] = true;
|
||||
} else {
|
||||
u32 valRCR;
|
||||
valRCR = rtw_read32(Adapter, REG_RCR);
|
||||
valRCR &= 0x00070000;
|
||||
if (valRCR)
|
||||
val[0] = false;
|
||||
else
|
||||
val[0] = true;
|
||||
}
|
||||
}
|
||||
break;
|
||||
case HW_VAR_CHK_HI_QUEUE_EMPTY:
|
||||
*val = ((rtw_read32(Adapter, REG_HGQ_INFORMATION) & 0x0000ff00) == 0) ? true : false;
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
/* Query setting of specified variable. */
|
||||
void GetHalDefVar8188EUsb(struct adapter *Adapter, enum hal_def_variable eVariable, void *pValue)
|
||||
{
|
||||
struct hal_data_8188e *haldata = &Adapter->haldata;
|
||||
|
||||
switch (eVariable) {
|
||||
case HAL_DEF_IS_SUPPORT_ANT_DIV:
|
||||
*((u8 *)pValue) = (haldata->AntDivCfg == 0) ? false : true;
|
||||
break;
|
||||
case HAL_DEF_CURRENT_ANTENNA:
|
||||
*((u8 *)pValue) = haldata->CurAntenna;
|
||||
break;
|
||||
case HAL_DEF_DBG_DM_FUNC:
|
||||
*((u32 *)pValue) = haldata->odmpriv.SupportAbility;
|
||||
break;
|
||||
case HAL_DEF_DBG_DUMP_RXPKT:
|
||||
*((u8 *)pValue) = haldata->bDumpRxPkt;
|
||||
break;
|
||||
case HAL_DEF_DBG_DUMP_TXPKT:
|
||||
*((u8 *)pValue) = haldata->bDumpTxPkt;
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
/* Change default setting of specified variable. */
|
||||
void SetHalDefVar8188EUsb(struct adapter *Adapter, enum hal_def_variable eVariable, void *pValue)
|
||||
{
|
||||
struct hal_data_8188e *haldata = &Adapter->haldata;
|
||||
|
||||
switch (eVariable) {
|
||||
case HAL_DEF_DBG_DM_FUNC:
|
||||
{
|
||||
u8 dm_func = *((u8 *)pValue);
|
||||
struct odm_dm_struct *podmpriv = &haldata->odmpriv;
|
||||
|
||||
if (dm_func == 0) { /* disable all dynamic func */
|
||||
podmpriv->SupportAbility = DYNAMIC_FUNC_DISABLE;
|
||||
} else if (dm_func == 1) {/* disable DIG */
|
||||
podmpriv->SupportAbility &= (~DYNAMIC_BB_DIG);
|
||||
} else if (dm_func == 2) {/* disable High power */
|
||||
podmpriv->SupportAbility &= (~DYNAMIC_BB_DYNAMIC_TXPWR);
|
||||
} else if (dm_func == 3) {/* disable tx power tracking */
|
||||
podmpriv->SupportAbility &= (~DYNAMIC_RF_CALIBRATION);
|
||||
} else if (dm_func == 5) {/* disable antenna diversity */
|
||||
podmpriv->SupportAbility &= (~DYNAMIC_BB_ANT_DIV);
|
||||
} else if (dm_func == 6) {/* turn on all dynamic func */
|
||||
if (!(podmpriv->SupportAbility & DYNAMIC_BB_DIG)) {
|
||||
struct rtw_dig *pDigTable = &podmpriv->DM_DigTable;
|
||||
pDigTable->CurIGValue = rtw_read8(Adapter, 0xc50);
|
||||
}
|
||||
podmpriv->SupportAbility = DYNAMIC_ALL_FUNC_ENABLE;
|
||||
}
|
||||
}
|
||||
break;
|
||||
case HAL_DEF_DBG_DUMP_RXPKT:
|
||||
haldata->bDumpRxPkt = *((u8 *)pValue);
|
||||
break;
|
||||
case HAL_DEF_DBG_DUMP_TXPKT:
|
||||
haldata->bDumpTxPkt = *((u8 *)pValue);
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
void UpdateHalRAMask8188EUsb(struct adapter *adapt, u32 mac_id, u8 rssi_level)
|
||||
{
|
||||
u8 init_rate = 0;
|
||||
|
@ -16,7 +16,7 @@ static int usb_read(struct intf_hdl *intf, u16 value, void *data, u8 size)
|
||||
int status;
|
||||
u8 io_buf[4];
|
||||
|
||||
if (adapt->bSurpriseRemoved || adapt->pwrctrlpriv.pnp_bstop_trx)
|
||||
if (adapt->bSurpriseRemoved)
|
||||
return -EPERM;
|
||||
|
||||
status = usb_control_msg_recv(udev, 0, REALTEK_USB_VENQT_CMD_REQ,
|
||||
@ -59,7 +59,7 @@ static int usb_write(struct intf_hdl *intf, u16 value, void *data, u8 size)
|
||||
int status;
|
||||
u8 io_buf[VENDOR_CMD_MAX_DATA_LEN];
|
||||
|
||||
if (adapt->bSurpriseRemoved || adapt->pwrctrlpriv.pnp_bstop_trx)
|
||||
if (adapt->bSurpriseRemoved)
|
||||
return -EPERM;
|
||||
|
||||
memcpy(io_buf, data, size);
|
||||
@ -260,7 +260,6 @@ static int recvbuf2recvframe(struct adapter *adapt, struct sk_buff *pskb)
|
||||
|
||||
pkt_copy = netdev_alloc_skb(adapt->pnetdev, alloc_sz);
|
||||
if (pkt_copy) {
|
||||
pkt_copy->dev = adapt->pnetdev;
|
||||
precvframe->pkt = pkt_copy;
|
||||
precvframe->rx_head = pkt_copy->data;
|
||||
precvframe->rx_end = pkt_copy->data + alloc_sz;
|
||||
@ -288,7 +287,7 @@ static int recvbuf2recvframe(struct adapter *adapt, struct sk_buff *pskb)
|
||||
|
||||
recvframe_put(precvframe, skb_len);
|
||||
|
||||
pkt_offset = (u16)_RND128(pkt_offset);
|
||||
pkt_offset = (u16)round_up(pkt_offset, 128);
|
||||
|
||||
if (pattrib->pkt_rpt_type == NORMAL_RX) { /* Normal rx packet */
|
||||
if (pattrib->physt)
|
||||
@ -415,8 +414,7 @@ u32 rtw_read_port(struct adapter *adapter, u8 *rmem)
|
||||
size_t alignment = 0;
|
||||
u32 ret = _SUCCESS;
|
||||
|
||||
if (adapter->bDriverStopped || adapter->bSurpriseRemoved ||
|
||||
adapter->pwrctrlpriv.pnp_bstop_trx)
|
||||
if (adapter->bDriverStopped || adapter->bSurpriseRemoved)
|
||||
return _FAIL;
|
||||
|
||||
if (!precvbuf)
|
||||
|
@ -25,7 +25,6 @@ struct HAL_VERSION {
|
||||
enum HAL_CHIP_TYPE ChipType;
|
||||
enum HAL_CUT_VERSION CUTVersion;
|
||||
enum HAL_VENDOR VendorType;
|
||||
u8 ROMVer;
|
||||
};
|
||||
|
||||
/* Get element */
|
||||
@ -34,10 +33,10 @@ struct HAL_VERSION {
|
||||
|
||||
/* HAL_CHIP_TYPE_E */
|
||||
#define IS_NORMAL_CHIP(version) \
|
||||
((GET_CVID_CHIP_TYPE(version) == NORMAL_CHIP) ? true : false)
|
||||
(GET_CVID_CHIP_TYPE(version) == NORMAL_CHIP)
|
||||
|
||||
/* HAL_VENDOR_E */
|
||||
#define IS_CHIP_VENDOR_TSMC(version) \
|
||||
((GET_CVID_MANUFACTUER(version) == CHIP_VENDOR_TSMC) ? true : false)
|
||||
(GET_CVID_MANUFACTUER(version) == CHIP_VENDOR_TSMC)
|
||||
|
||||
#endif
|
||||
|
@ -4,9 +4,6 @@
|
||||
#ifndef __BASIC_TYPES_H__
|
||||
#define __BASIC_TYPES_H__
|
||||
|
||||
#define SUCCESS 0
|
||||
#define FAIL (-1)
|
||||
|
||||
#include <linux/types.h>
|
||||
#define NDIS_OID uint
|
||||
|
||||
@ -14,9 +11,6 @@ typedef void (*proc_t)(void *);
|
||||
|
||||
#define FIELD_OFFSET(s, field) ((ssize_t)&((s *)(0))->field)
|
||||
|
||||
#define MEM_ALIGNMENT_OFFSET (sizeof(size_t))
|
||||
#define MEM_ALIGNMENT_PADDING (sizeof(size_t) - 1)
|
||||
|
||||
/* port from fw */
|
||||
/* TODO: Macros Below are Sync from SD7-Driver. It is necessary
|
||||
* to check correctness */
|
||||
@ -31,86 +25,21 @@ typedef void (*proc_t)(void *);
|
||||
/* Convert little data endian to host ordering */
|
||||
#define EF1BYTE(_val) \
|
||||
((u8)(_val))
|
||||
#define EF2BYTE(_val) \
|
||||
(le16_to_cpu(_val))
|
||||
#define EF4BYTE(_val) \
|
||||
(le32_to_cpu(_val))
|
||||
|
||||
/* Read data from memory */
|
||||
#define READEF1BYTE(_ptr) \
|
||||
EF1BYTE(*((u8 *)(_ptr)))
|
||||
/* Read le16 data from memory and convert to host ordering */
|
||||
#define READEF2BYTE(_ptr) \
|
||||
EF2BYTE(*(_ptr))
|
||||
#define READEF4BYTE(_ptr) \
|
||||
EF4BYTE(*(_ptr))
|
||||
|
||||
/* Write data to memory */
|
||||
#define WRITEEF1BYTE(_ptr, _val) \
|
||||
do { \
|
||||
(*((u8 *)(_ptr))) = EF1BYTE(_val) \
|
||||
} while (0)
|
||||
/* Write le data to memory in host ordering */
|
||||
#define WRITEEF2BYTE(_ptr, _val) \
|
||||
do { \
|
||||
(*((u16 *)(_ptr))) = EF2BYTE(_val) \
|
||||
} while (0)
|
||||
|
||||
#define WRITEEF4BYTE(_ptr, _val) \
|
||||
do { \
|
||||
(*((u32 *)(_ptr))) = EF2BYTE(_val) \
|
||||
} while (0)
|
||||
|
||||
/* Create a bit mask
|
||||
* Examples:
|
||||
* BIT_LEN_MASK_32(0) => 0x00000000
|
||||
* BIT_LEN_MASK_32(1) => 0x00000001
|
||||
* BIT_LEN_MASK_32(2) => 0x00000003
|
||||
* BIT_LEN_MASK_32(32) => 0xFFFFFFFF
|
||||
*/
|
||||
#define BIT_LEN_MASK_32(__bitlen) \
|
||||
(0xFFFFFFFF >> (32 - (__bitlen)))
|
||||
#define BIT_LEN_MASK_16(__bitlen) \
|
||||
(0xFFFF >> (16 - (__bitlen)))
|
||||
/* Create a bit mask */
|
||||
#define BIT_LEN_MASK_8(__bitlen) \
|
||||
(0xFF >> (8 - (__bitlen)))
|
||||
|
||||
/* Create an offset bit mask
|
||||
* Examples:
|
||||
* BIT_OFFSET_LEN_MASK_32(0, 2) => 0x00000003
|
||||
* BIT_OFFSET_LEN_MASK_32(16, 2) => 0x00030000
|
||||
*/
|
||||
#define BIT_OFFSET_LEN_MASK_32(__bitoffset, __bitlen) \
|
||||
(BIT_LEN_MASK_32(__bitlen) << (__bitoffset))
|
||||
#define BIT_OFFSET_LEN_MASK_16(__bitoffset, __bitlen) \
|
||||
(BIT_LEN_MASK_16(__bitlen) << (__bitoffset))
|
||||
#define BIT_OFFSET_LEN_MASK_8(__bitoffset, __bitlen) \
|
||||
(BIT_LEN_MASK_8(__bitlen) << (__bitoffset))
|
||||
|
||||
/*Description:
|
||||
* Return 4-byte value in host byte ordering from
|
||||
* 4-byte pointer in little-endian system.
|
||||
*/
|
||||
#define LE_P4BYTE_TO_HOST_4BYTE(__pstart) \
|
||||
(EF4BYTE(*((__le32 *)(__pstart))))
|
||||
#define LE_P2BYTE_TO_HOST_2BYTE(__pstart) \
|
||||
(EF2BYTE(*((__le16 *)(__pstart))))
|
||||
#define LE_P1BYTE_TO_HOST_1BYTE(__pstart) \
|
||||
(EF1BYTE(*((u8 *)(__pstart))))
|
||||
|
||||
/*Description:
|
||||
Translate subfield (continuous bits in little-endian) of 4-byte
|
||||
value to host byte ordering.*/
|
||||
#define LE_BITS_TO_4BYTE(__pstart, __bitoffset, __bitlen) \
|
||||
( \
|
||||
(LE_P4BYTE_TO_HOST_4BYTE(__pstart) >> (__bitoffset)) & \
|
||||
BIT_LEN_MASK_32(__bitlen) \
|
||||
)
|
||||
#define LE_BITS_TO_2BYTE(__pstart, __bitoffset, __bitlen) \
|
||||
( \
|
||||
(LE_P2BYTE_TO_HOST_2BYTE(__pstart) >> (__bitoffset)) & \
|
||||
BIT_LEN_MASK_16(__bitlen) \
|
||||
)
|
||||
#define LE_BITS_TO_1BYTE(__pstart, __bitoffset, __bitlen) \
|
||||
( \
|
||||
(LE_P1BYTE_TO_HOST_1BYTE(__pstart) >> (__bitoffset)) & \
|
||||
|
@ -26,7 +26,6 @@
|
||||
#include "rtw_eeprom.h"
|
||||
#include "sta_info.h"
|
||||
#include "rtw_mlme.h"
|
||||
#include "rtw_debug.h"
|
||||
#include "rtw_rf.h"
|
||||
#include "rtw_event.h"
|
||||
#include "rtw_led.h"
|
||||
@ -35,6 +34,7 @@
|
||||
#include "rtw_ap.h"
|
||||
#include "rtw_br_ext.h"
|
||||
#include "rtl8188e_hal.h"
|
||||
#include "rtw_fw.h"
|
||||
|
||||
#define DRIVERVERSION "v4.1.4_6773.20130222"
|
||||
|
||||
@ -116,11 +116,6 @@ struct registry_priv {
|
||||
|
||||
#define MAX_CONTINUAL_URB_ERR 4
|
||||
|
||||
struct rt_firmware {
|
||||
u8 *data;
|
||||
u32 size;
|
||||
};
|
||||
|
||||
struct dvobj_priv {
|
||||
struct adapter *if1;
|
||||
|
||||
|
@ -10,44 +10,16 @@
|
||||
|
||||
enum hw_variables {
|
||||
HW_VAR_SET_OPMODE,
|
||||
HW_VAR_BSSID,
|
||||
HW_VAR_BASIC_RATE,
|
||||
HW_VAR_CORRECT_TSF,
|
||||
HW_VAR_MLME_DISCONNECT,
|
||||
HW_VAR_MLME_SITESURVEY,
|
||||
HW_VAR_MLME_JOIN,
|
||||
HW_VAR_SLOT_TIME,
|
||||
HW_VAR_RESP_SIFS,
|
||||
HW_VAR_ACK_PREAMBLE,
|
||||
HW_VAR_BCN_VALID,
|
||||
HW_VAR_DM_FLAG,
|
||||
HW_VAR_DM_FUNC_OP,
|
||||
HW_VAR_DM_FUNC_SET,
|
||||
HW_VAR_DM_FUNC_RESET,
|
||||
HW_VAR_DM_FUNC_CLR,
|
||||
HW_VAR_AC_PARAM_BE,
|
||||
HW_VAR_ACM_CTRL,
|
||||
HW_VAR_AMPDU_MIN_SPACE,
|
||||
HW_VAR_AMPDU_FACTOR,
|
||||
HW_VAR_RXDMA_AGG_PG_TH,
|
||||
HW_VAR_H2C_FW_PWRMODE,
|
||||
HW_VAR_H2C_FW_JOINBSSRPT,
|
||||
HW_VAR_FWLPS_RF_ON,
|
||||
HW_VAR_H2C_FW_P2P_PS_OFFLOAD,
|
||||
HW_VAR_INITIAL_GAIN,
|
||||
HW_VAR_ANTENNA_DIVERSITY_SELECT,
|
||||
HW_VAR_FIFO_CLEARN_UP,
|
||||
HW_VAR_RPT_TIMER_SETTING,
|
||||
HW_VAR_TX_RPT_MAX_MACID,
|
||||
HW_VAR_H2C_MEDIA_STATUS_RPT,
|
||||
HW_VAR_CHK_HI_QUEUE_EMPTY,
|
||||
};
|
||||
|
||||
enum hal_def_variable {
|
||||
HAL_DEF_IS_SUPPORT_ANT_DIV,
|
||||
HAL_DEF_CURRENT_ANTENNA,
|
||||
HAL_DEF_DBG_DUMP_RXPKT,/* for dbg */
|
||||
HAL_DEF_DBG_DM_FUNC,/* for dbg */
|
||||
HAL_DEF_DBG_DUMP_TXPKT,
|
||||
};
|
||||
|
||||
typedef s32 (*c2h_id_filter)(u8 id);
|
||||
@ -70,13 +42,9 @@ void UpdateHalRAMask8188EUsb(struct adapter *adapt, u32 mac_id, u8 rssi_level);
|
||||
int rtl8188e_IOL_exec_cmds_sync(struct adapter *adapter,
|
||||
struct xmit_frame *xmit_frame, u32 max_wating_ms, u32 bndy_cnt);
|
||||
|
||||
void SetHalDefVar8188EUsb(struct adapter *Adapter, enum hal_def_variable eVariable, void *pValue);
|
||||
void GetHalDefVar8188EUsb(struct adapter *Adapter, enum hal_def_variable eVariable, void *pValue);
|
||||
|
||||
unsigned int rtl8188eu_inirp_init(struct adapter *Adapter);
|
||||
|
||||
void SetHwReg8188EU(struct adapter *Adapter, u8 variable, u8 *val);
|
||||
void GetHwReg8188EU(struct adapter *Adapter, u8 variable, u8 *val);
|
||||
|
||||
uint rtw_hal_init(struct adapter *padapter);
|
||||
uint rtw_hal_deinit(struct adapter *padapter);
|
||||
|
@ -123,24 +123,6 @@ enum NETWORK_TYPE {
|
||||
WIRELESS_11BG_24N = (WIRELESS_11B | WIRELESS_11G | WIRELESS_11_24N),
|
||||
};
|
||||
|
||||
#define SUPPORTED_24G_NETTYPE_MSK \
|
||||
(WIRELESS_11B | WIRELESS_11G | WIRELESS_11_24N)
|
||||
|
||||
#define IsSupported24G(NetType) \
|
||||
((NetType) & SUPPORTED_24G_NETTYPE_MSK ? true : false)
|
||||
|
||||
#define IsEnableHWCCK(NetType) \
|
||||
IsSupported24G(NetType)
|
||||
|
||||
#define IsSupportedRxCCK(NetType) IsEnableHWCCK(NetType)
|
||||
|
||||
#define IsSupportedTxCCK(NetType) \
|
||||
((NetType) & (WIRELESS_11B) ? true : false)
|
||||
#define IsSupportedTxOFDM(NetType) \
|
||||
((NetType) & (WIRELESS_11G) ? true : false)
|
||||
#define IsSupportedTxMCS(NetType) \
|
||||
((NetType) & (WIRELESS_11_24N) ? true : false)
|
||||
|
||||
struct ieee_param {
|
||||
u32 cmd;
|
||||
u8 sta_addr[ETH_ALEN];
|
||||
@ -196,35 +178,6 @@ struct ieee_param {
|
||||
/* this is stolen from ipw2200 driver */
|
||||
#define IEEE_IBSS_MAC_HASH_SIZE 31
|
||||
|
||||
struct rtw_ieee80211_hdr {
|
||||
__le16 frame_ctl;
|
||||
__le16 duration_id;
|
||||
u8 addr1[ETH_ALEN];
|
||||
u8 addr2[ETH_ALEN];
|
||||
u8 addr3[ETH_ALEN];
|
||||
u16 seq_ctl;
|
||||
u8 addr4[ETH_ALEN];
|
||||
} __packed;
|
||||
|
||||
struct rtw_ieee80211_hdr_3addr {
|
||||
__le16 frame_ctl;
|
||||
__le16 duration_id;
|
||||
u8 addr1[ETH_ALEN];
|
||||
u8 addr2[ETH_ALEN];
|
||||
u8 addr3[ETH_ALEN];
|
||||
u16 seq_ctl;
|
||||
} __packed;
|
||||
|
||||
struct rtw_ieee80211_hdr_3addr_qos {
|
||||
__le16 frame_ctl;
|
||||
__le16 duration_id;
|
||||
u8 addr1[ETH_ALEN];
|
||||
u8 addr2[ETH_ALEN];
|
||||
u8 addr3[ETH_ALEN];
|
||||
u16 seq_ctl;
|
||||
u16 qc;
|
||||
} __packed;
|
||||
|
||||
#define IEEE80211_3ADDR_LEN 24
|
||||
#define IEEE80211_4ADDR_LEN 30
|
||||
#define IEEE80211_FCS_LEN 4
|
||||
@ -636,24 +589,8 @@ static inline int is_broadcast_mac_addr(const u8 *addr)
|
||||
|
||||
#define MAXTID 16
|
||||
|
||||
#define IEEE_A (1<<0)
|
||||
#define IEEE_B (1<<1)
|
||||
#define IEEE_G (1<<2)
|
||||
#define IEEE_MODE_MASK (IEEE_A|IEEE_B|IEEE_G)
|
||||
|
||||
/* Action category code */
|
||||
enum rtw_ieee80211_category {
|
||||
RTW_WLAN_CATEGORY_SPECTRUM_MGMT = 0,
|
||||
RTW_WLAN_CATEGORY_QOS = 1,
|
||||
RTW_WLAN_CATEGORY_DLS = 2,
|
||||
RTW_WLAN_CATEGORY_BACK = 3,
|
||||
RTW_WLAN_CATEGORY_PUBLIC = 4, /* IEEE 802.11 public action frames */
|
||||
RTW_WLAN_CATEGORY_RADIO_MEASUREMENT = 5,
|
||||
RTW_WLAN_CATEGORY_FT = 6,
|
||||
RTW_WLAN_CATEGORY_HT = 7,
|
||||
RTW_WLAN_CATEGORY_SA_QUERY = 8,
|
||||
RTW_WLAN_CATEGORY_TDLS = 12,
|
||||
RTW_WLAN_CATEGORY_WMM = 17,
|
||||
RTW_WLAN_CATEGORY_P2P = 0x7f,/* P2P action frames */
|
||||
};
|
||||
|
||||
|
@ -98,22 +98,6 @@ struct odm_per_pkt_info {
|
||||
bool bPacketBeacon;
|
||||
};
|
||||
|
||||
enum odm_ability {
|
||||
/* BB Team */
|
||||
ODM_DIG = 0x00000001,
|
||||
ODM_HIGH_POWER = 0x00000002,
|
||||
ODM_CCK_CCA_TH = 0x00000004,
|
||||
ODM_FA_STATISTICS = 0x00000008,
|
||||
ODM_RAMASK = 0x00000010,
|
||||
ODM_RSSI_MONITOR = 0x00000020,
|
||||
ODM_SW_ANTDIV = 0x00000040,
|
||||
ODM_HW_ANTDIV = 0x00000080,
|
||||
ODM_BB_PWRSV = 0x00000100,
|
||||
ODM_2TPATHDIV = 0x00000200,
|
||||
ODM_1TPATHDIV = 0x00000400,
|
||||
ODM_PSD2AFH = 0x00000800
|
||||
};
|
||||
|
||||
/* 2011/10/20 MH Define Common info enum for all team. */
|
||||
|
||||
enum odm_common_info_def {
|
||||
@ -137,19 +121,6 @@ enum odm_ability_def {
|
||||
|
||||
# define ODM_ITRF_USB 0x2
|
||||
|
||||
/* ODM_CMNINFO_OP_MODE */
|
||||
enum odm_operation_mode {
|
||||
ODM_NO_LINK = BIT(0),
|
||||
ODM_LINK = BIT(1),
|
||||
ODM_SCAN = BIT(2),
|
||||
ODM_POWERSAVE = BIT(3),
|
||||
ODM_AP_MODE = BIT(4),
|
||||
ODM_CLIENT_MODE = BIT(5),
|
||||
ODM_AD_HOC = BIT(6),
|
||||
ODM_WIFI_DIRECT = BIT(7),
|
||||
ODM_WIFI_DISPLAY = BIT(8),
|
||||
};
|
||||
|
||||
/* ODM_CMNINFO_WM_MODE */
|
||||
enum odm_wireless_mode {
|
||||
ODM_WM_UNKNOW = 0x0,
|
||||
|
@ -77,10 +77,6 @@ void *rtw_malloc2d(int h, int w, int size);
|
||||
spin_lock_init(&((q)->lock)); \
|
||||
} while (0)
|
||||
|
||||
u32 rtw_systime_to_ms(u32 systime);
|
||||
u32 rtw_ms_to_systime(u32 ms);
|
||||
s32 rtw_get_passing_time_ms(u32 start);
|
||||
|
||||
void rtw_usleep_os(int us);
|
||||
|
||||
static inline unsigned char _cancel_timer_ex(struct timer_list *ptimer)
|
||||
@ -94,49 +90,6 @@ static inline void flush_signals_thread(void)
|
||||
flush_signals(current);
|
||||
}
|
||||
|
||||
#define _RND(sz, r) ((((sz)+((r)-1))/(r))*(r))
|
||||
#define RND4(x) (((x >> 2) + (((x & 3) == 0) ? 0: 1)) << 2)
|
||||
|
||||
static inline u32 _RND4(u32 sz)
|
||||
{
|
||||
u32 val;
|
||||
|
||||
val = ((sz >> 2) + ((sz & 3) ? 1: 0)) << 2;
|
||||
return val;
|
||||
}
|
||||
|
||||
static inline u32 _RND8(u32 sz)
|
||||
{
|
||||
u32 val;
|
||||
|
||||
val = ((sz >> 3) + ((sz & 7) ? 1: 0)) << 3;
|
||||
return val;
|
||||
}
|
||||
|
||||
static inline u32 _RND128(u32 sz)
|
||||
{
|
||||
u32 val;
|
||||
|
||||
val = ((sz >> 7) + ((sz & 127) ? 1: 0)) << 7;
|
||||
return val;
|
||||
}
|
||||
|
||||
static inline u32 _RND256(u32 sz)
|
||||
{
|
||||
u32 val;
|
||||
|
||||
val = ((sz >> 8) + ((sz & 255) ? 1: 0)) << 8;
|
||||
return val;
|
||||
}
|
||||
|
||||
static inline u32 _RND512(u32 sz)
|
||||
{
|
||||
u32 val;
|
||||
|
||||
val = ((sz >> 9) + ((sz & 511) ? 1: 0)) << 9;
|
||||
return val;
|
||||
}
|
||||
|
||||
struct rtw_netdev_priv_indicator {
|
||||
void *priv;
|
||||
u32 sizeof_priv;
|
||||
|
@ -160,9 +160,6 @@ struct hal_data_8188e {
|
||||
u8 AntDivCfg;
|
||||
u8 TRxAntDivType;
|
||||
|
||||
u8 bDumpRxPkt;/* for debug */
|
||||
u8 bDumpTxPkt;/* for debug */
|
||||
|
||||
u8 OutEpQueueSel;
|
||||
u8 OutEpNumber;
|
||||
|
||||
|
@ -998,13 +998,9 @@ Current IOREG MAP
|
||||
#define STOP_BCNQ BIT(6)
|
||||
|
||||
/* 2 ACMHWCTRL */
|
||||
#define AcmHw_HwEn BIT(0)
|
||||
#define AcmHw_BeqEn BIT(1)
|
||||
#define AcmHw_ViqEn BIT(2)
|
||||
#define AcmHw_VoqEn BIT(3)
|
||||
#define AcmHw_BeqStatus BIT(4)
|
||||
#define AcmHw_ViqStatus BIT(5)
|
||||
#define AcmHw_VoqStatus BIT(6)
|
||||
#define ACMHW_BEQEN BIT(1)
|
||||
#define ACMHW_VIQEN BIT(2)
|
||||
#define ACMHW_VOQEN BIT(3)
|
||||
|
||||
/* 0x0600h ~ 0x07FFh WMAC Configuration */
|
||||
/* 2APSD_CTRL */
|
||||
|
@ -1,55 +0,0 @@
|
||||
/* SPDX-License-Identifier: GPL-2.0 OR BSD-3-Clause */
|
||||
/* Copyright(c) 2007 - 2011 Realtek Corporation. */
|
||||
|
||||
#ifndef __RTW_DEBUG_H__
|
||||
#define __RTW_DEBUG_H__
|
||||
|
||||
#include "osdep_service.h"
|
||||
#include "drv_types.h"
|
||||
|
||||
#define _drv_always_ 1
|
||||
#define _drv_emerg_ 2
|
||||
#define _drv_alert_ 3
|
||||
#define _drv_crit_ 4
|
||||
#define _drv_err_ 5
|
||||
#define _drv_warning_ 6
|
||||
#define _drv_notice_ 7
|
||||
#define _drv_info_ 8
|
||||
#define _drv_debug_ 9
|
||||
|
||||
#define _module_rtl871x_xmit_c_ BIT(0)
|
||||
#define _module_xmit_osdep_c_ BIT(1)
|
||||
#define _module_rtl871x_recv_c_ BIT(2)
|
||||
#define _module_recv_osdep_c_ BIT(3)
|
||||
#define _module_rtl871x_mlme_c_ BIT(4)
|
||||
#define _module_mlme_osdep_c_ BIT(5)
|
||||
#define _module_rtl871x_sta_mgt_c_ BIT(6)
|
||||
#define _module_rtl871x_cmd_c_ BIT(7)
|
||||
#define _module_cmd_osdep_c_ BIT(8)
|
||||
#define _module_rtl871x_io_c_ BIT(9)
|
||||
#define _module_io_osdep_c_ BIT(10)
|
||||
#define _module_os_intfs_c_ BIT(11)
|
||||
#define _module_rtl871x_security_c_ BIT(12)
|
||||
#define _module_rtl871x_eeprom_c_ BIT(13)
|
||||
#define _module_hal_init_c_ BIT(14)
|
||||
#define _module_hci_hal_init_c_ BIT(15)
|
||||
#define _module_rtl871x_ioctl_c_ BIT(16)
|
||||
#define _module_rtl871x_ioctl_set_c_ BIT(17)
|
||||
#define _module_rtl871x_ioctl_query_c_ BIT(18)
|
||||
#define _module_rtl871x_pwrctrl_c_ BIT(19)
|
||||
#define _module_hci_intfs_c_ BIT(20)
|
||||
#define _module_hci_ops_c_ BIT(21)
|
||||
#define _module_osdep_service_c_ BIT(22)
|
||||
#define _module_mp_ BIT(23)
|
||||
#define _module_hci_ops_os_c_ BIT(24)
|
||||
#define _module_rtl871x_ioctl_os_c BIT(25)
|
||||
#define _module_rtl8712_cmd_c_ BIT(26)
|
||||
#define _module_rtl8192c_xmit_c_ BIT(27)
|
||||
#define _module_hal_xmit_c_ BIT(28)
|
||||
#define _module_efuse_ BIT(29)
|
||||
#define _module_rtl8712_recv_c_ BIT(30)
|
||||
#define _module_rtl8712_led_c_ BIT(31)
|
||||
|
||||
#define DRIVER_PREFIX "R8188EU: "
|
||||
|
||||
#endif /* __RTW_DEBUG_H__ */
|
@ -11,10 +11,7 @@
|
||||
|
||||
struct eeprom_priv {
|
||||
u8 bautoload_fail_flag;
|
||||
u8 bloadfile_fail_flag;
|
||||
u8 bloadmac_fail_flag;
|
||||
u8 mac_addr[ETH_ALEN] __aligned(2); /* PermanentAddress */
|
||||
u16 channel_plan;
|
||||
u8 EepromOrEfuse;
|
||||
u8 efuse_eeprom_data[HWSET_MAX_SIZE_512] __aligned(4);
|
||||
};
|
||||
|
@ -4,6 +4,11 @@
|
||||
#ifndef __RTW_FW_H__
|
||||
#define __RTW_FW_H__
|
||||
|
||||
struct rt_firmware {
|
||||
u8 *data;
|
||||
u32 size;
|
||||
};
|
||||
|
||||
#include "drv_types.h"
|
||||
|
||||
int rtl8188e_firmware_download(struct adapter *padapter);
|
||||
|
@ -7,86 +7,7 @@
|
||||
#include "osdep_service.h"
|
||||
#include "drv_types.h"
|
||||
|
||||
#ifndef OID_802_11_CAPABILITY
|
||||
#define OID_802_11_CAPABILITY 0x0d010122
|
||||
#endif
|
||||
|
||||
#ifndef OID_802_11_PMKID
|
||||
#define OID_802_11_PMKID 0x0d010123
|
||||
#endif
|
||||
|
||||
/* For DDK-defined OIDs */
|
||||
#define OID_NDIS_SEG1 0x00010100
|
||||
#define OID_NDIS_SEG2 0x00010200
|
||||
#define OID_NDIS_SEG3 0x00020100
|
||||
#define OID_NDIS_SEG4 0x01010100
|
||||
#define OID_NDIS_SEG5 0x01020100
|
||||
#define OID_NDIS_SEG6 0x01020200
|
||||
#define OID_NDIS_SEG7 0xFD010100
|
||||
#define OID_NDIS_SEG8 0x0D010100
|
||||
#define OID_NDIS_SEG9 0x0D010200
|
||||
#define OID_NDIS_SEG10 0x0D020200
|
||||
|
||||
#define SZ_OID_NDIS_SEG1 23
|
||||
#define SZ_OID_NDIS_SEG2 3
|
||||
#define SZ_OID_NDIS_SEG3 6
|
||||
#define SZ_OID_NDIS_SEG4 6
|
||||
#define SZ_OID_NDIS_SEG5 4
|
||||
#define SZ_OID_NDIS_SEG6 8
|
||||
#define SZ_OID_NDIS_SEG7 7
|
||||
#define SZ_OID_NDIS_SEG8 36
|
||||
#define SZ_OID_NDIS_SEG9 24
|
||||
#define SZ_OID_NDIS_SEG10 19
|
||||
|
||||
/* For Realtek-defined OIDs */
|
||||
#define OID_MP_SEG1 0xFF871100
|
||||
#define OID_MP_SEG2 0xFF818000
|
||||
|
||||
#define OID_MP_SEG3 0xFF818700
|
||||
#define OID_MP_SEG4 0xFF011100
|
||||
|
||||
enum oid_type {
|
||||
QUERY_OID,
|
||||
SET_OID
|
||||
};
|
||||
|
||||
struct oid_funs_node {
|
||||
unsigned int oid_start; /* the starting number for OID */
|
||||
unsigned int oid_end; /* the ending number for OID */
|
||||
struct oid_obj_priv *node_array;
|
||||
unsigned int array_sz; /* the size of node_array */
|
||||
int query_counter; /* count the number of query hits for this segment */
|
||||
int set_counter; /* count the number of set hits for this segment */
|
||||
};
|
||||
|
||||
struct oid_par_priv {
|
||||
void *adapter_context;
|
||||
NDIS_OID oid;
|
||||
void *information_buf;
|
||||
u32 information_buf_len;
|
||||
u32 *bytes_rw;
|
||||
u32 *bytes_needed;
|
||||
enum oid_type type_of_oid;
|
||||
u32 dbg;
|
||||
};
|
||||
|
||||
struct oid_obj_priv {
|
||||
unsigned char dbg; /* 0: without OID debug message
|
||||
* 1: with OID debug message */
|
||||
int (*oidfuns)(struct oid_par_priv *poid_par_priv);
|
||||
};
|
||||
|
||||
extern struct iw_handler_def rtw_handlers_def;
|
||||
|
||||
int drv_query_info(struct net_device *miniportadaptercontext, NDIS_OID oid,
|
||||
void *informationbuffer, u32 informationbufferlength,
|
||||
u32 *byteswritten, u32 *bytesneeded);
|
||||
|
||||
int drv_set_info(struct net_device *MiniportAdapterContext,
|
||||
NDIS_OID oid, void *informationbuffer,
|
||||
u32 informationbufferlength, u32 *bytesread,
|
||||
u32 *bytesneeded);
|
||||
|
||||
extern int ui_pid[3];
|
||||
|
||||
#endif /* #ifndef __INC_CEINFO_ */
|
||||
|
@ -363,8 +363,6 @@ struct mlme_priv {
|
||||
|
||||
u8 *assoc_req;
|
||||
u32 assoc_req_len;
|
||||
u8 *assoc_rsp;
|
||||
u32 assoc_rsp_len;
|
||||
|
||||
/* Number of associated Non-ERP stations (i.e., stations using 802.11b
|
||||
* in 802.11g BSS) */
|
||||
@ -558,13 +556,9 @@ void rtw_scan_timeout_handler(struct adapter *adapter);
|
||||
#define rtw_set_scan_deny_timer_hdl(adapter) do {} while (0)
|
||||
#define rtw_set_scan_deny(adapter, ms) do {} while (0)
|
||||
|
||||
int _rtw_init_mlme_priv(struct adapter *padapter);
|
||||
|
||||
void rtw_free_mlme_priv_ie_data(struct mlme_priv *pmlmepriv);
|
||||
|
||||
void _rtw_free_mlme_priv(struct mlme_priv *pmlmepriv);
|
||||
|
||||
struct wlan_network *_rtw_alloc_network(struct mlme_priv *pmlmepriv);
|
||||
struct wlan_network *rtw_alloc_network(struct mlme_priv *pmlmepriv);
|
||||
|
||||
void _rtw_free_network(struct mlme_priv *pmlmepriv,
|
||||
struct wlan_network *pnetwork, u8 isfreeall);
|
||||
@ -596,7 +590,10 @@ void _rtw_roaming(struct adapter *padapter, struct wlan_network *tgt_network);
|
||||
void rtw_set_roaming(struct adapter *adapter, u8 to_roaming);
|
||||
u8 rtw_to_roaming(struct adapter *adapter);
|
||||
|
||||
void rtw_set_max_rpt_macid(struct adapter *adapter, u8 macid);
|
||||
void rtw_sta_media_status_rpt(struct adapter *adapter, struct sta_info *psta,
|
||||
u32 mstatus);
|
||||
|
||||
u8 rtw_current_antenna(struct adapter *adapter);
|
||||
|
||||
#endif /* __RTL871X_MLME_H_ */
|
||||
|
@ -24,36 +24,12 @@
|
||||
|
||||
#define REAUTH_LIMIT (4)
|
||||
#define REASSOC_LIMIT (4)
|
||||
#define READDBA_LIMIT (2)
|
||||
|
||||
#define ROAMING_LIMIT 8
|
||||
|
||||
#define DYNAMIC_FUNC_DISABLE (0x0)
|
||||
|
||||
/* ====== ODM_ABILITY_E ======== */
|
||||
/* BB ODM section BIT 0-15 */
|
||||
#define DYNAMIC_BB_DIG BIT(0)
|
||||
#define DYNAMIC_BB_RA_MASK BIT(1)
|
||||
#define DYNAMIC_BB_DYNAMIC_TXPWR BIT(2)
|
||||
#define DYNAMIC_BB_BB_FA_CNT BIT(3)
|
||||
|
||||
#define DYNAMIC_BB_RSSI_MONITOR BIT(4)
|
||||
#define DYNAMIC_BB_CCK_PD BIT(5)
|
||||
#define DYNAMIC_BB_ANT_DIV BIT(6)
|
||||
#define DYNAMIC_BB_PWR_SAVE BIT(7)
|
||||
#define DYNAMIC_BB_PWR_TRA BIT(8)
|
||||
#define DYNAMIC_BB_RATE_ADAPTIVE BIT(9)
|
||||
#define DYNAMIC_BB_PATH_DIV BIT(10)
|
||||
#define DYNAMIC_BB_PSD BIT(11)
|
||||
|
||||
/* MAC DM section BIT 16-23 */
|
||||
#define DYNAMIC_MAC_EDCA_TURBO BIT(16)
|
||||
#define DYNAMIC_MAC_EARLY_MODE BIT(17)
|
||||
|
||||
/* RF ODM section BIT 24-31 */
|
||||
#define DYNAMIC_RF_TX_PWR_TRACK BIT(24)
|
||||
#define DYNAMIC_RF_RX_GAIN_TRACK BIT(25)
|
||||
#define DYNAMIC_RF_CALIBRATION BIT(26)
|
||||
|
||||
#define DYNAMIC_ALL_FUNC_ENABLE 0xFFFFFFF
|
||||
|
||||
@ -208,17 +184,7 @@ enum SCAN_STATE {
|
||||
SCAN_STATE_MAX,
|
||||
};
|
||||
|
||||
struct mlme_handler {
|
||||
unsigned int num;
|
||||
char *str;
|
||||
unsigned int (*func)(struct adapter *adapt, struct recv_frame *frame);
|
||||
};
|
||||
|
||||
struct action_handler {
|
||||
unsigned int num;
|
||||
char* str;
|
||||
unsigned int (*func)(struct adapter *adapt, struct recv_frame *frame);
|
||||
};
|
||||
typedef unsigned int (*mlme_handler)(struct adapter *adapt, struct recv_frame *frame);
|
||||
|
||||
struct ss_res {
|
||||
int state;
|
||||
@ -419,7 +385,7 @@ struct mlme_ext_priv {
|
||||
u8 active_keep_alive_check;
|
||||
};
|
||||
|
||||
int init_mlme_ext_priv(struct adapter *adapter);
|
||||
void init_mlme_ext_priv(struct adapter *adapter);
|
||||
int init_hw_mlme_ext(struct adapter *padapter);
|
||||
void free_mlme_ext_priv (struct mlme_ext_priv *pmlmeext);
|
||||
extern void init_mlme_ext_timer(struct adapter *padapter);
|
||||
@ -434,7 +400,6 @@ void UpdateBrateTblForSoftAP(u8 *bssrateset, u32 bssratelen);
|
||||
|
||||
void Save_DM_Func_Flag(struct adapter *padapter);
|
||||
void Restore_DM_Func_Flag(struct adapter *padapter);
|
||||
void Switch_DM_Func(struct adapter *padapter, u32 mode, u8 enable);
|
||||
|
||||
void Set_MSR(struct adapter *padapter, u8 type);
|
||||
|
||||
@ -563,6 +528,8 @@ void issue_action_BA(struct adapter *padapter, unsigned char *raddr,
|
||||
unsigned char action, unsigned short status);
|
||||
unsigned int send_delba(struct adapter *padapter, u8 initiator, u8 *addr);
|
||||
unsigned int send_beacon(struct adapter *padapter);
|
||||
bool get_beacon_valid_bit(struct adapter *adapter);
|
||||
void clear_beacon_valid_bit(struct adapter *adapter);
|
||||
|
||||
void start_clnt_assoc(struct adapter *padapter);
|
||||
void start_clnt_auth(struct adapter *padapter);
|
||||
@ -594,20 +561,10 @@ unsigned int OnDeAuth(struct adapter *padapter,
|
||||
unsigned int OnAction(struct adapter *padapter,
|
||||
struct recv_frame *precv_frame);
|
||||
|
||||
unsigned int on_action_spct(struct adapter *padapter,
|
||||
struct recv_frame *precv_frame);
|
||||
unsigned int OnAction_qos(struct adapter *padapter,
|
||||
struct recv_frame *precv_frame);
|
||||
unsigned int OnAction_dls(struct adapter *padapter,
|
||||
struct recv_frame *precv_frame);
|
||||
unsigned int OnAction_back(struct adapter *padapter,
|
||||
struct recv_frame *precv_frame);
|
||||
unsigned int on_action_public(struct adapter *padapter,
|
||||
struct recv_frame *precv_frame);
|
||||
unsigned int OnAction_ht(struct adapter *padapter,
|
||||
struct recv_frame *precv_frame);
|
||||
unsigned int OnAction_wmm(struct adapter *padapter,
|
||||
struct recv_frame *precv_frame);
|
||||
unsigned int OnAction_p2p(struct adapter *padapter,
|
||||
struct recv_frame *precv_frame);
|
||||
|
||||
@ -635,8 +592,6 @@ void addba_timer_hdl(struct sta_info *psta);
|
||||
bool cckrates_included(unsigned char *rate, int ratelen);
|
||||
bool cckratesonly_included(unsigned char *rate, int ratelen);
|
||||
|
||||
void process_addba_req(struct adapter *padapter, u8 *paddba_req, u8 *addr);
|
||||
|
||||
void update_TSF(struct mlme_ext_priv *pmlmeext, u8 *pframe, uint len);
|
||||
void correct_TSF(struct adapter *padapter, struct mlme_ext_priv *pmlmeext);
|
||||
|
||||
@ -769,9 +724,6 @@ struct C2HEvent_Header {
|
||||
unsigned int rsvd;
|
||||
};
|
||||
|
||||
void rtw_dummy_event_callback(struct adapter *adapter, u8 *pbuf);
|
||||
void rtw_fwdbg_event_callback(struct adapter *adapter, u8 *pbuf);
|
||||
|
||||
enum rtw_c2h_event {
|
||||
GEN_EVT_CODE(_Read_MACREG) = 0, /*0*/
|
||||
GEN_EVT_CODE(_Read_BBREG),
|
||||
@ -806,7 +758,7 @@ enum rtw_c2h_event {
|
||||
#ifdef _RTW_MLME_EXT_C_
|
||||
|
||||
static struct fwevent wlanevents[] = {
|
||||
{0, rtw_dummy_event_callback}, /*0*/
|
||||
{0, NULL}, /*0*/
|
||||
{0, NULL},
|
||||
{0, NULL},
|
||||
{0, NULL},
|
||||
@ -820,12 +772,12 @@ static struct fwevent wlanevents[] = {
|
||||
{sizeof(struct stassoc_event), &rtw_stassoc_event_callback},
|
||||
{sizeof(struct stadel_event), &rtw_stadel_event_callback},
|
||||
{0, NULL},
|
||||
{0, rtw_dummy_event_callback},
|
||||
{0, NULL},
|
||||
{0, NULL}, /*15*/
|
||||
{0, NULL},
|
||||
{0, NULL},
|
||||
{0, NULL},
|
||||
{0, rtw_fwdbg_event_callback},
|
||||
{0, NULL},
|
||||
{0, NULL}, /*20*/
|
||||
{0, NULL},
|
||||
{0, NULL},
|
||||
|
@ -47,16 +47,8 @@ struct pwrctrl_priv {
|
||||
u8 smart_ps;
|
||||
u8 bcn_ant_mode;
|
||||
|
||||
u32 alives;
|
||||
struct work_struct cpwm_event;
|
||||
bool bpower_saving;
|
||||
|
||||
u8 reg_rfoff;
|
||||
u8 reg_pdnmode; /* powerdown mode */
|
||||
|
||||
/* RF OFF Level */
|
||||
u32 cur_ps_level;
|
||||
u32 reg_rfps_level;
|
||||
uint ips_enter_cnts;
|
||||
uint ips_leave_cnts;
|
||||
|
||||
@ -64,7 +56,7 @@ struct pwrctrl_priv {
|
||||
u8 ips_mode_req; /* used to accept the mode setting request,
|
||||
* will update to ipsmode later */
|
||||
uint bips_processing;
|
||||
u32 ips_deny_time; /* will deny IPS when system time less than this */
|
||||
unsigned long ips_deny_time; /* will deny IPS when system time less than this */
|
||||
u8 ps_processing; /* temp used to mark whether in rtw_ps_processor */
|
||||
|
||||
u8 bLeisurePs;
|
||||
@ -72,21 +64,15 @@ struct pwrctrl_priv {
|
||||
u8 power_mgnt;
|
||||
u8 bFwCurrentInPSMode;
|
||||
u32 DelayLPSLastTimeStamp;
|
||||
s32 pnp_current_pwr_state;
|
||||
u8 pnp_bstop_trx;
|
||||
|
||||
u8 bInSuspend;
|
||||
u8 bSupportRemoteWakeup;
|
||||
struct timer_list pwr_state_check_timer;
|
||||
int pwr_state_check_interval;
|
||||
u8 pwr_state_check_cnts;
|
||||
|
||||
int ps_flag;
|
||||
|
||||
enum rt_rf_power_state rf_pwrstate;/* cur power state */
|
||||
enum rt_rf_power_state change_rfpwrstate;
|
||||
|
||||
u8 wepkeymask;
|
||||
u8 bkeepfwalive;
|
||||
};
|
||||
|
||||
@ -109,6 +95,7 @@ struct pwrctrl_priv {
|
||||
|
||||
void rtw_init_pwrctrl_priv(struct adapter *adapter);
|
||||
|
||||
void rtw_set_firmware_ps_mode(struct adapter *adapter, u8 mode);
|
||||
void rtw_set_ps_mode(struct adapter *adapter, u8 ps_mode, u8 smart_ps,
|
||||
u8 bcn_ant_mode);
|
||||
void LeaveAllPowerSaveMode(struct adapter *adapter);
|
||||
@ -117,14 +104,10 @@ int ips_leave(struct adapter *padapter);
|
||||
|
||||
void rtw_ps_processor(struct adapter *padapter);
|
||||
|
||||
s32 LPS_RF_ON_check(struct adapter *adapter, u32 delay_ms);
|
||||
void LPS_Enter(struct adapter *adapter);
|
||||
void LPS_Leave(struct adapter *adapter);
|
||||
|
||||
int _rtw_pwr_wakeup(struct adapter *adapter, u32 ips_defer_ms,
|
||||
const char *caller);
|
||||
#define rtw_pwr_wakeup(adapter) \
|
||||
_rtw_pwr_wakeup(adapter, RTW_PWR_STATE_CHK_INTERVAL, __func__)
|
||||
int rtw_pwr_wakeup(struct adapter *adapter);
|
||||
int rtw_pm_set_ips(struct adapter *adapter, u8 mode);
|
||||
int rtw_pm_set_lps(struct adapter *adapter, u8 mode);
|
||||
|
||||
|
@ -80,7 +80,6 @@ struct rx_pkt_attrib {
|
||||
u8 drvinfo_sz;
|
||||
u8 shift_sz;
|
||||
u8 hdrlen; /* the WLAN Header Len */
|
||||
u8 to_fr_ds;
|
||||
u8 amsdu;
|
||||
bool qos;
|
||||
u8 priority;
|
||||
@ -167,7 +166,6 @@ struct recv_priv {
|
||||
uint rx_largepacket_crcerr;
|
||||
uint rx_smallpacket_crcerr;
|
||||
uint rx_middlepacket_crcerr;
|
||||
struct semaphore allrxreturnevt;
|
||||
u8 rx_pending_cnt;
|
||||
|
||||
struct tasklet_struct recv_tasklet;
|
||||
@ -230,7 +228,6 @@ struct recv_buf {
|
||||
struct recv_frame {
|
||||
struct list_head list;
|
||||
struct sk_buff *pkt;
|
||||
struct sk_buff *pkt_newalloc;
|
||||
struct adapter *adapter;
|
||||
u8 fragcnt;
|
||||
int frame_tag;
|
||||
|
@ -198,7 +198,7 @@ struct xmit_buf {
|
||||
u32 len;
|
||||
struct submit_ctx *sctx;
|
||||
u32 ff_hwaddr;
|
||||
struct urb *pxmit_urb[8];
|
||||
struct urb *pxmit_urb;
|
||||
dma_addr_t dma_transfer_addr; /* (in) dma addr for transfer_buffer */
|
||||
u8 bpending[8];
|
||||
int last[8];
|
||||
@ -341,7 +341,7 @@ s32 rtw_txframes_sta_ac_pending(struct adapter *padapter,
|
||||
void rtw_init_hwxmits(struct hw_xmit *phwxmit, int entry);
|
||||
s32 _rtw_init_xmit_priv(struct xmit_priv *pxmitpriv, struct adapter *padapter);
|
||||
void _rtw_free_xmit_priv(struct xmit_priv *pxmitpriv);
|
||||
void rtw_alloc_hwxmits(struct adapter *padapter);
|
||||
int rtw_alloc_hwxmits(struct adapter *padapter);
|
||||
void rtw_free_hwxmits(struct adapter *padapter);
|
||||
s32 rtw_xmit(struct adapter *padapter, struct sk_buff **pkt);
|
||||
|
||||
|
@ -48,7 +48,6 @@ struct stainfo_stats {
|
||||
u64 rx_ctrl_pkts;
|
||||
u64 rx_data_pkts;
|
||||
|
||||
u64 last_rx_mgnt_pkts;
|
||||
u64 last_rx_beacon_pkts;
|
||||
u64 last_rx_probereq_pkts;
|
||||
u64 last_rx_probersp_pkts;
|
||||
@ -230,7 +229,6 @@ struct sta_info {
|
||||
|
||||
#define sta_update_last_rx_pkts(sta) \
|
||||
do { \
|
||||
sta->sta_stats.last_rx_mgnt_pkts = sta->sta_stats.rx_mgnt_pkts; \
|
||||
sta->sta_stats.last_rx_beacon_pkts = sta->sta_stats.rx_beacon_pkts; \
|
||||
sta->sta_stats.last_rx_probereq_pkts = sta->sta_stats.rx_probereq_pkts; \
|
||||
sta->sta_stats.last_rx_probersp_pkts = sta->sta_stats.rx_probersp_pkts; \
|
||||
|
@ -25,15 +25,14 @@
|
||||
* @return true:
|
||||
* @return false:
|
||||
*/
|
||||
static inline int rtw_inc_and_chk_continual_urb_error(struct dvobj_priv *dvobj)
|
||||
static inline bool rtw_inc_and_chk_continual_urb_error(struct dvobj_priv *dvobj)
|
||||
{
|
||||
int ret = false;
|
||||
int value;
|
||||
value = atomic_inc_return(&dvobj->continual_urb_error);
|
||||
if (value > MAX_CONTINUAL_URB_ERR)
|
||||
ret = true;
|
||||
int value = atomic_inc_return(&dvobj->continual_urb_error);
|
||||
|
||||
return ret;
|
||||
if (value > MAX_CONTINUAL_URB_ERR)
|
||||
return true;
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
/*
|
||||
@ -47,19 +46,14 @@ static inline void rtw_reset_continual_urb_error(struct dvobj_priv *dvobj)
|
||||
#define USB_HIGH_SPEED_BULK_SIZE 512
|
||||
#define USB_FULL_SPEED_BULK_SIZE 64
|
||||
|
||||
static inline u8 rtw_usb_bulk_size_boundary(struct adapter *padapter,
|
||||
int buf_len)
|
||||
static inline bool rtw_usb_bulk_size_boundary(struct adapter *padapter, int buf_len)
|
||||
{
|
||||
u8 rst = true;
|
||||
struct dvobj_priv *pdvobjpriv = adapter_to_dvobj(padapter);
|
||||
|
||||
if (pdvobjpriv->pusbdev->speed == USB_SPEED_HIGH)
|
||||
rst = (0 == (buf_len) % USB_HIGH_SPEED_BULK_SIZE) ?
|
||||
true : false;
|
||||
return buf_len % USB_HIGH_SPEED_BULK_SIZE == 0;
|
||||
else
|
||||
rst = (0 == (buf_len) % USB_FULL_SPEED_BULK_SIZE) ?
|
||||
true : false;
|
||||
return rst;
|
||||
return buf_len % USB_FULL_SPEED_BULK_SIZE == 0;
|
||||
}
|
||||
|
||||
#endif /* __USB_OPS_H_ */
|
||||
|
@ -6,16 +6,12 @@
|
||||
|
||||
#include "osdep_service.h"
|
||||
#include "drv_types.h"
|
||||
#include "usb_vendor_req.h"
|
||||
|
||||
extern char *rtw_initmac;
|
||||
extern int rtw_mc2u_disable;
|
||||
|
||||
#define USBD_HALTED(Status) ((u32)(Status) >> 30 == 3)
|
||||
|
||||
u8 usbvendorrequest(struct dvobj_priv *pdvobjpriv, enum bt_usb_request brequest,
|
||||
enum rt_usb_wvalue wvalue, u8 windex, void *data,
|
||||
u8 datalen, u8 isdirectionin);
|
||||
void netdev_br_init(struct net_device *netdev);
|
||||
void dhcp_flag_bcast(struct adapter *priv, struct sk_buff *skb);
|
||||
void *scdb_findEntry(struct adapter *priv, unsigned char *ipAddr);
|
||||
|
@ -1,35 +0,0 @@
|
||||
/* SPDX-License-Identifier: GPL-2.0 OR BSD-3-Clause */
|
||||
/* Copyright(c) 2007 - 2011 Realtek Corporation. */
|
||||
|
||||
#ifndef _USB_VENDOR_REQUEST_H_
|
||||
#define _USB_VENDOR_REQUEST_H_
|
||||
|
||||
/* 4 Set/Get Register related wIndex/Data */
|
||||
#define RT_USB_RESET_MASK_OFF 0
|
||||
#define RT_USB_RESET_MASK_ON 1
|
||||
#define RT_USB_SLEEP_MASK_OFF 0
|
||||
#define RT_USB_SLEEP_MASK_ON 1
|
||||
#define RT_USB_LDO_ON 1
|
||||
#define RT_USB_LDO_OFF 0
|
||||
|
||||
/* 4 Set/Get SYSCLK related wValue or Data */
|
||||
#define RT_USB_SYSCLK_32KHZ 0
|
||||
#define RT_USB_SYSCLK_40MHZ 1
|
||||
#define RT_USB_SYSCLK_60MHZ 2
|
||||
|
||||
enum bt_usb_request {
|
||||
RT_USB_SET_REGISTER = 1,
|
||||
RT_USB_SET_SYSCLK = 2,
|
||||
RT_USB_GET_SYSCLK = 3,
|
||||
RT_USB_GET_REGISTER = 4
|
||||
};
|
||||
|
||||
enum rt_usb_wvalue {
|
||||
RT_USB_RESET_MASK = 1,
|
||||
RT_USB_SLEEP_MASK = 2,
|
||||
RT_USB_USB_HRCPWM = 3,
|
||||
RT_USB_LDO = 4,
|
||||
RT_USB_BOOT_TYPE = 5
|
||||
};
|
||||
|
||||
#endif
|
@ -4,25 +4,14 @@
|
||||
#ifndef _WIFI_H_
|
||||
#define _WIFI_H_
|
||||
|
||||
#include <linux/bits.h>
|
||||
#include <linux/ieee80211.h>
|
||||
|
||||
#ifdef BIT
|
||||
/* error "BIT define occurred earlier elsewhere!\n" */
|
||||
#undef BIT
|
||||
#endif
|
||||
#define BIT(x) (1 << (x))
|
||||
|
||||
#define WLAN_ETHHDR_LEN 14
|
||||
#define WLAN_HDR_A3_LEN 24
|
||||
#define WLAN_HDR_A3_QOS_LEN 26
|
||||
#define WLAN_SSID_MAXLEN 32
|
||||
|
||||
enum WIFI_FRAME_TYPE {
|
||||
WIFI_CTRL_TYPE = (BIT(2)),
|
||||
WIFI_DATA_TYPE = (BIT(3)),
|
||||
WIFI_QOS_DATA_TYPE = (BIT(7)|BIT(3)), /* QoS Data */
|
||||
};
|
||||
|
||||
enum WIFI_FRAME_SUBTYPE {
|
||||
/* below is for mgt frame */
|
||||
WIFI_ASSOCREQ = (0 | IEEE80211_FTYPE_MGMT),
|
||||
@ -39,24 +28,15 @@ enum WIFI_FRAME_SUBTYPE {
|
||||
WIFI_ACTION = (BIT(7) | BIT(6) | BIT(4) | IEEE80211_FTYPE_MGMT),
|
||||
|
||||
/* below is for control frame */
|
||||
WIFI_PSPOLL = (BIT(7) | BIT(5) | WIFI_CTRL_TYPE),
|
||||
WIFI_RTS = (BIT(7) | BIT(5) | BIT(4) | WIFI_CTRL_TYPE),
|
||||
WIFI_CTS = (BIT(7) | BIT(6) | WIFI_CTRL_TYPE),
|
||||
WIFI_ACK = (BIT(7) | BIT(6) | BIT(4) | WIFI_CTRL_TYPE),
|
||||
WIFI_CFEND = (BIT(7) | BIT(6) | BIT(5) | WIFI_CTRL_TYPE),
|
||||
WIFI_CFEND_CFACK = (BIT(7) | BIT(6) | BIT(5) | BIT(4) |
|
||||
WIFI_CTRL_TYPE),
|
||||
WIFI_PSPOLL = (BIT(7) | BIT(5) | IEEE80211_FTYPE_CTL),
|
||||
|
||||
/* below is for data frame */
|
||||
WIFI_DATA = (0 | WIFI_DATA_TYPE),
|
||||
WIFI_DATA_CFACK = (BIT(4) | WIFI_DATA_TYPE),
|
||||
WIFI_DATA_CFPOLL = (BIT(5) | WIFI_DATA_TYPE),
|
||||
WIFI_DATA_CFACKPOLL = (BIT(5) | BIT(4) | WIFI_DATA_TYPE),
|
||||
WIFI_DATA_NULL = (BIT(6) | WIFI_DATA_TYPE),
|
||||
WIFI_CF_ACK = (BIT(6) | BIT(4) | WIFI_DATA_TYPE),
|
||||
WIFI_CF_POLL = (BIT(6) | BIT(5) | WIFI_DATA_TYPE),
|
||||
WIFI_CF_ACKPOLL = (BIT(6) | BIT(5) | BIT(4) | WIFI_DATA_TYPE),
|
||||
WIFI_QOS_DATA_NULL = (BIT(6) | WIFI_QOS_DATA_TYPE),
|
||||
WIFI_DATA = (0 | IEEE80211_FTYPE_DATA),
|
||||
WIFI_DATA_CFACK = (BIT(4) | IEEE80211_FTYPE_DATA),
|
||||
WIFI_DATA_CFPOLL = (BIT(5) | IEEE80211_FTYPE_DATA),
|
||||
WIFI_DATA_CFACKPOLL = (BIT(5) | BIT(4) | IEEE80211_FTYPE_DATA),
|
||||
WIFI_DATA_NULL = (BIT(6) | IEEE80211_FTYPE_DATA),
|
||||
WIFI_QOS_DATA_NULL = (BIT(6) | IEEE80211_STYPE_QOS_DATA | IEEE80211_FTYPE_DATA),
|
||||
};
|
||||
|
||||
enum WIFI_REASON_CODE {
|
||||
@ -172,8 +152,6 @@ enum WIFI_REG_DOMAIN {
|
||||
|
||||
#define GetFrDs(pbuf) (((*(__le16 *)(pbuf)) & cpu_to_le16(_FROM_DS_)) != 0)
|
||||
|
||||
#define get_tofr_ds(pframe) ((GetToDs(pframe) << 1) | GetFrDs(pframe))
|
||||
|
||||
#define SetMFrag(pbuf) \
|
||||
*(__le16 *)(pbuf) |= cpu_to_le16(_MORE_FRAG_)
|
||||
|
||||
@ -209,12 +187,6 @@ enum WIFI_REG_DOMAIN {
|
||||
*(__le16 *)(pbuf) |= cpu_to_le16(type); \
|
||||
} while (0)
|
||||
|
||||
#define GetSequence(pbuf) \
|
||||
(le16_to_cpu(*(__le16 *)((size_t)(pbuf) + 22)) >> 4)
|
||||
|
||||
#define GetFragNum(pbuf) \
|
||||
(le16_to_cpu(*(__le16 *)((size_t)(pbuf) + 22)) & 0x0f)
|
||||
|
||||
#define GetTupleCache(pbuf) \
|
||||
(cpu_to_le16(*(unsigned short *)((size_t)(pbuf) + 22)))
|
||||
|
||||
@ -239,8 +211,6 @@ enum WIFI_REG_DOMAIN {
|
||||
#define SetPriority(pbuf, tid) \
|
||||
*(__le16 *)(pbuf) |= cpu_to_le16(tid & 0xf)
|
||||
|
||||
#define GetPriority(pbuf) ((le16_to_cpu(*(__le16 *)(pbuf))) & 0xf)
|
||||
|
||||
#define SetEOSP(pbuf, eosp) \
|
||||
*(__le16 *)(pbuf) |= cpu_to_le16((eosp & 1) << 4)
|
||||
|
||||
@ -254,8 +224,6 @@ enum WIFI_REG_DOMAIN {
|
||||
#define SetAMsdu(pbuf, amsdu) \
|
||||
*(__le16 *)(pbuf) |= cpu_to_le16((amsdu & 1) << 7)
|
||||
|
||||
#define GetAid(pbuf) (le16_to_cpu(*(__le16 *)((size_t)(pbuf) + 2)) & 0x3fff)
|
||||
|
||||
#define GetTid(pbuf) (le16_to_cpu(*(__le16 *)((size_t)(pbuf) + \
|
||||
(((GetToDs(pbuf)<<1) | GetFrDs(pbuf)) == 3 ? \
|
||||
30 : 24))) & 0x000f)
|
||||
@ -270,10 +238,7 @@ enum WIFI_REG_DOMAIN {
|
||||
|
||||
static inline bool IS_MCAST(unsigned char *da)
|
||||
{
|
||||
if ((*da) & 0x01)
|
||||
return true;
|
||||
else
|
||||
return false;
|
||||
return (*da) & 0x01;
|
||||
}
|
||||
|
||||
static inline unsigned char *get_da(unsigned char *pframe)
|
||||
@ -345,13 +310,6 @@ static inline unsigned char *get_hdr_bssid(unsigned char *pframe)
|
||||
return sa;
|
||||
}
|
||||
|
||||
static inline bool IsFrameTypeCtrl(unsigned char *pframe)
|
||||
{
|
||||
if (WIFI_CTRL_TYPE == GetFrameType(pframe))
|
||||
return true;
|
||||
else
|
||||
return false;
|
||||
}
|
||||
/*-----------------------------------------------------------------------------
|
||||
Below is for the security related definition
|
||||
------------------------------------------------------------------------------*/
|
||||
|
@ -4,7 +4,6 @@
|
||||
#include "../include/osdep_service.h"
|
||||
#include "../include/drv_types.h"
|
||||
#include "../include/wlan_bssdef.h"
|
||||
#include "../include/rtw_debug.h"
|
||||
#include "../include/wifi.h"
|
||||
#include "../include/rtw_mlme.h"
|
||||
#include "../include/rtw_mlme_ext.h"
|
||||
@ -1131,9 +1130,11 @@ static int rtw_wx_set_scan(struct net_device *dev, struct iw_request_info *a,
|
||||
break;
|
||||
}
|
||||
sec_len = *(pos++); len -= 1;
|
||||
if (sec_len > 0 && sec_len <= len) {
|
||||
if (sec_len > 0 &&
|
||||
sec_len <= len &&
|
||||
sec_len <= 32) {
|
||||
ssid[ssid_index].SsidLength = sec_len;
|
||||
memcpy(ssid[ssid_index].Ssid, pos, ssid[ssid_index].SsidLength);
|
||||
memcpy(ssid[ssid_index].Ssid, pos, sec_len);
|
||||
ssid_index++;
|
||||
}
|
||||
pos += sec_len;
|
||||
@ -1886,88 +1887,6 @@ static int rtw_wx_get_nick(struct net_device *dev,
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int rtw_wx_read32(struct net_device *dev,
|
||||
struct iw_request_info *info,
|
||||
union iwreq_data *wrqu, char *extra)
|
||||
{
|
||||
struct adapter *padapter;
|
||||
struct iw_point *p;
|
||||
u16 len;
|
||||
u32 addr;
|
||||
u32 data32;
|
||||
u32 bytes;
|
||||
u8 *ptmp;
|
||||
int ret;
|
||||
|
||||
padapter = (struct adapter *)rtw_netdev_priv(dev);
|
||||
p = &wrqu->data;
|
||||
len = p->length;
|
||||
ptmp = memdup_user(p->pointer, len);
|
||||
if (IS_ERR(ptmp))
|
||||
return PTR_ERR(ptmp);
|
||||
|
||||
bytes = 0;
|
||||
addr = 0;
|
||||
sscanf(ptmp, "%d,%x", &bytes, &addr);
|
||||
|
||||
switch (bytes) {
|
||||
case 1:
|
||||
data32 = rtw_read8(padapter, addr);
|
||||
sprintf(extra, "0x%02X", data32);
|
||||
break;
|
||||
case 2:
|
||||
data32 = rtw_read16(padapter, addr);
|
||||
sprintf(extra, "0x%04X", data32);
|
||||
break;
|
||||
case 4:
|
||||
data32 = rtw_read32(padapter, addr);
|
||||
sprintf(extra, "0x%08X", data32);
|
||||
break;
|
||||
default:
|
||||
ret = -EINVAL;
|
||||
goto err_free_ptmp;
|
||||
}
|
||||
|
||||
kfree(ptmp);
|
||||
return 0;
|
||||
|
||||
err_free_ptmp:
|
||||
kfree(ptmp);
|
||||
return ret;
|
||||
}
|
||||
|
||||
static int rtw_wx_write32(struct net_device *dev,
|
||||
struct iw_request_info *info,
|
||||
union iwreq_data *wrqu, char *extra)
|
||||
{
|
||||
struct adapter *padapter = (struct adapter *)rtw_netdev_priv(dev);
|
||||
|
||||
u32 addr;
|
||||
u32 data32;
|
||||
u32 bytes;
|
||||
|
||||
bytes = 0;
|
||||
addr = 0;
|
||||
data32 = 0;
|
||||
sscanf(extra, "%d,%x,%x", &bytes, &addr, &data32);
|
||||
|
||||
switch (bytes) {
|
||||
case 1:
|
||||
rtw_write8(padapter, addr, (u8)data32);
|
||||
break;
|
||||
case 2:
|
||||
rtw_write16(padapter, addr, (u16)data32);
|
||||
break;
|
||||
case 4:
|
||||
rtw_write32(padapter, addr, data32);
|
||||
break;
|
||||
default:
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int rtw_wx_read_rf(struct net_device *dev,
|
||||
struct iw_request_info *info,
|
||||
union iwreq_data *wrqu, char *extra)
|
||||
@ -2363,114 +2282,6 @@ static void rtw_p2p_setDN(struct net_device *dev,
|
||||
pwdinfo->device_name_len = wrqu->data.length - 1;
|
||||
}
|
||||
|
||||
static void rtw_p2p_get_status(struct net_device *dev,
|
||||
struct iw_request_info *info,
|
||||
union iwreq_data *wrqu, char *extra)
|
||||
{
|
||||
struct adapter *padapter = (struct adapter *)rtw_netdev_priv(dev);
|
||||
struct wifidirect_info *pwdinfo = &padapter->wdinfo;
|
||||
|
||||
/* Commented by Albert 2010/10/12 */
|
||||
/* Because of the output size limitation, I had removed the "Role" information. */
|
||||
/* About the "Role" information, we will use the new private IOCTL to get the "Role" information. */
|
||||
sprintf(extra, "\n\nStatus =%.2d\n", rtw_p2p_state(pwdinfo));
|
||||
wrqu->data.length = strlen(extra);
|
||||
}
|
||||
|
||||
/* Commented by Albert 20110520 */
|
||||
/* This function will return the config method description */
|
||||
/* This config method description will show us which config method the remote P2P device is intended to use */
|
||||
/* by sending the provisioning discovery request frame. */
|
||||
|
||||
static void rtw_p2p_get_req_cm(struct net_device *dev,
|
||||
struct iw_request_info *info,
|
||||
union iwreq_data *wrqu, char *extra)
|
||||
{
|
||||
struct adapter *padapter = (struct adapter *)rtw_netdev_priv(dev);
|
||||
struct wifidirect_info *pwdinfo = &padapter->wdinfo;
|
||||
|
||||
sprintf(extra, "\n\nCM =%s\n", pwdinfo->rx_prov_disc_info.strconfig_method_desc_of_prov_disc_req);
|
||||
wrqu->data.length = strlen(extra);
|
||||
}
|
||||
|
||||
static void rtw_p2p_get_role(struct net_device *dev,
|
||||
struct iw_request_info *info,
|
||||
union iwreq_data *wrqu, char *extra)
|
||||
{
|
||||
struct adapter *padapter = (struct adapter *)rtw_netdev_priv(dev);
|
||||
struct wifidirect_info *pwdinfo = &padapter->wdinfo;
|
||||
|
||||
sprintf(extra, "\n\nRole =%.2d\n", rtw_p2p_role(pwdinfo));
|
||||
wrqu->data.length = strlen(extra);
|
||||
}
|
||||
|
||||
static void rtw_p2p_get_peer_ifaddr(struct net_device *dev,
|
||||
struct iw_request_info *info,
|
||||
union iwreq_data *wrqu, char *extra)
|
||||
{
|
||||
struct adapter *padapter = (struct adapter *)rtw_netdev_priv(dev);
|
||||
struct wifidirect_info *pwdinfo = &padapter->wdinfo;
|
||||
|
||||
sprintf(extra, "\nMAC %pM",
|
||||
pwdinfo->p2p_peer_interface_addr);
|
||||
wrqu->data.length = strlen(extra);
|
||||
}
|
||||
|
||||
static void rtw_p2p_get_peer_devaddr(struct net_device *dev,
|
||||
struct iw_request_info *info,
|
||||
union iwreq_data *wrqu, char *extra)
|
||||
|
||||
{
|
||||
struct adapter *padapter = (struct adapter *)rtw_netdev_priv(dev);
|
||||
struct wifidirect_info *pwdinfo = &padapter->wdinfo;
|
||||
|
||||
sprintf(extra, "\n%pM",
|
||||
pwdinfo->rx_prov_disc_info.peerDevAddr);
|
||||
wrqu->data.length = strlen(extra);
|
||||
}
|
||||
|
||||
static void rtw_p2p_get_peer_devaddr_by_invitation(struct net_device *dev,
|
||||
struct iw_request_info *info,
|
||||
union iwreq_data *wrqu,
|
||||
char *extra)
|
||||
|
||||
{
|
||||
struct adapter *padapter = (struct adapter *)rtw_netdev_priv(dev);
|
||||
struct wifidirect_info *pwdinfo = &padapter->wdinfo;
|
||||
|
||||
sprintf(extra, "\nMAC %pM",
|
||||
pwdinfo->p2p_peer_device_addr);
|
||||
wrqu->data.length = strlen(extra);
|
||||
}
|
||||
|
||||
static void rtw_p2p_get_groupid(struct net_device *dev,
|
||||
struct iw_request_info *info,
|
||||
union iwreq_data *wrqu, char *extra)
|
||||
|
||||
{
|
||||
struct adapter *padapter = (struct adapter *)rtw_netdev_priv(dev);
|
||||
struct wifidirect_info *pwdinfo = &padapter->wdinfo;
|
||||
|
||||
sprintf(extra, "\n%.2X:%.2X:%.2X:%.2X:%.2X:%.2X %s",
|
||||
pwdinfo->groupid_info.go_device_addr[0], pwdinfo->groupid_info.go_device_addr[1],
|
||||
pwdinfo->groupid_info.go_device_addr[2], pwdinfo->groupid_info.go_device_addr[3],
|
||||
pwdinfo->groupid_info.go_device_addr[4], pwdinfo->groupid_info.go_device_addr[5],
|
||||
pwdinfo->groupid_info.ssid);
|
||||
wrqu->data.length = strlen(extra);
|
||||
}
|
||||
|
||||
static void rtw_p2p_get_op_ch(struct net_device *dev,
|
||||
struct iw_request_info *info,
|
||||
union iwreq_data *wrqu, char *extra)
|
||||
|
||||
{
|
||||
struct adapter *padapter = (struct adapter *)rtw_netdev_priv(dev);
|
||||
struct wifidirect_info *pwdinfo = &padapter->wdinfo;
|
||||
|
||||
sprintf(extra, "\n\nOp_ch =%.2d\n", pwdinfo->operating_channel);
|
||||
wrqu->data.length = strlen(extra);
|
||||
}
|
||||
|
||||
static int rtw_p2p_get_wps_configmethod(struct net_device *dev,
|
||||
struct iw_request_info *info,
|
||||
union iwreq_data *wrqu, char *extra)
|
||||
@ -3229,32 +3040,6 @@ static int rtw_p2p_set(struct net_device *dev,
|
||||
return ret;
|
||||
}
|
||||
|
||||
static int rtw_p2p_get(struct net_device *dev,
|
||||
struct iw_request_info *info,
|
||||
union iwreq_data *wrqu, char *extra)
|
||||
{
|
||||
if (!memcmp(wrqu->data.pointer, "status", 6)) {
|
||||
rtw_p2p_get_status(dev, info, wrqu, extra);
|
||||
} else if (!memcmp(wrqu->data.pointer, "role", 4)) {
|
||||
rtw_p2p_get_role(dev, info, wrqu, extra);
|
||||
} else if (!memcmp(wrqu->data.pointer, "peer_ifa", 8)) {
|
||||
rtw_p2p_get_peer_ifaddr(dev, info, wrqu, extra);
|
||||
} else if (!memcmp(wrqu->data.pointer, "req_cm", 6)) {
|
||||
rtw_p2p_get_req_cm(dev, info, wrqu, extra);
|
||||
} else if (!memcmp(wrqu->data.pointer, "peer_deva", 9)) {
|
||||
/* Get the P2P device address when receiving the provision discovery request frame. */
|
||||
rtw_p2p_get_peer_devaddr(dev, info, wrqu, extra);
|
||||
} else if (!memcmp(wrqu->data.pointer, "group_id", 8)) {
|
||||
rtw_p2p_get_groupid(dev, info, wrqu, extra);
|
||||
} else if (!memcmp(wrqu->data.pointer, "peer_deva_inv", 9)) {
|
||||
/* Get the P2P device address when receiving the P2P Invitation request frame. */
|
||||
rtw_p2p_get_peer_devaddr_by_invitation(dev, info, wrqu, extra);
|
||||
} else if (!memcmp(wrqu->data.pointer, "op_ch", 5)) {
|
||||
rtw_p2p_get_op_ch(dev, info, wrqu, extra);
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int rtw_p2p_get2(struct net_device *dev,
|
||||
struct iw_request_info *info,
|
||||
union iwreq_data *wrqu, char *extra)
|
||||
@ -3389,6 +3174,34 @@ static void rf_reg_dump(struct adapter *padapter)
|
||||
}
|
||||
}
|
||||
|
||||
static void rtw_set_dynamic_functions(struct adapter *adapter, u8 dm_func)
|
||||
{
|
||||
struct hal_data_8188e *haldata = &adapter->haldata;
|
||||
struct odm_dm_struct *odmpriv = &haldata->odmpriv;
|
||||
|
||||
switch (dm_func) {
|
||||
case 0:
|
||||
/* disable all dynamic func */
|
||||
odmpriv->SupportAbility = DYNAMIC_FUNC_DISABLE;
|
||||
break;
|
||||
case 1:
|
||||
/* disable DIG */
|
||||
odmpriv->SupportAbility &= (~DYNAMIC_BB_DIG);
|
||||
break;
|
||||
case 6:
|
||||
/* turn on all dynamic func */
|
||||
if (!(odmpriv->SupportAbility & DYNAMIC_BB_DIG)) {
|
||||
struct rtw_dig *digtable = &odmpriv->DM_DigTable;
|
||||
|
||||
digtable->CurIGValue = rtw_read8(adapter, 0xc50);
|
||||
}
|
||||
odmpriv->SupportAbility = DYNAMIC_ALL_FUNC_ENABLE;
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
static int rtw_dbg_port(struct net_device *dev,
|
||||
struct iw_request_info *info,
|
||||
union iwreq_data *wrqu, char *extra)
|
||||
@ -3620,9 +3433,7 @@ static int rtw_dbg_port(struct net_device *dev,
|
||||
break;
|
||||
case 0x06:
|
||||
{
|
||||
u32 ODMFlag;
|
||||
GetHwReg8188EU(padapter, HW_VAR_DM_FLAG, (u8 *)(&ODMFlag));
|
||||
ODMFlag = (u32)(0x0f & arg);
|
||||
u32 ODMFlag = (u32)(0x0f & arg);
|
||||
SetHwReg8188EU(padapter, HW_VAR_DM_FLAG, (u8 *)(&ODMFlag));
|
||||
}
|
||||
break;
|
||||
@ -3632,13 +3443,6 @@ static int rtw_dbg_port(struct net_device *dev,
|
||||
break;
|
||||
case 0x09:
|
||||
break;
|
||||
case 0x0c:/* dump rx/tx packet */
|
||||
if (arg == 0) {
|
||||
SetHalDefVar8188EUsb(padapter, HAL_DEF_DBG_DUMP_RXPKT, &extra_arg);
|
||||
} else if (arg == 1) {
|
||||
SetHalDefVar8188EUsb(padapter, HAL_DEF_DBG_DUMP_TXPKT, &extra_arg);
|
||||
}
|
||||
break;
|
||||
case 0x15:
|
||||
break;
|
||||
case 0x10:/* driver version display */
|
||||
@ -3683,23 +3487,14 @@ static int rtw_dbg_port(struct net_device *dev,
|
||||
rf_reg_dump(padapter);
|
||||
break;
|
||||
case 0xee:/* turn on/off dynamic funcs */
|
||||
{
|
||||
u32 odm_flag;
|
||||
|
||||
if (0xf == extra_arg) {
|
||||
GetHalDefVar8188EUsb(padapter, HAL_DEF_DBG_DM_FUNC, &odm_flag);
|
||||
} else {
|
||||
/* extra_arg = 0 - disable all dynamic func
|
||||
extra_arg = 1 - disable DIG
|
||||
extra_arg = 2 - disable tx power tracking
|
||||
extra_arg = 3 - turn on all dynamic func
|
||||
*/
|
||||
SetHalDefVar8188EUsb(padapter, HAL_DEF_DBG_DM_FUNC, &extra_arg);
|
||||
GetHalDefVar8188EUsb(padapter, HAL_DEF_DBG_DM_FUNC, &odm_flag);
|
||||
}
|
||||
if (extra_arg != 0xf) {
|
||||
/* extra_arg = 0 - disable all dynamic func
|
||||
* extra_arg = 1 - disable DIG
|
||||
* extra_arg = 6 - turn on all dynamic func
|
||||
*/
|
||||
rtw_set_dynamic_functions(padapter, extra_arg);
|
||||
}
|
||||
break;
|
||||
|
||||
case 0xfd:
|
||||
rtw_write8(padapter, 0xc50, arg);
|
||||
rtw_write8(padapter, 0xc58, arg);
|
||||
@ -3895,8 +3690,8 @@ static const struct iw_priv_args rtw_private_args[] = {
|
||||
};
|
||||
|
||||
static iw_handler rtw_private_handler[] = {
|
||||
rtw_wx_write32, /* 0x00 */
|
||||
rtw_wx_read32, /* 0x01 */
|
||||
NULL, /* 0x00 */
|
||||
NULL, /* 0x01 */
|
||||
NULL, /* 0x02 */
|
||||
NULL, /* 0x03 */
|
||||
/* for MM DTV platform */
|
||||
@ -3919,7 +3714,7 @@ NULL, /* 0x03 */
|
||||
NULL, /* 0x0F */
|
||||
|
||||
rtw_p2p_set, /* 0x10 */
|
||||
rtw_p2p_get, /* 0x11 */
|
||||
NULL, /* 0x11 */
|
||||
rtw_p2p_get2, /* 0x12 */
|
||||
|
||||
NULL, /* 0x13 */
|
||||
@ -3958,10 +3753,10 @@ static struct iw_statistics *rtw_get_wireless_stats(struct net_device *dev)
|
||||
|
||||
struct iw_handler_def rtw_handlers_def = {
|
||||
.standard = rtw_handlers,
|
||||
.num_standard = sizeof(rtw_handlers) / sizeof(iw_handler),
|
||||
.num_standard = ARRAY_SIZE(rtw_handlers),
|
||||
.private = rtw_private_handler,
|
||||
.private_args = (struct iw_priv_args *)rtw_private_args,
|
||||
.num_private = sizeof(rtw_private_handler) / sizeof(iw_handler),
|
||||
.num_private_args = sizeof(rtw_private_args) / sizeof(struct iw_priv_args),
|
||||
.num_private = ARRAY_SIZE(rtw_private_handler),
|
||||
.num_private_args = ARRAY_SIZE(rtw_private_args),
|
||||
.get_wireless_stats = rtw_get_wireless_stats,
|
||||
};
|
||||
|
@ -66,7 +66,6 @@ void rtw_reset_securitypriv(struct adapter *adapter)
|
||||
/* We have to backup the PMK information for WiFi PMK Caching test item. */
|
||||
/* Backup the btkip_countermeasure information. */
|
||||
/* When the countermeasure is trigger, the driver have to disconnect with AP for 60 seconds. */
|
||||
memset(&backup_pmkid[0], 0x00, sizeof(struct rt_pmkid_list) * NUM_PMKID_CACHE);
|
||||
memcpy(&backup_pmkid[0], &adapter->securitypriv.PMKIDList[0], sizeof(struct rt_pmkid_list) * NUM_PMKID_CACHE);
|
||||
backup_index = adapter->securitypriv.PMKIDIndex;
|
||||
backup_counter = adapter->securitypriv.btkip_countermeasure;
|
||||
|
@ -441,7 +441,6 @@ static void rtw_init_default_value(struct adapter *padapter)
|
||||
u8 rtw_reset_drv_sw(struct adapter *padapter)
|
||||
{
|
||||
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
|
||||
struct pwrctrl_priv *pwrctrlpriv = &padapter->pwrctrlpriv;
|
||||
|
||||
/* hal_priv */
|
||||
rtl8188eu_init_default_value(padapter);
|
||||
@ -457,8 +456,6 @@ u8 rtw_reset_drv_sw(struct adapter *padapter)
|
||||
|
||||
_clr_fwstate_(pmlmepriv, _FW_UNDER_SURVEY | _FW_UNDER_LINKING);
|
||||
|
||||
pwrctrlpriv->pwr_state_check_cnts = 0;
|
||||
|
||||
/* mlmeextpriv */
|
||||
padapter->mlmeextpriv.sitesurvey_res.state = SCAN_DISABLE;
|
||||
|
||||
@ -490,10 +487,7 @@ u8 rtw_init_drv_sw(struct adapter *padapter)
|
||||
init_wifidirect_info(padapter, P2P_ROLE_DISABLE);
|
||||
reset_global_wifidirect_info(padapter);
|
||||
|
||||
if (init_mlme_ext_priv(padapter) == _FAIL) {
|
||||
dev_err(dvobj_to_dev(padapter->dvobj), "init_mlme_ext_priv failed\n");
|
||||
goto free_mlme_priv;
|
||||
}
|
||||
init_mlme_ext_priv(padapter);
|
||||
|
||||
if (_rtw_init_xmit_priv(&padapter->xmitpriv, padapter) == _FAIL) {
|
||||
dev_err(dvobj_to_dev(padapter->dvobj), "_rtw_init_xmit_priv failed\n");
|
||||
@ -534,7 +528,6 @@ u8 rtw_init_drv_sw(struct adapter *padapter)
|
||||
free_mlme_ext:
|
||||
free_mlme_ext_priv(&padapter->mlmeextpriv);
|
||||
|
||||
free_mlme_priv:
|
||||
rtw_free_mlme_priv(&padapter->mlmepriv);
|
||||
|
||||
free_evt_priv:
|
||||
@ -632,12 +625,6 @@ int _netdev_open(struct net_device *pnetdev)
|
||||
{
|
||||
uint status;
|
||||
struct adapter *padapter = (struct adapter *)rtw_netdev_priv(pnetdev);
|
||||
struct pwrctrl_priv *pwrctrlpriv = &padapter->pwrctrlpriv;
|
||||
|
||||
if (pwrctrlpriv->ps_flag) {
|
||||
padapter->net_closed = false;
|
||||
goto netdev_open_normal_process;
|
||||
}
|
||||
|
||||
if (!padapter->bup) {
|
||||
padapter->bDriverStopped = false;
|
||||
@ -681,7 +668,6 @@ int _netdev_open(struct net_device *pnetdev)
|
||||
|
||||
netdev_br_init(pnetdev);
|
||||
|
||||
netdev_open_normal_process:
|
||||
return 0;
|
||||
|
||||
netdev_open_error:
|
||||
@ -750,9 +736,36 @@ void rtw_ips_pwr_down(struct adapter *padapter)
|
||||
padapter->bCardDisableWOHSM = false;
|
||||
}
|
||||
|
||||
static void rtw_fifo_cleanup(struct adapter *adapter)
|
||||
{
|
||||
struct pwrctrl_priv *pwrpriv = &adapter->pwrctrlpriv;
|
||||
u8 trycnt = 100;
|
||||
|
||||
/* pause tx */
|
||||
rtw_write8(adapter, REG_TXPAUSE, 0xff);
|
||||
|
||||
/* keep sn */
|
||||
adapter->xmitpriv.nqos_ssn = rtw_read16(adapter, REG_NQOS_SEQ);
|
||||
|
||||
if (!pwrpriv->bkeepfwalive) {
|
||||
/* RX DMA stop */
|
||||
rtw_write32(adapter, REG_RXPKT_NUM,
|
||||
(rtw_read32(adapter, REG_RXPKT_NUM) | RW_RELEASE_EN));
|
||||
do {
|
||||
if (!(rtw_read32(adapter, REG_RXPKT_NUM) & RXDMA_IDLE))
|
||||
break;
|
||||
} while (trycnt--);
|
||||
|
||||
/* RQPN Load 0 */
|
||||
rtw_write16(adapter, REG_RQPN_NPQ, 0x0);
|
||||
rtw_write32(adapter, REG_RQPN, 0x80000000);
|
||||
mdelay(10);
|
||||
}
|
||||
}
|
||||
|
||||
void rtw_ips_dev_unload(struct adapter *padapter)
|
||||
{
|
||||
SetHwReg8188EU(padapter, HW_VAR_FIFO_CLEARN_UP, NULL);
|
||||
rtw_fifo_cleanup(padapter);
|
||||
|
||||
if (padapter->intf_stop)
|
||||
padapter->intf_stop(padapter);
|
||||
|
@ -42,22 +42,6 @@ Otherwise, there will be racing condition.
|
||||
Caller must check if the list is empty before calling rtw_list_delete
|
||||
*/
|
||||
|
||||
inline u32 rtw_systime_to_ms(u32 systime)
|
||||
{
|
||||
return systime * 1000 / HZ;
|
||||
}
|
||||
|
||||
inline u32 rtw_ms_to_systime(u32 ms)
|
||||
{
|
||||
return ms * HZ / 1000;
|
||||
}
|
||||
|
||||
/* the input parameter start use the same unit as jiffies */
|
||||
inline s32 rtw_get_passing_time_ms(u32 start)
|
||||
{
|
||||
return rtw_systime_to_ms(jiffies - start);
|
||||
}
|
||||
|
||||
void rtw_usleep_os(int us)
|
||||
{
|
||||
if (1 < (us / 1000))
|
||||
@ -116,19 +100,10 @@ void rtw_free_netdev(struct net_device *netdev)
|
||||
{
|
||||
struct rtw_netdev_priv_indicator *pnpi;
|
||||
|
||||
if (!netdev)
|
||||
goto RETURN;
|
||||
|
||||
pnpi = netdev_priv(netdev);
|
||||
|
||||
if (!pnpi->priv)
|
||||
goto RETURN;
|
||||
|
||||
vfree(pnpi->priv);
|
||||
free_netdev(netdev);
|
||||
|
||||
RETURN:
|
||||
return;
|
||||
}
|
||||
|
||||
int rtw_change_ifname(struct adapter *padapter, const char *ifname)
|
||||
@ -220,7 +195,7 @@ void rtw_buf_update(u8 **buf, u32 *buf_len, u8 *src, u32 src_len)
|
||||
*/
|
||||
inline bool rtw_cbuf_empty(struct rtw_cbuf *cbuf)
|
||||
{
|
||||
return (cbuf->write == cbuf->read) ? true : false;
|
||||
return cbuf->write == cbuf->read;
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -8,7 +8,6 @@
|
||||
#include "../include/xmit_osdep.h"
|
||||
#include "../include/hal_intf.h"
|
||||
#include "../include/osdep_intf.h"
|
||||
#include "../include/usb_vendor_req.h"
|
||||
#include "../include/usb_ops.h"
|
||||
#include "../include/usb_osintf.h"
|
||||
#include "../include/rtw_ioctl.h"
|
||||
@ -200,8 +199,6 @@ static int rtw_suspend(struct usb_interface *pusb_intf, pm_message_t message)
|
||||
struct mlme_priv *pmlmepriv = &padapter->mlmepriv;
|
||||
struct pwrctrl_priv *pwrpriv = &padapter->pwrctrlpriv;
|
||||
|
||||
int ret = 0;
|
||||
|
||||
if ((!padapter->bup) || (padapter->bDriverStopped) ||
|
||||
(padapter->bSurpriseRemoved))
|
||||
goto exit;
|
||||
@ -240,7 +237,7 @@ static int rtw_suspend(struct usb_interface *pusb_intf, pm_message_t message)
|
||||
rtw_indicate_disconnect(padapter);
|
||||
|
||||
exit:
|
||||
return ret;
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int rtw_resume(struct usb_interface *pusb_intf)
|
||||
|
@ -106,8 +106,7 @@ u32 rtw_write_port(struct adapter *padapter, u32 addr, u32 cnt, u8 *wmem)
|
||||
struct xmit_frame *pxmitframe = (struct xmit_frame *)pxmitbuf->priv_data;
|
||||
struct usb_device *pusbd = pdvobj->pusbdev;
|
||||
|
||||
if ((padapter->bDriverStopped) || (padapter->bSurpriseRemoved) ||
|
||||
(padapter->pwrctrlpriv.pnp_bstop_trx)) {
|
||||
if (padapter->bDriverStopped || padapter->bSurpriseRemoved) {
|
||||
rtw_sctx_done_err(&pxmitbuf->sctx, RTW_SCTX_DONE_TX_DENY);
|
||||
goto exit;
|
||||
}
|
||||
@ -141,7 +140,7 @@ u32 rtw_write_port(struct adapter *padapter, u32 addr, u32 cnt, u8 *wmem)
|
||||
|
||||
spin_unlock_irqrestore(&pxmitpriv->lock, irqL);
|
||||
|
||||
purb = pxmitbuf->pxmit_urb[0];
|
||||
purb = pxmitbuf->pxmit_urb;
|
||||
|
||||
/* translate DMA FIFO addr to pipehandle */
|
||||
pipe = ffaddr2pipehdl(pdvobj, addr);
|
||||
@ -179,25 +178,21 @@ u32 rtw_write_port(struct adapter *padapter, u32 addr, u32 cnt, u8 *wmem)
|
||||
|
||||
void rtw_write_port_cancel(struct adapter *padapter)
|
||||
{
|
||||
int i, j;
|
||||
int i;
|
||||
struct xmit_buf *pxmitbuf = (struct xmit_buf *)padapter->xmitpriv.pxmitbuf;
|
||||
|
||||
padapter->bWritePortCancel = true;
|
||||
|
||||
for (i = 0; i < NR_XMITBUFF; i++) {
|
||||
for (j = 0; j < 8; j++) {
|
||||
if (pxmitbuf->pxmit_urb[j])
|
||||
usb_kill_urb(pxmitbuf->pxmit_urb[j]);
|
||||
}
|
||||
if (pxmitbuf->pxmit_urb)
|
||||
usb_kill_urb(pxmitbuf->pxmit_urb);
|
||||
pxmitbuf++;
|
||||
}
|
||||
|
||||
pxmitbuf = (struct xmit_buf *)padapter->xmitpriv.pxmit_extbuf;
|
||||
for (i = 0; i < NR_XMIT_EXTBUFF; i++) {
|
||||
for (j = 0; j < 8; j++) {
|
||||
if (pxmitbuf->pxmit_urb[j])
|
||||
usb_kill_urb(pxmitbuf->pxmit_urb[j]);
|
||||
}
|
||||
if (pxmitbuf->pxmit_urb)
|
||||
usb_kill_urb(pxmitbuf->pxmit_urb);
|
||||
pxmitbuf++;
|
||||
}
|
||||
}
|
||||
|
@ -67,8 +67,6 @@ bool rtw_endofpktfile(struct pkt_file *pfile)
|
||||
|
||||
int rtw_os_xmit_resource_alloc(struct adapter *padapter, struct xmit_buf *pxmitbuf, u32 alloc_sz)
|
||||
{
|
||||
int i;
|
||||
|
||||
pxmitbuf->pallocated_buf = kzalloc(alloc_sz, GFP_KERNEL);
|
||||
if (!pxmitbuf->pallocated_buf)
|
||||
return _FAIL;
|
||||
@ -76,21 +74,17 @@ int rtw_os_xmit_resource_alloc(struct adapter *padapter, struct xmit_buf *pxmitb
|
||||
pxmitbuf->pbuf = (u8 *)N_BYTE_ALIGMENT((size_t)(pxmitbuf->pallocated_buf), XMITBUF_ALIGN_SZ);
|
||||
pxmitbuf->dma_transfer_addr = 0;
|
||||
|
||||
for (i = 0; i < 8; i++) {
|
||||
pxmitbuf->pxmit_urb[i] = usb_alloc_urb(0, GFP_KERNEL);
|
||||
if (!pxmitbuf->pxmit_urb[i])
|
||||
return _FAIL;
|
||||
}
|
||||
pxmitbuf->pxmit_urb = usb_alloc_urb(0, GFP_KERNEL);
|
||||
if (!pxmitbuf->pxmit_urb)
|
||||
return _FAIL;
|
||||
|
||||
return _SUCCESS;
|
||||
}
|
||||
|
||||
void rtw_os_xmit_resource_free(struct adapter *padapter,
|
||||
struct xmit_buf *pxmitbuf, u32 free_sz)
|
||||
{
|
||||
int i;
|
||||
|
||||
for (i = 0; i < 8; i++)
|
||||
usb_free_urb(pxmitbuf->pxmit_urb[i]);
|
||||
usb_free_urb(pxmitbuf->pxmit_urb);
|
||||
|
||||
kfree(pxmitbuf->pallocated_buf);
|
||||
}
|
||||
|
@ -185,10 +185,10 @@ void rtl92e_set_ofdm_tx_power(struct net_device *dev, u8 powerlevel)
|
||||
for (index = 0; index < 6; index++) {
|
||||
writeVal = (u32)(priv->MCSTxPowerLevelOriginalOffset[index] +
|
||||
((index < 2) ? powerBase0 : powerBase1));
|
||||
byte0 = (u8)(writeVal & 0x7f);
|
||||
byte1 = (u8)((writeVal & 0x7f00)>>8);
|
||||
byte2 = (u8)((writeVal & 0x7f0000)>>16);
|
||||
byte3 = (u8)((writeVal & 0x7f000000)>>24);
|
||||
byte0 = writeVal & 0x7f;
|
||||
byte1 = (writeVal & 0x7f00) >> 8;
|
||||
byte2 = (writeVal & 0x7f0000) >> 16;
|
||||
byte3 = (writeVal & 0x7f000000) >> 24;
|
||||
if (byte0 > 0x24)
|
||||
byte0 = 0x24;
|
||||
if (byte1 > 0x24)
|
||||
|
@ -58,7 +58,7 @@ bool rtl92e_send_cmd_pkt(struct net_device *dev, u32 type, const void *data,
|
||||
memset(pTxFwInfo, 0, sizeof(struct tx_fwinfo_8190pci));
|
||||
memset(pTxFwInfo, 0x12, 8);
|
||||
} else {
|
||||
tcb_desc->txbuf_size = (u16)frag_length;
|
||||
tcb_desc->txbuf_size = frag_length;
|
||||
}
|
||||
|
||||
seg_ptr = skb_put(skb, frag_length);
|
||||
|
@ -221,7 +221,7 @@ void rtl92e_set_reg(struct net_device *dev, u8 variable, u8 *val)
|
||||
&priv->rtllib->current_network.qos_data.parameters;
|
||||
u8 pAcParam = *val;
|
||||
u32 eACI = pAcParam;
|
||||
union aci_aifsn *pAciAifsn = (union aci_aifsn *) &
|
||||
union aci_aifsn *pAciAifsn = (union aci_aifsn *)&
|
||||
(qos_parameters->aifs[0]);
|
||||
u8 acm = pAciAifsn->f.acm;
|
||||
u8 AcmCtrl = rtl92e_readb(dev, AcmHwCtrl);
|
||||
@ -320,8 +320,8 @@ static void _rtl92e_read_eeprom_info(struct net_device *dev)
|
||||
priv->eeprom_did = rtl92e_eeprom_read(dev, EEPROM_DID >> 1);
|
||||
|
||||
usValue = rtl92e_eeprom_read(dev,
|
||||
(u16)(EEPROM_Customer_ID>>1)) >> 8;
|
||||
priv->eeprom_CustomerID = (u8)(usValue & 0xff);
|
||||
(EEPROM_Customer_ID >> 1)) >> 8;
|
||||
priv->eeprom_CustomerID = usValue & 0xff;
|
||||
usValue = rtl92e_eeprom_read(dev,
|
||||
EEPROM_ICVersion_ChannelPlan>>1);
|
||||
priv->eeprom_ChannelPlan = usValue&0xff;
|
||||
@ -399,9 +399,9 @@ static void _rtl92e_read_eeprom_info(struct net_device *dev)
|
||||
priv->EEPROMLegacyHTTxPowerDiff);
|
||||
|
||||
if (!priv->AutoloadFailFlag)
|
||||
priv->EEPROMThermalMeter = (u8)(((rtl92e_eeprom_read(dev,
|
||||
priv->EEPROMThermalMeter = ((rtl92e_eeprom_read(dev,
|
||||
(EEPROM_ThermalMeter>>1))) &
|
||||
0xff00)>>8);
|
||||
0xff00) >> 8;
|
||||
else
|
||||
priv->EEPROMThermalMeter = EEPROM_Default_ThermalMeter;
|
||||
RT_TRACE(COMP_INIT, "ThermalMeter = %d\n",
|
||||
@ -413,8 +413,8 @@ static void _rtl92e_read_eeprom_info(struct net_device *dev)
|
||||
usValue = rtl92e_eeprom_read(dev,
|
||||
EEPROM_TxPwDiff_CrystalCap >> 1);
|
||||
priv->EEPROMAntPwDiff = usValue & 0x0fff;
|
||||
priv->EEPROMCrystalCap = (u8)((usValue & 0xf000)
|
||||
>> 12);
|
||||
priv->EEPROMCrystalCap = (usValue & 0xf000)
|
||||
>> 12;
|
||||
} else {
|
||||
priv->EEPROMAntPwDiff =
|
||||
EEPROM_Default_AntTxPowerDiff;
|
||||
@ -811,7 +811,7 @@ bool rtl92e_start_adapter(struct net_device *dev)
|
||||
|
||||
rtl92e_config_mac(dev);
|
||||
|
||||
if (priv->card_8192_version > (u8) VERSION_8190_BD) {
|
||||
if (priv->card_8192_version > VERSION_8190_BD) {
|
||||
rtl92e_get_tx_power(dev);
|
||||
rtl92e_set_tx_power(dev, priv->chan);
|
||||
}
|
||||
@ -894,9 +894,8 @@ bool rtl92e_start_adapter(struct net_device *dev)
|
||||
|
||||
for (i = 0; i < TxBBGainTableLength; i++) {
|
||||
if (tmpRegA == dm_tx_bb_gain[i]) {
|
||||
priv->rfa_txpowertrackingindex = (u8)i;
|
||||
priv->rfa_txpowertrackingindex_real =
|
||||
(u8)i;
|
||||
priv->rfa_txpowertrackingindex = i;
|
||||
priv->rfa_txpowertrackingindex_real = i;
|
||||
priv->rfa_txpowertracking_default =
|
||||
priv->rfa_txpowertrackingindex;
|
||||
break;
|
||||
@ -908,7 +907,7 @@ bool rtl92e_start_adapter(struct net_device *dev)
|
||||
|
||||
for (i = 0; i < CCKTxBBGainTableLength; i++) {
|
||||
if (TempCCk == dm_cck_tx_bb_gain[i][0]) {
|
||||
priv->CCKPresentAttentuation_20Mdefault = (u8)i;
|
||||
priv->CCKPresentAttentuation_20Mdefault = i;
|
||||
break;
|
||||
}
|
||||
}
|
||||
@ -1176,7 +1175,7 @@ void rtl92e_fill_tx_desc(struct net_device *dev, struct tx_desc *pdesc,
|
||||
pTxFwInfo = (struct tx_fwinfo_8190pci *)skb->data;
|
||||
memset(pTxFwInfo, 0, sizeof(struct tx_fwinfo_8190pci));
|
||||
pTxFwInfo->TxHT = (cb_desc->data_rate & 0x80) ? 1 : 0;
|
||||
pTxFwInfo->TxRate = _rtl92e_rate_mgn_to_hw((u8)cb_desc->data_rate);
|
||||
pTxFwInfo->TxRate = _rtl92e_rate_mgn_to_hw(cb_desc->data_rate);
|
||||
pTxFwInfo->EnableCPUDur = cb_desc->bTxEnableFwCalcDur;
|
||||
pTxFwInfo->Short = _rtl92e_query_is_short(pTxFwInfo->TxHT,
|
||||
pTxFwInfo->TxRate, cb_desc);
|
||||
@ -1195,7 +1194,7 @@ void rtl92e_fill_tx_desc(struct net_device *dev, struct tx_desc *pdesc,
|
||||
pTxFwInfo->CtsEnable = (cb_desc->bCTSEnable) ? 1 : 0;
|
||||
pTxFwInfo->RtsSTBC = (cb_desc->bRTSSTBC) ? 1 : 0;
|
||||
pTxFwInfo->RtsHT = (cb_desc->rts_rate&0x80) ? 1 : 0;
|
||||
pTxFwInfo->RtsRate = _rtl92e_rate_mgn_to_hw((u8)cb_desc->rts_rate);
|
||||
pTxFwInfo->RtsRate = _rtl92e_rate_mgn_to_hw(cb_desc->rts_rate);
|
||||
pTxFwInfo->RtsBandwidth = 0;
|
||||
pTxFwInfo->RtsSubcarrier = cb_desc->RTSSC;
|
||||
pTxFwInfo->RtsShort = (pTxFwInfo->RtsHT == 0) ?
|
||||
@ -1226,7 +1225,7 @@ void rtl92e_fill_tx_desc(struct net_device *dev, struct tx_desc *pdesc,
|
||||
pdesc->LINIP = 0;
|
||||
pdesc->CmdInit = 1;
|
||||
pdesc->Offset = sizeof(struct tx_fwinfo_8190pci) + 8;
|
||||
pdesc->PktSize = (u16)skb->len-sizeof(struct tx_fwinfo_8190pci);
|
||||
pdesc->PktSize = skb->len - sizeof(struct tx_fwinfo_8190pci);
|
||||
|
||||
pdesc->SecCAMID = 0;
|
||||
pdesc->RATid = cb_desc->RATRIndex;
|
||||
@ -1299,11 +1298,10 @@ void rtl92e_fill_tx_cmd_desc(struct net_device *dev, struct tx_desc_cmd *entry,
|
||||
|
||||
entry_tmp->CmdInit = DESC_PACKET_TYPE_NORMAL;
|
||||
entry_tmp->Offset = sizeof(struct tx_fwinfo_8190pci) + 8;
|
||||
entry_tmp->PktSize = (u16)(cb_desc->pkt_size +
|
||||
entry_tmp->Offset);
|
||||
entry_tmp->PktSize = cb_desc->pkt_size + entry_tmp->Offset;
|
||||
entry_tmp->QueueSelect = QSLT_CMD;
|
||||
entry_tmp->TxFWInfoSize = 0x08;
|
||||
entry_tmp->RATid = (u8)DESC_PACKET_TYPE_INIT;
|
||||
entry_tmp->RATid = DESC_PACKET_TYPE_INIT;
|
||||
}
|
||||
entry->TxBufferSize = skb->len;
|
||||
entry->TxBuffAddr = mapping;
|
||||
@ -1613,9 +1611,8 @@ static void _rtl92e_query_rxphystatus(
|
||||
total_rssi += RSSI;
|
||||
|
||||
if (bpacket_match_bssid) {
|
||||
pstats->RxMIMOSignalStrength[i] = (u8) RSSI;
|
||||
precord_stats->RxMIMOSignalStrength[i] =
|
||||
(u8) RSSI;
|
||||
pstats->RxMIMOSignalStrength[i] = RSSI;
|
||||
precord_stats->RxMIMOSignalStrength[i] = RSSI;
|
||||
}
|
||||
}
|
||||
|
||||
@ -1661,14 +1658,14 @@ static void _rtl92e_query_rxphystatus(
|
||||
|
||||
if (is_cck_rate) {
|
||||
pstats->SignalStrength = precord_stats->SignalStrength =
|
||||
(u8)(_rtl92e_signal_scale_mapping(priv,
|
||||
(long)pwdb_all));
|
||||
_rtl92e_signal_scale_mapping(priv,
|
||||
(long)pwdb_all);
|
||||
|
||||
} else {
|
||||
if (rf_rx_num != 0)
|
||||
pstats->SignalStrength = precord_stats->SignalStrength =
|
||||
(u8)(_rtl92e_signal_scale_mapping(priv,
|
||||
(long)(total_rssi /= rf_rx_num)));
|
||||
_rtl92e_signal_scale_mapping(priv,
|
||||
(long)(total_rssi /= rf_rx_num));
|
||||
}
|
||||
}
|
||||
|
||||
@ -1709,8 +1706,7 @@ static void _rtl92e_process_phyinfo(struct r8192_priv *priv, u8 *buffer,
|
||||
slide_rssi_index = 0;
|
||||
|
||||
tmp_val = priv->stats.slide_rssi_total/slide_rssi_statistics;
|
||||
priv->stats.signal_strength = rtl92e_translate_to_dbm(priv,
|
||||
(u8)tmp_val);
|
||||
priv->stats.signal_strength = rtl92e_translate_to_dbm(priv, tmp_val);
|
||||
curr_st->rssi = priv->stats.signal_strength;
|
||||
if (!prev_st->bPacketMatchBSSID) {
|
||||
if (!prev_st->bToSelfBA)
|
||||
@ -2036,7 +2032,7 @@ bool rtl92e_get_rx_stats(struct net_device *dev, struct rtllib_rx_stats *stats,
|
||||
pDrvInfo = (struct rx_fwinfo *)(skb->data + stats->RxBufShift);
|
||||
|
||||
stats->rate = _rtl92e_rate_hw_to_mgn((bool)pDrvInfo->RxHT,
|
||||
(u8)pDrvInfo->RxRate);
|
||||
pDrvInfo->RxRate);
|
||||
stats->bShortPreamble = pDrvInfo->SPLCP;
|
||||
|
||||
_rtl92e_update_received_rate_histogram_stats(dev, stats);
|
||||
|
@ -34,8 +34,7 @@ static bool _rtl92e_fw_boot_cpu(struct net_device *dev)
|
||||
netdev_dbg(dev, "Download Firmware: Put code ok!\n");
|
||||
|
||||
CPU_status = rtl92e_readl(dev, CPU_GEN);
|
||||
rtl92e_writeb(dev, CPU_GEN,
|
||||
(u8)((CPU_status|CPU_GEN_PWR_STB_CPU)&0xff));
|
||||
rtl92e_writeb(dev, CPU_GEN, (CPU_status | CPU_GEN_PWR_STB_CPU) & 0xff);
|
||||
mdelay(1);
|
||||
|
||||
if (!_rtl92e_wait_for_fw(dev, CPU_GEN_BOOT_RDY, 200)) {
|
||||
|
@ -919,7 +919,7 @@ static u8 _rtl92e_phy_switch_channel_step(struct net_device *dev, u8 channel,
|
||||
continue;
|
||||
switch (CurrentCmd->CmdID) {
|
||||
case CmdID_SetTxPowerLevel:
|
||||
if (priv->IC_Cut > (u8)VERSION_8190_BD)
|
||||
if (priv->IC_Cut > VERSION_8190_BD)
|
||||
_rtl92e_set_tx_power_level(dev,
|
||||
channel);
|
||||
break;
|
||||
@ -929,11 +929,11 @@ static u8 _rtl92e_phy_switch_channel_step(struct net_device *dev, u8 channel,
|
||||
break;
|
||||
case CmdID_WritePortUshort:
|
||||
rtl92e_writew(dev, CurrentCmd->Para1,
|
||||
(u16)CurrentCmd->Para2);
|
||||
CurrentCmd->Para2);
|
||||
break;
|
||||
case CmdID_WritePortUchar:
|
||||
rtl92e_writeb(dev, CurrentCmd->Para1,
|
||||
(u8)CurrentCmd->Para2);
|
||||
CurrentCmd->Para2);
|
||||
break;
|
||||
case CmdID_RF_WriteReg:
|
||||
for (eRFPath = 0; eRFPath <
|
||||
@ -1299,17 +1299,17 @@ void rtl92e_init_gain(struct net_device *dev, u8 Operation)
|
||||
DIG_ALGO_BY_FALSE_ALARM)
|
||||
rtl92e_set_bb_reg(dev, UFWP, bMaskByte1, 0x8);
|
||||
priv->initgain_backup.xaagccore1 =
|
||||
(u8)rtl92e_get_bb_reg(dev, rOFDM0_XAAGCCore1,
|
||||
BitMask);
|
||||
rtl92e_get_bb_reg(dev, rOFDM0_XAAGCCore1,
|
||||
BitMask);
|
||||
priv->initgain_backup.xbagccore1 =
|
||||
(u8)rtl92e_get_bb_reg(dev, rOFDM0_XBAGCCore1,
|
||||
BitMask);
|
||||
rtl92e_get_bb_reg(dev, rOFDM0_XBAGCCore1,
|
||||
BitMask);
|
||||
priv->initgain_backup.xcagccore1 =
|
||||
(u8)rtl92e_get_bb_reg(dev, rOFDM0_XCAGCCore1,
|
||||
BitMask);
|
||||
rtl92e_get_bb_reg(dev, rOFDM0_XCAGCCore1,
|
||||
BitMask);
|
||||
priv->initgain_backup.xdagccore1 =
|
||||
(u8)rtl92e_get_bb_reg(dev, rOFDM0_XDAGCCore1,
|
||||
BitMask);
|
||||
rtl92e_get_bb_reg(dev, rOFDM0_XDAGCCore1,
|
||||
BitMask);
|
||||
BitMask = bMaskByte2;
|
||||
priv->initgain_backup.cca = (u8)rtl92e_get_bb_reg(dev,
|
||||
rCCK0_CCA, BitMask);
|
||||
|
@ -633,7 +633,7 @@ static void _rtl92e_dm_tx_power_tracking_callback_tssi(struct net_device *dev)
|
||||
rtl92e_writeb(dev, FW_Busy_Flag, 0);
|
||||
priv->rtllib->bdynamic_txpower_enable = false;
|
||||
|
||||
powerlevelOFDM24G = (u8)(priv->Pwr_Track>>24);
|
||||
powerlevelOFDM24G = priv->Pwr_Track >> 24;
|
||||
RF_Type = priv->rf_type;
|
||||
Value = (RF_Type<<8) | powerlevelOFDM24G;
|
||||
|
||||
@ -833,7 +833,7 @@ static void _rtl92e_dm_tx_power_tracking_cb_thermal(struct net_device *dev)
|
||||
bMaskDWord);
|
||||
for (i = 0; i < OFDM_Table_Length; i++) {
|
||||
if (tmpRegA == OFDMSwingTable[i]) {
|
||||
priv->OFDM_index[0] = (u8)i;
|
||||
priv->OFDM_index[0] = i;
|
||||
RT_TRACE(COMP_POWER_TRACKING,
|
||||
"Initial reg0x%x = 0x%x, OFDM_index = 0x%x\n",
|
||||
rOFDM0_XATxIQImbalance, tmpRegA,
|
||||
@ -844,7 +844,7 @@ static void _rtl92e_dm_tx_power_tracking_cb_thermal(struct net_device *dev)
|
||||
TempCCk = rtl92e_get_bb_reg(dev, rCCK0_TxFilter1, bMaskByte2);
|
||||
for (i = 0; i < CCK_Table_length; i++) {
|
||||
if (TempCCk == (u32)CCKSwingTable_Ch1_Ch13[i][0]) {
|
||||
priv->CCK_index = (u8) i;
|
||||
priv->CCK_index = i;
|
||||
RT_TRACE(COMP_POWER_TRACKING,
|
||||
"Initial reg0x%x = 0x%x, CCK_index = 0x%x\n",
|
||||
rCCK0_TxFilter1, TempCCk,
|
||||
@ -1041,7 +1041,7 @@ static void _rtl92e_dm_cck_tx_power_adjust_tssi(struct net_device *dev,
|
||||
{
|
||||
u32 TempVal;
|
||||
struct r8192_priv *priv = rtllib_priv(dev);
|
||||
u8 attenuation = (u8)priv->CCKPresentAttentuation;
|
||||
u8 attenuation = priv->CCKPresentAttentuation;
|
||||
|
||||
TempVal = 0;
|
||||
if (!bInCH14) {
|
||||
@ -1245,10 +1245,10 @@ void rtl92e_dm_backup_state(struct net_device *dev)
|
||||
return;
|
||||
|
||||
rtl92e_set_bb_reg(dev, UFWP, bMaskByte1, 0x8);
|
||||
priv->initgain_backup.xaagccore1 = (u8)rtl92e_get_bb_reg(dev, rOFDM0_XAAGCCore1, bit_mask);
|
||||
priv->initgain_backup.xbagccore1 = (u8)rtl92e_get_bb_reg(dev, rOFDM0_XBAGCCore1, bit_mask);
|
||||
priv->initgain_backup.xcagccore1 = (u8)rtl92e_get_bb_reg(dev, rOFDM0_XCAGCCore1, bit_mask);
|
||||
priv->initgain_backup.xdagccore1 = (u8)rtl92e_get_bb_reg(dev, rOFDM0_XDAGCCore1, bit_mask);
|
||||
priv->initgain_backup.xaagccore1 = rtl92e_get_bb_reg(dev, rOFDM0_XAAGCCore1, bit_mask);
|
||||
priv->initgain_backup.xbagccore1 = rtl92e_get_bb_reg(dev, rOFDM0_XBAGCCore1, bit_mask);
|
||||
priv->initgain_backup.xcagccore1 = rtl92e_get_bb_reg(dev, rOFDM0_XCAGCCore1, bit_mask);
|
||||
priv->initgain_backup.xdagccore1 = rtl92e_get_bb_reg(dev, rOFDM0_XDAGCCore1, bit_mask);
|
||||
bit_mask = bMaskByte2;
|
||||
priv->initgain_backup.cca = (u8)rtl92e_get_bb_reg(dev, rCCK0_CCA, bit_mask);
|
||||
|
||||
@ -1535,7 +1535,7 @@ static void _rtl92e_dm_initial_gain(struct net_device *dev)
|
||||
|
||||
if ((dm_digtable.pre_ig_value != dm_digtable.cur_ig_value)
|
||||
|| !initialized || force_write) {
|
||||
initial_gain = (u8)dm_digtable.cur_ig_value;
|
||||
initial_gain = dm_digtable.cur_ig_value;
|
||||
rtl92e_writeb(dev, rOFDM0_XAAGCCore1, initial_gain);
|
||||
rtl92e_writeb(dev, rOFDM0_XBAGCCore1, initial_gain);
|
||||
rtl92e_writeb(dev, rOFDM0_XCAGCCore1, initial_gain);
|
||||
@ -2513,5 +2513,5 @@ static void _rtl92e_dm_send_rssi_to_fw(struct net_device *dev)
|
||||
{
|
||||
struct r8192_priv *priv = rtllib_priv(dev);
|
||||
|
||||
rtl92e_writeb(dev, DRIVER_RSSI, (u8)priv->undecorated_smoothed_pwdb);
|
||||
rtl92e_writeb(dev, DRIVER_RSSI, priv->undecorated_smoothed_pwdb);
|
||||
}
|
||||
|
@ -238,7 +238,7 @@ int rtllib_rx_ADDBAReq(struct rtllib_device *ieee, struct sk_buff *skb)
|
||||
skb->data, skb->len);
|
||||
#endif
|
||||
|
||||
req = (struct rtllib_hdr_3addr *) skb->data;
|
||||
req = (struct rtllib_hdr_3addr *)skb->data;
|
||||
tag = (u8 *)req;
|
||||
dst = (u8 *)(&req->addr2[0]);
|
||||
tag += sizeof(struct rtllib_hdr_3addr);
|
||||
@ -343,7 +343,6 @@ int rtllib_rx_ADDBARsp(struct rtllib_device *ieee, struct sk_buff *skb)
|
||||
goto OnADDBARsp_Reject;
|
||||
}
|
||||
|
||||
|
||||
if (!GetTs(ieee, (struct ts_common_info **)(&pTS), dst,
|
||||
(u8)(pBaParamSet->field.tid), TX_DIR, false)) {
|
||||
netdev_warn(ieee->dev, "%s(): can't get TS\n", __func__);
|
||||
@ -355,7 +354,6 @@ int rtllib_rx_ADDBARsp(struct rtllib_device *ieee, struct sk_buff *skb)
|
||||
pPendingBA = &pTS->TxPendingBARecord;
|
||||
pAdmittedBA = &pTS->TxAdmittedBARecord;
|
||||
|
||||
|
||||
if (pAdmittedBA->b_valid) {
|
||||
netdev_dbg(ieee->dev, "%s(): ADDBA response already admitted\n",
|
||||
__func__);
|
||||
@ -374,7 +372,6 @@ int rtllib_rx_ADDBARsp(struct rtllib_device *ieee, struct sk_buff *skb)
|
||||
DeActivateBAEntry(ieee, pPendingBA);
|
||||
}
|
||||
|
||||
|
||||
if (*pStatusCode == ADDBA_STATUS_SUCCESS) {
|
||||
if (pBaParamSet->field.ba_policy == BA_POLICY_DELAYED) {
|
||||
pTS->bAddBaReqDelayed = true;
|
||||
|
@ -1585,7 +1585,7 @@ struct rtllib_device {
|
||||
short sta_sleep;
|
||||
int ps_timeout;
|
||||
int ps_period;
|
||||
struct tasklet_struct ps_task;
|
||||
struct work_struct ps_task;
|
||||
u64 ps_time;
|
||||
bool polling;
|
||||
|
||||
|
@ -103,7 +103,7 @@ static int ccmp_init_iv_and_aad(struct rtllib_hdr_4addr *hdr,
|
||||
if (a4_included)
|
||||
aad_len += 6;
|
||||
if (qc_included) {
|
||||
pos = (u8 *) &hdr->addr4;
|
||||
pos = (u8 *)&hdr->addr4;
|
||||
if (a4_included)
|
||||
pos += 6;
|
||||
qc = *pos & 0x0f;
|
||||
@ -130,13 +130,13 @@ static int ccmp_init_iv_and_aad(struct rtllib_hdr_4addr *hdr,
|
||||
* A4 (if present)
|
||||
* QC (if present)
|
||||
*/
|
||||
pos = (u8 *) hdr;
|
||||
pos = (u8 *)hdr;
|
||||
aad[0] = pos[0] & 0x8f;
|
||||
aad[1] = pos[1] & 0xc7;
|
||||
memcpy(&aad[2], &hdr->addr1, ETH_ALEN);
|
||||
memcpy(&aad[8], &hdr->addr2, ETH_ALEN);
|
||||
memcpy(&aad[14], &hdr->addr3, ETH_ALEN);
|
||||
pos = (u8 *) &hdr->seq_ctl;
|
||||
pos = (u8 *)&hdr->seq_ctl;
|
||||
aad[20] = pos[0] & 0x0f;
|
||||
aad[21] = 0; /* all bits masked */
|
||||
memset(aad + 22, 0, 8);
|
||||
@ -186,7 +186,7 @@ static int rtllib_ccmp_encrypt(struct sk_buff *skb, int hdr_len, void *priv)
|
||||
*pos++ = key->tx_pn[1];
|
||||
*pos++ = key->tx_pn[0];
|
||||
|
||||
hdr = (struct rtllib_hdr_4addr *) skb->data;
|
||||
hdr = (struct rtllib_hdr_4addr *)skb->data;
|
||||
if (!tcb_desc->bHwSec) {
|
||||
struct aead_request *req;
|
||||
struct scatterlist sg[2];
|
||||
@ -235,7 +235,7 @@ static int rtllib_ccmp_decrypt(struct sk_buff *skb, int hdr_len, void *priv)
|
||||
return -1;
|
||||
}
|
||||
|
||||
hdr = (struct rtllib_hdr_4addr *) skb->data;
|
||||
hdr = (struct rtllib_hdr_4addr *)skb->data;
|
||||
pos = skb->data + hdr_len;
|
||||
keyidx = pos[3];
|
||||
if (!(keyidx & (1 << 5))) {
|
||||
|
@ -136,7 +136,7 @@ static inline u16 Hi16(u32 val)
|
||||
|
||||
static inline u16 Mk16(u8 hi, u8 lo)
|
||||
{
|
||||
return lo | (((u16) hi) << 8);
|
||||
return lo | (hi << 8);
|
||||
}
|
||||
|
||||
|
||||
@ -220,7 +220,7 @@ static void tkip_mixing_phase2(u8 *WEPSeed, const u8 *TK, const u16 *TTAK,
|
||||
/* Make temporary area overlap WEP seed so that the final copy can be
|
||||
* avoided on little endian hosts.
|
||||
*/
|
||||
u16 *PPK = (u16 *) &WEPSeed[4];
|
||||
u16 *PPK = (u16 *)&WEPSeed[4];
|
||||
|
||||
/* Step 1 - make copy of TTAK and bring in TSC */
|
||||
PPK[0] = TTAK[0];
|
||||
@ -231,15 +231,15 @@ static void tkip_mixing_phase2(u8 *WEPSeed, const u8 *TK, const u16 *TTAK,
|
||||
PPK[5] = TTAK[4] + IV16;
|
||||
|
||||
/* Step 2 - 96-bit bijective mixing using S-box */
|
||||
PPK[0] += _S_(PPK[5] ^ Mk16_le((u16 *) &TK[0]));
|
||||
PPK[1] += _S_(PPK[0] ^ Mk16_le((u16 *) &TK[2]));
|
||||
PPK[2] += _S_(PPK[1] ^ Mk16_le((u16 *) &TK[4]));
|
||||
PPK[3] += _S_(PPK[2] ^ Mk16_le((u16 *) &TK[6]));
|
||||
PPK[4] += _S_(PPK[3] ^ Mk16_le((u16 *) &TK[8]));
|
||||
PPK[5] += _S_(PPK[4] ^ Mk16_le((u16 *) &TK[10]));
|
||||
PPK[0] += _S_(PPK[5] ^ Mk16_le((u16 *)&TK[0]));
|
||||
PPK[1] += _S_(PPK[0] ^ Mk16_le((u16 *)&TK[2]));
|
||||
PPK[2] += _S_(PPK[1] ^ Mk16_le((u16 *)&TK[4]));
|
||||
PPK[3] += _S_(PPK[2] ^ Mk16_le((u16 *)&TK[6]));
|
||||
PPK[4] += _S_(PPK[3] ^ Mk16_le((u16 *)&TK[8]));
|
||||
PPK[5] += _S_(PPK[4] ^ Mk16_le((u16 *)&TK[10]));
|
||||
|
||||
PPK[0] += RotR1(PPK[5] ^ Mk16_le((u16 *) &TK[12]));
|
||||
PPK[1] += RotR1(PPK[0] ^ Mk16_le((u16 *) &TK[14]));
|
||||
PPK[0] += RotR1(PPK[5] ^ Mk16_le((u16 *)&TK[12]));
|
||||
PPK[1] += RotR1(PPK[0] ^ Mk16_le((u16 *)&TK[14]));
|
||||
PPK[2] += RotR1(PPK[1]);
|
||||
PPK[3] += RotR1(PPK[2]);
|
||||
PPK[4] += RotR1(PPK[3]);
|
||||
@ -251,7 +251,7 @@ static void tkip_mixing_phase2(u8 *WEPSeed, const u8 *TK, const u16 *TTAK,
|
||||
WEPSeed[0] = Hi8(IV16);
|
||||
WEPSeed[1] = (Hi8(IV16) | 0x20) & 0x7F;
|
||||
WEPSeed[2] = Lo8(IV16);
|
||||
WEPSeed[3] = Lo8((PPK[5] ^ Mk16_le((u16 *) &TK[0])) >> 1);
|
||||
WEPSeed[3] = Lo8((PPK[5] ^ Mk16_le((u16 *)&TK[0])) >> 1);
|
||||
|
||||
#ifdef __BIG_ENDIAN
|
||||
{
|
||||
@ -280,7 +280,7 @@ static int rtllib_tkip_encrypt(struct sk_buff *skb, int hdr_len, void *priv)
|
||||
skb->len < hdr_len)
|
||||
return -1;
|
||||
|
||||
hdr = (struct rtllib_hdr_4addr *) skb->data;
|
||||
hdr = (struct rtllib_hdr_4addr *)skb->data;
|
||||
|
||||
if (!tcb_desc->bHwSec) {
|
||||
if (!tkey->tx_phase1_done) {
|
||||
@ -357,7 +357,7 @@ static int rtllib_tkip_decrypt(struct sk_buff *skb, int hdr_len, void *priv)
|
||||
if (skb->len < hdr_len + 8 + 4)
|
||||
return -1;
|
||||
|
||||
hdr = (struct rtllib_hdr_4addr *) skb->data;
|
||||
hdr = (struct rtllib_hdr_4addr *)skb->data;
|
||||
pos = skb->data + hdr_len;
|
||||
keyidx = pos[3];
|
||||
if (!(keyidx & (1 << 5))) {
|
||||
@ -485,7 +485,7 @@ static void michael_mic_hdr(struct sk_buff *skb, u8 *hdr)
|
||||
{
|
||||
struct rtllib_hdr_4addr *hdr11;
|
||||
|
||||
hdr11 = (struct rtllib_hdr_4addr *) skb->data;
|
||||
hdr11 = (struct rtllib_hdr_4addr *)skb->data;
|
||||
switch (le16_to_cpu(hdr11->frame_ctl) &
|
||||
(RTLLIB_FCTL_FROMDS | RTLLIB_FCTL_TODS)) {
|
||||
case RTLLIB_FCTL_TODS:
|
||||
@ -518,7 +518,7 @@ static int rtllib_michael_mic_add(struct sk_buff *skb, int hdr_len, void *priv)
|
||||
u8 *pos;
|
||||
struct rtllib_hdr_4addr *hdr;
|
||||
|
||||
hdr = (struct rtllib_hdr_4addr *) skb->data;
|
||||
hdr = (struct rtllib_hdr_4addr *)skb->data;
|
||||
|
||||
if (skb_tailroom(skb) < 8 || skb->len < hdr_len) {
|
||||
netdev_dbg(skb->dev,
|
||||
@ -558,7 +558,7 @@ static void rtllib_michael_mic_failure(struct net_device *dev,
|
||||
ether_addr_copy(ev.src_addr.sa_data, hdr->addr2);
|
||||
memset(&wrqu, 0, sizeof(wrqu));
|
||||
wrqu.data.length = sizeof(ev);
|
||||
wireless_send_event(dev, IWEVMICHAELMICFAILURE, &wrqu, (char *) &ev);
|
||||
wireless_send_event(dev, IWEVMICHAELMICFAILURE, &wrqu, (char *)&ev);
|
||||
}
|
||||
|
||||
static int rtllib_michael_mic_verify(struct sk_buff *skb, int keyidx,
|
||||
@ -568,7 +568,7 @@ static int rtllib_michael_mic_verify(struct sk_buff *skb, int keyidx,
|
||||
u8 mic[8];
|
||||
struct rtllib_hdr_4addr *hdr;
|
||||
|
||||
hdr = (struct rtllib_hdr_4addr *) skb->data;
|
||||
hdr = (struct rtllib_hdr_4addr *)skb->data;
|
||||
|
||||
if (!tkey->key_set)
|
||||
return -1;
|
||||
@ -584,7 +584,7 @@ static int rtllib_michael_mic_verify(struct sk_buff *skb, int keyidx,
|
||||
if (memcmp(mic, skb->data + skb->len - 8, 8) != 0) {
|
||||
struct rtllib_hdr_4addr *hdr;
|
||||
|
||||
hdr = (struct rtllib_hdr_4addr *) skb->data;
|
||||
hdr = (struct rtllib_hdr_4addr *)skb->data;
|
||||
netdev_dbg(skb->dev,
|
||||
"Michael MIC verification failed for MSDU from %pM keyidx=%d\n",
|
||||
hdr->addr2, keyidx);
|
||||
|
@ -250,7 +250,7 @@ static int rtllib_is_eapol_frame(struct rtllib_device *ieee,
|
||||
if (skb->len < 24)
|
||||
return 0;
|
||||
|
||||
hdr = (struct rtllib_hdr_4addr *) skb->data;
|
||||
hdr = (struct rtllib_hdr_4addr *)skb->data;
|
||||
fc = le16_to_cpu(hdr->frame_ctl);
|
||||
|
||||
/* check that the frame is unicast frame to us */
|
||||
@ -299,7 +299,7 @@ rtllib_rx_frame_decrypt(struct rtllib_device *ieee, struct sk_buff *skb,
|
||||
tcb_desc->bHwSec = 0;
|
||||
}
|
||||
|
||||
hdr = (struct rtllib_hdr_4addr *) skb->data;
|
||||
hdr = (struct rtllib_hdr_4addr *)skb->data;
|
||||
hdrlen = rtllib_get_hdrlen(le16_to_cpu(hdr->frame_ctl));
|
||||
|
||||
atomic_inc(&crypt->refcnt);
|
||||
@ -339,7 +339,7 @@ rtllib_rx_frame_decrypt_msdu(struct rtllib_device *ieee, struct sk_buff *skb,
|
||||
tcb_desc->bHwSec = 0;
|
||||
}
|
||||
|
||||
hdr = (struct rtllib_hdr_4addr *) skb->data;
|
||||
hdr = (struct rtllib_hdr_4addr *)skb->data;
|
||||
hdrlen = rtllib_get_hdrlen(le16_to_cpu(hdr->frame_ctl));
|
||||
|
||||
atomic_inc(&crypt->refcnt);
|
||||
@ -936,7 +936,7 @@ static int rtllib_rx_check_duplicate(struct rtllib_device *ieee,
|
||||
} else {
|
||||
struct rx_ts_record *pRxTS = NULL;
|
||||
|
||||
if (GetTs(ieee, (struct ts_common_info **) &pRxTS, hdr->addr2,
|
||||
if (GetTs(ieee, (struct ts_common_info **)&pRxTS, hdr->addr2,
|
||||
(u8)Frame_QoSTID((u8 *)(skb->data)), RX_DIR, true)) {
|
||||
if ((fc & (1<<11)) && (frag == pRxTS->rx_last_frag_num) &&
|
||||
(WLAN_GET_SEQ_SEQ(sc) == pRxTS->rx_last_seq_num))
|
||||
@ -1100,7 +1100,7 @@ static int rtllib_rx_decrypt(struct rtllib_device *ieee, struct sk_buff *skb,
|
||||
return -1;
|
||||
}
|
||||
|
||||
hdr = (struct rtllib_hdr_4addr *) skb->data;
|
||||
hdr = (struct rtllib_hdr_4addr *)skb->data;
|
||||
if ((frag != 0 || (fc & RTLLIB_FCTL_MOREFRAGS))) {
|
||||
int flen;
|
||||
struct sk_buff *frag_skb = rtllib_frag_cache_get(ieee, hdr);
|
||||
@ -1152,7 +1152,7 @@ static int rtllib_rx_decrypt(struct rtllib_device *ieee, struct sk_buff *skb,
|
||||
* delivered, so remove skb from fragment cache
|
||||
*/
|
||||
skb = frag_skb;
|
||||
hdr = (struct rtllib_hdr_4addr *) skb->data;
|
||||
hdr = (struct rtllib_hdr_4addr *)skb->data;
|
||||
rtllib_frag_cache_invalidate(ieee, hdr);
|
||||
}
|
||||
|
||||
@ -1165,7 +1165,7 @@ static int rtllib_rx_decrypt(struct rtllib_device *ieee, struct sk_buff *skb,
|
||||
return -1;
|
||||
}
|
||||
|
||||
hdr = (struct rtllib_hdr_4addr *) skb->data;
|
||||
hdr = (struct rtllib_hdr_4addr *)skb->data;
|
||||
if (crypt && !(fc & RTLLIB_FCTL_WEP) && !ieee->open_wep) {
|
||||
if (/*ieee->ieee802_1x &&*/
|
||||
rtllib_is_eapol_frame(ieee, skb, hdrlen)) {
|
||||
@ -1397,13 +1397,13 @@ static int rtllib_rx_InfraAdhoc(struct rtllib_device *ieee, struct sk_buff *skb,
|
||||
goto rx_exit;
|
||||
|
||||
/* Get TS for Rx Reorder */
|
||||
hdr = (struct rtllib_hdr_4addr *) skb->data;
|
||||
hdr = (struct rtllib_hdr_4addr *)skb->data;
|
||||
if (ieee->current_network.qos_data.active && IsQoSDataFrame(skb->data)
|
||||
&& !is_multicast_ether_addr(hdr->addr1)
|
||||
&& (!bToOtherSTA)) {
|
||||
TID = Frame_QoSTID(skb->data);
|
||||
SeqNum = WLAN_GET_SEQ_SEQ(sc);
|
||||
GetTs(ieee, (struct ts_common_info **) &pTS, hdr->addr2, TID,
|
||||
GetTs(ieee, (struct ts_common_info **)&pTS, hdr->addr2, TID,
|
||||
RX_DIR, true);
|
||||
if (TID != 0 && TID != 3)
|
||||
ieee->bis_any_nonbepkts = true;
|
||||
@ -2053,7 +2053,7 @@ int rtllib_parse_info_param(struct rtllib_device *ieee,
|
||||
}
|
||||
|
||||
network->ssid_len = min(info_element->len,
|
||||
(u8) IW_ESSID_MAX_SIZE);
|
||||
(u8)IW_ESSID_MAX_SIZE);
|
||||
memcpy(network->ssid, info_element->data,
|
||||
network->ssid_len);
|
||||
if (network->ssid_len < IW_ESSID_MAX_SIZE)
|
||||
@ -2721,7 +2721,7 @@ static void rtllib_rx_mgt(struct rtllib_device *ieee,
|
||||
if (ieee->sta_sleep || (ieee->ps != RTLLIB_PS_DISABLED &&
|
||||
ieee->iw_mode == IW_MODE_INFRA &&
|
||||
ieee->state == RTLLIB_LINKED))
|
||||
tasklet_schedule(&ieee->ps_task);
|
||||
schedule_work(&ieee->ps_task);
|
||||
|
||||
break;
|
||||
|
||||
|
@ -202,7 +202,7 @@ inline void softmac_mgmt_xmit(struct sk_buff *skb, struct rtllib_device *ieee)
|
||||
unsigned long flags;
|
||||
short single = ieee->softmac_features & IEEE_SOFTMAC_SINGLE_QUEUE;
|
||||
struct rtllib_hdr_3addr *header =
|
||||
(struct rtllib_hdr_3addr *) skb->data;
|
||||
(struct rtllib_hdr_3addr *)skb->data;
|
||||
|
||||
struct cb_desc *tcb_desc = (struct cb_desc *)(skb->cb + 8);
|
||||
|
||||
@ -279,7 +279,7 @@ softmac_ps_mgmt_xmit(struct sk_buff *skb,
|
||||
{
|
||||
short single = ieee->softmac_features & IEEE_SOFTMAC_SINGLE_QUEUE;
|
||||
struct rtllib_hdr_3addr *header =
|
||||
(struct rtllib_hdr_3addr *) skb->data;
|
||||
(struct rtllib_hdr_3addr *)skb->data;
|
||||
u16 fc, type, stype;
|
||||
struct cb_desc *tcb_desc = (struct cb_desc *)(skb->cb + 8);
|
||||
|
||||
@ -651,9 +651,9 @@ static void rtllib_beacons_stop(struct rtllib_device *ieee)
|
||||
spin_lock_irqsave(&ieee->beacon_lock, flags);
|
||||
|
||||
ieee->beacon_txing = 0;
|
||||
del_timer_sync(&ieee->beacon_timer);
|
||||
|
||||
spin_unlock_irqrestore(&ieee->beacon_lock, flags);
|
||||
del_timer_sync(&ieee->beacon_timer);
|
||||
|
||||
}
|
||||
|
||||
@ -856,9 +856,9 @@ static struct sk_buff *rtllib_probe_resp(struct rtllib_device *ieee,
|
||||
encrypt = ieee->host_encrypt && crypt && crypt->ops &&
|
||||
((strcmp(crypt->ops->name, "R-WEP") == 0 || wpa_ie_len));
|
||||
if (ieee->pHTInfo->bCurrentHTSupport) {
|
||||
tmp_ht_cap_buf = (u8 *) &(ieee->pHTInfo->SelfHTCap);
|
||||
tmp_ht_cap_buf = (u8 *)&(ieee->pHTInfo->SelfHTCap);
|
||||
tmp_ht_cap_len = sizeof(ieee->pHTInfo->SelfHTCap);
|
||||
tmp_ht_info_buf = (u8 *) &(ieee->pHTInfo->SelfHTInfo);
|
||||
tmp_ht_info_buf = (u8 *)&(ieee->pHTInfo->SelfHTInfo);
|
||||
tmp_ht_info_len = sizeof(ieee->pHTInfo->SelfHTInfo);
|
||||
HTConstructCapabilityElement(ieee, tmp_ht_cap_buf,
|
||||
&tmp_ht_cap_len, encrypt, false);
|
||||
@ -912,7 +912,7 @@ static struct sk_buff *rtllib_probe_resp(struct rtllib_device *ieee,
|
||||
beacon_buf->info_element[0].id = MFIE_TYPE_SSID;
|
||||
beacon_buf->info_element[0].len = ssid_len;
|
||||
|
||||
tag = (u8 *) beacon_buf->info_element[0].data;
|
||||
tag = (u8 *)beacon_buf->info_element[0].data;
|
||||
|
||||
memcpy(tag, ssid, ssid_len);
|
||||
|
||||
@ -1303,7 +1303,7 @@ rtllib_association_req(struct rtllib_network *beacon,
|
||||
0x00};
|
||||
struct octet_string osCcxRmCap;
|
||||
|
||||
osCcxRmCap.Octet = (u8 *) CcxRmCapBuf;
|
||||
osCcxRmCap.Octet = (u8 *)CcxRmCapBuf;
|
||||
osCcxRmCap.Length = sizeof(CcxRmCapBuf);
|
||||
tag = skb_put(skb, ccxrm_ie_len);
|
||||
*tag++ = MFIE_TYPE_GENERIC;
|
||||
@ -1764,7 +1764,7 @@ static void rtllib_softmac_check_all_nets(struct rtllib_device *ieee)
|
||||
spin_unlock_irqrestore(&ieee->lock, flags);
|
||||
}
|
||||
|
||||
static inline u16 auth_parse(struct net_device *dev, struct sk_buff *skb,
|
||||
static inline int auth_parse(struct net_device *dev, struct sk_buff *skb,
|
||||
u8 **challenge, int *chlen)
|
||||
{
|
||||
struct rtllib_authentication *a;
|
||||
@ -1773,10 +1773,10 @@ static inline u16 auth_parse(struct net_device *dev, struct sk_buff *skb,
|
||||
if (skb->len < (sizeof(struct rtllib_authentication) -
|
||||
sizeof(struct rtllib_info_element))) {
|
||||
netdev_dbg(dev, "invalid len in auth resp: %d\n", skb->len);
|
||||
return 0xcafe;
|
||||
return -EINVAL;
|
||||
}
|
||||
*challenge = NULL;
|
||||
a = (struct rtllib_authentication *) skb->data;
|
||||
a = (struct rtllib_authentication *)skb->data;
|
||||
if (skb->len > (sizeof(struct rtllib_authentication) + 3)) {
|
||||
t = skb->data + sizeof(struct rtllib_authentication);
|
||||
|
||||
@ -1787,7 +1787,13 @@ static inline u16 auth_parse(struct net_device *dev, struct sk_buff *skb,
|
||||
return -ENOMEM;
|
||||
}
|
||||
}
|
||||
return le16_to_cpu(a->status);
|
||||
|
||||
if (a->status) {
|
||||
netdev_dbg(dev, "auth_parse() failed\n");
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int auth_rq_parse(struct net_device *dev, struct sk_buff *skb, u8 *dest)
|
||||
@ -1799,7 +1805,7 @@ static int auth_rq_parse(struct net_device *dev, struct sk_buff *skb, u8 *dest)
|
||||
netdev_dbg(dev, "invalid len in auth request: %d\n", skb->len);
|
||||
return -1;
|
||||
}
|
||||
a = (struct rtllib_authentication *) skb->data;
|
||||
a = (struct rtllib_authentication *)skb->data;
|
||||
|
||||
ether_addr_copy(dest, a->header.addr2);
|
||||
|
||||
@ -1817,7 +1823,7 @@ static short probe_rq_parse(struct rtllib_device *ieee, struct sk_buff *skb,
|
||||
u8 *ssid = NULL;
|
||||
u8 ssidlen = 0;
|
||||
struct rtllib_hdr_3addr *header =
|
||||
(struct rtllib_hdr_3addr *) skb->data;
|
||||
(struct rtllib_hdr_3addr *)skb->data;
|
||||
bool bssid_match;
|
||||
|
||||
if (skb->len < sizeof(struct rtllib_hdr_3addr))
|
||||
@ -1865,7 +1871,7 @@ static int assoc_rq_parse(struct net_device *dev, struct sk_buff *skb, u8 *dest)
|
||||
return -1;
|
||||
}
|
||||
|
||||
a = (struct rtllib_assoc_request_frame *) skb->data;
|
||||
a = (struct rtllib_assoc_request_frame *)skb->data;
|
||||
|
||||
ether_addr_copy(dest, a->header.addr2);
|
||||
|
||||
@ -1884,7 +1890,7 @@ static inline u16 assoc_parse(struct rtllib_device *ieee, struct sk_buff *skb,
|
||||
return 0xcafe;
|
||||
}
|
||||
|
||||
response_head = (struct rtllib_assoc_response_frame *) skb->data;
|
||||
response_head = (struct rtllib_assoc_response_frame *)skb->data;
|
||||
*aid = le16_to_cpu(response_head->aid) & 0x3fff;
|
||||
|
||||
status_code = le16_to_cpu(response_head->status);
|
||||
@ -2042,13 +2048,15 @@ static short rtllib_sta_ps_sleep(struct rtllib_device *ieee, u64 *time)
|
||||
|
||||
}
|
||||
|
||||
static inline void rtllib_sta_ps(struct tasklet_struct *t)
|
||||
static inline void rtllib_sta_ps(struct work_struct *work)
|
||||
{
|
||||
struct rtllib_device *ieee = from_tasklet(ieee, t, ps_task);
|
||||
struct rtllib_device *ieee;
|
||||
u64 time;
|
||||
short sleep;
|
||||
unsigned long flags, flags2;
|
||||
|
||||
ieee = container_of(work, struct rtllib_device, ps_task);
|
||||
|
||||
spin_lock_irqsave(&ieee->lock, flags);
|
||||
|
||||
if ((ieee->ps == RTLLIB_PS_DISABLED ||
|
||||
@ -2167,7 +2175,7 @@ EXPORT_SYMBOL(rtllib_ps_tx_ack);
|
||||
static void rtllib_process_action(struct rtllib_device *ieee,
|
||||
struct sk_buff *skb)
|
||||
{
|
||||
struct rtllib_hdr_3addr *header = (struct rtllib_hdr_3addr *) skb->data;
|
||||
struct rtllib_hdr_3addr *header = (struct rtllib_hdr_3addr *)skb->data;
|
||||
u8 *act = rtllib_get_payload((struct rtllib_hdr *)header);
|
||||
u8 category = 0;
|
||||
|
||||
@ -2206,7 +2214,7 @@ rtllib_rx_assoc_resp(struct rtllib_device *ieee, struct sk_buff *skb,
|
||||
int aid;
|
||||
u8 *ies;
|
||||
struct rtllib_assoc_response_frame *assoc_resp;
|
||||
struct rtllib_hdr_3addr *header = (struct rtllib_hdr_3addr *) skb->data;
|
||||
struct rtllib_hdr_3addr *header = (struct rtllib_hdr_3addr *)skb->data;
|
||||
u16 frame_ctl = le16_to_cpu(header->frame_ctl);
|
||||
|
||||
netdev_dbg(ieee->dev, "received [RE]ASSOCIATION RESPONSE (%d)\n",
|
||||
@ -2278,7 +2286,7 @@ rtllib_rx_assoc_resp(struct rtllib_device *ieee, struct sk_buff *skb,
|
||||
|
||||
static void rtllib_rx_auth_resp(struct rtllib_device *ieee, struct sk_buff *skb)
|
||||
{
|
||||
u16 errcode;
|
||||
int errcode;
|
||||
u8 *challenge;
|
||||
int chlen = 0;
|
||||
bool bSupportNmode = true, bHalfSupportNmode = false;
|
||||
@ -2288,8 +2296,7 @@ static void rtllib_rx_auth_resp(struct rtllib_device *ieee, struct sk_buff *skb)
|
||||
if (errcode) {
|
||||
ieee->softmac_stats.rx_auth_rs_err++;
|
||||
netdev_info(ieee->dev,
|
||||
"Authentication response status code 0x%x",
|
||||
errcode);
|
||||
"Authentication response status code %d", errcode);
|
||||
rtllib_associate_abort(ieee);
|
||||
return;
|
||||
}
|
||||
@ -2351,7 +2358,7 @@ rtllib_rx_auth(struct rtllib_device *ieee, struct sk_buff *skb,
|
||||
static inline int
|
||||
rtllib_rx_deauth(struct rtllib_device *ieee, struct sk_buff *skb)
|
||||
{
|
||||
struct rtllib_hdr_3addr *header = (struct rtllib_hdr_3addr *) skb->data;
|
||||
struct rtllib_hdr_3addr *header = (struct rtllib_hdr_3addr *)skb->data;
|
||||
u16 frame_ctl;
|
||||
|
||||
if (memcmp(header->addr3, ieee->current_network.bssid, ETH_ALEN) != 0)
|
||||
@ -2391,7 +2398,7 @@ inline int rtllib_rx_frame_softmac(struct rtllib_device *ieee,
|
||||
struct rtllib_rx_stats *rx_stats, u16 type,
|
||||
u16 stype)
|
||||
{
|
||||
struct rtllib_hdr_3addr *header = (struct rtllib_hdr_3addr *) skb->data;
|
||||
struct rtllib_hdr_3addr *header = (struct rtllib_hdr_3addr *)skb->data;
|
||||
u16 frame_ctl;
|
||||
|
||||
if (!ieee->proto_started)
|
||||
@ -2811,7 +2818,7 @@ static struct sk_buff *rtllib_get_beacon_(struct rtllib_device *ieee)
|
||||
if (!skb)
|
||||
return NULL;
|
||||
|
||||
b = (struct rtllib_probe_response *) skb->data;
|
||||
b = (struct rtllib_probe_response *)skb->data;
|
||||
b->header.frame_ctl = cpu_to_le16(RTLLIB_STYPE_BEACON);
|
||||
|
||||
return skb;
|
||||
@ -2827,7 +2834,7 @@ struct sk_buff *rtllib_get_beacon(struct rtllib_device *ieee)
|
||||
if (!skb)
|
||||
return NULL;
|
||||
|
||||
b = (struct rtllib_probe_response *) skb->data;
|
||||
b = (struct rtllib_probe_response *)skb->data;
|
||||
b->header.seq_ctl = cpu_to_le16(ieee->seq_ctrl[0] << 4);
|
||||
|
||||
if (ieee->seq_ctrl[0] == 0xFFF)
|
||||
@ -3028,7 +3035,7 @@ int rtllib_softmac_init(struct rtllib_device *ieee)
|
||||
spin_lock_init(&ieee->mgmt_tx_lock);
|
||||
spin_lock_init(&ieee->beacon_lock);
|
||||
|
||||
tasklet_setup(&ieee->ps_task, rtllib_sta_ps);
|
||||
INIT_WORK(&ieee->ps_task, rtllib_sta_ps);
|
||||
|
||||
return 0;
|
||||
}
|
||||
@ -3050,8 +3057,8 @@ void rtllib_softmac_free(struct rtllib_device *ieee)
|
||||
cancel_work_sync(&ieee->associate_complete_wq);
|
||||
cancel_work_sync(&ieee->ips_leave_wq);
|
||||
cancel_work_sync(&ieee->wx_sync_scan_wq);
|
||||
cancel_work_sync(&ieee->ps_task);
|
||||
mutex_unlock(&ieee->wx_mutex);
|
||||
tasklet_kill(&ieee->ps_task);
|
||||
}
|
||||
|
||||
static inline struct sk_buff *
|
||||
|
@ -41,8 +41,8 @@ int rtllib_wx_set_freq(struct rtllib_device *ieee, struct iw_request_info *a,
|
||||
|
||||
/* if setting by freq convert to channel */
|
||||
if (fwrq->e == 1) {
|
||||
if ((fwrq->m >= (int) 2.412e8 &&
|
||||
fwrq->m <= (int) 2.487e8)) {
|
||||
if ((fwrq->m >= (int)2.412e8 &&
|
||||
fwrq->m <= (int)2.487e8)) {
|
||||
int f = fwrq->m / 100000;
|
||||
int c = 0;
|
||||
|
||||
|
@ -660,7 +660,7 @@ int rtllib_wx_set_mlme(struct rtllib_device *ieee,
|
||||
{
|
||||
u8 i = 0;
|
||||
bool deauth = false;
|
||||
struct iw_mlme *mlme = (struct iw_mlme *) extra;
|
||||
struct iw_mlme *mlme = (struct iw_mlme *)extra;
|
||||
|
||||
if (ieee->state != RTLLIB_LINKED)
|
||||
return -ENOLINK;
|
||||
|
@ -1790,7 +1790,7 @@ struct ieee80211_device {
|
||||
short sta_sleep;
|
||||
int ps_timeout;
|
||||
int ps_period;
|
||||
struct tasklet_struct ps_task;
|
||||
struct work_struct ps_task;
|
||||
u32 ps_th;
|
||||
u32 ps_tl;
|
||||
|
||||
|
@ -362,7 +362,7 @@ static int ieee80211_ccmp_get_key(void *key, int len, u8 *seq, void *priv)
|
||||
struct ieee80211_ccmp_data *data = priv;
|
||||
|
||||
if (len < CCMP_TK_LEN)
|
||||
return -1;
|
||||
return 0;
|
||||
|
||||
if (!data->key_set)
|
||||
return 0;
|
||||
|
@ -637,7 +637,7 @@ static int ieee80211_tkip_get_key(void *key, int len, u8 *seq, void *priv)
|
||||
struct ieee80211_tkip_data *tkey = priv;
|
||||
|
||||
if (len < TKIP_KEY_LEN)
|
||||
return -1;
|
||||
return 0;
|
||||
|
||||
if (!tkey->key_set)
|
||||
return 0;
|
||||
|
@ -201,7 +201,7 @@ static int prism2_wep_get_key(void *key, int len, u8 *seq, void *priv)
|
||||
struct prism2_wep_data *wep = priv;
|
||||
|
||||
if (len < wep->key_len)
|
||||
return -1;
|
||||
return 0;
|
||||
|
||||
memcpy(key, wep->key, wep->key_len);
|
||||
|
||||
|
@ -528,9 +528,9 @@ static void ieee80211_beacons_stop(struct ieee80211_device *ieee)
|
||||
spin_lock_irqsave(&ieee->beacon_lock, flags);
|
||||
|
||||
ieee->beacon_txing = 0;
|
||||
del_timer_sync(&ieee->beacon_timer);
|
||||
|
||||
spin_unlock_irqrestore(&ieee->beacon_lock, flags);
|
||||
del_timer_sync(&ieee->beacon_timer);
|
||||
}
|
||||
|
||||
void ieee80211_stop_send_beacons(struct ieee80211_device *ieee)
|
||||
@ -1461,13 +1461,13 @@ void ieee80211_softmac_check_all_nets(struct ieee80211_device *ieee)
|
||||
spin_unlock_irqrestore(&ieee->lock, flags);
|
||||
}
|
||||
|
||||
static inline u16 auth_parse(struct sk_buff *skb, u8 **challenge, int *chlen)
|
||||
static inline int auth_parse(struct sk_buff *skb, u8 **challenge, int *chlen)
|
||||
{
|
||||
struct ieee80211_authentication *a;
|
||||
u8 *t;
|
||||
if (skb->len < (sizeof(struct ieee80211_authentication) - sizeof(struct ieee80211_info_element))) {
|
||||
IEEE80211_DEBUG_MGMT("invalid len in auth resp: %d\n", skb->len);
|
||||
return 0xcafe;
|
||||
return -EINVAL;
|
||||
}
|
||||
*challenge = NULL;
|
||||
a = (struct ieee80211_authentication *)skb->data;
|
||||
@ -1482,7 +1482,12 @@ static inline u16 auth_parse(struct sk_buff *skb, u8 **challenge, int *chlen)
|
||||
}
|
||||
}
|
||||
|
||||
return le16_to_cpu(a->status);
|
||||
if (a->status) {
|
||||
IEEE80211_DEBUG_MGMT("auth_parse() failed\n");
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int auth_rq_parse(struct sk_buff *skb, u8 *dest)
|
||||
@ -1687,14 +1692,15 @@ static short ieee80211_sta_ps_sleep(struct ieee80211_device *ieee, u32 *time_h,
|
||||
return 1;
|
||||
}
|
||||
|
||||
static inline void ieee80211_sta_ps(struct tasklet_struct *t)
|
||||
static inline void ieee80211_sta_ps(struct work_struct *work)
|
||||
{
|
||||
struct ieee80211_device *ieee = from_tasklet(ieee, t, ps_task);
|
||||
struct ieee80211_device *ieee;
|
||||
u32 th, tl;
|
||||
short sleep;
|
||||
|
||||
unsigned long flags, flags2;
|
||||
|
||||
ieee = container_of(work, struct ieee80211_device, ps_task);
|
||||
|
||||
spin_lock_irqsave(&ieee->lock, flags);
|
||||
|
||||
if ((ieee->ps == IEEE80211_PS_DISABLED ||
|
||||
@ -1826,7 +1832,7 @@ static void ieee80211_check_auth_response(struct ieee80211_device *ieee,
|
||||
{
|
||||
/* default support N mode, disable halfNmode */
|
||||
bool bSupportNmode = true, bHalfSupportNmode = false;
|
||||
u16 errcode;
|
||||
int errcode;
|
||||
u8 *challenge;
|
||||
int chlen = 0;
|
||||
u32 iotAction;
|
||||
@ -1875,7 +1881,7 @@ static void ieee80211_check_auth_response(struct ieee80211_device *ieee,
|
||||
}
|
||||
} else {
|
||||
ieee->softmac_stats.rx_auth_rs_err++;
|
||||
IEEE80211_DEBUG_MGMT("Auth response status code 0x%x", errcode);
|
||||
IEEE80211_DEBUG_MGMT("Auth response status code %d\n", errcode);
|
||||
ieee80211_associate_abort(ieee);
|
||||
}
|
||||
}
|
||||
@ -1897,7 +1903,7 @@ ieee80211_rx_frame_softmac(struct ieee80211_device *ieee, struct sk_buff *skb,
|
||||
if (ieee->sta_sleep || (ieee->ps != IEEE80211_PS_DISABLED &&
|
||||
ieee->iw_mode == IW_MODE_INFRA &&
|
||||
ieee->state == IEEE80211_LINKED))
|
||||
tasklet_schedule(&ieee->ps_task);
|
||||
schedule_work(&ieee->ps_task);
|
||||
|
||||
if (WLAN_FC_GET_STYPE(header->frame_ctl) != IEEE80211_STYPE_PROBE_RESP &&
|
||||
WLAN_FC_GET_STYPE(header->frame_ctl) != IEEE80211_STYPE_BEACON)
|
||||
@ -2602,7 +2608,7 @@ void ieee80211_softmac_init(struct ieee80211_device *ieee)
|
||||
spin_lock_init(&ieee->mgmt_tx_lock);
|
||||
spin_lock_init(&ieee->beacon_lock);
|
||||
|
||||
tasklet_setup(&ieee->ps_task, ieee80211_sta_ps);
|
||||
INIT_WORK(&ieee->ps_task, ieee80211_sta_ps);
|
||||
}
|
||||
|
||||
void ieee80211_softmac_free(struct ieee80211_device *ieee)
|
||||
@ -2613,7 +2619,7 @@ void ieee80211_softmac_free(struct ieee80211_device *ieee)
|
||||
del_timer_sync(&ieee->associate_timer);
|
||||
|
||||
cancel_delayed_work(&ieee->associate_retry_wq);
|
||||
|
||||
cancel_work_sync(&ieee->ps_task);
|
||||
mutex_unlock(&ieee->wx_mutex);
|
||||
}
|
||||
|
||||
|
@ -470,7 +470,9 @@ int ieee80211_wx_get_encode(struct ieee80211_device *ieee,
|
||||
return 0;
|
||||
}
|
||||
len = crypt->ops->get_key(keybuf, SCM_KEY_LEN, NULL, crypt->priv);
|
||||
erq->length = (len >= 0 ? len : 0);
|
||||
if (len < 0)
|
||||
len = 0;
|
||||
erq->length = len;
|
||||
|
||||
erq->flags |= IW_ENCODE_ENABLED;
|
||||
|
||||
@ -686,9 +688,9 @@ int ieee80211_wx_get_encode_ext(struct ieee80211_device *ieee,
|
||||
} else {
|
||||
if (strcmp(crypt->ops->name, "WEP") == 0)
|
||||
ext->alg = IW_ENCODE_ALG_WEP;
|
||||
else if (strcmp(crypt->ops->name, "TKIP"))
|
||||
else if (strcmp(crypt->ops->name, "TKIP") == 0)
|
||||
ext->alg = IW_ENCODE_ALG_TKIP;
|
||||
else if (strcmp(crypt->ops->name, "CCMP"))
|
||||
else if (strcmp(crypt->ops->name, "CCMP") == 0)
|
||||
ext->alg = IW_ENCODE_ALG_CCMP;
|
||||
else
|
||||
return -EINVAL;
|
||||
|
@ -480,7 +480,7 @@ void HTConstructCapabilityElement(struct ieee80211_device *ieee, u8 *posHTCap, u
|
||||
}
|
||||
memset(posHTCap, 0, *len);
|
||||
if (pHT->ePeerHTSpecVer == HT_SPEC_VER_EWC) {
|
||||
u8 EWC11NHTCap[] = {0x00, 0x90, 0x4c, 0x33}; // For 11n EWC definition, 2007.07.17, by Emily
|
||||
static const u8 EWC11NHTCap[] = {0x00, 0x90, 0x4c, 0x33};
|
||||
|
||||
memcpy(posHTCap, EWC11NHTCap, sizeof(EWC11NHTCap));
|
||||
pCapELE = (struct ht_capability_ele *)&posHTCap[4];
|
||||
@ -940,10 +940,8 @@ void HTOnAssocRsp(struct ieee80211_device *ieee)
|
||||
else
|
||||
pHTInfo->CurrentAMPDUFactor = HT_AGG_SIZE_64K;
|
||||
} else {
|
||||
if (pPeerHTCap->MaxRxAMPDUFactor < HT_AGG_SIZE_32K)
|
||||
pHTInfo->CurrentAMPDUFactor = pPeerHTCap->MaxRxAMPDUFactor;
|
||||
else
|
||||
pHTInfo->CurrentAMPDUFactor = HT_AGG_SIZE_32K;
|
||||
pHTInfo->CurrentAMPDUFactor = min_t(u32, pPeerHTCap->MaxRxAMPDUFactor,
|
||||
HT_AGG_SIZE_32K);
|
||||
}
|
||||
}
|
||||
|
||||
@ -951,10 +949,9 @@ void HTOnAssocRsp(struct ieee80211_device *ieee)
|
||||
* <2> Set AMPDU Minimum MPDU Start Spacing
|
||||
* 802.11n 3.0 section 9.7d.3
|
||||
*/
|
||||
if (pHTInfo->MPDU_Density > pPeerHTCap->MPDUDensity)
|
||||
pHTInfo->CurrentMPDUDensity = pHTInfo->MPDU_Density;
|
||||
else
|
||||
pHTInfo->CurrentMPDUDensity = pPeerHTCap->MPDUDensity;
|
||||
pHTInfo->CurrentMPDUDensity = max_t(u32, pHTInfo->MPDU_Density,
|
||||
pPeerHTCap->MPDUDensity);
|
||||
|
||||
if (ieee->pairwise_key_type != KEY_TYPE_NA)
|
||||
pHTInfo->CurrentMPDUDensity = 7; // 8us
|
||||
// Force TX AMSDU
|
||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user