mirror of
https://github.com/nxp-imx/mwifiex.git
synced 2025-01-27 22:10:04 +00:00
mxm_wifiex: update to mxm5x17283 release
changes: 1. WCSWREL-191: Fixed the error when loading module param from user config for SD8801 2. WCSWREL-186: Fixed the issue of mlanutl failing on kernel higher than L5.15 3. Fixed low throughput issue for WPA3 SAE 4. Added driver change for WLAN throughput improvement on 8997 SoC 5. Updated README to recommend not to use WEP/TKIP for all chipsets 6. WCSWREL-180: Fix P2P test fail on kernel higher than L5.12 7. WCSWREL-156: kernel_write/kernel_read not allowed by drivers for L5.10 kernel GKI buildou 8. Alternative for pm_qos_add_request/pm_qos_remove_request Signed-off-by: Sherry Sun <sherry.sun@nxp.com> Approved-by: Tian Yang <yang.tian@nxp.com>
This commit is contained in:
parent
ca6dc88279
commit
13b6fdb0b4
61 changed files with 3999 additions and 1074 deletions
mxm_wifiex/wlan_src
MakefileREADME_MLAN
mapp
mlan
mlan_11ac.cmlan_11ax.cmlan_11ax.hmlan_11h.cmlan_11n_aggr.cmlan_cfp.cmlan_cmdevt.cmlan_decl.hmlan_fw.hmlan_ieee.hmlan_init.cmlan_ioctl.hmlan_join.cmlan_main.hmlan_misc.cmlan_module.cmlan_scan.cmlan_sdio.cmlan_shim.cmlan_sta_cmd.cmlan_sta_cmdresp.cmlan_sta_event.cmlan_sta_ioctl.cmlan_uap_cmdevent.cmlan_uap_ioctl.cmlan_uap_txrx.c
mlinux
mlan_decl.hmlan_ieee.hmlan_ioctl.hmoal_cfg80211.cmoal_cfg80211.hmoal_cfg80211_util.cmoal_cfg80211_util.hmoal_debug.cmoal_eth_ioctl.cmoal_eth_ioctl.hmoal_init.cmoal_ioctl.cmoal_main.cmoal_main.hmoal_pcie.cmoal_priv.cmoal_priv.hmoal_proc.cmoal_sdio_mmc.cmoal_shim.cmoal_shim.hmoal_sta_cfg80211.cmoal_uap.cmoal_uap.hmoal_uap_cfg80211.cmoal_uap_priv.cmoal_uap_priv.hmoal_uap_wext.cmoal_usb.cmoal_wext.c
|
@ -45,7 +45,7 @@ CONFIG_PCIE8997=y
|
||||||
CONFIG_SD8987=y
|
CONFIG_SD8987=y
|
||||||
CONFIG_SD9097=n
|
CONFIG_SD9097=n
|
||||||
CONFIG_SD9177=n
|
CONFIG_SD9177=n
|
||||||
CONFIG_SD8801=n
|
CONFIG_SD8801=y
|
||||||
CONFIG_USB8801=n
|
CONFIG_USB8801=n
|
||||||
CONFIG_USB9097=n
|
CONFIG_USB9097=n
|
||||||
CONFIG_PCIE9097=n
|
CONFIG_PCIE9097=n
|
||||||
|
@ -127,6 +127,8 @@ CONFIG_IMX_SUPPORT=y
|
||||||
ifeq ($(CONFIG_IMX_SUPPORT),y)
|
ifeq ($(CONFIG_IMX_SUPPORT),y)
|
||||||
ccflags-y += -DIMX_SUPPORT
|
ccflags-y += -DIMX_SUPPORT
|
||||||
endif
|
endif
|
||||||
|
KERNELDIR ?= /usr/src/arm/linux_5_10_y_kernel/linux-nxp
|
||||||
|
CROSS_COMPILE ?= /opt/fsl-imx-internal-xwayland/5.10-gatesgarth/sysroots/x86_64-pokysdk-linux/usr/bin/aarch64-poky-linux/aarch64-poky-linux-
|
||||||
|
|
||||||
LD += -S
|
LD += -S
|
||||||
|
|
||||||
|
|
|
@ -9,7 +9,7 @@
|
||||||
Goto source code directory wlan_src/.
|
Goto source code directory wlan_src/.
|
||||||
make [clean] build
|
make [clean] build
|
||||||
The driver and utility binaries can be found in ../bin_xxxx directory.
|
The driver and utility binaries can be found in ../bin_xxxx directory.
|
||||||
The driver code supports Linux kernel from 2.6.32 to 5.8.0.
|
The driver code supports Linux kernel from 2.6.32 to 5.13.4.
|
||||||
|
|
||||||
2) FOR DRIVER INSTALL
|
2) FOR DRIVER INSTALL
|
||||||
|
|
||||||
|
@ -49,7 +49,10 @@
|
||||||
dev_cap_mask=<Bit mask of the device capability>
|
dev_cap_mask=<Bit mask of the device capability>
|
||||||
mac_addr=xx:xx:xx:xx:xx:xx <override the MAC address (in hex)>
|
mac_addr=xx:xx:xx:xx:xx:xx <override the MAC address (in hex)>
|
||||||
auto_ds=0|1|2 <use MLAN default | enable auto deepsleep | disable auto deepsleep>
|
auto_ds=0|1|2 <use MLAN default | enable auto deepsleep | disable auto deepsleep>
|
||||||
|
ext_scan=0|1|2 <use MLAN default | Enable Extended Scan| Enable Enhanced Extended Scan>
|
||||||
|
net_rx=0|1 <use netif_rx_ni in rx | use netif_receive_skb in rx>
|
||||||
ps_mode=0|1|2 <use MLAN default | enable IEEE PS mode | disable IEEE PS mode>
|
ps_mode=0|1|2 <use MLAN default | enable IEEE PS mode | disable IEEE PS mode>
|
||||||
|
sched_scan=0|1 <disable sched_scan | enable sched_scan default>
|
||||||
max_tx_buf=2048|4096|8192 <maximum AMSDU Tx buffer size>
|
max_tx_buf=2048|4096|8192 <maximum AMSDU Tx buffer size>
|
||||||
pm_keep_power=1|0 <PM keep power in suspend (default) | PM no power in suspend>
|
pm_keep_power=1|0 <PM keep power in suspend (default) | PM no power in suspend>
|
||||||
shutdown_hs=1|0 <Enable HS when shutdown | No HS when shutdown (default)>
|
shutdown_hs=1|0 <Enable HS when shutdown | No HS when shutdown (default)>
|
||||||
|
@ -151,10 +154,10 @@
|
||||||
num_rx_pkts_err = <number of Rx packets failed to receive from device>
|
num_rx_pkts_err = <number of Rx packets failed to receive from device>
|
||||||
carrier "on" | "off"
|
carrier "on" | "off"
|
||||||
tx queue "stopped" | "started"
|
tx queue "stopped" | "started"
|
||||||
tkip_mic_failures = 0 // Only for uAP
|
tkip_mic_failures = 0 // Only for uAP (use of WEP/TKIP is not recommended anymore)
|
||||||
ccmp_decrypt_errors = 0 // Only for uAP
|
ccmp_decrypt_errors = 0 // Only for uAP
|
||||||
wep_undecryptable_count = 0 // Only for uAP
|
wep_undecryptable_count = 0 // Only for uAP (use of WEP/TKIP is not recommended anymore)
|
||||||
wep_icv_error_count = 0 // Only for uAP
|
wep_icv_error_count = 0 // Only for uAP (use of WEP/TKIP is not recommended anymore)
|
||||||
decrypt_failure_count = 0 // Only for uAP
|
decrypt_failure_count = 0 // Only for uAP
|
||||||
mcast_tx_count = 0 // Only for uAP
|
mcast_tx_count = 0 // Only for uAP
|
||||||
failed_count = 0 // Only for uAP
|
failed_count = 0 // Only for uAP
|
||||||
|
@ -168,7 +171,7 @@
|
||||||
mcast_rx_frame_count = 0 // Only for uAP
|
mcast_rx_frame_count = 0 // Only for uAP
|
||||||
fcs_error_count = 0 // Only for uAP
|
fcs_error_count = 0 // Only for uAP
|
||||||
tx_frame_count = 0 // Only for uAP
|
tx_frame_count = 0 // Only for uAP
|
||||||
rsna_tkip_cm_invoked = 0 // Only for uAP
|
rsna_tkip_cm_invoked = 0 // Only for uAP (use of WEP/TKIP is not recommended anymore)
|
||||||
rsna_4way_hshk_failures = 0 // Only for uAP
|
rsna_4way_hshk_failures = 0 // Only for uAP
|
||||||
|
|
||||||
The following debug info are provided in /proc/net/mwlan/adapterX/mlanY|uapY|wfdY/debug,
|
The following debug info are provided in /proc/net/mwlan/adapterX/mlanY|uapY|wfdY/debug,
|
||||||
|
@ -259,6 +262,10 @@
|
||||||
|
|
||||||
Examples:
|
Examples:
|
||||||
echo "debug_dump" > /proc/mwlan/adapterX/config # dump driver internal debug status.
|
echo "debug_dump" > /proc/mwlan/adapterX/config # dump driver internal debug status.
|
||||||
|
To obtain fw dump or driver dump, use command:
|
||||||
|
cat /proc/mwlan/adapter0/drv_dump > file_drv_dump #save the drv dump to file_drv_dump
|
||||||
|
cat /proc/mwlan/adapter0/fw_dump > file_fw_dump #save the fw dump to file_fw_dump
|
||||||
|
cat /proc/mwlan/adapter1/drv_dump > file_drv_dump_2 #save the adapter1 drv dump to file_drv_dump_2
|
||||||
|
|
||||||
Use dmesg or cat /var/log/debug to check driver debug messages.
|
Use dmesg or cat /var/log/debug to check driver debug messages.
|
||||||
|
|
||||||
|
@ -538,7 +545,7 @@ getlog
|
||||||
|
|
||||||
dot11TransmittedFrameCount Increments for each successfully transmitted MSDU
|
dot11TransmittedFrameCount Increments for each successfully transmitted MSDU
|
||||||
|
|
||||||
dot11WeplcvErrCnt Increment when WEP decryption error for key index 0.3
|
dot11WeplcvErrCnt Increment when WEP (use of WEP/TKIP is not recommended anymore)decryption error for key index 0.3
|
||||||
|
|
||||||
beaconReceivedCnt Increments when received beacon
|
beaconReceivedCnt Increments when received beacon
|
||||||
|
|
||||||
|
@ -581,9 +588,9 @@ getlog
|
||||||
|
|
||||||
dot11RSNAStatsRobustMgmtCCMPReplays Increments when a robust management frame discarded by CCMP replay error
|
dot11RSNAStatsRobustMgmtCCMPReplays Increments when a robust management frame discarded by CCMP replay error
|
||||||
|
|
||||||
dot11RSNAStatsTKIPICVErrors Increments when a MPDU discarded by TKIP ICV error
|
dot11RSNAStatsTKIPICVErrors Increments when a MPDU discarded by TKIP ICV error //(use of WEP/TKIP is not recommended anymore)
|
||||||
|
|
||||||
dot11RSNAStatsTKIPReplays Increments when a MPDU discarded by TKIP replay error
|
dot11RSNAStatsTKIPReplays Increments when a MPDU discarded by TKIP replay error //(use of WEP/TKIP is not recommended anymore)
|
||||||
|
|
||||||
dot11RSNAStatsCCMPDecryptErrors Increments when a MPDU discarded by CCMP decryption error
|
dot11RSNAStatsCCMPDecryptErrors Increments when a MPDU discarded by CCMP decryption error
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,15 @@
|
||||||
|
# File : ed_mac_ctrl_V1_8801.conf
|
||||||
|
#
|
||||||
|
# ./mlanutl mlan0 hostcmd config/ed_mac_ctrl_V1_8801.conf ed_mac_ctrl
|
||||||
|
#
|
||||||
|
#
|
||||||
|
## Set Energy Detect Threshold for EU Adaptivity test
|
||||||
|
|
||||||
|
ed_mac_ctrl={
|
||||||
|
CmdCode=0x0124 #Command code, DO NOT change this line
|
||||||
|
Enable:2=0x1 # 0 - disable EU adaptivity
|
||||||
|
# 1 - enable EU adaptivity
|
||||||
|
|
||||||
|
Offset:2=0x1b # 0 - Default Energy Detect threshold
|
||||||
|
#offset value range: 0x80 to 0x7F
|
||||||
|
}
|
|
@ -1588,7 +1588,11 @@ static int process_getlog(int argc, char *argv[])
|
||||||
"gOwnrshpCtlErrCnt %u\n"
|
"gOwnrshpCtlErrCnt %u\n"
|
||||||
"gOwnrshpBcnErrCnt %u\n"
|
"gOwnrshpBcnErrCnt %u\n"
|
||||||
"gOwnrshpMgtErrCnt %u\n"
|
"gOwnrshpMgtErrCnt %u\n"
|
||||||
"gOwnrshpDatErrCnt %u\n",
|
"gOwnrshpDatErrCnt %u\n"
|
||||||
|
"bigtk_mmeGoodCnt %u\n"
|
||||||
|
"bigtk_replayErrCnt %u\n"
|
||||||
|
"bigtk_micErrCnt %u\n"
|
||||||
|
"bigtk_mmeNotFoundCnt %u\n",
|
||||||
stats->rx_stuck_issue_cnt[0],
|
stats->rx_stuck_issue_cnt[0],
|
||||||
stats->rx_stuck_issue_cnt[1],
|
stats->rx_stuck_issue_cnt[1],
|
||||||
stats->rx_stuck_recovery_cnt, stats->rx_stuck_tsf[0],
|
stats->rx_stuck_recovery_cnt, stats->rx_stuck_tsf[0],
|
||||||
|
@ -1601,7 +1605,9 @@ static int process_getlog(int argc, char *argv[])
|
||||||
stats->rx_Isr2_NotDone_Cnt, stats->gdma_abort_cnt,
|
stats->rx_Isr2_NotDone_Cnt, stats->gdma_abort_cnt,
|
||||||
stats->g_reset_rx_mac_cnt, stats->dwCtlErrCnt,
|
stats->g_reset_rx_mac_cnt, stats->dwCtlErrCnt,
|
||||||
stats->dwBcnErrCnt, stats->dwMgtErrCnt,
|
stats->dwBcnErrCnt, stats->dwMgtErrCnt,
|
||||||
stats->dwDatErrCnt);
|
stats->dwDatErrCnt, stats->bigtk_mmeGoodCnt,
|
||||||
|
stats->bigtk_replayErrCnt, stats->bigtk_micErrCnt,
|
||||||
|
stats->bigtk_mmeNotFoundCnt);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (cmd->used_len == sizeof(struct eth_priv_get_log)) {
|
if (cmd->used_len == sizeof(struct eth_priv_get_log)) {
|
||||||
|
|
|
@ -374,6 +374,14 @@ struct eth_priv_get_log {
|
||||||
t_u32 dwMgtErrCnt;
|
t_u32 dwMgtErrCnt;
|
||||||
/*Control Ownership error count*/
|
/*Control Ownership error count*/
|
||||||
t_u32 dwDatErrCnt;
|
t_u32 dwDatErrCnt;
|
||||||
|
/*BIGTK MME good count*/
|
||||||
|
t_u32 bigtk_mmeGoodCnt;
|
||||||
|
/*BIGTK Replay error count*/
|
||||||
|
t_u32 bigtk_replayErrCnt;
|
||||||
|
/*BIGTK MIC error count*/
|
||||||
|
t_u32 bigtk_micErrCnt;
|
||||||
|
/*BIGTK MME not included count*/
|
||||||
|
t_u32 bigtk_mmeNotFoundCnt;
|
||||||
};
|
};
|
||||||
|
|
||||||
/** MLAN MAC Address Length */
|
/** MLAN MAC Address Length */
|
||||||
|
|
|
@ -29,8 +29,6 @@
|
||||||
#include "mlan_11n.h"
|
#include "mlan_11n.h"
|
||||||
#include "mlan_11ac.h"
|
#include "mlan_11ac.h"
|
||||||
|
|
||||||
#define NO_NSS_SUPPORT 0x3
|
|
||||||
|
|
||||||
/********************************************************
|
/********************************************************
|
||||||
Local Variables
|
Local Variables
|
||||||
********************************************************/
|
********************************************************/
|
||||||
|
@ -197,7 +195,6 @@ static void wlan_fill_cap_info(mlan_private *priv, VHT_capa_t *vht_cap,
|
||||||
t_u8 bands)
|
t_u8 bands)
|
||||||
{
|
{
|
||||||
t_u32 usr_dot_11ac_dev_cap;
|
t_u32 usr_dot_11ac_dev_cap;
|
||||||
|
|
||||||
ENTER();
|
ENTER();
|
||||||
|
|
||||||
if (bands & BAND_A)
|
if (bands & BAND_A)
|
||||||
|
@ -207,6 +204,7 @@ static void wlan_fill_cap_info(mlan_private *priv, VHT_capa_t *vht_cap,
|
||||||
|
|
||||||
vht_cap->vht_cap_info = usr_dot_11ac_dev_cap;
|
vht_cap->vht_cap_info = usr_dot_11ac_dev_cap;
|
||||||
|
|
||||||
|
RESET_VHTCAP_MAXMPDULEN(vht_cap->vht_cap_info);
|
||||||
LEAVE();
|
LEAVE();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -163,6 +163,10 @@ t_u16 wlan_fill_he_cap_tlv(mlan_private *pmpriv, t_u8 band,
|
||||||
t_u16 rx_nss = 0, tx_nss = 0;
|
t_u16 rx_nss = 0, tx_nss = 0;
|
||||||
#endif
|
#endif
|
||||||
MrvlIEtypes_He_cap_t *phecap = MNULL;
|
MrvlIEtypes_He_cap_t *phecap = MNULL;
|
||||||
|
t_u8 nss = 0;
|
||||||
|
t_u16 cfg_value = 0;
|
||||||
|
t_u16 hw_value = 0;
|
||||||
|
MrvlIEtypes_He_cap_t *phw_hecap = MNULL;
|
||||||
|
|
||||||
if (!phe_cap) {
|
if (!phe_cap) {
|
||||||
LEAVE();
|
LEAVE();
|
||||||
|
@ -173,11 +177,13 @@ t_u16 wlan_fill_he_cap_tlv(mlan_private *pmpriv, t_u8 band,
|
||||||
pmpriv->user_hecap_len,
|
pmpriv->user_hecap_len,
|
||||||
sizeof(MrvlIEtypes_He_cap_t));
|
sizeof(MrvlIEtypes_He_cap_t));
|
||||||
len = pmpriv->user_hecap_len;
|
len = pmpriv->user_hecap_len;
|
||||||
|
phw_hecap = (MrvlIEtypes_He_cap_t *)pmadapter->hw_he_cap;
|
||||||
} else {
|
} else {
|
||||||
memcpy_ext(pmadapter, (t_u8 *)phe_cap, pmpriv->user_2g_he_cap,
|
memcpy_ext(pmadapter, (t_u8 *)phe_cap, pmpriv->user_2g_he_cap,
|
||||||
pmpriv->user_2g_hecap_len,
|
pmpriv->user_2g_hecap_len,
|
||||||
sizeof(MrvlIEtypes_He_cap_t));
|
sizeof(MrvlIEtypes_He_cap_t));
|
||||||
len = pmpriv->user_2g_hecap_len;
|
len = pmpriv->user_2g_hecap_len;
|
||||||
|
phw_hecap = (MrvlIEtypes_He_cap_t *)pmadapter->hw_2g_he_cap;
|
||||||
}
|
}
|
||||||
phe_cap->type = wlan_cpu_to_le16(phe_cap->type);
|
phe_cap->type = wlan_cpu_to_le16(phe_cap->type);
|
||||||
phe_cap->len = wlan_cpu_to_le16(phe_cap->len);
|
phe_cap->len = wlan_cpu_to_le16(phe_cap->len);
|
||||||
|
@ -199,18 +205,39 @@ t_u16 wlan_fill_he_cap_tlv(mlan_private *pmpriv, t_u8 band,
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
phecap = (MrvlIEtypes_He_cap_t *)phe_cap;
|
phecap = (MrvlIEtypes_He_cap_t *)phe_cap;
|
||||||
phecap->rx_mcs_80 = wlan_cpu_to_le16(0xfffe);
|
for (nss = 1; nss <= 8; nss++) {
|
||||||
phecap->tx_mcs_80 = wlan_cpu_to_le16(0xfffe);
|
cfg_value = GET_HE_NSSMCS(phecap->rx_mcs_80, nss);
|
||||||
|
hw_value = GET_HE_NSSMCS(phw_hecap->rx_mcs_80, nss);
|
||||||
#if defined(PCIE9098) || defined(SD9098) || defined(USB9098) || \
|
#if defined(PCIE9098) || defined(SD9098) || defined(USB9098) || \
|
||||||
defined(PCIE9097) || defined(SD9097) || defined(USB9097)
|
defined(PCIE9097) || defined(SD9097) || defined(USB9097)
|
||||||
if (IS_CARD9098(pmpriv->adapter->card_type) ||
|
if ((rx_nss != 0) && (nss > rx_nss))
|
||||||
IS_CARD9097(pmpriv->adapter->card_type)) {
|
cfg_value = NO_NSS_SUPPORT;
|
||||||
if (rx_nss == 2)
|
|
||||||
phecap->rx_mcs_80 = wlan_cpu_to_le16(0xfffa);
|
|
||||||
if (tx_nss == 2)
|
|
||||||
phecap->tx_mcs_80 = wlan_cpu_to_le16(0xfffa);
|
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
|
if ((hw_value == NO_NSS_SUPPORT) ||
|
||||||
|
(cfg_value == NO_NSS_SUPPORT))
|
||||||
|
SET_HE_NSSMCS(phecap->rx_mcs_80, nss, NO_NSS_SUPPORT);
|
||||||
|
else
|
||||||
|
SET_HE_NSSMCS(phecap->rx_mcs_80, nss,
|
||||||
|
MIN(cfg_value, hw_value));
|
||||||
|
}
|
||||||
|
for (nss = 1; nss <= 8; nss++) {
|
||||||
|
cfg_value = GET_HE_NSSMCS(phecap->tx_mcs_80, nss);
|
||||||
|
hw_value = GET_HE_NSSMCS(phw_hecap->tx_mcs_80, nss);
|
||||||
|
#if defined(PCIE9098) || defined(SD9098) || defined(USB9098) || \
|
||||||
|
defined(PCIE9097) || defined(SD9097) || defined(USB9097)
|
||||||
|
if ((tx_nss != 0) && (nss > tx_nss))
|
||||||
|
cfg_value = NO_NSS_SUPPORT;
|
||||||
|
#endif
|
||||||
|
if ((hw_value == NO_NSS_SUPPORT) ||
|
||||||
|
(cfg_value == NO_NSS_SUPPORT))
|
||||||
|
SET_HE_NSSMCS(phecap->tx_mcs_80, nss, NO_NSS_SUPPORT);
|
||||||
|
else
|
||||||
|
SET_HE_NSSMCS(phecap->tx_mcs_80, nss,
|
||||||
|
MIN(cfg_value, hw_value));
|
||||||
|
}
|
||||||
|
PRINTM(MCMND, "Set: HE rx mcs set 0x%08x tx mcs set 0x%08x\n",
|
||||||
|
phecap->rx_mcs_80, phecap->tx_mcs_80);
|
||||||
|
|
||||||
DBG_HEXDUMP(MCMD_D, "fill_11ax_tlv", (t_u8 *)phecap, len);
|
DBG_HEXDUMP(MCMD_D, "fill_11ax_tlv", (t_u8 *)phecap, len);
|
||||||
LEAVE();
|
LEAVE();
|
||||||
return len;
|
return len;
|
||||||
|
@ -236,6 +263,10 @@ int wlan_cmd_append_11ax_tlv(mlan_private *pmpriv, BSSDescriptor_t *pbss_desc,
|
||||||
defined(PCIE9097) || defined(SD9097) || defined(USB9097)
|
defined(PCIE9097) || defined(SD9097) || defined(USB9097)
|
||||||
t_u16 rx_nss = 0, tx_nss = 0;
|
t_u16 rx_nss = 0, tx_nss = 0;
|
||||||
#endif
|
#endif
|
||||||
|
t_u8 nss = 0;
|
||||||
|
t_u16 cfg_value = 0;
|
||||||
|
t_u16 hw_value = 0;
|
||||||
|
MrvlIEtypes_He_cap_t *phw_hecap = MNULL;
|
||||||
|
|
||||||
ENTER();
|
ENTER();
|
||||||
|
|
||||||
|
@ -260,12 +291,14 @@ int wlan_cmd_append_11ax_tlv(mlan_private *pmpriv, BSSDescriptor_t *pbss_desc,
|
||||||
pmpriv->user_hecap_len, pmpriv->user_hecap_len);
|
pmpriv->user_hecap_len, pmpriv->user_hecap_len);
|
||||||
*ppbuffer += pmpriv->user_hecap_len;
|
*ppbuffer += pmpriv->user_hecap_len;
|
||||||
len = pmpriv->user_hecap_len;
|
len = pmpriv->user_hecap_len;
|
||||||
|
phw_hecap = (MrvlIEtypes_He_cap_t *)pmadapter->hw_he_cap;
|
||||||
} else {
|
} else {
|
||||||
memcpy_ext(pmadapter, *ppbuffer, pmpriv->user_2g_he_cap,
|
memcpy_ext(pmadapter, *ppbuffer, pmpriv->user_2g_he_cap,
|
||||||
pmpriv->user_2g_hecap_len,
|
pmpriv->user_2g_hecap_len,
|
||||||
pmpriv->user_2g_hecap_len);
|
pmpriv->user_2g_hecap_len);
|
||||||
*ppbuffer += pmpriv->user_2g_hecap_len;
|
*ppbuffer += pmpriv->user_2g_hecap_len;
|
||||||
len = pmpriv->user_2g_hecap_len;
|
len = pmpriv->user_2g_hecap_len;
|
||||||
|
phw_hecap = (MrvlIEtypes_He_cap_t *)pmadapter->hw_2g_he_cap;
|
||||||
}
|
}
|
||||||
phecap->type = wlan_cpu_to_le16(phecap->type);
|
phecap->type = wlan_cpu_to_le16(phecap->type);
|
||||||
phecap->len = wlan_cpu_to_le16(phecap->len);
|
phecap->len = wlan_cpu_to_le16(phecap->len);
|
||||||
|
@ -289,18 +322,38 @@ int wlan_cmd_append_11ax_tlv(mlan_private *pmpriv, BSSDescriptor_t *pbss_desc,
|
||||||
rx_nss = tx_nss = 1;
|
rx_nss = tx_nss = 1;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
phecap->rx_mcs_80 = wlan_cpu_to_le16(0xfffe);
|
for (nss = 1; nss <= 8; nss++) {
|
||||||
phecap->tx_mcs_80 = wlan_cpu_to_le16(0xfffe);
|
cfg_value = GET_HE_NSSMCS(phecap->rx_mcs_80, nss);
|
||||||
|
hw_value = GET_HE_NSSMCS(phw_hecap->rx_mcs_80, nss);
|
||||||
#if defined(PCIE9098) || defined(SD9098) || defined(USB9098) || \
|
#if defined(PCIE9098) || defined(SD9098) || defined(USB9098) || \
|
||||||
defined(PCIE9097) || defined(SD9097) || defined(USB9097)
|
defined(PCIE9097) || defined(SD9097) || defined(USB9097)
|
||||||
if (IS_CARD9098(pmpriv->adapter->card_type) ||
|
if ((rx_nss != 0) && (nss > rx_nss))
|
||||||
IS_CARD9097(pmpriv->adapter->card_type)) {
|
cfg_value = NO_NSS_SUPPORT;
|
||||||
if (rx_nss == 2)
|
|
||||||
phecap->rx_mcs_80 = wlan_cpu_to_le16(0xfffa);
|
|
||||||
if (tx_nss == 2)
|
|
||||||
phecap->tx_mcs_80 = wlan_cpu_to_le16(0xfffa);
|
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
|
if ((hw_value == NO_NSS_SUPPORT) ||
|
||||||
|
(cfg_value == NO_NSS_SUPPORT))
|
||||||
|
SET_HE_NSSMCS(phecap->rx_mcs_80, nss, NO_NSS_SUPPORT);
|
||||||
|
else
|
||||||
|
SET_HE_NSSMCS(phecap->rx_mcs_80, nss,
|
||||||
|
MIN(cfg_value, hw_value));
|
||||||
|
}
|
||||||
|
for (nss = 1; nss <= 8; nss++) {
|
||||||
|
cfg_value = GET_HE_NSSMCS(phecap->tx_mcs_80, nss);
|
||||||
|
hw_value = GET_HE_NSSMCS(phw_hecap->tx_mcs_80, nss);
|
||||||
|
#if defined(PCIE9098) || defined(SD9098) || defined(USB9098) || \
|
||||||
|
defined(PCIE9097) || defined(SD9097) || defined(USB9097)
|
||||||
|
if ((tx_nss != 0) && (nss > tx_nss))
|
||||||
|
cfg_value = NO_NSS_SUPPORT;
|
||||||
|
#endif
|
||||||
|
if ((hw_value == NO_NSS_SUPPORT) ||
|
||||||
|
(cfg_value == NO_NSS_SUPPORT))
|
||||||
|
SET_HE_NSSMCS(phecap->tx_mcs_80, nss, NO_NSS_SUPPORT);
|
||||||
|
else
|
||||||
|
SET_HE_NSSMCS(phecap->tx_mcs_80, nss,
|
||||||
|
MIN(cfg_value, hw_value));
|
||||||
|
}
|
||||||
|
PRINTM(MCMND, "Set: HE rx mcs set 0x%08x tx mcs set 0x%08x\n",
|
||||||
|
phecap->rx_mcs_80, phecap->tx_mcs_80);
|
||||||
if (!bw_80p80) {
|
if (!bw_80p80) {
|
||||||
/** reset BIT3 and BIT4 channel width ,not support 80 + 80*/
|
/** reset BIT3 and BIT4 channel width ,not support 80 + 80*/
|
||||||
/** not support 160Mhz now, if support,not reset bit3 */
|
/** not support 160Mhz now, if support,not reset bit3 */
|
||||||
|
|
|
@ -28,6 +28,16 @@
|
||||||
/** device support 2.4G 242 tone RUs */
|
/** device support 2.4G 242 tone RUs */
|
||||||
#define AX_2G_20MHZ_SUPPORT MBIT(5)
|
#define AX_2G_20MHZ_SUPPORT MBIT(5)
|
||||||
|
|
||||||
|
/*
|
||||||
|
* 0 indicates support for HE-MCS 0-7 for n spatial streams
|
||||||
|
* 1 indicates support for HE-MCS 0-9 for n spatial streams
|
||||||
|
* 2 indicates support for HE-MCS 0-11 for n spatial streams
|
||||||
|
* 3 indicates that n spatial streams is not supported for HE PPDUs
|
||||||
|
*/
|
||||||
|
#define GET_HE_NSSMCS(MCSMapSet, nss) ((MCSMapSet >> (2 * (nss - 1))) & 0x3)
|
||||||
|
#define SET_HE_NSSMCS(MCSMapSet, nss, value) \
|
||||||
|
(MCSMapSet |= (value & 0x3) << (2 * (nss - 1)))
|
||||||
|
|
||||||
t_u8 wlan_check_11ax_twt_supported(mlan_private *pmpriv,
|
t_u8 wlan_check_11ax_twt_supported(mlan_private *pmpriv,
|
||||||
BSSDescriptor_t *pbss_desc);
|
BSSDescriptor_t *pbss_desc);
|
||||||
mlan_status wlan_11ax_ioctl_twtcfg(pmlan_adapter pmadapter,
|
mlan_status wlan_11ax_ioctl_twtcfg(pmlan_adapter pmadapter,
|
||||||
|
|
|
@ -1306,6 +1306,8 @@ wlan_11h_prepare_custom_ie_chansw(mlan_adapter *pmadapter,
|
||||||
pvhttpcEnv_ie->local_max_tp_20mhz = 0xff;
|
pvhttpcEnv_ie->local_max_tp_20mhz = 0xff;
|
||||||
pvhttpcEnv_ie->local_max_tp_40mhz = 0xff;
|
pvhttpcEnv_ie->local_max_tp_40mhz = 0xff;
|
||||||
pvhttpcEnv_ie->local_max_tp_80mhz = 0xff;
|
pvhttpcEnv_ie->local_max_tp_80mhz = 0xff;
|
||||||
|
pvhttpcEnv_ie->local_max_tp_160mhz_80_80mhz =
|
||||||
|
0xff;
|
||||||
pChanSwWrap_ie->len +=
|
pChanSwWrap_ie->len +=
|
||||||
sizeof(IEEEtypes_VhtTpcEnvelope_t);
|
sizeof(IEEEtypes_VhtTpcEnvelope_t);
|
||||||
|
|
||||||
|
|
|
@ -230,6 +230,13 @@ mlan_status wlan_11n_deaggregate_pkt(mlan_private *priv, pmlan_buffer pmbuf)
|
||||||
t_u8 hdr_len = sizeof(Eth803Hdr_t);
|
t_u8 hdr_len = sizeof(Eth803Hdr_t);
|
||||||
t_u8 eapol_type[2] = {0x88, 0x8e};
|
t_u8 eapol_type[2] = {0x88, 0x8e};
|
||||||
t_u8 tdls_action_type[2] = {0x89, 0x0d};
|
t_u8 tdls_action_type[2] = {0x89, 0x0d};
|
||||||
|
t_u32 in_ts_sec, in_ts_usec;
|
||||||
|
t_u32 out_ts_sec, out_ts_usec;
|
||||||
|
t_u32 in_copy_ts_sec, in_copy_ts_usec;
|
||||||
|
t_u32 out_copy_ts_sec, out_copy_ts_usec;
|
||||||
|
pmlan_callbacks pcb = &pmadapter->callbacks;
|
||||||
|
t_u32 copy_delay = 0;
|
||||||
|
t_u32 delay = 0;
|
||||||
|
|
||||||
ENTER();
|
ENTER();
|
||||||
|
|
||||||
|
@ -260,7 +267,9 @@ mlan_status wlan_11n_deaggregate_pkt(mlan_private *priv, pmlan_buffer pmbuf)
|
||||||
total_pkt_len);
|
total_pkt_len);
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
|
if (pmadapter->tp_state_on)
|
||||||
|
pcb->moal_get_system_time(pmadapter->pmoal_handle, &in_ts_sec,
|
||||||
|
&in_ts_usec);
|
||||||
pmbuf->use_count = wlan_11n_get_num_aggrpkts(data, total_pkt_len);
|
pmbuf->use_count = wlan_11n_get_num_aggrpkts(data, total_pkt_len);
|
||||||
|
|
||||||
// rx_trace 7
|
// rx_trace 7
|
||||||
|
@ -321,10 +330,23 @@ mlan_status wlan_11n_deaggregate_pkt(mlan_private *priv, pmlan_buffer pmbuf)
|
||||||
daggr_mbuf->extra_ts_usec = pmbuf->extra_ts_usec;
|
daggr_mbuf->extra_ts_usec = pmbuf->extra_ts_usec;
|
||||||
daggr_mbuf->pparent = pmbuf;
|
daggr_mbuf->pparent = pmbuf;
|
||||||
daggr_mbuf->priority = pmbuf->priority;
|
daggr_mbuf->priority = pmbuf->priority;
|
||||||
|
if (pmadapter->tp_state_on)
|
||||||
|
pcb->moal_get_system_time(pmadapter->pmoal_handle,
|
||||||
|
&in_copy_ts_sec,
|
||||||
|
&in_copy_ts_usec);
|
||||||
memcpy_ext(pmadapter,
|
memcpy_ext(pmadapter,
|
||||||
daggr_mbuf->pbuf + daggr_mbuf->data_offset, data,
|
daggr_mbuf->pbuf + daggr_mbuf->data_offset, data,
|
||||||
pkt_len, daggr_mbuf->data_len);
|
pkt_len, daggr_mbuf->data_len);
|
||||||
|
if (pmadapter->tp_state_on) {
|
||||||
|
pcb->moal_get_system_time(pmadapter->pmoal_handle,
|
||||||
|
&out_copy_ts_sec,
|
||||||
|
&out_copy_ts_usec);
|
||||||
|
copy_delay +=
|
||||||
|
(t_s32)(out_copy_ts_sec - in_copy_ts_sec) *
|
||||||
|
1000000;
|
||||||
|
copy_delay +=
|
||||||
|
(t_s32)(out_copy_ts_usec - in_copy_ts_usec);
|
||||||
|
}
|
||||||
#ifdef UAP_SUPPORT
|
#ifdef UAP_SUPPORT
|
||||||
if (GET_BSS_ROLE(priv) == MLAN_BSS_ROLE_UAP) {
|
if (GET_BSS_ROLE(priv) == MLAN_BSS_ROLE_UAP) {
|
||||||
ret = wlan_uap_recv_packet(priv, daggr_mbuf);
|
ret = wlan_uap_recv_packet(priv, daggr_mbuf);
|
||||||
|
@ -385,6 +407,14 @@ mlan_status wlan_11n_deaggregate_pkt(mlan_private *priv, pmlan_buffer pmbuf)
|
||||||
|
|
||||||
data += pkt_len + pad;
|
data += pkt_len + pad;
|
||||||
}
|
}
|
||||||
|
if (pmadapter->tp_state_on) {
|
||||||
|
pcb->moal_get_system_time(pmadapter->pmoal_handle, &out_ts_sec,
|
||||||
|
&out_ts_usec);
|
||||||
|
delay += (t_s32)(out_ts_sec - in_ts_sec) * 1000000;
|
||||||
|
delay += (t_s32)(out_ts_usec - in_ts_usec);
|
||||||
|
pmadapter->callbacks.moal_amsdu_tp_accounting(
|
||||||
|
pmadapter->pmoal_handle, delay, copy_delay);
|
||||||
|
}
|
||||||
|
|
||||||
done:
|
done:
|
||||||
priv->msdu_in_rx_amsdu_cnt += pmbuf->use_count;
|
priv->msdu_in_rx_amsdu_cnt += pmbuf->use_count;
|
||||||
|
|
|
@ -2214,6 +2214,7 @@ t_u32 wlan_get_supported_rates(mlan_private *pmpriv, t_u32 bss_mode,
|
||||||
case BAND_B | BAND_G:
|
case BAND_B | BAND_G:
|
||||||
case BAND_A | BAND_B | BAND_G:
|
case BAND_A | BAND_B | BAND_G:
|
||||||
case BAND_A | BAND_B:
|
case BAND_A | BAND_B:
|
||||||
|
case BAND_A | BAND_B | BAND_G | BAND_GN:
|
||||||
case BAND_A | BAND_B | BAND_G | BAND_GN | BAND_AN:
|
case BAND_A | BAND_B | BAND_G | BAND_GN | BAND_AN:
|
||||||
case BAND_A | BAND_B | BAND_G | BAND_GN | BAND_AN | BAND_AAC:
|
case BAND_A | BAND_B | BAND_G | BAND_GN | BAND_AN | BAND_AAC:
|
||||||
case BAND_A | BAND_B | BAND_G | BAND_GN | BAND_AN | BAND_AAC |
|
case BAND_A | BAND_B | BAND_G | BAND_GN | BAND_AN | BAND_AAC |
|
||||||
|
|
|
@ -83,6 +83,104 @@ done:
|
||||||
LEAVE();
|
LEAVE();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief This function check if cmd allowed to send to firmware
|
||||||
|
* during scan
|
||||||
|
*
|
||||||
|
* @param cmd_id cmd id
|
||||||
|
*
|
||||||
|
* @return MTRUE/MFALSE
|
||||||
|
*/
|
||||||
|
static t_u8 wlan_is_cmd_allowed_during_scan(t_u16 cmd_id)
|
||||||
|
{
|
||||||
|
t_u8 ret = MTRUE;
|
||||||
|
ENTER();
|
||||||
|
switch (cmd_id) {
|
||||||
|
case HostCmd_CMD_FUNC_INIT:
|
||||||
|
case HostCmd_CMD_CFG_DATA:
|
||||||
|
case HostCmd_CMD_REGION_POWER_CFG:
|
||||||
|
case HostCmd_CHANNEL_TRPC_CONFIG:
|
||||||
|
case HostCmd_CMD_FUNC_SHUTDOWN:
|
||||||
|
case HostCmd_CMD_802_11_ASSOCIATE:
|
||||||
|
case HostCmd_CMD_802_11_DEAUTHENTICATE:
|
||||||
|
case HostCmd_CMD_802_11_DISASSOCIATE:
|
||||||
|
case HostCmd_CMD_802_11_AD_HOC_START:
|
||||||
|
case HostCmd_CMD_802_11_AD_HOC_JOIN:
|
||||||
|
case HostCmd_CMD_802_11_AD_HOC_STOP:
|
||||||
|
case HostCmd_CMD_11N_ADDBA_REQ:
|
||||||
|
case HostCmd_CMD_11N_ADDBA_RSP:
|
||||||
|
case HostCmd_CMD_11N_DELBA:
|
||||||
|
case HostCmd_CMD_802_11_REMAIN_ON_CHANNEL:
|
||||||
|
case HostCmd_CMD_TDLS_CONFIG:
|
||||||
|
case HostCmd_CMD_TDLS_OPERATION:
|
||||||
|
case HostCmd_CMD_SOFT_RESET:
|
||||||
|
#ifdef UAP_SUPPORT
|
||||||
|
case HOST_CMD_APCMD_SYS_RESET:
|
||||||
|
case HOST_CMD_APCMD_BSS_START:
|
||||||
|
case HOST_CMD_APCMD_BSS_STOP:
|
||||||
|
case HOST_CMD_APCMD_STA_DEAUTH:
|
||||||
|
#endif
|
||||||
|
case HostCMD_APCMD_ACS_SCAN:
|
||||||
|
ret = MFALSE;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
LEAVE();
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief This function move the cmd from scan_pending_q to
|
||||||
|
* cmd_pending_q
|
||||||
|
*
|
||||||
|
* @param cmd_id cmd id
|
||||||
|
*
|
||||||
|
* @return MTRUE/MFALSE
|
||||||
|
*/
|
||||||
|
t_void wlan_move_cmd_to_cmd_pending_q(pmlan_adapter pmadapter)
|
||||||
|
{
|
||||||
|
cmd_ctrl_node *pcmd_node = MNULL;
|
||||||
|
|
||||||
|
ENTER();
|
||||||
|
|
||||||
|
wlan_request_cmd_lock(pmadapter);
|
||||||
|
while ((pcmd_node = (cmd_ctrl_node *)util_peek_list(
|
||||||
|
pmadapter->pmoal_handle, &pmadapter->scan_pending_q,
|
||||||
|
MNULL, MNULL))) {
|
||||||
|
util_unlink_list(pmadapter->pmoal_handle,
|
||||||
|
&pmadapter->scan_pending_q,
|
||||||
|
(pmlan_linked_list)pcmd_node, MNULL, MNULL);
|
||||||
|
wlan_insert_cmd_to_pending_q(pmadapter, pcmd_node, MTRUE);
|
||||||
|
}
|
||||||
|
wlan_release_cmd_lock(pmadapter);
|
||||||
|
LEAVE();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief This function inserts command node to scan_pending_q or
|
||||||
|
* cmd_pending_q
|
||||||
|
*
|
||||||
|
* @param pmpriv A pointer to mlan_private structure
|
||||||
|
* @param pcmd_node A pointer to cmd_ctrl_node structure
|
||||||
|
* @return N/A
|
||||||
|
*/
|
||||||
|
|
||||||
|
static t_void wlan_queue_cmd(mlan_private *pmpriv, cmd_ctrl_node *pcmd_node,
|
||||||
|
t_u16 cmd_no)
|
||||||
|
{
|
||||||
|
ENTER();
|
||||||
|
if (pmpriv->adapter->scan_processing &&
|
||||||
|
pmpriv->adapter->ext_scan_type == EXT_SCAN_ENHANCE) {
|
||||||
|
if (MFALSE == wlan_is_cmd_allowed_during_scan(cmd_no)) {
|
||||||
|
wlan_queue_scan_cmd(pmpriv, pcmd_node);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
wlan_insert_cmd_to_pending_q(pmpriv->adapter, pcmd_node, MTRUE);
|
||||||
|
LEAVE();
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Internal function used to flush the scan pending queue
|
* @brief Internal function used to flush the scan pending queue
|
||||||
*
|
*
|
||||||
|
@ -330,7 +428,12 @@ static t_void wlan_dump_info(mlan_adapter *pmadapter, t_u8 reason)
|
||||||
PRINTM(MERROR, "mp_wr_bitmap=0x%x curr_wr_port=0x%x\n",
|
PRINTM(MERROR, "mp_wr_bitmap=0x%x curr_wr_port=0x%x\n",
|
||||||
pmadapter->pcard_sd->mp_wr_bitmap,
|
pmadapter->pcard_sd->mp_wr_bitmap,
|
||||||
pmadapter->pcard_sd->curr_wr_port);
|
pmadapter->pcard_sd->curr_wr_port);
|
||||||
PRINTM(MERROR, "mp_invalid_update=%d\n",
|
PRINTM(MMSG, "mp_data_port_mask = 0x%x\n",
|
||||||
|
pmadapter->pcard_sd->mp_data_port_mask);
|
||||||
|
|
||||||
|
PRINTM(MERROR,
|
||||||
|
"last_recv_rd_bitmap=0x%x mp_invalid_update=%d\n",
|
||||||
|
pmadapter->pcard_sd->last_recv_rd_bitmap,
|
||||||
pmadapter->pcard_sd->mp_invalid_update);
|
pmadapter->pcard_sd->mp_invalid_update);
|
||||||
PRINTM(MERROR, "last_recv_wr_bitmap=0x%x last_mp_index=%d\n",
|
PRINTM(MERROR, "last_recv_wr_bitmap=0x%x last_mp_index=%d\n",
|
||||||
pmadapter->pcard_sd->last_recv_wr_bitmap,
|
pmadapter->pcard_sd->last_recv_wr_bitmap,
|
||||||
|
@ -915,10 +1018,12 @@ static mlan_status wlan_ret_host_cmd(pmlan_private pmpriv,
|
||||||
* @param pmpriv A pointer to mlan_private structure
|
* @param pmpriv A pointer to mlan_private structure
|
||||||
* @param cmd A pointer to HostCmd_DS_COMMAND structure
|
* @param cmd A pointer to HostCmd_DS_COMMAND structure
|
||||||
* @param pdata_buf A pointer to data buffer
|
* @param pdata_buf A pointer to data buffer
|
||||||
|
* @param cmd_no A pointer to cmd_no
|
||||||
* @return MLAN_STATUS_SUCCESS
|
* @return MLAN_STATUS_SUCCESS
|
||||||
*/
|
*/
|
||||||
static mlan_status wlan_cmd_host_cmd(pmlan_private pmpriv,
|
static mlan_status wlan_cmd_host_cmd(pmlan_private pmpriv,
|
||||||
HostCmd_DS_COMMAND *cmd, t_void *pdata_buf)
|
HostCmd_DS_COMMAND *cmd, t_void *pdata_buf,
|
||||||
|
t_u16 *cmd_no)
|
||||||
{
|
{
|
||||||
mlan_ds_misc_cmd *pcmd_ptr = (mlan_ds_misc_cmd *)pdata_buf;
|
mlan_ds_misc_cmd *pcmd_ptr = (mlan_ds_misc_cmd *)pdata_buf;
|
||||||
|
|
||||||
|
@ -927,7 +1032,9 @@ static mlan_status wlan_cmd_host_cmd(pmlan_private pmpriv,
|
||||||
/* Copy the HOST command to command buffer */
|
/* Copy the HOST command to command buffer */
|
||||||
memcpy_ext(pmpriv->adapter, (void *)cmd, pcmd_ptr->cmd, pcmd_ptr->len,
|
memcpy_ext(pmpriv->adapter, (void *)cmd, pcmd_ptr->cmd, pcmd_ptr->len,
|
||||||
MRVDRV_SIZE_OF_CMD_BUFFER);
|
MRVDRV_SIZE_OF_CMD_BUFFER);
|
||||||
PRINTM(MINFO, "Host command size = %d\n", pcmd_ptr->len);
|
*cmd_no = wlan_le16_to_cpu(cmd->command);
|
||||||
|
PRINTM(MCMND, "Prepare Host command: 0x%x size = %d\n", *cmd_no,
|
||||||
|
pcmd_ptr->len);
|
||||||
LEAVE();
|
LEAVE();
|
||||||
return MLAN_STATUS_SUCCESS;
|
return MLAN_STATUS_SUCCESS;
|
||||||
}
|
}
|
||||||
|
@ -972,11 +1079,7 @@ static t_u16 wlan_get_cmd_timeout(t_u16 cmd_id)
|
||||||
case HOST_CMD_APCMD_STA_DEAUTH:
|
case HOST_CMD_APCMD_STA_DEAUTH:
|
||||||
#endif
|
#endif
|
||||||
case HostCMD_APCMD_ACS_SCAN:
|
case HostCMD_APCMD_ACS_SCAN:
|
||||||
#ifdef IMX_SUPPORT
|
|
||||||
timeout = MRVDRV_TIMER_10S;
|
|
||||||
#else
|
|
||||||
timeout = MRVDRV_TIMER_5S;
|
timeout = MRVDRV_TIMER_5S;
|
||||||
#endif
|
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
#ifdef IMX_SUPPORT
|
#ifdef IMX_SUPPORT
|
||||||
|
@ -985,15 +1088,15 @@ static t_u16 wlan_get_cmd_timeout(t_u16 cmd_id)
|
||||||
* timeout are observed for commands like 0x5e, 0x16, 0xd1.
|
* timeout are observed for commands like 0x5e, 0x16, 0xd1.
|
||||||
* Observed that response has come just after default timeout of
|
* Observed that response has come just after default timeout of
|
||||||
* 2 seconds for these commands. This random timeout is not
|
* 2 seconds for these commands. This random timeout is not
|
||||||
* observed when the default timeout is increased to 10 seconds
|
* observed when the default timeout is increased to 5 seconds
|
||||||
* (As an work around, Increase the default timeout to 10
|
* (As an work around, Increase the default timeout to 5
|
||||||
* seconds. Need to further debug exact reason for delay in cmd
|
* seconds. Need to further debug exact reason for delay in cmd
|
||||||
* responses)
|
* responses)
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
timeout = MRVDRV_TIMER_10S;
|
timeout = MRVDRV_TIMER_1S * 5;
|
||||||
#else
|
#else
|
||||||
timeout = MRVDRV_TIMER_1S * 2;
|
timeout = MRVDRV_TIMER_1S * 5;
|
||||||
#endif
|
#endif
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -1717,7 +1820,7 @@ mlan_status wlan_prepare_cmd(mlan_private *pmpriv, t_u16 cmd_no,
|
||||||
cmd_oid, pioctl_buf, pdata_buf,
|
cmd_oid, pioctl_buf, pdata_buf,
|
||||||
cmd_ptr);
|
cmd_ptr);
|
||||||
else {
|
else {
|
||||||
ret = wlan_cmd_host_cmd(pmpriv, cmd_ptr, pdata_buf);
|
ret = wlan_cmd_host_cmd(pmpriv, cmd_ptr, pdata_buf, &cmd_no);
|
||||||
pcmd_node->cmd_flag |= CMD_F_HOSTCMD;
|
pcmd_node->cmd_flag |= CMD_F_HOSTCMD;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1744,7 +1847,7 @@ mlan_status wlan_prepare_cmd(mlan_private *pmpriv, t_u16 cmd_no,
|
||||||
pmadapter->ext_scan && pmadapter->ext_scan_enh &&
|
pmadapter->ext_scan && pmadapter->ext_scan_enh &&
|
||||||
pmadapter->ext_scan_type == EXT_SCAN_ENHANCE) {
|
pmadapter->ext_scan_type == EXT_SCAN_ENHANCE) {
|
||||||
wlan_insert_cmd_to_pending_q(pmadapter, pcmd_node,
|
wlan_insert_cmd_to_pending_q(pmadapter, pcmd_node,
|
||||||
MFALSE);
|
MTRUE);
|
||||||
} else
|
} else
|
||||||
wlan_queue_scan_cmd(pmpriv, pcmd_node);
|
wlan_queue_scan_cmd(pmpriv, pcmd_node);
|
||||||
} else {
|
} else {
|
||||||
|
@ -1755,8 +1858,7 @@ mlan_status wlan_prepare_cmd(mlan_private *pmpriv, t_u16 cmd_no,
|
||||||
wlan_insert_cmd_to_pending_q(pmadapter, pcmd_node,
|
wlan_insert_cmd_to_pending_q(pmadapter, pcmd_node,
|
||||||
MFALSE);
|
MFALSE);
|
||||||
else
|
else
|
||||||
wlan_insert_cmd_to_pending_q(pmadapter, pcmd_node,
|
wlan_queue_cmd(pmpriv, pcmd_node, cmd_no);
|
||||||
MTRUE);
|
|
||||||
#ifdef STA_SUPPORT
|
#ifdef STA_SUPPORT
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -5490,6 +5592,242 @@ mlan_status wlan_ret_p2p_params_config(pmlan_private pmpriv,
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief This function prepares command of GPIO TSF LATCH.
|
||||||
|
*
|
||||||
|
* @param pmpriv A pointer to mlan_private structure
|
||||||
|
* @param cmd A pointer to HostCmd_DS_COMMAND structure
|
||||||
|
* @param cmd_action The action: GET or SET
|
||||||
|
* @param pioctl_buf A pointer to mlan_ioctl_req buf
|
||||||
|
* @param pdata_buf A pointer to data buffer
|
||||||
|
*
|
||||||
|
* @return MLAN_STATUS_SUCCESS
|
||||||
|
*/
|
||||||
|
mlan_status wlan_cmd_gpio_tsf_latch(pmlan_private pmpriv,
|
||||||
|
HostCmd_DS_COMMAND *cmd, t_u16 cmd_action,
|
||||||
|
mlan_ioctl_req *pioctl_buf,
|
||||||
|
t_void *pdata_buf)
|
||||||
|
{
|
||||||
|
HostCmd_DS_GPIO_TSF_LATCH_PARAM_CONFIG *gpio_tsf_config =
|
||||||
|
&cmd->params.gpio_tsf_latch;
|
||||||
|
mlan_ds_gpio_tsf_latch *cfg = (mlan_ds_gpio_tsf_latch *)pdata_buf;
|
||||||
|
mlan_ds_misc_cfg *misc_cfg = (mlan_ds_misc_cfg *)pioctl_buf->pbuf;
|
||||||
|
|
||||||
|
mlan_ds_tsf_info *tsf_info = (mlan_ds_tsf_info *)pdata_buf;
|
||||||
|
MrvlIEtypes_GPIO_TSF_LATCH_CONFIG *gpio_tsf_latch_config = MNULL;
|
||||||
|
MrvlIEtypes_GPIO_TSF_LATCH_REPORT *gpio_tsf_latch_report = MNULL;
|
||||||
|
t_u8 *tlv = MNULL;
|
||||||
|
ENTER();
|
||||||
|
|
||||||
|
cmd->size = sizeof(HostCmd_DS_GPIO_TSF_LATCH_PARAM_CONFIG) + S_DS_GEN;
|
||||||
|
cmd->command = wlan_cpu_to_le16(HOST_CMD_GPIO_TSF_LATCH_PARAM_CONFIG);
|
||||||
|
gpio_tsf_config->action = wlan_cpu_to_le16(cmd_action);
|
||||||
|
if (cmd_action == HostCmd_ACT_GEN_SET) {
|
||||||
|
tlv = (t_u8 *)gpio_tsf_config->tlv_buf;
|
||||||
|
if (misc_cfg->sub_command == MLAN_OID_MISC_GPIO_TSF_LATCH) {
|
||||||
|
gpio_tsf_latch_config =
|
||||||
|
(MrvlIEtypes_GPIO_TSF_LATCH_CONFIG *)tlv;
|
||||||
|
gpio_tsf_latch_config->header.type = wlan_cpu_to_le16(
|
||||||
|
TLV_TYPE_GPIO_TSF_LATCH_CONFIG);
|
||||||
|
gpio_tsf_latch_config->header.len = wlan_cpu_to_le16(
|
||||||
|
sizeof(MrvlIEtypes_GPIO_TSF_LATCH_CONFIG) -
|
||||||
|
sizeof(MrvlIEtypesHeader_t));
|
||||||
|
gpio_tsf_latch_config->clock_sync_mode =
|
||||||
|
cfg->clock_sync_mode;
|
||||||
|
gpio_tsf_latch_config->clock_sync_Role =
|
||||||
|
cfg->clock_sync_Role;
|
||||||
|
gpio_tsf_latch_config->clock_sync_gpio_pin_number =
|
||||||
|
cfg->clock_sync_gpio_pin_number;
|
||||||
|
gpio_tsf_latch_config->clock_sync_gpio_level_toggle =
|
||||||
|
cfg->clock_sync_gpio_level_toggle;
|
||||||
|
gpio_tsf_latch_config->clock_sync_gpio_pulse_width =
|
||||||
|
wlan_cpu_to_le16(
|
||||||
|
cfg->clock_sync_gpio_pulse_width);
|
||||||
|
cmd->size += sizeof(MrvlIEtypes_GPIO_TSF_LATCH_CONFIG);
|
||||||
|
tlv += sizeof(MrvlIEtypes_GPIO_TSF_LATCH_CONFIG);
|
||||||
|
PRINTM(MCMND,
|
||||||
|
"Set GPIO TSF latch config: Mode=%d Role=%d, GPIO Pin Number=%d, GPIO level/toggle=%d GPIO pulse width=%d\n",
|
||||||
|
cfg->clock_sync_mode, cfg->clock_sync_Role,
|
||||||
|
cfg->clock_sync_gpio_pin_number,
|
||||||
|
cfg->clock_sync_gpio_level_toggle,
|
||||||
|
(int)cfg->clock_sync_gpio_pulse_width);
|
||||||
|
}
|
||||||
|
} else if (cmd_action == HostCmd_ACT_GEN_GET) {
|
||||||
|
tlv = (t_u8 *)gpio_tsf_config->tlv_buf;
|
||||||
|
if (misc_cfg->sub_command == MLAN_OID_MISC_GPIO_TSF_LATCH) {
|
||||||
|
gpio_tsf_latch_config =
|
||||||
|
(MrvlIEtypes_GPIO_TSF_LATCH_CONFIG *)tlv;
|
||||||
|
gpio_tsf_latch_config->header.type = wlan_cpu_to_le16(
|
||||||
|
TLV_TYPE_GPIO_TSF_LATCH_CONFIG);
|
||||||
|
gpio_tsf_latch_config->header.len = wlan_cpu_to_le16(
|
||||||
|
sizeof(MrvlIEtypes_GPIO_TSF_LATCH_CONFIG) -
|
||||||
|
sizeof(MrvlIEtypesHeader_t));
|
||||||
|
cmd->size += sizeof(MrvlIEtypes_GPIO_TSF_LATCH_CONFIG);
|
||||||
|
tlv += sizeof(MrvlIEtypes_GPIO_TSF_LATCH_CONFIG);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (misc_cfg->sub_command == MLAN_OID_MISC_GET_TSF_INFO) {
|
||||||
|
gpio_tsf_latch_report =
|
||||||
|
(MrvlIEtypes_GPIO_TSF_LATCH_REPORT *)tlv;
|
||||||
|
gpio_tsf_latch_report->header.type = wlan_cpu_to_le16(
|
||||||
|
TLV_TYPE_GPIO_TSF_LATCH_REPORT);
|
||||||
|
gpio_tsf_latch_report->header.len = wlan_cpu_to_le16(
|
||||||
|
sizeof(MrvlIEtypes_GPIO_TSF_LATCH_REPORT) -
|
||||||
|
sizeof(MrvlIEtypesHeader_t));
|
||||||
|
gpio_tsf_latch_report->tsf_format =
|
||||||
|
wlan_cpu_to_le16(tsf_info->tsf_format);
|
||||||
|
PRINTM(MCMND, "Get TSF info: format=%d\n",
|
||||||
|
tsf_info->tsf_format);
|
||||||
|
cmd->size += sizeof(MrvlIEtypes_GPIO_TSF_LATCH_REPORT);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
cmd->size = wlan_cpu_to_le16(cmd->size);
|
||||||
|
LEAVE();
|
||||||
|
return MLAN_STATUS_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief This function handles the command response of GPIO TSF Latch
|
||||||
|
*
|
||||||
|
* @param pmpriv A pointer to mlan_private structure
|
||||||
|
* @param resp A pointer to HostCmd_DS_COMMAND
|
||||||
|
* @param pioctl_buf A pointer to mlan_ioctl_req structure
|
||||||
|
*
|
||||||
|
* @return MLAN_STATUS_SUCCESS
|
||||||
|
*/
|
||||||
|
mlan_status wlan_ret_gpio_tsf_latch(pmlan_private pmpriv,
|
||||||
|
HostCmd_DS_COMMAND *resp,
|
||||||
|
mlan_ioctl_req *pioctl_buf)
|
||||||
|
{
|
||||||
|
HostCmd_DS_GPIO_TSF_LATCH_PARAM_CONFIG *gpio_tsf_config =
|
||||||
|
&resp->params.gpio_tsf_latch;
|
||||||
|
mlan_ds_misc_cfg *cfg = MNULL;
|
||||||
|
MrvlIEtypes_GPIO_TSF_LATCH_CONFIG *gpio_tsf_latch_config = MNULL;
|
||||||
|
MrvlIEtypes_GPIO_TSF_LATCH_REPORT *gpio_tsf_latch_report = MNULL;
|
||||||
|
MrvlIEtypesHeader_t *tlv = MNULL;
|
||||||
|
t_u16 tlv_buf_left = 0;
|
||||||
|
t_u16 tlv_type = 0;
|
||||||
|
t_u16 tlv_len = 0;
|
||||||
|
|
||||||
|
ENTER();
|
||||||
|
if (wlan_le16_to_cpu(gpio_tsf_config->action) == HostCmd_ACT_GEN_GET) {
|
||||||
|
if (pioctl_buf) {
|
||||||
|
cfg = (mlan_ds_misc_cfg *)pioctl_buf->pbuf;
|
||||||
|
tlv = (MrvlIEtypesHeader_t *)(gpio_tsf_config->tlv_buf);
|
||||||
|
tlv_buf_left =
|
||||||
|
resp->size -
|
||||||
|
(sizeof(HostCmd_DS_GPIO_TSF_LATCH_PARAM_CONFIG) +
|
||||||
|
S_DS_GEN);
|
||||||
|
while (tlv_buf_left >= sizeof(MrvlIEtypesHeader_t)) {
|
||||||
|
tlv_type = wlan_le16_to_cpu(tlv->type);
|
||||||
|
tlv_len = wlan_le16_to_cpu(tlv->len);
|
||||||
|
if (tlv_buf_left <
|
||||||
|
(tlv_len + sizeof(MrvlIEtypesHeader_t))) {
|
||||||
|
PRINTM(MERROR,
|
||||||
|
"Error processing gpio tsf latch config TLVs, bytes left < TLV length\n");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
switch (tlv_type) {
|
||||||
|
case TLV_TYPE_GPIO_TSF_LATCH_CONFIG:
|
||||||
|
if (cfg->sub_command ==
|
||||||
|
MLAN_OID_MISC_GPIO_TSF_LATCH) {
|
||||||
|
gpio_tsf_latch_config =
|
||||||
|
(MrvlIEtypes_GPIO_TSF_LATCH_CONFIG
|
||||||
|
*)tlv;
|
||||||
|
cfg->param.gpio_tsf_latch_config
|
||||||
|
.clock_sync_mode =
|
||||||
|
gpio_tsf_latch_config
|
||||||
|
->clock_sync_mode;
|
||||||
|
cfg->param.gpio_tsf_latch_config
|
||||||
|
.clock_sync_Role =
|
||||||
|
gpio_tsf_latch_config
|
||||||
|
->clock_sync_Role;
|
||||||
|
cfg->param.gpio_tsf_latch_config
|
||||||
|
.clock_sync_gpio_pin_number =
|
||||||
|
gpio_tsf_latch_config
|
||||||
|
->clock_sync_gpio_pin_number;
|
||||||
|
cfg->param.gpio_tsf_latch_config
|
||||||
|
.clock_sync_gpio_level_toggle =
|
||||||
|
gpio_tsf_latch_config
|
||||||
|
->clock_sync_gpio_level_toggle;
|
||||||
|
cfg->param.gpio_tsf_latch_config
|
||||||
|
.clock_sync_gpio_pulse_width =
|
||||||
|
wlan_le16_to_cpu(
|
||||||
|
gpio_tsf_latch_config
|
||||||
|
->clock_sync_gpio_pulse_width);
|
||||||
|
PRINTM(MCMND,
|
||||||
|
"Get GPIO TSF latch config: Mode=%d Role=%d, GPIO Pin Number=%d, GPIO level/toggle=%d GPIO pulse width=%d\n",
|
||||||
|
cfg->param
|
||||||
|
.gpio_tsf_latch_config
|
||||||
|
.clock_sync_mode,
|
||||||
|
cfg->param
|
||||||
|
.gpio_tsf_latch_config
|
||||||
|
.clock_sync_Role,
|
||||||
|
cfg->param
|
||||||
|
.gpio_tsf_latch_config
|
||||||
|
.clock_sync_gpio_pin_number,
|
||||||
|
cfg->param
|
||||||
|
.gpio_tsf_latch_config
|
||||||
|
.clock_sync_gpio_level_toggle,
|
||||||
|
(int)cfg->param
|
||||||
|
.gpio_tsf_latch_config
|
||||||
|
.clock_sync_gpio_pulse_width);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case TLV_TYPE_GPIO_TSF_LATCH_REPORT:
|
||||||
|
if (cfg->sub_command ==
|
||||||
|
MLAN_OID_MISC_GET_TSF_INFO) {
|
||||||
|
gpio_tsf_latch_report =
|
||||||
|
(MrvlIEtypes_GPIO_TSF_LATCH_REPORT
|
||||||
|
*)tlv;
|
||||||
|
cfg->param.tsf_info
|
||||||
|
.tsf_format = wlan_le16_to_cpu(
|
||||||
|
gpio_tsf_latch_report
|
||||||
|
->tsf_format);
|
||||||
|
cfg->param.tsf_info
|
||||||
|
.tsf_info = wlan_le16_to_cpu(
|
||||||
|
gpio_tsf_latch_report
|
||||||
|
->tsf_info);
|
||||||
|
cfg->param.tsf_info
|
||||||
|
.tsf = wlan_le64_to_cpu(
|
||||||
|
gpio_tsf_latch_report
|
||||||
|
->tsf);
|
||||||
|
cfg->param.tsf_info
|
||||||
|
.tsf_offset = wlan_le16_to_cpu(
|
||||||
|
gpio_tsf_latch_report
|
||||||
|
->tsf_offset);
|
||||||
|
PRINTM(MCMND,
|
||||||
|
"Get GPIO TSF latch report : format=%d\n info=%d tsf=%llu offset=%d",
|
||||||
|
cfg->param.tsf_info
|
||||||
|
.tsf_format,
|
||||||
|
cfg->param.tsf_info
|
||||||
|
.tsf_info,
|
||||||
|
cfg->param.tsf_info.tsf,
|
||||||
|
cfg->param.tsf_info
|
||||||
|
.tsf_offset);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
tlv_buf_left -=
|
||||||
|
tlv_len + sizeof(MrvlIEtypesHeader_t);
|
||||||
|
tlv = (MrvlIEtypesHeader_t
|
||||||
|
*)((t_u8 *)tlv + tlv_len +
|
||||||
|
sizeof(MrvlIEtypesHeader_t));
|
||||||
|
}
|
||||||
|
if (cfg->sub_command == MLAN_OID_MISC_GPIO_TSF_LATCH)
|
||||||
|
pioctl_buf->data_read_written =
|
||||||
|
sizeof(mlan_ds_gpio_tsf_latch);
|
||||||
|
else if (cfg->sub_command == MLAN_OID_MISC_GET_TSF_INFO)
|
||||||
|
pioctl_buf->data_read_written =
|
||||||
|
sizeof(mlan_ds_tsf_info);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
LEAVE();
|
||||||
|
return MLAN_STATUS_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief This function prepares command of mimo switch configuration.
|
* @brief This function prepares command of mimo switch configuration.
|
||||||
*
|
*
|
||||||
|
|
|
@ -24,7 +24,7 @@
|
||||||
#define _MLAN_DECL_H_
|
#define _MLAN_DECL_H_
|
||||||
|
|
||||||
/** MLAN release version */
|
/** MLAN release version */
|
||||||
#define MLAN_RELEASE_VERSION "266.p4"
|
#define MLAN_RELEASE_VERSION "283"
|
||||||
|
|
||||||
/** Re-define generic data types for MLAN/MOAL */
|
/** Re-define generic data types for MLAN/MOAL */
|
||||||
/** Signed char (1-byte) */
|
/** Signed char (1-byte) */
|
||||||
|
@ -2039,7 +2039,8 @@ typedef struct _mlan_callbacks {
|
||||||
t_u32 drop_point);
|
t_u32 drop_point);
|
||||||
void (*moal_tp_accounting_rx_param)(t_void *pmoal, unsigned int type,
|
void (*moal_tp_accounting_rx_param)(t_void *pmoal, unsigned int type,
|
||||||
unsigned int rsvd1);
|
unsigned int rsvd1);
|
||||||
|
void (*moal_amsdu_tp_accounting)(t_void *pmoal, t_s32 delay,
|
||||||
|
t_s32 copy_delay);
|
||||||
} mlan_callbacks, *pmlan_callbacks;
|
} mlan_callbacks, *pmlan_callbacks;
|
||||||
|
|
||||||
/** Parameter unchanged, use MLAN default setting */
|
/** Parameter unchanged, use MLAN default setting */
|
||||||
|
@ -2180,6 +2181,8 @@ typedef struct _mlan_device {
|
||||||
t_u32 drv_mode;
|
t_u32 drv_mode;
|
||||||
/** dfs w53 cfg */
|
/** dfs w53 cfg */
|
||||||
t_u8 dfs53cfg;
|
t_u8 dfs53cfg;
|
||||||
|
/** extend enhance scan */
|
||||||
|
t_u8 ext_scan;
|
||||||
} mlan_device, *pmlan_device;
|
} mlan_device, *pmlan_device;
|
||||||
|
|
||||||
/** MLAN API function prototype */
|
/** MLAN API function prototype */
|
||||||
|
@ -2253,4 +2256,9 @@ MLAN_API mlan_status mlan_ioctl(t_void *padapter, pmlan_ioctl_req pioctl_req);
|
||||||
/** mlan select wmm queue */
|
/** mlan select wmm queue */
|
||||||
MLAN_API t_u8 mlan_select_wmm_queue(t_void *padapter, t_u8 bss_num, t_u8 tid);
|
MLAN_API t_u8 mlan_select_wmm_queue(t_void *padapter, t_u8 bss_num, t_u8 tid);
|
||||||
|
|
||||||
|
/** mlan mask host interrupt */
|
||||||
|
MLAN_API mlan_status mlan_disable_host_int(t_void *padapter);
|
||||||
|
/** mlan unmask host interrupt */
|
||||||
|
MLAN_API mlan_status mlan_enable_host_int(t_void *padapter);
|
||||||
|
|
||||||
#endif /* !_MLAN_DECL_H_ */
|
#endif /* !_MLAN_DECL_H_ */
|
||||||
|
|
|
@ -185,6 +185,10 @@ typedef enum _KEY_TYPE_ID {
|
||||||
KEY_TYPE_ID_GCMP_256 = 6,
|
KEY_TYPE_ID_GCMP_256 = 6,
|
||||||
/** Key type : CCMP_256 */
|
/** Key type : CCMP_256 */
|
||||||
KEY_TYPE_ID_CCMP_256 = 7,
|
KEY_TYPE_ID_CCMP_256 = 7,
|
||||||
|
/** Key type : GMAC_128 */
|
||||||
|
KEY_TYPE_ID_BIP_GMAC_128 = 8,
|
||||||
|
/** Key type : GMAC_256 */
|
||||||
|
KEY_TYPE_ID_BIP_GMAC_256 = 9,
|
||||||
} KEY_TYPE_ID;
|
} KEY_TYPE_ID;
|
||||||
|
|
||||||
/** Key Info flag for multicast key */
|
/** Key Info flag for multicast key */
|
||||||
|
@ -222,6 +226,7 @@ typedef enum _KEY_INFO_AES {
|
||||||
#define CMAC_AES_KEY_LEN 16
|
#define CMAC_AES_KEY_LEN 16
|
||||||
/** IGTK key length */
|
/** IGTK key length */
|
||||||
#define WPA_IGTK_KEY_LEN 16
|
#define WPA_IGTK_KEY_LEN 16
|
||||||
|
#define WPA_IGTK_256_KEY_LEN 32
|
||||||
|
|
||||||
/** WAPI key length */
|
/** WAPI key length */
|
||||||
#define WAPI_KEY_LEN 50
|
#define WAPI_KEY_LEN 50
|
||||||
|
@ -326,6 +331,9 @@ typedef enum _WLAN_802_11_WEP_STATUS {
|
||||||
/**TLV type : Host MLME Flag*/
|
/**TLV type : Host MLME Flag*/
|
||||||
#define TLV_TYPE_HOST_MLME (PROPRIETARY_TLV_BASE_ID + 307)
|
#define TLV_TYPE_HOST_MLME (PROPRIETARY_TLV_BASE_ID + 307)
|
||||||
|
|
||||||
|
/** TLV type : AP wacp mode */
|
||||||
|
#define TLV_TYPE_UAP_WACP_MODE (PROPRIETARY_TLV_BASE_ID + 0x147) /* 0x0247 */
|
||||||
|
|
||||||
/** TLV type : Vendor Specific IE */
|
/** TLV type : Vendor Specific IE */
|
||||||
#define TLV_TYPE_VENDOR_SPECIFIC_IE 0x00dd
|
#define TLV_TYPE_VENDOR_SPECIFIC_IE 0x00dd
|
||||||
|
|
||||||
|
@ -359,6 +367,8 @@ typedef enum _WLAN_802_11_WEP_STATUS {
|
||||||
#define TLV_TYPE_WILDCARDSSID (PROPRIETARY_TLV_BASE_ID + 0x12) /* 0x0112 */
|
#define TLV_TYPE_WILDCARDSSID (PROPRIETARY_TLV_BASE_ID + 0x12) /* 0x0112 */
|
||||||
/** TLV type : TSF timestamp */
|
/** TLV type : TSF timestamp */
|
||||||
#define TLV_TYPE_TSFTIMESTAMP (PROPRIETARY_TLV_BASE_ID + 0x13) /* 0x0113 */
|
#define TLV_TYPE_TSFTIMESTAMP (PROPRIETARY_TLV_BASE_ID + 0x13) /* 0x0113 */
|
||||||
|
/** TLV type : ARP filter */
|
||||||
|
#define TLV_TYPE_ARP_FILTER (PROPRIETARY_TLV_BASE_ID + 0x15) /* 0x0115 */
|
||||||
/** TLV type : Beacon RSSI high */
|
/** TLV type : Beacon RSSI high */
|
||||||
#define TLV_TYPE_RSSI_HIGH (PROPRIETARY_TLV_BASE_ID + 0x16) /* 0x0116 */
|
#define TLV_TYPE_RSSI_HIGH (PROPRIETARY_TLV_BASE_ID + 0x16) /* 0x0116 */
|
||||||
/** TLV type : Beacon SNR high */
|
/** TLV type : Beacon SNR high */
|
||||||
|
@ -475,6 +485,10 @@ typedef enum _WLAN_802_11_WEP_STATUS {
|
||||||
/** TLV type : p2p opp ps */
|
/** TLV type : p2p opp ps */
|
||||||
#define TLV_TYPE_WIFI_DIRECT_OPP_PS (PROPRIETARY_TLV_BASE_ID + 0x84)
|
#define TLV_TYPE_WIFI_DIRECT_OPP_PS (PROPRIETARY_TLV_BASE_ID + 0x84)
|
||||||
#endif /* WIFI_DIRECT_SUPPORT */
|
#endif /* WIFI_DIRECT_SUPPORT */
|
||||||
|
/** TLV type : GPIO TSF LATCH CONFIG */
|
||||||
|
#define TLV_TYPE_GPIO_TSF_LATCH_CONFIG (PROPRIETARY_TLV_BASE_ID + 0x153)
|
||||||
|
/** TLV type : GPIO TSF LATCH REPORT*/
|
||||||
|
#define TLV_TYPE_GPIO_TSF_LATCH_REPORT (PROPRIETARY_TLV_BASE_ID + 0x154)
|
||||||
|
|
||||||
/** TLV : 20/40 coex config */
|
/** TLV : 20/40 coex config */
|
||||||
#define TLV_TYPE_2040_BSS_COEX_CONTROL \
|
#define TLV_TYPE_2040_BSS_COEX_CONTROL \
|
||||||
|
@ -884,6 +898,9 @@ typedef enum _WLAN_802_11_WEP_STATUS {
|
||||||
|
|
||||||
/** Set VHT Cap Info: Max MPDU length */
|
/** Set VHT Cap Info: Max MPDU length */
|
||||||
#define SET_VHTCAP_MAXMPDULEN(VHTCapInfo, value) (VHTCapInfo |= (value & 0x03))
|
#define SET_VHTCAP_MAXMPDULEN(VHTCapInfo, value) (VHTCapInfo |= (value & 0x03))
|
||||||
|
/** Reset VHT Cap Info: Max MPDU length */
|
||||||
|
#define RESET_VHTCAP_MAXMPDULEN(VHTCapInfo) (VHTCapInfo &= ~(MBIT(0) | MBIT(1)))
|
||||||
|
|
||||||
/** SET VHT CapInfo: Supported Channel Width SET (2 bits)*/
|
/** SET VHT CapInfo: Supported Channel Width SET (2 bits)*/
|
||||||
#define SET_VHTCAP_CHWDSET(VHTCapInfo, value) \
|
#define SET_VHTCAP_CHWDSET(VHTCapInfo, value) \
|
||||||
(VHTCapInfo |= ((value & 0x3) << 2))
|
(VHTCapInfo |= ((value & 0x3) << 2))
|
||||||
|
@ -978,6 +995,7 @@ typedef enum _WLAN_802_11_WEP_STATUS {
|
||||||
#define SET_OPER_MODE_1NSS(oper_mode) \
|
#define SET_OPER_MODE_1NSS(oper_mode) \
|
||||||
(oper_mode &= ~(MBIT(4) | MBIT(5) | MBIT(6)))
|
(oper_mode &= ~(MBIT(4) | MBIT(5) | MBIT(6)))
|
||||||
|
|
||||||
|
#define NO_NSS_SUPPORT 0x3
|
||||||
#define GET_VHTMCS(MCSMapSet) (MCSMapSet & 0xFFFF)
|
#define GET_VHTMCS(MCSMapSet) (MCSMapSet & 0xFFFF)
|
||||||
#define GET_VHTNSSMCS(MCSMapSet, nss) ((MCSMapSet >> (2 * (nss - 1))) & 0x3)
|
#define GET_VHTNSSMCS(MCSMapSet, nss) ((MCSMapSet >> (2 * (nss - 1))) & 0x3)
|
||||||
#define RET_VHTNSSMCS(MCSMapSet, nss) ((MCSMapSet >> (2 * (nss - 1))) & 0x3)
|
#define RET_VHTNSSMCS(MCSMapSet, nss) ((MCSMapSet >> (2 * (nss - 1))) & 0x3)
|
||||||
|
@ -1356,6 +1374,8 @@ typedef enum _WLAN_802_11_WEP_STATUS {
|
||||||
#define FW_CAPINFO_EXT_NO_80MHZ MBIT(8)
|
#define FW_CAPINFO_EXT_NO_80MHZ MBIT(8)
|
||||||
/** FW cap info bit 9: Multi BSSID Support */
|
/** FW cap info bit 9: Multi BSSID Support */
|
||||||
#define FW_CAPINFO_EXT_MULTI_BSSID MBIT(9)
|
#define FW_CAPINFO_EXT_MULTI_BSSID MBIT(9)
|
||||||
|
/** FW cap info bit 10: Beacon Protection Support */
|
||||||
|
#define FW_CAPINFO_EXT_BEACON_PROT MBIT(10)
|
||||||
|
|
||||||
/** Check if 5G 1x1 only is supported by firmware */
|
/** Check if 5G 1x1 only is supported by firmware */
|
||||||
#define IS_FW_SUPPORT_5G_1X1_ONLY(_adapter) \
|
#define IS_FW_SUPPORT_5G_1X1_ONLY(_adapter) \
|
||||||
|
@ -1384,6 +1404,9 @@ typedef enum _WLAN_802_11_WEP_STATUS {
|
||||||
/** Check if Multi BSSID supported by firmware */
|
/** Check if Multi BSSID supported by firmware */
|
||||||
#define IS_FW_SUPPORT_MULTIBSSID(_adapter) \
|
#define IS_FW_SUPPORT_MULTIBSSID(_adapter) \
|
||||||
(_adapter->fw_cap_ext & FW_CAPINFO_EXT_MULTI_BSSID)
|
(_adapter->fw_cap_ext & FW_CAPINFO_EXT_MULTI_BSSID)
|
||||||
|
/** Check if Beacon Protection supported by firmware */
|
||||||
|
#define IS_FW_SUPPORT_BEACON_PROT(_adapter) \
|
||||||
|
(_adapter->fw_cap_ext & FW_CAPINFO_EXT_BEACON_PROT)
|
||||||
|
|
||||||
/** MrvlIEtypes_PrevBssid_t */
|
/** MrvlIEtypes_PrevBssid_t */
|
||||||
typedef MLAN_PACK_START struct _MrvlIEtypes_PrevBssid_t {
|
typedef MLAN_PACK_START struct _MrvlIEtypes_PrevBssid_t {
|
||||||
|
@ -1505,6 +1528,8 @@ typedef MLAN_PACK_START struct _MrvlIEtypes_He_cap_t {
|
||||||
#define HOST_CMD_WIFI_DIRECT_MODE_CONFIG 0x00eb
|
#define HOST_CMD_WIFI_DIRECT_MODE_CONFIG 0x00eb
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/** Host Command ID: GPIO TSF LATCH */
|
||||||
|
#define HOST_CMD_GPIO_TSF_LATCH_PARAM_CONFIG 0x0278
|
||||||
/** Host Command ID: Remain On Channel */
|
/** Host Command ID: Remain On Channel */
|
||||||
#define HostCmd_CMD_802_11_REMAIN_ON_CHANNEL 0x010d
|
#define HostCmd_CMD_802_11_REMAIN_ON_CHANNEL 0x010d
|
||||||
|
|
||||||
|
@ -1544,6 +1569,8 @@ typedef MLAN_PACK_START struct _MrvlIEtypes_He_cap_t {
|
||||||
/** Host Command ID : Configure ADHOC_OVER_IP parameters */
|
/** Host Command ID : Configure ADHOC_OVER_IP parameters */
|
||||||
#define HostCmd_CMD_WMM_PARAM_CONFIG 0x023a
|
#define HostCmd_CMD_WMM_PARAM_CONFIG 0x023a
|
||||||
|
|
||||||
|
#define HostCmd_CMD_IPV6_RA_OFFLOAD_CFG 0x0238
|
||||||
|
|
||||||
#ifdef STA_SUPPORT
|
#ifdef STA_SUPPORT
|
||||||
/** Host Command ID : set/get sta configure */
|
/** Host Command ID : set/get sta configure */
|
||||||
#define HostCmd_CMD_STA_CONFIGURE 0x023f
|
#define HostCmd_CMD_STA_CONFIGURE 0x023f
|
||||||
|
@ -1565,7 +1592,11 @@ typedef MLAN_PACK_START struct _MrvlIEtypes_Reg_type_t {
|
||||||
} MLAN_PACK_END MrvlIEtypes_Reg_type_t;
|
} MLAN_PACK_END MrvlIEtypes_Reg_type_t;
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
/** use to query chan region cfg setting in firmware */
|
||||||
#define HostCmd_CMD_CHAN_REGION_CFG 0x0242
|
#define HostCmd_CMD_CHAN_REGION_CFG 0x0242
|
||||||
|
/** used in hostcmd to download region power cfg setting to firmware */
|
||||||
|
#define HostCmd_CMD_REGION_POWER_CFG 0x0249
|
||||||
|
|
||||||
/* mod_grp */
|
/* mod_grp */
|
||||||
typedef enum _mod_grp {
|
typedef enum _mod_grp {
|
||||||
MOD_CCK, // 0
|
MOD_CCK, // 0
|
||||||
|
@ -1983,7 +2014,7 @@ typedef enum _ENH_PS_MODES {
|
||||||
#define TDLS_EVENT_TYPE_CHAN_SWITCH_STOPPED 9
|
#define TDLS_EVENT_TYPE_CHAN_SWITCH_STOPPED 9
|
||||||
|
|
||||||
/** Packet received on direct link */
|
/** Packet received on direct link */
|
||||||
#define RXPD_FLAG_PKT_DIRECT_LINK 1
|
#define RXPD_FLAG_PKT_DIRECT_LINK MBIT(0)
|
||||||
/** TDLS base channel */
|
/** TDLS base channel */
|
||||||
#define TDLS_BASE_CHANNEL 0
|
#define TDLS_BASE_CHANNEL 0
|
||||||
/** TDLS off channel */
|
/** TDLS off channel */
|
||||||
|
@ -2100,6 +2131,7 @@ typedef MLAN_PACK_START struct _MrvlIEtypes_TDLS_Idle_Timeout_t {
|
||||||
|
|
||||||
/** Packet type: 802.11 */
|
/** Packet type: 802.11 */
|
||||||
#define PKT_TYPE_802DOT11 0x05
|
#define PKT_TYPE_802DOT11 0x05
|
||||||
|
|
||||||
#define PKT_TYPE_MGMT_FRAME 0xE5
|
#define PKT_TYPE_MGMT_FRAME 0xE5
|
||||||
/** Packet type: AMSDU */
|
/** Packet type: AMSDU */
|
||||||
#define PKT_TYPE_AMSDU 0xE6
|
#define PKT_TYPE_AMSDU 0xE6
|
||||||
|
@ -2192,6 +2224,9 @@ typedef MLAN_PACK_START struct _RxPD {
|
||||||
/** rx info */
|
/** rx info */
|
||||||
t_u32 rx_info;
|
t_u32 rx_info;
|
||||||
|
|
||||||
|
/** Reserved */
|
||||||
|
t_u8 reserved3[8];
|
||||||
|
|
||||||
} MLAN_PACK_END RxPD, *PRxPD;
|
} MLAN_PACK_END RxPD, *PRxPD;
|
||||||
|
|
||||||
/** IEEEtypes_FrameCtl_t*/
|
/** IEEEtypes_FrameCtl_t*/
|
||||||
|
@ -2761,6 +2796,16 @@ typedef MLAN_PACK_START struct _cmac_aes_param {
|
||||||
t_u8 key[CMAC_AES_KEY_LEN];
|
t_u8 key[CMAC_AES_KEY_LEN];
|
||||||
} MLAN_PACK_END cmac_aes_param;
|
} MLAN_PACK_END cmac_aes_param;
|
||||||
|
|
||||||
|
/** gmac_aes_256_param */
|
||||||
|
typedef MLAN_PACK_START struct _gmac_aes_256_param {
|
||||||
|
/** IGTK pn */
|
||||||
|
t_u8 ipn[IGTK_PN_SIZE];
|
||||||
|
/** key_len */
|
||||||
|
t_u16 key_len;
|
||||||
|
/** aes key */
|
||||||
|
t_u8 key[WPA_IGTK_256_KEY_LEN];
|
||||||
|
} MLAN_PACK_END gmac_aes_256_param;
|
||||||
|
|
||||||
/** gmac_param */
|
/** gmac_param */
|
||||||
typedef MLAN_PACK_START struct _gcmp_param {
|
typedef MLAN_PACK_START struct _gcmp_param {
|
||||||
/** GCMP pn */
|
/** GCMP pn */
|
||||||
|
@ -2973,6 +3018,39 @@ typedef MLAN_PACK_START struct _HostCmd_DS_CHANNEL_TRPC_CONFIG {
|
||||||
// MrvlIETypes_ChanTRPCConfig_t tlv[];
|
// MrvlIETypes_ChanTRPCConfig_t tlv[];
|
||||||
} MLAN_PACK_END HostCmd_DS_CHANNEL_TRPC_CONFIG;
|
} MLAN_PACK_END HostCmd_DS_CHANNEL_TRPC_CONFIG;
|
||||||
|
|
||||||
|
/** Address type: broadcast */
|
||||||
|
#define ADDR_TYPE_BROADCAST 1
|
||||||
|
/* Address type: unicast */
|
||||||
|
#define ADDR_TYPE_UNICAST 2
|
||||||
|
/* Address type: multicast */
|
||||||
|
#define ADDR_TYPE_MULTICAST 3
|
||||||
|
|
||||||
|
/** Ether type: any */
|
||||||
|
#define ETHER_TYPE_ANY 0xffff
|
||||||
|
/** Ether type: ARP */
|
||||||
|
#define ETHER_TYPE_ARP 0x0608
|
||||||
|
|
||||||
|
/** IPv4 address any */
|
||||||
|
#define IPV4_ADDR_ANY 0xffffffff
|
||||||
|
|
||||||
|
/** Header structure for ARP filter */
|
||||||
|
typedef MLAN_PACK_START struct _arpfilter_header {
|
||||||
|
/** Type */
|
||||||
|
t_u16 type;
|
||||||
|
/** TLV length */
|
||||||
|
t_u16 len;
|
||||||
|
} MLAN_PACK_END arpfilter_header;
|
||||||
|
|
||||||
|
/** Filter entry structure */
|
||||||
|
typedef MLAN_PACK_START struct _filter_entry {
|
||||||
|
/** Address type */
|
||||||
|
t_u16 addr_type;
|
||||||
|
/** Ether type */
|
||||||
|
t_u16 eth_type;
|
||||||
|
/** IPv4 address */
|
||||||
|
t_u32 ipv4_addr;
|
||||||
|
} MLAN_PACK_END filter_entry;
|
||||||
|
|
||||||
typedef MLAN_PACK_START struct _HostCmd_DS_MEF_CFG {
|
typedef MLAN_PACK_START struct _HostCmd_DS_MEF_CFG {
|
||||||
/** Criteria */
|
/** Criteria */
|
||||||
t_u32 criteria;
|
t_u32 criteria;
|
||||||
|
@ -3710,6 +3788,14 @@ typedef MLAN_PACK_START struct _HostCmd_DS_802_11_GET_LOG {
|
||||||
t_u32 dwMgtErrCnt;
|
t_u32 dwMgtErrCnt;
|
||||||
/*Control Ownership error count*/
|
/*Control Ownership error count*/
|
||||||
t_u32 dwDatErrCnt;
|
t_u32 dwDatErrCnt;
|
||||||
|
/*BIGTK MME good count*/
|
||||||
|
t_u32 bigtk_mmeGoodCnt;
|
||||||
|
/*BIGTK Replay error count*/
|
||||||
|
t_u32 bigtk_replayErrCnt;
|
||||||
|
/*BIGTK MIC error count*/
|
||||||
|
t_u32 bigtk_micErrCnt;
|
||||||
|
/*BIGTK MME not included count*/
|
||||||
|
t_u32 bigtk_mmeNotFoundCnt;
|
||||||
} MLAN_PACK_END HostCmd_DS_802_11_GET_LOG;
|
} MLAN_PACK_END HostCmd_DS_802_11_GET_LOG;
|
||||||
|
|
||||||
/* maln wifi rate */
|
/* maln wifi rate */
|
||||||
|
@ -4325,6 +4411,48 @@ typedef MLAN_PACK_START struct _HostCmd_DS_WIFI_DIRECT_PARAM_CONFIG {
|
||||||
} MLAN_PACK_END HostCmd_DS_WIFI_DIRECT_PARAM_CONFIG;
|
} MLAN_PACK_END HostCmd_DS_WIFI_DIRECT_PARAM_CONFIG;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/** MrvlIEtypes_GPIO_TSF_LATCH_CONFIG*/
|
||||||
|
typedef MLAN_PACK_START struct _MrvlIEtypes_GPIO_TSF_LATCH_CONFIG {
|
||||||
|
/** Header */
|
||||||
|
MrvlIEtypesHeader_t header;
|
||||||
|
/**clock sync Mode */
|
||||||
|
t_u8 clock_sync_mode;
|
||||||
|
/**clock sync Role */
|
||||||
|
t_u8 clock_sync_Role;
|
||||||
|
/**clock sync GPIO Pin Number */
|
||||||
|
t_u8 clock_sync_gpio_pin_number;
|
||||||
|
/**clock sync GPIO Level or Toggle */
|
||||||
|
t_u8 clock_sync_gpio_level_toggle;
|
||||||
|
/**clock sync GPIO Pulse Width */
|
||||||
|
t_u16 clock_sync_gpio_pulse_width;
|
||||||
|
|
||||||
|
} MLAN_PACK_END MrvlIEtypes_GPIO_TSF_LATCH_CONFIG;
|
||||||
|
|
||||||
|
/** MrvlIEtypes_GPIO_TSF_LATCH_REPORT */
|
||||||
|
typedef MLAN_PACK_START struct _MrvlIEtypes_GPIO_TSF_LATCH_REPORT {
|
||||||
|
/** Header */
|
||||||
|
MrvlIEtypesHeader_t header;
|
||||||
|
/**get tsf info format */
|
||||||
|
t_u16 tsf_format;
|
||||||
|
/**tsf info */
|
||||||
|
t_u16 tsf_info;
|
||||||
|
/**tsf */
|
||||||
|
t_u64 tsf;
|
||||||
|
/**Positive or negative offset in microsecond from Beacon TSF to GPIO
|
||||||
|
* toggle TSF */
|
||||||
|
t_s32 tsf_offset;
|
||||||
|
} MLAN_PACK_END MrvlIEtypes_GPIO_TSF_LATCH_REPORT;
|
||||||
|
|
||||||
|
/** HostCmd_DS_GPIO_TSF_LATCH_PARAM_CONFIG */
|
||||||
|
typedef MLAN_PACK_START struct _HostCmd_DS_GPIO_TSF_LATCH_PARAM_CONFIG {
|
||||||
|
/** Action 0-GET, 1-SET */
|
||||||
|
t_u16 action;
|
||||||
|
/** MrvlIEtypes_GPIO_TSF_LATCH_CONFIG
|
||||||
|
* MrvlIEtypes_GPIO_TSF_LATCH_REPORT
|
||||||
|
*/
|
||||||
|
t_u8 tlv_buf[];
|
||||||
|
} MLAN_PACK_END HostCmd_DS_GPIO_TSF_LATCH_PARAM_CONFIG;
|
||||||
|
|
||||||
MLAN_PACK_START struct coalesce_filt_field_param {
|
MLAN_PACK_START struct coalesce_filt_field_param {
|
||||||
t_u8 operation;
|
t_u8 operation;
|
||||||
t_u8 operand_len;
|
t_u8 operand_len;
|
||||||
|
@ -6267,6 +6395,14 @@ typedef MLAN_PACK_START struct _MrvlIEtypes_wmm_parameter_t {
|
||||||
WmmParameter_t wmm_para;
|
WmmParameter_t wmm_para;
|
||||||
} MLAN_PACK_END MrvlIEtypes_wmm_parameter_t;
|
} MLAN_PACK_END MrvlIEtypes_wmm_parameter_t;
|
||||||
|
|
||||||
|
/** MrvlIEtypes_wacp_mode_t */
|
||||||
|
typedef MLAN_PACK_START struct _MrvlIEtypes_wacp_mode_t {
|
||||||
|
/** Header */
|
||||||
|
MrvlIEtypesHeader_t header;
|
||||||
|
/** wacp_mode */
|
||||||
|
t_u8 wacp_mode;
|
||||||
|
} MLAN_PACK_END MrvlIEtypes_wacp_mode_t;
|
||||||
|
|
||||||
/** SNMP_MIB_UAP_INDEX */
|
/** SNMP_MIB_UAP_INDEX */
|
||||||
typedef enum _SNMP_MIB_UAP_INDEX {
|
typedef enum _SNMP_MIB_UAP_INDEX {
|
||||||
tkip_mic_failures = 0x0b,
|
tkip_mic_failures = 0x0b,
|
||||||
|
@ -7018,6 +7154,22 @@ typedef MLAN_PACK_START struct _HostCmd_DS_SENSOR_TEMP {
|
||||||
t_u32 temperature;
|
t_u32 temperature;
|
||||||
} MLAN_PACK_END HostCmd_DS_SENSOR_TEMP;
|
} MLAN_PACK_END HostCmd_DS_SENSOR_TEMP;
|
||||||
|
|
||||||
|
#define TLV_TYPE_IPV6_RA_OFFLOAD (PROPRIETARY_TLV_BASE_ID + 0xE6) /** 0x1E6*/
|
||||||
|
typedef MLAN_PACK_START struct {
|
||||||
|
MrvlIEtypesHeader_t Header;
|
||||||
|
t_u8 ipv6_addr[16];
|
||||||
|
} MLAN_PACK_END MrvlIETypes_IPv6AddrParamSet_t;
|
||||||
|
|
||||||
|
typedef MLAN_PACK_START struct _HostCmd_DS_IPV6_RA_OFFLOAD {
|
||||||
|
/** 0x0000: Get IPv6 RA Offload configuration
|
||||||
|
* 0x0001: Set IPv6 RA Offload configuration
|
||||||
|
*/
|
||||||
|
t_u16 action;
|
||||||
|
/** 0x00: disable IPv6 RA Offload; 0x01: enable IPv6 RA offload */
|
||||||
|
t_u8 enable;
|
||||||
|
MrvlIETypes_IPv6AddrParamSet_t ipv6_addr_param;
|
||||||
|
} MLAN_PACK_END HostCmd_DS_IPV6_RA_OFFLOAD;
|
||||||
|
|
||||||
#ifdef STA_SUPPORT
|
#ifdef STA_SUPPORT
|
||||||
typedef MLAN_PACK_START struct _HostCmd_DS_STA_CONFIGURE {
|
typedef MLAN_PACK_START struct _HostCmd_DS_STA_CONFIGURE {
|
||||||
/** Action Set or get */
|
/** Action Set or get */
|
||||||
|
@ -7504,6 +7656,7 @@ typedef struct MLAN_PACK_START _HostCmd_DS_COMMAND {
|
||||||
HostCmd_DS_WIFI_DIRECT_MODE wifi_direct_mode;
|
HostCmd_DS_WIFI_DIRECT_MODE wifi_direct_mode;
|
||||||
HostCmd_DS_WIFI_DIRECT_PARAM_CONFIG p2p_params_config;
|
HostCmd_DS_WIFI_DIRECT_PARAM_CONFIG p2p_params_config;
|
||||||
#endif
|
#endif
|
||||||
|
HostCmd_DS_GPIO_TSF_LATCH_PARAM_CONFIG gpio_tsf_latch;
|
||||||
HostCmd_DS_COALESCE_CONFIG coalesce_config;
|
HostCmd_DS_COALESCE_CONFIG coalesce_config;
|
||||||
HostCmd_DS_HS_WAKEUP_REASON hs_wakeup_reason;
|
HostCmd_DS_HS_WAKEUP_REASON hs_wakeup_reason;
|
||||||
HostCmd_DS_PACKET_AGGR_CTRL aggr_ctrl;
|
HostCmd_DS_PACKET_AGGR_CTRL aggr_ctrl;
|
||||||
|
@ -7520,6 +7673,7 @@ typedef struct MLAN_PACK_START _HostCmd_DS_COMMAND {
|
||||||
HostCmd_DS_SENSOR_TEMP temp_sensor;
|
HostCmd_DS_SENSOR_TEMP temp_sensor;
|
||||||
HostCMD_DS_APCMD_ACS_SCAN acs_scan;
|
HostCMD_DS_APCMD_ACS_SCAN acs_scan;
|
||||||
HostCmd_DS_MIMO_SWITCH mimo_switch;
|
HostCmd_DS_MIMO_SWITCH mimo_switch;
|
||||||
|
HostCmd_DS_IPV6_RA_OFFLOAD ipv6_ra_offload;
|
||||||
#ifdef STA_SUPPORT
|
#ifdef STA_SUPPORT
|
||||||
HostCmd_DS_STA_CONFIGURE sta_cfg;
|
HostCmd_DS_STA_CONFIGURE sta_cfg;
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -1403,6 +1403,8 @@ typedef MLAN_PACK_START struct {
|
||||||
t_u8 local_max_tp_20mhz; /**< Local Maximum Transmit Power for 20 MHZ>*/
|
t_u8 local_max_tp_20mhz; /**< Local Maximum Transmit Power for 20 MHZ>*/
|
||||||
t_u8 local_max_tp_40mhz; /**< Local Maximum Transmit Power for 40 MHZ>*/
|
t_u8 local_max_tp_40mhz; /**< Local Maximum Transmit Power for 40 MHZ>*/
|
||||||
t_u8 local_max_tp_80mhz; /**< Local Maximum Transmit Power for 80 MHZ>*/
|
t_u8 local_max_tp_80mhz; /**< Local Maximum Transmit Power for 80 MHZ>*/
|
||||||
|
t_u8 local_max_tp_160mhz_80_80mhz; /**< Local Maximum Transmit Power for
|
||||||
|
160/80+80 MHZ>*/
|
||||||
} MLAN_PACK_END IEEEtypes_VhtTpcEnvelope_t;
|
} MLAN_PACK_END IEEEtypes_VhtTpcEnvelope_t;
|
||||||
|
|
||||||
/* IEEE Quiet Period Element (7.3.2.23) */
|
/* IEEE Quiet Period Element (7.3.2.23) */
|
||||||
|
|
|
@ -474,6 +474,9 @@ mlan_status wlan_init_priv(pmlan_private priv)
|
||||||
wlan_11h_priv_init(priv);
|
wlan_11h_priv_init(priv);
|
||||||
|
|
||||||
#ifdef UAP_SUPPORT
|
#ifdef UAP_SUPPORT
|
||||||
|
priv->is_11n_enabled = MFALSE;
|
||||||
|
priv->is_11ac_enabled = MFALSE;
|
||||||
|
priv->is_11ax_enabled = MFALSE;
|
||||||
priv->uap_bss_started = MFALSE;
|
priv->uap_bss_started = MFALSE;
|
||||||
priv->uap_host_based = MFALSE;
|
priv->uap_host_based = MFALSE;
|
||||||
memset(pmadapter, &priv->uap_state_chan_cb, 0,
|
memset(pmadapter, &priv->uap_state_chan_cb, 0,
|
||||||
|
@ -516,10 +519,13 @@ mlan_status wlan_init_priv(pmlan_private priv)
|
||||||
#if defined(STA_SUPPORT)
|
#if defined(STA_SUPPORT)
|
||||||
priv->pmfcfg.mfpc = 0;
|
priv->pmfcfg.mfpc = 0;
|
||||||
priv->pmfcfg.mfpr = 0;
|
priv->pmfcfg.mfpr = 0;
|
||||||
|
memset(pmadapter, &priv->pmfcfg, 0, sizeof(priv->pmfcfg));
|
||||||
#endif
|
#endif
|
||||||
priv->sec_info.wapi_enabled = MFALSE;
|
priv->sec_info.wapi_enabled = MFALSE;
|
||||||
priv->wapi_ie_len = 0;
|
priv->wapi_ie_len = 0;
|
||||||
priv->sec_info.wapi_key_on = MFALSE;
|
priv->sec_info.wapi_key_on = MFALSE;
|
||||||
|
priv->osen_ie_len = 0;
|
||||||
|
memset(pmadapter, &priv->osen_ie, 0, sizeof(priv->osen_ie));
|
||||||
|
|
||||||
memset(pmadapter, &priv->wps, 0, sizeof(priv->wps));
|
memset(pmadapter, &priv->wps, 0, sizeof(priv->wps));
|
||||||
memset(pmadapter, &priv->gen_ie_buf, 0, sizeof(priv->gen_ie_buf));
|
memset(pmadapter, &priv->gen_ie_buf, 0, sizeof(priv->gen_ie_buf));
|
||||||
|
@ -527,6 +533,7 @@ mlan_status wlan_init_priv(pmlan_private priv)
|
||||||
#endif /* STA_SUPPORT */
|
#endif /* STA_SUPPORT */
|
||||||
priv->wmm_required = MTRUE;
|
priv->wmm_required = MTRUE;
|
||||||
priv->wmm_enabled = MFALSE;
|
priv->wmm_enabled = MFALSE;
|
||||||
|
priv->disconnect_reason_code = 0;
|
||||||
priv->wmm_qosinfo = 0;
|
priv->wmm_qosinfo = 0;
|
||||||
priv->saved_wmm_qosinfo = 0;
|
priv->saved_wmm_qosinfo = 0;
|
||||||
priv->host_tdls_cs_support = MTRUE;
|
priv->host_tdls_cs_support = MTRUE;
|
||||||
|
@ -534,8 +541,14 @@ mlan_status wlan_init_priv(pmlan_private priv)
|
||||||
priv->tdls_cs_channel = 0;
|
priv->tdls_cs_channel = 0;
|
||||||
priv->supp_regulatory_class_len = 0;
|
priv->supp_regulatory_class_len = 0;
|
||||||
priv->chan_supp_len = 0;
|
priv->chan_supp_len = 0;
|
||||||
|
memset(pmadapter, &priv->chan_supp, 0, sizeof(priv->chan_supp));
|
||||||
|
memset(pmadapter, &priv->supp_regulatory_class, 0,
|
||||||
|
sizeof(priv->supp_regulatory_class));
|
||||||
priv->tdls_idle_time = TDLS_IDLE_TIMEOUT;
|
priv->tdls_idle_time = TDLS_IDLE_TIMEOUT;
|
||||||
priv->txaggrctrl = MTRUE;
|
priv->txaggrctrl = MTRUE;
|
||||||
|
for (i = 0; i < MAX_MGMT_IE_INDEX; i++)
|
||||||
|
memset(pmadapter, &priv->mgmt_ie[i], 0, sizeof(custom_ie));
|
||||||
|
priv->mgmt_frame_passthru_mask = 0;
|
||||||
#ifdef STA_SUPPORT
|
#ifdef STA_SUPPORT
|
||||||
priv->pcurr_bcn_buf = MNULL;
|
priv->pcurr_bcn_buf = MNULL;
|
||||||
priv->curr_bcn_size = 0;
|
priv->curr_bcn_size = 0;
|
||||||
|
@ -549,6 +562,10 @@ mlan_status wlan_init_priv(pmlan_private priv)
|
||||||
sizeof(priv->ext_cap), sizeof(priv->def_ext_cap));
|
sizeof(priv->ext_cap), sizeof(priv->def_ext_cap));
|
||||||
#endif /* STA_SUPPORT */
|
#endif /* STA_SUPPORT */
|
||||||
|
|
||||||
|
priv->amsdu_rx_cnt = 0;
|
||||||
|
priv->msdu_in_rx_amsdu_cnt = 0;
|
||||||
|
priv->amsdu_tx_cnt = 0;
|
||||||
|
priv->msdu_in_tx_amsdu_cnt = 0;
|
||||||
for (i = 0; i < MAX_NUM_TID; i++)
|
for (i = 0; i < MAX_NUM_TID; i++)
|
||||||
priv->addba_reject[i] = ADDBA_RSP_STATUS_ACCEPT;
|
priv->addba_reject[i] = ADDBA_RSP_STATUS_ACCEPT;
|
||||||
priv->addba_reject[6] = ADDBA_RSP_STATUS_REJECT;
|
priv->addba_reject[6] = ADDBA_RSP_STATUS_REJECT;
|
||||||
|
@ -578,9 +595,12 @@ mlan_status wlan_init_priv(pmlan_private priv)
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
priv->user_rxwinsize = priv->add_ba_param.rx_win_size;
|
priv->user_rxwinsize = priv->add_ba_param.rx_win_size;
|
||||||
|
memset(pmadapter, priv->rx_seq, 0, sizeof(priv->rx_seq));
|
||||||
priv->port_ctrl_mode = MTRUE;
|
priv->port_ctrl_mode = MTRUE;
|
||||||
priv->port_open = MFALSE;
|
priv->port_open = MFALSE;
|
||||||
|
priv->prior_port_status = MFALSE;
|
||||||
|
priv->tx_pause = MFALSE;
|
||||||
|
priv->hotspot_cfg = 0;
|
||||||
|
|
||||||
priv->intf_hr_len = pmadapter->ops.intf_header_len;
|
priv->intf_hr_len = pmadapter->ops.intf_header_len;
|
||||||
#ifdef USB
|
#ifdef USB
|
||||||
|
@ -634,7 +654,17 @@ t_void wlan_init_adapter(pmlan_adapter pmadapter)
|
||||||
#ifdef STA_SUPPORT
|
#ifdef STA_SUPPORT
|
||||||
pmadapter->pwarm_reset_ioctl_req = MNULL;
|
pmadapter->pwarm_reset_ioctl_req = MNULL;
|
||||||
#endif
|
#endif
|
||||||
|
pmadapter->pscan_ioctl_req = MNULL;
|
||||||
pmadapter->cmd_sent = MFALSE;
|
pmadapter->cmd_sent = MFALSE;
|
||||||
|
pmadapter->mlan_processing = MFALSE;
|
||||||
|
pmadapter->main_process_cnt = 0;
|
||||||
|
pmadapter->mlan_rx_processing = MFALSE;
|
||||||
|
pmadapter->more_rx_task_flag = MFALSE;
|
||||||
|
pmadapter->more_task_flag = MFALSE;
|
||||||
|
pmadapter->delay_task_flag = MFALSE;
|
||||||
|
pmadapter->data_sent = MFALSE;
|
||||||
|
pmadapter->data_sent_cnt = 0;
|
||||||
|
|
||||||
#ifdef SDIO
|
#ifdef SDIO
|
||||||
if (IS_SD(pmadapter->card_type)) {
|
if (IS_SD(pmadapter->card_type)) {
|
||||||
pmadapter->pcard_sd->int_mode = pmadapter->init_para.int_mode;
|
pmadapter->pcard_sd->int_mode = pmadapter->init_para.int_mode;
|
||||||
|
@ -687,13 +717,20 @@ t_void wlan_init_adapter(pmlan_adapter pmadapter)
|
||||||
pmadapter->cmd_resp_received = MFALSE;
|
pmadapter->cmd_resp_received = MFALSE;
|
||||||
pmadapter->event_received = MFALSE;
|
pmadapter->event_received = MFALSE;
|
||||||
pmadapter->data_received = MFALSE;
|
pmadapter->data_received = MFALSE;
|
||||||
|
pmadapter->seq_num = 0;
|
||||||
|
pmadapter->num_cmd_timeout = 0;
|
||||||
|
pmadapter->last_init_cmd = 0;
|
||||||
|
pmadapter->pending_ioctl = MFALSE;
|
||||||
|
pmadapter->scan_processing = MFALSE;
|
||||||
pmadapter->cmd_timer_is_set = MFALSE;
|
pmadapter->cmd_timer_is_set = MFALSE;
|
||||||
|
pmadapter->dnld_cmd_in_secs = 0;
|
||||||
|
|
||||||
/* PnP and power profile */
|
/* PnP and power profile */
|
||||||
pmadapter->surprise_removed = MFALSE;
|
pmadapter->surprise_removed = MFALSE;
|
||||||
/* FW hang report */
|
/* FW hang report */
|
||||||
pmadapter->fw_hang_report = MFALSE;
|
pmadapter->fw_hang_report = MFALSE;
|
||||||
|
pmadapter->ecsa_enable = MFALSE;
|
||||||
|
pmadapter->getlog_enable = MFALSE;
|
||||||
|
|
||||||
if (!pmadapter->init_para.ps_mode) {
|
if (!pmadapter->init_para.ps_mode) {
|
||||||
pmadapter->ps_mode = DEFAULT_PS_MODE;
|
pmadapter->ps_mode = DEFAULT_PS_MODE;
|
||||||
|
@ -727,7 +764,14 @@ t_void wlan_init_adapter(pmlan_adapter pmadapter)
|
||||||
memset(pmadapter, pmadapter->pscan_table, 0,
|
memset(pmadapter, pmadapter->pscan_table, 0,
|
||||||
(sizeof(BSSDescriptor_t) * MRVDRV_MAX_BSSID_LIST));
|
(sizeof(BSSDescriptor_t) * MRVDRV_MAX_BSSID_LIST));
|
||||||
pmadapter->active_scan_triggered = MFALSE;
|
pmadapter->active_scan_triggered = MFALSE;
|
||||||
|
if (!pmadapter->init_para.ext_scan)
|
||||||
pmadapter->ext_scan = EXT_SCAN_TYPE_ENH;
|
pmadapter->ext_scan = EXT_SCAN_TYPE_ENH;
|
||||||
|
else if (pmadapter->init_para.ext_scan == EXT_SCAN_TYPE_ENH)
|
||||||
|
pmadapter->ext_scan = EXT_SCAN_TYPE_ENH;
|
||||||
|
else
|
||||||
|
pmadapter->ext_scan = MTRUE;
|
||||||
|
pmadapter->ext_scan_enh = MFALSE;
|
||||||
|
pmadapter->ext_scan_timeout = MFALSE;
|
||||||
pmadapter->scan_probes = DEFAULT_PROBES;
|
pmadapter->scan_probes = DEFAULT_PROBES;
|
||||||
|
|
||||||
memset(pmadapter, pmadapter->bcn_buf, 0, pmadapter->bcn_buf_size);
|
memset(pmadapter, pmadapter->bcn_buf, 0, pmadapter->bcn_buf_size);
|
||||||
|
@ -760,6 +804,7 @@ t_void wlan_init_adapter(pmlan_adapter pmadapter)
|
||||||
*/
|
*/
|
||||||
|
|
||||||
pmadapter->pm_wakeup_card_req = MFALSE;
|
pmadapter->pm_wakeup_card_req = MFALSE;
|
||||||
|
pmadapter->pm_wakeup_timeout = 0;
|
||||||
|
|
||||||
pmadapter->pm_wakeup_fw_try = MFALSE;
|
pmadapter->pm_wakeup_fw_try = MFALSE;
|
||||||
|
|
||||||
|
@ -871,6 +916,8 @@ t_void wlan_init_adapter(pmlan_adapter pmadapter)
|
||||||
memset(pmadapter, &pmadapter->saved_sleep_period, 0,
|
memset(pmadapter, &pmadapter->saved_sleep_period, 0,
|
||||||
sizeof(pmadapter->saved_sleep_period));
|
sizeof(pmadapter->saved_sleep_period));
|
||||||
pmadapter->tx_lock_flag = MFALSE;
|
pmadapter->tx_lock_flag = MFALSE;
|
||||||
|
pmadapter->rx_lock_flag = MFALSE;
|
||||||
|
pmadapter->main_lock_flag = MFALSE;
|
||||||
pmadapter->null_pkt_interval = 0;
|
pmadapter->null_pkt_interval = 0;
|
||||||
pmadapter->fw_bands = 0;
|
pmadapter->fw_bands = 0;
|
||||||
pmadapter->config_bands = 0;
|
pmadapter->config_bands = 0;
|
||||||
|
@ -889,6 +936,11 @@ t_void wlan_init_adapter(pmlan_adapter pmadapter)
|
||||||
MRVDRV_DEFAULT_COUNTRY_CODE, COUNTRY_CODE_LEN,
|
MRVDRV_DEFAULT_COUNTRY_CODE, COUNTRY_CODE_LEN,
|
||||||
COUNTRY_CODE_LEN);
|
COUNTRY_CODE_LEN);
|
||||||
pmadapter->bcn_miss_time_out = DEFAULT_BCN_MISS_TIMEOUT;
|
pmadapter->bcn_miss_time_out = DEFAULT_BCN_MISS_TIMEOUT;
|
||||||
|
#ifdef STA_SUPPORT
|
||||||
|
memset(pmadapter, &pmadapter->arp_filter, 0,
|
||||||
|
sizeof(pmadapter->arp_filter));
|
||||||
|
pmadapter->arp_filter_size = 0;
|
||||||
|
#endif /* STA_SUPPORT */
|
||||||
|
|
||||||
#ifdef PCIE
|
#ifdef PCIE
|
||||||
if (IS_PCIE(pmadapter->card_type)) {
|
if (IS_PCIE(pmadapter->card_type)) {
|
||||||
|
|
|
@ -298,6 +298,7 @@ enum _mlan_ioctl_req_id {
|
||||||
MLAN_OID_MISC_COALESCE_CFG = 0x0020002E,
|
MLAN_OID_MISC_COALESCE_CFG = 0x0020002E,
|
||||||
MLAN_OID_MISC_TDLS_IDLE_TIME = 0x0020002F,
|
MLAN_OID_MISC_TDLS_IDLE_TIME = 0x0020002F,
|
||||||
MLAN_OID_MISC_GET_SENSOR_TEMP = 0x00200030,
|
MLAN_OID_MISC_GET_SENSOR_TEMP = 0x00200030,
|
||||||
|
MLAN_OID_MISC_IPV6_RA_OFFLOAD = 0x00200036,
|
||||||
MLAN_OID_MISC_GTK_REKEY_OFFLOAD = 0x00200037,
|
MLAN_OID_MISC_GTK_REKEY_OFFLOAD = 0x00200037,
|
||||||
MLAN_OID_MISC_OPER_CLASS = 0x00200038,
|
MLAN_OID_MISC_OPER_CLASS = 0x00200038,
|
||||||
MLAN_OID_MISC_PMIC_CFG = 0x00200039,
|
MLAN_OID_MISC_PMIC_CFG = 0x00200039,
|
||||||
|
@ -340,6 +341,11 @@ enum _mlan_ioctl_req_id {
|
||||||
MLAN_OID_MISC_TP_STATE = 0x0020007D,
|
MLAN_OID_MISC_TP_STATE = 0x0020007D,
|
||||||
MLAN_OID_MISC_HAL_PHY_CFG = 0x0020007E,
|
MLAN_OID_MISC_HAL_PHY_CFG = 0x0020007E,
|
||||||
MLAN_OID_MISC_RF_TEST_HE_POWER = 0X0020007F,
|
MLAN_OID_MISC_RF_TEST_HE_POWER = 0X0020007F,
|
||||||
|
#ifdef UAP_SUPPORT
|
||||||
|
MLAN_OID_MISC_WACP_MODE = 0x00200081,
|
||||||
|
#endif
|
||||||
|
MLAN_OID_MISC_GPIO_TSF_LATCH = 0x00200082,
|
||||||
|
MLAN_OID_MISC_GET_TSF_INFO = 0x00200083,
|
||||||
};
|
};
|
||||||
|
|
||||||
/** Sub command size */
|
/** Sub command size */
|
||||||
|
@ -1646,6 +1652,14 @@ typedef struct _mlan_ds_get_stats {
|
||||||
t_u32 dwMgtErrCnt;
|
t_u32 dwMgtErrCnt;
|
||||||
/*Control Ownership error count*/
|
/*Control Ownership error count*/
|
||||||
t_u32 dwDatErrCnt;
|
t_u32 dwDatErrCnt;
|
||||||
|
/*BIGTK MME good count*/
|
||||||
|
t_u32 bigtk_mmeGoodCnt;
|
||||||
|
/*BIGTK Replay error count*/
|
||||||
|
t_u32 bigtk_replayErrCnt;
|
||||||
|
/*BIGTK MIC error count*/
|
||||||
|
t_u32 bigtk_micErrCnt;
|
||||||
|
/*BIGTK MME not included count*/
|
||||||
|
t_u32 bigtk_mmeNotFoundCnt;
|
||||||
} mlan_ds_get_stats, *pmlan_ds_get_stats;
|
} mlan_ds_get_stats, *pmlan_ds_get_stats;
|
||||||
|
|
||||||
/** Type definition of mlan_ds_uap_stats for MLAN_OID_GET_STATS */
|
/** Type definition of mlan_ds_uap_stats for MLAN_OID_GET_STATS */
|
||||||
|
@ -1827,6 +1841,8 @@ typedef struct _mlan_fw_info {
|
||||||
t_u8 max_ap_assoc_sta;
|
t_u8 max_ap_assoc_sta;
|
||||||
/** Bandwidth not support 80Mhz */
|
/** Bandwidth not support 80Mhz */
|
||||||
t_u8 prohibit_80mhz;
|
t_u8 prohibit_80mhz;
|
||||||
|
/** FW support beacon protection */
|
||||||
|
t_u8 fw_beacon_prot;
|
||||||
} mlan_fw_info, *pmlan_fw_info;
|
} mlan_fw_info, *pmlan_fw_info;
|
||||||
|
|
||||||
/** Version string buffer length */
|
/** Version string buffer length */
|
||||||
|
@ -1844,6 +1860,14 @@ typedef struct _mlan_ver_ext {
|
||||||
/** Extended Capabilities Data */
|
/** Extended Capabilities Data */
|
||||||
typedef struct MLAN_PACK_START _ExtCap_t {
|
typedef struct MLAN_PACK_START _ExtCap_t {
|
||||||
/** Extended Capabilities value */
|
/** Extended Capabilities value */
|
||||||
|
t_u8 rsvdBit87 : 1; /* bit 87 */
|
||||||
|
t_u8 rsvdBit86 : 1; /* bit 86 */
|
||||||
|
t_u8 rsvdBit85 : 1; /* bit 85 */
|
||||||
|
t_u8 beacon_prot : 1; /* bit 84 */
|
||||||
|
t_u8 rsvdBit83 : 1; /* bit 83 */
|
||||||
|
t_u8 rsvdBit82 : 1; /* bit 82 */
|
||||||
|
t_u8 rsvdBit81 : 1; /* bit 81 */
|
||||||
|
t_u8 rsvdBit80 : 1; /* bit 80 */
|
||||||
t_u8 rsvdBit79 : 1; /* bit 79 */
|
t_u8 rsvdBit79 : 1; /* bit 79 */
|
||||||
t_u8 TWTResp : 1; /* bit 78 */
|
t_u8 TWTResp : 1; /* bit 78 */
|
||||||
t_u8 TWTReq : 1; /* bit 77 */
|
t_u8 TWTReq : 1; /* bit 77 */
|
||||||
|
@ -2009,6 +2033,14 @@ typedef struct MLAN_PACK_START _ExtCap_t {
|
||||||
t_u8 TWTReq : 1; /* bit 77 */
|
t_u8 TWTReq : 1; /* bit 77 */
|
||||||
t_u8 TWTResp : 1; /* bit 78 */
|
t_u8 TWTResp : 1; /* bit 78 */
|
||||||
t_u8 rsvdBit79 : 1; /* bit 79 */
|
t_u8 rsvdBit79 : 1; /* bit 79 */
|
||||||
|
t_u8 rsvdBit80 : 1; /* bit 80 */
|
||||||
|
t_u8 rsvdBit81 : 1; /* bit 81 */
|
||||||
|
t_u8 rsvdBit82 : 1; /* bit 82 */
|
||||||
|
t_u8 rsvdBit83 : 1; /* bit 83 */
|
||||||
|
t_u8 beacon_prot : 1; /* bit 84 */
|
||||||
|
t_u8 rsvdBit85 : 1; /* bit 85 */
|
||||||
|
t_u8 rsvdBit86 : 1; /* bit 86 */
|
||||||
|
t_u8 rsvdBit87 : 1; /* bit 87 */
|
||||||
} MLAN_PACK_END ExtCap_t, *pExtCap_t;
|
} MLAN_PACK_END ExtCap_t, *pExtCap_t;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -2215,7 +2247,7 @@ typedef struct _mlan_debug_info {
|
||||||
/** Corresponds to port_open member of mlan_private */
|
/** Corresponds to port_open member of mlan_private */
|
||||||
t_u8 port_open;
|
t_u8 port_open;
|
||||||
/** bypass pkt count */
|
/** bypass pkt count */
|
||||||
t_u16 bypass_pkt_count;
|
t_u32 bypass_pkt_count;
|
||||||
/** Corresponds to scan_processing member of mlan_adapter */
|
/** Corresponds to scan_processing member of mlan_adapter */
|
||||||
t_u32 scan_processing;
|
t_u32 scan_processing;
|
||||||
/** Corresponds to mlan_processing member of mlan_adapter */
|
/** Corresponds to mlan_processing member of mlan_adapter */
|
||||||
|
@ -2265,6 +2297,10 @@ typedef struct _mlan_debug_info {
|
||||||
t_u32 mpa_sent_no_ports;
|
t_u32 mpa_sent_no_ports;
|
||||||
/** last recv wr_bitmap */
|
/** last recv wr_bitmap */
|
||||||
t_u32 last_recv_wr_bitmap;
|
t_u32 last_recv_wr_bitmap;
|
||||||
|
/** last recv rd_bitmap */
|
||||||
|
t_u32 last_recv_rd_bitmap;
|
||||||
|
/** mp_data_port_mask */
|
||||||
|
t_u32 mp_data_port_mask;
|
||||||
/** last mp_wr_bitmap */
|
/** last mp_wr_bitmap */
|
||||||
t_u32 last_mp_wr_bitmap[SDIO_MP_DBG_NUM];
|
t_u32 last_mp_wr_bitmap[SDIO_MP_DBG_NUM];
|
||||||
/** last ports for cmd53 write data */
|
/** last ports for cmd53 write data */
|
||||||
|
@ -2480,7 +2516,7 @@ typedef enum {
|
||||||
AssocAgentAuth_FastBss,
|
AssocAgentAuth_FastBss,
|
||||||
AssocAgentAuth_FastBss_Skip,
|
AssocAgentAuth_FastBss_Skip,
|
||||||
AssocAgentAuth_Network_EAP,
|
AssocAgentAuth_Network_EAP,
|
||||||
AssocAgentAuth_Wpa3Sae,
|
AssocAgentAuth_Wpa3Sae = 6,
|
||||||
AssocAgentAuth_Auto,
|
AssocAgentAuth_Auto,
|
||||||
} AssocAgentAuthType_e;
|
} AssocAgentAuthType_e;
|
||||||
|
|
||||||
|
@ -2549,6 +2585,10 @@ enum _mlan_psk_type {
|
||||||
#define KEY_FLAG_GCMP_256 0x00000040
|
#define KEY_FLAG_GCMP_256 0x00000040
|
||||||
/** key flag for ccmp 256 */
|
/** key flag for ccmp 256 */
|
||||||
#define KEY_FLAG_CCMP_256 0x00000080
|
#define KEY_FLAG_CCMP_256 0x00000080
|
||||||
|
/** key flag for GMAC_128 */
|
||||||
|
#define KEY_FLAG_GMAC_128 0x00000100
|
||||||
|
/** key flag for GMAC_256 */
|
||||||
|
#define KEY_FLAG_GMAC_256 0x00000200
|
||||||
|
|
||||||
/** Type definition of mlan_ds_encrypt_key for MLAN_OID_SEC_CFG_ENCRYPT_KEY */
|
/** Type definition of mlan_ds_encrypt_key for MLAN_OID_SEC_CFG_ENCRYPT_KEY */
|
||||||
typedef struct _mlan_ds_encrypt_key {
|
typedef struct _mlan_ds_encrypt_key {
|
||||||
|
@ -4219,6 +4259,9 @@ typedef struct _mlan_ds_11h_cfg {
|
||||||
/** Enumeration for IE type */
|
/** Enumeration for IE type */
|
||||||
enum _mlan_ie_type {
|
enum _mlan_ie_type {
|
||||||
MLAN_IE_TYPE_GEN_IE = 0,
|
MLAN_IE_TYPE_GEN_IE = 0,
|
||||||
|
#ifdef STA_SUPPORT
|
||||||
|
MLAN_IE_TYPE_ARP_FILTER,
|
||||||
|
#endif /* STA_SUPPORT */
|
||||||
};
|
};
|
||||||
|
|
||||||
/** Type definition of mlan_ds_misc_gen_ie for MLAN_OID_MISC_GEN_IE */
|
/** Type definition of mlan_ds_misc_gen_ie for MLAN_OID_MISC_GEN_IE */
|
||||||
|
@ -4376,6 +4419,8 @@ typedef struct _mlan_ds_misc_cck_desense_cfg {
|
||||||
#define IPADDR_TYPE_IPV4 (1)
|
#define IPADDR_TYPE_IPV4 (1)
|
||||||
/** IP operation remove */
|
/** IP operation remove */
|
||||||
#define MLAN_IPADDR_OP_IP_REMOVE (0)
|
#define MLAN_IPADDR_OP_IP_REMOVE (0)
|
||||||
|
/** IP operation ARP filter */
|
||||||
|
#define MLAN_IPADDR_OP_ARP_FILTER MBIT(0)
|
||||||
/** IP operation ARP response */
|
/** IP operation ARP response */
|
||||||
#define MLAN_IPADDR_OP_AUTO_ARP_RESP MBIT(1)
|
#define MLAN_IPADDR_OP_AUTO_ARP_RESP MBIT(1)
|
||||||
|
|
||||||
|
@ -4391,6 +4436,14 @@ typedef struct _mlan_ds_misc_ipaddr_cfg {
|
||||||
t_u8 ip_addr[MAX_IPADDR][IPADDR_LEN];
|
t_u8 ip_addr[MAX_IPADDR][IPADDR_LEN];
|
||||||
} mlan_ds_misc_ipaddr_cfg;
|
} mlan_ds_misc_ipaddr_cfg;
|
||||||
|
|
||||||
|
/** Type definnition of mlan_ds_misc_ipv6_ra_offload for
|
||||||
|
* MLAN_OID_MISC_IPV6_RA_OFFLOAD*/
|
||||||
|
typedef struct _mlan_ds_misc_ipv6_ra_offload {
|
||||||
|
/** 0: disable; 1: enable*/
|
||||||
|
t_u8 enable;
|
||||||
|
t_u8 ipv6_addr[16];
|
||||||
|
} mlan_ds_misc_ipv6_ra_offload;
|
||||||
|
|
||||||
/* MEF configuration disable */
|
/* MEF configuration disable */
|
||||||
#define MEF_CFG_DISABLE 0
|
#define MEF_CFG_DISABLE 0
|
||||||
/* MEF configuration Rx filter enable */
|
/* MEF configuration Rx filter enable */
|
||||||
|
@ -4647,6 +4700,33 @@ typedef struct _mlan_ds_wifi_direct_config {
|
||||||
} mlan_ds_wifi_direct_config;
|
} mlan_ds_wifi_direct_config;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/** Type definition of mlan_ds_gpio_tsf_latch */
|
||||||
|
typedef struct _mlan_ds_gpio_tsf_latch {
|
||||||
|
/**clock sync Mode */
|
||||||
|
t_u8 clock_sync_mode;
|
||||||
|
/**clock sync Role */
|
||||||
|
t_u8 clock_sync_Role;
|
||||||
|
/**clock sync GPIO Pin Number */
|
||||||
|
t_u8 clock_sync_gpio_pin_number;
|
||||||
|
/**clock sync GPIO Level or Toggle */
|
||||||
|
t_u8 clock_sync_gpio_level_toggle;
|
||||||
|
/**clock sync GPIO Pulse Width */
|
||||||
|
t_u16 clock_sync_gpio_pulse_width;
|
||||||
|
} mlan_ds_gpio_tsf_latch;
|
||||||
|
|
||||||
|
/** Type definition of mlan_ds_tsf_info */
|
||||||
|
typedef struct _mlan_ds_tsf_info {
|
||||||
|
/**get tsf info format */
|
||||||
|
t_u16 tsf_format;
|
||||||
|
/**tsf info */
|
||||||
|
t_u16 tsf_info;
|
||||||
|
/**tsf */
|
||||||
|
t_u64 tsf;
|
||||||
|
/**Positive or negative offset in microsecond from Beacon TSF to GPIO
|
||||||
|
* toggle TSF */
|
||||||
|
t_s32 tsf_offset;
|
||||||
|
} mlan_ds_tsf_info;
|
||||||
|
|
||||||
#if defined(STA_SUPPORT)
|
#if defined(STA_SUPPORT)
|
||||||
typedef struct _mlan_ds_misc_pmfcfg {
|
typedef struct _mlan_ds_misc_pmfcfg {
|
||||||
/** Management Frame Protection Capable */
|
/** Management Frame Protection Capable */
|
||||||
|
@ -4851,6 +4931,8 @@ typedef struct _mef_entry_t {
|
||||||
typedef struct _mlan_ds_misc_mef_flt_cfg {
|
typedef struct _mlan_ds_misc_mef_flt_cfg {
|
||||||
/** Type of action*/
|
/** Type of action*/
|
||||||
int mef_act_type;
|
int mef_act_type;
|
||||||
|
/** Operation code*/
|
||||||
|
t_u32 op_code;
|
||||||
/** NV Filter Criteria*/
|
/** NV Filter Criteria*/
|
||||||
t_u32 criteria;
|
t_u32 criteria;
|
||||||
/** NV MEF entry*/
|
/** NV MEF entry*/
|
||||||
|
@ -5236,6 +5318,8 @@ typedef struct _mlan_ds_misc_cfg {
|
||||||
mlan_ds_misc_tx_datapause tx_datapause;
|
mlan_ds_misc_tx_datapause tx_datapause;
|
||||||
/** IP address configuration */
|
/** IP address configuration */
|
||||||
mlan_ds_misc_ipaddr_cfg ipaddr_cfg;
|
mlan_ds_misc_ipaddr_cfg ipaddr_cfg;
|
||||||
|
/** IPv6 Router Advertisement offload configuration */
|
||||||
|
mlan_ds_misc_ipv6_ra_offload ipv6_ra_offload;
|
||||||
/** MAC control for MLAN_OID_MISC_MAC_CONTROL */
|
/** MAC control for MLAN_OID_MISC_MAC_CONTROL */
|
||||||
t_u32 mac_ctrl;
|
t_u32 mac_ctrl;
|
||||||
/** MEF configuration for MLAN_OID_MISC_MEF_CFG */
|
/** MEF configuration for MLAN_OID_MISC_MEF_CFG */
|
||||||
|
@ -5274,6 +5358,8 @@ typedef struct _mlan_ds_misc_cfg {
|
||||||
#ifdef WIFI_DIRECT_SUPPORT
|
#ifdef WIFI_DIRECT_SUPPORT
|
||||||
mlan_ds_wifi_direct_config p2p_config;
|
mlan_ds_wifi_direct_config p2p_config;
|
||||||
#endif
|
#endif
|
||||||
|
mlan_ds_gpio_tsf_latch gpio_tsf_latch_config;
|
||||||
|
mlan_ds_tsf_info tsf_info;
|
||||||
mlan_ds_coalesce_cfg coalesce_cfg;
|
mlan_ds_coalesce_cfg coalesce_cfg;
|
||||||
t_u8 low_pwr_mode;
|
t_u8 low_pwr_mode;
|
||||||
/** MEF-FLT-CONFIG for MLAN_OID_MISC_NV_FLT_CFG */
|
/** MEF-FLT-CONFIG for MLAN_OID_MISC_NV_FLT_CFG */
|
||||||
|
@ -5325,6 +5411,9 @@ typedef struct _mlan_ds_misc_cfg {
|
||||||
mlan_ds_misc_dot11mc_unassoc_ftm_cfg dot11mc_unassoc_ftm_cfg;
|
mlan_ds_misc_dot11mc_unassoc_ftm_cfg dot11mc_unassoc_ftm_cfg;
|
||||||
mlan_ds_misc_tp_state tp_state;
|
mlan_ds_misc_tp_state tp_state;
|
||||||
mlan_ds_hal_phy_cfg_params hal_phy_cfg_params;
|
mlan_ds_hal_phy_cfg_params hal_phy_cfg_params;
|
||||||
|
#ifdef UAP_SUPPORT
|
||||||
|
t_u8 wacp_mode;
|
||||||
|
#endif
|
||||||
} param;
|
} param;
|
||||||
} mlan_ds_misc_cfg, *pmlan_ds_misc_cfg;
|
} mlan_ds_misc_cfg, *pmlan_ds_misc_cfg;
|
||||||
|
|
||||||
|
|
|
@ -1360,14 +1360,21 @@ mlan_status wlan_ret_802_11_associate(mlan_private *pmpriv,
|
||||||
mlan_adapter *pmadapter = pmpriv->adapter;
|
mlan_adapter *pmadapter = pmpriv->adapter;
|
||||||
assoc_logger_data *assoc_succ;
|
assoc_logger_data *assoc_succ;
|
||||||
mlan_ds_bss *bss;
|
mlan_ds_bss *bss;
|
||||||
|
IEEEtypes_MgmtHdr_t *hdr;
|
||||||
|
|
||||||
ENTER();
|
ENTER();
|
||||||
|
|
||||||
if (pmpriv->curr_bss_params.host_mlme)
|
if (pmpriv->curr_bss_params.host_mlme) {
|
||||||
passoc_rsp =
|
hdr = (IEEEtypes_MgmtHdr_t *)&resp->params;
|
||||||
(IEEEtypes_AssocRsp_t *)((t_u8 *)(&resp->params) +
|
if (!memcmp(pmpriv->adapter, hdr->BssId,
|
||||||
|
pmpriv->pattempted_bss_desc->mac_address,
|
||||||
|
MLAN_MAC_ADDR_LENGTH))
|
||||||
|
passoc_rsp = (IEEEtypes_AssocRsp_t
|
||||||
|
*)((t_u8 *)(&resp->params) +
|
||||||
sizeof(IEEEtypes_MgmtHdr_t));
|
sizeof(IEEEtypes_MgmtHdr_t));
|
||||||
else
|
else
|
||||||
|
passoc_rsp = (IEEEtypes_AssocRsp_t *)&resp->params;
|
||||||
|
} else
|
||||||
|
|
||||||
passoc_rsp = (IEEEtypes_AssocRsp_t *)&resp->params;
|
passoc_rsp = (IEEEtypes_AssocRsp_t *)&resp->params;
|
||||||
passoc_rsp->status_code = wlan_le16_to_cpu(passoc_rsp->status_code);
|
passoc_rsp->status_code = wlan_le16_to_cpu(passoc_rsp->status_code);
|
||||||
|
@ -1432,7 +1439,6 @@ mlan_status wlan_ret_802_11_associate(mlan_private *pmpriv,
|
||||||
|
|
||||||
/* Send a Media Connected event, according to the Spec */
|
/* Send a Media Connected event, according to the Spec */
|
||||||
pmpriv->media_connected = MTRUE;
|
pmpriv->media_connected = MTRUE;
|
||||||
|
|
||||||
pmpriv->adapter->pps_uapsd_mode = MFALSE;
|
pmpriv->adapter->pps_uapsd_mode = MFALSE;
|
||||||
pmpriv->adapter->tx_lock_flag = MFALSE;
|
pmpriv->adapter->tx_lock_flag = MFALSE;
|
||||||
pmpriv->adapter->delay_null_pkt = MFALSE;
|
pmpriv->adapter->delay_null_pkt = MFALSE;
|
||||||
|
|
|
@ -402,6 +402,11 @@ extern t_void (*assert_callback)(t_void *pmoal_handle, t_u32 cond);
|
||||||
/** Maximum event buffer size */
|
/** Maximum event buffer size */
|
||||||
#define MAX_EVENT_SIZE (3 * 1024)
|
#define MAX_EVENT_SIZE (3 * 1024)
|
||||||
|
|
||||||
|
#ifdef STA_SUPPORT
|
||||||
|
/** Maximum buffer size for ARP filter */
|
||||||
|
#define ARP_FILTER_MAX_BUF_SIZE 68
|
||||||
|
#endif /* STA_SUPPORT */
|
||||||
|
|
||||||
/** 60 seconds */
|
/** 60 seconds */
|
||||||
#define MRVDRV_TIMER_60S 60000
|
#define MRVDRV_TIMER_60S 60000
|
||||||
/** 10 seconds */
|
/** 10 seconds */
|
||||||
|
@ -1817,6 +1822,8 @@ typedef struct _mef_cfg_data {
|
||||||
|
|
||||||
/** Type definition of mef_entry*/
|
/** Type definition of mef_entry*/
|
||||||
typedef struct _mef_entry {
|
typedef struct _mef_entry {
|
||||||
|
/** Flag for auto arp entry*/
|
||||||
|
int enable_autoarp_entry;
|
||||||
/** Num for wowlan entry*/
|
/** Num for wowlan entry*/
|
||||||
int num_wowlan_entry;
|
int num_wowlan_entry;
|
||||||
/** Num for IPv6 neighbor solicitation message offload */
|
/** Num for IPv6 neighbor solicitation message offload */
|
||||||
|
@ -1892,6 +1899,7 @@ typedef struct _mlan_init_para {
|
||||||
/** adma ring size */
|
/** adma ring size */
|
||||||
t_u16 ring_size;
|
t_u16 ring_size;
|
||||||
#endif
|
#endif
|
||||||
|
t_u8 ext_scan;
|
||||||
} mlan_init_para, *pmlan_init_para;
|
} mlan_init_para, *pmlan_init_para;
|
||||||
|
|
||||||
#ifdef SDIO
|
#ifdef SDIO
|
||||||
|
@ -2018,6 +2026,8 @@ typedef struct _mlan_sdio_card {
|
||||||
t_u32 mpa_sent_no_ports;
|
t_u32 mpa_sent_no_ports;
|
||||||
/** last wr_bitmap from FW */
|
/** last wr_bitmap from FW */
|
||||||
t_u32 last_recv_wr_bitmap;
|
t_u32 last_recv_wr_bitmap;
|
||||||
|
/** last wr_bitmap from FW */
|
||||||
|
t_u32 last_recv_rd_bitmap;
|
||||||
/** last mp_wr_bitmap */
|
/** last mp_wr_bitmap */
|
||||||
t_u32 last_mp_wr_bitmap[SDIO_MP_DBG_NUM];
|
t_u32 last_mp_wr_bitmap[SDIO_MP_DBG_NUM];
|
||||||
/** last ports for cmd53 write data */
|
/** last ports for cmd53 write data */
|
||||||
|
@ -2265,6 +2275,10 @@ typedef struct _adapter_operations {
|
||||||
pmlan_buffer pmbuf);
|
pmlan_buffer pmbuf);
|
||||||
/** handle dump interface specific info */
|
/** handle dump interface specific info */
|
||||||
mlan_status (*debug_dump)(mlan_adapter *pmadapter);
|
mlan_status (*debug_dump)(mlan_adapter *pmadapter);
|
||||||
|
/** disable host interrupt */
|
||||||
|
mlan_status (*disable_host_int)(mlan_adapter *pmadapter);
|
||||||
|
/** enable host interrupt */
|
||||||
|
mlan_status (*enable_host_int)(mlan_adapter *pmadapter);
|
||||||
/**Interface header length*/
|
/**Interface header length*/
|
||||||
t_u32 intf_header_len;
|
t_u32 intf_header_len;
|
||||||
} mlan_adapter_operations;
|
} mlan_adapter_operations;
|
||||||
|
@ -2405,8 +2419,6 @@ typedef struct _mlan_adapter {
|
||||||
* FALSE - No cmd response to process
|
* FALSE - No cmd response to process
|
||||||
*/
|
*/
|
||||||
t_u8 cmd_resp_received;
|
t_u8 cmd_resp_received;
|
||||||
/** block download cmd to firmware */
|
|
||||||
t_u8 cmd_lock;
|
|
||||||
/** Event received:
|
/** Event received:
|
||||||
* TRUE - Event received from fw, and yet to process
|
* TRUE - Event received from fw, and yet to process
|
||||||
* FALSE - No events to process
|
* FALSE - No events to process
|
||||||
|
@ -2687,6 +2699,12 @@ typedef struct _mlan_adapter {
|
||||||
/** RX pending for forwarding packets */
|
/** RX pending for forwarding packets */
|
||||||
mlan_scalar pending_bridge_pkts;
|
mlan_scalar pending_bridge_pkts;
|
||||||
|
|
||||||
|
#ifdef STA_SUPPORT
|
||||||
|
/** ARP filter buffer */
|
||||||
|
t_u8 arp_filter[ARP_FILTER_MAX_BUF_SIZE];
|
||||||
|
/** ARP filter buffer size */
|
||||||
|
t_u32 arp_filter_size;
|
||||||
|
#endif /* STA_SUPPORT */
|
||||||
/** Minimum delay between HsActive and HostWake (in msec) */
|
/** Minimum delay between HsActive and HostWake (in msec) */
|
||||||
t_u16 min_wake_holdoff;
|
t_u16 min_wake_holdoff;
|
||||||
/** Host sleep wake interval(in msec) */
|
/** Host sleep wake interval(in msec) */
|
||||||
|
@ -2714,7 +2732,7 @@ typedef struct _mlan_adapter {
|
||||||
/** management frame wakeup filter config */
|
/** management frame wakeup filter config */
|
||||||
mlan_mgmt_frame_wakeup mgmt_filter[MAX_MGMT_FRAME_FILTER];
|
mlan_mgmt_frame_wakeup mgmt_filter[MAX_MGMT_FRAME_FILTER];
|
||||||
/** Bypass TX queue pkt count */
|
/** Bypass TX queue pkt count */
|
||||||
t_u16 bypass_pkt_count;
|
t_u32 bypass_pkt_count;
|
||||||
#ifdef STA_SUPPORT
|
#ifdef STA_SUPPORT
|
||||||
/** warm-reset IOCTL request buffer pointer */
|
/** warm-reset IOCTL request buffer pointer */
|
||||||
pmlan_ioctl_req pwarm_reset_ioctl_req;
|
pmlan_ioctl_req pwarm_reset_ioctl_req;
|
||||||
|
@ -2901,6 +2919,7 @@ t_void wlan_release_cmd_lock(mlan_adapter *pmadapter);
|
||||||
#ifdef STA_SUPPORT
|
#ifdef STA_SUPPORT
|
||||||
/** Flush the scan pending queue */
|
/** Flush the scan pending queue */
|
||||||
t_void wlan_flush_scan_queue(pmlan_adapter pmadapter);
|
t_void wlan_flush_scan_queue(pmlan_adapter pmadapter);
|
||||||
|
t_void wlan_move_cmd_to_cmd_pending_q(pmlan_adapter pmadapter);
|
||||||
mlan_status wlan_cancel_pending_scan_cmd(pmlan_adapter pmadapter,
|
mlan_status wlan_cancel_pending_scan_cmd(pmlan_adapter pmadapter,
|
||||||
pmlan_ioctl_req pioctl_req);
|
pmlan_ioctl_req pioctl_req);
|
||||||
#endif
|
#endif
|
||||||
|
@ -3118,6 +3137,17 @@ mlan_status wlan_ret_p2p_params_config(pmlan_private pmpriv,
|
||||||
mlan_status wlan_misc_p2p_config(pmlan_adapter pmadapter,
|
mlan_status wlan_misc_p2p_config(pmlan_adapter pmadapter,
|
||||||
pmlan_ioctl_req pioctl_req);
|
pmlan_ioctl_req pioctl_req);
|
||||||
#endif
|
#endif
|
||||||
|
mlan_status wlan_cmd_gpio_tsf_latch(pmlan_private pmpriv,
|
||||||
|
HostCmd_DS_COMMAND *cmd, t_u16 cmd_action,
|
||||||
|
mlan_ioctl_req *pioctl_buf,
|
||||||
|
t_void *pdata_buf);
|
||||||
|
mlan_status wlan_ret_gpio_tsf_latch(pmlan_private pmpriv,
|
||||||
|
HostCmd_DS_COMMAND *resp,
|
||||||
|
mlan_ioctl_req *pioctl_buf);
|
||||||
|
mlan_status wlan_misc_gpio_tsf_latch_config(pmlan_adapter pmadapter,
|
||||||
|
pmlan_ioctl_req pioctl_req);
|
||||||
|
mlan_status wlan_misc_get_tsf_info(pmlan_adapter pmadapter,
|
||||||
|
pmlan_ioctl_req pioctl_req);
|
||||||
/** get ralist info */
|
/** get ralist info */
|
||||||
int wlan_get_ralist_info(mlan_private *priv, pralist_info buf);
|
int wlan_get_ralist_info(mlan_private *priv, pralist_info buf);
|
||||||
/** dump ralist */
|
/** dump ralist */
|
||||||
|
@ -3804,6 +3834,7 @@ mlan_status wlan_set_drvdbg(pmlan_adapter pmadapter,
|
||||||
|
|
||||||
mlan_status wlan_misc_hotspot_cfg(pmlan_adapter pmadapter,
|
mlan_status wlan_misc_hotspot_cfg(pmlan_adapter pmadapter,
|
||||||
pmlan_ioctl_req pioctl_req);
|
pmlan_ioctl_req pioctl_req);
|
||||||
|
|
||||||
#ifdef STA_SUPPORT
|
#ifdef STA_SUPPORT
|
||||||
mlan_status wlan_misc_ext_capa_cfg(pmlan_adapter pmadapter,
|
mlan_status wlan_misc_ext_capa_cfg(pmlan_adapter pmadapter,
|
||||||
pmlan_ioctl_req pioctl_req);
|
pmlan_ioctl_req pioctl_req);
|
||||||
|
@ -3986,6 +4017,12 @@ mlan_status wlan_cmd_config_dyn_bw(pmlan_private pmpriv,
|
||||||
mlan_status wlan_ret_dyn_bw(pmlan_private pmpriv, HostCmd_DS_COMMAND *resp,
|
mlan_status wlan_ret_dyn_bw(pmlan_private pmpriv, HostCmd_DS_COMMAND *resp,
|
||||||
mlan_ioctl_req *pioctl_buf);
|
mlan_ioctl_req *pioctl_buf);
|
||||||
|
|
||||||
|
#ifdef UAP_SUPPORT
|
||||||
|
/** wacp mode misc ioctl */
|
||||||
|
mlan_status wlan_misc_ioctl_wacp_mode(pmlan_adapter pmadapter,
|
||||||
|
mlan_ioctl_req *pioctl_req);
|
||||||
|
#endif
|
||||||
|
|
||||||
mlan_status wlan_power_ioctl_set_get_lpm(pmlan_adapter pmadapter,
|
mlan_status wlan_power_ioctl_set_get_lpm(pmlan_adapter pmadapter,
|
||||||
pmlan_ioctl_req pioctl_req);
|
pmlan_ioctl_req pioctl_req);
|
||||||
mlan_status wlan_cmd_set_get_low_power_mode_cfg(pmlan_private pmpriv,
|
mlan_status wlan_cmd_set_get_low_power_mode_cfg(pmlan_private pmpriv,
|
||||||
|
|
|
@ -531,6 +531,10 @@ mlan_status wlan_get_info_debug_info(pmlan_adapter pmadapter,
|
||||||
pmadapter->pcard_sd->mpa_sent_no_ports;
|
pmadapter->pcard_sd->mpa_sent_no_ports;
|
||||||
debug_info->last_recv_wr_bitmap =
|
debug_info->last_recv_wr_bitmap =
|
||||||
pmadapter->pcard_sd->last_recv_wr_bitmap;
|
pmadapter->pcard_sd->last_recv_wr_bitmap;
|
||||||
|
debug_info->last_recv_rd_bitmap =
|
||||||
|
pmadapter->pcard_sd->last_recv_rd_bitmap;
|
||||||
|
debug_info->mp_data_port_mask =
|
||||||
|
pmadapter->pcard_sd->mp_data_port_mask;
|
||||||
debug_info->last_mp_index =
|
debug_info->last_mp_index =
|
||||||
pmadapter->pcard_sd->last_mp_index;
|
pmadapter->pcard_sd->last_mp_index;
|
||||||
memcpy_ext(
|
memcpy_ext(
|
||||||
|
@ -1769,11 +1773,8 @@ sta_node *wlan_get_station_entry(mlan_private *priv, t_u8 *mac)
|
||||||
sta_node *wlan_add_station_entry(mlan_private *priv, t_u8 *mac)
|
sta_node *wlan_add_station_entry(mlan_private *priv, t_u8 *mac)
|
||||||
{
|
{
|
||||||
sta_node *sta_ptr = MNULL;
|
sta_node *sta_ptr = MNULL;
|
||||||
mlan_adapter *pmadapter = priv->adapter;
|
|
||||||
|
|
||||||
ENTER();
|
ENTER();
|
||||||
pmadapter->callbacks.moal_spin_lock(pmadapter->pmoal_handle,
|
|
||||||
priv->wmm.ra_list_spinlock);
|
|
||||||
|
|
||||||
sta_ptr = wlan_get_station_entry(priv, mac);
|
sta_ptr = wlan_get_station_entry(priv, mac);
|
||||||
if (sta_ptr)
|
if (sta_ptr)
|
||||||
|
@ -1782,8 +1783,6 @@ sta_node *wlan_add_station_entry(mlan_private *priv, t_u8 *mac)
|
||||||
sizeof(sta_node), MLAN_MEM_DEF,
|
sizeof(sta_node), MLAN_MEM_DEF,
|
||||||
(t_u8 **)&sta_ptr)) {
|
(t_u8 **)&sta_ptr)) {
|
||||||
PRINTM(MERROR, "Failed to allocate memory for station node\n");
|
PRINTM(MERROR, "Failed to allocate memory for station node\n");
|
||||||
pmadapter->callbacks.moal_spin_unlock(
|
|
||||||
pmadapter->pmoal_handle, priv->wmm.ra_list_spinlock);
|
|
||||||
LEAVE();
|
LEAVE();
|
||||||
return MNULL;
|
return MNULL;
|
||||||
}
|
}
|
||||||
|
@ -1791,7 +1790,9 @@ sta_node *wlan_add_station_entry(mlan_private *priv, t_u8 *mac)
|
||||||
memcpy_ext(priv->adapter, sta_ptr->mac_addr, mac, MLAN_MAC_ADDR_LENGTH,
|
memcpy_ext(priv->adapter, sta_ptr->mac_addr, mac, MLAN_MAC_ADDR_LENGTH,
|
||||||
MLAN_MAC_ADDR_LENGTH);
|
MLAN_MAC_ADDR_LENGTH);
|
||||||
util_enqueue_list_tail(priv->adapter->pmoal_handle, &priv->sta_list,
|
util_enqueue_list_tail(priv->adapter->pmoal_handle, &priv->sta_list,
|
||||||
(pmlan_linked_list)sta_ptr, MNULL, MNULL);
|
(pmlan_linked_list)sta_ptr,
|
||||||
|
priv->adapter->callbacks.moal_spin_lock,
|
||||||
|
priv->adapter->callbacks.moal_spin_unlock);
|
||||||
#ifdef DRV_EMBEDDED_AUTHENTICATOR
|
#ifdef DRV_EMBEDDED_AUTHENTICATOR
|
||||||
if ((GET_BSS_ROLE(priv) == MLAN_BSS_ROLE_UAP) &&
|
if ((GET_BSS_ROLE(priv) == MLAN_BSS_ROLE_UAP) &&
|
||||||
IsAuthenticatorEnabled(priv->psapriv))
|
IsAuthenticatorEnabled(priv->psapriv))
|
||||||
|
@ -1799,8 +1800,6 @@ sta_node *wlan_add_station_entry(mlan_private *priv, t_u8 *mac)
|
||||||
&sta_ptr->cm_connectioninfo, mac);
|
&sta_ptr->cm_connectioninfo, mac);
|
||||||
#endif
|
#endif
|
||||||
done:
|
done:
|
||||||
pmadapter->callbacks.moal_spin_unlock(pmadapter->pmoal_handle,
|
|
||||||
priv->wmm.ra_list_spinlock);
|
|
||||||
LEAVE();
|
LEAVE();
|
||||||
return sta_ptr;
|
return sta_ptr;
|
||||||
}
|
}
|
||||||
|
@ -1817,10 +1816,7 @@ done:
|
||||||
t_void wlan_delete_station_entry(mlan_private *priv, t_u8 *mac)
|
t_void wlan_delete_station_entry(mlan_private *priv, t_u8 *mac)
|
||||||
{
|
{
|
||||||
sta_node *sta_ptr = MNULL;
|
sta_node *sta_ptr = MNULL;
|
||||||
mlan_adapter *pmadapter = priv->adapter;
|
|
||||||
ENTER();
|
ENTER();
|
||||||
pmadapter->callbacks.moal_spin_lock(pmadapter->pmoal_handle,
|
|
||||||
priv->wmm.ra_list_spinlock);
|
|
||||||
sta_ptr = wlan_get_station_entry(priv, mac);
|
sta_ptr = wlan_get_station_entry(priv, mac);
|
||||||
if (sta_ptr) {
|
if (sta_ptr) {
|
||||||
#ifdef DRV_EMBEDDED_AUTHENTICATOR
|
#ifdef DRV_EMBEDDED_AUTHENTICATOR
|
||||||
|
@ -1830,12 +1826,13 @@ t_void wlan_delete_station_entry(mlan_private *priv, t_u8 *mac)
|
||||||
sta_ptr->cm_connectioninfo);
|
sta_ptr->cm_connectioninfo);
|
||||||
#endif
|
#endif
|
||||||
util_unlink_list(priv->adapter->pmoal_handle, &priv->sta_list,
|
util_unlink_list(priv->adapter->pmoal_handle, &priv->sta_list,
|
||||||
(pmlan_linked_list)sta_ptr, MNULL, MNULL);
|
(pmlan_linked_list)sta_ptr,
|
||||||
|
priv->adapter->callbacks.moal_spin_lock,
|
||||||
|
priv->adapter->callbacks.moal_spin_unlock);
|
||||||
priv->adapter->callbacks.moal_mfree(priv->adapter->pmoal_handle,
|
priv->adapter->callbacks.moal_mfree(priv->adapter->pmoal_handle,
|
||||||
(t_u8 *)sta_ptr);
|
(t_u8 *)sta_ptr);
|
||||||
}
|
}
|
||||||
pmadapter->callbacks.moal_spin_unlock(pmadapter->pmoal_handle,
|
|
||||||
priv->wmm.ra_list_spinlock);
|
|
||||||
LEAVE();
|
LEAVE();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -3404,15 +3401,15 @@ mlan_status wlan_process_802dot11_mgmt_pkt(mlan_private *priv, t_u8 *payload,
|
||||||
#endif
|
#endif
|
||||||
if (priv->bss_role == MLAN_BSS_ROLE_STA) {
|
if (priv->bss_role == MLAN_BSS_ROLE_STA) {
|
||||||
if (priv->curr_bss_params.host_mlme) {
|
if (priv->curr_bss_params.host_mlme) {
|
||||||
if (memcmp(pmadapter, pieee_pkt_hdr->addr2,
|
if (memcmp(pmadapter, pieee_pkt_hdr->addr3,
|
||||||
(t_u8 *)priv->curr_bss_params
|
(t_u8 *)priv->curr_bss_params
|
||||||
.bss_descriptor.mac_address,
|
.bss_descriptor.mac_address,
|
||||||
MLAN_MAC_ADDR_LENGTH)) {
|
MLAN_MAC_ADDR_LENGTH)) {
|
||||||
PRINTM(MINFO,
|
PRINTM(MCMND,
|
||||||
"Dropping mgmt frame from others: type=%d " MACSTR
|
"Dropping Deauth frame from other bssid: type=%d " MACSTR
|
||||||
"\n",
|
"\n",
|
||||||
sub_type,
|
sub_type,
|
||||||
MAC2STR(pieee_pkt_hdr->addr2));
|
MAC2STR(pieee_pkt_hdr->addr3));
|
||||||
LEAVE();
|
LEAVE();
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
@ -4865,6 +4862,75 @@ mlan_status wlan_misc_p2p_config(pmlan_adapter pmadapter,
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Set/Get GPIO TSF Latch config
|
||||||
|
*
|
||||||
|
* @param pmadapter A pointer to mlan_adapter structure
|
||||||
|
* @param pioctl_req A pointer to ioctl request buffer
|
||||||
|
*
|
||||||
|
* @return MLAN_STATUS_SUCCESS --success, otherwise fail
|
||||||
|
*/
|
||||||
|
mlan_status wlan_misc_gpio_tsf_latch_config(pmlan_adapter pmadapter,
|
||||||
|
pmlan_ioctl_req pioctl_req)
|
||||||
|
{
|
||||||
|
mlan_status ret = MLAN_STATUS_SUCCESS;
|
||||||
|
mlan_ds_misc_cfg *misc_cfg = MNULL;
|
||||||
|
t_u16 cmd_action = 0;
|
||||||
|
mlan_private *pmpriv = pmadapter->priv[pioctl_req->bss_index];
|
||||||
|
|
||||||
|
ENTER();
|
||||||
|
|
||||||
|
misc_cfg = (mlan_ds_misc_cfg *)pioctl_req->pbuf;
|
||||||
|
if (pioctl_req->action == MLAN_ACT_SET)
|
||||||
|
cmd_action = HostCmd_ACT_GEN_SET;
|
||||||
|
else
|
||||||
|
cmd_action = HostCmd_ACT_GEN_GET;
|
||||||
|
|
||||||
|
/* Send request to firmware */
|
||||||
|
ret = wlan_prepare_cmd(pmpriv, HOST_CMD_GPIO_TSF_LATCH_PARAM_CONFIG,
|
||||||
|
cmd_action, 0, (t_void *)pioctl_req,
|
||||||
|
&misc_cfg->param.gpio_tsf_latch_config);
|
||||||
|
|
||||||
|
if (ret == MLAN_STATUS_SUCCESS)
|
||||||
|
ret = MLAN_STATUS_PENDING;
|
||||||
|
|
||||||
|
LEAVE();
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Get TSF info
|
||||||
|
*
|
||||||
|
* @param pmadapter A pointer to mlan_adapter structure
|
||||||
|
* @param pioctl_req A pointer to ioctl request buffer
|
||||||
|
*
|
||||||
|
* @return MLAN_STATUS_SUCCESS --success, otherwise fail
|
||||||
|
*/
|
||||||
|
mlan_status wlan_misc_get_tsf_info(pmlan_adapter pmadapter,
|
||||||
|
pmlan_ioctl_req pioctl_req)
|
||||||
|
{
|
||||||
|
mlan_status ret = MLAN_STATUS_SUCCESS;
|
||||||
|
mlan_ds_misc_cfg *misc_cfg = MNULL;
|
||||||
|
t_u16 cmd_action = 0;
|
||||||
|
mlan_private *pmpriv = pmadapter->priv[pioctl_req->bss_index];
|
||||||
|
|
||||||
|
ENTER();
|
||||||
|
|
||||||
|
misc_cfg = (mlan_ds_misc_cfg *)pioctl_req->pbuf;
|
||||||
|
cmd_action = HostCmd_ACT_GEN_GET;
|
||||||
|
|
||||||
|
/* Send request to firmware */
|
||||||
|
ret = wlan_prepare_cmd(pmpriv, HOST_CMD_GPIO_TSF_LATCH_PARAM_CONFIG,
|
||||||
|
cmd_action, 0, (t_void *)pioctl_req,
|
||||||
|
&misc_cfg->param.tsf_info);
|
||||||
|
|
||||||
|
if (ret == MLAN_STATUS_SUCCESS)
|
||||||
|
ret = MLAN_STATUS_PENDING;
|
||||||
|
|
||||||
|
LEAVE();
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Set coalesce config
|
* @brief Set coalesce config
|
||||||
*
|
*
|
||||||
|
@ -5689,6 +5755,7 @@ mlan_status wlan_process_mef_cfg_cmd(mlan_private *pmpriv,
|
||||||
|
|
||||||
/** check how many entries in adapter*/
|
/** check how many entries in adapter*/
|
||||||
pmef = &pmadapter->entry_cfg;
|
pmef = &pmadapter->entry_cfg;
|
||||||
|
entry_num += pmef->enable_autoarp_entry;
|
||||||
entry_num += pmef->num_wowlan_entry;
|
entry_num += pmef->num_wowlan_entry;
|
||||||
entry_num += pmef->num_ipv6_ns_offload;
|
entry_num += pmef->num_ipv6_ns_offload;
|
||||||
if (!entry_num) {
|
if (!entry_num) {
|
||||||
|
@ -5710,6 +5777,12 @@ mlan_status wlan_process_mef_cfg_cmd(mlan_private *pmpriv,
|
||||||
memset(pmadapter, mef.pentry, 0, sizeof(mef_entry_t) * entry_num);
|
memset(pmadapter, mef.pentry, 0, sizeof(mef_entry_t) * entry_num);
|
||||||
pentry = mef.pentry;
|
pentry = mef.pentry;
|
||||||
/** Fill mef_entry_t structure*/
|
/** Fill mef_entry_t structure*/
|
||||||
|
/** Copy Auto arp response entry*/
|
||||||
|
if (pmef->enable_autoarp_entry) {
|
||||||
|
memcpy_ext(pmadapter, pentry, &pmef->entry[5],
|
||||||
|
sizeof(mef_entry_t), sizeof(mef_entry_t));
|
||||||
|
pentry += pmef->enable_autoarp_entry;
|
||||||
|
}
|
||||||
/** Copy wowlan entry*/
|
/** Copy wowlan entry*/
|
||||||
if (pmef->num_wowlan_entry) {
|
if (pmef->num_wowlan_entry) {
|
||||||
memcpy_ext(pmadapter, pentry, &pmef->entry[6],
|
memcpy_ext(pmadapter, pentry, &pmef->entry[6],
|
||||||
|
@ -5770,6 +5843,29 @@ mlan_status wlan_misc_ioctl_mef_flt_cfg(pmlan_adapter pmadapter,
|
||||||
&mef_cfg->mef_entry, sizeof(mef_entry_t),
|
&mef_cfg->mef_entry, sizeof(mef_entry_t),
|
||||||
sizeof(mef_entry_t));
|
sizeof(mef_entry_t));
|
||||||
}
|
}
|
||||||
|
/** Set AUTO ARP Entry to adapter*/
|
||||||
|
if (mef_cfg->mef_act_type == MEF_ACT_AUTOARP) {
|
||||||
|
if (mef_cfg->op_code & MLAN_IPADDR_OP_AUTO_ARP_RESP) {
|
||||||
|
pmef->enable_autoarp_entry = 1;
|
||||||
|
pmef->criteria |= mef_cfg->criteria;
|
||||||
|
memcpy_ext(pmadapter, &pmef->entry[5],
|
||||||
|
&mef_cfg->mef_entry,
|
||||||
|
sizeof(mef_entry_t),
|
||||||
|
sizeof(mef_entry_t));
|
||||||
|
if (MLAN_STATUS_SUCCESS !=
|
||||||
|
wlan_process_mef_cfg_cmd(
|
||||||
|
pmadapter
|
||||||
|
->priv[pioctl_req->bss_index],
|
||||||
|
pmadapter))
|
||||||
|
PRINTM(MERROR,
|
||||||
|
"Set MEF Entries Error\n");
|
||||||
|
} else if (mef_cfg->op_code &
|
||||||
|
MLAN_IPADDR_OP_IP_REMOVE) {
|
||||||
|
pmef->enable_autoarp_entry = 0;
|
||||||
|
memset(pmadapter, &pmef->entry[5], 0,
|
||||||
|
sizeof(mef_entry_t));
|
||||||
|
}
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case MLAN_ACT_GET:
|
case MLAN_ACT_GET:
|
||||||
if (mef_cfg->mef_act_type == MEF_ACT_WOWLAN)
|
if (mef_cfg->mef_act_type == MEF_ACT_WOWLAN)
|
||||||
|
@ -6800,3 +6896,41 @@ mlan_status wlan_misc_ioctl_range_ext(pmlan_adapter pmadapter,
|
||||||
LEAVE();
|
LEAVE();
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef UAP_SUPPORT
|
||||||
|
/**
|
||||||
|
* @brief set wacp mode
|
||||||
|
*
|
||||||
|
* @param pmadapter A pointer to mlan_adapter structure
|
||||||
|
* @param pioctl_req A pointer to ioctl request buffer
|
||||||
|
*
|
||||||
|
* @return MLAN_STATUS_PENDING --success, otherwise fail
|
||||||
|
*/
|
||||||
|
mlan_status wlan_misc_ioctl_wacp_mode(IN pmlan_adapter pmadapter,
|
||||||
|
IN pmlan_ioctl_req pioctl_req)
|
||||||
|
{
|
||||||
|
mlan_status ret = MLAN_STATUS_SUCCESS;
|
||||||
|
mlan_private *pmpriv = pmadapter->priv[pioctl_req->bss_index];
|
||||||
|
mlan_ds_misc_cfg *misc = MNULL;
|
||||||
|
t_u16 cmd_action;
|
||||||
|
|
||||||
|
ENTER();
|
||||||
|
|
||||||
|
misc = (mlan_ds_misc_cfg *)pioctl_req->pbuf;
|
||||||
|
|
||||||
|
if (pioctl_req->action == MLAN_ACT_SET)
|
||||||
|
cmd_action = HostCmd_ACT_GEN_SET;
|
||||||
|
else
|
||||||
|
cmd_action = HostCmd_ACT_GEN_GET;
|
||||||
|
|
||||||
|
ret = wlan_prepare_cmd(pmpriv, HOST_CMD_APCMD_SYS_CONFIGURE, cmd_action,
|
||||||
|
0, (t_void *)pioctl_req,
|
||||||
|
(t_void *)&misc->param.wacp_mode);
|
||||||
|
|
||||||
|
if (ret == MLAN_STATUS_SUCCESS)
|
||||||
|
ret = MLAN_STATUS_PENDING;
|
||||||
|
|
||||||
|
LEAVE();
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
|
@ -57,6 +57,8 @@ EXPORT_SYMBOL(mlan_is_main_process_running);
|
||||||
#ifdef PCIE
|
#ifdef PCIE
|
||||||
EXPORT_SYMBOL(mlan_set_int_mode);
|
EXPORT_SYMBOL(mlan_set_int_mode);
|
||||||
#endif
|
#endif
|
||||||
|
EXPORT_SYMBOL(mlan_disable_host_int);
|
||||||
|
EXPORT_SYMBOL(mlan_enable_host_int);
|
||||||
|
|
||||||
MODULE_DESCRIPTION("M-WLAN MLAN Driver");
|
MODULE_DESCRIPTION("M-WLAN MLAN Driver");
|
||||||
MODULE_AUTHOR("NXP");
|
MODULE_AUTHOR("NXP");
|
||||||
|
|
|
@ -46,7 +46,7 @@ Change log:
|
||||||
/** minimum scan time for passive to active scan */
|
/** minimum scan time for passive to active scan */
|
||||||
#define MIN_PASSIVE_TO_ACTIVE_SCAN_TIME 150
|
#define MIN_PASSIVE_TO_ACTIVE_SCAN_TIME 150
|
||||||
|
|
||||||
#define MRVDRV_MAX_CHANNELS_PER_SCAN 40
|
#define MRVDRV_MAX_CHANNELS_PER_SCAN 38
|
||||||
/** The maximum number of channels the firmware can scan per command */
|
/** The maximum number of channels the firmware can scan per command */
|
||||||
#define MRVDRV_MAX_CHANNELS_PER_SPECIFIC_SCAN 4
|
#define MRVDRV_MAX_CHANNELS_PER_SPECIFIC_SCAN 4
|
||||||
|
|
||||||
|
@ -4832,7 +4832,6 @@ mlan_status wlan_cmd_802_11_scan_ext(mlan_private *pmpriv,
|
||||||
(t_u16)(sizeof(pext_scan_cmd->reserved)) +
|
(t_u16)(sizeof(pext_scan_cmd->reserved)) +
|
||||||
S_DS_GEN));
|
S_DS_GEN));
|
||||||
pext_scan_cmd->ext_scan_type = EXT_SCAN_CANCEL;
|
pext_scan_cmd->ext_scan_type = EXT_SCAN_CANCEL;
|
||||||
pmpriv->adapter->cmd_lock = MFALSE;
|
|
||||||
LEAVE();
|
LEAVE();
|
||||||
return MLAN_STATUS_SUCCESS;
|
return MLAN_STATUS_SUCCESS;
|
||||||
}
|
}
|
||||||
|
@ -4902,7 +4901,6 @@ mlan_status wlan_ret_802_11_scan_ext(mlan_private *pmpriv,
|
||||||
LEAVE();
|
LEAVE();
|
||||||
return MLAN_STATUS_SUCCESS;
|
return MLAN_STATUS_SUCCESS;
|
||||||
} else if (ext_scan_type == EXT_SCAN_ENHANCE) {
|
} else if (ext_scan_type == EXT_SCAN_ENHANCE) {
|
||||||
pmpriv->adapter->cmd_lock = MTRUE;
|
|
||||||
/* Setup the timer after scan command response */
|
/* Setup the timer after scan command response */
|
||||||
pcb->moal_start_timer(pmpriv->adapter->pmoal_handle,
|
pcb->moal_start_timer(pmpriv->adapter->pmoal_handle,
|
||||||
pmpriv->adapter->pmlan_cmd_timer, MFALSE,
|
pmpriv->adapter->pmlan_cmd_timer, MFALSE,
|
||||||
|
@ -5902,6 +5900,7 @@ done:
|
||||||
MLAN_STATUS_SUCCESS);
|
MLAN_STATUS_SUCCESS);
|
||||||
}
|
}
|
||||||
wlan_release_cmd_lock(pmadapter);
|
wlan_release_cmd_lock(pmadapter);
|
||||||
|
wlan_move_cmd_to_cmd_pending_q(pmadapter);
|
||||||
pmadapter->bgscan_reported = MFALSE;
|
pmadapter->bgscan_reported = MFALSE;
|
||||||
wlan_recv_event(pmpriv, MLAN_EVENT_ID_DRV_SCAN_REPORT, MNULL);
|
wlan_recv_event(pmpriv, MLAN_EVENT_ID_DRV_SCAN_REPORT, MNULL);
|
||||||
LEAVE();
|
LEAVE();
|
||||||
|
|
|
@ -290,6 +290,7 @@ static const struct _mlan_sdio_card_reg mlan_reg_sd8977_sd8997 = {
|
||||||
.winner_check_reg = 0xFC,
|
.winner_check_reg = 0xFC,
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef SD8997
|
#ifdef SD8997
|
||||||
static const struct _mlan_card_info mlan_card_info_sd8997 = {
|
static const struct _mlan_card_info mlan_card_info_sd8997 = {
|
||||||
.max_tx_buf_size = MLAN_TX_DATA_BUF_SIZE_4K,
|
.max_tx_buf_size = MLAN_TX_DATA_BUF_SIZE_4K,
|
||||||
|
@ -1235,6 +1236,8 @@ static mlan_status wlan_decode_rx_packet(mlan_adapter *pmadapter,
|
||||||
{
|
{
|
||||||
t_u8 *cmd_buf;
|
t_u8 *cmd_buf;
|
||||||
t_u32 event;
|
t_u32 event;
|
||||||
|
t_u32 in_ts_sec, in_ts_usec;
|
||||||
|
pmlan_callbacks pcb = &pmadapter->callbacks;
|
||||||
|
|
||||||
ENTER();
|
ENTER();
|
||||||
|
|
||||||
|
@ -1277,19 +1280,43 @@ static mlan_status wlan_decode_rx_packet(mlan_adapter *pmadapter,
|
||||||
pmbuf->data_len = (pmadapter->upld_len - SDIO_INTF_HEADER_LEN);
|
pmbuf->data_len = (pmadapter->upld_len - SDIO_INTF_HEADER_LEN);
|
||||||
pmbuf->data_offset += SDIO_INTF_HEADER_LEN;
|
pmbuf->data_offset += SDIO_INTF_HEADER_LEN;
|
||||||
if (pmadapter->rx_work_flag) {
|
if (pmadapter->rx_work_flag) {
|
||||||
|
// rx_trace 5
|
||||||
|
if (pmadapter->tp_state_on) {
|
||||||
|
pmadapter->callbacks.moal_tp_accounting(
|
||||||
|
pmadapter->pmoal_handle, pmbuf,
|
||||||
|
5 /*RX_DROP_P1*/);
|
||||||
|
pcb->moal_get_system_time(
|
||||||
|
pmadapter->pmoal_handle, &in_ts_sec,
|
||||||
|
&in_ts_usec);
|
||||||
|
pmbuf->in_ts_sec = in_ts_sec;
|
||||||
|
pmbuf->in_ts_usec = in_ts_usec;
|
||||||
|
}
|
||||||
|
if (pmadapter->tp_state_drop_point ==
|
||||||
|
5 /*RX_DROP_P1*/) {
|
||||||
|
pmadapter->ops.data_complete(
|
||||||
|
pmadapter, pmbuf, MLAN_STATUS_SUCCESS);
|
||||||
|
} else {
|
||||||
if (lock_flag)
|
if (lock_flag)
|
||||||
pmadapter->callbacks.moal_spin_lock(
|
pmadapter->callbacks.moal_spin_lock(
|
||||||
pmadapter->pmoal_handle,
|
pmadapter->pmoal_handle,
|
||||||
pmadapter->rx_data_queue.plock);
|
pmadapter->rx_data_queue.plock);
|
||||||
util_enqueue_list_tail(pmadapter->pmoal_handle,
|
util_enqueue_list_tail(
|
||||||
|
pmadapter->pmoal_handle,
|
||||||
&pmadapter->rx_data_queue,
|
&pmadapter->rx_data_queue,
|
||||||
(pmlan_linked_list)pmbuf, MNULL,
|
(pmlan_linked_list)pmbuf, MNULL, MNULL);
|
||||||
MNULL);
|
|
||||||
pmadapter->rx_pkts_queued++;
|
pmadapter->rx_pkts_queued++;
|
||||||
|
if (pmadapter->tp_state_on)
|
||||||
|
pmadapter->callbacks
|
||||||
|
.moal_tp_accounting_rx_param(
|
||||||
|
pmadapter->pmoal_handle,
|
||||||
|
1,
|
||||||
|
pmadapter
|
||||||
|
->rx_pkts_queued);
|
||||||
if (lock_flag)
|
if (lock_flag)
|
||||||
pmadapter->callbacks.moal_spin_unlock(
|
pmadapter->callbacks.moal_spin_unlock(
|
||||||
pmadapter->pmoal_handle,
|
pmadapter->pmoal_handle,
|
||||||
pmadapter->rx_data_queue.plock);
|
pmadapter->rx_data_queue.plock);
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
wlan_handle_rx_packet(pmadapter, pmbuf);
|
wlan_handle_rx_packet(pmadapter, pmbuf);
|
||||||
}
|
}
|
||||||
|
@ -2397,6 +2424,80 @@ mlan_status wlan_get_sdio_device(pmlan_adapter pmadapter)
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief This function dump the mp registers when issue happened
|
||||||
|
*
|
||||||
|
* @param pmadapter A pointer to mlan_adapter structure
|
||||||
|
* @return N/A
|
||||||
|
*/
|
||||||
|
void wlan_dump_mp_registers(pmlan_adapter pmadapter)
|
||||||
|
{
|
||||||
|
t_u32 mp_wr_bitmap;
|
||||||
|
t_bool new_mode = pmadapter->pcard_sd->supports_sdio_new_mode;
|
||||||
|
t_u32 mp_rd_bitmap;
|
||||||
|
t_u16 rx_len = 0;
|
||||||
|
const mlan_sdio_card_reg *reg = pmadapter->pcard_sd->reg;
|
||||||
|
t_u8 cmd_rd_len_0 = reg->cmd_rd_len_0;
|
||||||
|
t_u8 cmd_rd_len_1 = reg->cmd_rd_len_1;
|
||||||
|
t_u8 host_int_status_reg = reg->host_int_status_reg;
|
||||||
|
t_u32 sdio_ireg = 0;
|
||||||
|
|
||||||
|
mp_wr_bitmap = (t_u32)pmadapter->pcard_sd->mp_regs[reg->wr_bitmap_l];
|
||||||
|
mp_wr_bitmap |= ((t_u32)pmadapter->pcard_sd->mp_regs[reg->wr_bitmap_u])
|
||||||
|
<< 8;
|
||||||
|
if (new_mode) {
|
||||||
|
mp_wr_bitmap |=
|
||||||
|
((t_u32)pmadapter->pcard_sd->mp_regs[reg->wr_bitmap_1l])
|
||||||
|
<< 16;
|
||||||
|
mp_wr_bitmap |=
|
||||||
|
((t_u32)pmadapter->pcard_sd->mp_regs[reg->wr_bitmap_1u])
|
||||||
|
<< 24;
|
||||||
|
}
|
||||||
|
PRINTM(MMSG, "wlan: mp_data_port_mask = 0x%x\n",
|
||||||
|
pmadapter->pcard_sd->mp_data_port_mask);
|
||||||
|
PRINTM(MMSG, "wlan: HW wr_bitmap=0x%08x Host: wr_bitmap=0x%08x\n",
|
||||||
|
mp_wr_bitmap, pmadapter->pcard_sd->mp_wr_bitmap);
|
||||||
|
mp_rd_bitmap = (t_u32)pmadapter->pcard_sd->mp_regs[reg->rd_bitmap_l];
|
||||||
|
mp_rd_bitmap |= ((t_u32)pmadapter->pcard_sd->mp_regs[reg->rd_bitmap_u])
|
||||||
|
<< 8;
|
||||||
|
if (new_mode) {
|
||||||
|
mp_rd_bitmap |=
|
||||||
|
((t_u32)pmadapter->pcard_sd->mp_regs[reg->rd_bitmap_1l])
|
||||||
|
<< 16;
|
||||||
|
mp_rd_bitmap |=
|
||||||
|
((t_u32)pmadapter->pcard_sd->mp_regs[reg->rd_bitmap_1u])
|
||||||
|
<< 24;
|
||||||
|
}
|
||||||
|
PRINTM(MMSG, "wlan: HW rd_bitmap=0x%08x Host: rd_bitmap=0x%08x\n",
|
||||||
|
mp_rd_bitmap, pmadapter->pcard_sd->mp_rd_bitmap);
|
||||||
|
|
||||||
|
if (new_mode) {
|
||||||
|
rx_len = ((t_u16)pmadapter->pcard_sd->mp_regs[cmd_rd_len_1])
|
||||||
|
<< 8;
|
||||||
|
rx_len |= (t_u16)pmadapter->pcard_sd->mp_regs[cmd_rd_len_0];
|
||||||
|
PRINTM(MMSG, "wlan: cmd rx buffer rx_len = %d\n", rx_len);
|
||||||
|
}
|
||||||
|
PRINTM(MMSG, "wlan: HW sdio_ireg = 0x%x\n",
|
||||||
|
pmadapter->pcard_sd->mp_regs[host_int_status_reg]);
|
||||||
|
sdio_ireg = pmadapter->pcard_sd->mp_regs[host_int_status_reg];
|
||||||
|
|
||||||
|
if (new_mode && rx_len)
|
||||||
|
sdio_ireg |= UP_LD_CMD_PORT_HOST_INT_STATUS;
|
||||||
|
|
||||||
|
if (!(pmadapter->pcard_sd->mp_wr_bitmap &
|
||||||
|
pmadapter->pcard_sd->mp_data_port_mask)) {
|
||||||
|
if (mp_wr_bitmap & pmadapter->pcard_sd->mp_data_port_mask)
|
||||||
|
sdio_ireg |= DN_LD_HOST_INT_STATUS;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((!pmadapter->pcard_sd->mp_rd_bitmap) && mp_rd_bitmap)
|
||||||
|
sdio_ireg |= UP_LD_HOST_INT_STATUS;
|
||||||
|
|
||||||
|
pmadapter->pcard_sd->mp_regs[host_int_status_reg] = sdio_ireg;
|
||||||
|
PRINTM(MMSG, "wlan: recovered sdio_ireg=0x%x\n", sdio_ireg);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief This function gets interrupt status.
|
* @brief This function gets interrupt status.
|
||||||
*
|
*
|
||||||
|
@ -2405,10 +2506,12 @@ mlan_status wlan_get_sdio_device(pmlan_adapter pmadapter)
|
||||||
*/
|
*/
|
||||||
static mlan_status wlan_sdio_interrupt(t_u16 msg_id, pmlan_adapter pmadapter)
|
static mlan_status wlan_sdio_interrupt(t_u16 msg_id, pmlan_adapter pmadapter)
|
||||||
{
|
{
|
||||||
|
mlan_status ret = MLAN_STATUS_SUCCESS;
|
||||||
pmlan_callbacks pcb = &pmadapter->callbacks;
|
pmlan_callbacks pcb = &pmadapter->callbacks;
|
||||||
mlan_buffer mbuf;
|
mlan_buffer mbuf;
|
||||||
t_u32 sdio_ireg = 0;
|
t_u32 sdio_ireg = 0;
|
||||||
t_u8 offset = 0;
|
t_u8 offset = 0;
|
||||||
|
t_u8 i = 0;
|
||||||
int max_mp_regs = pmadapter->pcard_sd->reg->max_mp_regs;
|
int max_mp_regs = pmadapter->pcard_sd->reg->max_mp_regs;
|
||||||
t_u8 host_int_status_reg =
|
t_u8 host_int_status_reg =
|
||||||
pmadapter->pcard_sd->reg->host_int_status_reg;
|
pmadapter->pcard_sd->reg->host_int_status_reg;
|
||||||
|
@ -2419,20 +2522,32 @@ static mlan_status wlan_sdio_interrupt(t_u16 msg_id, pmlan_adapter pmadapter)
|
||||||
memset(pmadapter, &mbuf, 0, sizeof(mlan_buffer));
|
memset(pmadapter, &mbuf, 0, sizeof(mlan_buffer));
|
||||||
mbuf.pbuf = pmadapter->pcard_sd->mp_regs + offset;
|
mbuf.pbuf = pmadapter->pcard_sd->mp_regs + offset;
|
||||||
mbuf.data_len = MIN(max_mp_regs, MLAN_SDIO_BLOCK_SIZE);
|
mbuf.data_len = MIN(max_mp_regs, MLAN_SDIO_BLOCK_SIZE);
|
||||||
|
do {
|
||||||
if (MLAN_STATUS_SUCCESS !=
|
ret = pcb->moal_read_data_sync(
|
||||||
pcb->moal_read_data_sync(pmadapter->pmoal_handle, &mbuf,
|
pmadapter->pmoal_handle, &mbuf,
|
||||||
(REG_PORT + offset) |
|
(REG_PORT + offset) | MLAN_SDIO_BYTE_MODE_MASK,
|
||||||
MLAN_SDIO_BYTE_MODE_MASK,
|
0);
|
||||||
0)) {
|
if (ret != MLAN_STATUS_SUCCESS) {
|
||||||
PRINTM(MERROR,
|
PRINTM(MERROR,
|
||||||
"moal_read_data_sync: read registers failed\n");
|
"wlan: cmd53 read regs failed: %d port=%x retry=%d\n",
|
||||||
|
ret, REG_PORT + offset, i);
|
||||||
|
i++;
|
||||||
|
pcb->moal_write_reg(pmadapter->pmoal_handle,
|
||||||
|
HOST_TO_CARD_EVENT_REG,
|
||||||
|
HOST_TERM_CMD53);
|
||||||
|
if (i > MAX_WRITE_IOMEM_RETRY) {
|
||||||
|
PRINTM(MERROR,
|
||||||
|
"wlan: Fail to read mp_regs\n");
|
||||||
pmadapter->dbg.num_int_read_failure++;
|
pmadapter->dbg.num_int_read_failure++;
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
} while (ret == MLAN_STATUS_FAILURE);
|
||||||
offset += mbuf.data_len;
|
offset += mbuf.data_len;
|
||||||
max_mp_regs -= mbuf.data_len;
|
max_mp_regs -= mbuf.data_len;
|
||||||
}
|
}
|
||||||
|
if (i > 0)
|
||||||
|
wlan_dump_mp_registers(pmadapter);
|
||||||
|
|
||||||
DBG_HEXDUMP(MIF_D, "SDIO MP Registers", pmadapter->pcard_sd->mp_regs,
|
DBG_HEXDUMP(MIF_D, "SDIO MP Registers", pmadapter->pcard_sd->mp_regs,
|
||||||
max_mp_regs);
|
max_mp_regs);
|
||||||
|
@ -2669,6 +2784,8 @@ static mlan_status wlan_process_sdio_int_status(mlan_adapter *pmadapter)
|
||||||
if (pmadapter->data_sent &&
|
if (pmadapter->data_sent &&
|
||||||
(pmadapter->pcard_sd->mp_wr_bitmap &
|
(pmadapter->pcard_sd->mp_wr_bitmap &
|
||||||
(1 << pmadapter->pcard_sd->curr_wr_port))) {
|
(1 << pmadapter->pcard_sd->curr_wr_port))) {
|
||||||
|
pmadapter->callbacks.moal_tp_accounting_rx_param(
|
||||||
|
pmadapter->pmoal_handle, 3, 0);
|
||||||
PRINTM(MINFO, " <--- Tx DONE Interrupt --->\n");
|
PRINTM(MINFO, " <--- Tx DONE Interrupt --->\n");
|
||||||
pmadapter->data_sent = MFALSE;
|
pmadapter->data_sent = MFALSE;
|
||||||
}
|
}
|
||||||
|
@ -2699,8 +2816,13 @@ static mlan_status wlan_process_sdio_int_status(mlan_adapter *pmadapter)
|
||||||
->mp_regs[reg->rd_bitmap_1u])
|
->mp_regs[reg->rd_bitmap_1u])
|
||||||
<< 24;
|
<< 24;
|
||||||
}
|
}
|
||||||
|
pmadapter->pcard_sd->last_recv_rd_bitmap =
|
||||||
|
pmadapter->pcard_sd->mp_rd_bitmap;
|
||||||
|
|
||||||
PRINTM(MINTR, "UPLD: rd_bitmap=0x%08x\n",
|
PRINTM(MINTR, "UPLD: rd_bitmap=0x%08x\n",
|
||||||
pmadapter->pcard_sd->mp_rd_bitmap);
|
pmadapter->pcard_sd->mp_rd_bitmap);
|
||||||
|
pmadapter->callbacks.moal_tp_accounting_rx_param(
|
||||||
|
pmadapter->pmoal_handle, 0, 0);
|
||||||
|
|
||||||
while (MTRUE) {
|
while (MTRUE) {
|
||||||
ret = wlan_get_rd_port(pmadapter, &port);
|
ret = wlan_get_rd_port(pmadapter, &port);
|
||||||
|
@ -3522,6 +3644,8 @@ mlan_adapter_operations mlan_sdio_ops = {
|
||||||
.data_complete = wlan_sdio_data_evt_complete,
|
.data_complete = wlan_sdio_data_evt_complete,
|
||||||
.cmdrsp_complete = wlan_sdio_data_evt_complete,
|
.cmdrsp_complete = wlan_sdio_data_evt_complete,
|
||||||
.handle_rx_packet = wlan_sdio_handle_rx_packet,
|
.handle_rx_packet = wlan_sdio_handle_rx_packet,
|
||||||
|
.disable_host_int = wlan_disable_sdio_host_int,
|
||||||
|
.enable_host_int = wlan_enable_sdio_host_int,
|
||||||
|
|
||||||
.intf_header_len = SDIO_INTF_HEADER_LEN,
|
.intf_header_len = SDIO_INTF_HEADER_LEN,
|
||||||
};
|
};
|
||||||
|
|
|
@ -414,6 +414,7 @@ mlan_status mlan_register(pmlan_device pmdevice, t_void **ppmlan_adapter)
|
||||||
pmadapter->init_para.mfg_mode = pmdevice->mfg_mode;
|
pmadapter->init_para.mfg_mode = pmdevice->mfg_mode;
|
||||||
#endif
|
#endif
|
||||||
pmadapter->init_para.auto_ds = pmdevice->auto_ds;
|
pmadapter->init_para.auto_ds = pmdevice->auto_ds;
|
||||||
|
pmadapter->init_para.ext_scan = pmdevice->ext_scan;
|
||||||
pmadapter->init_para.ps_mode = pmdevice->ps_mode;
|
pmadapter->init_para.ps_mode = pmdevice->ps_mode;
|
||||||
if (pmdevice->max_tx_buf == MLAN_TX_DATA_BUF_SIZE_2K ||
|
if (pmdevice->max_tx_buf == MLAN_TX_DATA_BUF_SIZE_2K ||
|
||||||
pmdevice->max_tx_buf == MLAN_TX_DATA_BUF_SIZE_4K ||
|
pmdevice->max_tx_buf == MLAN_TX_DATA_BUF_SIZE_4K ||
|
||||||
|
@ -644,6 +645,74 @@ mlan_status mlan_dnld_fw(t_void *padapter, pmlan_fw_image pmfw)
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief This function mask host interrupt from firmware
|
||||||
|
*
|
||||||
|
* @param padapter A pointer to a t_void pointer to store
|
||||||
|
* mlan_adapter structure pointer
|
||||||
|
*
|
||||||
|
* @return MLAN_STATUS_SUCCESS
|
||||||
|
* The firmware download succeeded.
|
||||||
|
* MLAN_STATUS_FAILURE
|
||||||
|
* The firmware download failed.
|
||||||
|
*/
|
||||||
|
mlan_status mlan_disable_host_int(t_void *padapter)
|
||||||
|
{
|
||||||
|
mlan_status ret = MLAN_STATUS_FAILURE;
|
||||||
|
mlan_adapter *pmadapter = (mlan_adapter *)padapter;
|
||||||
|
|
||||||
|
ENTER();
|
||||||
|
MASSERT(padapter);
|
||||||
|
|
||||||
|
/* mask host interrupt from firmware */
|
||||||
|
if (pmadapter->ops.disable_host_int) {
|
||||||
|
ret = pmadapter->ops.disable_host_int(pmadapter);
|
||||||
|
if (ret != MLAN_STATUS_SUCCESS) {
|
||||||
|
PRINTM(MERROR,
|
||||||
|
"mlan_disable_host_int fail ret = 0x%x\n", ret);
|
||||||
|
LEAVE();
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
LEAVE();
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief This function unmask host interrupt from firmware
|
||||||
|
*
|
||||||
|
* @param padapter A pointer to a t_void pointer to store
|
||||||
|
* mlan_adapter structure pointer
|
||||||
|
*
|
||||||
|
* @return MLAN_STATUS_SUCCESS
|
||||||
|
* The firmware download succeeded.
|
||||||
|
* MLAN_STATUS_FAILURE
|
||||||
|
* The firmware download failed.
|
||||||
|
*/
|
||||||
|
mlan_status mlan_enable_host_int(t_void *padapter)
|
||||||
|
{
|
||||||
|
mlan_status ret = MLAN_STATUS_FAILURE;
|
||||||
|
mlan_adapter *pmadapter = (mlan_adapter *)padapter;
|
||||||
|
|
||||||
|
ENTER();
|
||||||
|
MASSERT(padapter);
|
||||||
|
|
||||||
|
/* unmask host interrupt from firmware */
|
||||||
|
if (pmadapter->ops.enable_host_int) {
|
||||||
|
ret = pmadapter->ops.enable_host_int(pmadapter);
|
||||||
|
if (ret != MLAN_STATUS_SUCCESS) {
|
||||||
|
PRINTM(MERROR, "mlan_enable_host_int fail ret = 0x%x\n",
|
||||||
|
ret);
|
||||||
|
LEAVE();
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
LEAVE();
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief This function pass init param to MLAN
|
* @brief This function pass init param to MLAN
|
||||||
*
|
*
|
||||||
|
@ -1164,7 +1233,6 @@ process_start:
|
||||||
wlan_11h_radar_detected_tx_blocked(pmadapter)) {
|
wlan_11h_radar_detected_tx_blocked(pmadapter)) {
|
||||||
if (pmadapter->cmd_sent ||
|
if (pmadapter->cmd_sent ||
|
||||||
pmadapter->curr_cmd ||
|
pmadapter->curr_cmd ||
|
||||||
pmadapter->cmd_lock ||
|
|
||||||
!wlan_is_send_cmd_allowed(
|
!wlan_is_send_cmd_allowed(
|
||||||
pmadapter->tdls_status) ||
|
pmadapter->tdls_status) ||
|
||||||
!wlan_is_cmd_pending(pmadapter)) {
|
!wlan_is_cmd_pending(pmadapter)) {
|
||||||
|
@ -1224,7 +1292,6 @@ process_start:
|
||||||
pmadapter->vdll_ctrl.pending_block = MNULL;
|
pmadapter->vdll_ctrl.pending_block = MNULL;
|
||||||
}
|
}
|
||||||
if (!pmadapter->cmd_sent && !pmadapter->curr_cmd &&
|
if (!pmadapter->cmd_sent && !pmadapter->curr_cmd &&
|
||||||
!pmadapter->cmd_lock &&
|
|
||||||
wlan_is_send_cmd_allowed(pmadapter->tdls_status)) {
|
wlan_is_send_cmd_allowed(pmadapter->tdls_status)) {
|
||||||
if (wlan_exec_next_cmd(pmadapter) ==
|
if (wlan_exec_next_cmd(pmadapter) ==
|
||||||
MLAN_STATUS_FAILURE) {
|
MLAN_STATUS_FAILURE) {
|
||||||
|
|
|
@ -686,6 +686,21 @@ static mlan_status wlan_cmd_802_11_hs_cfg(pmlan_private pmpriv,
|
||||||
}
|
}
|
||||||
cmd->command = wlan_cpu_to_le16(HostCmd_CMD_802_11_HS_CFG_ENH);
|
cmd->command = wlan_cpu_to_le16(HostCmd_CMD_802_11_HS_CFG_ENH);
|
||||||
|
|
||||||
|
if (!hs_activate && (pdata_buf->conditions != HOST_SLEEP_CFG_CANCEL) &&
|
||||||
|
((pmadapter->arp_filter_size > 0) &&
|
||||||
|
(pmadapter->arp_filter_size <= ARP_FILTER_MAX_BUF_SIZE))) {
|
||||||
|
PRINTM(MINFO, "Attach %d bytes ArpFilter to HSCfg cmd\n",
|
||||||
|
pmadapter->arp_filter_size);
|
||||||
|
memcpy_ext(pmpriv->adapter,
|
||||||
|
((t_u8 *)phs_cfg) +
|
||||||
|
sizeof(HostCmd_DS_802_11_HS_CFG_ENH),
|
||||||
|
pmadapter->arp_filter, pmadapter->arp_filter_size,
|
||||||
|
pmadapter->arp_filter_size);
|
||||||
|
cmd->size = pmadapter->arp_filter_size +
|
||||||
|
sizeof(HostCmd_DS_802_11_HS_CFG_ENH) + S_DS_GEN;
|
||||||
|
tlv = (t_u8 *)phs_cfg + sizeof(HostCmd_DS_802_11_HS_CFG_ENH) +
|
||||||
|
pmadapter->arp_filter_size;
|
||||||
|
} else
|
||||||
cmd->size = S_DS_GEN + sizeof(HostCmd_DS_802_11_HS_CFG_ENH);
|
cmd->size = S_DS_GEN + sizeof(HostCmd_DS_802_11_HS_CFG_ENH);
|
||||||
|
|
||||||
if (hs_activate) {
|
if (hs_activate) {
|
||||||
|
@ -1265,7 +1280,12 @@ static mlan_status wlan_cmd_802_11_key_material(pmlan_private pmpriv,
|
||||||
~(wlan_cpu_to_le16(KEY_INFO_MCAST_KEY));
|
~(wlan_cpu_to_le16(KEY_INFO_MCAST_KEY));
|
||||||
pkey_material->key_param_set.key_info |=
|
pkey_material->key_param_set.key_info |=
|
||||||
wlan_cpu_to_le16(KEY_INFO_AES_MCAST_IGTK);
|
wlan_cpu_to_le16(KEY_INFO_AES_MCAST_IGTK);
|
||||||
pkey_material->key_param_set.key_type = KEY_TYPE_ID_AES_CMAC;
|
if (pkey->key_flags & KEY_FLAG_GMAC_128)
|
||||||
|
pkey_material->key_param_set.key_type =
|
||||||
|
KEY_TYPE_ID_BIP_GMAC_128;
|
||||||
|
else
|
||||||
|
pkey_material->key_param_set.key_type =
|
||||||
|
KEY_TYPE_ID_AES_CMAC;
|
||||||
pkey_material->key_param_set.key_params.cmac_aes.key_len =
|
pkey_material->key_param_set.key_params.cmac_aes.key_len =
|
||||||
wlan_cpu_to_le16(pkey->key_len);
|
wlan_cpu_to_le16(pkey->key_len);
|
||||||
memcpy_ext(pmpriv->adapter,
|
memcpy_ext(pmpriv->adapter,
|
||||||
|
@ -1277,9 +1297,41 @@ static mlan_status wlan_cmd_802_11_key_material(pmlan_private pmpriv,
|
||||||
S_DS_GEN + KEY_PARAMS_FIXED_LEN +
|
S_DS_GEN + KEY_PARAMS_FIXED_LEN +
|
||||||
sizeof(cmac_aes_param) +
|
sizeof(cmac_aes_param) +
|
||||||
sizeof(pkey_material->action));
|
sizeof(pkey_material->action));
|
||||||
|
if (pkey->key_flags & KEY_FLAG_GMAC_128)
|
||||||
|
PRINTM(MCMND, "Set AES 128 GMAC Key\n");
|
||||||
|
else
|
||||||
PRINTM(MCMND, "Set CMAC AES Key\n");
|
PRINTM(MCMND, "Set CMAC AES Key\n");
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
|
if (pkey->key_len == WPA_IGTK_256_KEY_LEN &&
|
||||||
|
(pkey->key_flags & KEY_FLAG_AES_MCAST_IGTK)) {
|
||||||
|
if (pkey->key_flags &
|
||||||
|
(KEY_FLAG_RX_SEQ_VALID | KEY_FLAG_TX_SEQ_VALID))
|
||||||
|
memcpy_ext(pmpriv->adapter,
|
||||||
|
pkey_material->key_param_set.key_params
|
||||||
|
.cmac_aes.ipn,
|
||||||
|
pkey->pn, SEQ_MAX_SIZE, IGTK_PN_SIZE);
|
||||||
|
pkey_material->key_param_set.key_info &=
|
||||||
|
~(wlan_cpu_to_le16(KEY_INFO_MCAST_KEY));
|
||||||
|
pkey_material->key_param_set.key_info |=
|
||||||
|
wlan_cpu_to_le16(KEY_INFO_AES_MCAST_IGTK);
|
||||||
|
pkey_material->key_param_set.key_type =
|
||||||
|
KEY_TYPE_ID_BIP_GMAC_256;
|
||||||
|
pkey_material->key_param_set.key_params.cmac_aes.key_len =
|
||||||
|
wlan_cpu_to_le16(pkey->key_len);
|
||||||
|
memcpy_ext(pmpriv->adapter,
|
||||||
|
pkey_material->key_param_set.key_params.cmac_aes.key,
|
||||||
|
pkey->key_material, pkey->key_len,
|
||||||
|
WPA_IGTK_256_KEY_LEN);
|
||||||
|
pkey_material->key_param_set.length = wlan_cpu_to_le16(
|
||||||
|
KEY_PARAMS_FIXED_LEN + sizeof(gmac_aes_256_param));
|
||||||
|
cmd->size = wlan_cpu_to_le16(sizeof(MrvlIEtypesHeader_t) +
|
||||||
|
S_DS_GEN + KEY_PARAMS_FIXED_LEN +
|
||||||
|
sizeof(gmac_aes_256_param) +
|
||||||
|
sizeof(pkey_material->action));
|
||||||
|
PRINTM(MCMND, "Set AES 256 GMAC Key\n");
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
if (pkey->key_len == WPA_TKIP_KEY_LEN) {
|
if (pkey->key_len == WPA_TKIP_KEY_LEN) {
|
||||||
if (pkey->key_flags &
|
if (pkey->key_flags &
|
||||||
(KEY_FLAG_RX_SEQ_VALID | KEY_FLAG_TX_SEQ_VALID))
|
(KEY_FLAG_RX_SEQ_VALID | KEY_FLAG_TX_SEQ_VALID))
|
||||||
|
@ -2679,6 +2731,47 @@ mlan_status wlan_cmd_arb_cfg(pmlan_private pmpriv, HostCmd_DS_COMMAND *cmd,
|
||||||
return MLAN_STATUS_SUCCESS;
|
return MLAN_STATUS_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief This function set ipv6 ra offload configuration.
|
||||||
|
*
|
||||||
|
* @param pmpriv A pointer to mlan_private structure
|
||||||
|
* @param pcmd A pointer to HostCmd_DS_COMMAND structure
|
||||||
|
* @param cmd_action Command action
|
||||||
|
* @param pdata_buf A pointer to information buffer
|
||||||
|
* @return N/A
|
||||||
|
*/
|
||||||
|
|
||||||
|
mlan_status wlan_cmd_ipv6_ra_offload(mlan_private *pmpriv,
|
||||||
|
HostCmd_DS_COMMAND *pcmd, t_u16 cmd_action,
|
||||||
|
void *pdata_buf)
|
||||||
|
{
|
||||||
|
HostCmd_DS_IPV6_RA_OFFLOAD *ipv6_ra_cfg = &pcmd->params.ipv6_ra_offload;
|
||||||
|
mlan_ds_misc_ipv6_ra_offload *ipv6_ra_offload =
|
||||||
|
(mlan_ds_misc_ipv6_ra_offload *)pdata_buf;
|
||||||
|
MrvlIEtypesHeader_t *ie = &ipv6_ra_cfg->ipv6_addr_param.Header;
|
||||||
|
|
||||||
|
ENTER();
|
||||||
|
|
||||||
|
pcmd->command = wlan_cpu_to_le16(HostCmd_CMD_IPV6_RA_OFFLOAD_CFG);
|
||||||
|
ipv6_ra_cfg->action = wlan_cpu_to_le16(cmd_action);
|
||||||
|
if (cmd_action == HostCmd_ACT_GEN_SET) {
|
||||||
|
ipv6_ra_cfg->enable = ipv6_ra_offload->enable;
|
||||||
|
ie->type = wlan_cpu_to_le16(TLV_TYPE_IPV6_RA_OFFLOAD);
|
||||||
|
ie->len = wlan_cpu_to_le16(16);
|
||||||
|
memcpy_ext(pmpriv->adapter,
|
||||||
|
ipv6_ra_cfg->ipv6_addr_param.ipv6_addr,
|
||||||
|
ipv6_ra_offload->ipv6_addr, 16,
|
||||||
|
sizeof(ipv6_ra_cfg->ipv6_addr_param.ipv6_addr));
|
||||||
|
pcmd->size = wlan_cpu_to_le16(
|
||||||
|
S_DS_GEN + sizeof(HostCmd_DS_IPV6_RA_OFFLOAD));
|
||||||
|
} else if (cmd_action == HostCmd_ACT_GEN_GET)
|
||||||
|
pcmd->size = wlan_cpu_to_le16(S_DS_GEN +
|
||||||
|
sizeof(ipv6_ra_cfg->action));
|
||||||
|
|
||||||
|
LEAVE();
|
||||||
|
return MLAN_STATUS_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief This function sends get sta band channel command to firmware.
|
* @brief This function sends get sta band channel command to firmware.
|
||||||
*
|
*
|
||||||
|
@ -3310,6 +3403,10 @@ mlan_status wlan_ops_sta_prepare_cmd(t_void *priv, t_u16 cmd_no,
|
||||||
case HostCmd_CMD_802_11_MIMO_SWITCH:
|
case HostCmd_CMD_802_11_MIMO_SWITCH:
|
||||||
ret = wlan_cmd_802_11_mimo_switch(pmpriv, cmd_ptr, pdata_buf);
|
ret = wlan_cmd_802_11_mimo_switch(pmpriv, cmd_ptr, pdata_buf);
|
||||||
break;
|
break;
|
||||||
|
case HostCmd_CMD_IPV6_RA_OFFLOAD_CFG:
|
||||||
|
ret = wlan_cmd_ipv6_ra_offload(pmpriv, cmd_ptr, cmd_action,
|
||||||
|
pdata_buf);
|
||||||
|
break;
|
||||||
case HostCmd_CMD_STA_CONFIGURE:
|
case HostCmd_CMD_STA_CONFIGURE:
|
||||||
ret = wlan_cmd_sta_config(pmpriv, cmd_ptr, cmd_action,
|
ret = wlan_cmd_sta_config(pmpriv, cmd_ptr, cmd_action,
|
||||||
pioctl_buf, pdata_buf);
|
pioctl_buf, pdata_buf);
|
||||||
|
@ -3368,6 +3465,10 @@ mlan_status wlan_ops_sta_prepare_cmd(t_void *priv, t_u16 cmd_no,
|
||||||
case HostCmd_CMD_TWT_CFG:
|
case HostCmd_CMD_TWT_CFG:
|
||||||
ret = wlan_cmd_twt_cfg(pmpriv, cmd_ptr, cmd_action, pdata_buf);
|
ret = wlan_cmd_twt_cfg(pmpriv, cmd_ptr, cmd_action, pdata_buf);
|
||||||
break;
|
break;
|
||||||
|
case HOST_CMD_GPIO_TSF_LATCH_PARAM_CONFIG:
|
||||||
|
ret = wlan_cmd_gpio_tsf_latch(pmpriv, cmd_ptr, cmd_action,
|
||||||
|
pioctl_buf, pdata_buf);
|
||||||
|
break;
|
||||||
case HostCmd_CMD_RX_ABORT_CFG:
|
case HostCmd_CMD_RX_ABORT_CFG:
|
||||||
ret = wlan_cmd_rxabortcfg(pmpriv, cmd_ptr, cmd_action,
|
ret = wlan_cmd_rxabortcfg(pmpriv, cmd_ptr, cmd_action,
|
||||||
pdata_buf);
|
pdata_buf);
|
||||||
|
|
|
@ -751,6 +751,14 @@ static mlan_status wlan_ret_get_log(pmlan_private pmpriv,
|
||||||
wlan_le32_to_cpu(pget_log->dwMgtErrCnt);
|
wlan_le32_to_cpu(pget_log->dwMgtErrCnt);
|
||||||
pget_info->param.stats.dwDatErrCnt =
|
pget_info->param.stats.dwDatErrCnt =
|
||||||
wlan_le32_to_cpu(pget_log->dwDatErrCnt);
|
wlan_le32_to_cpu(pget_log->dwDatErrCnt);
|
||||||
|
pget_info->param.stats.bigtk_mmeGoodCnt =
|
||||||
|
wlan_le32_to_cpu(pget_log->bigtk_mmeGoodCnt);
|
||||||
|
pget_info->param.stats.bigtk_replayErrCnt =
|
||||||
|
wlan_le32_to_cpu(pget_log->bigtk_replayErrCnt);
|
||||||
|
pget_info->param.stats.bigtk_micErrCnt =
|
||||||
|
wlan_le32_to_cpu(pget_log->bigtk_micErrCnt);
|
||||||
|
pget_info->param.stats.bigtk_mmeNotFoundCnt =
|
||||||
|
wlan_le32_to_cpu(pget_log->bigtk_mmeNotFoundCnt);
|
||||||
|
|
||||||
if (pmpriv->adapter->getlog_enable) {
|
if (pmpriv->adapter->getlog_enable) {
|
||||||
pget_info->param.stats.tx_frag_cnt =
|
pget_info->param.stats.tx_frag_cnt =
|
||||||
|
@ -2472,6 +2480,40 @@ mlan_status wlan_ret_arb_cfg(pmlan_private pmpriv, HostCmd_DS_COMMAND *resp,
|
||||||
return MLAN_STATUS_SUCCESS;
|
return MLAN_STATUS_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief This function handles the command response of ipv6 ra offload feature
|
||||||
|
*
|
||||||
|
* @param pmpriv A pointer to mlan_private structure
|
||||||
|
* @param resp A pointer to HostCmd_DS_COMMAND
|
||||||
|
* @param pioctl_buf A pointer to mlan_ioctl_req structure
|
||||||
|
*
|
||||||
|
* @return MLAN_STATUS_SUCCESS
|
||||||
|
*/
|
||||||
|
mlan_status wlan_ret_ipv6_ra_offload(pmlan_private pmpriv,
|
||||||
|
HostCmd_DS_COMMAND *resp,
|
||||||
|
mlan_ioctl_req *pioctl_buf)
|
||||||
|
{
|
||||||
|
HostCmd_DS_IPV6_RA_OFFLOAD *ipv6_ra_resp =
|
||||||
|
&resp->params.ipv6_ra_offload;
|
||||||
|
mlan_ds_misc_cfg *misc = MNULL;
|
||||||
|
mlan_ds_misc_ipv6_ra_offload *ipv6_ra = MNULL;
|
||||||
|
|
||||||
|
ENTER();
|
||||||
|
|
||||||
|
if (pioctl_buf && (pioctl_buf->action == MLAN_ACT_GET)) {
|
||||||
|
misc = (mlan_ds_misc_cfg *)pioctl_buf->pbuf;
|
||||||
|
ipv6_ra = (mlan_ds_misc_ipv6_ra_offload *)&misc->param
|
||||||
|
.ipv6_ra_offload;
|
||||||
|
ipv6_ra->enable = ipv6_ra_resp->enable;
|
||||||
|
memcpy_ext(pmpriv->adapter, ipv6_ra->ipv6_addr,
|
||||||
|
ipv6_ra_resp->ipv6_addr_param.ipv6_addr, 16,
|
||||||
|
sizeof(ipv6_ra->ipv6_addr));
|
||||||
|
}
|
||||||
|
|
||||||
|
LEAVE();
|
||||||
|
return MLAN_STATUS_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief This function handles the command response of sta get band and
|
* @brief This function handles the command response of sta get band and
|
||||||
* channel
|
* channel
|
||||||
|
@ -3196,6 +3238,9 @@ mlan_status wlan_ops_sta_process_cmdresp(t_void *priv, t_u16 cmdresp_no,
|
||||||
break;
|
break;
|
||||||
case HostCmd_CMD_802_11_MIMO_SWITCH:
|
case HostCmd_CMD_802_11_MIMO_SWITCH:
|
||||||
break;
|
break;
|
||||||
|
case HostCmd_CMD_IPV6_RA_OFFLOAD_CFG:
|
||||||
|
ret = wlan_ret_ipv6_ra_offload(pmpriv, resp, pioctl_buf);
|
||||||
|
break;
|
||||||
case HostCmd_CMD_STA_CONFIGURE:
|
case HostCmd_CMD_STA_CONFIGURE:
|
||||||
ret = wlan_ret_sta_config(pmpriv, resp, pioctl_buf);
|
ret = wlan_ret_sta_config(pmpriv, resp, pioctl_buf);
|
||||||
break;
|
break;
|
||||||
|
@ -3240,6 +3285,9 @@ mlan_status wlan_ops_sta_process_cmdresp(t_void *priv, t_u16 cmdresp_no,
|
||||||
break;
|
break;
|
||||||
case HostCmd_CMD_TWT_CFG:
|
case HostCmd_CMD_TWT_CFG:
|
||||||
break;
|
break;
|
||||||
|
case HOST_CMD_GPIO_TSF_LATCH_PARAM_CONFIG:
|
||||||
|
ret = wlan_ret_gpio_tsf_latch(pmpriv, resp, pioctl_buf);
|
||||||
|
break;
|
||||||
case HostCmd_CMD_RX_ABORT_CFG:
|
case HostCmd_CMD_RX_ABORT_CFG:
|
||||||
ret = wlan_ret_rxabortcfg(pmpriv, resp, pioctl_buf);
|
ret = wlan_ret_rxabortcfg(pmpriv, resp, pioctl_buf);
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -1004,7 +1004,6 @@ mlan_status wlan_ops_sta_process_event(t_void *priv)
|
||||||
PRINTM(MEVENT, "EVENT: EXT_SCAN status report (%d)\n",
|
PRINTM(MEVENT, "EVENT: EXT_SCAN status report (%d)\n",
|
||||||
pmbuf->data_len);
|
pmbuf->data_len);
|
||||||
pmadapter->ext_scan_timeout = MFALSE;
|
pmadapter->ext_scan_timeout = MFALSE;
|
||||||
pmadapter->cmd_lock = MFALSE;
|
|
||||||
ret = wlan_handle_event_ext_scan_status(priv, pmbuf);
|
ret = wlan_handle_event_ext_scan_status(priv, pmbuf);
|
||||||
break;
|
break;
|
||||||
case EVENT_MEAS_REPORT_RDY:
|
case EVENT_MEAS_REPORT_RDY:
|
||||||
|
|
|
@ -356,12 +356,8 @@ static mlan_status wlan_get_info_bss_info(pmlan_adapter pmadapter,
|
||||||
info->param.bss_info.listen_interval = pmpriv->listen_interval;
|
info->param.bss_info.listen_interval = pmpriv->listen_interval;
|
||||||
|
|
||||||
/* Association ID */
|
/* Association ID */
|
||||||
if (pmpriv->assoc_rsp_buf)
|
|
||||||
info->param.bss_info.assoc_id =
|
info->param.bss_info.assoc_id =
|
||||||
(t_u16)((IEEEtypes_AssocRsp_t *)pmpriv->assoc_rsp_buf)
|
(t_u16)((IEEEtypes_AssocRsp_t *)pmpriv->assoc_rsp_buf)->a_id;
|
||||||
->a_id;
|
|
||||||
else
|
|
||||||
info->param.bss_info.assoc_id = 0;
|
|
||||||
|
|
||||||
/* AP/Peer supported rates */
|
/* AP/Peer supported rates */
|
||||||
memset(pmadapter, info->param.bss_info.peer_supp_rates, 0,
|
memset(pmadapter, info->param.bss_info.peer_supp_rates, 0,
|
||||||
|
@ -462,6 +458,8 @@ static mlan_status wlan_get_info_ioctl(pmlan_adapter pmadapter,
|
||||||
pget_info->param.fw_info.antinfo = pmadapter->antinfo;
|
pget_info->param.fw_info.antinfo = pmadapter->antinfo;
|
||||||
pget_info->param.fw_info.max_ap_assoc_sta =
|
pget_info->param.fw_info.max_ap_assoc_sta =
|
||||||
pmadapter->max_sta_conn;
|
pmadapter->max_sta_conn;
|
||||||
|
pget_info->param.fw_info.fw_beacon_prot =
|
||||||
|
IS_FW_SUPPORT_BEACON_PROT(pmadapter) ? 0x01 : 0x00;
|
||||||
break;
|
break;
|
||||||
case MLAN_OID_GET_BSS_INFO:
|
case MLAN_OID_GET_BSS_INFO:
|
||||||
status = wlan_get_info_bss_info(pmadapter, pioctl_req);
|
status = wlan_get_info_bss_info(pmadapter, pioctl_req);
|
||||||
|
@ -2882,9 +2880,9 @@ static mlan_status wlan_sec_ioctl_set_wep_key(pmlan_adapter pmadapter,
|
||||||
/* Copy the required key as the current key */
|
/* Copy the required key as the current key */
|
||||||
pwep_key = &pmpriv->wep_key[index];
|
pwep_key = &pmpriv->wep_key[index];
|
||||||
if (!pwep_key->key_length) {
|
if (!pwep_key->key_length) {
|
||||||
if (&pmpriv->sec_info.wpa_enabled ||
|
if (pmpriv->sec_info.wpa_enabled ||
|
||||||
&pmpriv->sec_info.wpa2_enabled ||
|
pmpriv->sec_info.wpa2_enabled ||
|
||||||
&pmpriv->sec_info.wapi_enabled) {
|
pmpriv->sec_info.wapi_enabled) {
|
||||||
ret = MLAN_STATUS_SUCCESS;
|
ret = MLAN_STATUS_SUCCESS;
|
||||||
goto exit;
|
goto exit;
|
||||||
}
|
}
|
||||||
|
@ -3944,6 +3942,28 @@ static mlan_status wlan_misc_ioctl_gen_ie(pmlan_adapter pmadapter,
|
||||||
(t_u16)misc->param.gen_ie.len);
|
(t_u16)misc->param.gen_ie.len);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
case MLAN_IE_TYPE_ARP_FILTER:
|
||||||
|
memset(pmadapter, pmadapter->arp_filter, 0,
|
||||||
|
sizeof(pmadapter->arp_filter));
|
||||||
|
if (misc->param.gen_ie.len > ARP_FILTER_MAX_BUF_SIZE) {
|
||||||
|
pmadapter->arp_filter_size = 0;
|
||||||
|
PRINTM(MERROR, "Invalid ARP Filter Size\n");
|
||||||
|
pioctl_req->status_code = MLAN_ERROR_INVALID_PARAMETER;
|
||||||
|
ret = MLAN_STATUS_FAILURE;
|
||||||
|
} else if (misc->param.gen_ie.len <=
|
||||||
|
sizeof(MrvlIEtypesHeader_t)) {
|
||||||
|
pmadapter->arp_filter_size = 0;
|
||||||
|
PRINTM(MINFO, "Clear ARP filter\n");
|
||||||
|
} else {
|
||||||
|
memcpy_ext(pmadapter, pmadapter->arp_filter,
|
||||||
|
misc->param.gen_ie.ie_data,
|
||||||
|
misc->param.gen_ie.len,
|
||||||
|
ARP_FILTER_MAX_BUF_SIZE);
|
||||||
|
pmadapter->arp_filter_size = misc->param.gen_ie.len;
|
||||||
|
HEXDUMP("ArpFilter", pmadapter->arp_filter,
|
||||||
|
pmadapter->arp_filter_size);
|
||||||
|
}
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
PRINTM(MERROR, "Invalid IE type\n");
|
PRINTM(MERROR, "Invalid IE type\n");
|
||||||
pioctl_req->status_code = MLAN_ERROR_INVALID_PARAMETER;
|
pioctl_req->status_code = MLAN_ERROR_INVALID_PARAMETER;
|
||||||
|
@ -4321,6 +4341,84 @@ static mlan_status wlan_misc_ioctl_subscribe_evt(pmlan_adapter pmadapter,
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Set ARP filter based on IP address
|
||||||
|
*
|
||||||
|
* @param pmadapter A pointer to mlan_adapter structure
|
||||||
|
* @param pioctl_req A pointer to ioctl request buffer
|
||||||
|
* @param ipv4_addr ipv4 Address
|
||||||
|
*
|
||||||
|
* @return MLAN_STATUS_PENDING --success, otherwise fail
|
||||||
|
*/
|
||||||
|
static mlan_status wlan_ipaddr_arp_filter(pmlan_adapter pmadapter,
|
||||||
|
pmlan_ioctl_req pioctl_req,
|
||||||
|
t_u32 ipv4_addr)
|
||||||
|
{
|
||||||
|
mlan_status ret = MLAN_STATUS_SUCCESS;
|
||||||
|
pmlan_callbacks pcb = &pmadapter->callbacks;
|
||||||
|
t_u8 *buf;
|
||||||
|
arpfilter_header *arpfilter = MNULL;
|
||||||
|
filter_entry *entry = MNULL;
|
||||||
|
t_u32 len;
|
||||||
|
|
||||||
|
ENTER();
|
||||||
|
|
||||||
|
pcb->moal_malloc(pmadapter->pmoal_handle, MRVDRV_SIZE_OF_CMD_BUFFER,
|
||||||
|
MLAN_MEM_DEF, &buf);
|
||||||
|
if (!buf) {
|
||||||
|
ret = MLAN_STATUS_FAILURE;
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Construct the ARP filter TLV */
|
||||||
|
arpfilter = (arpfilter_header *)buf;
|
||||||
|
arpfilter->type = wlan_cpu_to_le16(TLV_TYPE_ARP_FILTER);
|
||||||
|
|
||||||
|
if (ipv4_addr) {
|
||||||
|
arpfilter->len = wlan_cpu_to_le16(sizeof(filter_entry) * 3);
|
||||||
|
entry = (filter_entry *)(buf + sizeof(arpfilter_header));
|
||||||
|
entry->addr_type = wlan_cpu_to_le16(ADDR_TYPE_BROADCAST);
|
||||||
|
entry->eth_type = wlan_cpu_to_le16(ETHER_TYPE_ARP);
|
||||||
|
entry->ipv4_addr = wlan_cpu_to_le32(ipv4_addr);
|
||||||
|
entry++;
|
||||||
|
entry->addr_type = wlan_cpu_to_le16(ADDR_TYPE_UNICAST);
|
||||||
|
entry->eth_type = wlan_cpu_to_le16(ETHER_TYPE_ANY);
|
||||||
|
entry->ipv4_addr = wlan_cpu_to_le32(IPV4_ADDR_ANY);
|
||||||
|
entry++;
|
||||||
|
entry->addr_type = wlan_cpu_to_le16(ADDR_TYPE_MULTICAST);
|
||||||
|
entry->eth_type = wlan_cpu_to_le16(ETHER_TYPE_ANY);
|
||||||
|
entry->ipv4_addr = wlan_cpu_to_le32(IPV4_ADDR_ANY);
|
||||||
|
} else
|
||||||
|
arpfilter->len = 0;
|
||||||
|
|
||||||
|
/* Update the total length */
|
||||||
|
len = sizeof(arpfilter_header) + wlan_le16_to_cpu(arpfilter->len);
|
||||||
|
|
||||||
|
memset(pmadapter, pmadapter->arp_filter, 0,
|
||||||
|
sizeof(pmadapter->arp_filter));
|
||||||
|
if (len > ARP_FILTER_MAX_BUF_SIZE) {
|
||||||
|
pmadapter->arp_filter_size = 0;
|
||||||
|
PRINTM(MERROR, "Invalid ARP Filter Size\n");
|
||||||
|
pioctl_req->status_code = MLAN_ERROR_INVALID_PARAMETER;
|
||||||
|
ret = MLAN_STATUS_FAILURE;
|
||||||
|
} else if (len <= sizeof(MrvlIEtypesHeader_t)) {
|
||||||
|
pmadapter->arp_filter_size = 0;
|
||||||
|
PRINTM(MINFO, "Clear ARP filter\n");
|
||||||
|
} else {
|
||||||
|
memcpy_ext(pmadapter, pmadapter->arp_filter, buf, len,
|
||||||
|
ARP_FILTER_MAX_BUF_SIZE);
|
||||||
|
pmadapter->arp_filter_size = len;
|
||||||
|
HEXDUMP("ArpFilter", pmadapter->arp_filter,
|
||||||
|
pmadapter->arp_filter_size);
|
||||||
|
}
|
||||||
|
|
||||||
|
done:
|
||||||
|
if (buf)
|
||||||
|
pcb->moal_mfree(pmadapter->pmoal_handle, buf);
|
||||||
|
LEAVE();
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief MEF configuration
|
* @brief MEF configuration
|
||||||
*
|
*
|
||||||
|
@ -4470,6 +4568,13 @@ static mlan_status wlan_misc_ioctl_ipaddr_cfg(pmlan_adapter pmadapter,
|
||||||
ret = MLAN_STATUS_FAILURE;
|
ret = MLAN_STATUS_FAILURE;
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
|
if (misc->param.ipaddr_cfg.op_code & MLAN_IPADDR_OP_ARP_FILTER)
|
||||||
|
ret = wlan_ipaddr_arp_filter(pmadapter, pioctl_req,
|
||||||
|
ipv4_addr[0]);
|
||||||
|
else if (pmpriv->op_code & MLAN_IPADDR_OP_ARP_FILTER)
|
||||||
|
ret = wlan_ipaddr_arp_filter(pmadapter, pioctl_req, 0);
|
||||||
|
if (ret == MLAN_STATUS_FAILURE)
|
||||||
|
goto done;
|
||||||
|
|
||||||
/* Save the values in MLAN */
|
/* Save the values in MLAN */
|
||||||
if (pioctl_req->action == MLAN_ACT_SET) {
|
if (pioctl_req->action == MLAN_ACT_SET) {
|
||||||
|
@ -4755,6 +4860,40 @@ static mlan_status wlan_misc_ioctl_get_sensor_temp(pmlan_adapter pmadapter,
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief IPv6 Router Advertisement offload configuration
|
||||||
|
*
|
||||||
|
* @param pmadapter A pointer to mlan_adapter structure
|
||||||
|
* @param pioctl_req Pointer to the IOCTL request buffer
|
||||||
|
*
|
||||||
|
* @return MLAN_STATUS_SUCCESS or MLAN_STATUS_FAILURE
|
||||||
|
*/
|
||||||
|
mlan_status wlan_misc_ioctl_ipv6_ra_offload(pmlan_adapter pmadapter,
|
||||||
|
mlan_ioctl_req *pioctl_req)
|
||||||
|
{
|
||||||
|
pmlan_private pmpriv = pmadapter->priv[pioctl_req->bss_index];
|
||||||
|
mlan_ds_misc_cfg *misc = MNULL;
|
||||||
|
t_u16 cmd_action = 0;
|
||||||
|
mlan_status ret = MLAN_STATUS_SUCCESS;
|
||||||
|
|
||||||
|
ENTER();
|
||||||
|
|
||||||
|
misc = (mlan_ds_misc_cfg *)pioctl_req->pbuf;
|
||||||
|
if (pioctl_req->action == MLAN_ACT_SET)
|
||||||
|
cmd_action = HostCmd_ACT_GEN_SET;
|
||||||
|
else if (pioctl_req->action == MLAN_ACT_GET)
|
||||||
|
cmd_action = HostCmd_ACT_GEN_GET;
|
||||||
|
|
||||||
|
ret = wlan_prepare_cmd(pmpriv, HostCmd_CMD_IPV6_RA_OFFLOAD_CFG,
|
||||||
|
cmd_action, 0, (t_void *)pioctl_req,
|
||||||
|
&misc->param.ipv6_ra_offload);
|
||||||
|
if (ret == MLAN_STATUS_SUCCESS)
|
||||||
|
ret = MLAN_STATUS_PENDING;
|
||||||
|
|
||||||
|
LEAVE();
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Gtk Rekey Offload
|
* @brief Gtk Rekey Offload
|
||||||
*
|
*
|
||||||
|
@ -4882,6 +5021,7 @@ static mlan_status wlan_misc_cfg_ioctl(pmlan_adapter pmadapter,
|
||||||
status = wlan_misc_ioctl_region(pmadapter, pioctl_req);
|
status = wlan_misc_ioctl_region(pmadapter, pioctl_req);
|
||||||
break;
|
break;
|
||||||
case MLAN_OID_MISC_WARM_RESET:
|
case MLAN_OID_MISC_WARM_RESET:
|
||||||
|
PRINTM(MCMND, "Request WARM RESET\n");
|
||||||
util_enqueue_list_tail(pmadapter->pmoal_handle,
|
util_enqueue_list_tail(pmadapter->pmoal_handle,
|
||||||
&pmadapter->ioctl_pending_q,
|
&pmadapter->ioctl_pending_q,
|
||||||
(pmlan_linked_list)pioctl_req,
|
(pmlan_linked_list)pioctl_req,
|
||||||
|
@ -5022,6 +5162,9 @@ static mlan_status wlan_misc_cfg_ioctl(pmlan_adapter pmadapter,
|
||||||
status = wlan_misc_ioctl_operclass_validation(pmadapter,
|
status = wlan_misc_ioctl_operclass_validation(pmadapter,
|
||||||
pioctl_req);
|
pioctl_req);
|
||||||
break;
|
break;
|
||||||
|
case MLAN_OID_MISC_IPV6_RA_OFFLOAD:
|
||||||
|
status = wlan_misc_ioctl_ipv6_ra_offload(pmadapter, pioctl_req);
|
||||||
|
break;
|
||||||
case MLAN_OID_MISC_GTK_REKEY_OFFLOAD:
|
case MLAN_OID_MISC_GTK_REKEY_OFFLOAD:
|
||||||
status = wlan_misc_ioctl_gtk_rekey_offload(pmadapter,
|
status = wlan_misc_ioctl_gtk_rekey_offload(pmadapter,
|
||||||
pioctl_req);
|
pioctl_req);
|
||||||
|
@ -5073,6 +5216,12 @@ static mlan_status wlan_misc_cfg_ioctl(pmlan_adapter pmadapter,
|
||||||
case MLAN_OID_MISC_HAL_PHY_CFG:
|
case MLAN_OID_MISC_HAL_PHY_CFG:
|
||||||
status = wlan_misc_hal_phy_cfg(pmadapter, pioctl_req);
|
status = wlan_misc_hal_phy_cfg(pmadapter, pioctl_req);
|
||||||
break;
|
break;
|
||||||
|
case MLAN_OID_MISC_GPIO_TSF_LATCH:
|
||||||
|
status = wlan_misc_gpio_tsf_latch_config(pmadapter, pioctl_req);
|
||||||
|
break;
|
||||||
|
case MLAN_OID_MISC_GET_TSF_INFO:
|
||||||
|
status = wlan_misc_get_tsf_info(pmadapter, pioctl_req);
|
||||||
|
break;
|
||||||
case MLAN_OID_MISC_RX_ABORT_CFG:
|
case MLAN_OID_MISC_RX_ABORT_CFG:
|
||||||
status = wlan_misc_ioctl_rxabortcfg(pmadapter, pioctl_req);
|
status = wlan_misc_ioctl_rxabortcfg(pmadapter, pioctl_req);
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -1462,7 +1462,6 @@ static mlan_status wlan_uap_cmd_ap_config(pmlan_private pmpriv,
|
||||||
cmd_size += sizeof(MrvlIEtypes_preamble_t);
|
cmd_size += sizeof(MrvlIEtypes_preamble_t);
|
||||||
tlv += sizeof(MrvlIEtypes_preamble_t);
|
tlv += sizeof(MrvlIEtypes_preamble_t);
|
||||||
}
|
}
|
||||||
|
|
||||||
cmd->size = (t_u16)wlan_cpu_to_le16(cmd_size);
|
cmd->size = (t_u16)wlan_cpu_to_le16(cmd_size);
|
||||||
PRINTM(MCMND, "AP config: cmd_size=%d\n", cmd_size);
|
PRINTM(MCMND, "AP config: cmd_size=%d\n", cmd_size);
|
||||||
LEAVE();
|
LEAVE();
|
||||||
|
@ -1512,6 +1511,7 @@ static mlan_status wlan_uap_cmd_sys_configure(pmlan_private pmpriv,
|
||||||
t_u16 req_len = 0, travel_len = 0;
|
t_u16 req_len = 0, travel_len = 0;
|
||||||
custom_ie *cptr = MNULL;
|
custom_ie *cptr = MNULL;
|
||||||
mlan_status ret = MLAN_STATUS_SUCCESS;
|
mlan_status ret = MLAN_STATUS_SUCCESS;
|
||||||
|
MrvlIEtypes_wacp_mode_t *tlv_wacp_mode = MNULL;
|
||||||
|
|
||||||
ENTER();
|
ENTER();
|
||||||
|
|
||||||
|
@ -1900,6 +1900,21 @@ static mlan_status wlan_uap_cmd_sys_configure(pmlan_private pmpriv,
|
||||||
misc->param.cust_ie.len);
|
misc->param.cust_ie.len);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (misc->sub_command == MLAN_OID_MISC_WACP_MODE) {
|
||||||
|
tlv_wacp_mode = (MrvlIEtypes_wacp_mode_t *)
|
||||||
|
sys_config->tlv_buffer;
|
||||||
|
tlv_wacp_mode->header.type =
|
||||||
|
wlan_cpu_to_le16(TLV_TYPE_UAP_WACP_MODE);
|
||||||
|
tlv_wacp_mode->header.len =
|
||||||
|
wlan_cpu_to_le16(sizeof(t_u8));
|
||||||
|
if (cmd_action == HostCmd_ACT_GEN_SET) {
|
||||||
|
tlv_wacp_mode->wacp_mode =
|
||||||
|
misc->param.wacp_mode;
|
||||||
|
}
|
||||||
|
cmd->size = wlan_cpu_to_le16(
|
||||||
|
sizeof(HostCmd_DS_SYS_CONFIG) - 1 + S_DS_GEN +
|
||||||
|
sizeof(MrvlIEtypes_wacp_mode_t));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
done:
|
done:
|
||||||
LEAVE();
|
LEAVE();
|
||||||
|
@ -3186,6 +3201,15 @@ static mlan_status wlan_uap_ret_get_log(pmlan_private pmpriv,
|
||||||
wlan_le32_to_cpu(pget_log->dwMgtErrCnt);
|
wlan_le32_to_cpu(pget_log->dwMgtErrCnt);
|
||||||
pget_info->param.stats.dwDatErrCnt =
|
pget_info->param.stats.dwDatErrCnt =
|
||||||
wlan_le32_to_cpu(pget_log->dwDatErrCnt);
|
wlan_le32_to_cpu(pget_log->dwDatErrCnt);
|
||||||
|
pget_info->param.stats.bigtk_mmeGoodCnt =
|
||||||
|
wlan_le32_to_cpu(pget_log->bigtk_mmeGoodCnt);
|
||||||
|
pget_info->param.stats.bigtk_replayErrCnt =
|
||||||
|
wlan_le32_to_cpu(pget_log->bigtk_replayErrCnt);
|
||||||
|
pget_info->param.stats.bigtk_micErrCnt =
|
||||||
|
wlan_le32_to_cpu(pget_log->bigtk_micErrCnt);
|
||||||
|
pget_info->param.stats.bigtk_mmeNotFoundCnt =
|
||||||
|
wlan_le32_to_cpu(pget_log->bigtk_mmeNotFoundCnt);
|
||||||
|
|
||||||
if (pmpriv->adapter->getlog_enable) {
|
if (pmpriv->adapter->getlog_enable) {
|
||||||
pget_info->param.stats.tx_frag_cnt =
|
pget_info->param.stats.tx_frag_cnt =
|
||||||
wlan_le32_to_cpu(pget_log->tx_frag_cnt);
|
wlan_le32_to_cpu(pget_log->tx_frag_cnt);
|
||||||
|
@ -3426,7 +3450,7 @@ static mlan_status wlan_uap_cmd_key_material(pmlan_private pmpriv,
|
||||||
else
|
else
|
||||||
pkey_material->key_param_set.key_info |= KEY_INFO_UCAST_KEY;
|
pkey_material->key_param_set.key_info |= KEY_INFO_UCAST_KEY;
|
||||||
if (pkey->key_flags & KEY_FLAG_AES_MCAST_IGTK)
|
if (pkey->key_flags & KEY_FLAG_AES_MCAST_IGTK)
|
||||||
pkey_material->key_param_set.key_info = KEY_INFO_CMAC_AES_KEY;
|
pkey_material->key_param_set.key_info |= KEY_INFO_CMAC_AES_KEY;
|
||||||
if (pkey->key_flags & KEY_FLAG_SET_TX_KEY)
|
if (pkey->key_flags & KEY_FLAG_SET_TX_KEY)
|
||||||
pkey_material->key_param_set.key_info |=
|
pkey_material->key_param_set.key_info |=
|
||||||
KEY_INFO_TX_KEY | KEY_INFO_RX_KEY;
|
KEY_INFO_TX_KEY | KEY_INFO_RX_KEY;
|
||||||
|
@ -3505,7 +3529,12 @@ static mlan_status wlan_uap_cmd_key_material(pmlan_private pmpriv,
|
||||||
~(wlan_cpu_to_le16(KEY_INFO_MCAST_KEY));
|
~(wlan_cpu_to_le16(KEY_INFO_MCAST_KEY));
|
||||||
pkey_material->key_param_set.key_info |=
|
pkey_material->key_param_set.key_info |=
|
||||||
wlan_cpu_to_le16(KEY_INFO_AES_MCAST_IGTK);
|
wlan_cpu_to_le16(KEY_INFO_AES_MCAST_IGTK);
|
||||||
pkey_material->key_param_set.key_type = KEY_TYPE_ID_AES_CMAC;
|
if (pkey->key_flags & KEY_FLAG_GMAC_128)
|
||||||
|
pkey_material->key_param_set.key_type =
|
||||||
|
KEY_TYPE_ID_BIP_GMAC_128;
|
||||||
|
else
|
||||||
|
pkey_material->key_param_set.key_type =
|
||||||
|
KEY_TYPE_ID_AES_CMAC;
|
||||||
pkey_material->key_param_set.key_params.cmac_aes.key_len =
|
pkey_material->key_param_set.key_params.cmac_aes.key_len =
|
||||||
wlan_cpu_to_le16(pkey->key_len);
|
wlan_cpu_to_le16(pkey->key_len);
|
||||||
memcpy_ext(pmpriv->adapter,
|
memcpy_ext(pmpriv->adapter,
|
||||||
|
@ -3517,9 +3546,41 @@ static mlan_status wlan_uap_cmd_key_material(pmlan_private pmpriv,
|
||||||
S_DS_GEN + KEY_PARAMS_FIXED_LEN +
|
S_DS_GEN + KEY_PARAMS_FIXED_LEN +
|
||||||
sizeof(cmac_aes_param) +
|
sizeof(cmac_aes_param) +
|
||||||
sizeof(pkey_material->action));
|
sizeof(pkey_material->action));
|
||||||
|
if (pkey->key_flags & KEY_FLAG_GMAC_128)
|
||||||
|
PRINTM(MCMND, "Set AES 128 GMAC Key\n");
|
||||||
|
else
|
||||||
PRINTM(MCMND, "Set CMAC AES Key\n");
|
PRINTM(MCMND, "Set CMAC AES Key\n");
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
|
if (pkey->key_len == WPA_IGTK_256_KEY_LEN &&
|
||||||
|
(pkey->key_flags & KEY_FLAG_AES_MCAST_IGTK)) {
|
||||||
|
if (pkey->key_flags &
|
||||||
|
(KEY_FLAG_RX_SEQ_VALID | KEY_FLAG_TX_SEQ_VALID))
|
||||||
|
memcpy_ext(pmpriv->adapter,
|
||||||
|
pkey_material->key_param_set.key_params
|
||||||
|
.cmac_aes.ipn,
|
||||||
|
pkey->pn, SEQ_MAX_SIZE, IGTK_PN_SIZE);
|
||||||
|
pkey_material->key_param_set.key_info &=
|
||||||
|
~(wlan_cpu_to_le16(KEY_INFO_MCAST_KEY));
|
||||||
|
pkey_material->key_param_set.key_info |=
|
||||||
|
wlan_cpu_to_le16(KEY_INFO_AES_MCAST_IGTK);
|
||||||
|
pkey_material->key_param_set.key_type =
|
||||||
|
KEY_TYPE_ID_BIP_GMAC_256;
|
||||||
|
pkey_material->key_param_set.key_params.cmac_aes.key_len =
|
||||||
|
wlan_cpu_to_le16(pkey->key_len);
|
||||||
|
memcpy_ext(pmpriv->adapter,
|
||||||
|
pkey_material->key_param_set.key_params.cmac_aes.key,
|
||||||
|
pkey->key_material, pkey->key_len,
|
||||||
|
WPA_IGTK_256_KEY_LEN);
|
||||||
|
pkey_material->key_param_set.length = wlan_cpu_to_le16(
|
||||||
|
KEY_PARAMS_FIXED_LEN + sizeof(gmac_aes_256_param));
|
||||||
|
cmd->size = wlan_cpu_to_le16(sizeof(MrvlIEtypesHeader_t) +
|
||||||
|
S_DS_GEN + KEY_PARAMS_FIXED_LEN +
|
||||||
|
sizeof(gmac_aes_256_param) +
|
||||||
|
sizeof(pkey_material->action));
|
||||||
|
PRINTM(MCMND, "Set AES 256 GMAC Key\n");
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
if (pkey->key_len == WPA_TKIP_KEY_LEN) {
|
if (pkey->key_len == WPA_TKIP_KEY_LEN) {
|
||||||
if (pkey->key_flags &
|
if (pkey->key_flags &
|
||||||
(KEY_FLAG_RX_SEQ_VALID | KEY_FLAG_TX_SEQ_VALID))
|
(KEY_FLAG_RX_SEQ_VALID | KEY_FLAG_TX_SEQ_VALID))
|
||||||
|
@ -4515,6 +4576,10 @@ mlan_status wlan_ops_uap_prepare_cmd(t_void *priv, t_u16 cmd_no,
|
||||||
pdata_buf);
|
pdata_buf);
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
|
case HOST_CMD_GPIO_TSF_LATCH_PARAM_CONFIG:
|
||||||
|
ret = wlan_cmd_gpio_tsf_latch(pmpriv, cmd_ptr, cmd_action,
|
||||||
|
pioctl_buf, pdata_buf);
|
||||||
|
break;
|
||||||
case HostCmd_CMD_802_11_RF_ANTENNA:
|
case HostCmd_CMD_802_11_RF_ANTENNA:
|
||||||
ret = wlan_cmd_802_11_rf_antenna(pmpriv, cmd_ptr, cmd_action,
|
ret = wlan_cmd_802_11_rf_antenna(pmpriv, cmd_ptr, cmd_action,
|
||||||
pdata_buf);
|
pdata_buf);
|
||||||
|
@ -4921,6 +4986,9 @@ mlan_status wlan_ops_uap_process_cmdresp(t_void *priv, t_u16 cmdresp_no,
|
||||||
ret = wlan_ret_p2p_params_config(pmpriv, resp, pioctl_buf);
|
ret = wlan_ret_p2p_params_config(pmpriv, resp, pioctl_buf);
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
|
case HOST_CMD_GPIO_TSF_LATCH_PARAM_CONFIG:
|
||||||
|
ret = wlan_ret_gpio_tsf_latch(pmpriv, resp, pioctl_buf);
|
||||||
|
break;
|
||||||
case HostCmd_CMD_802_11_RF_ANTENNA:
|
case HostCmd_CMD_802_11_RF_ANTENNA:
|
||||||
ret = wlan_ret_802_11_rf_antenna(pmpriv, resp, pioctl_buf);
|
ret = wlan_ret_802_11_rf_antenna(pmpriv, resp, pioctl_buf);
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -2007,6 +2007,11 @@ mlan_status wlan_ops_uap_ioctl(t_void *adapter, pmlan_ioctl_req pioctl_req)
|
||||||
if (misc->sub_command == MLAN_OID_MISC_WIFI_DIRECT_CONFIG)
|
if (misc->sub_command == MLAN_OID_MISC_WIFI_DIRECT_CONFIG)
|
||||||
status = wlan_misc_p2p_config(pmadapter, pioctl_req);
|
status = wlan_misc_p2p_config(pmadapter, pioctl_req);
|
||||||
#endif
|
#endif
|
||||||
|
if (misc->sub_command == MLAN_OID_MISC_GPIO_TSF_LATCH)
|
||||||
|
status = wlan_misc_gpio_tsf_latch_config(pmadapter,
|
||||||
|
pioctl_req);
|
||||||
|
if (misc->sub_command == MLAN_OID_MISC_GET_TSF_INFO)
|
||||||
|
status = wlan_misc_get_tsf_info(pmadapter, pioctl_req);
|
||||||
|
|
||||||
if (misc->sub_command == MLAN_OID_MISC_DFS_REAPTER_MODE) {
|
if (misc->sub_command == MLAN_OID_MISC_DFS_REAPTER_MODE) {
|
||||||
mlan_ds_misc_cfg *misc_cfg = MNULL;
|
mlan_ds_misc_cfg *misc_cfg = MNULL;
|
||||||
|
@ -2088,6 +2093,9 @@ mlan_status wlan_ops_uap_ioctl(t_void *adapter, pmlan_ioctl_req pioctl_req)
|
||||||
if (misc->sub_command == MLAN_OID_MISC_RANGE_EXT)
|
if (misc->sub_command == MLAN_OID_MISC_RANGE_EXT)
|
||||||
status = wlan_misc_ioctl_range_ext(pmadapter,
|
status = wlan_misc_ioctl_range_ext(pmadapter,
|
||||||
pioctl_req);
|
pioctl_req);
|
||||||
|
if (misc->sub_command == MLAN_OID_MISC_WACP_MODE)
|
||||||
|
status = wlan_misc_ioctl_wacp_mode(pmadapter,
|
||||||
|
pioctl_req);
|
||||||
break;
|
break;
|
||||||
case MLAN_IOCTL_POWER_CFG:
|
case MLAN_IOCTL_POWER_CFG:
|
||||||
power = (mlan_ds_power_cfg *)pioctl_req->pbuf;
|
power = (mlan_ds_power_cfg *)pioctl_req->pbuf;
|
||||||
|
|
|
@ -244,6 +244,7 @@ t_void *wlan_ops_uap_process_txpd(t_void *priv, pmlan_buffer pmbuf)
|
||||||
plocal_tx_pd->tx_pkt_type = (t_u16)pkt_type;
|
plocal_tx_pd->tx_pkt_type = (t_u16)pkt_type;
|
||||||
plocal_tx_pd->tx_control = tx_control;
|
plocal_tx_pd->tx_control = tx_control;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (pmbuf->flags & MLAN_BUF_FLAG_TX_CTRL) {
|
if (pmbuf->flags & MLAN_BUF_FLAG_TX_CTRL) {
|
||||||
if (pmbuf->u.tx_info.data_rate) {
|
if (pmbuf->u.tx_info.data_rate) {
|
||||||
memcpy_ext(pmpriv->adapter, dst_mac,
|
memcpy_ext(pmpriv->adapter, dst_mac,
|
||||||
|
@ -423,7 +424,7 @@ mlan_status wlan_ops_uap_process_rx_packet(t_void *adapter, pmlan_buffer pmbuf)
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
pmbuf->priority = prx_pd->priority;
|
pmbuf->priority |= prx_pd->priority;
|
||||||
memcpy_ext(pmadapter, ta, prx_pkt->eth803_hdr.src_addr,
|
memcpy_ext(pmadapter, ta, prx_pkt->eth803_hdr.src_addr,
|
||||||
MLAN_MAC_ADDR_LENGTH, MLAN_MAC_ADDR_LENGTH);
|
MLAN_MAC_ADDR_LENGTH, MLAN_MAC_ADDR_LENGTH);
|
||||||
if ((rx_pkt_type != PKT_TYPE_BAR) && (prx_pd->priority < MAX_NUM_TID)) {
|
if ((rx_pkt_type != PKT_TYPE_BAR) && (prx_pd->priority < MAX_NUM_TID)) {
|
||||||
|
|
|
@ -24,7 +24,7 @@
|
||||||
#define _MLAN_DECL_H_
|
#define _MLAN_DECL_H_
|
||||||
|
|
||||||
/** MLAN release version */
|
/** MLAN release version */
|
||||||
#define MLAN_RELEASE_VERSION "266.p4"
|
#define MLAN_RELEASE_VERSION "283"
|
||||||
|
|
||||||
/** Re-define generic data types for MLAN/MOAL */
|
/** Re-define generic data types for MLAN/MOAL */
|
||||||
/** Signed char (1-byte) */
|
/** Signed char (1-byte) */
|
||||||
|
@ -2039,7 +2039,8 @@ typedef struct _mlan_callbacks {
|
||||||
t_u32 drop_point);
|
t_u32 drop_point);
|
||||||
void (*moal_tp_accounting_rx_param)(t_void *pmoal, unsigned int type,
|
void (*moal_tp_accounting_rx_param)(t_void *pmoal, unsigned int type,
|
||||||
unsigned int rsvd1);
|
unsigned int rsvd1);
|
||||||
|
void (*moal_amsdu_tp_accounting)(t_void *pmoal, t_s32 delay,
|
||||||
|
t_s32 copy_delay);
|
||||||
} mlan_callbacks, *pmlan_callbacks;
|
} mlan_callbacks, *pmlan_callbacks;
|
||||||
|
|
||||||
/** Parameter unchanged, use MLAN default setting */
|
/** Parameter unchanged, use MLAN default setting */
|
||||||
|
@ -2180,6 +2181,8 @@ typedef struct _mlan_device {
|
||||||
t_u32 drv_mode;
|
t_u32 drv_mode;
|
||||||
/** dfs w53 cfg */
|
/** dfs w53 cfg */
|
||||||
t_u8 dfs53cfg;
|
t_u8 dfs53cfg;
|
||||||
|
/** extend enhance scan */
|
||||||
|
t_u8 ext_scan;
|
||||||
} mlan_device, *pmlan_device;
|
} mlan_device, *pmlan_device;
|
||||||
|
|
||||||
/** MLAN API function prototype */
|
/** MLAN API function prototype */
|
||||||
|
@ -2253,4 +2256,9 @@ MLAN_API mlan_status mlan_ioctl(t_void *padapter, pmlan_ioctl_req pioctl_req);
|
||||||
/** mlan select wmm queue */
|
/** mlan select wmm queue */
|
||||||
MLAN_API t_u8 mlan_select_wmm_queue(t_void *padapter, t_u8 bss_num, t_u8 tid);
|
MLAN_API t_u8 mlan_select_wmm_queue(t_void *padapter, t_u8 bss_num, t_u8 tid);
|
||||||
|
|
||||||
|
/** mlan mask host interrupt */
|
||||||
|
MLAN_API mlan_status mlan_disable_host_int(t_void *padapter);
|
||||||
|
/** mlan unmask host interrupt */
|
||||||
|
MLAN_API mlan_status mlan_enable_host_int(t_void *padapter);
|
||||||
|
|
||||||
#endif /* !_MLAN_DECL_H_ */
|
#endif /* !_MLAN_DECL_H_ */
|
||||||
|
|
|
@ -1403,6 +1403,8 @@ typedef MLAN_PACK_START struct {
|
||||||
t_u8 local_max_tp_20mhz; /**< Local Maximum Transmit Power for 20 MHZ>*/
|
t_u8 local_max_tp_20mhz; /**< Local Maximum Transmit Power for 20 MHZ>*/
|
||||||
t_u8 local_max_tp_40mhz; /**< Local Maximum Transmit Power for 40 MHZ>*/
|
t_u8 local_max_tp_40mhz; /**< Local Maximum Transmit Power for 40 MHZ>*/
|
||||||
t_u8 local_max_tp_80mhz; /**< Local Maximum Transmit Power for 80 MHZ>*/
|
t_u8 local_max_tp_80mhz; /**< Local Maximum Transmit Power for 80 MHZ>*/
|
||||||
|
t_u8 local_max_tp_160mhz_80_80mhz; /**< Local Maximum Transmit Power for
|
||||||
|
160/80+80 MHZ>*/
|
||||||
} MLAN_PACK_END IEEEtypes_VhtTpcEnvelope_t;
|
} MLAN_PACK_END IEEEtypes_VhtTpcEnvelope_t;
|
||||||
|
|
||||||
/* IEEE Quiet Period Element (7.3.2.23) */
|
/* IEEE Quiet Period Element (7.3.2.23) */
|
||||||
|
|
|
@ -298,6 +298,7 @@ enum _mlan_ioctl_req_id {
|
||||||
MLAN_OID_MISC_COALESCE_CFG = 0x0020002E,
|
MLAN_OID_MISC_COALESCE_CFG = 0x0020002E,
|
||||||
MLAN_OID_MISC_TDLS_IDLE_TIME = 0x0020002F,
|
MLAN_OID_MISC_TDLS_IDLE_TIME = 0x0020002F,
|
||||||
MLAN_OID_MISC_GET_SENSOR_TEMP = 0x00200030,
|
MLAN_OID_MISC_GET_SENSOR_TEMP = 0x00200030,
|
||||||
|
MLAN_OID_MISC_IPV6_RA_OFFLOAD = 0x00200036,
|
||||||
MLAN_OID_MISC_GTK_REKEY_OFFLOAD = 0x00200037,
|
MLAN_OID_MISC_GTK_REKEY_OFFLOAD = 0x00200037,
|
||||||
MLAN_OID_MISC_OPER_CLASS = 0x00200038,
|
MLAN_OID_MISC_OPER_CLASS = 0x00200038,
|
||||||
MLAN_OID_MISC_PMIC_CFG = 0x00200039,
|
MLAN_OID_MISC_PMIC_CFG = 0x00200039,
|
||||||
|
@ -340,6 +341,11 @@ enum _mlan_ioctl_req_id {
|
||||||
MLAN_OID_MISC_TP_STATE = 0x0020007D,
|
MLAN_OID_MISC_TP_STATE = 0x0020007D,
|
||||||
MLAN_OID_MISC_HAL_PHY_CFG = 0x0020007E,
|
MLAN_OID_MISC_HAL_PHY_CFG = 0x0020007E,
|
||||||
MLAN_OID_MISC_RF_TEST_HE_POWER = 0X0020007F,
|
MLAN_OID_MISC_RF_TEST_HE_POWER = 0X0020007F,
|
||||||
|
#ifdef UAP_SUPPORT
|
||||||
|
MLAN_OID_MISC_WACP_MODE = 0x00200081,
|
||||||
|
#endif
|
||||||
|
MLAN_OID_MISC_GPIO_TSF_LATCH = 0x00200082,
|
||||||
|
MLAN_OID_MISC_GET_TSF_INFO = 0x00200083,
|
||||||
};
|
};
|
||||||
|
|
||||||
/** Sub command size */
|
/** Sub command size */
|
||||||
|
@ -1646,6 +1652,14 @@ typedef struct _mlan_ds_get_stats {
|
||||||
t_u32 dwMgtErrCnt;
|
t_u32 dwMgtErrCnt;
|
||||||
/*Control Ownership error count*/
|
/*Control Ownership error count*/
|
||||||
t_u32 dwDatErrCnt;
|
t_u32 dwDatErrCnt;
|
||||||
|
/*BIGTK MME good count*/
|
||||||
|
t_u32 bigtk_mmeGoodCnt;
|
||||||
|
/*BIGTK Replay error count*/
|
||||||
|
t_u32 bigtk_replayErrCnt;
|
||||||
|
/*BIGTK MIC error count*/
|
||||||
|
t_u32 bigtk_micErrCnt;
|
||||||
|
/*BIGTK MME not included count*/
|
||||||
|
t_u32 bigtk_mmeNotFoundCnt;
|
||||||
} mlan_ds_get_stats, *pmlan_ds_get_stats;
|
} mlan_ds_get_stats, *pmlan_ds_get_stats;
|
||||||
|
|
||||||
/** Type definition of mlan_ds_uap_stats for MLAN_OID_GET_STATS */
|
/** Type definition of mlan_ds_uap_stats for MLAN_OID_GET_STATS */
|
||||||
|
@ -1827,6 +1841,8 @@ typedef struct _mlan_fw_info {
|
||||||
t_u8 max_ap_assoc_sta;
|
t_u8 max_ap_assoc_sta;
|
||||||
/** Bandwidth not support 80Mhz */
|
/** Bandwidth not support 80Mhz */
|
||||||
t_u8 prohibit_80mhz;
|
t_u8 prohibit_80mhz;
|
||||||
|
/** FW support beacon protection */
|
||||||
|
t_u8 fw_beacon_prot;
|
||||||
} mlan_fw_info, *pmlan_fw_info;
|
} mlan_fw_info, *pmlan_fw_info;
|
||||||
|
|
||||||
/** Version string buffer length */
|
/** Version string buffer length */
|
||||||
|
@ -1844,6 +1860,14 @@ typedef struct _mlan_ver_ext {
|
||||||
/** Extended Capabilities Data */
|
/** Extended Capabilities Data */
|
||||||
typedef struct MLAN_PACK_START _ExtCap_t {
|
typedef struct MLAN_PACK_START _ExtCap_t {
|
||||||
/** Extended Capabilities value */
|
/** Extended Capabilities value */
|
||||||
|
t_u8 rsvdBit87 : 1; /* bit 87 */
|
||||||
|
t_u8 rsvdBit86 : 1; /* bit 86 */
|
||||||
|
t_u8 rsvdBit85 : 1; /* bit 85 */
|
||||||
|
t_u8 beacon_prot : 1; /* bit 84 */
|
||||||
|
t_u8 rsvdBit83 : 1; /* bit 83 */
|
||||||
|
t_u8 rsvdBit82 : 1; /* bit 82 */
|
||||||
|
t_u8 rsvdBit81 : 1; /* bit 81 */
|
||||||
|
t_u8 rsvdBit80 : 1; /* bit 80 */
|
||||||
t_u8 rsvdBit79 : 1; /* bit 79 */
|
t_u8 rsvdBit79 : 1; /* bit 79 */
|
||||||
t_u8 TWTResp : 1; /* bit 78 */
|
t_u8 TWTResp : 1; /* bit 78 */
|
||||||
t_u8 TWTReq : 1; /* bit 77 */
|
t_u8 TWTReq : 1; /* bit 77 */
|
||||||
|
@ -2009,6 +2033,14 @@ typedef struct MLAN_PACK_START _ExtCap_t {
|
||||||
t_u8 TWTReq : 1; /* bit 77 */
|
t_u8 TWTReq : 1; /* bit 77 */
|
||||||
t_u8 TWTResp : 1; /* bit 78 */
|
t_u8 TWTResp : 1; /* bit 78 */
|
||||||
t_u8 rsvdBit79 : 1; /* bit 79 */
|
t_u8 rsvdBit79 : 1; /* bit 79 */
|
||||||
|
t_u8 rsvdBit80 : 1; /* bit 80 */
|
||||||
|
t_u8 rsvdBit81 : 1; /* bit 81 */
|
||||||
|
t_u8 rsvdBit82 : 1; /* bit 82 */
|
||||||
|
t_u8 rsvdBit83 : 1; /* bit 83 */
|
||||||
|
t_u8 beacon_prot : 1; /* bit 84 */
|
||||||
|
t_u8 rsvdBit85 : 1; /* bit 85 */
|
||||||
|
t_u8 rsvdBit86 : 1; /* bit 86 */
|
||||||
|
t_u8 rsvdBit87 : 1; /* bit 87 */
|
||||||
} MLAN_PACK_END ExtCap_t, *pExtCap_t;
|
} MLAN_PACK_END ExtCap_t, *pExtCap_t;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -2215,7 +2247,7 @@ typedef struct _mlan_debug_info {
|
||||||
/** Corresponds to port_open member of mlan_private */
|
/** Corresponds to port_open member of mlan_private */
|
||||||
t_u8 port_open;
|
t_u8 port_open;
|
||||||
/** bypass pkt count */
|
/** bypass pkt count */
|
||||||
t_u16 bypass_pkt_count;
|
t_u32 bypass_pkt_count;
|
||||||
/** Corresponds to scan_processing member of mlan_adapter */
|
/** Corresponds to scan_processing member of mlan_adapter */
|
||||||
t_u32 scan_processing;
|
t_u32 scan_processing;
|
||||||
/** Corresponds to mlan_processing member of mlan_adapter */
|
/** Corresponds to mlan_processing member of mlan_adapter */
|
||||||
|
@ -2265,6 +2297,10 @@ typedef struct _mlan_debug_info {
|
||||||
t_u32 mpa_sent_no_ports;
|
t_u32 mpa_sent_no_ports;
|
||||||
/** last recv wr_bitmap */
|
/** last recv wr_bitmap */
|
||||||
t_u32 last_recv_wr_bitmap;
|
t_u32 last_recv_wr_bitmap;
|
||||||
|
/** last recv rd_bitmap */
|
||||||
|
t_u32 last_recv_rd_bitmap;
|
||||||
|
/** mp_data_port_mask */
|
||||||
|
t_u32 mp_data_port_mask;
|
||||||
/** last mp_wr_bitmap */
|
/** last mp_wr_bitmap */
|
||||||
t_u32 last_mp_wr_bitmap[SDIO_MP_DBG_NUM];
|
t_u32 last_mp_wr_bitmap[SDIO_MP_DBG_NUM];
|
||||||
/** last ports for cmd53 write data */
|
/** last ports for cmd53 write data */
|
||||||
|
@ -2480,7 +2516,7 @@ typedef enum {
|
||||||
AssocAgentAuth_FastBss,
|
AssocAgentAuth_FastBss,
|
||||||
AssocAgentAuth_FastBss_Skip,
|
AssocAgentAuth_FastBss_Skip,
|
||||||
AssocAgentAuth_Network_EAP,
|
AssocAgentAuth_Network_EAP,
|
||||||
AssocAgentAuth_Wpa3Sae,
|
AssocAgentAuth_Wpa3Sae = 6,
|
||||||
AssocAgentAuth_Auto,
|
AssocAgentAuth_Auto,
|
||||||
} AssocAgentAuthType_e;
|
} AssocAgentAuthType_e;
|
||||||
|
|
||||||
|
@ -2549,6 +2585,10 @@ enum _mlan_psk_type {
|
||||||
#define KEY_FLAG_GCMP_256 0x00000040
|
#define KEY_FLAG_GCMP_256 0x00000040
|
||||||
/** key flag for ccmp 256 */
|
/** key flag for ccmp 256 */
|
||||||
#define KEY_FLAG_CCMP_256 0x00000080
|
#define KEY_FLAG_CCMP_256 0x00000080
|
||||||
|
/** key flag for GMAC_128 */
|
||||||
|
#define KEY_FLAG_GMAC_128 0x00000100
|
||||||
|
/** key flag for GMAC_256 */
|
||||||
|
#define KEY_FLAG_GMAC_256 0x00000200
|
||||||
|
|
||||||
/** Type definition of mlan_ds_encrypt_key for MLAN_OID_SEC_CFG_ENCRYPT_KEY */
|
/** Type definition of mlan_ds_encrypt_key for MLAN_OID_SEC_CFG_ENCRYPT_KEY */
|
||||||
typedef struct _mlan_ds_encrypt_key {
|
typedef struct _mlan_ds_encrypt_key {
|
||||||
|
@ -4219,6 +4259,9 @@ typedef struct _mlan_ds_11h_cfg {
|
||||||
/** Enumeration for IE type */
|
/** Enumeration for IE type */
|
||||||
enum _mlan_ie_type {
|
enum _mlan_ie_type {
|
||||||
MLAN_IE_TYPE_GEN_IE = 0,
|
MLAN_IE_TYPE_GEN_IE = 0,
|
||||||
|
#ifdef STA_SUPPORT
|
||||||
|
MLAN_IE_TYPE_ARP_FILTER,
|
||||||
|
#endif /* STA_SUPPORT */
|
||||||
};
|
};
|
||||||
|
|
||||||
/** Type definition of mlan_ds_misc_gen_ie for MLAN_OID_MISC_GEN_IE */
|
/** Type definition of mlan_ds_misc_gen_ie for MLAN_OID_MISC_GEN_IE */
|
||||||
|
@ -4376,6 +4419,8 @@ typedef struct _mlan_ds_misc_cck_desense_cfg {
|
||||||
#define IPADDR_TYPE_IPV4 (1)
|
#define IPADDR_TYPE_IPV4 (1)
|
||||||
/** IP operation remove */
|
/** IP operation remove */
|
||||||
#define MLAN_IPADDR_OP_IP_REMOVE (0)
|
#define MLAN_IPADDR_OP_IP_REMOVE (0)
|
||||||
|
/** IP operation ARP filter */
|
||||||
|
#define MLAN_IPADDR_OP_ARP_FILTER MBIT(0)
|
||||||
/** IP operation ARP response */
|
/** IP operation ARP response */
|
||||||
#define MLAN_IPADDR_OP_AUTO_ARP_RESP MBIT(1)
|
#define MLAN_IPADDR_OP_AUTO_ARP_RESP MBIT(1)
|
||||||
|
|
||||||
|
@ -4391,6 +4436,14 @@ typedef struct _mlan_ds_misc_ipaddr_cfg {
|
||||||
t_u8 ip_addr[MAX_IPADDR][IPADDR_LEN];
|
t_u8 ip_addr[MAX_IPADDR][IPADDR_LEN];
|
||||||
} mlan_ds_misc_ipaddr_cfg;
|
} mlan_ds_misc_ipaddr_cfg;
|
||||||
|
|
||||||
|
/** Type definnition of mlan_ds_misc_ipv6_ra_offload for
|
||||||
|
* MLAN_OID_MISC_IPV6_RA_OFFLOAD*/
|
||||||
|
typedef struct _mlan_ds_misc_ipv6_ra_offload {
|
||||||
|
/** 0: disable; 1: enable*/
|
||||||
|
t_u8 enable;
|
||||||
|
t_u8 ipv6_addr[16];
|
||||||
|
} mlan_ds_misc_ipv6_ra_offload;
|
||||||
|
|
||||||
/* MEF configuration disable */
|
/* MEF configuration disable */
|
||||||
#define MEF_CFG_DISABLE 0
|
#define MEF_CFG_DISABLE 0
|
||||||
/* MEF configuration Rx filter enable */
|
/* MEF configuration Rx filter enable */
|
||||||
|
@ -4647,6 +4700,33 @@ typedef struct _mlan_ds_wifi_direct_config {
|
||||||
} mlan_ds_wifi_direct_config;
|
} mlan_ds_wifi_direct_config;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/** Type definition of mlan_ds_gpio_tsf_latch */
|
||||||
|
typedef struct _mlan_ds_gpio_tsf_latch {
|
||||||
|
/**clock sync Mode */
|
||||||
|
t_u8 clock_sync_mode;
|
||||||
|
/**clock sync Role */
|
||||||
|
t_u8 clock_sync_Role;
|
||||||
|
/**clock sync GPIO Pin Number */
|
||||||
|
t_u8 clock_sync_gpio_pin_number;
|
||||||
|
/**clock sync GPIO Level or Toggle */
|
||||||
|
t_u8 clock_sync_gpio_level_toggle;
|
||||||
|
/**clock sync GPIO Pulse Width */
|
||||||
|
t_u16 clock_sync_gpio_pulse_width;
|
||||||
|
} mlan_ds_gpio_tsf_latch;
|
||||||
|
|
||||||
|
/** Type definition of mlan_ds_tsf_info */
|
||||||
|
typedef struct _mlan_ds_tsf_info {
|
||||||
|
/**get tsf info format */
|
||||||
|
t_u16 tsf_format;
|
||||||
|
/**tsf info */
|
||||||
|
t_u16 tsf_info;
|
||||||
|
/**tsf */
|
||||||
|
t_u64 tsf;
|
||||||
|
/**Positive or negative offset in microsecond from Beacon TSF to GPIO
|
||||||
|
* toggle TSF */
|
||||||
|
t_s32 tsf_offset;
|
||||||
|
} mlan_ds_tsf_info;
|
||||||
|
|
||||||
#if defined(STA_SUPPORT)
|
#if defined(STA_SUPPORT)
|
||||||
typedef struct _mlan_ds_misc_pmfcfg {
|
typedef struct _mlan_ds_misc_pmfcfg {
|
||||||
/** Management Frame Protection Capable */
|
/** Management Frame Protection Capable */
|
||||||
|
@ -4851,6 +4931,8 @@ typedef struct _mef_entry_t {
|
||||||
typedef struct _mlan_ds_misc_mef_flt_cfg {
|
typedef struct _mlan_ds_misc_mef_flt_cfg {
|
||||||
/** Type of action*/
|
/** Type of action*/
|
||||||
int mef_act_type;
|
int mef_act_type;
|
||||||
|
/** Operation code*/
|
||||||
|
t_u32 op_code;
|
||||||
/** NV Filter Criteria*/
|
/** NV Filter Criteria*/
|
||||||
t_u32 criteria;
|
t_u32 criteria;
|
||||||
/** NV MEF entry*/
|
/** NV MEF entry*/
|
||||||
|
@ -5236,6 +5318,8 @@ typedef struct _mlan_ds_misc_cfg {
|
||||||
mlan_ds_misc_tx_datapause tx_datapause;
|
mlan_ds_misc_tx_datapause tx_datapause;
|
||||||
/** IP address configuration */
|
/** IP address configuration */
|
||||||
mlan_ds_misc_ipaddr_cfg ipaddr_cfg;
|
mlan_ds_misc_ipaddr_cfg ipaddr_cfg;
|
||||||
|
/** IPv6 Router Advertisement offload configuration */
|
||||||
|
mlan_ds_misc_ipv6_ra_offload ipv6_ra_offload;
|
||||||
/** MAC control for MLAN_OID_MISC_MAC_CONTROL */
|
/** MAC control for MLAN_OID_MISC_MAC_CONTROL */
|
||||||
t_u32 mac_ctrl;
|
t_u32 mac_ctrl;
|
||||||
/** MEF configuration for MLAN_OID_MISC_MEF_CFG */
|
/** MEF configuration for MLAN_OID_MISC_MEF_CFG */
|
||||||
|
@ -5274,6 +5358,8 @@ typedef struct _mlan_ds_misc_cfg {
|
||||||
#ifdef WIFI_DIRECT_SUPPORT
|
#ifdef WIFI_DIRECT_SUPPORT
|
||||||
mlan_ds_wifi_direct_config p2p_config;
|
mlan_ds_wifi_direct_config p2p_config;
|
||||||
#endif
|
#endif
|
||||||
|
mlan_ds_gpio_tsf_latch gpio_tsf_latch_config;
|
||||||
|
mlan_ds_tsf_info tsf_info;
|
||||||
mlan_ds_coalesce_cfg coalesce_cfg;
|
mlan_ds_coalesce_cfg coalesce_cfg;
|
||||||
t_u8 low_pwr_mode;
|
t_u8 low_pwr_mode;
|
||||||
/** MEF-FLT-CONFIG for MLAN_OID_MISC_NV_FLT_CFG */
|
/** MEF-FLT-CONFIG for MLAN_OID_MISC_NV_FLT_CFG */
|
||||||
|
@ -5325,6 +5411,9 @@ typedef struct _mlan_ds_misc_cfg {
|
||||||
mlan_ds_misc_dot11mc_unassoc_ftm_cfg dot11mc_unassoc_ftm_cfg;
|
mlan_ds_misc_dot11mc_unassoc_ftm_cfg dot11mc_unassoc_ftm_cfg;
|
||||||
mlan_ds_misc_tp_state tp_state;
|
mlan_ds_misc_tp_state tp_state;
|
||||||
mlan_ds_hal_phy_cfg_params hal_phy_cfg_params;
|
mlan_ds_hal_phy_cfg_params hal_phy_cfg_params;
|
||||||
|
#ifdef UAP_SUPPORT
|
||||||
|
t_u8 wacp_mode;
|
||||||
|
#endif
|
||||||
} param;
|
} param;
|
||||||
} mlan_ds_misc_cfg, *pmlan_ds_misc_cfg;
|
} mlan_ds_misc_cfg, *pmlan_ds_misc_cfg;
|
||||||
|
|
||||||
|
|
|
@ -412,6 +412,7 @@ mlan_status woal_cfg80211_set_key(moal_private *priv, t_u8 is_enable_wep,
|
||||||
cipher != WLAN_CIPHER_SUITE_GCMP &&
|
cipher != WLAN_CIPHER_SUITE_GCMP &&
|
||||||
#endif
|
#endif
|
||||||
#if KERNEL_VERSION(4, 0, 0) <= CFG80211_VERSION_CODE
|
#if KERNEL_VERSION(4, 0, 0) <= CFG80211_VERSION_CODE
|
||||||
|
cipher != WLAN_CIPHER_SUITE_BIP_GMAC_128 &&
|
||||||
cipher != WLAN_CIPHER_SUITE_BIP_GMAC_256 &&
|
cipher != WLAN_CIPHER_SUITE_BIP_GMAC_256 &&
|
||||||
cipher != WLAN_CIPHER_SUITE_GCMP_256 &&
|
cipher != WLAN_CIPHER_SUITE_GCMP_256 &&
|
||||||
#endif
|
#endif
|
||||||
|
@ -480,11 +481,21 @@ mlan_status woal_cfg80211_set_key(moal_private *priv, t_u8 is_enable_wep,
|
||||||
|
|
||||||
if (cipher == WLAN_CIPHER_SUITE_AES_CMAC
|
if (cipher == WLAN_CIPHER_SUITE_AES_CMAC
|
||||||
#if KERNEL_VERSION(4, 0, 0) <= CFG80211_VERSION_CODE
|
#if KERNEL_VERSION(4, 0, 0) <= CFG80211_VERSION_CODE
|
||||||
|| cipher == WLAN_CIPHER_SUITE_BIP_GMAC_256
|
|| cipher == WLAN_CIPHER_SUITE_BIP_GMAC_128 ||
|
||||||
|
cipher == WLAN_CIPHER_SUITE_BIP_GMAC_256
|
||||||
#endif
|
#endif
|
||||||
) {
|
) {
|
||||||
sec->param.encrypt_key.key_flags |=
|
sec->param.encrypt_key.key_flags |=
|
||||||
KEY_FLAG_AES_MCAST_IGTK;
|
KEY_FLAG_AES_MCAST_IGTK;
|
||||||
|
|
||||||
|
#if KERNEL_VERSION(4, 0, 0) <= CFG80211_VERSION_CODE
|
||||||
|
if (cipher == WLAN_CIPHER_SUITE_BIP_GMAC_128)
|
||||||
|
sec->param.encrypt_key.key_flags |=
|
||||||
|
KEY_FLAG_GMAC_128;
|
||||||
|
else if (cipher == WLAN_CIPHER_SUITE_BIP_GMAC_256)
|
||||||
|
sec->param.encrypt_key.key_flags |=
|
||||||
|
KEY_FLAG_GMAC_256;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (key_index == KEY_INDEX_CLEAR_ALL)
|
if (key_index == KEY_INDEX_CLEAR_ALL)
|
||||||
|
@ -1511,6 +1522,17 @@ int woal_cfg80211_set_default_mgmt_key(struct wiphy *wiphy,
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if KERNEL_VERSION(5, 10, 0) <= CFG80211_VERSION_CODE
|
||||||
|
int woal_cfg80211_set_default_beacon_key(struct wiphy *wiphy,
|
||||||
|
struct net_device *netdev,
|
||||||
|
t_u8 key_index)
|
||||||
|
{
|
||||||
|
PRINTM(MINFO, "set default beacon key, key index=%d\n", key_index);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
#if KERNEL_VERSION(3, 1, 0) <= CFG80211_VERSION_CODE
|
#if KERNEL_VERSION(3, 1, 0) <= CFG80211_VERSION_CODE
|
||||||
/**
|
/**
|
||||||
* @brief Set GTK rekey data to driver
|
* @brief Set GTK rekey data to driver
|
||||||
|
@ -4596,7 +4618,47 @@ void woal_cfg80211_notify_sched_scan_stop(moal_private *priv)
|
||||||
#endif
|
#endif
|
||||||
);
|
);
|
||||||
priv->sched_scanning = MFALSE;
|
priv->sched_scanning = MFALSE;
|
||||||
PRINTM(MEVENT, "Sched_Scan stopped\n");
|
PRINTM(MEVENT, "Notify sched scan stopped\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief sched_scan work handler
|
||||||
|
*
|
||||||
|
* @param work a pointer to work_struct
|
||||||
|
*
|
||||||
|
* @return 0 -- success, otherwise fail
|
||||||
|
*/
|
||||||
|
void woal_sched_scan_work_queue(struct work_struct *work)
|
||||||
|
{
|
||||||
|
struct delayed_work *delayed_work =
|
||||||
|
container_of(work, struct delayed_work, work);
|
||||||
|
moal_private *priv =
|
||||||
|
container_of(delayed_work, moal_private, sched_scan_work);
|
||||||
|
ENTER();
|
||||||
|
|
||||||
|
if (priv->sched_scanning)
|
||||||
|
woal_cfg80211_notify_sched_scan_stop(priv);
|
||||||
|
|
||||||
|
LEAVE();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief report sched_scan result to kernel
|
||||||
|
*
|
||||||
|
* @param priv A pointer moal_private structure
|
||||||
|
*
|
||||||
|
* @return N/A
|
||||||
|
*/
|
||||||
|
void woal_report_sched_scan_result(moal_private *priv)
|
||||||
|
{
|
||||||
|
cfg80211_sched_scan_results(priv->wdev->wiphy
|
||||||
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(4, 12, 0)
|
||||||
|
,
|
||||||
|
priv->bg_scan_reqid
|
||||||
|
#endif
|
||||||
|
);
|
||||||
|
queue_delayed_work(priv->sched_scan_workqueue, &priv->sched_scan_work,
|
||||||
|
msecs_to_jiffies(2000));
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -48,6 +48,9 @@
|
||||||
#define WLAN_CIPHER_SUITE_AES_CMAC 0x000FAC06
|
#define WLAN_CIPHER_SUITE_AES_CMAC 0x000FAC06
|
||||||
#endif
|
#endif
|
||||||
#if KERNEL_VERSION(4, 0, 0) <= CFG80211_VERSION_CODE
|
#if KERNEL_VERSION(4, 0, 0) <= CFG80211_VERSION_CODE
|
||||||
|
#ifndef WLAN_CIPHER_SUITE_BIP_GMAC_128
|
||||||
|
#define WLAN_CIPHER_SUITE_BIP_GMAC_128 0x000FAC0B
|
||||||
|
#endif
|
||||||
#ifndef WLAN_CIPHER_SUITE_BIP_GMAC_256
|
#ifndef WLAN_CIPHER_SUITE_BIP_GMAC_256
|
||||||
#define WLAN_CIPHER_SUITE_BIP_GMAC_256 0x000FAC0C
|
#define WLAN_CIPHER_SUITE_BIP_GMAC_256 0x000FAC0C
|
||||||
#endif
|
#endif
|
||||||
|
@ -206,6 +209,12 @@ int woal_cfg80211_set_default_mgmt_key(struct wiphy *wiphy,
|
||||||
t_u8 key_index);
|
t_u8 key_index);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if KERNEL_VERSION(5, 10, 0) <= CFG80211_VERSION_CODE
|
||||||
|
int woal_cfg80211_set_default_beacon_key(struct wiphy *wiphy,
|
||||||
|
struct net_device *netdev,
|
||||||
|
t_u8 key_index);
|
||||||
|
#endif
|
||||||
|
|
||||||
#if KERNEL_VERSION(3, 1, 0) <= CFG80211_VERSION_CODE
|
#if KERNEL_VERSION(3, 1, 0) <= CFG80211_VERSION_CODE
|
||||||
int woal_cfg80211_set_rekey_data(struct wiphy *wiphy, struct net_device *dev,
|
int woal_cfg80211_set_rekey_data(struct wiphy *wiphy, struct net_device *dev,
|
||||||
struct cfg80211_gtk_rekey_data *data);
|
struct cfg80211_gtk_rekey_data *data);
|
||||||
|
@ -356,7 +365,7 @@ int woal_cfg80211_deinit_p2p(moal_private *priv);
|
||||||
#endif /* WIFI_DIRECT_SUPPORT */
|
#endif /* WIFI_DIRECT_SUPPORT */
|
||||||
|
|
||||||
/** Define for remain on channel duration timer */
|
/** Define for remain on channel duration timer */
|
||||||
#define MAX_REMAIN_ON_CHANNEL_DURATION (1000)
|
#define MAX_REMAIN_ON_CHANNEL_DURATION (5000)
|
||||||
|
|
||||||
int woal_cfg80211_remain_on_channel_cfg(moal_private *priv, t_u8 wait_option,
|
int woal_cfg80211_remain_on_channel_cfg(moal_private *priv, t_u8 wait_option,
|
||||||
t_u8 remove, t_u8 *status,
|
t_u8 remove, t_u8 *status,
|
||||||
|
@ -453,6 +462,8 @@ void woal_channel_switch_event(moal_private *priv, chan_band_info *pchan_info);
|
||||||
#if KERNEL_VERSION(3, 2, 0) <= CFG80211_VERSION_CODE
|
#if KERNEL_VERSION(3, 2, 0) <= CFG80211_VERSION_CODE
|
||||||
void woal_bgscan_stop_event(moal_private *priv);
|
void woal_bgscan_stop_event(moal_private *priv);
|
||||||
void woal_cfg80211_notify_sched_scan_stop(moal_private *priv);
|
void woal_cfg80211_notify_sched_scan_stop(moal_private *priv);
|
||||||
|
void woal_sched_scan_work_queue(struct work_struct *work);
|
||||||
|
void woal_report_sched_scan_result(moal_private *priv);
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
|
@ -48,6 +48,10 @@ static const struct nl80211_vendor_cmd_info vendor_events[] = {
|
||||||
.vendor_id = MRVL_VENDOR_ID,
|
.vendor_id = MRVL_VENDOR_ID,
|
||||||
.subcmd = event_hang,
|
.subcmd = event_hang,
|
||||||
}, /*event_id 0*/
|
}, /*event_id 0*/
|
||||||
|
{
|
||||||
|
.vendor_id = MRVL_VENDOR_ID,
|
||||||
|
.subcmd = event_fw_dump_done,
|
||||||
|
}, /*event_id 1*/
|
||||||
{
|
{
|
||||||
.vendor_id = MRVL_VENDOR_ID,
|
.vendor_id = MRVL_VENDOR_ID,
|
||||||
.subcmd = event_rssi_monitor,
|
.subcmd = event_rssi_monitor,
|
||||||
|
@ -242,6 +246,20 @@ int woal_cfg80211_vendor_event(moal_private *priv, int event, t_u8 *data,
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief send fw dump complete event to vendorhal
|
||||||
|
*
|
||||||
|
* @param priv A pointer to moal_private
|
||||||
|
*
|
||||||
|
* @return N/A
|
||||||
|
*/
|
||||||
|
void woal_cfg80211_vendor_event_fw_dump(moal_private *priv)
|
||||||
|
{
|
||||||
|
PRINTM(MEVENT, "wlan: Notify FW dump complete event\n");
|
||||||
|
woal_cfg80211_vendor_event(priv, event_fw_dump_done, CUS_EVT_FW_DUMP,
|
||||||
|
strlen(CUS_EVT_FW_DUMP));
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief send dfs vendor event to kernel
|
* @brief send dfs vendor event to kernel
|
||||||
*
|
*
|
||||||
|
@ -675,7 +693,6 @@ static int woal_cfg80211_subcmd_get_drv_dump(struct wiphy *wiphy,
|
||||||
int ret = MLAN_STATUS_SUCCESS;
|
int ret = MLAN_STATUS_SUCCESS;
|
||||||
int length = 0;
|
int length = 0;
|
||||||
char driver_dump_file[128];
|
char driver_dump_file[128];
|
||||||
char path_name[64];
|
|
||||||
struct sk_buff *skb = NULL;
|
struct sk_buff *skb = NULL;
|
||||||
|
|
||||||
ENTER();
|
ENTER();
|
||||||
|
@ -687,12 +704,12 @@ static int woal_cfg80211_subcmd_get_drv_dump(struct wiphy *wiphy,
|
||||||
dev = wdev->netdev;
|
dev = wdev->netdev;
|
||||||
priv = (moal_private *)woal_get_netdev_priv(dev);
|
priv = (moal_private *)woal_get_netdev_priv(dev);
|
||||||
handle = priv->phandle;
|
handle = priv->phandle;
|
||||||
memset(path_name, 0, sizeof(path_name));
|
|
||||||
woal_create_dump_dir(handle, path_name, sizeof(path_name));
|
|
||||||
PRINTM(MMSG, "driver dump path name is %s\n", path_name);
|
|
||||||
woal_dump_drv_info(handle, path_name);
|
|
||||||
memset(driver_dump_file, 0, sizeof(driver_dump_file));
|
memset(driver_dump_file, 0, sizeof(driver_dump_file));
|
||||||
sprintf(driver_dump_file, "%s/%s", path_name, "file_drv_info");
|
sprintf(driver_dump_file, "/proc/mwlan/");
|
||||||
|
if (handle->handle_idx)
|
||||||
|
sprintf(driver_dump_file, "drv_dump%d", handle->handle_idx);
|
||||||
|
else
|
||||||
|
sprintf(driver_dump_file, "drv_dump");
|
||||||
PRINTM(MMSG, "driver dump file is %s\n", driver_dump_file);
|
PRINTM(MMSG, "driver dump file is %s\n", driver_dump_file);
|
||||||
length = sizeof(driver_dump_file);
|
length = sizeof(driver_dump_file);
|
||||||
skb = cfg80211_vendor_cmd_alloc_reply_skb(wiphy, length);
|
skb = cfg80211_vendor_cmd_alloc_reply_skb(wiphy, length);
|
||||||
|
@ -2762,9 +2779,6 @@ static int woal_cfg80211_subcmd_link_statistic_get(struct wiphy *wiphy,
|
||||||
t_u64 max_msec = (t_u64)24 * (t_u64)24 * (t_u64)3600 * (t_u64)1000;
|
t_u64 max_msec = (t_u64)24 * (t_u64)24 * (t_u64)3600 * (t_u64)1000;
|
||||||
moal_handle *handle = priv->phandle;
|
moal_handle *handle = priv->phandle;
|
||||||
|
|
||||||
if (priv->media_connected == MFALSE)
|
|
||||||
return -EFAULT;
|
|
||||||
|
|
||||||
/* Allocate an IOCTL request buffer */
|
/* Allocate an IOCTL request buffer */
|
||||||
req = woal_alloc_mlan_ioctl_req(sizeof(t_u32) + BUF_MAXLEN);
|
req = woal_alloc_mlan_ioctl_req(sizeof(t_u32) + BUF_MAXLEN);
|
||||||
if (req == NULL) {
|
if (req == NULL) {
|
||||||
|
|
|
@ -603,6 +603,7 @@ enum mrvl_wlan_vendor_attr_wifi_logger {
|
||||||
/**vendor event*/
|
/**vendor event*/
|
||||||
enum vendor_event {
|
enum vendor_event {
|
||||||
event_hang = 0,
|
event_hang = 0,
|
||||||
|
event_fw_dump_done = 1,
|
||||||
event_rssi_monitor = 0x1501,
|
event_rssi_monitor = 0x1501,
|
||||||
event_cloud_keep_alive = 0x10003,
|
event_cloud_keep_alive = 0x10003,
|
||||||
event_dfs_radar_detected = 0x10004,
|
event_dfs_radar_detected = 0x10004,
|
||||||
|
|
|
@ -1032,6 +1032,9 @@ static int woal_debug_read(struct seq_file *sfp, void *data)
|
||||||
mp_aggr_pkt_limit = info->mp_aggr_pkt_limit;
|
mp_aggr_pkt_limit = info->mp_aggr_pkt_limit;
|
||||||
seq_printf(sfp, "last_recv_wr_bitmap=0x%x last_mp_index=%d\n",
|
seq_printf(sfp, "last_recv_wr_bitmap=0x%x last_mp_index=%d\n",
|
||||||
info->last_recv_wr_bitmap, info->last_mp_index);
|
info->last_recv_wr_bitmap, info->last_mp_index);
|
||||||
|
seq_printf(sfp,
|
||||||
|
"last_recv_rd_bitmap=0x%x mp_data_port_mask=0x%x\n",
|
||||||
|
info->last_recv_rd_bitmap, info->mp_data_port_mask);
|
||||||
for (i = 0; i < SDIO_MP_DBG_NUM; i++) {
|
for (i = 0; i < SDIO_MP_DBG_NUM; i++) {
|
||||||
seq_printf(
|
seq_printf(
|
||||||
sfp,
|
sfp,
|
||||||
|
@ -1076,6 +1079,7 @@ static int woal_debug_read(struct seq_file *sfp, void *data)
|
||||||
#endif
|
#endif
|
||||||
seq_printf(sfp, "tcp_ack_drop_cnt=%d\n", priv->tcp_ack_drop_cnt);
|
seq_printf(sfp, "tcp_ack_drop_cnt=%d\n", priv->tcp_ack_drop_cnt);
|
||||||
seq_printf(sfp, "tcp_ack_cnt=%d\n", priv->tcp_ack_cnt);
|
seq_printf(sfp, "tcp_ack_cnt=%d\n", priv->tcp_ack_cnt);
|
||||||
|
seq_printf(sfp, "tcp_ack_payload=%d\n", priv->tcp_ack_payload);
|
||||||
#if LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 29)
|
#if LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 29)
|
||||||
for (i = 0; i < 4; i++)
|
for (i = 0; i < 4; i++)
|
||||||
seq_printf(sfp, "wmm_tx_pending[%d]:%d\n", i,
|
seq_printf(sfp, "wmm_tx_pending[%d]:%d\n", i,
|
||||||
|
|
|
@ -6552,6 +6552,58 @@ done:
|
||||||
}
|
}
|
||||||
#endif /* SDIO */
|
#endif /* SDIO */
|
||||||
|
|
||||||
|
#ifdef STA_SUPPORT
|
||||||
|
/**
|
||||||
|
* @brief arpfilter ioctl function
|
||||||
|
*
|
||||||
|
* @param priv A pointer to moal_private structure
|
||||||
|
* @param respbuf A pointer to response buffer
|
||||||
|
* @param respbuflen Available length of response buffer
|
||||||
|
*
|
||||||
|
* @return 0 --success, otherwise fail
|
||||||
|
*/
|
||||||
|
static int woal_priv_arpfilter(moal_private *priv, t_u8 *respbuf,
|
||||||
|
t_u32 respbuflen)
|
||||||
|
{
|
||||||
|
int ret = 0;
|
||||||
|
mlan_ds_misc_cfg *misc = NULL;
|
||||||
|
mlan_ioctl_req *req = NULL;
|
||||||
|
t_u8 *data_ptr = NULL;
|
||||||
|
t_u32 buf_len = 0;
|
||||||
|
mlan_status status = MLAN_STATUS_SUCCESS;
|
||||||
|
|
||||||
|
ENTER();
|
||||||
|
|
||||||
|
req = woal_alloc_mlan_ioctl_req(sizeof(mlan_ds_misc_cfg));
|
||||||
|
if (req == NULL) {
|
||||||
|
ret = -ENOMEM;
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
misc = (mlan_ds_misc_cfg *)req->pbuf;
|
||||||
|
misc->sub_command = MLAN_OID_MISC_GEN_IE;
|
||||||
|
req->req_id = MLAN_IOCTL_MISC_CFG;
|
||||||
|
req->action = MLAN_ACT_SET;
|
||||||
|
misc->param.gen_ie.type = MLAN_IE_TYPE_ARP_FILTER;
|
||||||
|
|
||||||
|
data_ptr = respbuf + (strlen(CMD_NXP) + strlen(PRIV_CMD_ARPFILTER));
|
||||||
|
buf_len = *((t_u16 *)data_ptr);
|
||||||
|
misc->param.gen_ie.len = buf_len;
|
||||||
|
moal_memcpy_ext(priv->phandle, (void *)(misc->param.gen_ie.ie_data),
|
||||||
|
data_ptr + sizeof(buf_len), buf_len, MAX_IE_SIZE);
|
||||||
|
|
||||||
|
status = woal_request_ioctl(priv, req, MOAL_IOCTL_WAIT);
|
||||||
|
if (status != MLAN_STATUS_SUCCESS) {
|
||||||
|
ret = -EFAULT;
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
done:
|
||||||
|
if (status != MLAN_STATUS_PENDING)
|
||||||
|
kfree(req);
|
||||||
|
LEAVE();
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
#endif /* STA_SUPPORT */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Set / Get Auto ARP Response configuration
|
* @brief Set / Get Auto ARP Response configuration
|
||||||
*
|
*
|
||||||
|
@ -10889,6 +10941,7 @@ static int woal_channel_switch(moal_private *priv, t_u8 block_tx,
|
||||||
pvhttpcEnv_ie->local_max_tp_20mhz = 0xff;
|
pvhttpcEnv_ie->local_max_tp_20mhz = 0xff;
|
||||||
pvhttpcEnv_ie->local_max_tp_40mhz = 0xff;
|
pvhttpcEnv_ie->local_max_tp_40mhz = 0xff;
|
||||||
pvhttpcEnv_ie->local_max_tp_80mhz = 0xff;
|
pvhttpcEnv_ie->local_max_tp_80mhz = 0xff;
|
||||||
|
pvhttpcEnv_ie->local_max_tp_160mhz_80_80mhz = 0xff;
|
||||||
pChanSwWrap_ie->len += sizeof(IEEEtypes_VhtTpcEnvelope_t);
|
pChanSwWrap_ie->len += sizeof(IEEEtypes_VhtTpcEnvelope_t);
|
||||||
pcust_chansw_ie->ie_length +=
|
pcust_chansw_ie->ie_length +=
|
||||||
pChanSwWrap_ie->len + sizeof(IEEEtypes_Header_t);
|
pChanSwWrap_ie->len + sizeof(IEEEtypes_Header_t);
|
||||||
|
@ -12801,6 +12854,192 @@ done:
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Set/Get GPIO TSF latch clock sync config parameters
|
||||||
|
* @param priv Pointer to moal_private structure
|
||||||
|
* @param respbuf Pointer to response buffer
|
||||||
|
* @param resplen Response buffer length
|
||||||
|
*
|
||||||
|
* @return Number of bytes written, negative for failure.
|
||||||
|
*/
|
||||||
|
static int woal_priv_cfg_clock_sync(moal_private *priv, t_u8 *respbuf,
|
||||||
|
t_u32 respbuflen)
|
||||||
|
{
|
||||||
|
int header_len = 0, user_data_len = 0;
|
||||||
|
int ret = 0, data[5];
|
||||||
|
mlan_ds_gpio_tsf_latch *clock_sync_cfg = NULL;
|
||||||
|
mlan_ioctl_req *req = NULL;
|
||||||
|
mlan_ds_misc_cfg *misc_cfg = NULL;
|
||||||
|
mlan_status status = MLAN_STATUS_SUCCESS;
|
||||||
|
|
||||||
|
ENTER();
|
||||||
|
|
||||||
|
header_len = strlen(CMD_NXP) + strlen(PRIV_CMD_CFG_CLOCK_SYNC);
|
||||||
|
|
||||||
|
memset(data, 0, sizeof(data));
|
||||||
|
parse_arguments(respbuf + header_len, data, ARRAY_SIZE(data),
|
||||||
|
&user_data_len);
|
||||||
|
|
||||||
|
if (user_data_len > 5) {
|
||||||
|
PRINTM(MERROR, "invalid parameters\n");
|
||||||
|
ret = -EINVAL;
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Allocate an IOCTL request buffer */
|
||||||
|
req = woal_alloc_mlan_ioctl_req(sizeof(mlan_ds_misc_cfg));
|
||||||
|
if (req == NULL) {
|
||||||
|
ret = -ENOMEM;
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Fill request buffer */
|
||||||
|
req->req_id = MLAN_IOCTL_MISC_CFG;
|
||||||
|
misc_cfg = (mlan_ds_misc_cfg *)req->pbuf;
|
||||||
|
misc_cfg->sub_command = MLAN_OID_MISC_GPIO_TSF_LATCH;
|
||||||
|
clock_sync_cfg = &misc_cfg->param.gpio_tsf_latch_config;
|
||||||
|
memset(clock_sync_cfg, 0, sizeof(mlan_ds_gpio_tsf_latch));
|
||||||
|
|
||||||
|
if ((int)strlen(respbuf) == header_len) {
|
||||||
|
/* GET operation */
|
||||||
|
req->action = MLAN_ACT_GET;
|
||||||
|
user_data_len = 0;
|
||||||
|
} else {
|
||||||
|
req->action = MLAN_ACT_SET;
|
||||||
|
switch (user_data_len) {
|
||||||
|
case 5:
|
||||||
|
clock_sync_cfg->clock_sync_gpio_pulse_width =
|
||||||
|
(t_u16)data[4];
|
||||||
|
/* fall through */
|
||||||
|
case 4:
|
||||||
|
if (data[3] < 0 || data[3] > 1) {
|
||||||
|
PRINTM(MERROR, "Invalid Level/Trigger\n");
|
||||||
|
ret = -EINVAL;
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
clock_sync_cfg->clock_sync_gpio_level_toggle =
|
||||||
|
(t_u8)data[3];
|
||||||
|
/* fall through */
|
||||||
|
case 3:
|
||||||
|
if (data[2] < 1 || data[2] > 255) {
|
||||||
|
PRINTM(MERROR,
|
||||||
|
"Invalid number of GPIO Pin Number\n");
|
||||||
|
ret = -EINVAL;
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
clock_sync_cfg->clock_sync_gpio_pin_number =
|
||||||
|
(t_u8)data[2];
|
||||||
|
/* fall through */
|
||||||
|
case 2:
|
||||||
|
if (data[1] < 0 || data[1] > 2) {
|
||||||
|
PRINTM(MERROR, "Invalid Role\n");
|
||||||
|
ret = -EINVAL;
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
clock_sync_cfg->clock_sync_Role = (t_u8)data[1];
|
||||||
|
/* fall through */
|
||||||
|
case 1:
|
||||||
|
if (data[0] < 0 || data[0] > 2) {
|
||||||
|
PRINTM(MERROR, "Invalid Mode\n");
|
||||||
|
ret = -EINVAL;
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
clock_sync_cfg->clock_sync_mode = (t_u8)data[0];
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/* Send IOCTL request to MLAN */
|
||||||
|
status = woal_request_ioctl(priv, req, MOAL_IOCTL_WAIT);
|
||||||
|
if (status != MLAN_STATUS_SUCCESS) {
|
||||||
|
ret = -EFAULT;
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!user_data_len) {
|
||||||
|
moal_memcpy_ext(priv->phandle, respbuf, (t_u8 *)clock_sync_cfg,
|
||||||
|
sizeof(mlan_ds_gpio_tsf_latch), respbuflen);
|
||||||
|
ret = sizeof(mlan_ds_gpio_tsf_latch);
|
||||||
|
}
|
||||||
|
|
||||||
|
done:
|
||||||
|
if (status != MLAN_STATUS_PENDING)
|
||||||
|
kfree(req);
|
||||||
|
|
||||||
|
LEAVE();
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Set/Get GPIO TSF latch get tsf info config parameters
|
||||||
|
* @param priv Pointer to moal_private structure
|
||||||
|
* @param respbuf Pointer to response buffer
|
||||||
|
* @param resplen Response buffer length
|
||||||
|
*
|
||||||
|
* @return Number of bytes written, negative for failure.
|
||||||
|
*/
|
||||||
|
static int woal_priv_cfg_get_tsf_info(moal_private *priv, t_u8 *respbuf,
|
||||||
|
t_u32 respbuflen)
|
||||||
|
{
|
||||||
|
int header_len = 0, user_data_len = 0;
|
||||||
|
int ret = 0, data[1];
|
||||||
|
mlan_ds_tsf_info *tsf_info;
|
||||||
|
mlan_ioctl_req *req = NULL;
|
||||||
|
mlan_ds_misc_cfg *misc_cfg = NULL;
|
||||||
|
mlan_status status = MLAN_STATUS_SUCCESS;
|
||||||
|
|
||||||
|
ENTER();
|
||||||
|
|
||||||
|
header_len = strlen(CMD_NXP) + strlen(PRIV_CMD_CFG_GET_TSF_INFO);
|
||||||
|
|
||||||
|
memset(data, 0, sizeof(data));
|
||||||
|
parse_arguments(respbuf + header_len, data, ARRAY_SIZE(data),
|
||||||
|
&user_data_len);
|
||||||
|
|
||||||
|
if (user_data_len > 1) {
|
||||||
|
PRINTM(MERROR, "invalid parameters\n");
|
||||||
|
ret = -EINVAL;
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
/* Allocate an IOCTL request buffer */
|
||||||
|
req = woal_alloc_mlan_ioctl_req(sizeof(mlan_ds_misc_cfg));
|
||||||
|
if (req == NULL) {
|
||||||
|
ret = -ENOMEM;
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Fill request buffer */
|
||||||
|
req->req_id = MLAN_IOCTL_MISC_CFG;
|
||||||
|
req->action = MLAN_ACT_GET;
|
||||||
|
misc_cfg = (mlan_ds_misc_cfg *)req->pbuf;
|
||||||
|
misc_cfg->sub_command = MLAN_OID_MISC_GET_TSF_INFO;
|
||||||
|
tsf_info = &misc_cfg->param.tsf_info;
|
||||||
|
memset(tsf_info, 0, sizeof(mlan_ds_tsf_info));
|
||||||
|
if (user_data_len == 1) {
|
||||||
|
if (data[0] < 0 || data[0] > 1) {
|
||||||
|
PRINTM(MERROR, "Invalid tsf Format\n");
|
||||||
|
ret = -EINVAL;
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
tsf_info->tsf_format = data[0];
|
||||||
|
}
|
||||||
|
status = woal_request_ioctl(priv, req, MOAL_IOCTL_WAIT);
|
||||||
|
if (status != MLAN_STATUS_SUCCESS) {
|
||||||
|
ret = -EFAULT;
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
moal_memcpy_ext(priv->phandle, respbuf, (t_u8 *)tsf_info,
|
||||||
|
sizeof(mlan_ds_tsf_info), respbuflen);
|
||||||
|
ret = sizeof(mlan_ds_tsf_info);
|
||||||
|
done:
|
||||||
|
if (status != MLAN_STATUS_PENDING)
|
||||||
|
kfree(req);
|
||||||
|
|
||||||
|
LEAVE();
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
#if defined(STA_CFG80211) || defined(UAP_CFG80211)
|
#if defined(STA_CFG80211) || defined(UAP_CFG80211)
|
||||||
#ifdef WIFI_DIRECT_SUPPORT
|
#ifdef WIFI_DIRECT_SUPPORT
|
||||||
#define DEF_NOA_INTERVAL 100
|
#define DEF_NOA_INTERVAL 100
|
||||||
|
@ -15875,6 +16114,14 @@ int woal_android_priv_cmd(struct net_device *dev, struct ifreq *req)
|
||||||
strlen(PRIV_CMD_HAL_PHY_CFG) - strlen(CMD_NXP);
|
strlen(PRIV_CMD_HAL_PHY_CFG) - strlen(CMD_NXP);
|
||||||
len = woal_priv_hal_phy_cfg_cmd(priv, pdata, len);
|
len = woal_priv_hal_phy_cfg_cmd(priv, pdata, len);
|
||||||
goto handled;
|
goto handled;
|
||||||
|
#ifdef STA_SUPPORT
|
||||||
|
} else if (strnicmp(buf + strlen(CMD_NXP), PRIV_CMD_ARPFILTER,
|
||||||
|
strlen(PRIV_CMD_ARPFILTER)) == 0) {
|
||||||
|
/* ARPFilter Configuration */
|
||||||
|
len = woal_priv_arpfilter(priv, buf,
|
||||||
|
priv_cmd.total_len);
|
||||||
|
goto handled;
|
||||||
|
#endif
|
||||||
} else if (strnicmp(buf + strlen(CMD_NXP), PRIV_CMD_AUTO_ARP,
|
} else if (strnicmp(buf + strlen(CMD_NXP), PRIV_CMD_AUTO_ARP,
|
||||||
strlen(PRIV_CMD_AUTO_ARP)) == 0) {
|
strlen(PRIV_CMD_AUTO_ARP)) == 0) {
|
||||||
/* Auto ARP enable/disable */
|
/* Auto ARP enable/disable */
|
||||||
|
@ -16266,6 +16513,20 @@ int woal_android_priv_cmd(struct net_device *dev, struct ifreq *req)
|
||||||
goto handled;
|
goto handled;
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
} else if (strnicmp(buf + strlen(CMD_NXP),
|
||||||
|
PRIV_CMD_CFG_CLOCK_SYNC,
|
||||||
|
strlen(PRIV_CMD_CFG_CLOCK_SYNC)) == 0) {
|
||||||
|
/* Set/Get P2P NoA (Notice of Absence) parameters */
|
||||||
|
len = woal_priv_cfg_clock_sync(priv, buf,
|
||||||
|
priv_cmd.total_len);
|
||||||
|
goto handled;
|
||||||
|
} else if (strnicmp(buf + strlen(CMD_NXP),
|
||||||
|
PRIV_CMD_CFG_GET_TSF_INFO,
|
||||||
|
strlen(PRIV_CMD_CFG_GET_TSF_INFO)) == 0) {
|
||||||
|
/* Set/Get P2P OPP-PS parameters */
|
||||||
|
len = woal_priv_cfg_get_tsf_info(priv, buf,
|
||||||
|
priv_cmd.total_len);
|
||||||
|
goto handled;
|
||||||
} else if (strnicmp(buf + strlen(CMD_NXP),
|
} else if (strnicmp(buf + strlen(CMD_NXP),
|
||||||
PRIV_CMD_DFS_REPEATER_CFG,
|
PRIV_CMD_DFS_REPEATER_CFG,
|
||||||
strlen(PRIV_CMD_DFS_REPEATER_CFG)) == 0) {
|
strlen(PRIV_CMD_DFS_REPEATER_CFG)) == 0) {
|
||||||
|
@ -17179,10 +17440,12 @@ int wlan_get_scan_table_ret_entry(BSSDescriptor_t *pbss_desc, t_u8 **ppbuffer,
|
||||||
* @return 0 --success, otherwise fail
|
* @return 0 --success, otherwise fail
|
||||||
*/
|
*/
|
||||||
#if LINUX_VERSION_CODE >= KERNEL_VERSION(5, 15, 0)
|
#if LINUX_VERSION_CODE >= KERNEL_VERSION(5, 15, 0)
|
||||||
int woal_do_ioctl(struct net_device *dev, struct ifreq *req, void __user *data, int cmd)
|
int woal_do_ioctl(struct net_device *dev, struct ifreq *req, void __user *data,
|
||||||
|
int cmd)
|
||||||
#else
|
#else
|
||||||
int woal_do_ioctl(struct net_device *dev, struct ifreq *req, int cmd)
|
int woal_do_ioctl(struct net_device *dev, struct ifreq *req, int cmd)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
{
|
{
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
|
||||||
|
|
|
@ -148,6 +148,7 @@ typedef struct _chan_stats {
|
||||||
#ifdef SDIO
|
#ifdef SDIO
|
||||||
#define PRIV_CMD_SDCMD52RW "sdcmd52rw"
|
#define PRIV_CMD_SDCMD52RW "sdcmd52rw"
|
||||||
#endif
|
#endif
|
||||||
|
#define PRIV_CMD_ARPFILTER "arpfilter"
|
||||||
#define PRIV_CMD_HOTSPOTCFG "hotspotcfg"
|
#define PRIV_CMD_HOTSPOTCFG "hotspotcfg"
|
||||||
#define PRIV_CMD_MGMT_FRAME_CTRL "mgmtframectrl"
|
#define PRIV_CMD_MGMT_FRAME_CTRL "mgmtframectrl"
|
||||||
#define PRIV_CMD_QCONFIG "qconfig"
|
#define PRIV_CMD_QCONFIG "qconfig"
|
||||||
|
@ -235,6 +236,8 @@ typedef struct _chan_stats {
|
||||||
#define PRIV_CMD_CFG_OPP_PS "cfg_opp_ps"
|
#define PRIV_CMD_CFG_OPP_PS "cfg_opp_ps"
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
#define PRIV_CMD_CFG_CLOCK_SYNC "clocksync"
|
||||||
|
#define PRIV_CMD_CFG_GET_TSF_INFO "gettsfinfo"
|
||||||
#define PRIV_CMD_DFS_REPEATER_CFG "dfs_repeater"
|
#define PRIV_CMD_DFS_REPEATER_CFG "dfs_repeater"
|
||||||
#ifdef WIFI_DIRECT_SUPPORT
|
#ifdef WIFI_DIRECT_SUPPORT
|
||||||
#if defined(STA_CFG80211) || defined(UAP_CFG80211)
|
#if defined(STA_CFG80211) || defined(UAP_CFG80211)
|
||||||
|
@ -365,11 +368,11 @@ typedef struct _ssu_params_cfg {
|
||||||
#define PRIV_CMD_LPM "lpm"
|
#define PRIV_CMD_LPM "lpm"
|
||||||
|
|
||||||
#if LINUX_VERSION_CODE >= KERNEL_VERSION(5, 15, 0)
|
#if LINUX_VERSION_CODE >= KERNEL_VERSION(5, 15, 0)
|
||||||
int woal_do_ioctl(struct net_device *dev, struct ifreq *req, void __user *data, int cmd);
|
int woal_do_ioctl(struct net_device *dev, struct ifreq *req, void __user *data,
|
||||||
|
int cmd);
|
||||||
#else
|
#else
|
||||||
int woal_do_ioctl(struct net_device *dev, struct ifreq *req, int cmd);
|
int woal_do_ioctl(struct net_device *dev, struct ifreq *req, int cmd);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* For android private commands, fixed value of ioctl is used.
|
* For android private commands, fixed value of ioctl is used.
|
||||||
* Internally commands are differentiated using strings.
|
* Internally commands are differentiated using strings.
|
||||||
|
|
|
@ -66,12 +66,19 @@ static int host_mlme;
|
||||||
/** Auto deep sleep */
|
/** Auto deep sleep */
|
||||||
static int auto_ds;
|
static int auto_ds;
|
||||||
|
|
||||||
|
/** net_rx mode*/
|
||||||
|
static int net_rx;
|
||||||
|
|
||||||
|
static int ext_scan;
|
||||||
|
|
||||||
/** IEEE PS mode */
|
/** IEEE PS mode */
|
||||||
static int ps_mode;
|
static int ps_mode;
|
||||||
/** passive to active scan */
|
/** passive to active scan */
|
||||||
static int p2a_scan;
|
static int p2a_scan;
|
||||||
/** scan chan gap */
|
/** scan chan gap */
|
||||||
static int scan_chan_gap;
|
static int scan_chan_gap;
|
||||||
|
/** sched scan */
|
||||||
|
static int sched_scan = 1;
|
||||||
/** Max Tx buffer size */
|
/** Max Tx buffer size */
|
||||||
int max_tx_buf;
|
int max_tx_buf;
|
||||||
|
|
||||||
|
@ -89,6 +96,8 @@ static int max_uap_bss = DEF_UAP_BSS;
|
||||||
static char *uap_name;
|
static char *uap_name;
|
||||||
/** Max uAP station number */
|
/** Max uAP station number */
|
||||||
static int uap_max_sta;
|
static int uap_max_sta;
|
||||||
|
/** WACP mode */
|
||||||
|
static int wacp_mode = WACP_MODE_DEFAULT;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef WIFI_DIRECT_SUPPORT
|
#ifdef WIFI_DIRECT_SUPPORT
|
||||||
|
@ -116,6 +125,7 @@ static int slew_rate = 3;
|
||||||
int tx_work = 0;
|
int tx_work = 0;
|
||||||
static int rps = 0;
|
static int rps = 0;
|
||||||
static int tx_skb_clone = 0;
|
static int tx_skb_clone = 0;
|
||||||
|
static int pmqos = 0;
|
||||||
|
|
||||||
#if defined(STA_SUPPORT)
|
#if defined(STA_SUPPORT)
|
||||||
/** 802.11d configuration */
|
/** 802.11d configuration */
|
||||||
|
@ -147,7 +157,8 @@ static char *band_steer_cfg;
|
||||||
|
|
||||||
#if defined(STA_WEXT) || defined(UAP_WEXT)
|
#if defined(STA_WEXT) || defined(UAP_WEXT)
|
||||||
/** CFG80211 and WEXT mode */
|
/** CFG80211 and WEXT mode */
|
||||||
static int cfg80211_wext = STA_WEXT_MASK | UAP_WEXT_MASK;
|
static int cfg80211_wext =
|
||||||
|
STA_WEXT_MASK | UAP_WEXT_MASK | STA_CFG80211_MASK | UAP_CFG80211_MASK;
|
||||||
#else
|
#else
|
||||||
/** CFG80211 mode */
|
/** CFG80211 mode */
|
||||||
static int cfg80211_wext = STA_CFG80211_MASK | UAP_CFG80211_MASK;
|
static int cfg80211_wext = STA_CFG80211_MASK | UAP_CFG80211_MASK;
|
||||||
|
@ -250,6 +261,9 @@ t_u32 drvdbg = DEFAULT_DEBUG_MASK;
|
||||||
#endif /* DEBUG_LEVEL1 */
|
#endif /* DEBUG_LEVEL1 */
|
||||||
|
|
||||||
static card_type_entry card_type_map_tbl[] = {
|
static card_type_entry card_type_map_tbl[] = {
|
||||||
|
#ifdef SD8801
|
||||||
|
{CARD_TYPE_SD8801, 0, CARD_SD8801},
|
||||||
|
#endif
|
||||||
#ifdef SD8887
|
#ifdef SD8887
|
||||||
{CARD_TYPE_SD8887, 0, CARD_SD8887},
|
{CARD_TYPE_SD8887, 0, CARD_SD8887},
|
||||||
#endif
|
#endif
|
||||||
|
@ -289,6 +303,10 @@ static card_type_entry card_type_map_tbl[] = {
|
||||||
#ifdef PCIE9098
|
#ifdef PCIE9098
|
||||||
{CARD_TYPE_PCIE9098, 0, CARD_PCIE9098},
|
{CARD_TYPE_PCIE9098, 0, CARD_PCIE9098},
|
||||||
#endif
|
#endif
|
||||||
|
#ifdef USB8801
|
||||||
|
{CARD_TYPE_USB8801, 0, CARD_USB8801},
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef USB8897
|
#ifdef USB8897
|
||||||
{CARD_TYPE_USB8897, 0, CARD_USB8897},
|
{CARD_TYPE_USB8897, 0, CARD_USB8897},
|
||||||
#endif
|
#endif
|
||||||
|
@ -651,6 +669,18 @@ static mlan_status parse_cfg_read_block(t_u8 *data, t_u32 size,
|
||||||
goto err;
|
goto err;
|
||||||
params->auto_ds = out_data;
|
params->auto_ds = out_data;
|
||||||
PRINTM(MMSG, "auto_ds = %d\n", params->auto_ds);
|
PRINTM(MMSG, "auto_ds = %d\n", params->auto_ds);
|
||||||
|
} else if (strncmp(line, "net_rx", strlen("net_rx")) == 0) {
|
||||||
|
if (parse_line_read_int(line, &out_data) !=
|
||||||
|
MLAN_STATUS_SUCCESS)
|
||||||
|
goto err;
|
||||||
|
params->net_rx = out_data;
|
||||||
|
PRINTM(MMSG, "net_rx = %d\n", params->net_rx);
|
||||||
|
} else if (strncmp(line, "ext_scan", strlen("ext_scan")) == 0) {
|
||||||
|
if (parse_line_read_int(line, &out_data) !=
|
||||||
|
MLAN_STATUS_SUCCESS)
|
||||||
|
goto err;
|
||||||
|
params->ext_scan = out_data;
|
||||||
|
PRINTM(MMSG, "ext_scan = %d\n", params->ext_scan);
|
||||||
} else if (strncmp(line, "ps_mode", strlen("ps_mode")) == 0) {
|
} else if (strncmp(line, "ps_mode", strlen("ps_mode")) == 0) {
|
||||||
if (parse_line_read_int(line, &out_data) !=
|
if (parse_line_read_int(line, &out_data) !=
|
||||||
MLAN_STATUS_SUCCESS)
|
MLAN_STATUS_SUCCESS)
|
||||||
|
@ -671,6 +701,13 @@ static mlan_status parse_cfg_read_block(t_u8 *data, t_u32 size,
|
||||||
params->scan_chan_gap = out_data;
|
params->scan_chan_gap = out_data;
|
||||||
PRINTM(MMSG, "scan_chan_gap = %d\n",
|
PRINTM(MMSG, "scan_chan_gap = %d\n",
|
||||||
params->scan_chan_gap);
|
params->scan_chan_gap);
|
||||||
|
} else if (strncmp(line, "sched_scan", strlen("sched_scan")) ==
|
||||||
|
0) {
|
||||||
|
if (parse_line_read_int(line, &out_data) !=
|
||||||
|
MLAN_STATUS_SUCCESS)
|
||||||
|
goto err;
|
||||||
|
params->sched_scan = out_data;
|
||||||
|
PRINTM(MMSG, "sched_scan = %d\n", params->sched_scan);
|
||||||
} else if (strncmp(line, "max_tx_buf", strlen("max_tx_buf")) ==
|
} else if (strncmp(line, "max_tx_buf", strlen("max_tx_buf")) ==
|
||||||
0) {
|
0) {
|
||||||
if (parse_line_read_int(line, &out_data) !=
|
if (parse_line_read_int(line, &out_data) !=
|
||||||
|
@ -1110,6 +1147,17 @@ static mlan_status parse_cfg_read_block(t_u8 *data, t_u32 size,
|
||||||
moal_extflg_isset(handle, EXT_TX_SKB_CLONE) ?
|
moal_extflg_isset(handle, EXT_TX_SKB_CLONE) ?
|
||||||
"on" :
|
"on" :
|
||||||
"off");
|
"off");
|
||||||
|
} else if (strncmp(line, "pmqos", strlen("pmqos")) == 0) {
|
||||||
|
if (parse_line_read_int(line, &out_data) !=
|
||||||
|
MLAN_STATUS_SUCCESS)
|
||||||
|
goto err;
|
||||||
|
if (out_data)
|
||||||
|
moal_extflg_set(handle, EXT_PMQOS);
|
||||||
|
else
|
||||||
|
moal_extflg_clear(handle, EXT_PMQOS);
|
||||||
|
PRINTM(MMSG, "pmqos %s\n",
|
||||||
|
moal_extflg_isset(handle, EXT_PMQOS) ? "on" :
|
||||||
|
"off");
|
||||||
}
|
}
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 14, 0)
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 14, 0)
|
||||||
else if (strncmp(line, "dfs_offload", strlen("dfs_offload")) ==
|
else if (strncmp(line, "dfs_offload", strlen("dfs_offload")) ==
|
||||||
|
@ -1192,6 +1240,13 @@ static mlan_status parse_cfg_read_block(t_u8 *data, t_u32 size,
|
||||||
goto err;
|
goto err;
|
||||||
params->uap_max_sta = out_data;
|
params->uap_max_sta = out_data;
|
||||||
PRINTM(MMSG, "uap_max_sta=%d\n", params->uap_max_sta);
|
PRINTM(MMSG, "uap_max_sta=%d\n", params->uap_max_sta);
|
||||||
|
} else if (strncmp(line, "wacp_mode", strlen("wacp_mode")) ==
|
||||||
|
0) {
|
||||||
|
if (parse_line_read_int(line, &out_data) !=
|
||||||
|
MLAN_STATUS_SUCCESS)
|
||||||
|
goto err;
|
||||||
|
params->wacp_mode = out_data;
|
||||||
|
PRINTM(MMSG, "wacp_moe=%d\n", params->wacp_mode);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
#if defined(STA_CFG80211) || defined(UAP_CFG80211)
|
#if defined(STA_CFG80211) || defined(UAP_CFG80211)
|
||||||
|
@ -1282,10 +1337,12 @@ static void woal_setup_module_param(moal_handle *handle, moal_mod_para *params)
|
||||||
handle->params.max_uap_bss = max_uap_bss;
|
handle->params.max_uap_bss = max_uap_bss;
|
||||||
woal_dup_string(&handle->params.uap_name, uap_name);
|
woal_dup_string(&handle->params.uap_name, uap_name);
|
||||||
handle->params.uap_max_sta = uap_max_sta;
|
handle->params.uap_max_sta = uap_max_sta;
|
||||||
|
handle->params.wacp_mode = wacp_mode;
|
||||||
if (params) {
|
if (params) {
|
||||||
handle->params.max_uap_bss = params->max_uap_bss;
|
handle->params.max_uap_bss = params->max_uap_bss;
|
||||||
woal_dup_string(&handle->params.uap_name, params->uap_name);
|
woal_dup_string(&handle->params.uap_name, params->uap_name);
|
||||||
handle->params.uap_max_sta = params->uap_max_sta;
|
handle->params.uap_max_sta = params->uap_max_sta;
|
||||||
|
handle->params.wacp_mode = params->wacp_mode;
|
||||||
}
|
}
|
||||||
#endif /* UAP_SUPPORT */
|
#endif /* UAP_SUPPORT */
|
||||||
#ifdef WIFI_DIRECT_SUPPORT
|
#ifdef WIFI_DIRECT_SUPPORT
|
||||||
|
@ -1304,15 +1361,25 @@ static void woal_setup_module_param(moal_handle *handle, moal_mod_para *params)
|
||||||
handle->params.auto_ds = auto_ds;
|
handle->params.auto_ds = auto_ds;
|
||||||
if (params)
|
if (params)
|
||||||
handle->params.auto_ds = params->auto_ds;
|
handle->params.auto_ds = params->auto_ds;
|
||||||
|
handle->params.net_rx = net_rx;
|
||||||
|
if (params)
|
||||||
|
handle->params.net_rx = params->net_rx;
|
||||||
|
|
||||||
|
handle->params.ext_scan = ext_scan;
|
||||||
|
if (params)
|
||||||
|
handle->params.ext_scan = params->ext_scan;
|
||||||
|
|
||||||
handle->params.ps_mode = ps_mode;
|
handle->params.ps_mode = ps_mode;
|
||||||
handle->params.p2a_scan = p2a_scan;
|
handle->params.p2a_scan = p2a_scan;
|
||||||
handle->params.scan_chan_gap = scan_chan_gap;
|
handle->params.scan_chan_gap = scan_chan_gap;
|
||||||
|
handle->params.sched_scan = sched_scan;
|
||||||
handle->params.max_tx_buf = max_tx_buf;
|
handle->params.max_tx_buf = max_tx_buf;
|
||||||
if (params) {
|
if (params) {
|
||||||
handle->params.ps_mode = params->ps_mode;
|
handle->params.ps_mode = params->ps_mode;
|
||||||
handle->params.max_tx_buf = params->max_tx_buf;
|
handle->params.max_tx_buf = params->max_tx_buf;
|
||||||
handle->params.p2a_scan = params->p2a_scan;
|
handle->params.p2a_scan = params->p2a_scan;
|
||||||
handle->params.scan_chan_gap = params->scan_chan_gap;
|
handle->params.scan_chan_gap = params->scan_chan_gap;
|
||||||
|
handle->params.sched_scan = params->sched_scan;
|
||||||
}
|
}
|
||||||
#if defined(SDIO)
|
#if defined(SDIO)
|
||||||
if (intmode)
|
if (intmode)
|
||||||
|
@ -1458,6 +1525,8 @@ static void woal_setup_module_param(moal_handle *handle, moal_mod_para *params)
|
||||||
moal_extflg_set(handle, EXT_RPS);
|
moal_extflg_set(handle, EXT_RPS);
|
||||||
if (tx_skb_clone)
|
if (tx_skb_clone)
|
||||||
moal_extflg_set(handle, EXT_TX_SKB_CLONE);
|
moal_extflg_set(handle, EXT_TX_SKB_CLONE);
|
||||||
|
if (pmqos)
|
||||||
|
moal_extflg_set(handle, EXT_PMQOS);
|
||||||
|
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 14, 0)
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 14, 0)
|
||||||
if (dfs_offload)
|
if (dfs_offload)
|
||||||
|
@ -1682,6 +1751,11 @@ void woal_init_from_dev_tree(void)
|
||||||
PRINTM(MIOCTL, "tx_skb_clone=0x%x\n", data);
|
PRINTM(MIOCTL, "tx_skb_clone=0x%x\n", data);
|
||||||
tx_skb_clone = data;
|
tx_skb_clone = data;
|
||||||
}
|
}
|
||||||
|
} else if (!strncmp(prop->name, "pmqos", strlen("pmqos"))) {
|
||||||
|
if (!of_property_read_u32(dt_node, prop->name, &data)) {
|
||||||
|
PRINTM(MIOCTL, "pmqos=0x%x\n", data);
|
||||||
|
pmqos = data;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
#ifdef MFG_CMD_SUPPORT
|
#ifdef MFG_CMD_SUPPORT
|
||||||
else if (!strncmp(prop->name, "mfg_mode", strlen("mfg_mode"))) {
|
else if (!strncmp(prop->name, "mfg_mode", strlen("mfg_mode"))) {
|
||||||
|
@ -1931,8 +2005,21 @@ void woal_init_from_dev_tree(void)
|
||||||
PRINTM(MERROR, "uap_max_sta=0x%x\n", data);
|
PRINTM(MERROR, "uap_max_sta=0x%x\n", data);
|
||||||
uap_max_sta = data;
|
uap_max_sta = data;
|
||||||
}
|
}
|
||||||
|
} else if (!strncmp(prop->name, "wacp_mode",
|
||||||
|
strlen("wacp_mode"))) {
|
||||||
|
if (!of_property_read_u32(dt_node, prop->name, &data)) {
|
||||||
|
PRINTM(MERROR, "wacp_mode=0x%x\n", data);
|
||||||
|
wacp_mode = data;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
else if (!strncmp(prop->name, "sched_scan",
|
||||||
|
strlen("sched_scan"))) {
|
||||||
|
if (!of_property_read_u32(dt_node, prop->name, &data)) {
|
||||||
|
PRINTM(MIOCTL, "sched_scan=%d\n", data);
|
||||||
|
sched_scan = data;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
LEAVE();
|
LEAVE();
|
||||||
return;
|
return;
|
||||||
|
@ -2179,6 +2266,10 @@ module_param(auto_ds, int, 0660);
|
||||||
MODULE_PARM_DESC(
|
MODULE_PARM_DESC(
|
||||||
auto_ds,
|
auto_ds,
|
||||||
"0: MLAN default; 1: Enable auto deep sleep; 2: Disable auto deep sleep");
|
"0: MLAN default; 1: Enable auto deep sleep; 2: Disable auto deep sleep");
|
||||||
|
module_param(ext_scan, int, 0660);
|
||||||
|
MODULE_PARM_DESC(
|
||||||
|
ext_scan,
|
||||||
|
"0: MLAN default; 1: Enable Extended Scan; 2: Enable Enhanced Extended Scan");
|
||||||
module_param(ps_mode, int, 0660);
|
module_param(ps_mode, int, 0660);
|
||||||
MODULE_PARM_DESC(
|
MODULE_PARM_DESC(
|
||||||
ps_mode,
|
ps_mode,
|
||||||
|
@ -2191,6 +2282,9 @@ module_param(scan_chan_gap, int, 0660);
|
||||||
MODULE_PARM_DESC(
|
MODULE_PARM_DESC(
|
||||||
scan_chan_gap,
|
scan_chan_gap,
|
||||||
"Time gap between two scans in milliseconds when connected to AP(max value 500ms)");
|
"Time gap between two scans in milliseconds when connected to AP(max value 500ms)");
|
||||||
|
module_param(sched_scan, int, 0);
|
||||||
|
MODULE_PARM_DESC(sched_scan,
|
||||||
|
"0: disable sched_scan; 1: enable sched_scan default");
|
||||||
module_param(max_tx_buf, int, 0);
|
module_param(max_tx_buf, int, 0);
|
||||||
MODULE_PARM_DESC(max_tx_buf, "Maximum Tx buffer size (2048/4096/8192)");
|
MODULE_PARM_DESC(max_tx_buf, "Maximum Tx buffer size (2048/4096/8192)");
|
||||||
|
|
||||||
|
@ -2226,6 +2320,8 @@ MODULE_PARM_DESC(rps, "1: Enable rps; 0: Disable rps");
|
||||||
module_param(tx_skb_clone, uint, 0660);
|
module_param(tx_skb_clone, uint, 0660);
|
||||||
MODULE_PARM_DESC(tx_skb_clone,
|
MODULE_PARM_DESC(tx_skb_clone,
|
||||||
"1: Enable tx_skb_clone; 0: Disable tx_skb_clone");
|
"1: Enable tx_skb_clone; 0: Disable tx_skb_clone");
|
||||||
|
module_param(pmqos, uint, 0660);
|
||||||
|
MODULE_PARM_DESC(pmqos, "1: Enable pmqos; 0: Disable pmqos");
|
||||||
|
|
||||||
module_param(dpd_data_cfg, charp, 0);
|
module_param(dpd_data_cfg, charp, 0);
|
||||||
MODULE_PARM_DESC(dpd_data_cfg, "DPD data file name");
|
MODULE_PARM_DESC(dpd_data_cfg, "DPD data file name");
|
||||||
|
@ -2289,7 +2385,9 @@ MODULE_PARM_DESC(wakelock_timeout, "set wakelock_timeout value (ms)");
|
||||||
|
|
||||||
module_param(dev_cap_mask, uint, 0);
|
module_param(dev_cap_mask, uint, 0);
|
||||||
MODULE_PARM_DESC(dev_cap_mask, "Device capability mask");
|
MODULE_PARM_DESC(dev_cap_mask, "Device capability mask");
|
||||||
|
module_param(net_rx, int, 0);
|
||||||
|
MODULE_PARM_DESC(net_rx,
|
||||||
|
"0: use netif_rx_ni in rx; 1: use netif_receive_skb in rx");
|
||||||
#ifdef SDIO
|
#ifdef SDIO
|
||||||
module_param(sdio_rx_aggr, int, 0);
|
module_param(sdio_rx_aggr, int, 0);
|
||||||
MODULE_PARM_DESC(sdio_rx_aggr,
|
MODULE_PARM_DESC(sdio_rx_aggr,
|
||||||
|
@ -2364,6 +2462,10 @@ MODULE_PARM_DESC(dfs_offload, "1: enable dfs offload; 0: disable dfs offload.");
|
||||||
#ifdef UAP_SUPPORT
|
#ifdef UAP_SUPPORT
|
||||||
module_param(uap_max_sta, int, 0);
|
module_param(uap_max_sta, int, 0);
|
||||||
MODULE_PARM_DESC(uap_max_sta, "Maximum station number for UAP/GO.");
|
MODULE_PARM_DESC(uap_max_sta, "Maximum station number for UAP/GO.");
|
||||||
|
module_param(wacp_mode, int, 0);
|
||||||
|
MODULE_PARM_DESC(
|
||||||
|
wacp_mode,
|
||||||
|
"WACP mode for UAP/GO 0: WACP_MODE_DEFAULT; 1: WACP_MODE_1; 2: WACP_MODE_2");
|
||||||
#endif
|
#endif
|
||||||
#if defined(STA_CFG80211) || defined(UAP_CFG80211)
|
#if defined(STA_CFG80211) || defined(UAP_CFG80211)
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 8, 0)
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 8, 0)
|
||||||
|
|
|
@ -626,7 +626,8 @@ mlan_status woal_request_ioctl(moal_private *priv, mlan_ioctl_req *req,
|
||||||
|
|
||||||
sub_command = *(t_u32 *)req->pbuf;
|
sub_command = *(t_u32 *)req->pbuf;
|
||||||
|
|
||||||
if (sub_command != MLAN_OID_GET_DEBUG_INFO) {
|
if (sub_command != MLAN_OID_GET_DEBUG_INFO &&
|
||||||
|
sub_command != MLAN_OID_MISC_WARM_RESET) {
|
||||||
if (priv->phandle->surprise_removed == MTRUE ||
|
if (priv->phandle->surprise_removed == MTRUE ||
|
||||||
priv->phandle->driver_status) {
|
priv->phandle->driver_status) {
|
||||||
PRINTM(MCMND,
|
PRINTM(MCMND,
|
||||||
|
@ -2720,6 +2721,300 @@ done:
|
||||||
#endif /* STA_WEXT || UAP_WEXT */
|
#endif /* STA_WEXT || UAP_WEXT */
|
||||||
#endif /* STA_SUPPORT && UAP_SUPPORT */
|
#endif /* STA_SUPPORT && UAP_SUPPORT */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Enable IPv6 Router Advertisement offload
|
||||||
|
*
|
||||||
|
* @param handle A pointer to moal_handle structure
|
||||||
|
* @param enable enable or disable
|
||||||
|
*
|
||||||
|
* @return MLAN_STATUS_SUCCESS/MLAN_STATUS_PENDING -- success, otherwise
|
||||||
|
* fail
|
||||||
|
*/
|
||||||
|
static mlan_status woal_set_ipv6_ra_offload(moal_handle *handle, t_u8 enable)
|
||||||
|
{
|
||||||
|
mlan_status ret = MLAN_STATUS_SUCCESS;
|
||||||
|
moal_private *priv = NULL;
|
||||||
|
mlan_ds_misc_cfg *misc = NULL;
|
||||||
|
mlan_ioctl_req *req = NULL;
|
||||||
|
mlan_ds_misc_ipv6_ra_offload *ipv6_ra;
|
||||||
|
int i = 0;
|
||||||
|
|
||||||
|
ENTER();
|
||||||
|
|
||||||
|
for (i = 0; i < handle->priv_num && (priv = handle->priv[i]); i++) {
|
||||||
|
if (priv->ipv6_addr_configured)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!priv || !priv->ipv6_addr_configured) {
|
||||||
|
PRINTM(MIOCTL, "No IPv6 address configured\n");
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
|
||||||
|
req = woal_alloc_mlan_ioctl_req(sizeof(mlan_ds_misc_cfg));
|
||||||
|
if (req == NULL) {
|
||||||
|
PRINTM(MIOCTL, "IOCTL req allocated failed!\n");
|
||||||
|
ret = MLAN_STATUS_FAILURE;
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
misc = (mlan_ds_misc_cfg *)req->pbuf;
|
||||||
|
misc->sub_command = MLAN_OID_MISC_IPV6_RA_OFFLOAD;
|
||||||
|
req->req_id = MLAN_IOCTL_MISC_CFG;
|
||||||
|
req->action = MLAN_ACT_SET;
|
||||||
|
ipv6_ra = &misc->param.ipv6_ra_offload;
|
||||||
|
ipv6_ra->enable = enable;
|
||||||
|
moal_memcpy_ext(priv->phandle, ipv6_ra->ipv6_addr, priv->ipv6_addr, 16,
|
||||||
|
sizeof(ipv6_ra->ipv6_addr));
|
||||||
|
ret = woal_request_ioctl(woal_get_priv(handle, MLAN_BSS_ROLE_STA), req,
|
||||||
|
MOAL_NO_WAIT);
|
||||||
|
if (ret != MLAN_STATUS_SUCCESS && ret != MLAN_STATUS_PENDING)
|
||||||
|
PRINTM(MIOCTL, "Set IPv6 RA offload failed\n");
|
||||||
|
|
||||||
|
done:
|
||||||
|
if (ret != MLAN_STATUS_PENDING && req != NULL)
|
||||||
|
kfree(req);
|
||||||
|
LEAVE();
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Enable IPv6 Neighbor Solicitation offload
|
||||||
|
*
|
||||||
|
* @param handle A pointer to moal_handle structure
|
||||||
|
* @param enable enable or disable mef entry
|
||||||
|
*
|
||||||
|
* @return MLAN_STATUS_SUCCESS/MLAN_STATUS_PENDING -- success, otherwise
|
||||||
|
* fail
|
||||||
|
*/
|
||||||
|
static mlan_status woal_set_ipv6_ns_offload(moal_handle *handle)
|
||||||
|
{
|
||||||
|
mlan_status ret = MLAN_STATUS_SUCCESS;
|
||||||
|
mlan_ds_misc_cfg *misc = NULL;
|
||||||
|
mlan_ioctl_req *req = NULL;
|
||||||
|
mlan_ds_misc_mef_flt_cfg *mef_cfg = NULL;
|
||||||
|
mef_entry_t *entry = NULL;
|
||||||
|
mef_filter_t *filter = NULL;
|
||||||
|
|
||||||
|
ENTER();
|
||||||
|
|
||||||
|
req = woal_alloc_mlan_ioctl_req(sizeof(mlan_ds_misc_cfg));
|
||||||
|
if (req == NULL) {
|
||||||
|
PRINTM(MIOCTL, "IOCTL req allocated failed!\n");
|
||||||
|
ret = MLAN_STATUS_FAILURE;
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
misc = (mlan_ds_misc_cfg *)req->pbuf;
|
||||||
|
misc->sub_command = MLAN_OID_MISC_MEF_FLT_CFG;
|
||||||
|
req->req_id = MLAN_IOCTL_MISC_CFG;
|
||||||
|
req->action = MLAN_ACT_SET;
|
||||||
|
|
||||||
|
mef_cfg = (mlan_ds_misc_mef_flt_cfg *)(&misc->param.mef_flt_cfg);
|
||||||
|
mef_cfg->mef_act_type = MEF_ACT_IPV6_NS;
|
||||||
|
mef_cfg->criteria = (MBIT(1) | MBIT(3));
|
||||||
|
|
||||||
|
entry = (mef_entry_t *)&mef_cfg->mef_entry;
|
||||||
|
entry->mode = MBIT(0);
|
||||||
|
entry->action = 0x40;
|
||||||
|
|
||||||
|
filter = (mef_filter_t *)entry->filter_item;
|
||||||
|
filter->fill_flag = (FILLING_TYPE | FILLING_REPEAT | FILLING_OFFSET |
|
||||||
|
FILLING_BYTE_SEQ);
|
||||||
|
filter->type = TYPE_BYTE_EQ;
|
||||||
|
filter->repeat = 1;
|
||||||
|
filter->offset = 20;
|
||||||
|
filter->num_byte_seq = 2;
|
||||||
|
moal_memcpy_ext(handle, filter->byte_seq, "\x86\xdd", 2,
|
||||||
|
sizeof(filter->byte_seq));
|
||||||
|
entry->rpn[1] = RPN_TYPE_AND;
|
||||||
|
|
||||||
|
filter++;
|
||||||
|
filter->fill_flag = (FILLING_TYPE | FILLING_REPEAT | FILLING_OFFSET |
|
||||||
|
FILLING_BYTE_SEQ);
|
||||||
|
filter->type = TYPE_BYTE_EQ;
|
||||||
|
filter->repeat = 1;
|
||||||
|
filter->offset = 62;
|
||||||
|
filter->num_byte_seq = 1;
|
||||||
|
moal_memcpy_ext(handle, filter->byte_seq, "\x87", 1,
|
||||||
|
sizeof(filter->byte_seq));
|
||||||
|
|
||||||
|
entry->filter_num = 2;
|
||||||
|
|
||||||
|
ret = woal_request_ioctl(woal_get_priv(handle, MLAN_BSS_ROLE_ANY), req,
|
||||||
|
MOAL_NO_WAIT);
|
||||||
|
if (ret != MLAN_STATUS_SUCCESS && ret != MLAN_STATUS_PENDING)
|
||||||
|
PRINTM(MIOCTL, "Set ipv6 ns offload failed! ret=%d\n", ret);
|
||||||
|
|
||||||
|
done:
|
||||||
|
if (ret != MLAN_STATUS_PENDING)
|
||||||
|
kfree(req);
|
||||||
|
LEAVE();
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Set auto arp resp
|
||||||
|
*
|
||||||
|
* @param handle A pointer to moal_handle structure
|
||||||
|
* @param enable enable/disable
|
||||||
|
*
|
||||||
|
* @return MLAN_STATUS_SUCCESS/MLAN_STATUS_PENDING -- success,
|
||||||
|
* otherwise fail
|
||||||
|
*/
|
||||||
|
static mlan_status woal_set_auto_arp(moal_handle *handle, t_u8 enable)
|
||||||
|
{
|
||||||
|
mlan_status ret = MLAN_STATUS_SUCCESS;
|
||||||
|
int i = 0;
|
||||||
|
moal_private *priv = NULL;
|
||||||
|
mlan_ds_misc_cfg *misc = NULL;
|
||||||
|
mlan_ioctl_req *req = NULL;
|
||||||
|
mlan_ds_misc_ipaddr_cfg ipaddr_cfg;
|
||||||
|
|
||||||
|
ENTER();
|
||||||
|
|
||||||
|
memset(&ipaddr_cfg, 0, sizeof(ipaddr_cfg));
|
||||||
|
for (i = 0; i < handle->priv_num && (priv = handle->priv[i]); i++) {
|
||||||
|
if (priv && priv->ip_addr_type != IPADDR_TYPE_NONE) {
|
||||||
|
moal_memcpy_ext(
|
||||||
|
handle,
|
||||||
|
ipaddr_cfg.ip_addr[ipaddr_cfg.ip_addr_num],
|
||||||
|
priv->ip_addr, IPADDR_LEN, IPADDR_LEN);
|
||||||
|
ipaddr_cfg.ip_addr_num++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (ipaddr_cfg.ip_addr_num == 0) {
|
||||||
|
PRINTM(MIOCTL, "No IP addr configured.\n");
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
|
||||||
|
req = woal_alloc_mlan_ioctl_req(sizeof(mlan_ds_misc_cfg));
|
||||||
|
if (req == NULL) {
|
||||||
|
PRINTM(MIOCTL, "IOCTL req allocated failed!\n");
|
||||||
|
ret = MLAN_STATUS_FAILURE;
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
misc = (mlan_ds_misc_cfg *)req->pbuf;
|
||||||
|
misc->sub_command = MLAN_OID_MISC_IP_ADDR;
|
||||||
|
req->req_id = MLAN_IOCTL_MISC_CFG;
|
||||||
|
req->action = MLAN_ACT_SET;
|
||||||
|
moal_memcpy_ext(handle, &misc->param.ipaddr_cfg, &ipaddr_cfg,
|
||||||
|
sizeof(ipaddr_cfg), sizeof(misc->param.ipaddr_cfg));
|
||||||
|
if (enable) {
|
||||||
|
misc->param.ipaddr_cfg.op_code = MLAN_IPADDR_OP_ARP_FILTER |
|
||||||
|
MLAN_IPADDR_OP_AUTO_ARP_RESP;
|
||||||
|
misc->param.ipaddr_cfg.ip_addr_type = IPADDR_TYPE_IPV4;
|
||||||
|
} else {
|
||||||
|
/** remove ip */
|
||||||
|
misc->param.ipaddr_cfg.op_code = MLAN_IPADDR_OP_IP_REMOVE;
|
||||||
|
}
|
||||||
|
ret = woal_request_ioctl(woal_get_priv(handle, MLAN_BSS_ROLE_ANY), req,
|
||||||
|
MOAL_NO_WAIT);
|
||||||
|
if (ret != MLAN_STATUS_SUCCESS && ret != MLAN_STATUS_PENDING)
|
||||||
|
PRINTM(MIOCTL, "Set auto arp IOCTL failed!\n");
|
||||||
|
done:
|
||||||
|
if (ret != MLAN_STATUS_PENDING)
|
||||||
|
kfree(req);
|
||||||
|
LEAVE();
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Set auto arp resp with enhancement method
|
||||||
|
*
|
||||||
|
* @param handle A pointer to moal_handle structure
|
||||||
|
* @param enable enable/disable
|
||||||
|
*
|
||||||
|
* @return MLAN_STATUS_SUCCESS/MLAN_STATUS_PENDING -- success,
|
||||||
|
* otherwise fail
|
||||||
|
*/
|
||||||
|
mlan_status woal_set_auto_arp_ext(moal_handle *handle, t_u8 enable)
|
||||||
|
{
|
||||||
|
mlan_status ret = MLAN_STATUS_SUCCESS;
|
||||||
|
int i = 0, ip_addr_num = 0;
|
||||||
|
moal_private *priv = NULL;
|
||||||
|
mlan_ds_misc_cfg *misc = NULL;
|
||||||
|
mlan_ioctl_req *req = NULL;
|
||||||
|
mlan_ds_misc_mef_flt_cfg *mef_cfg = NULL;
|
||||||
|
mef_entry_t *entry = NULL;
|
||||||
|
mef_filter_t *filter = NULL;
|
||||||
|
t_u8 ip_addr[MAX_IPADDR][IPADDR_LEN];
|
||||||
|
|
||||||
|
ENTER();
|
||||||
|
|
||||||
|
memset(&mef_cfg, 0, sizeof(mef_cfg));
|
||||||
|
for (i = 0; i < handle->priv_num && (priv = handle->priv[i]); i++) {
|
||||||
|
if (priv && priv->ip_addr_type != IPADDR_TYPE_NONE) {
|
||||||
|
moal_memcpy_ext(handle, ip_addr[ip_addr_num],
|
||||||
|
priv->ip_addr, IPADDR_LEN, IPADDR_LEN);
|
||||||
|
ip_addr_num++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (ip_addr_num == 0) {
|
||||||
|
PRINTM(MIOCTL, "No IP addr configured.\n");
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
|
||||||
|
req = woal_alloc_mlan_ioctl_req(sizeof(mlan_ds_misc_cfg));
|
||||||
|
if (req == NULL) {
|
||||||
|
PRINTM(MIOCTL, "IOCTL req allocated failed!\n");
|
||||||
|
ret = MLAN_STATUS_FAILURE;
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
misc = (mlan_ds_misc_cfg *)req->pbuf;
|
||||||
|
misc->sub_command = MLAN_OID_MISC_MEF_FLT_CFG;
|
||||||
|
req->req_id = MLAN_IOCTL_MISC_CFG;
|
||||||
|
req->action = MLAN_ACT_SET;
|
||||||
|
|
||||||
|
mef_cfg = (mlan_ds_misc_mef_flt_cfg *)(&(misc->param.mef_flt_cfg));
|
||||||
|
mef_cfg->mef_act_type = MEF_ACT_AUTOARP;
|
||||||
|
mef_cfg->criteria = (MBIT(0) | MBIT(1));
|
||||||
|
|
||||||
|
entry = (mef_entry_t *)&mef_cfg->mef_entry;
|
||||||
|
entry->mode = MBIT(0);
|
||||||
|
entry->action = 0x10;
|
||||||
|
|
||||||
|
filter = (mef_filter_t *)(entry->filter_item);
|
||||||
|
filter->fill_flag = (FILLING_TYPE | FILLING_REPEAT | FILLING_OFFSET |
|
||||||
|
FILLING_BYTE_SEQ);
|
||||||
|
filter->type = TYPE_BYTE_EQ;
|
||||||
|
filter->repeat = 1;
|
||||||
|
filter->offset = 20;
|
||||||
|
filter->num_byte_seq = 2;
|
||||||
|
moal_memcpy_ext(handle, filter->byte_seq, "\x08\x06", 2,
|
||||||
|
sizeof(filter->byte_seq));
|
||||||
|
entry->rpn[1] = RPN_TYPE_AND;
|
||||||
|
|
||||||
|
for (i = 0; i < ip_addr_num; i++) {
|
||||||
|
filter++;
|
||||||
|
filter->fill_flag = (FILLING_TYPE | FILLING_REPEAT |
|
||||||
|
FILLING_OFFSET | FILLING_BYTE_SEQ);
|
||||||
|
filter->type = TYPE_BYTE_EQ;
|
||||||
|
filter->repeat = 1;
|
||||||
|
filter->offset = 46;
|
||||||
|
filter->num_byte_seq = 4;
|
||||||
|
moal_memcpy_ext(handle, filter->byte_seq, &ip_addr[i],
|
||||||
|
sizeof(t_u32), sizeof(filter->byte_seq));
|
||||||
|
if (i > 1)
|
||||||
|
entry->rpn[i] = RPN_TYPE_OR;
|
||||||
|
}
|
||||||
|
entry->filter_num = ip_addr_num + 1;
|
||||||
|
|
||||||
|
if (enable)
|
||||||
|
mef_cfg->op_code = MLAN_IPADDR_OP_ARP_FILTER |
|
||||||
|
MLAN_IPADDR_OP_AUTO_ARP_RESP;
|
||||||
|
else
|
||||||
|
/** remove ip */
|
||||||
|
mef_cfg->op_code = MLAN_IPADDR_OP_IP_REMOVE;
|
||||||
|
ret = woal_request_ioctl(woal_get_priv(handle, MLAN_BSS_ROLE_ANY), req,
|
||||||
|
MOAL_NO_WAIT);
|
||||||
|
if (ret != MLAN_STATUS_SUCCESS && ret != MLAN_STATUS_PENDING)
|
||||||
|
PRINTM(MIOCTL, "Set auto arp IOCTL failed!\n");
|
||||||
|
done:
|
||||||
|
if (ret != MLAN_STATUS_PENDING)
|
||||||
|
kfree(req);
|
||||||
|
LEAVE();
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Set/Get DTIM period
|
* @brief Set/Get DTIM period
|
||||||
*
|
*
|
||||||
|
@ -2952,6 +3247,22 @@ mlan_status woal_cancel_hs(moal_private *priv, t_u8 wait_option)
|
||||||
hscfg.is_invoke_hostcmd = MTRUE;
|
hscfg.is_invoke_hostcmd = MTRUE;
|
||||||
ret = woal_set_get_hs_params(priv, MLAN_ACT_SET, wait_option, &hscfg);
|
ret = woal_set_get_hs_params(priv, MLAN_ACT_SET, wait_option, &hscfg);
|
||||||
|
|
||||||
|
#if IS_ENABLED(CONFIG_IPV6)
|
||||||
|
if (priv->phandle->hs_auto_arp) {
|
||||||
|
PRINTM(MIOCTL, "Canecl Host Sleep... remove ipv6 offload\n");
|
||||||
|
/** Set ipv6 router advertisement message offload */
|
||||||
|
woal_set_ipv6_ra_offload(priv->phandle, MFALSE);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
if (priv->phandle->hs_auto_arp) {
|
||||||
|
PRINTM(MIOCTL, "Cancel Host Sleep... remove FW auto arp\n");
|
||||||
|
/* remove auto arp from FW */
|
||||||
|
woal_set_auto_arp(priv->phandle, MFALSE);
|
||||||
|
/* remove auto arp from FW */
|
||||||
|
woal_set_auto_arp_ext(priv->phandle, MFALSE);
|
||||||
|
}
|
||||||
|
|
||||||
#ifdef STA_CFG80211
|
#ifdef STA_CFG80211
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 1, 0)
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 1, 0)
|
||||||
handle = priv->phandle;
|
handle = priv->phandle;
|
||||||
|
@ -3062,6 +3373,24 @@ int woal_enable_hs(moal_private *priv)
|
||||||
woal_reconfig_bgscan(priv->phandle);
|
woal_reconfig_bgscan(priv->phandle);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if IS_ENABLED(CONFIG_IPV6)
|
||||||
|
if (handle->hs_auto_arp) {
|
||||||
|
PRINTM(MIOCTL, "Host Sleep enabled... set ipv6 offload\n");
|
||||||
|
/** Set ipv6 router advertisement message offload */
|
||||||
|
woal_set_ipv6_ra_offload(handle, MTRUE);
|
||||||
|
/** Set Neighbor Solitation message offload */
|
||||||
|
woal_set_ipv6_ns_offload(handle);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
if (handle->hs_auto_arp) {
|
||||||
|
PRINTM(MIOCTL, "Host Sleep enabled... set FW auto arp\n");
|
||||||
|
/* Set auto arp response configuration to Fw */
|
||||||
|
woal_set_auto_arp(handle, MTRUE);
|
||||||
|
/* Set auto arp response configuration to Fw */
|
||||||
|
woal_set_auto_arp_ext(handle, MTRUE);
|
||||||
|
}
|
||||||
|
|
||||||
#ifdef STA_CFG80211
|
#ifdef STA_CFG80211
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 1, 0)
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 1, 0)
|
||||||
if (GTK_REKEY_OFFLOAD_SUSPEND == handle->params.gtk_rekey_offload) {
|
if (GTK_REKEY_OFFLOAD_SUSPEND == handle->params.gtk_rekey_offload) {
|
||||||
|
|
File diff suppressed because it is too large
Load diff
|
@ -697,6 +697,8 @@ out:
|
||||||
#define NUM_TX_TIMEOUT_THRESHOLD 10
|
#define NUM_TX_TIMEOUT_THRESHOLD 10
|
||||||
/** Custom event : DRIVER HANG */
|
/** Custom event : DRIVER HANG */
|
||||||
#define CUS_EVT_DRIVER_HANG "EVENT=DRIVER_HANG"
|
#define CUS_EVT_DRIVER_HANG "EVENT=DRIVER_HANG"
|
||||||
|
/** Custom event : FW_DUMP */
|
||||||
|
#define CUS_EVT_FW_DUMP "EVENT=FW_DUMP"
|
||||||
|
|
||||||
/** TDLS connected event */
|
/** TDLS connected event */
|
||||||
#define CUS_EVT_TDLS_CONNECTED "EVENT=TDLS_CONNECTED"
|
#define CUS_EVT_TDLS_CONNECTED "EVENT=TDLS_CONNECTED"
|
||||||
|
@ -786,6 +788,8 @@ typedef enum {
|
||||||
/** Custom indiciation message sent to the application layer for WMM changes */
|
/** Custom indiciation message sent to the application layer for WMM changes */
|
||||||
#define WMM_CONFIG_CHANGE_INDICATION "WMM_CONFIG_CHANGE.indication"
|
#define WMM_CONFIG_CHANGE_INDICATION "WMM_CONFIG_CHANGE.indication"
|
||||||
|
|
||||||
|
#define CUS_EVT_FW_DUMP_DONE "EVENT=FW_DUMP_DONE"
|
||||||
|
|
||||||
#ifdef UAP_SUPPORT
|
#ifdef UAP_SUPPORT
|
||||||
/** Custom event : STA connected */
|
/** Custom event : STA connected */
|
||||||
#define CUS_EVT_STA_CONNECTED "EVENT=STA_CONNECTED"
|
#define CUS_EVT_STA_CONNECTED "EVENT=STA_CONNECTED"
|
||||||
|
@ -831,9 +835,9 @@ typedef enum {
|
||||||
#define MAX_RX_PENDING_THRHLD 50
|
#define MAX_RX_PENDING_THRHLD 50
|
||||||
|
|
||||||
/** high rx pending packets */
|
/** high rx pending packets */
|
||||||
#define HIGH_RX_PENDING 100
|
#define USB_HIGH_RX_PENDING 100
|
||||||
/** low rx pending packets */
|
/** low rx pending packets */
|
||||||
#define LOW_RX_PENDING 80
|
#define USB_LOW_RX_PENDING 80
|
||||||
|
|
||||||
/** MAX Tx Pending count */
|
/** MAX Tx Pending count */
|
||||||
#define MAX_TX_PENDING 800
|
#define MAX_TX_PENDING 800
|
||||||
|
@ -937,6 +941,11 @@ typedef struct _wait_queue {
|
||||||
#define MAX_UAP_BSS 1
|
#define MAX_UAP_BSS 1
|
||||||
/** Default uAP BSS */
|
/** Default uAP BSS */
|
||||||
#define DEF_UAP_BSS 1
|
#define DEF_UAP_BSS 1
|
||||||
|
|
||||||
|
/** WACP Modes for uAP */
|
||||||
|
#define WACP_MODE_DEFAULT 0
|
||||||
|
#define WACP_MODE_1 1
|
||||||
|
#define WACP_MODE_2 2
|
||||||
#endif
|
#endif
|
||||||
#ifdef WIFI_DIRECT_SUPPORT
|
#ifdef WIFI_DIRECT_SUPPORT
|
||||||
/** Driver mode WIFIDIRECT bit */
|
/** Driver mode WIFIDIRECT bit */
|
||||||
|
@ -1266,12 +1275,14 @@ struct _moal_private {
|
||||||
BOOLEAN media_connected;
|
BOOLEAN media_connected;
|
||||||
/** mclist work queue */
|
/** mclist work queue */
|
||||||
struct workqueue_struct *mclist_workqueue;
|
struct workqueue_struct *mclist_workqueue;
|
||||||
/** csa work */
|
/** mclist work */
|
||||||
struct work_struct mclist_work;
|
struct work_struct mclist_work;
|
||||||
/** Statistics of tcp ack tx dropped */
|
/** Statistics of tcp ack tx dropped */
|
||||||
t_u32 tcp_ack_drop_cnt;
|
t_u32 tcp_ack_drop_cnt;
|
||||||
/** Statistics of tcp ack tx in total from kernel */
|
/** Statistics of tcp ack tx in total from kernel */
|
||||||
t_u32 tcp_ack_cnt;
|
t_u32 tcp_ack_cnt;
|
||||||
|
/** Statistics of tcp ack with payload*/
|
||||||
|
t_u32 tcp_ack_payload;
|
||||||
#ifdef UAP_SUPPORT
|
#ifdef UAP_SUPPORT
|
||||||
/** uAP started or not */
|
/** uAP started or not */
|
||||||
BOOLEAN bss_started;
|
BOOLEAN bss_started;
|
||||||
|
@ -1302,6 +1313,12 @@ struct _moal_private {
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
/** IP addr type */
|
||||||
|
t_u32 ip_addr_type;
|
||||||
|
/** IP addr */
|
||||||
|
t_u8 ip_addr[IPADDR_LEN];
|
||||||
|
t_u8 ipv6_addr_configured;
|
||||||
|
t_u8 ipv6_addr[16];
|
||||||
#ifdef STA_SUPPORT
|
#ifdef STA_SUPPORT
|
||||||
/** scan type */
|
/** scan type */
|
||||||
t_u8 scan_type;
|
t_u8 scan_type;
|
||||||
|
@ -1315,6 +1332,10 @@ struct _moal_private {
|
||||||
wlan_bgscan_cfg scan_cfg;
|
wlan_bgscan_cfg scan_cfg;
|
||||||
/** sched scaning flag */
|
/** sched scaning flag */
|
||||||
t_u8 sched_scanning;
|
t_u8 sched_scanning;
|
||||||
|
/** sched_scan work queue */
|
||||||
|
struct workqueue_struct *sched_scan_workqueue;
|
||||||
|
/** sched_scan work */
|
||||||
|
struct delayed_work sched_scan_work;
|
||||||
/** bgscan request id */
|
/** bgscan request id */
|
||||||
t_u64 bg_scan_reqid;
|
t_u64 bg_scan_reqid;
|
||||||
#ifdef STA_CFG80211
|
#ifdef STA_CFG80211
|
||||||
|
@ -1694,6 +1715,7 @@ enum ext_mod_params {
|
||||||
EXT_TX_WORK,
|
EXT_TX_WORK,
|
||||||
EXT_RPS,
|
EXT_RPS,
|
||||||
EXT_TX_SKB_CLONE,
|
EXT_TX_SKB_CLONE,
|
||||||
|
EXT_PMQOS,
|
||||||
EXT_MAX_PARAM,
|
EXT_MAX_PARAM,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -1717,6 +1739,7 @@ typedef struct _moal_mod_para {
|
||||||
int max_uap_bss;
|
int max_uap_bss;
|
||||||
char *uap_name;
|
char *uap_name;
|
||||||
int uap_max_sta;
|
int uap_max_sta;
|
||||||
|
int wacp_mode;
|
||||||
#endif /* UAP_SUPPORT */
|
#endif /* UAP_SUPPORT */
|
||||||
#ifdef WIFI_DIRECT_SUPPORT
|
#ifdef WIFI_DIRECT_SUPPORT
|
||||||
int max_wfd_bss;
|
int max_wfd_bss;
|
||||||
|
@ -1726,10 +1749,13 @@ typedef struct _moal_mod_para {
|
||||||
#endif
|
#endif
|
||||||
#endif /* WIFI_DIRECT_SUPPORT */
|
#endif /* WIFI_DIRECT_SUPPORT */
|
||||||
int auto_ds;
|
int auto_ds;
|
||||||
|
int net_rx;
|
||||||
|
int ext_scan;
|
||||||
int ps_mode;
|
int ps_mode;
|
||||||
int p2a_scan;
|
int p2a_scan;
|
||||||
/** scan chan gap */
|
/** scan chan gap */
|
||||||
int scan_chan_gap;
|
int scan_chan_gap;
|
||||||
|
int sched_scan;
|
||||||
int max_tx_buf;
|
int max_tx_buf;
|
||||||
#if defined(SDIO)
|
#if defined(SDIO)
|
||||||
int gpiopin;
|
int gpiopin;
|
||||||
|
@ -1790,7 +1816,7 @@ void woal_set_tp_state(moal_private *priv);
|
||||||
#define RX_DROP_P3 (MAX_TP_ACCOUNT_DROP_POINT_NUM + 2)
|
#define RX_DROP_P3 (MAX_TP_ACCOUNT_DROP_POINT_NUM + 2)
|
||||||
#define RX_DROP_P4 (MAX_TP_ACCOUNT_DROP_POINT_NUM + 3)
|
#define RX_DROP_P4 (MAX_TP_ACCOUNT_DROP_POINT_NUM + 3)
|
||||||
#define RX_DROP_P5 (MAX_TP_ACCOUNT_DROP_POINT_NUM + 4)
|
#define RX_DROP_P5 (MAX_TP_ACCOUNT_DROP_POINT_NUM + 4)
|
||||||
#define TXRX_MAX_SAMPLE 100
|
#define TXRX_MAX_SAMPLE 60
|
||||||
#define RX_TIME_PKT (MAX_TP_ACCOUNT_DROP_POINT_NUM + 5)
|
#define RX_TIME_PKT (MAX_TP_ACCOUNT_DROP_POINT_NUM + 5)
|
||||||
#define TX_TIME_PKT (MAX_TP_ACCOUNT_DROP_POINT_NUM + 6)
|
#define TX_TIME_PKT (MAX_TP_ACCOUNT_DROP_POINT_NUM + 6)
|
||||||
|
|
||||||
|
@ -1838,6 +1864,9 @@ typedef struct _moal_tp_acnt_t {
|
||||||
unsigned long rx_delay1_driver[TXRX_MAX_SAMPLE];
|
unsigned long rx_delay1_driver[TXRX_MAX_SAMPLE];
|
||||||
unsigned long rx_delay2_driver[TXRX_MAX_SAMPLE];
|
unsigned long rx_delay2_driver[TXRX_MAX_SAMPLE];
|
||||||
unsigned long rx_delay_kernel[TXRX_MAX_SAMPLE];
|
unsigned long rx_delay_kernel[TXRX_MAX_SAMPLE];
|
||||||
|
unsigned long rx_amsdu_delay[TXRX_MAX_SAMPLE];
|
||||||
|
unsigned long rx_amsdu_copy_delay[TXRX_MAX_SAMPLE];
|
||||||
|
t_u8 rx_amsdu_index;
|
||||||
t_u8 rx_index;
|
t_u8 rx_index;
|
||||||
t_u8 tx_index;
|
t_u8 tx_index;
|
||||||
/* TP account mode 0-disable 1-enable */
|
/* TP account mode 0-disable 1-enable */
|
||||||
|
@ -2126,14 +2155,25 @@ struct _moal_handle {
|
||||||
t_u8 driver_state;
|
t_u8 driver_state;
|
||||||
/** ioctl timeout */
|
/** ioctl timeout */
|
||||||
t_u8 ioctl_timeout;
|
t_u8 ioctl_timeout;
|
||||||
|
/** Pointer of fw dump buffer */
|
||||||
|
t_u8 *drv_dump_buf;
|
||||||
|
/** drv dump len */
|
||||||
|
t_u32 drv_dump_len;
|
||||||
/** FW dump state */
|
/** FW dump state */
|
||||||
t_u8 fw_dump;
|
t_u8 fw_dump;
|
||||||
/** event fw dump */
|
/** event fw dump */
|
||||||
t_u8 event_fw_dump;
|
t_u8 event_fw_dump;
|
||||||
|
/** Re-association timer set flag */
|
||||||
|
BOOLEAN is_fw_dump_timer_set;
|
||||||
|
/** Re-association timer */
|
||||||
|
moal_drv_timer fw_dump_timer __ATTRIB_ALIGN__;
|
||||||
/** fw dump buffer total len */
|
/** fw dump buffer total len */
|
||||||
t_u64 fw_dump_len;
|
t_u64 fw_dump_len;
|
||||||
|
/** Pointer of fw dump buffer */
|
||||||
|
t_u8 *fw_dump_buf;
|
||||||
/** FW dump full name */
|
/** FW dump full name */
|
||||||
t_u8 firmware_dump_file[128];
|
t_u8 firmware_dump_file[128];
|
||||||
|
|
||||||
#ifdef SDIO
|
#ifdef SDIO
|
||||||
/** cmd52 function */
|
/** cmd52 function */
|
||||||
t_u8 cmd52_func;
|
t_u8 cmd52_func;
|
||||||
|
@ -2170,6 +2210,9 @@ struct _moal_handle {
|
||||||
/* feature_control */
|
/* feature_control */
|
||||||
t_u32 feature_control;
|
t_u32 feature_control;
|
||||||
struct notifier_block woal_notifier;
|
struct notifier_block woal_notifier;
|
||||||
|
#if IS_ENABLED(CONFIG_IPV6)
|
||||||
|
struct notifier_block woal_inet6_notifier;
|
||||||
|
#endif
|
||||||
mlan_ds_misc_keep_alive keep_alive[MAX_KEEP_ALIVE_ID];
|
mlan_ds_misc_keep_alive keep_alive[MAX_KEEP_ALIVE_ID];
|
||||||
struct net_device napi_dev;
|
struct net_device napi_dev;
|
||||||
struct napi_struct napi_rx;
|
struct napi_struct napi_rx;
|
||||||
|
@ -2809,6 +2852,7 @@ mlan_status woal_init_sw(moal_handle *handle);
|
||||||
void woal_update_firmware_name(moal_handle *handle);
|
void woal_update_firmware_name(moal_handle *handle);
|
||||||
/** cancel all works in the queue */
|
/** cancel all works in the queue */
|
||||||
void woal_terminate_workqueue(moal_handle *handle);
|
void woal_terminate_workqueue(moal_handle *handle);
|
||||||
|
void woal_flush_workqueue(moal_handle *handle);
|
||||||
/** initializes firmware */
|
/** initializes firmware */
|
||||||
mlan_status woal_init_fw(moal_handle *handle);
|
mlan_status woal_init_fw(moal_handle *handle);
|
||||||
/** frees the structure of moal_handle */
|
/** frees the structure of moal_handle */
|
||||||
|
@ -2932,12 +2976,24 @@ int woal_enable_hs(moal_private *priv);
|
||||||
/** Get wakeup reason */
|
/** Get wakeup reason */
|
||||||
mlan_status woal_get_wakeup_reason(moal_private *priv,
|
mlan_status woal_get_wakeup_reason(moal_private *priv,
|
||||||
mlan_ds_hs_wakeup_reason *wakeup_reason);
|
mlan_ds_hs_wakeup_reason *wakeup_reason);
|
||||||
#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 1, 0)
|
#define FW_DUMP_INFO_LEN 0x280000
|
||||||
void woal_create_dump_dir(moal_handle *phandle, char *dir_buf, int buf_size);
|
/** mem dump header */
|
||||||
#endif
|
typedef struct {
|
||||||
mlan_status woal_save_dump_info_to_file(char *dir_name, char *file_name,
|
/** seq number */
|
||||||
t_u8 *buf, t_u32 buf_len);
|
t_u16 seq_num;
|
||||||
void woal_dump_drv_info(moal_handle *phandle, t_u8 *dir_name);
|
/** resvered */
|
||||||
|
t_u16 reserved;
|
||||||
|
/** type */
|
||||||
|
t_u16 type;
|
||||||
|
/** len */
|
||||||
|
t_u16 len;
|
||||||
|
/** start addr */
|
||||||
|
t_u32 start_addr;
|
||||||
|
} mem_dump_header;
|
||||||
|
int woal_save_dump_info_to_buf(moal_handle *phandle, t_u8 *src, t_u32 len,
|
||||||
|
t_u32 type);
|
||||||
|
void woal_append_end_block(moal_handle *phandle);
|
||||||
|
t_u8 *woal_dump_drv_info(moal_handle *phandle, t_u32 *dump_len);
|
||||||
|
|
||||||
#define FW_DUMP_TYPE_ENDED 0x002
|
#define FW_DUMP_TYPE_ENDED 0x002
|
||||||
#define FW_DUMP_TYPE_MEM_ITCM 0x004
|
#define FW_DUMP_TYPE_MEM_ITCM 0x004
|
||||||
|
@ -2955,13 +3011,8 @@ void woal_dump_firmware_info_v3(moal_handle *phandle);
|
||||||
#endif /* SDIO_MMC */
|
#endif /* SDIO_MMC */
|
||||||
/* Store the FW dumps received from events in a file */
|
/* Store the FW dumps received from events in a file */
|
||||||
void woal_store_firmware_dump(moal_handle *phandle, pmlan_event pmevent);
|
void woal_store_firmware_dump(moal_handle *phandle, pmlan_event pmevent);
|
||||||
|
void woal_send_fw_dump_complete_event(moal_private *priv);
|
||||||
|
|
||||||
#if defined(PCIE)
|
|
||||||
void woal_store_ssu_dump(moal_handle *phandle, pmlan_event pmevent);
|
|
||||||
#endif /* SSU_SUPPORT */
|
|
||||||
|
|
||||||
/** save hostcmd response to file */
|
|
||||||
t_void woal_save_host_cmdresp(moal_handle *phandle, mlan_cmdresp_event *pevent);
|
|
||||||
int woal_pre_warmreset(moal_private *priv);
|
int woal_pre_warmreset(moal_private *priv);
|
||||||
int woal_warmreset(moal_private *priv);
|
int woal_warmreset(moal_private *priv);
|
||||||
|
|
||||||
|
@ -3180,6 +3231,8 @@ int woal_reassociation_thread(void *data);
|
||||||
void woal_reassoc_timer_func(void *context);
|
void woal_reassoc_timer_func(void *context);
|
||||||
#endif /* REASSOCIATION */
|
#endif /* REASSOCIATION */
|
||||||
|
|
||||||
|
void woal_fw_dump_timer_func(void *context);
|
||||||
|
|
||||||
t_void woal_main_work_queue(struct work_struct *work);
|
t_void woal_main_work_queue(struct work_struct *work);
|
||||||
t_void woal_rx_work_queue(struct work_struct *work);
|
t_void woal_rx_work_queue(struct work_struct *work);
|
||||||
t_void woal_evt_work_queue(struct work_struct *work);
|
t_void woal_evt_work_queue(struct work_struct *work);
|
||||||
|
@ -3287,6 +3340,7 @@ void woal_hist_data_add(moal_private *priv, t_u16 rx_rate, t_s8 snr, t_s8 nflr,
|
||||||
t_u8 antenna);
|
t_u8 antenna);
|
||||||
mlan_status woal_set_hotspotcfg(moal_private *priv, t_u8 wait_option,
|
mlan_status woal_set_hotspotcfg(moal_private *priv, t_u8 wait_option,
|
||||||
t_u32 hotspotcfg);
|
t_u32 hotspotcfg);
|
||||||
|
|
||||||
mlan_status woal_set_get_wowlan_config(moal_private *priv, t_u16 action,
|
mlan_status woal_set_get_wowlan_config(moal_private *priv, t_u16 action,
|
||||||
t_u8 wait_option,
|
t_u8 wait_option,
|
||||||
mlan_ds_misc_mef_flt_cfg *mefcfg);
|
mlan_ds_misc_mef_flt_cfg *mefcfg);
|
||||||
|
@ -3308,8 +3362,15 @@ int woal_priv_save_cloud_keep_alive_params(
|
||||||
moal_private *priv, t_u8 mkeep_alive_id, t_u8 enable, t_u16 ether_type,
|
moal_private *priv, t_u8 mkeep_alive_id, t_u8 enable, t_u16 ether_type,
|
||||||
t_u8 *ip_pkt, t_u16 ip_pkt_len, t_u8 *src_mac, t_u8 *dst_mac,
|
t_u8 *ip_pkt, t_u16 ip_pkt_len, t_u8 *src_mac, t_u8 *dst_mac,
|
||||||
t_u32 period_msec, t_u32 retry_interval, t_u8 retry_cnt);
|
t_u32 period_msec, t_u32 retry_interval, t_u8 retry_cnt);
|
||||||
|
#ifdef UAP_SUPPORT
|
||||||
|
mlan_status woal_set_wacp_mode(moal_private *priv, t_u8 wait_option);
|
||||||
|
#endif
|
||||||
mlan_status woal_init_aggr_ctrl(moal_handle *handle, t_u8 wait_option);
|
mlan_status woal_init_aggr_ctrl(moal_handle *handle, t_u8 wait_option);
|
||||||
|
|
||||||
|
#if defined(STA_CFG80211) || defined(UAP_CFG80211)
|
||||||
|
void woal_cfg80211_vendor_event_fw_dump(moal_private *priv);
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef STA_CFG80211
|
#ifdef STA_CFG80211
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 1, 0)
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 1, 0)
|
||||||
mlan_status woal_set_rekey_data(moal_private *priv,
|
mlan_status woal_set_rekey_data(moal_private *priv,
|
||||||
|
|
|
@ -36,6 +36,10 @@ Change log:
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if IS_ENABLED(CONFIG_IPV6)
|
||||||
|
#include <net/addrconf.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
/********************************************************
|
/********************************************************
|
||||||
Local Variables
|
Local Variables
|
||||||
********************************************************/
|
********************************************************/
|
||||||
|
@ -266,6 +270,11 @@ static mlan_status woal_do_flr(moal_handle *handle, bool prepare, bool flr_flag)
|
||||||
atomic_read(&handle->ioctl_pending));
|
atomic_read(&handle->ioctl_pending));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
unregister_inetaddr_notifier(&handle->woal_notifier);
|
||||||
|
#if IS_ENABLED(CONFIG_IPV6)
|
||||||
|
unregister_inet6addr_notifier(&handle->woal_inet6_notifier);
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Remove interface */
|
/* Remove interface */
|
||||||
for (i = 0; i < handle->priv_num; i++)
|
for (i = 0; i < handle->priv_num; i++)
|
||||||
woal_remove_interface(handle, i);
|
woal_remove_interface(handle, i);
|
||||||
|
@ -582,12 +591,7 @@ static int woal_pcie_suspend(struct pci_dev *pdev, pm_message_t state)
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
flush_workqueue(handle->workqueue);
|
woal_flush_workqueue(handle);
|
||||||
flush_workqueue(handle->evt_workqueue);
|
|
||||||
if (handle->rx_workqueue)
|
|
||||||
flush_workqueue(handle->rx_workqueue);
|
|
||||||
if (handle->tx_workqueue)
|
|
||||||
flush_workqueue(handle->tx_workqueue);
|
|
||||||
if (!keep_power) {
|
if (!keep_power) {
|
||||||
woal_do_flr(handle, true, false);
|
woal_do_flr(handle, true, false);
|
||||||
handle->surprise_removed = MTRUE;
|
handle->surprise_removed = MTRUE;
|
||||||
|
@ -1906,8 +1910,8 @@ static void woal_pcie_dump_fw_info_v1(moal_handle *phandle)
|
||||||
rdwr_status stat;
|
rdwr_status stat;
|
||||||
t_u8 i = 0;
|
t_u8 i = 0;
|
||||||
t_u8 read_reg = 0;
|
t_u8 read_reg = 0;
|
||||||
t_u32 memory_size = 0, DEBUG_MEMDUMP_FINISH;
|
t_u32 memory_size = 0;
|
||||||
t_u8 path_name[64], file_name[32], firmware_dump_file[128];
|
t_u32 memdump_finsh = 0;
|
||||||
t_u8 *end_ptr = NULL;
|
t_u8 *end_ptr = NULL;
|
||||||
memory_type_mapping *mem_type_mapping_tbl = mem_type_mapping_tbl_8897;
|
memory_type_mapping *mem_type_mapping_tbl = mem_type_mapping_tbl_8897;
|
||||||
|
|
||||||
|
@ -1915,16 +1919,17 @@ static void woal_pcie_dump_fw_info_v1(moal_handle *phandle)
|
||||||
PRINTM(MERROR, "Could not dump firmwware info\n");
|
PRINTM(MERROR, "Could not dump firmwware info\n");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
DEBUG_MEMDUMP_FINISH = DEBUG_MEMDUMP_FINISH_8897;
|
if (!phandle->fw_dump_buf) {
|
||||||
#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 1, 0)
|
ret = moal_vmalloc(phandle, FW_DUMP_INFO_LEN,
|
||||||
/** Create dump directory*/
|
&(phandle->fw_dump_buf));
|
||||||
woal_create_dump_dir(phandle, path_name, sizeof(path_name));
|
if (ret != MLAN_STATUS_SUCCESS || !phandle->fw_dump_buf) {
|
||||||
#else
|
PRINTM(MERROR, "Failed to vmalloc fw dump bufffer\n");
|
||||||
memset(path_name, 0, sizeof(path_name));
|
return;
|
||||||
strcpy(path_name, "/data");
|
}
|
||||||
#endif
|
} else {
|
||||||
PRINTM(MMSG, "Directory name is %s\n", path_name);
|
memset(phandle->fw_dump_buf, 0x00, FW_DUMP_INFO_LEN);
|
||||||
woal_dump_drv_info(phandle, path_name);
|
}
|
||||||
|
phandle->fw_dump_len = 0;
|
||||||
/* start dump fw memory */
|
/* start dump fw memory */
|
||||||
moal_get_system_time(phandle, &sec, &usec);
|
moal_get_system_time(phandle, &sec, &usec);
|
||||||
PRINTM(MMSG, "====PCIE DEBUG MODE OUTPUT START: %u.%06u ====\n", sec,
|
PRINTM(MMSG, "====PCIE DEBUG MODE OUTPUT START: %u.%06u ====\n", sec,
|
||||||
|
@ -1960,7 +1965,7 @@ static void woal_pcie_dump_fw_info_v1(moal_handle *phandle)
|
||||||
if (memory_size == 0) {
|
if (memory_size == 0) {
|
||||||
PRINTM(MMSG, "Firmware Dump Finished!\n");
|
PRINTM(MMSG, "Firmware Dump Finished!\n");
|
||||||
ret = woal_pcie_write_reg(phandle, DEBUG_DUMP_CTRL_REG,
|
ret = woal_pcie_write_reg(phandle, DEBUG_DUMP_CTRL_REG,
|
||||||
DEBUG_MEMDUMP_FINISH);
|
memdump_finsh);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
PRINTM(MERROR,
|
PRINTM(MERROR,
|
||||||
"PCIE Write MEMDUMP_FINISH ERR\n");
|
"PCIE Write MEMDUMP_FINISH ERR\n");
|
||||||
|
@ -2013,17 +2018,11 @@ static void woal_pcie_dump_fw_info_v1(moal_handle *phandle)
|
||||||
(unsigned int)(dbg_ptr -
|
(unsigned int)(dbg_ptr -
|
||||||
mem_type_mapping_tbl[idx]
|
mem_type_mapping_tbl[idx]
|
||||||
.mem_Ptr));
|
.mem_Ptr));
|
||||||
memset(file_name, 0, sizeof(file_name));
|
woal_save_dump_info_to_buf(
|
||||||
sprintf(file_name, "%s%s", "file_pcie_",
|
phandle,
|
||||||
mem_type_mapping_tbl[idx].mem_name);
|
|
||||||
if (MLAN_STATUS_SUCCESS !=
|
|
||||||
woal_save_dump_info_to_file(
|
|
||||||
path_name, file_name,
|
|
||||||
mem_type_mapping_tbl[idx].mem_Ptr,
|
mem_type_mapping_tbl[idx].mem_Ptr,
|
||||||
memory_size))
|
memory_size,
|
||||||
PRINTM(MMSG,
|
mem_type_mapping_tbl[idx].type);
|
||||||
"Can't save dump file %s in %s\n",
|
|
||||||
file_name, path_name);
|
|
||||||
moal_vfree(phandle,
|
moal_vfree(phandle,
|
||||||
mem_type_mapping_tbl[idx].mem_Ptr);
|
mem_type_mapping_tbl[idx].mem_Ptr);
|
||||||
mem_type_mapping_tbl[idx].mem_Ptr = NULL;
|
mem_type_mapping_tbl[idx].mem_Ptr = NULL;
|
||||||
|
@ -2031,15 +2030,11 @@ static void woal_pcie_dump_fw_info_v1(moal_handle *phandle)
|
||||||
}
|
}
|
||||||
} while (1);
|
} while (1);
|
||||||
}
|
}
|
||||||
|
woal_append_end_block(phandle);
|
||||||
moal_get_system_time(phandle, &sec, &usec);
|
moal_get_system_time(phandle, &sec, &usec);
|
||||||
PRINTM(MMSG, "====PCIE DEBUG MODE OUTPUT END: %u.%06u ====\n", sec,
|
PRINTM(MMSG, "====PCIE DEBUG MODE OUTPUT END: %u.%06u ====\n", sec,
|
||||||
usec);
|
usec);
|
||||||
/* end dump fw memory */
|
/* end dump fw memory */
|
||||||
memset(firmware_dump_file, 0, sizeof(firmware_dump_file));
|
|
||||||
sprintf(firmware_dump_file, "%s/%s", path_name, file_name);
|
|
||||||
moal_memcpy_ext(phandle, phandle->firmware_dump_file,
|
|
||||||
firmware_dump_file, sizeof(firmware_dump_file),
|
|
||||||
sizeof(phandle->firmware_dump_file));
|
|
||||||
done:
|
done:
|
||||||
for (idx = 0;
|
for (idx = 0;
|
||||||
idx < dump_num && idx < ARRAY_SIZE(mem_type_mapping_tbl_8897);
|
idx < dump_num && idx < ARRAY_SIZE(mem_type_mapping_tbl_8897);
|
||||||
|
@ -2073,8 +2068,6 @@ static void woal_pcie_dump_fw_info_v2(moal_handle *phandle)
|
||||||
t_u8 doneflag = 0;
|
t_u8 doneflag = 0;
|
||||||
rdwr_status stat;
|
rdwr_status stat;
|
||||||
t_u32 memory_size = 0;
|
t_u32 memory_size = 0;
|
||||||
t_u8 path_name[64], file_name[32], firmware_dump_file[128];
|
|
||||||
moal_handle *ref_handle;
|
|
||||||
t_u8 *end_ptr = NULL;
|
t_u8 *end_ptr = NULL;
|
||||||
memory_type_mapping *mem_type_mapping_tbl = &mem_type_mapping_tbl_8997;
|
memory_type_mapping *mem_type_mapping_tbl = &mem_type_mapping_tbl_8997;
|
||||||
t_u32 dump_start_reg = 0;
|
t_u32 dump_start_reg = 0;
|
||||||
|
@ -2097,18 +2090,6 @@ static void woal_pcie_dump_fw_info_v2(moal_handle *phandle)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 1, 0)
|
|
||||||
/** Create dump directory*/
|
|
||||||
woal_create_dump_dir(phandle, path_name, sizeof(path_name));
|
|
||||||
#else
|
|
||||||
memset(path_name, 0, sizeof(path_name));
|
|
||||||
strcpy(path_name, "/data");
|
|
||||||
#endif
|
|
||||||
PRINTM(MMSG, "Create DUMP directory success:dir_name=%s\n", path_name);
|
|
||||||
ref_handle = (moal_handle *)phandle->pref_mac;
|
|
||||||
if (ref_handle)
|
|
||||||
woal_dump_drv_info(ref_handle, path_name);
|
|
||||||
woal_dump_drv_info(phandle, path_name);
|
|
||||||
|
|
||||||
/* start dump fw memory */
|
/* start dump fw memory */
|
||||||
moal_get_system_time(phandle, &sec, &usec);
|
moal_get_system_time(phandle, &sec, &usec);
|
||||||
|
@ -2206,17 +2187,14 @@ static void woal_pcie_dump_fw_info_v2(moal_handle *phandle)
|
||||||
mem_type_mapping_tbl->mem_name,
|
mem_type_mapping_tbl->mem_name,
|
||||||
dbg_ptr - mem_type_mapping_tbl->mem_Ptr);
|
dbg_ptr - mem_type_mapping_tbl->mem_Ptr);
|
||||||
#endif
|
#endif
|
||||||
memset(file_name, 0, sizeof(file_name));
|
if (phandle->fw_dump_buf) {
|
||||||
sprintf(file_name, "%s%s", "file_pcie_",
|
moal_vfree(phandle, phandle->fw_dump_buf);
|
||||||
mem_type_mapping_tbl->mem_name);
|
phandle->fw_dump_buf = NULL;
|
||||||
if (MLAN_STATUS_SUCCESS !=
|
phandle->fw_dump_len = 0;
|
||||||
woal_save_dump_info_to_file(
|
}
|
||||||
path_name, file_name,
|
phandle->fw_dump_buf = mem_type_mapping_tbl->mem_Ptr;
|
||||||
mem_type_mapping_tbl->mem_Ptr,
|
phandle->fw_dump_len =
|
||||||
dbg_ptr - mem_type_mapping_tbl->mem_Ptr))
|
dbg_ptr - mem_type_mapping_tbl->mem_Ptr;
|
||||||
PRINTM(MMSG, "Can't save dump file %s in %s\n",
|
|
||||||
file_name, path_name);
|
|
||||||
moal_vfree(phandle, mem_type_mapping_tbl->mem_Ptr);
|
|
||||||
mem_type_mapping_tbl->mem_Ptr = NULL;
|
mem_type_mapping_tbl->mem_Ptr = NULL;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -2225,11 +2203,6 @@ static void woal_pcie_dump_fw_info_v2(moal_handle *phandle)
|
||||||
PRINTM(MMSG, "====PCIE DEBUG MODE OUTPUT END: %u.%06u ====\n", sec,
|
PRINTM(MMSG, "====PCIE DEBUG MODE OUTPUT END: %u.%06u ====\n", sec,
|
||||||
usec);
|
usec);
|
||||||
/* end dump fw memory */
|
/* end dump fw memory */
|
||||||
memset(firmware_dump_file, 0, sizeof(firmware_dump_file));
|
|
||||||
sprintf(firmware_dump_file, "%s/%s", path_name, file_name);
|
|
||||||
moal_memcpy_ext(phandle, phandle->firmware_dump_file,
|
|
||||||
firmware_dump_file, sizeof(firmware_dump_file),
|
|
||||||
sizeof(phandle->firmware_dump_file));
|
|
||||||
done:
|
done:
|
||||||
if (mem_type_mapping_tbl->mem_Ptr) {
|
if (mem_type_mapping_tbl->mem_Ptr) {
|
||||||
moal_vfree(phandle, mem_type_mapping_tbl->mem_Ptr);
|
moal_vfree(phandle, mem_type_mapping_tbl->mem_Ptr);
|
||||||
|
@ -2273,13 +2246,18 @@ static void woal_pcie_dump_fw_info(moal_handle *phandle)
|
||||||
if (phandle->event_fw_dump) {
|
if (phandle->event_fw_dump) {
|
||||||
phandle->event_fw_dump = MFALSE;
|
phandle->event_fw_dump = MFALSE;
|
||||||
queue_work(phandle->workqueue, &phandle->main_work);
|
queue_work(phandle->workqueue, &phandle->main_work);
|
||||||
|
phandle->is_fw_dump_timer_set = MTRUE;
|
||||||
|
woal_mod_timer(&phandle->fw_dump_timer, MOAL_TIMER_5S);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
woal_send_fw_dump_complete_event(
|
||||||
|
woal_get_priv(phandle, MLAN_BSS_ROLE_ANY));
|
||||||
phandle->fw_dump = MFALSE;
|
phandle->fw_dump = MFALSE;
|
||||||
mlan_pm_wakeup_card(phandle->pmlan_adapter, MFALSE);
|
mlan_pm_wakeup_card(phandle->pmlan_adapter, MFALSE);
|
||||||
queue_work(phandle->workqueue, &phandle->main_work);
|
queue_work(phandle->workqueue, &phandle->main_work);
|
||||||
|
woal_process_hang(phandle);
|
||||||
}
|
}
|
||||||
|
|
||||||
static mlan_status woal_pcie_get_fw_name(moal_handle *handle)
|
static mlan_status woal_pcie_get_fw_name(moal_handle *handle)
|
||||||
|
|
|
@ -803,7 +803,7 @@ static int woal_11n_prio_tbl(moal_private *priv, struct iwreq *wrq)
|
||||||
|
|
||||||
ENTER();
|
ENTER();
|
||||||
|
|
||||||
if ((wrq->u.data.pointer == NULL)) {
|
if (wrq->u.data.pointer == NULL) {
|
||||||
LEAVE();
|
LEAVE();
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
@ -3898,6 +3898,57 @@ done:
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief arpfilter ioctl function
|
||||||
|
*
|
||||||
|
* @param priv A pointer to moal_private structure
|
||||||
|
* @param wrq A pointer to iwreq structure
|
||||||
|
* @return 0 --success, otherwise fail
|
||||||
|
*/
|
||||||
|
static int woal_arp_filter(moal_private *priv, struct iwreq *wrq)
|
||||||
|
{
|
||||||
|
int ret = 0;
|
||||||
|
mlan_ds_misc_cfg *misc = NULL;
|
||||||
|
mlan_ioctl_req *req = NULL;
|
||||||
|
int data_length = wrq->u.data.length, copy_len;
|
||||||
|
mlan_status status = MLAN_STATUS_SUCCESS;
|
||||||
|
|
||||||
|
ENTER();
|
||||||
|
|
||||||
|
copy_len = MIN(sizeof(misc->param.gen_ie.ie_data),
|
||||||
|
sizeof(int) * data_length);
|
||||||
|
req = woal_alloc_mlan_ioctl_req(sizeof(mlan_ds_misc_cfg));
|
||||||
|
if (req == NULL) {
|
||||||
|
ret = -ENOMEM;
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
misc = (mlan_ds_misc_cfg *)req->pbuf;
|
||||||
|
misc->sub_command = MLAN_OID_MISC_GEN_IE;
|
||||||
|
req->req_id = MLAN_IOCTL_MISC_CFG;
|
||||||
|
req->action = MLAN_ACT_SET;
|
||||||
|
misc->param.gen_ie.type = MLAN_IE_TYPE_ARP_FILTER;
|
||||||
|
misc->param.gen_ie.len = data_length;
|
||||||
|
|
||||||
|
/* get the whole command from user */
|
||||||
|
if (copy_from_user(misc->param.gen_ie.ie_data, wrq->u.data.pointer,
|
||||||
|
copy_len)) {
|
||||||
|
PRINTM(MERROR, "copy from user failed\n");
|
||||||
|
ret = -EFAULT;
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
|
||||||
|
status = woal_request_ioctl(priv, req, MOAL_IOCTL_WAIT);
|
||||||
|
if (status != MLAN_STATUS_SUCCESS) {
|
||||||
|
ret = -EFAULT;
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
done:
|
||||||
|
if (status != MLAN_STATUS_PENDING)
|
||||||
|
kfree(req);
|
||||||
|
LEAVE();
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Set/get IP address
|
* @brief Set/get IP address
|
||||||
*
|
*
|
||||||
|
@ -6634,6 +6685,9 @@ int woal_wext_do_ioctl(struct net_device *dev, struct ifreq *req, int cmd)
|
||||||
case WOAL_HOST_CMD:
|
case WOAL_HOST_CMD:
|
||||||
ret = woal_host_command(priv, wrq);
|
ret = woal_host_command(priv, wrq);
|
||||||
break;
|
break;
|
||||||
|
case WOAL_ARP_FILTER:
|
||||||
|
ret = woal_arp_filter(priv, wrq);
|
||||||
|
break;
|
||||||
case WOAL_SET_INTS_GET_CHARS:
|
case WOAL_SET_INTS_GET_CHARS:
|
||||||
switch ((int)wrq->u.data.flags) {
|
switch ((int)wrq->u.data.flags) {
|
||||||
case WOAL_READ_EEPROM:
|
case WOAL_READ_EEPROM:
|
||||||
|
|
|
@ -235,6 +235,9 @@ Change log:
|
||||||
/** Private command ID for hostcmd */
|
/** Private command ID for hostcmd */
|
||||||
#define WOAL_HOST_CMD (WOAL_IOCTL + 17)
|
#define WOAL_HOST_CMD (WOAL_IOCTL + 17)
|
||||||
|
|
||||||
|
/** Private command ID for arpfilter */
|
||||||
|
#define WOAL_ARP_FILTER (WOAL_IOCTL + 19)
|
||||||
|
|
||||||
/** Private command ID to set ints and get chars */
|
/** Private command ID to set ints and get chars */
|
||||||
#define WOAL_SET_INTS_GET_CHARS (WOAL_IOCTL + 21)
|
#define WOAL_SET_INTS_GET_CHARS (WOAL_IOCTL + 21)
|
||||||
/** Private command ID to read EEPROM data */
|
/** Private command ID to read EEPROM data */
|
||||||
|
|
|
@ -513,6 +513,9 @@ static ssize_t woal_config_write(struct file *f, const char __user *buf,
|
||||||
#endif /* SD */
|
#endif /* SD */
|
||||||
if (!strncmp(databuf, "debug_dump", strlen("debug_dump"))) {
|
if (!strncmp(databuf, "debug_dump", strlen("debug_dump"))) {
|
||||||
PRINTM(MERROR, "Recevie debug_dump command\n");
|
PRINTM(MERROR, "Recevie debug_dump command\n");
|
||||||
|
#ifdef USB
|
||||||
|
if (!IS_USB(handle->card_type))
|
||||||
|
#endif
|
||||||
handle->driver_status = MTRUE;
|
handle->driver_status = MTRUE;
|
||||||
ref_handle = (moal_handle *)handle->pref_mac;
|
ref_handle = (moal_handle *)handle->pref_mac;
|
||||||
if (ref_handle) {
|
if (ref_handle) {
|
||||||
|
@ -799,6 +802,156 @@ static const struct file_operations config_proc_fops = {
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
static int woal_drv_dump_read(struct seq_file *sfp, void *data)
|
||||||
|
{
|
||||||
|
moal_handle *handle = (moal_handle *)sfp->private;
|
||||||
|
int ret = 0;
|
||||||
|
|
||||||
|
ENTER();
|
||||||
|
|
||||||
|
if (MODULE_GET == 0) {
|
||||||
|
LEAVE();
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!handle) {
|
||||||
|
PRINTM(MERROR, "handle is NULL!\n");
|
||||||
|
LEAVE();
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
if (!handle->drv_dump_buf || !handle->drv_dump_len)
|
||||||
|
handle->drv_dump_buf =
|
||||||
|
woal_dump_drv_info(handle, &handle->drv_dump_len);
|
||||||
|
if (!handle->drv_dump_buf || !handle->drv_dump_len) {
|
||||||
|
PRINTM(MERROR,
|
||||||
|
"driver dump buffer is NULL or total length is zero\n");
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
if (sfp->size < handle->drv_dump_len) {
|
||||||
|
PRINTM(MERROR,
|
||||||
|
"drv dump size too big, size=%d, drv_dump_len=%d\n",
|
||||||
|
(int)sfp->size, handle->drv_dump_len);
|
||||||
|
sfp->count = sfp->size;
|
||||||
|
ret = 0;
|
||||||
|
MODULE_PUT;
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
memset(sfp->buf, 0x00, sfp->size);
|
||||||
|
sfp->count = handle->drv_dump_len;
|
||||||
|
moal_memcpy_ext(handle, sfp->buf, handle->drv_dump_buf,
|
||||||
|
handle->drv_dump_len, sfp->size);
|
||||||
|
done:
|
||||||
|
moal_vfree(handle, handle->drv_dump_buf);
|
||||||
|
handle->drv_dump_len = 0;
|
||||||
|
handle->drv_dump_buf = NULL;
|
||||||
|
MODULE_PUT;
|
||||||
|
LEAVE();
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int woal_drv_dump_proc_open(struct inode *inode, struct file *file)
|
||||||
|
{
|
||||||
|
#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 10, 0)
|
||||||
|
return single_open(file, woal_drv_dump_read, PDE_DATA(inode));
|
||||||
|
#else
|
||||||
|
return single_open(file, woal_drv_dump_read, PDE(inode)->data);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
#if LINUX_VERSION_CODE >= KERNEL_VERSION(5, 6, 0)
|
||||||
|
static const struct proc_ops drv_dump_fops = {
|
||||||
|
.proc_open = woal_drv_dump_proc_open,
|
||||||
|
.proc_read = seq_read,
|
||||||
|
.proc_lseek = seq_lseek,
|
||||||
|
.proc_release = single_release,
|
||||||
|
};
|
||||||
|
#else
|
||||||
|
static const struct file_operations drv_dump_fops = {
|
||||||
|
.owner = THIS_MODULE,
|
||||||
|
.open = woal_drv_dump_proc_open,
|
||||||
|
.read = seq_read,
|
||||||
|
.llseek = seq_lseek,
|
||||||
|
.release = single_release,
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
|
static int woal_fw_dump_read(struct seq_file *sfp, void *data)
|
||||||
|
{
|
||||||
|
moal_handle *handle = (moal_handle *)sfp->private;
|
||||||
|
int ret = 0;
|
||||||
|
|
||||||
|
ENTER();
|
||||||
|
|
||||||
|
if (MODULE_GET == 0) {
|
||||||
|
LEAVE();
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!handle) {
|
||||||
|
PRINTM(MERROR, "handle is null!\n");
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (handle->fw_dump == MTRUE) {
|
||||||
|
PRINTM(MERROR, "fw dump is in progress\n");
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!handle->fw_dump_buf || !handle->fw_dump_len) {
|
||||||
|
PRINTM(MERROR,
|
||||||
|
"fw dump buffer is NULL or total length is zero\n");
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (sfp->size < handle->fw_dump_len) {
|
||||||
|
PRINTM(MERROR,
|
||||||
|
"fw dump size too big, size=%d, fw_dump_len=%ld\n",
|
||||||
|
(int)sfp->size, (long int)handle->fw_dump_len);
|
||||||
|
sfp->count = sfp->size;
|
||||||
|
ret = 0;
|
||||||
|
MODULE_PUT;
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
sfp->count = handle->fw_dump_len;
|
||||||
|
moal_memcpy_ext(handle, sfp->buf, handle->fw_dump_buf,
|
||||||
|
handle->fw_dump_len, sfp->size);
|
||||||
|
moal_vfree(handle, handle->fw_dump_buf);
|
||||||
|
handle->fw_dump_buf = NULL;
|
||||||
|
handle->fw_dump_len = 0;
|
||||||
|
|
||||||
|
done:
|
||||||
|
MODULE_PUT;
|
||||||
|
LEAVE();
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int woal_fw_dump_proc_open(struct inode *inode, struct file *file)
|
||||||
|
{
|
||||||
|
#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 10, 0)
|
||||||
|
return single_open(file, woal_fw_dump_read, PDE_DATA(inode));
|
||||||
|
#else
|
||||||
|
return single_open(file, woal_fw_dump_read, PDE(inode)->data);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
#if LINUX_VERSION_CODE >= KERNEL_VERSION(5, 6, 0)
|
||||||
|
static const struct proc_ops fw_dump_fops = {
|
||||||
|
.proc_open = woal_fw_dump_proc_open,
|
||||||
|
.proc_read = seq_read,
|
||||||
|
.proc_lseek = seq_lseek,
|
||||||
|
.proc_release = single_release,
|
||||||
|
};
|
||||||
|
#else
|
||||||
|
static const struct file_operations fw_dump_fops = {
|
||||||
|
.owner = THIS_MODULE,
|
||||||
|
.open = woal_fw_dump_proc_open,
|
||||||
|
.read = seq_read,
|
||||||
|
.llseek = seq_lseek,
|
||||||
|
.release = single_release,
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief wifi status proc read function
|
* @brief wifi status proc read function
|
||||||
*
|
*
|
||||||
|
@ -875,7 +1028,7 @@ int woal_string_to_number(char *s)
|
||||||
} else
|
} else
|
||||||
base = 10;
|
base = 10;
|
||||||
|
|
||||||
for (s = s; *s; s++) {
|
for (; *s; s++) {
|
||||||
if ((*s >= '0') && (*s <= '9'))
|
if ((*s >= '0') && (*s <= '9'))
|
||||||
r = (r * base) + (*s - '0');
|
r = (r * base) + (*s - '0');
|
||||||
else if ((*s >= 'A') && (*s <= 'F'))
|
else if ((*s >= 'A') && (*s <= 'F'))
|
||||||
|
@ -910,7 +1063,7 @@ mlan_status woal_root_proc_init(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* create /proc/mwlan/wifi_status */
|
/* create /proc/mwlan/wifi_status */
|
||||||
proc_create_data(STATUS_PROC, 0644, proc_mwlan, &wifi_status_proc_fops,
|
proc_create_data(STATUS_PROC, 0666, proc_mwlan, &wifi_status_proc_fops,
|
||||||
NULL);
|
NULL);
|
||||||
|
|
||||||
LEAVE();
|
LEAVE();
|
||||||
|
@ -949,6 +1102,8 @@ void woal_proc_init(moal_handle *handle)
|
||||||
struct proc_dir_entry *pde = proc_mwlan;
|
struct proc_dir_entry *pde = proc_mwlan;
|
||||||
#endif
|
#endif
|
||||||
char config_proc_dir[20];
|
char config_proc_dir[20];
|
||||||
|
char drv_dump_dir[20];
|
||||||
|
char fw_dump_dir[20];
|
||||||
|
|
||||||
ENTER();
|
ENTER();
|
||||||
|
|
||||||
|
@ -992,7 +1147,7 @@ void woal_proc_init(moal_handle *handle)
|
||||||
|
|
||||||
strcpy(config_proc_dir, "config");
|
strcpy(config_proc_dir, "config");
|
||||||
#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 26)
|
#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 26)
|
||||||
r = proc_create_data(config_proc_dir, 0644, handle->proc_wlan,
|
r = proc_create_data(config_proc_dir, 0666, handle->proc_wlan,
|
||||||
&config_proc_fops, handle);
|
&config_proc_fops, handle);
|
||||||
#else
|
#else
|
||||||
r = create_proc_entry(config_proc_dir, 0644, handle->proc_wlan);
|
r = create_proc_entry(config_proc_dir, 0644, handle->proc_wlan);
|
||||||
|
@ -1004,6 +1159,34 @@ void woal_proc_init(moal_handle *handle)
|
||||||
if (!r)
|
if (!r)
|
||||||
PRINTM(MERROR, "Fail to create proc config\n");
|
PRINTM(MERROR, "Fail to create proc config\n");
|
||||||
|
|
||||||
|
strcpy(drv_dump_dir, "drv_dump");
|
||||||
|
#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 26)
|
||||||
|
r = proc_create_data(drv_dump_dir, 0644, handle->proc_wlan,
|
||||||
|
&drv_dump_fops, handle);
|
||||||
|
#else
|
||||||
|
r = create_proc_entry(drv_dump_dir, 0644, handle->proc_wlan);
|
||||||
|
if (r) {
|
||||||
|
r->data = handle;
|
||||||
|
r->proc_fops = &drv_dump_fops;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
if (!r)
|
||||||
|
PRINTM(MERROR, "Failed to create proc drv dump\n");
|
||||||
|
|
||||||
|
strcpy(fw_dump_dir, "fw_dump");
|
||||||
|
#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 26)
|
||||||
|
r = proc_create_data(fw_dump_dir, 0644, handle->proc_wlan,
|
||||||
|
&fw_dump_fops, handle);
|
||||||
|
#else
|
||||||
|
r = create_proc_entry(fw_dump_dir, 0644, handle->proc_wlan);
|
||||||
|
if (r) {
|
||||||
|
r->data = handle;
|
||||||
|
r->proc_fops = &fw_dump_fops;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
if (!r)
|
||||||
|
PRINTM(MERROR, "Failed to create proc fw dump\n");
|
||||||
|
|
||||||
done:
|
done:
|
||||||
LEAVE();
|
LEAVE();
|
||||||
}
|
}
|
||||||
|
@ -1018,6 +1201,8 @@ done:
|
||||||
void woal_proc_exit(moal_handle *handle)
|
void woal_proc_exit(moal_handle *handle)
|
||||||
{
|
{
|
||||||
char config_proc_dir[20];
|
char config_proc_dir[20];
|
||||||
|
char drv_dump_dir[20];
|
||||||
|
char fw_dump_dir[20];
|
||||||
|
|
||||||
ENTER();
|
ENTER();
|
||||||
|
|
||||||
|
@ -1025,6 +1210,10 @@ void woal_proc_exit(moal_handle *handle)
|
||||||
if (handle->proc_wlan) {
|
if (handle->proc_wlan) {
|
||||||
strcpy(config_proc_dir, "config");
|
strcpy(config_proc_dir, "config");
|
||||||
remove_proc_entry(config_proc_dir, handle->proc_wlan);
|
remove_proc_entry(config_proc_dir, handle->proc_wlan);
|
||||||
|
strcpy(drv_dump_dir, "drv_dump");
|
||||||
|
remove_proc_entry(drv_dump_dir, handle->proc_wlan);
|
||||||
|
strcpy(fw_dump_dir, "fw_dump");
|
||||||
|
remove_proc_entry(fw_dump_dir, handle->proc_wlan);
|
||||||
|
|
||||||
#if LINUX_VERSION_CODE < KERNEL_VERSION(3, 10, 0)
|
#if LINUX_VERSION_CODE < KERNEL_VERSION(3, 10, 0)
|
||||||
/* Remove only if we are the only instance using this */
|
/* Remove only if we are the only instance using this */
|
||||||
|
@ -1042,6 +1231,16 @@ void woal_proc_exit(moal_handle *handle)
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
if (handle->fw_dump_buf) {
|
||||||
|
moal_vfree(handle, handle->fw_dump_buf);
|
||||||
|
handle->fw_dump_buf = NULL;
|
||||||
|
handle->fw_dump_len = 0;
|
||||||
|
}
|
||||||
|
if (handle->drv_dump_buf) {
|
||||||
|
moal_vfree(handle, handle->drv_dump_buf);
|
||||||
|
handle->drv_dump_len = 0;
|
||||||
|
handle->drv_dump_buf = NULL;
|
||||||
|
}
|
||||||
LEAVE();
|
LEAVE();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1670,7 +1670,6 @@ void woal_dump_firmware_info(moal_handle *phandle)
|
||||||
{
|
{
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
unsigned int reg, reg_start, reg_end;
|
unsigned int reg, reg_start, reg_end;
|
||||||
t_u8 path_name[64], file_name[32];
|
|
||||||
t_u8 *ITCM_Ptr = NULL;
|
t_u8 *ITCM_Ptr = NULL;
|
||||||
t_u8 *DTCM_Ptr = NULL;
|
t_u8 *DTCM_Ptr = NULL;
|
||||||
t_u8 *SQRAM_Ptr = NULL;
|
t_u8 *SQRAM_Ptr = NULL;
|
||||||
|
@ -1686,15 +1685,17 @@ void woal_dump_firmware_info(moal_handle *phandle)
|
||||||
PRINTM(MERROR, "Could not dump firmwware info\n");
|
PRINTM(MERROR, "Could not dump firmwware info\n");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 1, 0)
|
if (!phandle->fw_dump_buf) {
|
||||||
/** Create dump directort*/
|
ret = moal_vmalloc(phandle, FW_DUMP_INFO_LEN,
|
||||||
woal_create_dump_dir(phandle, path_name, sizeof(path_name));
|
&(phandle->fw_dump_buf));
|
||||||
#else
|
if (ret != MLAN_STATUS_SUCCESS || !phandle->fw_dump_buf) {
|
||||||
memset(path_name, 0, sizeof(path_name));
|
PRINTM(MERROR, "Failed to vmalloc fw dump bufffer\n");
|
||||||
strcpy(path_name, "/data");
|
return;
|
||||||
#endif
|
}
|
||||||
PRINTM(MMSG, "Directory name is %s\n", path_name);
|
} else {
|
||||||
woal_dump_drv_info(phandle, path_name);
|
memset(phandle->fw_dump_buf, 0x00, FW_DUMP_INFO_LEN);
|
||||||
|
}
|
||||||
|
phandle->fw_dump_len = 0;
|
||||||
|
|
||||||
#if LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 32)
|
#if LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 32)
|
||||||
sdio_claim_host(((struct sdio_mmc_card *)phandle->card)->func);
|
sdio_claim_host(((struct sdio_mmc_card *)phandle->card)->func);
|
||||||
|
@ -1792,13 +1793,8 @@ void woal_dump_firmware_info(moal_handle *phandle)
|
||||||
PRINTM(MMSG, "ITCM done: size=0x%x\n",
|
PRINTM(MMSG, "ITCM done: size=0x%x\n",
|
||||||
dbg_ptr - ITCM_Ptr);
|
dbg_ptr - ITCM_Ptr);
|
||||||
#endif
|
#endif
|
||||||
memset(file_name, 0, sizeof(file_name));
|
woal_save_dump_info_to_buf(phandle, ITCM_Ptr, ITCM_SIZE,
|
||||||
sprintf(file_name, "%s", "file_sdio_ITCM");
|
FW_DUMP_TYPE_MEM_ITCM);
|
||||||
if (MLAN_STATUS_SUCCESS !=
|
|
||||||
woal_save_dump_info_to_file(path_name, file_name,
|
|
||||||
ITCM_Ptr, ITCM_SIZE))
|
|
||||||
PRINTM(MMSG, "Can't save dump file %s in %s\n",
|
|
||||||
file_name, path_name);
|
|
||||||
dbg_ptr = DTCM_Ptr;
|
dbg_ptr = DTCM_Ptr;
|
||||||
end_ptr = DTCM_Ptr + dtcm_size;
|
end_ptr = DTCM_Ptr + dtcm_size;
|
||||||
moal_get_system_time(phandle, &sec, &usec);
|
moal_get_system_time(phandle, &sec, &usec);
|
||||||
|
@ -1814,13 +1810,8 @@ void woal_dump_firmware_info(moal_handle *phandle)
|
||||||
PRINTM(MMSG, "DTCM done: size=0x%x\n",
|
PRINTM(MMSG, "DTCM done: size=0x%x\n",
|
||||||
dbg_ptr - DTCM_Ptr);
|
dbg_ptr - DTCM_Ptr);
|
||||||
#endif
|
#endif
|
||||||
memset(file_name, 0, sizeof(file_name));
|
woal_save_dump_info_to_buf(phandle, ITCM_Ptr, dtcm_size,
|
||||||
sprintf(file_name, "%s", "file_sdio_DTCM");
|
FW_DUMP_TYPE_MEM_DTCM);
|
||||||
if (MLAN_STATUS_SUCCESS !=
|
|
||||||
woal_save_dump_info_to_file(path_name, file_name,
|
|
||||||
DTCM_Ptr, dtcm_size))
|
|
||||||
PRINTM(MMSG, "Can't save dump file %s in %s\n",
|
|
||||||
file_name, path_name);
|
|
||||||
dbg_ptr = SQRAM_Ptr;
|
dbg_ptr = SQRAM_Ptr;
|
||||||
end_ptr = SQRAM_Ptr + sqram_size;
|
end_ptr = SQRAM_Ptr + sqram_size;
|
||||||
moal_get_system_time(phandle, &sec, &usec);
|
moal_get_system_time(phandle, &sec, &usec);
|
||||||
|
@ -1836,13 +1827,9 @@ void woal_dump_firmware_info(moal_handle *phandle)
|
||||||
PRINTM(MMSG, "SQRAM done: size=0x%x\n",
|
PRINTM(MMSG, "SQRAM done: size=0x%x\n",
|
||||||
dbg_ptr - SQRAM_Ptr);
|
dbg_ptr - SQRAM_Ptr);
|
||||||
#endif
|
#endif
|
||||||
memset(file_name, 0, sizeof(file_name));
|
woal_save_dump_info_to_buf(phandle, SQRAM_Ptr,
|
||||||
sprintf(file_name, "%s", "file_sdio_SQRAM");
|
sqram_size,
|
||||||
if (MLAN_STATUS_SUCCESS !=
|
FW_DUMP_TYPE_MEM_SQRAM);
|
||||||
woal_save_dump_info_to_file(path_name, file_name,
|
|
||||||
SQRAM_Ptr, sqram_size))
|
|
||||||
PRINTM(MMSG, "Can't save dump file %s in %s\n",
|
|
||||||
file_name, path_name);
|
|
||||||
PRINTM(MMSG, "End output!\n");
|
PRINTM(MMSG, "End output!\n");
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
@ -1850,6 +1837,7 @@ void woal_dump_firmware_info(moal_handle *phandle)
|
||||||
}
|
}
|
||||||
} while (ctrl_data != DEBUG_SQRAM_DONE);
|
} while (ctrl_data != DEBUG_SQRAM_DONE);
|
||||||
|
|
||||||
|
woal_append_end_block(phandle);
|
||||||
PRINTM(MMSG,
|
PRINTM(MMSG,
|
||||||
"The output ITCM/DTCM/SQRAM have been saved to files successfully!\n");
|
"The output ITCM/DTCM/SQRAM have been saved to files successfully!\n");
|
||||||
moal_get_system_time(phandle, &sec, &usec);
|
moal_get_system_time(phandle, &sec, &usec);
|
||||||
|
@ -1890,7 +1878,6 @@ void woal_dump_firmware_info_v2(moal_handle *phandle)
|
||||||
t_u8 i = 0;
|
t_u8 i = 0;
|
||||||
t_u8 read_reg = 0;
|
t_u8 read_reg = 0;
|
||||||
t_u32 memory_size = 0;
|
t_u32 memory_size = 0;
|
||||||
t_u8 path_name[64], file_name[32], firmware_dump_file[128];
|
|
||||||
t_u8 *end_ptr = NULL;
|
t_u8 *end_ptr = NULL;
|
||||||
t_u8 dbg_dump_start_reg = 0;
|
t_u8 dbg_dump_start_reg = 0;
|
||||||
t_u8 dbg_dump_end_reg = 0;
|
t_u8 dbg_dump_end_reg = 0;
|
||||||
|
@ -1905,16 +1892,17 @@ void woal_dump_firmware_info_v2(moal_handle *phandle)
|
||||||
dbg_dump_end_reg = phandle->card_info->dump_fw_end_reg;
|
dbg_dump_end_reg = phandle->card_info->dump_fw_end_reg;
|
||||||
dbg_dump_ctrl_reg = phandle->card_info->dump_fw_ctrl_reg;
|
dbg_dump_ctrl_reg = phandle->card_info->dump_fw_ctrl_reg;
|
||||||
|
|
||||||
#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 1, 0)
|
if (!phandle->fw_dump_buf) {
|
||||||
/** Create dump directort*/
|
ret = moal_vmalloc(phandle, FW_DUMP_INFO_LEN,
|
||||||
woal_create_dump_dir(phandle, path_name, sizeof(path_name));
|
&(phandle->fw_dump_buf));
|
||||||
#else
|
if (ret != MLAN_STATUS_SUCCESS || !phandle->fw_dump_buf) {
|
||||||
memset(path_name, 0, sizeof(path_name));
|
PRINTM(MERROR, "Failed to vmalloc fw dump bufffer\n");
|
||||||
strcpy(path_name, "/data");
|
return;
|
||||||
#endif
|
}
|
||||||
PRINTM(MMSG, "Directory name is %s\n", path_name);
|
} else {
|
||||||
|
memset(phandle->fw_dump_buf, 0x00, FW_DUMP_INFO_LEN);
|
||||||
woal_dump_drv_info(phandle, path_name);
|
}
|
||||||
|
phandle->fw_dump_len = 0;
|
||||||
|
|
||||||
/* start dump fw memory */
|
/* start dump fw memory */
|
||||||
moal_get_system_time(phandle, &sec, &usec);
|
moal_get_system_time(phandle, &sec, &usec);
|
||||||
|
@ -2009,17 +1997,11 @@ void woal_dump_firmware_info_v2(moal_handle *phandle)
|
||||||
dbg_ptr - mem_type_mapping_tbl[idx]
|
dbg_ptr - mem_type_mapping_tbl[idx]
|
||||||
.mem_Ptr);
|
.mem_Ptr);
|
||||||
#endif
|
#endif
|
||||||
memset(file_name, 0, sizeof(file_name));
|
woal_save_dump_info_to_buf(
|
||||||
sprintf(file_name, "%s%s", "file_sdio_",
|
phandle,
|
||||||
mem_type_mapping_tbl[idx].mem_name);
|
|
||||||
if (MLAN_STATUS_SUCCESS !=
|
|
||||||
woal_save_dump_info_to_file(
|
|
||||||
path_name, file_name,
|
|
||||||
mem_type_mapping_tbl[idx].mem_Ptr,
|
mem_type_mapping_tbl[idx].mem_Ptr,
|
||||||
memory_size))
|
memory_size,
|
||||||
PRINTM(MERROR,
|
mem_type_mapping_tbl[idx].type);
|
||||||
"Can't save dump file %s in %s\n",
|
|
||||||
file_name, path_name);
|
|
||||||
moal_vfree(phandle,
|
moal_vfree(phandle,
|
||||||
mem_type_mapping_tbl[idx].mem_Ptr);
|
mem_type_mapping_tbl[idx].mem_Ptr);
|
||||||
mem_type_mapping_tbl[idx].mem_Ptr = NULL;
|
mem_type_mapping_tbl[idx].mem_Ptr = NULL;
|
||||||
|
@ -2027,14 +2009,10 @@ void woal_dump_firmware_info_v2(moal_handle *phandle)
|
||||||
}
|
}
|
||||||
} while (1);
|
} while (1);
|
||||||
}
|
}
|
||||||
|
woal_append_end_block(phandle);
|
||||||
moal_get_system_time(phandle, &sec, &usec);
|
moal_get_system_time(phandle, &sec, &usec);
|
||||||
PRINTM(MMSG, "==== DEBUG MODE OUTPUT END: %u.%06u ====\n", sec, usec);
|
PRINTM(MMSG, "==== DEBUG MODE OUTPUT END: %u.%06u ====\n", sec, usec);
|
||||||
/* end dump fw memory */
|
/* end dump fw memory */
|
||||||
memset(firmware_dump_file, 0, sizeof(firmware_dump_file));
|
|
||||||
sprintf(firmware_dump_file, "%s/%s", path_name, file_name);
|
|
||||||
moal_memcpy_ext(phandle, phandle->firmware_dump_file,
|
|
||||||
firmware_dump_file, sizeof(firmware_dump_file),
|
|
||||||
sizeof(phandle->firmware_dump_file));
|
|
||||||
done:
|
done:
|
||||||
for (idx = 0; idx < dump_num; idx++) {
|
for (idx = 0; idx < dump_num; idx++) {
|
||||||
if (mem_type_mapping_tbl[idx].mem_Ptr) {
|
if (mem_type_mapping_tbl[idx].mem_Ptr) {
|
||||||
|
@ -2065,8 +2043,6 @@ void woal_dump_firmware_info_v3(moal_handle *phandle)
|
||||||
t_u8 doneflag = 0;
|
t_u8 doneflag = 0;
|
||||||
rdwr_status stat;
|
rdwr_status stat;
|
||||||
t_u32 memory_size = 0;
|
t_u32 memory_size = 0;
|
||||||
t_u8 path_name[64], file_name[32], firmware_dump_file[128];
|
|
||||||
moal_handle *ref_handle;
|
|
||||||
t_u8 *end_ptr = NULL;
|
t_u8 *end_ptr = NULL;
|
||||||
t_u8 dbg_dump_start_reg = 0;
|
t_u8 dbg_dump_start_reg = 0;
|
||||||
t_u8 dbg_dump_end_reg = 0;
|
t_u8 dbg_dump_end_reg = 0;
|
||||||
|
@ -2093,19 +2069,6 @@ void woal_dump_firmware_info_v3(moal_handle *phandle)
|
||||||
dbg_dump_start_reg = phandle->card_info->dump_fw_start_reg;
|
dbg_dump_start_reg = phandle->card_info->dump_fw_start_reg;
|
||||||
dbg_dump_end_reg = phandle->card_info->dump_fw_end_reg;
|
dbg_dump_end_reg = phandle->card_info->dump_fw_end_reg;
|
||||||
|
|
||||||
#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 1, 0)
|
|
||||||
/** Create dump directort*/
|
|
||||||
woal_create_dump_dir(phandle, path_name, sizeof(path_name));
|
|
||||||
#else
|
|
||||||
memset(path_name, 0, sizeof(path_name));
|
|
||||||
strcpy(path_name, "/data");
|
|
||||||
#endif
|
|
||||||
PRINTM(MMSG, "Directory name is %s\n", path_name);
|
|
||||||
ref_handle = (moal_handle *)phandle->pref_mac;
|
|
||||||
if (ref_handle)
|
|
||||||
woal_dump_drv_info(ref_handle, path_name);
|
|
||||||
woal_dump_drv_info(phandle, path_name);
|
|
||||||
|
|
||||||
/* start dump fw memory */
|
/* start dump fw memory */
|
||||||
moal_get_system_time(phandle, &sec, &usec);
|
moal_get_system_time(phandle, &sec, &usec);
|
||||||
PRINTM(MMSG, "==== DEBUG MODE OUTPUT START: %u.%06u ====\n", sec, usec);
|
PRINTM(MMSG, "==== DEBUG MODE OUTPUT START: %u.%06u ====\n", sec, usec);
|
||||||
|
@ -2201,18 +2164,14 @@ void woal_dump_firmware_info_v3(moal_handle *phandle)
|
||||||
dbg_ptr - pmem_type_mapping_tbl->mem_Ptr);
|
dbg_ptr - pmem_type_mapping_tbl->mem_Ptr);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
memset(file_name, 0, sizeof(file_name));
|
if (phandle->fw_dump_buf) {
|
||||||
sprintf(file_name, "%s%s", "file_sdio_",
|
moal_vfree(phandle, phandle->fw_dump_buf);
|
||||||
pmem_type_mapping_tbl->mem_name);
|
phandle->fw_dump_buf = NULL;
|
||||||
if (MLAN_STATUS_SUCCESS !=
|
phandle->fw_dump_len = 0;
|
||||||
woal_save_dump_info_to_file(
|
}
|
||||||
path_name, file_name,
|
phandle->fw_dump_buf = pmem_type_mapping_tbl->mem_Ptr;
|
||||||
pmem_type_mapping_tbl->mem_Ptr,
|
phandle->fw_dump_len =
|
||||||
dbg_ptr - pmem_type_mapping_tbl->mem_Ptr))
|
dbg_ptr - pmem_type_mapping_tbl->mem_Ptr;
|
||||||
PRINTM(MERROR,
|
|
||||||
"Can't save dump file %s in %s\n",
|
|
||||||
file_name, path_name);
|
|
||||||
moal_vfree(phandle, pmem_type_mapping_tbl->mem_Ptr);
|
|
||||||
pmem_type_mapping_tbl->mem_Ptr = NULL;
|
pmem_type_mapping_tbl->mem_Ptr = NULL;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -2220,11 +2179,6 @@ void woal_dump_firmware_info_v3(moal_handle *phandle)
|
||||||
moal_get_system_time(phandle, &sec, &usec);
|
moal_get_system_time(phandle, &sec, &usec);
|
||||||
PRINTM(MMSG, "==== DEBUG MODE OUTPUT END: %u.%06u ====\n", sec, usec);
|
PRINTM(MMSG, "==== DEBUG MODE OUTPUT END: %u.%06u ====\n", sec, usec);
|
||||||
/* end dump fw memory */
|
/* end dump fw memory */
|
||||||
memset(firmware_dump_file, 0, sizeof(firmware_dump_file));
|
|
||||||
sprintf(firmware_dump_file, "%s/%s", path_name, file_name);
|
|
||||||
moal_memcpy_ext(phandle, phandle->firmware_dump_file,
|
|
||||||
firmware_dump_file, sizeof(firmware_dump_file),
|
|
||||||
sizeof(phandle->firmware_dump_file));
|
|
||||||
done:
|
done:
|
||||||
if (pmem_type_mapping_tbl->mem_Ptr) {
|
if (pmem_type_mapping_tbl->mem_Ptr) {
|
||||||
moal_vfree(phandle, pmem_type_mapping_tbl->mem_Ptr);
|
moal_vfree(phandle, pmem_type_mapping_tbl->mem_Ptr);
|
||||||
|
@ -2329,6 +2283,8 @@ static void woal_sdiommc_dump_fw_info(moal_handle *phandle)
|
||||||
if (phandle->event_fw_dump) {
|
if (phandle->event_fw_dump) {
|
||||||
phandle->event_fw_dump = MFALSE;
|
phandle->event_fw_dump = MFALSE;
|
||||||
queue_work(phandle->workqueue, &phandle->main_work);
|
queue_work(phandle->workqueue, &phandle->main_work);
|
||||||
|
phandle->is_fw_dump_timer_set = MTRUE;
|
||||||
|
woal_mod_timer(&phandle->fw_dump_timer, MOAL_TIMER_5S);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2337,9 +2293,12 @@ static void woal_sdiommc_dump_fw_info(moal_handle *phandle)
|
||||||
woal_dump_firmware_info(phandle);
|
woal_dump_firmware_info(phandle);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
woal_send_fw_dump_complete_event(
|
||||||
|
woal_get_priv(phandle, MLAN_BSS_ROLE_ANY));
|
||||||
phandle->fw_dump = MFALSE;
|
phandle->fw_dump = MFALSE;
|
||||||
mlan_pm_wakeup_card(phandle->pmlan_adapter, MFALSE);
|
mlan_pm_wakeup_card(phandle->pmlan_adapter, MFALSE);
|
||||||
queue_work(phandle->workqueue, &phandle->main_work);
|
queue_work(phandle->workqueue, &phandle->main_work);
|
||||||
|
woal_process_hang(phandle);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -653,6 +653,28 @@ mlan_status moal_spin_unlock(t_void *pmoal, t_void *plock)
|
||||||
return MLAN_STATUS_SUCCESS;
|
return MLAN_STATUS_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief This function collects AMSDU TP statistics.
|
||||||
|
*
|
||||||
|
* @param pmoal Pointer to the MOAL context
|
||||||
|
* @param amsdu_process_delay amsdu process time
|
||||||
|
* @param amsdu_copy_delay amsdu copy time
|
||||||
|
*
|
||||||
|
* @return N/A
|
||||||
|
*/
|
||||||
|
void moal_amsdu_tp_accounting(t_void *pmoal, t_s32 amsdu_process_delay,
|
||||||
|
t_s32 amsdu_copy_delay)
|
||||||
|
{
|
||||||
|
moal_handle *handle = (moal_handle *)pmoal;
|
||||||
|
handle->tp_acnt.rx_amsdu_delay[handle->tp_acnt.rx_amsdu_index] =
|
||||||
|
amsdu_process_delay;
|
||||||
|
handle->tp_acnt.rx_amsdu_copy_delay[handle->tp_acnt.rx_amsdu_index] =
|
||||||
|
amsdu_copy_delay;
|
||||||
|
handle->tp_acnt.rx_amsdu_index++;
|
||||||
|
if (handle->tp_acnt.rx_amsdu_index >= TXRX_MAX_SAMPLE)
|
||||||
|
handle->tp_acnt.rx_amsdu_index = 0;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief This function collects TP statistics.
|
* @brief This function collects TP statistics.
|
||||||
*
|
*
|
||||||
|
@ -1189,13 +1211,13 @@ mlan_status moal_recv_complete(t_void *pmoal, pmlan_buffer pmbuf, t_u32 port,
|
||||||
else {
|
else {
|
||||||
woal_free_mlan_buffer(handle, pmbuf);
|
woal_free_mlan_buffer(handle, pmbuf);
|
||||||
if ((atomic_read(&handle->rx_pending) <
|
if ((atomic_read(&handle->rx_pending) <
|
||||||
LOW_RX_PENDING) &&
|
USB_LOW_RX_PENDING) &&
|
||||||
atomic_read(&cardp->rx_data_urb_pending) <
|
atomic_read(&cardp->rx_data_urb_pending) <
|
||||||
MVUSB_RX_DATA_URB)
|
MVUSB_RX_DATA_URB)
|
||||||
woal_usb_submit_rx_data_urbs(handle);
|
woal_usb_submit_rx_data_urbs(handle);
|
||||||
}
|
}
|
||||||
} else if (port == cardp->rx_data_ep) {
|
} else if (port == cardp->rx_data_ep) {
|
||||||
if ((atomic_read(&handle->rx_pending) < LOW_RX_PENDING) &&
|
if ((atomic_read(&handle->rx_pending) < USB_LOW_RX_PENDING) &&
|
||||||
atomic_read(&cardp->rx_data_urb_pending) <
|
atomic_read(&cardp->rx_data_urb_pending) <
|
||||||
MVUSB_RX_DATA_URB)
|
MVUSB_RX_DATA_URB)
|
||||||
woal_usb_submit_rx_data_urbs(handle);
|
woal_usb_submit_rx_data_urbs(handle);
|
||||||
|
@ -1327,6 +1349,7 @@ mlan_status moal_recv_packet(t_void *pmoal, pmlan_buffer pmbuf)
|
||||||
t_u8 rx_info_flag = MFALSE;
|
t_u8 rx_info_flag = MFALSE;
|
||||||
int j;
|
int j;
|
||||||
struct ethhdr *ethh = NULL;
|
struct ethhdr *ethh = NULL;
|
||||||
|
struct net_device *netdev = NULL;
|
||||||
|
|
||||||
ENTER();
|
ENTER();
|
||||||
if (pmbuf) {
|
if (pmbuf) {
|
||||||
|
@ -1411,8 +1434,10 @@ mlan_status moal_recv_packet(t_void *pmoal, pmlan_buffer pmbuf)
|
||||||
"\n",
|
"\n",
|
||||||
priv->netdev->name,
|
priv->netdev->name,
|
||||||
MAC2STR(ethh->h_source));
|
MAC2STR(ethh->h_source));
|
||||||
skb->dev = priv->netdev;
|
if (!netdev)
|
||||||
skb->protocol = eth_type_trans(skb, priv->netdev);
|
netdev = priv->netdev;
|
||||||
|
skb->dev = netdev;
|
||||||
|
skb->protocol = eth_type_trans(skb, netdev);
|
||||||
skb->ip_summed = CHECKSUM_NONE;
|
skb->ip_summed = CHECKSUM_NONE;
|
||||||
|
|
||||||
#if defined(USB) || defined(PCIE)
|
#if defined(USB) || defined(PCIE)
|
||||||
|
@ -1530,9 +1555,16 @@ mlan_status moal_recv_packet(t_void *pmoal, pmlan_buffer pmbuf)
|
||||||
if (atomic_read(&handle->rx_pending) >
|
if (atomic_read(&handle->rx_pending) >
|
||||||
MAX_RX_PENDING_THRHLD)
|
MAX_RX_PENDING_THRHLD)
|
||||||
netif_rx(skb);
|
netif_rx(skb);
|
||||||
else
|
else {
|
||||||
|
if (handle->params.net_rx == MTRUE) {
|
||||||
|
local_bh_disable();
|
||||||
|
netif_receive_skb(skb);
|
||||||
|
local_bh_enable();
|
||||||
|
} else {
|
||||||
netif_rx_ni(skb);
|
netif_rx_ni(skb);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
if (priv->phandle->tp_acnt.on) {
|
if (priv->phandle->tp_acnt.on) {
|
||||||
if (pmbuf && pmbuf->in_ts_sec)
|
if (pmbuf && pmbuf->in_ts_sec)
|
||||||
moal_tp_accounting(handle, pmbuf,
|
moal_tp_accounting(handle, pmbuf,
|
||||||
|
@ -1546,16 +1578,17 @@ done:
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined(PCIE) || defined(SDIO)
|
#if defined(PCIE) || defined(SDIO)
|
||||||
void woal_request_busfreq_pmqos_add(t_u16 card_type)
|
void woal_request_busfreq_pmqos_add(t_void *handle)
|
||||||
{
|
{
|
||||||
|
moal_handle *pmhandle = (moal_handle *)handle;
|
||||||
#if LINUX_VERSION_CODE < KERNEL_VERSION(5, 4, 70)
|
#if LINUX_VERSION_CODE < KERNEL_VERSION(5, 4, 70)
|
||||||
#ifdef IMX_SUPPORT
|
#ifdef IMX_SUPPORT
|
||||||
if (IS_PCIE(card_type)) {
|
if (IS_PCIE(pmhandle->card_type)) {
|
||||||
request_bus_freq(BUS_FREQ_HIGH);
|
request_bus_freq(BUS_FREQ_HIGH);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
if (moal_extflg_isset(pmhandle, EXT_PMQOS)) {
|
||||||
#if LINUX_VERSION_CODE <= KERNEL_VERSION(5, 6, 0)
|
#if LINUX_VERSION_CODE <= KERNEL_VERSION(5, 6, 0)
|
||||||
#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35)
|
#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35)
|
||||||
#ifdef IMX_SUPPORT
|
#ifdef IMX_SUPPORT
|
||||||
|
@ -1567,20 +1600,22 @@ void woal_request_busfreq_pmqos_add(t_u16 card_type)
|
||||||
cpu_latency_qos_add_request(&woal_pm_qos_req, 0);
|
cpu_latency_qos_add_request(&woal_pm_qos_req, 0);
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
void woal_release_busfreq_pmqos_remove(t_u16 card_type)
|
void woal_release_busfreq_pmqos_remove(t_void *handle)
|
||||||
{
|
{
|
||||||
|
moal_handle *pmhandle = (moal_handle *)handle;
|
||||||
#if LINUX_VERSION_CODE < KERNEL_VERSION(5, 4, 70)
|
#if LINUX_VERSION_CODE < KERNEL_VERSION(5, 4, 70)
|
||||||
#ifdef IMX_SUPPORT
|
#ifdef IMX_SUPPORT
|
||||||
if (IS_PCIE(card_type)) {
|
if (IS_PCIE(pmhandle->card_type)) {
|
||||||
release_bus_freq(BUS_FREQ_HIGH);
|
release_bus_freq(BUS_FREQ_HIGH);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
if (moal_extflg_isset(pmhandle, EXT_PMQOS)) {
|
||||||
#if LINUX_VERSION_CODE <= KERNEL_VERSION(5, 6, 0)
|
#if LINUX_VERSION_CODE <= KERNEL_VERSION(5, 6, 0)
|
||||||
#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35)
|
#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 35)
|
||||||
#ifdef IMX_SUPPORT
|
#ifdef IMX_SUPPORT
|
||||||
|
@ -1592,6 +1627,7 @@ void woal_release_busfreq_pmqos_remove(t_u16 card_type)
|
||||||
cpu_latency_qos_remove_request(&woal_pm_qos_req);
|
cpu_latency_qos_remove_request(&woal_pm_qos_req);
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
#endif /*defined(PCIE) || defined(SDIO)*/
|
#endif /*defined(PCIE) || defined(SDIO)*/
|
||||||
|
@ -1612,7 +1648,7 @@ static int woal_check_media_connected(t_void *pmoal)
|
||||||
i++) {
|
i++) {
|
||||||
if (!pmpriv)
|
if (!pmpriv)
|
||||||
continue;
|
continue;
|
||||||
if ((pmpriv->media_connected == MTRUE)) {
|
if (pmpriv->media_connected == MTRUE) {
|
||||||
return MTRUE;
|
return MTRUE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1630,17 +1666,17 @@ static void moal_connection_status_check_pmqos(t_void *pmoal)
|
||||||
{
|
{
|
||||||
moal_handle *pmhandle = (moal_handle *)pmoal;
|
moal_handle *pmhandle = (moal_handle *)pmoal;
|
||||||
if ((woal_check_media_connected(pmoal) == MTRUE)) {
|
if ((woal_check_media_connected(pmoal) == MTRUE)) {
|
||||||
if ((pmhandle->request_pm == MFALSE)) {
|
if (pmhandle->request_pm == MFALSE) {
|
||||||
pmhandle->request_pm = MTRUE;
|
pmhandle->request_pm = MTRUE;
|
||||||
#if defined(PCIE) || defined(SDIO)
|
#if defined(PCIE) || defined(SDIO)
|
||||||
woal_request_busfreq_pmqos_add(pmhandle->card_type);
|
woal_request_busfreq_pmqos_add(pmhandle);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (pmhandle->request_pm == MTRUE) {
|
if (pmhandle->request_pm == MTRUE) {
|
||||||
pmhandle->request_pm = MFALSE;
|
pmhandle->request_pm = MFALSE;
|
||||||
#if defined(PCIE) || defined(SDIO)
|
#if defined(PCIE) || defined(SDIO)
|
||||||
woal_release_busfreq_pmqos_remove(pmhandle->card_type);
|
woal_release_busfreq_pmqos_remove(pmhandle);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1725,8 +1761,14 @@ mlan_status moal_recv_event(t_void *pmoal, pmlan_event pmevent)
|
||||||
#endif
|
#endif
|
||||||
t_u8 radar_detected;
|
t_u8 radar_detected;
|
||||||
|
|
||||||
|
t_u8 auto_fw_dump = MFALSE;
|
||||||
ENTER();
|
ENTER();
|
||||||
if (pmevent->event_id == MLAN_EVENT_ID_FW_DUMP_INFO) {
|
if (pmevent->event_id == MLAN_EVENT_ID_FW_DUMP_INFO) {
|
||||||
|
if (!handle->is_fw_dump_timer_set) {
|
||||||
|
PRINTM(MMSG, "FW trigger fw dump\n");
|
||||||
|
handle->is_fw_dump_timer_set = MTRUE;
|
||||||
|
woal_mod_timer(&handle->fw_dump_timer, MOAL_TIMER_5S);
|
||||||
|
}
|
||||||
woal_store_firmware_dump(pmoal, pmevent);
|
woal_store_firmware_dump(pmoal, pmevent);
|
||||||
handle->driver_status = MTRUE;
|
handle->driver_status = MTRUE;
|
||||||
ref_handle = (moal_handle *)handle->pref_mac;
|
ref_handle = (moal_handle *)handle->pref_mac;
|
||||||
|
@ -1740,12 +1782,10 @@ mlan_status moal_recv_event(t_void *pmoal, pmlan_event pmevent)
|
||||||
PRINTM(MEVENT, "event id:0x%x\n", pmevent->event_id);
|
PRINTM(MEVENT, "event id:0x%x\n", pmevent->event_id);
|
||||||
#if defined(PCIE)
|
#if defined(PCIE)
|
||||||
if (pmevent->event_id == MLAN_EVENT_ID_SSU_DUMP_FILE) {
|
if (pmevent->event_id == MLAN_EVENT_ID_SSU_DUMP_FILE) {
|
||||||
woal_store_ssu_dump(pmoal, pmevent);
|
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
#endif /* SSU_SUPPORT */
|
#endif /* SSU_SUPPORT */
|
||||||
if (pmevent->event_id == MLAN_EVENT_ID_STORE_HOST_CMD_RESP) {
|
if (pmevent->event_id == MLAN_EVENT_ID_STORE_HOST_CMD_RESP) {
|
||||||
woal_save_host_cmdresp(handle, (mlan_cmdresp_event *)pmevent);
|
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
priv = woal_bss_index_to_priv(pmoal, pmevent->bss_index);
|
priv = woal_bss_index_to_priv(pmoal, pmevent->bss_index);
|
||||||
|
@ -2278,17 +2318,11 @@ mlan_status moal_recv_event(t_void *pmoal, pmlan_event pmevent)
|
||||||
ref_handle = (moal_handle *)priv->phandle->pref_mac;
|
ref_handle = (moal_handle *)priv->phandle->pref_mac;
|
||||||
if (ref_handle)
|
if (ref_handle)
|
||||||
ref_handle->driver_status = MTRUE;
|
ref_handle->driver_status = MTRUE;
|
||||||
|
if (drvdbg & MFW_D)
|
||||||
|
auto_fw_dump = MTRUE;
|
||||||
|
|
||||||
woal_moal_debug_info(priv, NULL, MFALSE);
|
woal_moal_debug_info(priv, NULL, MFALSE);
|
||||||
woal_broadcast_event(priv, CUS_EVT_DRIVER_HANG,
|
if (!auto_fw_dump && !handle->fw_dump)
|
||||||
strlen(CUS_EVT_DRIVER_HANG));
|
|
||||||
#ifdef STA_CFG80211
|
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 14, 0)
|
|
||||||
if (IS_STA_OR_UAP_CFG80211(cfg80211_wext))
|
|
||||||
woal_cfg80211_vendor_event(priv, event_hang,
|
|
||||||
CUS_EVT_DRIVER_HANG,
|
|
||||||
strlen(CUS_EVT_DRIVER_HANG));
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
woal_process_hang(priv->phandle);
|
woal_process_hang(priv->phandle);
|
||||||
wifi_status = 2;
|
wifi_status = 2;
|
||||||
break;
|
break;
|
||||||
|
@ -2337,6 +2371,18 @@ mlan_status moal_recv_event(t_void *pmoal, pmlan_event pmevent)
|
||||||
#endif
|
#endif
|
||||||
wake_up_interruptible(
|
wake_up_interruptible(
|
||||||
&priv->phandle->reassoc_thread.wait_q);
|
&priv->phandle->reassoc_thread.wait_q);
|
||||||
|
} else {
|
||||||
|
#if CFG80211_VERSION_CODE > KERNEL_VERSION(2, 6, 35)
|
||||||
|
if (priv->mrvl_rssi_low) {
|
||||||
|
cfg80211_cqm_rssi_notify(
|
||||||
|
priv->netdev,
|
||||||
|
NL80211_CQM_RSSI_THRESHOLD_EVENT_LOW,
|
||||||
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(4, 11, 0)
|
||||||
|
0,
|
||||||
|
#endif
|
||||||
|
GFP_KERNEL);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -2359,14 +2405,10 @@ mlan_status moal_recv_event(t_void *pmoal, pmlan_event pmevent)
|
||||||
!priv->phandle->cfg80211_suspend) {
|
!priv->phandle->cfg80211_suspend) {
|
||||||
woal_inform_bss_from_scan_result(priv, NULL,
|
woal_inform_bss_from_scan_result(priv, NULL,
|
||||||
MOAL_NO_WAIT);
|
MOAL_NO_WAIT);
|
||||||
cfg80211_sched_scan_results(priv->wdev->wiphy
|
PRINTM(MMSG,
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(4, 12, 0)
|
"wlan: Report sched_scan result\n");
|
||||||
,
|
woal_report_sched_scan_result(priv);
|
||||||
priv->bg_scan_reqid
|
|
||||||
#endif
|
|
||||||
);
|
|
||||||
priv->last_event = 0;
|
priv->last_event = 0;
|
||||||
woal_bgscan_stop_event(priv);
|
|
||||||
PRINTM(MEVENT,
|
PRINTM(MEVENT,
|
||||||
"Reporting Sched_Scan results\n");
|
"Reporting Sched_Scan results\n");
|
||||||
}
|
}
|
||||||
|
@ -2988,6 +3030,11 @@ mlan_status moal_recv_event(t_void *pmoal, pmlan_event pmevent)
|
||||||
PRINTM(MEVENT,
|
PRINTM(MEVENT,
|
||||||
"HostMlme %s: Receive deauth/disassociate\n",
|
"HostMlme %s: Receive deauth/disassociate\n",
|
||||||
priv->netdev->name);
|
priv->netdev->name);
|
||||||
|
if (!priv->wdev->current_bss) {
|
||||||
|
PRINTM(MEVENT,
|
||||||
|
"HostMlme: Drop deauth/disassociate, current_bss = null\n");
|
||||||
|
break;
|
||||||
|
}
|
||||||
priv->cfg_disconnect = MTRUE;
|
priv->cfg_disconnect = MTRUE;
|
||||||
woal_mgmt_frame_register(
|
woal_mgmt_frame_register(
|
||||||
priv,
|
priv,
|
||||||
|
@ -3003,11 +3050,6 @@ mlan_status moal_recv_event(t_void *pmoal, pmlan_event pmevent)
|
||||||
priv->host_mlme = MFALSE;
|
priv->host_mlme = MFALSE;
|
||||||
priv->auth_flag = 0;
|
priv->auth_flag = 0;
|
||||||
priv->auth_alg = 0xFFFF;
|
priv->auth_alg = 0xFFFF;
|
||||||
if (!priv->wdev->current_bss) {
|
|
||||||
PRINTM(MEVENT,
|
|
||||||
"HostMlme: Drop deauth/disassociate, we already disconnected\n");
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 11, 0)
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 11, 0)
|
||||||
woal_rx_mgmt_pkt_event(
|
woal_rx_mgmt_pkt_event(
|
||||||
|
|
|
@ -118,12 +118,14 @@ mlan_status moal_stop_timer(t_void *pmoal, t_void *ptimer);
|
||||||
void moal_tp_accounting(t_void *pmoal, void *buf, t_u32 drop_point);
|
void moal_tp_accounting(t_void *pmoal, void *buf, t_u32 drop_point);
|
||||||
void moal_tp_accounting_rx_param(t_void *pmoal, unsigned int type,
|
void moal_tp_accounting_rx_param(t_void *pmoal, unsigned int type,
|
||||||
unsigned int rsvd1);
|
unsigned int rsvd1);
|
||||||
|
void moal_amsdu_tp_accounting(t_void *pmoal, t_s32 amsdu_process_delay,
|
||||||
|
t_s32 amsdu_copy_delay);
|
||||||
|
|
||||||
#if defined(PCIE) || defined(SDIO)
|
#if defined(PCIE) || defined(SDIO)
|
||||||
/* pmqos busfreq add request handler*/
|
/* pmqos busfreq add request handler*/
|
||||||
void woal_request_busfreq_pmqos_add(t_u16 card_type);
|
void woal_request_busfreq_pmqos_add(t_void *pmhandle);
|
||||||
/* pmqos busfreq remove handler*/
|
/* pmqos busfreq remove handler*/
|
||||||
void woal_release_busfreq_pmqos_remove(t_u16 card_type);
|
void woal_release_busfreq_pmqos_remove(t_void *pmhandle);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif /*_MOAL_H */
|
#endif /*_MOAL_H */
|
||||||
|
|
|
@ -40,7 +40,7 @@ static const u32 cfg80211_cipher_suites[] = {
|
||||||
WLAN_CIPHER_SUITE_TKIP, WLAN_CIPHER_SUITE_CCMP,
|
WLAN_CIPHER_SUITE_TKIP, WLAN_CIPHER_SUITE_CCMP,
|
||||||
WLAN_CIPHER_SUITE_SMS4, WLAN_CIPHER_SUITE_AES_CMAC,
|
WLAN_CIPHER_SUITE_SMS4, WLAN_CIPHER_SUITE_AES_CMAC,
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(4, 0, 0)
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(4, 0, 0)
|
||||||
WLAN_CIPHER_SUITE_BIP_GMAC_256,
|
WLAN_CIPHER_SUITE_BIP_GMAC_128, WLAN_CIPHER_SUITE_BIP_GMAC_256,
|
||||||
#endif
|
#endif
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 6, 0)
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 6, 0)
|
||||||
WLAN_CIPHER_SUITE_GCMP,
|
WLAN_CIPHER_SUITE_GCMP,
|
||||||
|
@ -295,6 +295,10 @@ static struct cfg80211_ops woal_cfg80211_ops = {
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(2, 6, 30)
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(2, 6, 30)
|
||||||
.set_default_mgmt_key = woal_cfg80211_set_default_mgmt_key,
|
.set_default_mgmt_key = woal_cfg80211_set_default_mgmt_key,
|
||||||
#endif
|
#endif
|
||||||
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 10, 0)
|
||||||
|
.set_default_beacon_key = woal_cfg80211_set_default_beacon_key,
|
||||||
|
#endif
|
||||||
|
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 1, 0)
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 1, 0)
|
||||||
.set_rekey_data = woal_cfg80211_set_rekey_data,
|
.set_rekey_data = woal_cfg80211_set_rekey_data,
|
||||||
#endif
|
#endif
|
||||||
|
@ -810,6 +814,7 @@ static int woal_cfg80211_assoc_ies_cfg(moal_private *priv, t_u8 *ie, int ie_len,
|
||||||
PRINTM(MIOCTL, "Enable WPS session\n");
|
PRINTM(MIOCTL, "Enable WPS session\n");
|
||||||
woal_wps_cfg(priv, MTRUE);
|
woal_wps_cfg(priv, MTRUE);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!memcmp(pvendor_ie->vend_hdr.oui, hs20_oui,
|
if (!memcmp(pvendor_ie->vend_hdr.oui, hs20_oui,
|
||||||
sizeof(pvendor_ie->vend_hdr.oui)) &&
|
sizeof(pvendor_ie->vend_hdr.oui)) &&
|
||||||
(pvendor_ie->vend_hdr.oui_type == hs20_oui[3])) {
|
(pvendor_ie->vend_hdr.oui_type == hs20_oui[3])) {
|
||||||
|
@ -1983,6 +1988,9 @@ static int woal_cfg80211_authenticate(struct wiphy *wiphy,
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** cancel pending scan */
|
||||||
|
woal_cancel_scan(priv, MOAL_IOCTL_WAIT);
|
||||||
|
|
||||||
ssid_bssid = kzalloc(sizeof(mlan_ssid_bssid), GFP_ATOMIC);
|
ssid_bssid = kzalloc(sizeof(mlan_ssid_bssid), GFP_ATOMIC);
|
||||||
if (!ssid_bssid) {
|
if (!ssid_bssid) {
|
||||||
PRINTM(MERROR, "Fail to allocate ssid_bssid buffer\n");
|
PRINTM(MERROR, "Fail to allocate ssid_bssid buffer\n");
|
||||||
|
@ -2023,10 +2031,6 @@ static int woal_cfg80211_authenticate(struct wiphy *wiphy,
|
||||||
LEAVE();
|
LEAVE();
|
||||||
return -EBUSY;
|
return -EBUSY;
|
||||||
}
|
}
|
||||||
|
|
||||||
/** cancel pending scan */
|
|
||||||
woal_cancel_scan(priv, MOAL_IOCTL_WAIT);
|
|
||||||
|
|
||||||
#ifdef WIFI_DIRECT_SUPPORT
|
#ifdef WIFI_DIRECT_SUPPORT
|
||||||
if (priv->bss_type == MLAN_BSS_TYPE_WIFIDIRECT &&
|
if (priv->bss_type == MLAN_BSS_TYPE_WIFIDIRECT &&
|
||||||
(priv->wdev->iftype == NL80211_IFTYPE_STATION ||
|
(priv->wdev->iftype == NL80211_IFTYPE_STATION ||
|
||||||
|
@ -2498,6 +2502,9 @@ static int woal_cfg80211_associate(struct wiphy *wiphy, struct net_device *dev,
|
||||||
return -EBUSY;
|
return -EBUSY;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** cancel pending scan */
|
||||||
|
woal_cancel_scan(priv, MOAL_IOCTL_WAIT);
|
||||||
|
|
||||||
priv->cfg_connect = MTRUE;
|
priv->cfg_connect = MTRUE;
|
||||||
priv->assoc_status = 0;
|
priv->assoc_status = 0;
|
||||||
priv->auth_alg = 0xFFFF;
|
priv->auth_alg = 0xFFFF;
|
||||||
|
@ -3403,8 +3410,9 @@ static int compare(const void *lhs, const void *rhs)
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief This function update channel region config
|
* @brief This function get channel reg_rule flags
|
||||||
*
|
*
|
||||||
* @param buf Buffer containing channel region config
|
* @param buf Buffer containing channel region config
|
||||||
* @param num_chan Length of buffer
|
* @param num_chan Length of buffer
|
||||||
|
@ -3412,6 +3420,78 @@ static int compare(const void *lhs, const void *rhs)
|
||||||
*
|
*
|
||||||
* @return N/A
|
* @return N/A
|
||||||
*/
|
*/
|
||||||
|
t_u32 woal_get_chan_rule_flags(mlan_ds_custom_reg_domain *custom_reg,
|
||||||
|
t_u8 channel)
|
||||||
|
{
|
||||||
|
t_u16 num_chan = 0;
|
||||||
|
t_u32 flags = 0;
|
||||||
|
int idx;
|
||||||
|
t_u16 chflags;
|
||||||
|
|
||||||
|
num_chan = custom_reg->num_bg_chan;
|
||||||
|
num_chan += custom_reg->num_a_chan;
|
||||||
|
for (idx = 0; idx < num_chan; idx++) {
|
||||||
|
chflags = custom_reg->cfp_tbl[idx].dynamic.flags;
|
||||||
|
if (chflags & NXP_CHANNEL_DISABLED)
|
||||||
|
continue;
|
||||||
|
if (custom_reg->cfp_tbl[idx].channel == channel) {
|
||||||
|
if (chflags & NXP_CHANNEL_PASSIVE)
|
||||||
|
flags |= NL80211_RRF_NO_IR;
|
||||||
|
if (chflags & NXP_CHANNEL_DFS)
|
||||||
|
flags |= NL80211_RRF_DFS;
|
||||||
|
if (chflags & NXP_CHANNEL_NO_OFDM)
|
||||||
|
flags |= NL80211_RRF_NO_OFDM;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return flags;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief This function update the beaconng flags of channel
|
||||||
|
*
|
||||||
|
* @param custom_reg pointer to mlan_ds_custom_reg_domain
|
||||||
|
*
|
||||||
|
* @return pointer to ieee80211_regdomain
|
||||||
|
*/
|
||||||
|
|
||||||
|
static void
|
||||||
|
woal_reg_apply_beaconing_flags(struct wiphy *wiphy,
|
||||||
|
mlan_ds_custom_reg_domain *custom_reg)
|
||||||
|
{
|
||||||
|
struct ieee80211_supported_band *sband;
|
||||||
|
struct ieee80211_channel *ch;
|
||||||
|
int band, i;
|
||||||
|
t_u32 rule_flags = 0;
|
||||||
|
|
||||||
|
for (band = 0; band < NUM_NL80211_BANDS; band++) {
|
||||||
|
sband = wiphy->bands[band];
|
||||||
|
if (!sband)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
for (i = 0; i < sband->n_channels; i++) {
|
||||||
|
ch = &sband->channels[i];
|
||||||
|
|
||||||
|
if (ch->flags &
|
||||||
|
(IEEE80211_CHAN_DISABLED | IEEE80211_CHAN_RADAR))
|
||||||
|
continue;
|
||||||
|
|
||||||
|
rule_flags = woal_get_chan_rule_flags(custom_reg,
|
||||||
|
ch->hw_value);
|
||||||
|
|
||||||
|
if (!(rule_flags & NL80211_RRF_NO_IR))
|
||||||
|
ch->flags &= ~IEEE80211_CHAN_NO_IR;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief This function create the custom regdomain
|
||||||
|
*
|
||||||
|
* @param custom_reg pointer to mlan_ds_custom_reg_domain
|
||||||
|
*
|
||||||
|
* @return pointer to ieee80211_regdomain
|
||||||
|
*/
|
||||||
static struct ieee80211_regdomain *
|
static struct ieee80211_regdomain *
|
||||||
create_custom_regdomain(mlan_ds_custom_reg_domain *custom_reg)
|
create_custom_regdomain(mlan_ds_custom_reg_domain *custom_reg)
|
||||||
{
|
{
|
||||||
|
@ -3439,65 +3519,6 @@ create_custom_regdomain(mlan_ds_custom_reg_domain *custom_reg)
|
||||||
if (!regd) {
|
if (!regd) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
#define NXP_CHANNEL_TMP_NOHT40 MBIT(15)
|
|
||||||
/* preprocess 2.4G 40MHz support */
|
|
||||||
for (idx = 0; idx < num_chan; idx++) {
|
|
||||||
chan = custom_reg->cfp_tbl[idx].channel;
|
|
||||||
if (!chan) {
|
|
||||||
if (regd)
|
|
||||||
kfree(regd);
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (chan > 14)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
chflags = custom_reg->cfp_tbl[idx].dynamic.flags;
|
|
||||||
|
|
||||||
if (chflags & NXP_CHANNEL_DISABLED)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
/* duplicate a temp flag */
|
|
||||||
if (chflags & NXP_CHANNEL_NOHT40)
|
|
||||||
chflags |= NXP_CHANNEL_TMP_NOHT40;
|
|
||||||
}
|
|
||||||
for (idx = 0; idx < num_chan; idx++) {
|
|
||||||
chan = custom_reg->cfp_tbl[idx].channel;
|
|
||||||
if (!chan) {
|
|
||||||
if (regd)
|
|
||||||
kfree(regd);
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (chan > 14)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
chflags = custom_reg->cfp_tbl[idx].dynamic.flags;
|
|
||||||
|
|
||||||
if (chflags & NXP_CHANNEL_DISABLED)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
/* 40 MHz band of one center channel will spread to upper and
|
|
||||||
* lower 2 channels */
|
|
||||||
/* Mark HT40 flag for all channels of this 40 MHz band */
|
|
||||||
if (!(chflags & NXP_CHANNEL_TMP_NOHT40)) {
|
|
||||||
if (idx >= 2)
|
|
||||||
custom_reg->cfp_tbl[idx - 2].dynamic.flags &=
|
|
||||||
~NXP_CHANNEL_NOHT40;
|
|
||||||
if (idx >= 1)
|
|
||||||
custom_reg->cfp_tbl[idx - 1].dynamic.flags &=
|
|
||||||
~NXP_CHANNEL_NOHT40;
|
|
||||||
if (idx < (num_chan - 1))
|
|
||||||
custom_reg->cfp_tbl[idx + 1].dynamic.flags &=
|
|
||||||
~NXP_CHANNEL_NOHT40;
|
|
||||||
if (idx < (num_chan - 2))
|
|
||||||
custom_reg->cfp_tbl[idx + 2].dynamic.flags &=
|
|
||||||
~NXP_CHANNEL_NOHT40;
|
|
||||||
} else {
|
|
||||||
custom_reg->cfp_tbl[idx].dynamic.flags &=
|
|
||||||
~NXP_CHANNEL_TMP_NOHT40;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
for (idx = 0; idx < num_chan; idx++) {
|
for (idx = 0; idx < num_chan; idx++) {
|
||||||
enum ieee80211_band band;
|
enum ieee80211_band band;
|
||||||
|
|
||||||
|
@ -3679,8 +3700,13 @@ static int woal_update_custom_regdomain(moal_private *priv, struct wiphy *wiphy)
|
||||||
wiphy->regulatory_flags &=
|
wiphy->regulatory_flags &=
|
||||||
~(REGULATORY_STRICT_REG | REGULATORY_CUSTOM_REG);
|
~(REGULATORY_STRICT_REG | REGULATORY_CUSTOM_REG);
|
||||||
wiphy->regulatory_flags |= REGULATORY_WIPHY_SELF_MANAGED;
|
wiphy->regulatory_flags |= REGULATORY_WIPHY_SELF_MANAGED;
|
||||||
regulatory_set_wiphy_regd(wiphy, regd);
|
ret = regulatory_set_wiphy_regd(wiphy, regd);
|
||||||
kfree(regd);
|
kfree(regd);
|
||||||
|
if (!ret) {
|
||||||
|
woal_sched_timeout(100);
|
||||||
|
woal_reg_apply_beaconing_flags(
|
||||||
|
wiphy, &misc->param.custom_reg_domain);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
done:
|
done:
|
||||||
if (status != MLAN_STATUS_PENDING)
|
if (status != MLAN_STATUS_PENDING)
|
||||||
|
@ -3821,8 +3847,7 @@ woal_cfg80211_reg_notifier(struct wiphy *wiphy,
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (priv->wdev && priv->wdev->wiphy &&
|
if (priv->wdev && priv->wdev->wiphy &&
|
||||||
(request->initiator != NL80211_REGDOM_SET_BY_COUNTRY_IE) &&
|
(request->initiator != NL80211_REGDOM_SET_BY_COUNTRY_IE)) {
|
||||||
(MTRUE != is_cfg80211_special_region_code(region))) {
|
|
||||||
band = priv->phandle->band;
|
band = priv->phandle->band;
|
||||||
priv->phandle->band = IEEE80211_BAND_2GHZ;
|
priv->phandle->band = IEEE80211_BAND_2GHZ;
|
||||||
woal_send_domain_info_cmd_fw(priv, MOAL_IOCTL_WAIT);
|
woal_send_domain_info_cmd_fw(priv, MOAL_IOCTL_WAIT);
|
||||||
|
@ -4049,12 +4074,19 @@ static t_u8 woal_is_scan_result_expired(moal_private *priv)
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
if (!priv->media_connected) {
|
||||||
|
LEAVE();
|
||||||
|
return MTRUE;
|
||||||
|
}
|
||||||
if (MLAN_STATUS_SUCCESS !=
|
if (MLAN_STATUS_SUCCESS !=
|
||||||
woal_get_scan_table(priv, MOAL_IOCTL_WAIT, &scan_resp)) {
|
woal_get_scan_table(priv, MOAL_IOCTL_WAIT, &scan_resp)) {
|
||||||
LEAVE();
|
LEAVE();
|
||||||
return MTRUE;
|
return MTRUE;
|
||||||
}
|
}
|
||||||
|
if (!scan_resp.num_in_scan_table) {
|
||||||
|
LEAVE();
|
||||||
|
return MTRUE;
|
||||||
|
}
|
||||||
woal_get_monotonic_time(&t);
|
woal_get_monotonic_time(&t);
|
||||||
/** scan result expired value */
|
/** scan result expired value */
|
||||||
#define SCAN_RESULT_EXPIRTED 1
|
#define SCAN_RESULT_EXPIRTED 1
|
||||||
|
@ -4232,8 +4264,7 @@ static int woal_cfg80211_scan(struct wiphy *wiphy, struct net_device *dev,
|
||||||
if (scan_req->scan_chan_gap && priv->phandle->pref_mac)
|
if (scan_req->scan_chan_gap && priv->phandle->pref_mac)
|
||||||
scan_req->scan_chan_gap |= GAP_FLAG_OPTIONAL;
|
scan_req->scan_chan_gap |= GAP_FLAG_OPTIONAL;
|
||||||
|
|
||||||
if (priv->phandle->scan_request->n_channels <= 38 &&
|
if (priv->phandle->scan_request->n_channels <= 38) {
|
||||||
!woal_is_any_interface_active(priv->phandle)) {
|
|
||||||
if (scan_cfg.ext_scan == 3)
|
if (scan_cfg.ext_scan == 3)
|
||||||
scan_req->ext_scan_type = EXT_SCAN_ENHANCE;
|
scan_req->ext_scan_type = EXT_SCAN_ENHANCE;
|
||||||
}
|
}
|
||||||
|
@ -5087,6 +5118,8 @@ static int woal_cfg80211_disconnect(struct wiphy *wiphy, struct net_device *dev,
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** cancel pending scan */
|
||||||
|
woal_cancel_scan(priv, MOAL_IOCTL_WAIT);
|
||||||
priv->cfg_disconnect = MTRUE;
|
priv->cfg_disconnect = MTRUE;
|
||||||
if (woal_disconnect(priv, MOAL_IOCTL_WAIT_TIMEOUT, priv->cfg_bssid,
|
if (woal_disconnect(priv, MOAL_IOCTL_WAIT_TIMEOUT, priv->cfg_bssid,
|
||||||
reason_code) != MLAN_STATUS_SUCCESS) {
|
reason_code) != MLAN_STATUS_SUCCESS) {
|
||||||
|
@ -6150,6 +6183,7 @@ int woal_cfg80211_sched_scan_start(struct wiphy *wiphy, struct net_device *dev,
|
||||||
MAC2STR(priv->scan_cfg.random_mac));
|
MAC2STR(priv->scan_cfg.random_mac));
|
||||||
if (MLAN_STATUS_SUCCESS ==
|
if (MLAN_STATUS_SUCCESS ==
|
||||||
woal_request_bgscan(priv, MOAL_IOCTL_WAIT, &priv->scan_cfg)) {
|
woal_request_bgscan(priv, MOAL_IOCTL_WAIT, &priv->scan_cfg)) {
|
||||||
|
PRINTM(MMSG, "wlan: sched scan start\n");
|
||||||
priv->sched_scanning = MTRUE;
|
priv->sched_scanning = MTRUE;
|
||||||
priv->bg_scan_start = MTRUE;
|
priv->bg_scan_start = MTRUE;
|
||||||
priv->bg_scan_reported = MFALSE;
|
priv->bg_scan_reported = MFALSE;
|
||||||
|
@ -6180,7 +6214,7 @@ int woal_cfg80211_sched_scan_stop(struct wiphy *wiphy, struct net_device *dev
|
||||||
{
|
{
|
||||||
moal_private *priv = (moal_private *)woal_get_netdev_priv(dev);
|
moal_private *priv = (moal_private *)woal_get_netdev_priv(dev);
|
||||||
ENTER();
|
ENTER();
|
||||||
PRINTM(MIOCTL, "sched scan stop\n");
|
PRINTM(MMSG, "wlan: sched scan stop\n");
|
||||||
priv->sched_scanning = MFALSE;
|
priv->sched_scanning = MFALSE;
|
||||||
woal_stop_bg_scan(priv, MOAL_NO_WAIT);
|
woal_stop_bg_scan(priv, MOAL_NO_WAIT);
|
||||||
priv->bg_scan_start = MFALSE;
|
priv->bg_scan_start = MFALSE;
|
||||||
|
@ -6224,16 +6258,10 @@ int woal_cfg80211_resume(struct wiphy *wiphy)
|
||||||
woal_inform_bss_from_scan_result(
|
woal_inform_bss_from_scan_result(
|
||||||
handle->priv[i], NULL,
|
handle->priv[i], NULL,
|
||||||
MOAL_IOCTL_WAIT);
|
MOAL_IOCTL_WAIT);
|
||||||
cfg80211_sched_scan_results(
|
woal_report_sched_scan_result(
|
||||||
handle->priv[i]->wdev->wiphy
|
handle->priv[i]);
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(4, 12, 0)
|
|
||||||
,
|
|
||||||
0
|
|
||||||
#endif
|
|
||||||
);
|
|
||||||
woal_bgscan_stop_event(handle->priv[i]);
|
|
||||||
handle->priv[i]->last_event = 0;
|
handle->priv[i]->last_event = 0;
|
||||||
PRINTM(MIOCTL,
|
PRINTM(MCMND,
|
||||||
"Report sched scan result in cfg80211 resume\n");
|
"Report sched scan result in cfg80211 resume\n");
|
||||||
}
|
}
|
||||||
if (!moal_extflg_isset(handle, EXT_HW_TEST) &&
|
if (!moal_extflg_isset(handle, EXT_HW_TEST) &&
|
||||||
|
@ -8075,7 +8103,6 @@ static int woal_cfg80211_change_station(struct wiphy *wiphy,
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
|
||||||
ENTER();
|
ENTER();
|
||||||
|
|
||||||
/**do nothing*/
|
/**do nothing*/
|
||||||
|
|
||||||
LEAVE();
|
LEAVE();
|
||||||
|
@ -9142,6 +9169,10 @@ static mlan_status woal_cfg80211_init_wiphy(moal_private *priv,
|
||||||
woal_cfg80211_setup_ht_cap(
|
woal_cfg80211_setup_ht_cap(
|
||||||
&wiphy->bands[IEEE80211_BAND_2GHZ]->ht_cap, hw_dev_cap,
|
&wiphy->bands[IEEE80211_BAND_2GHZ]->ht_cap, hw_dev_cap,
|
||||||
cfg_11n->param.supported_mcs_set);
|
cfg_11n->param.supported_mcs_set);
|
||||||
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 6, 0)
|
||||||
|
woal_cfg80211_setup_vht_cap(
|
||||||
|
priv, &wiphy->bands[IEEE80211_BAND_2GHZ]->vht_cap);
|
||||||
|
#endif
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(4, 20, 0)
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(4, 20, 0)
|
||||||
woal_cfg80211_setup_he_cap(priv,
|
woal_cfg80211_setup_he_cap(priv,
|
||||||
wiphy->bands[IEEE80211_BAND_2GHZ]);
|
wiphy->bands[IEEE80211_BAND_2GHZ]);
|
||||||
|
@ -9462,7 +9493,9 @@ mlan_status woal_register_cfg80211(moal_private *priv)
|
||||||
if (!moal_extflg_isset(priv->phandle, EXT_HOST_MLME))
|
if (!moal_extflg_isset(priv->phandle, EXT_HOST_MLME))
|
||||||
#endif
|
#endif
|
||||||
wiphy->flags |= WIPHY_FLAG_HAVE_AP_SME;
|
wiphy->flags |= WIPHY_FLAG_HAVE_AP_SME;
|
||||||
|
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 2, 0)
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 2, 0)
|
||||||
|
if (priv->phandle->params.sched_scan) {
|
||||||
#if CFG80211_VERSION_CODE < KERNEL_VERSION(4, 12, 0)
|
#if CFG80211_VERSION_CODE < KERNEL_VERSION(4, 12, 0)
|
||||||
wiphy->flags |= WIPHY_FLAG_SUPPORTS_SCHED_SCAN;
|
wiphy->flags |= WIPHY_FLAG_SUPPORTS_SCHED_SCAN;
|
||||||
#else
|
#else
|
||||||
|
@ -9475,6 +9508,7 @@ mlan_status woal_register_cfg80211(moal_private *priv)
|
||||||
wiphy->max_sched_scan_plans = 3;
|
wiphy->max_sched_scan_plans = 3;
|
||||||
wiphy->max_sched_scan_plan_iterations = 100;
|
wiphy->max_sched_scan_plan_iterations = 100;
|
||||||
#endif
|
#endif
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 4, 0)
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 4, 0)
|
||||||
wiphy->features |= NL80211_FEATURE_INACTIVITY_TIMER;
|
wiphy->features |= NL80211_FEATURE_INACTIVITY_TIMER;
|
||||||
|
@ -9494,7 +9528,6 @@ mlan_status woal_register_cfg80211(moal_private *priv)
|
||||||
if (moal_extflg_isset(priv->phandle, EXT_HOST_MLME))
|
if (moal_extflg_isset(priv->phandle, EXT_HOST_MLME))
|
||||||
wiphy->features |= NL80211_FEATURE_SAE;
|
wiphy->features |= NL80211_FEATURE_SAE;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 8, 0)
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 8, 0)
|
||||||
wiphy->features |= NL80211_FEATURE_NEED_OBSS_SCAN;
|
wiphy->features |= NL80211_FEATURE_NEED_OBSS_SCAN;
|
||||||
#endif
|
#endif
|
||||||
|
@ -9518,6 +9551,13 @@ mlan_status woal_register_cfg80211(moal_private *priv)
|
||||||
wiphy->features |= NL80211_FEATURE_SCAN_RANDOM_MAC_ADDR;
|
wiphy->features |= NL80211_FEATURE_SCAN_RANDOM_MAC_ADDR;
|
||||||
wiphy->features |= NL80211_FEATURE_SCHED_SCAN_RANDOM_MAC_ADDR;
|
wiphy->features |= NL80211_FEATURE_SCHED_SCAN_RANDOM_MAC_ADDR;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(4, 11, 0)
|
||||||
|
wiphy_ext_feature_set(wiphy, NL80211_EXT_FEATURE_MGMT_TX_RANDOM_TA);
|
||||||
|
wiphy_ext_feature_set(wiphy,
|
||||||
|
NL80211_EXT_FEATURE_MGMT_TX_RANDOM_TA_CONNECTED);
|
||||||
|
#endif
|
||||||
|
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(4, 8, 0)
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(4, 8, 0)
|
||||||
wiphy_ext_feature_set(wiphy, NL80211_EXT_FEATURE_SET_SCAN_DWELL);
|
wiphy_ext_feature_set(wiphy, NL80211_EXT_FEATURE_SET_SCAN_DWELL);
|
||||||
#endif
|
#endif
|
||||||
|
@ -9525,6 +9565,16 @@ mlan_status woal_register_cfg80211(moal_private *priv)
|
||||||
if (moal_extflg_isset(priv->phandle, EXT_HOST_MLME))
|
if (moal_extflg_isset(priv->phandle, EXT_HOST_MLME))
|
||||||
wiphy->features |= NL80211_FEATURE_SK_TX_STATUS;
|
wiphy->features |= NL80211_FEATURE_SK_TX_STATUS;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 10, 0)
|
||||||
|
if (fw_info.fw_beacon_prot) {
|
||||||
|
wiphy_ext_feature_set(wiphy,
|
||||||
|
NL80211_EXT_FEATURE_BEACON_PROTECTION);
|
||||||
|
wiphy_ext_feature_set(
|
||||||
|
wiphy, NL80211_EXT_FEATURE_BEACON_PROTECTION_CLIENT);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Set struct moal_handle pointer in wiphy_priv */
|
/* Set struct moal_handle pointer in wiphy_priv */
|
||||||
wdev_priv = wiphy_priv(wiphy);
|
wdev_priv = wiphy_priv(wiphy);
|
||||||
*(unsigned long *)wdev_priv = (unsigned long)priv->phandle;
|
*(unsigned long *)wdev_priv = (unsigned long)priv->phandle;
|
||||||
|
|
|
@ -4224,7 +4224,8 @@ void woal_uap_set_multicast_list(struct net_device *dev)
|
||||||
* @return 0 --success, otherwise fail
|
* @return 0 --success, otherwise fail
|
||||||
*/
|
*/
|
||||||
#if LINUX_VERSION_CODE >= KERNEL_VERSION(5, 15, 0)
|
#if LINUX_VERSION_CODE >= KERNEL_VERSION(5, 15, 0)
|
||||||
int woal_uap_do_ioctl(struct net_device *dev, struct ifreq *req, void __user *data, int cmd)
|
int woal_uap_do_ioctl(struct net_device *dev, struct ifreq *req,
|
||||||
|
void __user *data, int cmd)
|
||||||
#else
|
#else
|
||||||
int woal_uap_do_ioctl(struct net_device *dev, struct ifreq *req, int cmd)
|
int woal_uap_do_ioctl(struct net_device *dev, struct ifreq *req, int cmd)
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -531,11 +531,14 @@ typedef struct _domain_info_param {
|
||||||
int woal_set_get_uap_power_mode(moal_private *priv, t_u32 action,
|
int woal_set_get_uap_power_mode(moal_private *priv, t_u32 action,
|
||||||
mlan_ds_ps_mgmt *ps_mgmt);
|
mlan_ds_ps_mgmt *ps_mgmt);
|
||||||
void woal_uap_set_multicast_list(struct net_device *dev);
|
void woal_uap_set_multicast_list(struct net_device *dev);
|
||||||
|
|
||||||
#if LINUX_VERSION_CODE >= KERNEL_VERSION(5, 15, 0)
|
#if LINUX_VERSION_CODE >= KERNEL_VERSION(5, 15, 0)
|
||||||
int woal_uap_do_ioctl(struct net_device *dev, struct ifreq *req, void __user *data, int cmd);
|
int woal_uap_do_ioctl(struct net_device *dev, struct ifreq *req,
|
||||||
|
void __user *data, int cmd);
|
||||||
#else
|
#else
|
||||||
int woal_uap_do_ioctl(struct net_device *dev, struct ifreq *req, int cmd);
|
int woal_uap_do_ioctl(struct net_device *dev, struct ifreq *req, int cmd);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
int woal_uap_bss_ctrl(moal_private *priv, t_u8 wait_option, int data);
|
int woal_uap_bss_ctrl(moal_private *priv, t_u8 wait_option, int data);
|
||||||
#ifdef UAP_CFG80211
|
#ifdef UAP_CFG80211
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 12, 0)
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 12, 0)
|
||||||
|
@ -567,6 +570,7 @@ mlan_status woal_set_get_sys_config(moal_private *priv, t_u16 action,
|
||||||
mlan_status woal_set_get_ap_wmm_para(moal_private *priv, t_u16 action,
|
mlan_status woal_set_get_ap_wmm_para(moal_private *priv, t_u16 action,
|
||||||
wmm_parameter_t *ap_wmm_para);
|
wmm_parameter_t *ap_wmm_para);
|
||||||
int woal_uap_set_ap_cfg(moal_private *priv, t_u8 *data, int len);
|
int woal_uap_set_ap_cfg(moal_private *priv, t_u8 *data, int len);
|
||||||
|
|
||||||
int woal_uap_set_11ac_status(moal_private *priv, t_u8 action, t_u8 vht20_40,
|
int woal_uap_set_11ac_status(moal_private *priv, t_u8 action, t_u8 vht20_40,
|
||||||
IEEEtypes_VHTCap_t *vhtcap_ie);
|
IEEEtypes_VHTCap_t *vhtcap_ie);
|
||||||
int woal_11ax_cfg(moal_private *priv, t_u8 action, mlan_ds_11ax_he_cfg *he_cfg);
|
int woal_11ax_cfg(moal_private *priv, t_u8 action, mlan_ds_11ax_he_cfg *he_cfg);
|
||||||
|
|
|
@ -1377,6 +1377,19 @@ static int woal_cfg80211_beacon_config(moal_private *priv,
|
||||||
ret = -EFAULT;
|
ret = -EFAULT;
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** Set wacp_mode for uAP/P2P-GO */
|
||||||
|
if (priv->phandle->params.wacp_mode) {
|
||||||
|
PRINTM(MIOCTL, "wacp_mode: %d\n",
|
||||||
|
priv->phandle->params.wacp_mode);
|
||||||
|
if (MLAN_STATUS_SUCCESS !=
|
||||||
|
woal_set_wacp_mode(priv, MOAL_IOCTL_WAIT)) {
|
||||||
|
PRINTM(MERROR, "Set wacp_mode failed\n");
|
||||||
|
ret = -EFAULT;
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 12, 0)
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 12, 0)
|
||||||
woal_enable_dfs_support(priv, &priv->chan);
|
woal_enable_dfs_support(priv, &priv->chan);
|
||||||
#endif
|
#endif
|
||||||
|
@ -1846,7 +1859,7 @@ int woal_cfg80211_del_virt_if(struct wiphy *wiphy, struct net_device *dev)
|
||||||
priv->phandle->priv_num--;
|
priv->phandle->priv_num--;
|
||||||
if (dev->reg_state == NETREG_REGISTERED)
|
if (dev->reg_state == NETREG_REGISTERED)
|
||||||
#if LINUX_VERSION_CODE >= KERNEL_VERSION(5, 12, 0)
|
#if LINUX_VERSION_CODE >= KERNEL_VERSION(5, 12, 0)
|
||||||
cfg80211_unregister_netdevice(dev);
|
cfg80211_unregister_netdevice(ndev);
|
||||||
#else
|
#else
|
||||||
unregister_netdevice(dev);
|
unregister_netdevice(dev);
|
||||||
#endif
|
#endif
|
||||||
|
@ -1889,7 +1902,7 @@ void woal_remove_virtual_interface(moal_handle *handle)
|
||||||
if (priv->netdev->reg_state ==
|
if (priv->netdev->reg_state ==
|
||||||
NETREG_REGISTERED)
|
NETREG_REGISTERED)
|
||||||
#if LINUX_VERSION_CODE >= KERNEL_VERSION(5, 12, 0)
|
#if LINUX_VERSION_CODE >= KERNEL_VERSION(5, 12, 0)
|
||||||
cfg80211_unregister_netdevice(priv->netdev);
|
cfg80211_unregister_netdevice(ndev);
|
||||||
#else
|
#else
|
||||||
unregister_netdevice(priv->netdev);
|
unregister_netdevice(priv->netdev);
|
||||||
#endif
|
#endif
|
||||||
|
@ -2104,6 +2117,7 @@ int woal_cfg80211_del_virtual_intf(struct wiphy *wiphy,
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 6, 0)
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 6, 0)
|
||||||
struct net_device *dev = wdev->netdev;
|
struct net_device *dev = wdev->netdev;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
ENTER();
|
ENTER();
|
||||||
|
|
||||||
PRINTM(MIOCTL, "del virtual intf %s\n", dev->name);
|
PRINTM(MIOCTL, "del virtual intf %s\n", dev->name);
|
||||||
|
|
|
@ -111,20 +111,20 @@ int woal_uap_do_priv_ioctl(struct net_device *dev, struct ifreq *req, int cmd)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
#ifdef WIFI_DIRECT_SUPPORT
|
|
||||||
#if defined(STA_SUPPORT) && defined(UAP_SUPPORT)
|
|
||||||
case WOAL_UAP_SETONEINT_GETONEINT:
|
case WOAL_UAP_SETONEINT_GETONEINT:
|
||||||
switch (wrq->u.data.flags) {
|
switch (wrq->u.data.flags) {
|
||||||
|
#ifdef WIFI_DIRECT_SUPPORT
|
||||||
|
#if defined(STA_SUPPORT) && defined(UAP_SUPPORT)
|
||||||
case WOAL_UAP_SET_GET_BSS_ROLE:
|
case WOAL_UAP_SET_GET_BSS_ROLE:
|
||||||
ret = woal_set_get_bss_role(priv, wrq);
|
ret = woal_set_get_bss_role(priv, wrq);
|
||||||
break;
|
break;
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
default:
|
default:
|
||||||
ret = -EINVAL;
|
ret = -EINVAL;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
case WOAL_UAP_HOST_CMD:
|
case WOAL_UAP_HOST_CMD:
|
||||||
ret = woal_host_command(priv, wrq);
|
ret = woal_host_command(priv, wrq);
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -56,10 +56,10 @@ Change log:
|
||||||
/** Private command ID to get extended version */
|
/** Private command ID to get extended version */
|
||||||
#define WOAL_UAP_VEREXT 2
|
#define WOAL_UAP_VEREXT 2
|
||||||
|
|
||||||
#ifdef WIFI_DIRECT_SUPPORT
|
|
||||||
#if defined(STA_SUPPORT) && defined(UAP_SUPPORT)
|
|
||||||
/** Private command ID to set one int/get one int */
|
/** Private command ID to set one int/get one int */
|
||||||
#define WOAL_UAP_SETONEINT_GETONEINT (WOAL_UAP_IOCTL + 5)
|
#define WOAL_UAP_SETONEINT_GETONEINT (WOAL_UAP_IOCTL + 5)
|
||||||
|
#ifdef WIFI_DIRECT_SUPPORT
|
||||||
|
#if defined(STA_SUPPORT) && defined(UAP_SUPPORT)
|
||||||
/** Private command ID for set/get BSS role */
|
/** Private command ID for set/get BSS role */
|
||||||
#define WOAL_UAP_SET_GET_BSS_ROLE 1
|
#define WOAL_UAP_SET_GET_BSS_ROLE 1
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -75,14 +75,15 @@ static const struct iw_priv_args woal_uap_priv_args[] = {
|
||||||
"version"},
|
"version"},
|
||||||
{WOAL_UAP_VEREXT, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_CHAR | 128,
|
{WOAL_UAP_VEREXT, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_CHAR | 128,
|
||||||
"verext"},
|
"verext"},
|
||||||
#ifdef WIFI_DIRECT_SUPPORT
|
|
||||||
#if defined(STA_SUPPORT) && defined(UAP_SUPPORT)
|
|
||||||
{WOAL_UAP_SETONEINT_GETONEINT, IW_PRIV_TYPE_INT | 1,
|
{WOAL_UAP_SETONEINT_GETONEINT, IW_PRIV_TYPE_INT | 1,
|
||||||
IW_PRIV_TYPE_INT | 1, ""},
|
IW_PRIV_TYPE_INT | 1, ""},
|
||||||
|
#ifdef WIFI_DIRECT_SUPPORT
|
||||||
|
#if defined(STA_SUPPORT) && defined(UAP_SUPPORT)
|
||||||
{WOAL_UAP_SET_GET_BSS_ROLE, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_INT | 1,
|
{WOAL_UAP_SET_GET_BSS_ROLE, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_INT | 1,
|
||||||
"bssrole"},
|
"bssrole"},
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
{WOAL_UAP_SET_GET_256_CHAR, IW_PRIV_TYPE_CHAR | 256,
|
{WOAL_UAP_SET_GET_256_CHAR, IW_PRIV_TYPE_CHAR | 256,
|
||||||
IW_PRIV_TYPE_CHAR | 256, ""},
|
IW_PRIV_TYPE_CHAR | 256, ""},
|
||||||
{WOAL_WL_FW_RELOAD, IW_PRIV_TYPE_CHAR | 256, IW_PRIV_TYPE_CHAR | 256,
|
{WOAL_WL_FW_RELOAD, IW_PRIV_TYPE_CHAR | 256, IW_PRIV_TYPE_CHAR | 256,
|
||||||
|
|
|
@ -266,13 +266,13 @@ static void woal_usb_receive(struct urb *urb)
|
||||||
if (status == MLAN_STATUS_PENDING) {
|
if (status == MLAN_STATUS_PENDING) {
|
||||||
queue_work(handle->workqueue, &handle->main_work);
|
queue_work(handle->workqueue, &handle->main_work);
|
||||||
/* urb for data_ep is re-submitted now, unless we reach
|
/* urb for data_ep is re-submitted now, unless we reach
|
||||||
* HIGH_RX_PENDING */
|
* USB_HIGH_RX_PENDING */
|
||||||
/* urb for cmd_ep will be re-submitted in callback
|
/* urb for cmd_ep will be re-submitted in callback
|
||||||
* moal_recv_complete */
|
* moal_recv_complete */
|
||||||
if (cardp->rx_cmd_ep == context->ep)
|
if (cardp->rx_cmd_ep == context->ep)
|
||||||
goto rx_exit;
|
goto rx_exit;
|
||||||
else if (atomic_read(&handle->rx_pending) >=
|
else if (atomic_read(&handle->rx_pending) >=
|
||||||
HIGH_RX_PENDING) {
|
USB_HIGH_RX_PENDING) {
|
||||||
context->pmbuf = NULL;
|
context->pmbuf = NULL;
|
||||||
goto rx_exit;
|
goto rx_exit;
|
||||||
}
|
}
|
||||||
|
@ -1919,6 +1919,8 @@ static void woal_usb_dump_fw_info(moal_handle *phandle)
|
||||||
|
|
||||||
if (status != MLAN_STATUS_PENDING)
|
if (status != MLAN_STATUS_PENDING)
|
||||||
kfree(req);
|
kfree(req);
|
||||||
|
phandle->is_fw_dump_timer_set = MTRUE;
|
||||||
|
woal_mod_timer(&phandle->fw_dump_timer, MOAL_TIMER_5S);
|
||||||
|
|
||||||
done:
|
done:
|
||||||
LEAVE();
|
LEAVE();
|
||||||
|
|
|
@ -197,6 +197,8 @@ static const struct iw_priv_args woal_private_args[] = {
|
||||||
"sysclock"},
|
"sysclock"},
|
||||||
{WOAL_HOST_CMD, IW_PRIV_TYPE_BYTE | 2047, IW_PRIV_TYPE_BYTE | 2047,
|
{WOAL_HOST_CMD, IW_PRIV_TYPE_BYTE | 2047, IW_PRIV_TYPE_BYTE | 2047,
|
||||||
"hostcmd"},
|
"hostcmd"},
|
||||||
|
{WOAL_ARP_FILTER, IW_PRIV_TYPE_BYTE | 2047, IW_PRIV_TYPE_BYTE | 2047,
|
||||||
|
"arpfilter"},
|
||||||
{WOAL_SET_INTS_GET_CHARS, IW_PRIV_TYPE_INT | 16,
|
{WOAL_SET_INTS_GET_CHARS, IW_PRIV_TYPE_INT | 16,
|
||||||
IW_PRIV_TYPE_BYTE | 256, ""},
|
IW_PRIV_TYPE_BYTE | 256, ""},
|
||||||
{WOAL_READ_EEPROM, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_BYTE | 256,
|
{WOAL_READ_EEPROM, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_BYTE | 256,
|
||||||
|
|
Loading…
Add table
Reference in a new issue