mirror of
https://github.com/nxp-imx/mwifiex.git
synced 2025-01-15 16:25:35 +00:00
mxm_wifiex: update to mxm5x17266 release
changes: 1. WCSWREL-126: Fixed PCIE9098 suspend fail on imx8mq. 2. WCSWREL-87: Hostsleep fails as DUT doesnot wake up on traffic/pattern. Signed-off-by: Sherry Sun <sherry.sun@nxp.com> Approved-by: Tian Yang <yang.tian@nxp.com>
This commit is contained in:
parent
5a5e60da84
commit
27fd8ecca5
55 changed files with 3673 additions and 1163 deletions
|
@ -37,7 +37,7 @@ CONFIG_SD8897=n
|
||||||
CONFIG_USB8897=n
|
CONFIG_USB8897=n
|
||||||
CONFIG_PCIE8897=n
|
CONFIG_PCIE8897=n
|
||||||
CONFIG_SD8977=n
|
CONFIG_SD8977=n
|
||||||
CONFIG_SD8978=n
|
CONFIG_SD8978=y
|
||||||
CONFIG_USB8978=n
|
CONFIG_USB8978=n
|
||||||
CONFIG_SD8997=y
|
CONFIG_SD8997=y
|
||||||
CONFIG_USB8997=n
|
CONFIG_USB8997=n
|
||||||
|
@ -343,6 +343,7 @@ endif
|
||||||
#ccflags-y += -Wmissing-field-initializers
|
#ccflags-y += -Wmissing-field-initializers
|
||||||
#ccflags-y += -Wstringop-truncation
|
#ccflags-y += -Wstringop-truncation
|
||||||
#ccflags-y += -Wmisleading-indentation
|
#ccflags-y += -Wmisleading-indentation
|
||||||
|
#ccflags-y += -Wunused-const-variable
|
||||||
#############################################################################
|
#############################################################################
|
||||||
# Make Targets
|
# Make Targets
|
||||||
#############################################################################
|
#############################################################################
|
||||||
|
|
|
@ -119,7 +119,8 @@
|
||||||
multi_dtim=0|x <use default DTIM interval(default) | set x*beacon_period as DTIM interval>
|
multi_dtim=0|x <use default DTIM interval(default) | set x*beacon_period as DTIM interval>
|
||||||
inact_tmo=0|x <use default IEEE ps inactivity timout value (default) | use IEEE ps inactivity timeout value x ms>
|
inact_tmo=0|x <use default IEEE ps inactivity timout value (default) | use IEEE ps inactivity timeout value x ms>
|
||||||
uap_max_sta: Maximum number of STA for UAP/GO (default 0, max 64)
|
uap_max_sta: Maximum number of STA for UAP/GO (default 0, max 64)
|
||||||
host_mlme=0|1 <Disable Host MLME support (default)| Enable Host MLME support>
|
host_mlme=0|1 <Operate in non-host_mlme mode (default)| Operate in host_mlme mode>
|
||||||
|
for supplicant/authenticator running on host side, WPA3 support is available only in host_mlme mode
|
||||||
country_ie_ignore=0|1 <Follow countryIE from AP and beacon hint enable (default) | Ignore countryIE from AP and beacon hint disable>
|
country_ie_ignore=0|1 <Follow countryIE from AP and beacon hint enable (default) | Ignore countryIE from AP and beacon hint disable>
|
||||||
beacon_hints=0|1 <enable beacon hints(default) | disable beacon hints>
|
beacon_hints=0|1 <enable beacon hints(default) | disable beacon hints>
|
||||||
|
|
||||||
|
@ -439,6 +440,8 @@ SYNOPSIS
|
||||||
mlanutl mlanX txratecfg [l] [m] [n] [o]
|
mlanutl mlanX txratecfg [l] [m] [n] [o]
|
||||||
mlanutl uapX txratecfg [l] [m] [n] [o]
|
mlanutl uapX txratecfg [l] [m] [n] [o]
|
||||||
mlanutl mlanX hssetpara condition [GPIO# [gap]] [ind_GPIO# [level]]
|
mlanutl mlanX hssetpara condition [GPIO# [gap]] [ind_GPIO# [level]]
|
||||||
|
mlanutl mlanX mefcfg <mef.conf>
|
||||||
|
mlanutl mlanX cloud_keep_alive <keep_alive.conf> <start/stop/reset>
|
||||||
|
|
||||||
DESCRIPTION
|
DESCRIPTION
|
||||||
Those commands are used to send additional commands to the NXP MLAN
|
Those commands are used to send additional commands to the NXP MLAN
|
||||||
|
@ -640,6 +643,31 @@ getlog
|
||||||
dot11AMPDUDelimiterCRCErrorCount Increments when an MPDU delimiter has a CRC error when this is the first
|
dot11AMPDUDelimiterCRCErrorCount Increments when an MPDU delimiter has a CRC error when this is the first
|
||||||
CRC error in the received A-MPDU or when the previous delimiter has been decoded correctly
|
CRC error in the received A-MPDU or when the previous delimiter has been decoded correctly
|
||||||
|
|
||||||
|
Cmd Usage: mlanutl mlanX getlog ext
|
||||||
|
The above command is used with the argument "ext" to display the following error statistics:-
|
||||||
|
|
||||||
|
rxStuckIssueCount-1
|
||||||
|
rxStuckIssueCount-2
|
||||||
|
rxStuckRecoveryCount
|
||||||
|
rxStuckTsf-1
|
||||||
|
rxStuckTsf-2
|
||||||
|
txWatchdogRecoveryCount
|
||||||
|
txWatchdogTsf-1
|
||||||
|
txWatchdogTsf-2
|
||||||
|
channelSwitchAnnouncementSent
|
||||||
|
channelSwitchState
|
||||||
|
registerClass
|
||||||
|
channelNumber
|
||||||
|
channelSwitchMode
|
||||||
|
RxResetRecoveryCount
|
||||||
|
RxIsr2NotDoneCnt
|
||||||
|
gdmaAbortCnt
|
||||||
|
gResetRxMacCnt
|
||||||
|
gOwnrshpCtlErrCnt
|
||||||
|
gOwnrshpBcnErrCnt
|
||||||
|
gOwnrshpMgtErrCnt
|
||||||
|
gOwnrshpDatErrCnt
|
||||||
|
|
||||||
getsignal
|
getsignal
|
||||||
This command gets the last and average value of RSSI, SNR and NF of
|
This command gets the last and average value of RSSI, SNR and NF of
|
||||||
Beacon and Data.
|
Beacon and Data.
|
||||||
|
@ -731,9 +759,10 @@ Usage:
|
||||||
0: Get 2.4G txpwrlimit table
|
0: Get 2.4G txpwrlimit table
|
||||||
0x10: Get 5G sub0 txpwrlimit table
|
0x10: Get 5G sub0 txpwrlimit table
|
||||||
0x11: Get 5G sub1 txpwrlimit table
|
0x11: Get 5G sub1 txpwrlimit table
|
||||||
0x12 Get 5G sub2 txpwrlimit table
|
0x12: Get 5G sub2 txpwrlimit table
|
||||||
0x1f Get all 5G txpwrlimit table
|
0x13: Get 5G sub3 txpwrlimit table
|
||||||
0xff Get both 2G and 5G txpwrlimit table
|
0x1f: Get all 5G txpwrlimit table
|
||||||
|
0xff: Get both 2G and 5G txpwrlimit table
|
||||||
<raw_data_file> driver will save fw raw data to this file.
|
<raw_data_file> driver will save fw raw data to this file.
|
||||||
|
|
||||||
Examples:
|
Examples:
|
||||||
|
@ -1403,3 +1432,27 @@ hssetpara
|
||||||
|
|
||||||
Note: The parameters will be saved in the driver and be used when host suspends.
|
Note: The parameters will be saved in the driver and be used when host suspends.
|
||||||
The ind_GPIO# and level parameters only work with specific board and firmware.
|
The ind_GPIO# and level parameters only work with specific board and firmware.
|
||||||
|
mefcfg
|
||||||
|
This command is used to set MEF settings.
|
||||||
|
|
||||||
|
Usage:
|
||||||
|
mlanutl mlanX mefcfg <mef.conf>
|
||||||
|
|
||||||
|
Where the parameter is:
|
||||||
|
mef.conf : The configuration file specifying the MEF settings.
|
||||||
|
|
||||||
|
Example:
|
||||||
|
mlanutl mlan0 mefcfg config/mef.conf
|
||||||
|
cloud_keep_alive
|
||||||
|
This command is used to start/stop send keep alive packet which set from host.And reset TCP connection.
|
||||||
|
|
||||||
|
Usage:
|
||||||
|
mlanutl mlanX cloud_keep_alive <keep_alive.conf> <start/stop/reset>
|
||||||
|
|
||||||
|
where <start/stop/reset>
|
||||||
|
start means set cloud keep alive packet and paramters to firmware. stop means stop firmware from sending keep alive packet.reset will stop and reset TCP connection when host resume.
|
||||||
|
|
||||||
|
Examples:
|
||||||
|
mlanutl mlan0 cloud_keep_alive keep_alive.conf start
|
||||||
|
mlanutl mlan0 cloud_keep_alive keep_alive.conf stop
|
||||||
|
mlanutl mlan0 cloud_keep_alive keep_alive.conf reset
|
||||||
|
|
|
@ -13,6 +13,10 @@ txpwrlimit_2g_cfg_get={
|
||||||
# 0x13 5G subband3 (5G: channel 183,184,185,187,188,
|
# 0x13 5G subband3 (5G: channel 183,184,185,187,188,
|
||||||
# 189, 192,196;
|
# 189, 192,196;
|
||||||
# 5G: channel 7,8,11,12,16,34)
|
# 5G: channel 7,8,11,12,16,34)
|
||||||
|
ChanTRPC.TlvType:2=0x0249
|
||||||
|
ChanTRPC.TlvLength:2={ # Get Tx Power Values for a particular antenna
|
||||||
|
TLVAntNum:1=0 # Antenna Num: 0 - Both, 1 - Main, 2 - Aux
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -29,6 +33,10 @@ txpwrlimit_5g_cfg_get_sub0={
|
||||||
# 0x13 5G subband3 (5G: channel 183,184,185,187,188,
|
# 0x13 5G subband3 (5G: channel 183,184,185,187,188,
|
||||||
# 189, 192,196;
|
# 189, 192,196;
|
||||||
# 5G: channel 7,8,11,12,16,34)
|
# 5G: channel 7,8,11,12,16,34)
|
||||||
|
ChanTRPC.TlvType:2=0x0249
|
||||||
|
ChanTRPC.TlvLength:2={ # Get Tx Power Values for a particular antenna
|
||||||
|
TLVAntNum:1=0 # Antenna Num: 0 - Both, 1 - Main, 2 - Aux
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -45,6 +53,10 @@ txpwrlimit_5g_cfg_get_sub1={
|
||||||
# 0x13 5G subband3 (5G: channel 183,184,185,187,188,
|
# 0x13 5G subband3 (5G: channel 183,184,185,187,188,
|
||||||
# 189, 192,196;
|
# 189, 192,196;
|
||||||
# 5G: channel 7,8,11,12,16,34)
|
# 5G: channel 7,8,11,12,16,34)
|
||||||
|
ChanTRPC.TlvType:2=0x0249
|
||||||
|
ChanTRPC.TlvLength:2={ # Get Tx Power Values for a particular antenna
|
||||||
|
TLVAntNum:1=0 # Antenna Num: 0 - Both, 1 - Main, 2 - Aux
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -61,6 +73,10 @@ txpwrlimit_5g_cfg_get_sub2={
|
||||||
# 0x13 5G subband3 (5G: channel 183,184,185,187,188,
|
# 0x13 5G subband3 (5G: channel 183,184,185,187,188,
|
||||||
# 189, 192,196;
|
# 189, 192,196;
|
||||||
# 5G: channel 7,8,11,12,16,34)
|
# 5G: channel 7,8,11,12,16,34)
|
||||||
|
ChanTRPC.TlvType:2=0x0249
|
||||||
|
ChanTRPC.TlvLength:2={ # Get Tx Power Values for a particular antenna
|
||||||
|
TLVAntNum:1=0 # Antenna Num: 0 - Both, 1 - Main, 2 - Aux
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -77,6 +93,10 @@ txpwrlimit_5g_cfg_get_sub3={
|
||||||
# 0x13 5G subband3 (5G: channel 183,184,185,187,188,
|
# 0x13 5G subband3 (5G: channel 183,184,185,187,188,
|
||||||
# 189, 192,196;
|
# 189, 192,196;
|
||||||
# 5G: channel 7,8,11,12,16,34)
|
# 5G: channel 7,8,11,12,16,34)
|
||||||
|
ChanTRPC.TlvType:2=0x0249
|
||||||
|
ChanTRPC.TlvLength:2={ # Get Tx Power Values for a particular antenna
|
||||||
|
TLVAntNum:1=0 # Antenna Num: 0 - Both, 1 - Main, 2 - Aux
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
## Set CFG data for Tx power limitation
|
## Set CFG data for Tx power limitation
|
||||||
|
@ -127,6 +147,10 @@ txpwrlimit_2g_cfg_set={
|
||||||
Action:2=1 # 1 - SET
|
Action:2=1 # 1 - SET
|
||||||
RSVD:2=0 # do NOT change this line
|
RSVD:2=0 # do NOT change this line
|
||||||
|
|
||||||
|
ChanTRPC.TlvType:2=0x0249
|
||||||
|
ChanTRPC.TlvLength:2={ # Configure Tx Power Values for a particular antenna
|
||||||
|
TLVAntNum:1=0 # Antenna Num: 0 - Both, 1 - Main, 2 - Aux
|
||||||
|
}
|
||||||
ChanTRPC.TlvType:2=0x0189
|
ChanTRPC.TlvType:2=0x0189
|
||||||
ChanTRPC.TlvLength:2={
|
ChanTRPC.TlvLength:2={
|
||||||
TLVStartFreq:2=2407
|
TLVStartFreq:2=2407
|
||||||
|
@ -233,6 +257,10 @@ txpwrlimit_5g_cfg_set={
|
||||||
Action:2=1 # 1 - SET
|
Action:2=1 # 1 - SET
|
||||||
RSVD:2=0 # do NOT change this line
|
RSVD:2=0 # do NOT change this line
|
||||||
|
|
||||||
|
ChanTRPC.TlvType:2=0x0249
|
||||||
|
ChanTRPC.TlvLength:2={ # Configure Tx Power Values for a particular antenna
|
||||||
|
TLVAntNum:1=0 # Antenna Num: 0 - Both, 1 - Main, 2 - Aux
|
||||||
|
}
|
||||||
ChanTRPC.TlvType:2=0x0189
|
ChanTRPC.TlvType:2=0x0189
|
||||||
ChanTRPC.TlvLength:2={
|
ChanTRPC.TlvLength:2={
|
||||||
TLVStartFreq:2=5000
|
TLVStartFreq:2=5000
|
||||||
|
|
|
@ -22,7 +22,9 @@ CFLAGS := $(filter-out -I$(KERNELDIR)%, $(CFLAGS))
|
||||||
#CFLAGS += -DAP22 -fshort-enums
|
#CFLAGS += -DAP22 -fshort-enums
|
||||||
CFLAGS += -Wall
|
CFLAGS += -Wall
|
||||||
#ECHO = @
|
#ECHO = @
|
||||||
|
ifeq (,$(findstring ANDROID_KERNEL, $(CFLAGS)))
|
||||||
LIBS=-lrt
|
LIBS=-lrt
|
||||||
|
endif
|
||||||
|
|
||||||
.PHONY: default tags all
|
.PHONY: default tags all
|
||||||
|
|
||||||
|
|
File diff suppressed because it is too large
Load diff
|
@ -365,6 +365,15 @@ struct eth_priv_get_log {
|
||||||
t_u32 gdma_abort_cnt;
|
t_u32 gdma_abort_cnt;
|
||||||
/** Rx Reset MAC Count */
|
/** Rx Reset MAC Count */
|
||||||
t_u32 g_reset_rx_mac_cnt;
|
t_u32 g_reset_rx_mac_cnt;
|
||||||
|
// Ownership error counters
|
||||||
|
/*Error Ownership error count*/
|
||||||
|
t_u32 dwCtlErrCnt;
|
||||||
|
/*Control Ownership error count*/
|
||||||
|
t_u32 dwBcnErrCnt;
|
||||||
|
/*Control Ownership error count*/
|
||||||
|
t_u32 dwMgtErrCnt;
|
||||||
|
/*Control Ownership error count*/
|
||||||
|
t_u32 dwDatErrCnt;
|
||||||
};
|
};
|
||||||
|
|
||||||
/** MLAN MAC Address Length */
|
/** MLAN MAC Address Length */
|
||||||
|
@ -1183,4 +1192,44 @@ typedef struct MAPP_HostCmd_DS_MEM {
|
||||||
t_u32 value;
|
t_u32 value;
|
||||||
} __ATTRIB_PACK__ HostCmd_DS_MEM;
|
} __ATTRIB_PACK__ HostCmd_DS_MEM;
|
||||||
|
|
||||||
|
typedef struct _HostCmd_DS_MEF_CFG {
|
||||||
|
/** Criteria */
|
||||||
|
t_u32 Criteria;
|
||||||
|
/** Number of entries */
|
||||||
|
t_u16 NumEntries;
|
||||||
|
} __ATTRIB_PACK__ HostCmd_DS_MEF_CFG;
|
||||||
|
|
||||||
|
typedef struct _MEF_CFG_DATA {
|
||||||
|
/** Size */
|
||||||
|
t_u16 size;
|
||||||
|
/** Data */
|
||||||
|
HostCmd_DS_MEF_CFG data;
|
||||||
|
} __ATTRIB_PACK__ MEF_CFG_DATA;
|
||||||
|
|
||||||
|
/** cloud keep alive parameters */
|
||||||
|
typedef struct _cloud_keep_alive {
|
||||||
|
/** id */
|
||||||
|
t_u8 mkeep_alive_id;
|
||||||
|
/** enable/disable of this id */
|
||||||
|
t_u8 enable;
|
||||||
|
/** enable/disable reset*/
|
||||||
|
t_u8 reset;
|
||||||
|
/** Reserved */
|
||||||
|
t_u8 reserved;
|
||||||
|
/** Destination MAC address */
|
||||||
|
t_u8 dst_mac[ETH_ALEN];
|
||||||
|
/** Source MAC address */
|
||||||
|
t_u8 src_mac[ETH_ALEN];
|
||||||
|
/** packet send period */
|
||||||
|
t_u32 sendInterval;
|
||||||
|
/** packet retry interval */
|
||||||
|
t_u32 retryInterval;
|
||||||
|
/** packet retry count */
|
||||||
|
t_u8 retryCount;
|
||||||
|
/** packet length */
|
||||||
|
t_u8 pkt_len;
|
||||||
|
/** packet content */
|
||||||
|
t_u8 pkt[255];
|
||||||
|
} __ATTRIB_PACK__ cloud_keep_alive;
|
||||||
|
|
||||||
#endif /* _MLANUTL_H_ */
|
#endif /* _MLANUTL_H_ */
|
||||||
|
|
|
@ -158,6 +158,11 @@ t_u16 wlan_fill_he_cap_tlv(mlan_private *pmpriv, t_u8 band,
|
||||||
{
|
{
|
||||||
pmlan_adapter pmadapter = pmpriv->adapter;
|
pmlan_adapter pmadapter = pmpriv->adapter;
|
||||||
t_u16 len = 0;
|
t_u16 len = 0;
|
||||||
|
#if defined(PCIE9098) || defined(SD9098) || defined(USB9098) || \
|
||||||
|
defined(PCIE9097) || defined(SD9097) || defined(USB9097)
|
||||||
|
t_u16 rx_nss = 0, tx_nss = 0;
|
||||||
|
#endif
|
||||||
|
MrvlIEtypes_He_cap_t *phecap = MNULL;
|
||||||
|
|
||||||
if (!phe_cap) {
|
if (!phe_cap) {
|
||||||
LEAVE();
|
LEAVE();
|
||||||
|
@ -176,7 +181,37 @@ t_u16 wlan_fill_he_cap_tlv(mlan_private *pmpriv, t_u8 band,
|
||||||
}
|
}
|
||||||
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);
|
||||||
|
#if defined(PCIE9098) || defined(SD9098) || defined(USB9098) || \
|
||||||
|
defined(PCIE9097) || defined(SD9097) || defined(USB9097)
|
||||||
|
if (IS_CARD9098(pmpriv->adapter->card_type) ||
|
||||||
|
IS_CARD9097(pmpriv->adapter->card_type)) {
|
||||||
|
if (band & BAND_A) {
|
||||||
|
rx_nss = GET_RXMCSSUPP(pmpriv->adapter->user_htstream >>
|
||||||
|
8);
|
||||||
|
tx_nss = GET_TXMCSSUPP(pmpriv->adapter->user_htstream >>
|
||||||
|
8) &
|
||||||
|
0x0f;
|
||||||
|
} else {
|
||||||
|
rx_nss = GET_RXMCSSUPP(pmpriv->adapter->user_htstream);
|
||||||
|
tx_nss = GET_TXMCSSUPP(pmpriv->adapter->user_htstream) &
|
||||||
|
0x0f;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
phecap = (MrvlIEtypes_He_cap_t *)phe_cap;
|
||||||
|
phecap->rx_mcs_80 = wlan_cpu_to_le16(0xfffe);
|
||||||
|
phecap->tx_mcs_80 = wlan_cpu_to_le16(0xfffe);
|
||||||
|
#if defined(PCIE9098) || defined(SD9098) || defined(USB9098) || \
|
||||||
|
defined(PCIE9097) || defined(SD9097) || defined(USB9097)
|
||||||
|
if (IS_CARD9098(pmpriv->adapter->card_type) ||
|
||||||
|
IS_CARD9097(pmpriv->adapter->card_type)) {
|
||||||
|
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
|
||||||
|
DBG_HEXDUMP(MCMD_D, "fill_11ax_tlv", (t_u8 *)phecap, len);
|
||||||
LEAVE();
|
LEAVE();
|
||||||
return len;
|
return len;
|
||||||
}
|
}
|
||||||
|
@ -197,6 +232,10 @@ int wlan_cmd_append_11ax_tlv(mlan_private *pmpriv, BSSDescriptor_t *pbss_desc,
|
||||||
MrvlIEtypes_He_cap_t *phecap = MNULL;
|
MrvlIEtypes_He_cap_t *phecap = MNULL;
|
||||||
int len = 0;
|
int len = 0;
|
||||||
t_u8 bw_80p80 = MFALSE;
|
t_u8 bw_80p80 = MFALSE;
|
||||||
|
#if defined(PCIE9098) || defined(SD9098) || defined(USB9098) || \
|
||||||
|
defined(PCIE9097) || defined(SD9097) || defined(USB9097)
|
||||||
|
t_u16 rx_nss = 0, tx_nss = 0;
|
||||||
|
#endif
|
||||||
|
|
||||||
ENTER();
|
ENTER();
|
||||||
|
|
||||||
|
@ -230,26 +269,44 @@ int wlan_cmd_append_11ax_tlv(mlan_private *pmpriv, BSSDescriptor_t *pbss_desc,
|
||||||
}
|
}
|
||||||
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);
|
||||||
|
#if defined(PCIE9098) || defined(SD9098) || defined(USB9098) || \
|
||||||
if (bw_80p80) {
|
defined(PCIE9097) || defined(SD9097) || defined(USB9097)
|
||||||
/** configure 2*2 to 1*1 to support 80+80Mhz*/
|
if (IS_CARD9098(pmpriv->adapter->card_type) ||
|
||||||
/** set 1*1 mcs rate for 80Mhz rx*/
|
IS_CARD9097(pmpriv->adapter->card_type)) {
|
||||||
phecap->he_txrx_mcs_support[0] &= ~(MBIT(0) | MBIT(1));
|
if (pbss_desc->bss_band & BAND_A) {
|
||||||
/** set 1*1 mcs rate for 80Mhz tx*/
|
rx_nss = GET_RXMCSSUPP(pmpriv->adapter->user_htstream >>
|
||||||
phecap->he_txrx_mcs_support[3] &= ~(MBIT(0) | MBIT(1));
|
8);
|
||||||
/** set 1*1 mcs rate for 160Mhz rx*/
|
tx_nss = GET_TXMCSSUPP(pmpriv->adapter->user_htstream >>
|
||||||
phecap->he160_txrx_mcs_support[0] &= ~(MBIT(0) | MBIT(1));
|
8) &
|
||||||
/** set 1*1 mcs rate for 160Mhz tx*/
|
0x0f;
|
||||||
phecap->he160_txrx_mcs_support[3] &= ~(MBIT(0) | MBIT(1));
|
|
||||||
/** set 1*1 mcs rate for 80+80Mhz rx*/
|
|
||||||
phecap->he8080_txrx_mcs_support[0] &= ~(MBIT(0) | MBIT(1));
|
|
||||||
/** set 1*1 mcs rate for 80+80Mhz tx*/
|
|
||||||
phecap->he8080_txrx_mcs_support[3] &= ~(MBIT(0) | MBIT(1));
|
|
||||||
} else {
|
} else {
|
||||||
|
rx_nss = GET_RXMCSSUPP(pmpriv->adapter->user_htstream);
|
||||||
|
tx_nss = GET_TXMCSSUPP(pmpriv->adapter->user_htstream) &
|
||||||
|
0x0f;
|
||||||
|
}
|
||||||
|
/** force 1x1 when enable 80P80 */
|
||||||
|
if (bw_80p80)
|
||||||
|
rx_nss = tx_nss = 1;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
phecap->rx_mcs_80 = wlan_cpu_to_le16(0xfffe);
|
||||||
|
phecap->tx_mcs_80 = wlan_cpu_to_le16(0xfffe);
|
||||||
|
#if defined(PCIE9098) || defined(SD9098) || defined(USB9098) || \
|
||||||
|
defined(PCIE9097) || defined(SD9097) || defined(USB9097)
|
||||||
|
if (IS_CARD9098(pmpriv->adapter->card_type) ||
|
||||||
|
IS_CARD9097(pmpriv->adapter->card_type)) {
|
||||||
|
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
|
||||||
|
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 */
|
||||||
phecap->he_phy_cap[0] &= ~(MBIT(3) | MBIT(4));
|
phecap->he_phy_cap[0] &= ~(MBIT(3) | MBIT(4));
|
||||||
}
|
}
|
||||||
|
DBG_HEXDUMP(MCMD_D, "append_11ax_tlv", (t_u8 *)phecap, len);
|
||||||
|
|
||||||
LEAVE();
|
LEAVE();
|
||||||
return len;
|
return len;
|
||||||
|
|
|
@ -1396,10 +1396,16 @@ static void wlan_fill_cap_info(mlan_private *priv, HTCap_t *ht_cap, t_u8 bands)
|
||||||
RESETHT_MAXAMSDU(ht_cap->ht_cap_info);
|
RESETHT_MAXAMSDU(ht_cap->ht_cap_info);
|
||||||
|
|
||||||
/* SM power save */
|
/* SM power save */
|
||||||
if (ISSUPP_MIMOPS(priv->adapter->hw_dot_11n_dev_cap))
|
RESETHT_SM_POWERSAVE(ht_cap->ht_cap_info); /* Clear to HT SMPS static
|
||||||
RESETHT_SM_POWERSAVE(ht_cap->ht_cap_info); /* Enable HT SMPS*/
|
mode*/
|
||||||
else
|
if (ISSUPP_MIMOPS(usr_dot_11n_dev_cap)) {
|
||||||
SETHT_STATIC_SMPS(ht_cap->ht_cap_info); /* Disable HT SMPS */
|
if (ISSUPP_SMPS_DYNAMIC_MODE(usr_dot_11n_dev_cap))
|
||||||
|
SETHT_SMPS_DYNAMIC(ht_cap->ht_cap_info); /* Set to HT
|
||||||
|
SMPS dynamic
|
||||||
|
mode */
|
||||||
|
} else {
|
||||||
|
SETHT_SMPS_DISABLE(ht_cap->ht_cap_info); /* Disable HT SMPS */
|
||||||
|
}
|
||||||
|
|
||||||
LEAVE();
|
LEAVE();
|
||||||
}
|
}
|
||||||
|
@ -1462,8 +1468,8 @@ static void wlan_reset_cap_info(mlan_private *priv, HTCap_t *ht_cap, t_u8 bands)
|
||||||
/* Need change to support 8k AMSDU receive */
|
/* Need change to support 8k AMSDU receive */
|
||||||
RESETHT_MAXAMSDU(ht_cap->ht_cap_info);
|
RESETHT_MAXAMSDU(ht_cap->ht_cap_info);
|
||||||
/* SM power save */
|
/* SM power save */
|
||||||
if (!ISSUPP_MIMOPS(priv->adapter->hw_dot_11n_dev_cap))
|
if (!ISSUPP_MIMOPS(usr_dot_11n_dev_cap))
|
||||||
SETHT_STATIC_SMPS(ht_cap->ht_cap_info); /* Disable HT SMPS */
|
SETHT_SMPS_DISABLE(ht_cap->ht_cap_info); /* Disable HT SMPS */
|
||||||
|
|
||||||
LEAVE();
|
LEAVE();
|
||||||
}
|
}
|
||||||
|
@ -3046,6 +3052,7 @@ int wlan_get_rxreorder_tbl(mlan_private *priv, rx_reorder_tbl *buf)
|
||||||
MLAN_MAC_ADDR_LENGTH, MLAN_MAC_ADDR_LENGTH);
|
MLAN_MAC_ADDR_LENGTH, MLAN_MAC_ADDR_LENGTH);
|
||||||
ptbl->start_win = rx_reorder_tbl_ptr->start_win;
|
ptbl->start_win = rx_reorder_tbl_ptr->start_win;
|
||||||
ptbl->win_size = rx_reorder_tbl_ptr->win_size;
|
ptbl->win_size = rx_reorder_tbl_ptr->win_size;
|
||||||
|
|
||||||
ptbl->amsdu = rx_reorder_tbl_ptr->amsdu;
|
ptbl->amsdu = rx_reorder_tbl_ptr->amsdu;
|
||||||
for (i = 0; i < rx_reorder_tbl_ptr->win_size; ++i) {
|
for (i = 0; i < rx_reorder_tbl_ptr->win_size; ++i) {
|
||||||
if (rx_reorder_tbl_ptr->rx_reorder_ptr[i])
|
if (rx_reorder_tbl_ptr->rx_reorder_ptr[i])
|
||||||
|
|
|
@ -79,10 +79,12 @@ static mlan_status wlan_11n_dispatch_amsdu_pkt(mlan_private *priv,
|
||||||
*
|
*
|
||||||
* @param priv A pointer to mlan_private
|
* @param priv A pointer to mlan_private
|
||||||
* @param payload A pointer to rx packet payload
|
* @param payload A pointer to rx packet payload
|
||||||
|
* @param rx_reor_tbl_ptr pointer to RxReorderTbl
|
||||||
*
|
*
|
||||||
* @return MLAN_STATUS_SUCCESS or MLAN_STATUS_FAILURE
|
* @return MLAN_STATUS_SUCCESS or MLAN_STATUS_FAILURE
|
||||||
*/
|
*/
|
||||||
static mlan_status wlan_11n_dispatch_pkt(t_void *priv, t_void *payload)
|
static mlan_status wlan_11n_dispatch_pkt(t_void *priv, t_void *payload,
|
||||||
|
RxReorderTbl *rx_reor_tbl_ptr)
|
||||||
{
|
{
|
||||||
mlan_status ret = MLAN_STATUS_SUCCESS;
|
mlan_status ret = MLAN_STATUS_SUCCESS;
|
||||||
#ifdef STA_SUPPORT
|
#ifdef STA_SUPPORT
|
||||||
|
@ -93,6 +95,7 @@ static mlan_status wlan_11n_dispatch_pkt(t_void *priv, t_void *payload)
|
||||||
LEAVE();
|
LEAVE();
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef UAP_SUPPORT
|
#ifdef UAP_SUPPORT
|
||||||
if (GET_BSS_ROLE((mlan_private *)priv) == MLAN_BSS_ROLE_UAP) {
|
if (GET_BSS_ROLE((mlan_private *)priv) == MLAN_BSS_ROLE_UAP) {
|
||||||
if (MLAN_STATUS_SUCCESS ==
|
if (MLAN_STATUS_SUCCESS ==
|
||||||
|
@ -188,7 +191,8 @@ static mlan_status wlan_11n_dispatch_pkt_until_start_win(
|
||||||
pmpriv->adapter->callbacks.moal_spin_unlock(
|
pmpriv->adapter->callbacks.moal_spin_unlock(
|
||||||
pmpriv->adapter->pmoal_handle, pmpriv->rx_pkt_lock);
|
pmpriv->adapter->pmoal_handle, pmpriv->rx_pkt_lock);
|
||||||
if (rx_tmp_ptr)
|
if (rx_tmp_ptr)
|
||||||
wlan_11n_dispatch_pkt(priv, rx_tmp_ptr);
|
wlan_11n_dispatch_pkt(priv, rx_tmp_ptr,
|
||||||
|
rx_reor_tbl_ptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
pmpriv->adapter->callbacks.moal_spin_lock(pmpriv->adapter->pmoal_handle,
|
pmpriv->adapter->callbacks.moal_spin_lock(pmpriv->adapter->pmoal_handle,
|
||||||
|
@ -264,7 +268,7 @@ static mlan_status wlan_11n_scan_and_dispatch(t_void *priv,
|
||||||
rx_reor_tbl_ptr->rx_reorder_ptr[i] = MNULL;
|
rx_reor_tbl_ptr->rx_reorder_ptr[i] = MNULL;
|
||||||
pmpriv->adapter->callbacks.moal_spin_unlock(
|
pmpriv->adapter->callbacks.moal_spin_unlock(
|
||||||
pmpriv->adapter->pmoal_handle, pmpriv->rx_pkt_lock);
|
pmpriv->adapter->pmoal_handle, pmpriv->rx_pkt_lock);
|
||||||
wlan_11n_dispatch_pkt(priv, rx_tmp_ptr);
|
wlan_11n_dispatch_pkt(priv, rx_tmp_ptr, rx_reor_tbl_ptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
pmpriv->adapter->callbacks.moal_spin_lock(pmpriv->adapter->pmoal_handle,
|
pmpriv->adapter->callbacks.moal_spin_lock(pmpriv->adapter->pmoal_handle,
|
||||||
|
@ -516,6 +520,7 @@ static t_void wlan_11n_create_rxreorder_tbl(mlan_private *priv, t_u8 *ta,
|
||||||
new_node->ba_status = BA_STREAM_SETUP_INPROGRESS;
|
new_node->ba_status = BA_STREAM_SETUP_INPROGRESS;
|
||||||
for (i = 0; i < win_size; ++i)
|
for (i = 0; i < win_size; ++i)
|
||||||
new_node->rx_reorder_ptr[i] = MNULL;
|
new_node->rx_reorder_ptr[i] = MNULL;
|
||||||
|
|
||||||
mlan_block_rx_process(pmadapter, MFALSE);
|
mlan_block_rx_process(pmadapter, MFALSE);
|
||||||
LEAVE();
|
LEAVE();
|
||||||
}
|
}
|
||||||
|
@ -763,7 +768,7 @@ mlan_status mlan_11n_rxreorder_pkt(void *priv, t_u16 seq_num, t_u16 tid,
|
||||||
wlan_11n_get_rxreorder_tbl((mlan_private *)priv, tid, ta);
|
wlan_11n_get_rxreorder_tbl((mlan_private *)priv, tid, ta);
|
||||||
if (!rx_reor_tbl_ptr || rx_reor_tbl_ptr->win_size <= 1) {
|
if (!rx_reor_tbl_ptr || rx_reor_tbl_ptr->win_size <= 1) {
|
||||||
if (pkt_type != PKT_TYPE_BAR)
|
if (pkt_type != PKT_TYPE_BAR)
|
||||||
wlan_11n_dispatch_pkt(priv, payload);
|
wlan_11n_dispatch_pkt(priv, payload, rx_reor_tbl_ptr);
|
||||||
|
|
||||||
LEAVE();
|
LEAVE();
|
||||||
return ret;
|
return ret;
|
||||||
|
@ -774,7 +779,7 @@ mlan_status mlan_11n_rxreorder_pkt(void *priv, t_u16 seq_num, t_u16 tid,
|
||||||
wlan_start_flush_data(priv, rx_reor_tbl_ptr);
|
wlan_start_flush_data(priv, rx_reor_tbl_ptr);
|
||||||
}
|
}
|
||||||
if ((pkt_type == PKT_TYPE_AMSDU) && !rx_reor_tbl_ptr->amsdu) {
|
if ((pkt_type == PKT_TYPE_AMSDU) && !rx_reor_tbl_ptr->amsdu) {
|
||||||
wlan_11n_dispatch_pkt(priv, payload);
|
wlan_11n_dispatch_pkt(priv, payload, rx_reor_tbl_ptr);
|
||||||
LEAVE();
|
LEAVE();
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
@ -801,7 +806,8 @@ mlan_status mlan_11n_rxreorder_pkt(void *priv, t_u16 seq_num, t_u16 tid,
|
||||||
seq_num;
|
seq_num;
|
||||||
if (pkt_type != PKT_TYPE_BAR)
|
if (pkt_type != PKT_TYPE_BAR)
|
||||||
wlan_11n_dispatch_pkt(
|
wlan_11n_dispatch_pkt(
|
||||||
priv, payload);
|
priv, payload,
|
||||||
|
rx_reor_tbl_ptr);
|
||||||
}
|
}
|
||||||
LEAVE();
|
LEAVE();
|
||||||
return ret;
|
return ret;
|
||||||
|
|
|
@ -1281,9 +1281,9 @@ static t_void wlan_cfp_copy_dynamic(pmlan_adapter pmadapter,
|
||||||
}
|
}
|
||||||
|
|
||||||
/* first clear dest dynamic blacklisted entries */
|
/* first clear dest dynamic blacklisted entries */
|
||||||
|
/* do not clear the flags */
|
||||||
for (i = 0; i < num_cfp; i++) {
|
for (i = 0; i < num_cfp; i++) {
|
||||||
cfp[i].dynamic.blacklist = MFALSE;
|
cfp[i].dynamic.blacklist = MFALSE;
|
||||||
cfp[i].dynamic.flags = 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* copy dynamic blacklisted entries from source where channels match */
|
/* copy dynamic blacklisted entries from source where channels match */
|
||||||
|
@ -1293,8 +1293,6 @@ static t_void wlan_cfp_copy_dynamic(pmlan_adapter pmadapter,
|
||||||
if (cfp[i].channel == cfp_src[j].channel) {
|
if (cfp[i].channel == cfp_src[j].channel) {
|
||||||
cfp[i].dynamic.blacklist =
|
cfp[i].dynamic.blacklist =
|
||||||
cfp_src[j].dynamic.blacklist;
|
cfp_src[j].dynamic.blacklist;
|
||||||
cfp[i].dynamic.flags =
|
|
||||||
cfp_src[j].dynamic.flags;
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1323,6 +1321,17 @@ mlan_status wlan_misc_country_2_cfp_table_code(pmlan_adapter pmadapter,
|
||||||
|
|
||||||
ENTER();
|
ENTER();
|
||||||
|
|
||||||
|
if (pmadapter->otp_region) {
|
||||||
|
if (!memcmp(pmadapter, pmadapter->otp_region->country_code,
|
||||||
|
country_code, COUNTRY_CODE_LEN - 1)) {
|
||||||
|
if (pmadapter->cfp_otp_bg)
|
||||||
|
*cfp_bg = pmadapter->otp_region->region_code;
|
||||||
|
if (pmadapter->cfp_otp_a)
|
||||||
|
*cfp_a = pmadapter->otp_region->region_code;
|
||||||
|
LEAVE();
|
||||||
|
return MLAN_STATUS_SUCCESS;
|
||||||
|
}
|
||||||
|
}
|
||||||
/* Look for code in mapping table */
|
/* Look for code in mapping table */
|
||||||
for (i = 0; i < NELEMENTS(country_code_mapping); i++) {
|
for (i = 0; i < NELEMENTS(country_code_mapping); i++) {
|
||||||
if (!memcmp(pmadapter, country_code_mapping[i].country_code,
|
if (!memcmp(pmadapter, country_code_mapping[i].country_code,
|
||||||
|
@ -2712,7 +2721,7 @@ mlan_status wlan_set_regiontable(mlan_private *pmpriv, t_u8 region, t_u8 band)
|
||||||
wlan_cfp_copy_dynamic(pmadapter, cfp, cfp_no,
|
wlan_cfp_copy_dynamic(pmadapter, cfp, cfp_no,
|
||||||
region_chan_old[j].pcfp,
|
region_chan_old[j].pcfp,
|
||||||
region_chan_old[j].num_cfp);
|
region_chan_old[j].num_cfp);
|
||||||
} else if (region) {
|
} else if (cfp) {
|
||||||
wlan_cfp_copy_dynamic(pmadapter, cfp, cfp_no, MNULL, 0);
|
wlan_cfp_copy_dynamic(pmadapter, cfp, cfp_no, MNULL, 0);
|
||||||
}
|
}
|
||||||
i++;
|
i++;
|
||||||
|
@ -2744,7 +2753,7 @@ mlan_status wlan_set_regiontable(mlan_private *pmpriv, t_u8 region, t_u8 band)
|
||||||
wlan_cfp_copy_dynamic(pmadapter, cfp, cfp_no,
|
wlan_cfp_copy_dynamic(pmadapter, cfp, cfp_no,
|
||||||
region_chan_old[j].pcfp,
|
region_chan_old[j].pcfp,
|
||||||
region_chan_old[j].num_cfp);
|
region_chan_old[j].num_cfp);
|
||||||
} else if (region) {
|
} else if (cfp) {
|
||||||
wlan_cfp_copy_dynamic(pmadapter, cfp, cfp_no, MNULL, 0);
|
wlan_cfp_copy_dynamic(pmadapter, cfp, cfp_no, MNULL, 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -3110,6 +3119,43 @@ t_u8 wlan_mrvl_rateid_to_ieee_rateid(t_u8 rate)
|
||||||
return rateUnit_500Kbps[rate];
|
return rateUnit_500Kbps[rate];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief sort cfp otp table
|
||||||
|
*
|
||||||
|
* @param pmapdater a pointer to mlan_adapter structure
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
* None
|
||||||
|
*/
|
||||||
|
static void wlan_sort_cfp_otp_table(mlan_adapter *pmadapter)
|
||||||
|
{
|
||||||
|
t_u8 c, d;
|
||||||
|
chan_freq_power_t *ch1;
|
||||||
|
chan_freq_power_t *ch2;
|
||||||
|
chan_freq_power_t swap;
|
||||||
|
|
||||||
|
if (pmadapter->tx_power_table_a_rows <= 1)
|
||||||
|
return;
|
||||||
|
for (c = 0; c < pmadapter->tx_power_table_a_rows - 1; c++) {
|
||||||
|
for (d = 0; d < pmadapter->tx_power_table_a_rows - c - 1; d++) {
|
||||||
|
ch1 = (chan_freq_power_t *)(pmadapter->cfp_otp_a + d);
|
||||||
|
ch2 = (chan_freq_power_t *)(pmadapter->cfp_otp_a + d +
|
||||||
|
1);
|
||||||
|
if (ch1->channel > ch2->channel) {
|
||||||
|
memcpy_ext(pmadapter, &swap, ch1,
|
||||||
|
sizeof(chan_freq_power_t),
|
||||||
|
sizeof(chan_freq_power_t));
|
||||||
|
memcpy_ext(pmadapter, ch1, ch2,
|
||||||
|
sizeof(chan_freq_power_t),
|
||||||
|
sizeof(chan_freq_power_t));
|
||||||
|
memcpy_ext(pmadapter, ch2, &swap,
|
||||||
|
sizeof(chan_freq_power_t),
|
||||||
|
sizeof(chan_freq_power_t));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Update CFP tables and power tables from FW
|
* @brief Update CFP tables and power tables from FW
|
||||||
*
|
*
|
||||||
|
@ -3144,8 +3190,11 @@ void wlan_add_fw_cfp_tables(pmlan_private pmpriv, t_u8 *buf, t_u16 buf_left)
|
||||||
PRINTM(MERROR, "CFP table update failed!\n");
|
PRINTM(MERROR, "CFP table update failed!\n");
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
if (pmadapter->otp_region)
|
if (pmadapter->otp_region) {
|
||||||
|
memset(pmadapter, pmadapter->region_channel, 0,
|
||||||
|
sizeof(pmadapter->region_channel));
|
||||||
wlan_free_fw_cfp_tables(pmadapter);
|
wlan_free_fw_cfp_tables(pmadapter);
|
||||||
|
}
|
||||||
pmadapter->tx_power_table_bg_rows = FW_CFP_TABLE_MAX_ROWS_BG;
|
pmadapter->tx_power_table_bg_rows = FW_CFP_TABLE_MAX_ROWS_BG;
|
||||||
pmadapter->tx_power_table_bg_cols = FW_CFP_TABLE_MAX_COLS_BG;
|
pmadapter->tx_power_table_bg_cols = FW_CFP_TABLE_MAX_COLS_BG;
|
||||||
pmadapter->tx_power_table_a_rows = FW_CFP_TABLE_MAX_ROWS_A;
|
pmadapter->tx_power_table_a_rows = FW_CFP_TABLE_MAX_ROWS_A;
|
||||||
|
@ -3223,6 +3272,10 @@ void wlan_add_fw_cfp_tables(pmlan_private pmpriv, t_u8 *buf, t_u16 buf_left)
|
||||||
pmadapter->domain_reg.country_code[1] =
|
pmadapter->domain_reg.country_code[1] =
|
||||||
pmadapter->otp_region->country_code[1];
|
pmadapter->otp_region->country_code[1];
|
||||||
pmadapter->domain_reg.country_code[2] = '\0';
|
pmadapter->domain_reg.country_code[2] = '\0';
|
||||||
|
PRINTM(MCMND, "OTP region: region_code=%d %c%c\n",
|
||||||
|
pmadapter->otp_region->region_code,
|
||||||
|
pmadapter->country_code[0],
|
||||||
|
pmadapter->country_code[1]);
|
||||||
pmadapter->cfp_code_bg =
|
pmadapter->cfp_code_bg =
|
||||||
pmadapter->otp_region->region_code;
|
pmadapter->otp_region->region_code;
|
||||||
pmadapter->cfp_code_a =
|
pmadapter->cfp_code_a =
|
||||||
|
@ -3271,6 +3324,11 @@ void wlan_add_fw_cfp_tables(pmlan_private pmpriv, t_u8 *buf, t_u16 buf_left)
|
||||||
(pmadapter->cfp_otp_bg + i)
|
(pmadapter->cfp_otp_bg + i)
|
||||||
->passive_scan_or_radar_detect =
|
->passive_scan_or_radar_detect =
|
||||||
MTRUE;
|
MTRUE;
|
||||||
|
PRINTM(MCMD_D,
|
||||||
|
"OTP Region (BG): chan=%d flags=0x%x\n",
|
||||||
|
(pmadapter->cfp_otp_bg + i)->channel,
|
||||||
|
(pmadapter->cfp_otp_bg + i)
|
||||||
|
->dynamic.flags);
|
||||||
data++;
|
data++;
|
||||||
}
|
}
|
||||||
ret = pcb->moal_malloc(
|
ret = pcb->moal_malloc(
|
||||||
|
@ -3306,6 +3364,12 @@ void wlan_add_fw_cfp_tables(pmlan_private pmpriv, t_u8 *buf, t_u16 buf_left)
|
||||||
(pmadapter->cfp_otp_a + i)
|
(pmadapter->cfp_otp_a + i)
|
||||||
->passive_scan_or_radar_detect =
|
->passive_scan_or_radar_detect =
|
||||||
MTRUE;
|
MTRUE;
|
||||||
|
PRINTM(MCMD_D,
|
||||||
|
"OTP Region (A): chan=%d flags=0x%x\n",
|
||||||
|
(pmadapter->cfp_otp_a + i)->channel,
|
||||||
|
(pmadapter->cfp_otp_a + i)
|
||||||
|
->dynamic.flags);
|
||||||
|
|
||||||
data++;
|
data++;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -3380,6 +3444,9 @@ void wlan_add_fw_cfp_tables(pmlan_private pmpriv, t_u8 *buf, t_u16 buf_left)
|
||||||
((power_table_attr_t *)data)->rows_5g;
|
((power_table_attr_t *)data)->rows_5g;
|
||||||
pmadapter->tx_power_table_a_cols =
|
pmadapter->tx_power_table_a_cols =
|
||||||
((power_table_attr_t *)data)->cols_5g;
|
((power_table_attr_t *)data)->cols_5g;
|
||||||
|
PRINTM(MCMD_D, "OTP region: bg_row=%d, a_row=%d\n",
|
||||||
|
pmadapter->tx_power_table_bg_rows,
|
||||||
|
pmadapter->tx_power_table_a_rows);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
|
@ -3410,7 +3477,8 @@ void wlan_add_fw_cfp_tables(pmlan_private pmpriv, t_u8 *buf, t_u16 buf_left)
|
||||||
NXP_CHANNEL_NO_OFDM;
|
NXP_CHANNEL_NO_OFDM;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (pmadapter->cfp_otp_a)
|
||||||
|
wlan_sort_cfp_otp_table(pmadapter);
|
||||||
out:
|
out:
|
||||||
LEAVE();
|
LEAVE();
|
||||||
}
|
}
|
||||||
|
|
|
@ -320,6 +320,7 @@ static t_void wlan_dump_info(mlan_adapter *pmadapter, t_u8 reason)
|
||||||
pmadapter->pps_uapsd_mode, pmadapter->sleep_period.period);
|
pmadapter->pps_uapsd_mode, pmadapter->sleep_period.period);
|
||||||
PRINTM(MERROR, "tx_lock_flag = %d\n", pmadapter->tx_lock_flag);
|
PRINTM(MERROR, "tx_lock_flag = %d\n", pmadapter->tx_lock_flag);
|
||||||
PRINTM(MERROR, "scan_processing = %d\n", pmadapter->scan_processing);
|
PRINTM(MERROR, "scan_processing = %d\n", pmadapter->scan_processing);
|
||||||
|
PRINTM(MERROR, "bypass_pkt_count=%d\n", pmadapter->bypass_pkt_count);
|
||||||
#ifdef SDIO
|
#ifdef SDIO
|
||||||
if (IS_SD(pmadapter->card_type)) {
|
if (IS_SD(pmadapter->card_type)) {
|
||||||
mp_aggr_pkt_limit = pmadapter->pcard_sd->mp_aggr_pkt_limit;
|
mp_aggr_pkt_limit = pmadapter->pcard_sd->mp_aggr_pkt_limit;
|
||||||
|
@ -974,7 +975,22 @@ static t_u16 wlan_get_cmd_timeout(t_u16 cmd_id)
|
||||||
timeout = MRVDRV_TIMER_5S;
|
timeout = MRVDRV_TIMER_5S;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
#ifdef IMX_SUPPORT
|
||||||
|
/*
|
||||||
|
* During the roaming test and the 5AP connection test, cmd
|
||||||
|
* timeout are observed for commands like 0x5e, 0x16, 0xd1.
|
||||||
|
* Observed that response has come just after default timeout of
|
||||||
|
* 2 seconds for these commands. This random timeout is not
|
||||||
|
* observed when the default timeout is increased to 5 seconds
|
||||||
|
* (As an work around, Increase the default timeout to 5
|
||||||
|
* seconds. Need to further debug exact reason for delay in cmd
|
||||||
|
* responses)
|
||||||
|
*
|
||||||
|
*/
|
||||||
timeout = MRVDRV_TIMER_1S * 5;
|
timeout = MRVDRV_TIMER_1S * 5;
|
||||||
|
#else
|
||||||
|
timeout = MRVDRV_TIMER_1S * 2;
|
||||||
|
#endif
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
LEAVE();
|
LEAVE();
|
||||||
|
@ -2409,22 +2425,8 @@ t_void wlan_cancel_all_pending_cmd(pmlan_adapter pmadapter, t_u8 flag)
|
||||||
wlan_insert_cmd_to_free_q(pmadapter, pcmd_node);
|
wlan_insert_cmd_to_free_q(pmadapter, pcmd_node);
|
||||||
}
|
}
|
||||||
wlan_release_cmd_lock(pmadapter);
|
wlan_release_cmd_lock(pmadapter);
|
||||||
#ifdef STA_SUPPORT
|
|
||||||
if (pmadapter->scan_processing &&
|
|
||||||
pmadapter->ext_scan_type == EXT_SCAN_ENHANCE) {
|
|
||||||
if (priv) {
|
|
||||||
if (MLAN_STATUS_FAILURE ==
|
|
||||||
wlan_prepare_cmd(priv, HostCmd_CMD_802_11_SCAN_EXT,
|
|
||||||
HostCmd_ACT_GEN_SET, 0, MNULL,
|
|
||||||
MNULL))
|
|
||||||
PRINTM(MERROR, "Failed to prepare command");
|
|
||||||
wlan_recv_event(priv, MLAN_EVENT_ID_DRV_DEFER_HANDLING,
|
|
||||||
MNULL);
|
|
||||||
}
|
|
||||||
} else
|
|
||||||
/* Cancel all pending scan command */
|
/* Cancel all pending scan command */
|
||||||
wlan_flush_scan_queue(pmadapter);
|
wlan_flush_scan_queue(pmadapter);
|
||||||
#endif
|
|
||||||
LEAVE();
|
LEAVE();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -5047,6 +5049,11 @@ mlan_status wlan_ret_get_hw_spec(pmlan_private pmpriv, HostCmd_DS_COMMAND *resp,
|
||||||
PRINTM(MCMND, "chanrpt api ver=%d.%d\n",
|
PRINTM(MCMND, "chanrpt api ver=%d.%d\n",
|
||||||
api_rev->major_ver, api_rev->minor_ver);
|
api_rev->major_ver, api_rev->minor_ver);
|
||||||
break;
|
break;
|
||||||
|
case FW_HOTFIX_VER_ID:
|
||||||
|
pmadapter->fw_hotfix_ver = api_rev->major_ver;
|
||||||
|
PRINTM(MCMND, "fw hotfix ver=%d\n",
|
||||||
|
api_rev->major_ver);
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
|
@ -24,7 +24,7 @@
|
||||||
#define _MLAN_DECL_H_
|
#define _MLAN_DECL_H_
|
||||||
|
|
||||||
/** MLAN release version */
|
/** MLAN release version */
|
||||||
#define MLAN_RELEASE_VERSION "247.p5"
|
#define MLAN_RELEASE_VERSION "266"
|
||||||
|
|
||||||
/** Re-define generic data types for MLAN/MOAL */
|
/** Re-define generic data types for MLAN/MOAL */
|
||||||
/** Signed char (1-byte) */
|
/** Signed char (1-byte) */
|
||||||
|
@ -266,6 +266,7 @@ typedef t_s32 t_sval;
|
||||||
/** pcie card reset */
|
/** pcie card reset */
|
||||||
#define FW_RELOAD_PCIE_RESET 4
|
#define FW_RELOAD_PCIE_RESET 4
|
||||||
#endif
|
#endif
|
||||||
|
#define FW_RELOAD_SDIO_HW_RESET 5
|
||||||
|
|
||||||
#ifdef USB
|
#ifdef USB
|
||||||
#define MLAN_USB_BLOCK_SIZE (512)
|
#define MLAN_USB_BLOCK_SIZE (512)
|
||||||
|
@ -428,6 +429,8 @@ typedef t_u8 mlan_802_11_mac_addr[MLAN_MAC_ADDR_LENGTH];
|
||||||
#define CARD_SD8987 "SD8987"
|
#define CARD_SD8987 "SD8987"
|
||||||
/** SD9097 Card */
|
/** SD9097 Card */
|
||||||
#define CARD_SD9097 "SD9097"
|
#define CARD_SD9097 "SD9097"
|
||||||
|
/** SDIW620 Card */
|
||||||
|
#define CARD_SDIW620 "SDIW620"
|
||||||
/** SD9098 Card */
|
/** SD9098 Card */
|
||||||
#define CARD_SD9098 "SD9098"
|
#define CARD_SD9098 "SD9098"
|
||||||
/** SD9177 Card */
|
/** SD9177 Card */
|
||||||
|
@ -457,6 +460,8 @@ typedef t_u8 mlan_802_11_mac_addr[MLAN_MAC_ADDR_LENGTH];
|
||||||
#define CARD_PCIE8997 "PCIE8997"
|
#define CARD_PCIE8997 "PCIE8997"
|
||||||
/** PCIE9097 Card */
|
/** PCIE9097 Card */
|
||||||
#define CARD_PCIE9097 "PCIE9097"
|
#define CARD_PCIE9097 "PCIE9097"
|
||||||
|
/** PCIEIW620 Card */
|
||||||
|
#define CARD_PCIEIW620 "PCIEIW620"
|
||||||
/** PCIE9000S Card */
|
/** PCIE9000S Card */
|
||||||
#define CARD_PCIE9000S "PCIE9000S"
|
#define CARD_PCIE9000S "PCIE9000S"
|
||||||
/** PCIE9098 Card */
|
/** PCIE9098 Card */
|
||||||
|
@ -498,6 +503,8 @@ typedef t_u8 mlan_802_11_mac_addr[MLAN_MAC_ADDR_LENGTH];
|
||||||
#define CARD_USB9098 "USB9098"
|
#define CARD_USB9098 "USB9098"
|
||||||
/** USB9097 Card */
|
/** USB9097 Card */
|
||||||
#define CARD_USB9097 "USB9097"
|
#define CARD_USB9097 "USB9097"
|
||||||
|
/** USBIW620 Card */
|
||||||
|
#define CARD_USBIW620 "USBIW620"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define IS_CARD8801(ct) (CARD_TYPE_8801 == ((ct)&0xf))
|
#define IS_CARD8801(ct) (CARD_TYPE_8801 == ((ct)&0xf))
|
||||||
|
@ -1386,7 +1393,7 @@ typedef MLAN_PACK_START struct _tdls_each_link_status {
|
||||||
/** Key Length */
|
/** Key Length */
|
||||||
t_u8 key_length;
|
t_u8 key_length;
|
||||||
/** actual key */
|
/** actual key */
|
||||||
t_u8 key[];
|
t_u8 key[1];
|
||||||
} MLAN_PACK_END tdls_each_link_status;
|
} MLAN_PACK_END tdls_each_link_status;
|
||||||
|
|
||||||
/** TDLS configuration data */
|
/** TDLS configuration data */
|
||||||
|
@ -2021,6 +2028,7 @@ typedef struct _mlan_callbacks {
|
||||||
t_u8 antenna);
|
t_u8 antenna);
|
||||||
t_void (*moal_updata_peer_signal)(t_void *pmoal, t_u32 bss_index,
|
t_void (*moal_updata_peer_signal)(t_void *pmoal, t_u32 bss_index,
|
||||||
t_u8 *peer_addr, t_s8 snr, t_s8 nflr);
|
t_u8 *peer_addr, t_s8 snr, t_s8 nflr);
|
||||||
|
t_u64 (*moal_do_div)(t_u64 num, t_u32 base);
|
||||||
#if defined(DRV_EMBEDDED_AUTHENTICATOR) || defined(DRV_EMBEDDED_SUPPLICANT)
|
#if defined(DRV_EMBEDDED_AUTHENTICATOR) || defined(DRV_EMBEDDED_SUPPLICANT)
|
||||||
mlan_status (*moal_wait_hostcmd_complete)(t_void *pmoal,
|
mlan_status (*moal_wait_hostcmd_complete)(t_void *pmoal,
|
||||||
t_u32 bss_index);
|
t_u32 bss_index);
|
||||||
|
|
|
@ -552,6 +552,8 @@ typedef enum _WLAN_802_11_WEP_STATUS {
|
||||||
#define HWSPEC_MAX_AMSDU_SUPP MBIT(31)
|
#define HWSPEC_MAX_AMSDU_SUPP MBIT(31)
|
||||||
/** Greenfield support */
|
/** Greenfield support */
|
||||||
#define HWSPEC_GREENFIELD_SUPP MBIT(29)
|
#define HWSPEC_GREENFIELD_SUPP MBIT(29)
|
||||||
|
/** SM Power Save enable */
|
||||||
|
#define CAPINFO_SMPS_ENABLE MBIT(27)
|
||||||
/** RX STBC support */
|
/** RX STBC support */
|
||||||
#define HWSPEC_RXSTBC_SUPP MBIT(26)
|
#define HWSPEC_RXSTBC_SUPP MBIT(26)
|
||||||
/** ShortGI @ 40Mhz support */
|
/** ShortGI @ 40Mhz support */
|
||||||
|
@ -562,6 +564,8 @@ typedef enum _WLAN_802_11_WEP_STATUS {
|
||||||
#define HWSPEC_LDPC_SUPP MBIT(22)
|
#define HWSPEC_LDPC_SUPP MBIT(22)
|
||||||
/** Channel width 40Mhz support */
|
/** Channel width 40Mhz support */
|
||||||
#define HWSPEC_CHANBW40_SUPP MBIT(17)
|
#define HWSPEC_CHANBW40_SUPP MBIT(17)
|
||||||
|
/** SM Power Save mode */
|
||||||
|
#define CAPINFO_SMPS_MODE MBIT(9)
|
||||||
/** 40Mhz intolarent enable */
|
/** 40Mhz intolarent enable */
|
||||||
#define CAPINFO_40MHZ_INTOLARENT MBIT(8)
|
#define CAPINFO_40MHZ_INTOLARENT MBIT(8)
|
||||||
|
|
||||||
|
@ -580,7 +584,11 @@ typedef enum _WLAN_802_11_WEP_STATUS {
|
||||||
#define DEFAULT_11N_TX_BF_CAP_1X1 0x19E74608
|
#define DEFAULT_11N_TX_BF_CAP_1X1 0x19E74608
|
||||||
|
|
||||||
/** Bits to ignore in hw_dev_cap as these bits are set in get_hw_spec */
|
/** Bits to ignore in hw_dev_cap as these bits are set in get_hw_spec */
|
||||||
#define IGN_HW_DEV_CAP (CAPINFO_40MHZ_INTOLARENT)
|
#define IGN_HW_DEV_CAP \
|
||||||
|
(CAPINFO_40MHZ_INTOLARENT | (CAPINFO_SMPS_ENABLE | CAPINFO_SMPS_MODE))
|
||||||
|
|
||||||
|
/** HW_SPEC FwCapInfo : If FW support RSN Replay Detection */
|
||||||
|
#define ISSUPP_RSN_REPLAY_DETECTION(FwCapInfo) (FwCapInfo & MBIT(28))
|
||||||
|
|
||||||
/** HW_SPEC FwCapInfo */
|
/** HW_SPEC FwCapInfo */
|
||||||
#define ISSUPP_11NENABLED(FwCapInfo) (FwCapInfo & MBIT(11))
|
#define ISSUPP_11NENABLED(FwCapInfo) (FwCapInfo & MBIT(11))
|
||||||
|
@ -615,6 +623,8 @@ typedef enum _WLAN_802_11_WEP_STATUS {
|
||||||
#define ISSUPP_CHANWIDTH20(Dot11nDevCap) (Dot11nDevCap & MBIT(16))
|
#define ISSUPP_CHANWIDTH20(Dot11nDevCap) (Dot11nDevCap & MBIT(16))
|
||||||
/** HW_SPEC Dot11nDevCap : Channel BW support @ 10Mhz support */
|
/** HW_SPEC Dot11nDevCap : Channel BW support @ 10Mhz support */
|
||||||
#define ISSUPP_CHANWIDTH10(Dot11nDevCap) (Dot11nDevCap & MBIT(15))
|
#define ISSUPP_CHANWIDTH10(Dot11nDevCap) (Dot11nDevCap & MBIT(15))
|
||||||
|
/** Dot11nUsrCap : SMPS static/dynamic mode if BIT27 MIMO PS support eanbled */
|
||||||
|
#define ISSUPP_SMPS_DYNAMIC_MODE(Dot11nDevCap) (Dot11nDevCap & MBIT(9))
|
||||||
/** Dot11nUsrCap : 40Mhz intolarance enabled */
|
/** Dot11nUsrCap : 40Mhz intolarance enabled */
|
||||||
#define ISENABLED_40MHZ_INTOLARENT(Dot11nDevCap) (Dot11nDevCap & MBIT(8))
|
#define ISENABLED_40MHZ_INTOLARENT(Dot11nDevCap) (Dot11nDevCap & MBIT(8))
|
||||||
/** Dot11nUsrCap : Reset 40Mhz intolarance enabled */
|
/** Dot11nUsrCap : Reset 40Mhz intolarance enabled */
|
||||||
|
@ -689,8 +699,11 @@ typedef enum _WLAN_802_11_WEP_STATUS {
|
||||||
#define SETHT_DSSSCCK40(HTCapInfo) (HTCapInfo |= MBIT(12))
|
#define SETHT_DSSSCCK40(HTCapInfo) (HTCapInfo |= MBIT(12))
|
||||||
/** SET HTCapInfo : Enable 40Mhz Intolarence */
|
/** SET HTCapInfo : Enable 40Mhz Intolarence */
|
||||||
#define SETHT_40MHZ_INTOLARANT(HTCapInfo) (HTCapInfo |= MBIT(14))
|
#define SETHT_40MHZ_INTOLARANT(HTCapInfo) (HTCapInfo |= MBIT(14))
|
||||||
/** SET HTCapInfo : Disable Static SM power save */
|
|
||||||
#define SETHT_STATIC_SMPS(HTCapInfo) ((HTCapInfo) |= (MBIT(2) | MBIT(3)))
|
/** SET HTCapInfo : Set SM power save disabled */
|
||||||
|
#define SETHT_SMPS_DISABLE(HTCapInfo) ((HTCapInfo) |= (MBIT(2) | MBIT(3)))
|
||||||
|
/** SET HTCapInfo : Set Dynamic SM power save */
|
||||||
|
#define SETHT_SMPS_DYNAMIC(HTCapInfo) ((HTCapInfo) |= MBIT(2))
|
||||||
|
|
||||||
/** RESET HTCapInfo : Set support for LDPC coding capability */
|
/** RESET HTCapInfo : Set support for LDPC coding capability */
|
||||||
#define RESETHT_LDPCCODINGCAP(HTCapInfo) (HTCapInfo &= ~MBIT(0))
|
#define RESETHT_LDPCCODINGCAP(HTCapInfo) (HTCapInfo &= ~MBIT(0))
|
||||||
|
@ -1404,7 +1417,7 @@ typedef MLAN_PACK_START struct _MrvlIEtypes_Extension_t {
|
||||||
/** Element id extension */
|
/** Element id extension */
|
||||||
t_u8 ext_id;
|
t_u8 ext_id;
|
||||||
/** payload */
|
/** payload */
|
||||||
t_u8 data[];
|
t_u8 data[1];
|
||||||
} MLAN_PACK_END MrvlIEtypes_Extension_t, *pMrvlIEtypes_Extension_t;
|
} MLAN_PACK_END MrvlIEtypes_Extension_t, *pMrvlIEtypes_Extension_t;
|
||||||
|
|
||||||
/* HE MAC Capabilities Information field BIT 1 for TWT Req */
|
/* HE MAC Capabilities Information field BIT 1 for TWT Req */
|
||||||
|
@ -1422,12 +1435,18 @@ typedef MLAN_PACK_START struct _MrvlIEtypes_He_cap_t {
|
||||||
t_u8 he_mac_cap[6];
|
t_u8 he_mac_cap[6];
|
||||||
/** he phy capability info */
|
/** he phy capability info */
|
||||||
t_u8 he_phy_cap[11];
|
t_u8 he_phy_cap[11];
|
||||||
/** he txrx mcs support , size would be 4 or 8 or 12 */
|
/** rx mcs for 80 */
|
||||||
t_u8 he_txrx_mcs_support[4];
|
t_u16 rx_mcs_80;
|
||||||
/** 160Mhz tx rx mcs support*/
|
/** tx mcs for 80 */
|
||||||
t_u8 he160_txrx_mcs_support[4];
|
t_u16 tx_mcs_80;
|
||||||
/** 80+80 Mhz tx rx mcs suport */
|
/** rx mcs for bw 160 */
|
||||||
t_u8 he8080_txrx_mcs_support[4];
|
t_u16 rx_mcs_160;
|
||||||
|
/** tx mcs for bw 160 */
|
||||||
|
t_u16 tx_mcs_160;
|
||||||
|
/** rx mcs for bw 80+80 */
|
||||||
|
t_u16 rx_mcs_80p80;
|
||||||
|
/** tx mcs for bw 80+80 */
|
||||||
|
t_u16 tx_mcs_80p80;
|
||||||
/** PPE Thresholds (optional) */
|
/** PPE Thresholds (optional) */
|
||||||
t_u8 val[20];
|
t_u8 val[20];
|
||||||
} MLAN_PACK_END MrvlIEtypes_He_cap_t, *pMrvlIEtypes_he_cap_t;
|
} MLAN_PACK_END MrvlIEtypes_He_cap_t, *pMrvlIEtypes_he_cap_t;
|
||||||
|
@ -1927,6 +1946,8 @@ typedef enum _ENH_PS_MODES {
|
||||||
#define EVENT_VDLL_IND 0x00000081
|
#define EVENT_VDLL_IND 0x00000081
|
||||||
#define EVENT_EXCEED_MAX_P2P_CONN 0x00000089
|
#define EVENT_EXCEED_MAX_P2P_CONN 0x00000089
|
||||||
|
|
||||||
|
/** Card Event definition : RESET PN */
|
||||||
|
|
||||||
#define EVENT_FW_HANG_REPORT 0x0000008F
|
#define EVENT_FW_HANG_REPORT 0x0000008F
|
||||||
|
|
||||||
#define EVENT_FW_DUMP_INFO 0x00000073
|
#define EVENT_FW_DUMP_INFO 0x00000073
|
||||||
|
@ -1982,7 +2003,7 @@ typedef MLAN_PACK_START struct _ie_data {
|
||||||
/** IE Length */
|
/** IE Length */
|
||||||
t_u16 ie_length;
|
t_u16 ie_length;
|
||||||
/** IE pointer */
|
/** IE pointer */
|
||||||
t_u8 ie_ptr[];
|
t_u8 ie_ptr[1];
|
||||||
} MLAN_PACK_END tdls_ie_data;
|
} MLAN_PACK_END tdls_ie_data;
|
||||||
|
|
||||||
/** Event structure for generic events from TDLS FW */
|
/** Event structure for generic events from TDLS FW */
|
||||||
|
@ -2170,6 +2191,7 @@ typedef MLAN_PACK_START struct _RxPD {
|
||||||
t_u64 toa_tod_tstamps;
|
t_u64 toa_tod_tstamps;
|
||||||
/** rx info */
|
/** rx info */
|
||||||
t_u32 rx_info;
|
t_u32 rx_info;
|
||||||
|
|
||||||
} MLAN_PACK_END RxPD, *PRxPD;
|
} MLAN_PACK_END RxPD, *PRxPD;
|
||||||
|
|
||||||
/** IEEEtypes_FrameCtl_t*/
|
/** IEEEtypes_FrameCtl_t*/
|
||||||
|
@ -2938,7 +2960,7 @@ typedef MLAN_PACK_START struct _MrvlIETypes_ChanTRPCConfig_t {
|
||||||
/** channel number */
|
/** channel number */
|
||||||
t_u8 chan_num;
|
t_u8 chan_num;
|
||||||
/** mode groups */
|
/** mode groups */
|
||||||
mod_group_setting mod_group[];
|
mod_group_setting mod_group[1];
|
||||||
} MLAN_PACK_END MrvlIETypes_ChanTRPCConfig_t;
|
} MLAN_PACK_END MrvlIETypes_ChanTRPCConfig_t;
|
||||||
|
|
||||||
/* HostCmd_DS_CHANNEL_TRPC_CONFIG */
|
/* HostCmd_DS_CHANNEL_TRPC_CONFIG */
|
||||||
|
@ -2948,7 +2970,7 @@ typedef MLAN_PACK_START struct _HostCmd_DS_CHANNEL_TRPC_CONFIG {
|
||||||
/** 0/1/2/3 */
|
/** 0/1/2/3 */
|
||||||
t_u16 sub_band;
|
t_u16 sub_band;
|
||||||
/** chan TRPC config */
|
/** chan 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;
|
||||||
|
|
||||||
typedef MLAN_PACK_START struct _HostCmd_DS_MEF_CFG {
|
typedef MLAN_PACK_START struct _HostCmd_DS_MEF_CFG {
|
||||||
|
@ -3176,6 +3198,7 @@ enum API_VER_ID {
|
||||||
FW_API_VER_ID = 2,
|
FW_API_VER_ID = 2,
|
||||||
UAP_FW_API_VER_ID = 3,
|
UAP_FW_API_VER_ID = 3,
|
||||||
CHANRPT_API_VER_ID = 4,
|
CHANRPT_API_VER_ID = 4,
|
||||||
|
FW_HOTFIX_VER_ID = 5,
|
||||||
};
|
};
|
||||||
|
|
||||||
/** FW AP V15 */
|
/** FW AP V15 */
|
||||||
|
@ -3678,6 +3701,15 @@ typedef MLAN_PACK_START struct _HostCmd_DS_802_11_GET_LOG {
|
||||||
t_u32 gdma_abort_cnt;
|
t_u32 gdma_abort_cnt;
|
||||||
/** Rx Reset MAC Count */
|
/** Rx Reset MAC Count */
|
||||||
t_u32 g_reset_rx_mac_cnt;
|
t_u32 g_reset_rx_mac_cnt;
|
||||||
|
// Ownership error counters
|
||||||
|
/*Error Ownership error count*/
|
||||||
|
t_u32 dwCtlErrCnt;
|
||||||
|
/*Control Ownership error count*/
|
||||||
|
t_u32 dwBcnErrCnt;
|
||||||
|
/*Control Ownership error count*/
|
||||||
|
t_u32 dwMgtErrCnt;
|
||||||
|
/*Control Ownership error count*/
|
||||||
|
t_u32 dwDatErrCnt;
|
||||||
} MLAN_PACK_END HostCmd_DS_802_11_GET_LOG;
|
} MLAN_PACK_END HostCmd_DS_802_11_GET_LOG;
|
||||||
|
|
||||||
/* maln wifi rate */
|
/* maln wifi rate */
|
||||||
|
@ -4305,7 +4337,7 @@ MLAN_PACK_START struct coalesce_receive_filt_rule {
|
||||||
t_u8 num_of_fields;
|
t_u8 num_of_fields;
|
||||||
t_u8 pkt_type;
|
t_u8 pkt_type;
|
||||||
t_u16 max_coalescing_delay;
|
t_u16 max_coalescing_delay;
|
||||||
struct coalesce_filt_field_param params[];
|
struct coalesce_filt_field_param params[1];
|
||||||
} MLAN_PACK_END;
|
} MLAN_PACK_END;
|
||||||
|
|
||||||
/** HostCmd_DS_COALESCE_CONFIG */
|
/** HostCmd_DS_COALESCE_CONFIG */
|
||||||
|
@ -4313,7 +4345,7 @@ typedef MLAN_PACK_START struct _HostCmd_DS_COALESCE_CONFIG {
|
||||||
/** Action 0-GET, 1-SET */
|
/** Action 0-GET, 1-SET */
|
||||||
t_u16 action;
|
t_u16 action;
|
||||||
t_u16 num_of_rules;
|
t_u16 num_of_rules;
|
||||||
struct coalesce_receive_filt_rule rule[];
|
struct coalesce_receive_filt_rule rule[1];
|
||||||
} MLAN_PACK_END HostCmd_DS_COALESCE_CONFIG;
|
} MLAN_PACK_END HostCmd_DS_COALESCE_CONFIG;
|
||||||
|
|
||||||
/** TLV type : FW support max connection TLV */
|
/** TLV type : FW support max connection TLV */
|
||||||
|
|
|
@ -132,6 +132,7 @@ typedef MLAN_PACK_START enum _IEEEtypes_ElementId_e {
|
||||||
VS_IE = VENDOR_SPECIFIC_221,
|
VS_IE = VENDOR_SPECIFIC_221,
|
||||||
WAPI_IE = 68,
|
WAPI_IE = 68,
|
||||||
FRAGMENT = 242,
|
FRAGMENT = 242,
|
||||||
|
RSNX_IE = 244,
|
||||||
EXTENSION = 255
|
EXTENSION = 255
|
||||||
} MLAN_PACK_END IEEEtypes_ElementId_e;
|
} MLAN_PACK_END IEEEtypes_ElementId_e;
|
||||||
|
|
||||||
|
@ -1994,7 +1995,8 @@ typedef struct _BSSDescriptor_t {
|
||||||
t_u32 beacon_buf_size;
|
t_u32 beacon_buf_size;
|
||||||
/** Max allocated size for updated scan response */
|
/** Max allocated size for updated scan response */
|
||||||
t_u32 beacon_buf_size_max;
|
t_u32 beacon_buf_size_max;
|
||||||
|
/** scan age in secs */
|
||||||
|
t_u32 age_in_secs;
|
||||||
} BSSDescriptor_t, *pBSSDescriptor_t;
|
} BSSDescriptor_t, *pBSSDescriptor_t;
|
||||||
|
|
||||||
#endif /* !_MLAN_IEEE_H_ */
|
#endif /* !_MLAN_IEEE_H_ */
|
||||||
|
|
|
@ -283,9 +283,15 @@ mlan_status wlan_allocate_adapter(pmlan_adapter pmadapter)
|
||||||
beacon_buffer_size = MAX_SCAN_BEACON_BUFFER;
|
beacon_buffer_size = MAX_SCAN_BEACON_BUFFER;
|
||||||
else
|
else
|
||||||
beacon_buffer_size = DEFAULT_SCAN_BEACON_BUFFER;
|
beacon_buffer_size = DEFAULT_SCAN_BEACON_BUFFER;
|
||||||
ret = pmadapter->callbacks.moal_malloc(pmadapter->pmoal_handle,
|
if (pmadapter->callbacks.moal_vmalloc &&
|
||||||
beacon_buffer_size, MLAN_MEM_DEF,
|
pmadapter->callbacks.moal_vfree)
|
||||||
|
ret = pmadapter->callbacks.moal_vmalloc(
|
||||||
|
pmadapter->pmoal_handle, beacon_buffer_size,
|
||||||
(t_u8 **)&pmadapter->bcn_buf);
|
(t_u8 **)&pmadapter->bcn_buf);
|
||||||
|
else
|
||||||
|
ret = pmadapter->callbacks.moal_malloc(
|
||||||
|
pmadapter->pmoal_handle, beacon_buffer_size,
|
||||||
|
MLAN_MEM_DEF, (t_u8 **)&pmadapter->bcn_buf);
|
||||||
if (ret != MLAN_STATUS_SUCCESS || !pmadapter->bcn_buf) {
|
if (ret != MLAN_STATUS_SUCCESS || !pmadapter->bcn_buf) {
|
||||||
PRINTM(MERROR, "Failed to allocate bcn buf\n");
|
PRINTM(MERROR, "Failed to allocate bcn buf\n");
|
||||||
LEAVE();
|
LEAVE();
|
||||||
|
@ -721,7 +727,7 @@ 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;
|
||||||
pmadapter->ext_scan = MTRUE;
|
pmadapter->ext_scan = EXT_SCAN_TYPE_ENH;
|
||||||
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);
|
||||||
|
@ -1666,6 +1672,10 @@ t_void wlan_free_adapter(pmlan_adapter pmadapter)
|
||||||
pmadapter->pchan_stats = MNULL;
|
pmadapter->pchan_stats = MNULL;
|
||||||
}
|
}
|
||||||
if (pmadapter->bcn_buf) {
|
if (pmadapter->bcn_buf) {
|
||||||
|
if (pcb->moal_vmalloc && pcb->moal_vfree)
|
||||||
|
pcb->moal_vfree(pmadapter->pmoal_handle,
|
||||||
|
(t_u8 *)pmadapter->bcn_buf);
|
||||||
|
else
|
||||||
pcb->moal_mfree(pmadapter->pmoal_handle,
|
pcb->moal_mfree(pmadapter->pmoal_handle,
|
||||||
(t_u8 *)pmadapter->bcn_buf);
|
(t_u8 *)pmadapter->bcn_buf);
|
||||||
pmadapter->bcn_buf = MNULL;
|
pmadapter->bcn_buf = MNULL;
|
||||||
|
|
|
@ -1259,8 +1259,9 @@ typedef MLAN_PACK_START struct _otp_region_info {
|
||||||
t_u8 country_code[2];
|
t_u8 country_code[2];
|
||||||
t_u8 region_code;
|
t_u8 region_code;
|
||||||
t_u8 environment;
|
t_u8 environment;
|
||||||
t_u16 force_reg : 1;
|
t_u8 force_reg : 1;
|
||||||
t_u16 reserved : 15;
|
t_u8 reserved : 7;
|
||||||
|
t_u8 dfs_region;
|
||||||
} MLAN_PACK_END otp_region_info_t;
|
} MLAN_PACK_END otp_region_info_t;
|
||||||
|
|
||||||
/** Type definition of mlan_ds_custom_reg_domain */
|
/** Type definition of mlan_ds_custom_reg_domain */
|
||||||
|
@ -1636,6 +1637,15 @@ typedef struct _mlan_ds_get_stats {
|
||||||
t_u32 gdma_abort_cnt;
|
t_u32 gdma_abort_cnt;
|
||||||
/** Rx Reset MAC Count */
|
/** Rx Reset MAC Count */
|
||||||
t_u32 g_reset_rx_mac_cnt;
|
t_u32 g_reset_rx_mac_cnt;
|
||||||
|
// Ownership error counters
|
||||||
|
/*Error Ownership error count*/
|
||||||
|
t_u32 dwCtlErrCnt;
|
||||||
|
/*Control Ownership error count*/
|
||||||
|
t_u32 dwBcnErrCnt;
|
||||||
|
/*Control Ownership error count*/
|
||||||
|
t_u32 dwMgtErrCnt;
|
||||||
|
/*Control Ownership error count*/
|
||||||
|
t_u32 dwDatErrCnt;
|
||||||
} 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 */
|
||||||
|
@ -1771,6 +1781,8 @@ typedef struct _mlan_ds_get_signal {
|
||||||
typedef struct _mlan_fw_info {
|
typedef struct _mlan_fw_info {
|
||||||
/** Firmware version */
|
/** Firmware version */
|
||||||
t_u32 fw_ver;
|
t_u32 fw_ver;
|
||||||
|
/** Firmware Hotfix version */
|
||||||
|
t_u8 hotfix_version;
|
||||||
/** MAC address */
|
/** MAC address */
|
||||||
mlan_802_11_mac_addr mac_addr;
|
mlan_802_11_mac_addr mac_addr;
|
||||||
/** 802.11n device capabilities */
|
/** 802.11n device capabilities */
|
||||||
|
@ -2402,7 +2414,7 @@ typedef struct _sta_info_data {
|
||||||
/** ie length */
|
/** ie length */
|
||||||
t_u16 ie_len;
|
t_u16 ie_len;
|
||||||
/** ie buffer */
|
/** ie buffer */
|
||||||
t_u8 ie_buf[];
|
t_u8 ie_buf[1];
|
||||||
} sta_info_data;
|
} sta_info_data;
|
||||||
|
|
||||||
/** mlan_ds_sta_list structure for MLAN_OID_UAP_STA_LIST */
|
/** mlan_ds_sta_list structure for MLAN_OID_UAP_STA_LIST */
|
||||||
|
@ -2933,7 +2945,9 @@ typedef struct _mlan_ds_beacon_stuck_param_cfg {
|
||||||
#define HOST_SLEEP_COND_IPV6_PACKET MBIT(31)
|
#define HOST_SLEEP_COND_IPV6_PACKET MBIT(31)
|
||||||
|
|
||||||
/** Host sleep config conditions: Default */
|
/** Host sleep config conditions: Default */
|
||||||
#define HOST_SLEEP_DEF_COND 0
|
#define HOST_SLEEP_DEF_COND \
|
||||||
|
(HOST_SLEEP_COND_BROADCAST_DATA | HOST_SLEEP_COND_UNICAST_DATA | \
|
||||||
|
HOST_SLEEP_COND_MAC_EVENT)
|
||||||
|
|
||||||
/** Host sleep config GPIO : Default */
|
/** Host sleep config GPIO : Default */
|
||||||
#define HOST_SLEEP_DEF_GPIO 0xff
|
#define HOST_SLEEP_DEF_GPIO 0xff
|
||||||
|
|
|
@ -346,7 +346,7 @@ extern t_u32 mlan_drvdbg;
|
||||||
(x)->rx_pkt_offset = wlan_le16_to_cpu((x)->rx_pkt_offset); \
|
(x)->rx_pkt_offset = wlan_le16_to_cpu((x)->rx_pkt_offset); \
|
||||||
(x)->rx_pkt_type = wlan_le16_to_cpu((x)->rx_pkt_type); \
|
(x)->rx_pkt_type = wlan_le16_to_cpu((x)->rx_pkt_type); \
|
||||||
(x)->seq_num = wlan_le16_to_cpu((x)->seq_num); \
|
(x)->seq_num = wlan_le16_to_cpu((x)->seq_num); \
|
||||||
(x)->rx_info = wlan_le32_to_cpu((x)->rx_info); \
|
(x)->rx_info = wlan_le32_to_cpu((x)->rx_info);
|
||||||
}
|
}
|
||||||
|
|
||||||
#else
|
#else
|
||||||
|
@ -473,7 +473,7 @@ extern t_void (*assert_callback)(t_void *pmoal_handle, t_u32 cond);
|
||||||
#define DEFAULT_BCN_MISS_TIMEOUT 10
|
#define DEFAULT_BCN_MISS_TIMEOUT 10
|
||||||
|
|
||||||
/** Maximum buffer space for beacons retrieved from scan responses */
|
/** Maximum buffer space for beacons retrieved from scan responses */
|
||||||
#define MAX_SCAN_BEACON_BUFFER 49152
|
#define MAX_SCAN_BEACON_BUFFER 102400
|
||||||
/** Default buffer space for beacons retrieved from scan responses */
|
/** Default buffer space for beacons retrieved from scan responses */
|
||||||
#define DEFAULT_SCAN_BEACON_BUFFER 4096
|
#define DEFAULT_SCAN_BEACON_BUFFER 4096
|
||||||
|
|
||||||
|
@ -2337,6 +2337,8 @@ typedef struct _mlan_adapter {
|
||||||
t_u8 fw_ver;
|
t_u8 fw_ver;
|
||||||
/** firmware minor version */
|
/** firmware minor version */
|
||||||
t_u8 fw_min_ver;
|
t_u8 fw_min_ver;
|
||||||
|
/** firmare hotfix version */
|
||||||
|
t_u8 fw_hotfix_ver;
|
||||||
/** uap firmware version */
|
/** uap firmware version */
|
||||||
t_u8 uap_fw_ver;
|
t_u8 uap_fw_ver;
|
||||||
/** mac address retrun from get_hw_spec */
|
/** mac address retrun from get_hw_spec */
|
||||||
|
@ -2403,6 +2405,8 @@ 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
|
||||||
|
@ -2539,7 +2543,7 @@ typedef struct _mlan_adapter {
|
||||||
t_u8 scan_block;
|
t_u8 scan_block;
|
||||||
/** Extended scan or legacy scan */
|
/** Extended scan or legacy scan */
|
||||||
t_u8 ext_scan;
|
t_u8 ext_scan;
|
||||||
t_u16 bcn_buf_size;
|
t_u32 bcn_buf_size;
|
||||||
/** Beacon buffer */
|
/** Beacon buffer */
|
||||||
t_u8 *bcn_buf;
|
t_u8 *bcn_buf;
|
||||||
/** Pointer to valid beacon buffer end */
|
/** Pointer to valid beacon buffer end */
|
||||||
|
|
|
@ -683,15 +683,16 @@ mlan_status wlan_misc_ioctl_mac_control(pmlan_adapter pmadapter,
|
||||||
t_void wlan_wakeup_card_timeout_func(void *function_context)
|
t_void wlan_wakeup_card_timeout_func(void *function_context)
|
||||||
{
|
{
|
||||||
pmlan_adapter pmadapter = (pmlan_adapter)function_context;
|
pmlan_adapter pmadapter = (pmlan_adapter)function_context;
|
||||||
|
mlan_private *pmpriv = wlan_get_priv(pmadapter, MLAN_BSS_ROLE_ANY);
|
||||||
|
|
||||||
ENTER();
|
ENTER();
|
||||||
|
|
||||||
PRINTM(MERROR, "%s: ps_state=%d\n", __FUNCTION__, pmadapter->ps_state);
|
PRINTM(MERROR, "%s: ps_state=%d\n", __FUNCTION__, pmadapter->ps_state);
|
||||||
if (pmadapter->ps_state != PS_STATE_AWAKE) {
|
if (pmadapter->ps_state != PS_STATE_AWAKE) {
|
||||||
|
PRINTM_NETINTF(MERROR, pmpriv);
|
||||||
PRINTM(MERROR, "Wakeup card timeout!\n");
|
PRINTM(MERROR, "Wakeup card timeout!\n");
|
||||||
pmadapter->pm_wakeup_timeout++;
|
pmadapter->pm_wakeup_timeout++;
|
||||||
wlan_recv_event(wlan_get_priv(pmadapter, MLAN_BSS_ROLE_ANY),
|
wlan_recv_event(pmpriv, MLAN_EVENT_ID_DRV_DBG_DUMP, MNULL);
|
||||||
MLAN_EVENT_ID_DRV_DBG_DUMP, MNULL);
|
|
||||||
}
|
}
|
||||||
pmadapter->wakeup_fw_timer_is_set = MFALSE;
|
pmadapter->wakeup_fw_timer_is_set = MFALSE;
|
||||||
|
|
||||||
|
@ -1741,10 +1742,8 @@ sta_node *wlan_get_station_entry(mlan_private *priv, t_u8 *mac)
|
||||||
LEAVE();
|
LEAVE();
|
||||||
return MNULL;
|
return MNULL;
|
||||||
}
|
}
|
||||||
sta_ptr = (sta_node *)util_peek_list(
|
sta_ptr = (sta_node *)util_peek_list(priv->adapter->pmoal_handle,
|
||||||
priv->adapter->pmoal_handle, &priv->sta_list,
|
&priv->sta_list, MNULL, MNULL);
|
||||||
priv->adapter->callbacks.moal_spin_lock,
|
|
||||||
priv->adapter->callbacks.moal_spin_unlock);
|
|
||||||
|
|
||||||
while (sta_ptr && (sta_ptr != (sta_node *)&priv->sta_list)) {
|
while (sta_ptr && (sta_ptr != (sta_node *)&priv->sta_list)) {
|
||||||
if (!memcmp(priv->adapter, sta_ptr->mac_addr, mac,
|
if (!memcmp(priv->adapter, sta_ptr->mac_addr, mac,
|
||||||
|
@ -1792,9 +1791,7 @@ 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,
|
(pmlan_linked_list)sta_ptr, MNULL, MNULL);
|
||||||
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))
|
||||||
|
@ -1833,9 +1830,7 @@ 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,
|
(pmlan_linked_list)sta_ptr, MNULL, MNULL);
|
||||||
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);
|
||||||
}
|
}
|
||||||
|
|
|
@ -40,7 +40,159 @@ Change log:
|
||||||
/********************************************************
|
/********************************************************
|
||||||
Local Variables
|
Local Variables
|
||||||
********************************************************/
|
********************************************************/
|
||||||
|
#ifdef PCIE8897
|
||||||
|
static const struct _mlan_pcie_card_reg mlan_reg_pcie8897 = {
|
||||||
|
.reg_txbd_rdptr = PCIE8897_RD_DATA_PTR_Q0_Q1,
|
||||||
|
.reg_txbd_wrptr = PCIE8897_WR_DATA_PTR_Q0_Q1,
|
||||||
|
.reg_rxbd_rdptr = PCIE8897_RD_DATA_PTR_Q0_Q1,
|
||||||
|
.reg_rxbd_wrptr = PCIE8897_WR_DATA_PTR_Q0_Q1,
|
||||||
|
.reg_evtbd_rdptr = REG_EVTBD_RDPTR,
|
||||||
|
.reg_evtbd_wrptr = REG_EVTBD_WRPTR,
|
||||||
|
.reg_host_int_mask = PCIE_HOST_INT_MASK,
|
||||||
|
.reg_host_int_status_mask = PCIE_HOST_INT_STATUS_MASK,
|
||||||
|
.reg_host_int_status = PCIE_HOST_INT_STATUS,
|
||||||
|
.reg_cpu_int_event = PCIE_CPU_INT_EVENT,
|
||||||
|
.reg_ip_rev = PCIE_IP_REV_REG,
|
||||||
|
.reg_drv_ready = REG_DRV_READY,
|
||||||
|
.reg_cpu_int_status = PCIE_CPU_INT_STATUS,
|
||||||
|
.reg_scratch_0 = PCIE_SCRATCH_0_REG,
|
||||||
|
.reg_scratch_1 = PCIE_SCRATCH_1_REG,
|
||||||
|
.reg_scratch_2 = PCIE_SCRATCH_2_REG,
|
||||||
|
.reg_scratch_3 = PCIE_SCRATCH_3_REG,
|
||||||
|
.host_intr_mask = HOST_INTR_MASK,
|
||||||
|
.host_intr_dnld_done = HOST_INTR_DNLD_DONE,
|
||||||
|
.host_intr_upld_rdy = HOST_INTR_UPLD_RDY,
|
||||||
|
.host_intr_cmd_done = HOST_INTR_CMD_DONE,
|
||||||
|
.host_intr_event_rdy = HOST_INTR_EVENT_RDY,
|
||||||
|
.txrx_rw_ptr_mask = 0x000003FF,
|
||||||
|
.txrx_rw_ptr_wrap_mask = 0x000007FF,
|
||||||
|
.txrx_rw_ptr_rollover_ind = MBIT(10),
|
||||||
|
.use_adma = MFALSE,
|
||||||
|
.msi_int_wr_clr = MTRUE,
|
||||||
|
};
|
||||||
|
|
||||||
|
static const struct _mlan_card_info mlan_card_info_pcie8897 = {
|
||||||
|
.max_tx_buf_size = MLAN_TX_DATA_BUF_SIZE_4K,
|
||||||
|
.v16_fw_api = 0,
|
||||||
|
.supp_ps_handshake = 0,
|
||||||
|
.default_11n_tx_bf_cap = DEFAULT_11N_TX_BF_CAP_2X2,
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef PCIE8997
|
||||||
|
static const struct _mlan_pcie_card_reg mlan_reg_pcie8997 = {
|
||||||
|
.reg_txbd_rdptr = PCIE8997_RD_DATA_PTR_Q0_Q1,
|
||||||
|
.reg_txbd_wrptr = PCIE8997_WR_DATA_PTR_Q0_Q1,
|
||||||
|
.reg_rxbd_rdptr = PCIE8997_RD_DATA_PTR_Q0_Q1,
|
||||||
|
.reg_rxbd_wrptr = PCIE8997_WR_DATA_PTR_Q0_Q1,
|
||||||
|
.reg_evtbd_rdptr = REG_EVTBD_RDPTR,
|
||||||
|
.reg_evtbd_wrptr = REG_EVTBD_WRPTR,
|
||||||
|
.reg_host_int_mask = PCIE_HOST_INT_MASK,
|
||||||
|
.reg_host_int_status_mask = PCIE_HOST_INT_STATUS_MASK,
|
||||||
|
.reg_host_int_status = PCIE_HOST_INT_STATUS,
|
||||||
|
.reg_cpu_int_event = PCIE_CPU_INT_EVENT,
|
||||||
|
.reg_ip_rev = PCIE_IP_REV_REG,
|
||||||
|
.reg_drv_ready = REG_DRV_READY,
|
||||||
|
.reg_cpu_int_status = PCIE_CPU_INT_STATUS,
|
||||||
|
.reg_scratch_0 = PCIE_SCRATCH_0_REG,
|
||||||
|
.reg_scratch_1 = PCIE_SCRATCH_1_REG,
|
||||||
|
.reg_scratch_2 = PCIE_SCRATCH_2_REG,
|
||||||
|
.reg_scratch_3 = PCIE_SCRATCH_3_REG,
|
||||||
|
.host_intr_mask = HOST_INTR_MASK,
|
||||||
|
.host_intr_dnld_done = HOST_INTR_DNLD_DONE,
|
||||||
|
.host_intr_upld_rdy = HOST_INTR_UPLD_RDY,
|
||||||
|
.host_intr_cmd_done = HOST_INTR_CMD_DONE,
|
||||||
|
.host_intr_event_rdy = HOST_INTR_EVENT_RDY,
|
||||||
|
.txrx_rw_ptr_mask = 0x00000FFF,
|
||||||
|
.txrx_rw_ptr_wrap_mask = 0x00001FFF,
|
||||||
|
.txrx_rw_ptr_rollover_ind = MBIT(12),
|
||||||
|
.use_adma = MFALSE,
|
||||||
|
.msi_int_wr_clr = MTRUE,
|
||||||
|
};
|
||||||
|
|
||||||
|
static const struct _mlan_card_info mlan_card_info_pcie8997 = {
|
||||||
|
.max_tx_buf_size = MLAN_TX_DATA_BUF_SIZE_4K,
|
||||||
|
.v16_fw_api = 1,
|
||||||
|
.supp_ps_handshake = 0,
|
||||||
|
.default_11n_tx_bf_cap = DEFAULT_11N_TX_BF_CAP_2X2,
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef PCIE9097
|
||||||
|
static const struct _mlan_pcie_card_reg mlan_reg_pcie9097_b0 = {
|
||||||
|
.reg_txbd_rdptr = PCIE9098_TXBD_RDPTR,
|
||||||
|
.reg_txbd_wrptr = PCIE9098_TXBD_WRPTR,
|
||||||
|
.reg_rxbd_rdptr = PCIE9098_RXBD_RDPTR,
|
||||||
|
.reg_rxbd_wrptr = PCIE9098_RXBD_WRPTR,
|
||||||
|
.reg_evtbd_rdptr = PCIE9098_EVTBD_RDPTR,
|
||||||
|
.reg_evtbd_wrptr = PCIE9098_EVTBD_WRPTR,
|
||||||
|
.reg_host_int_mask = PCIE9097_B0_HOST_INT_MASK,
|
||||||
|
.reg_host_int_status_mask = PCIE9097_B0_HOST_INT_STATUS_MASK,
|
||||||
|
.reg_host_int_status = PCIE9097_B0_HOST_INT_STATUS,
|
||||||
|
.reg_host_int_clr_sel = PCIE9097_B0_HOST_INT_CLR_SEL,
|
||||||
|
.reg_cpu_int_event = PCIE9098_CPU_INT_EVENT,
|
||||||
|
.reg_ip_rev = PCIE9098_DEV_ID_REG,
|
||||||
|
.reg_drv_ready = PCIE9098_DRV_READY,
|
||||||
|
.reg_cpu_int_status = PCIE9098_CPU_INT_STATUS,
|
||||||
|
.reg_rev_id = PCIE9098_REV_ID_REG,
|
||||||
|
.reg_scratch_0 = PCIE9098_SCRATCH_0_REG,
|
||||||
|
.reg_scratch_1 = PCIE9098_SCRATCH_1_REG,
|
||||||
|
.reg_scratch_2 = PCIE9098_SCRATCH_2_REG,
|
||||||
|
.reg_scratch_3 = PCIE9098_SCRATCH_3_REG,
|
||||||
|
.reg_scratch_6 = PCIE9098_SCRATCH_6_REG,
|
||||||
|
.reg_scratch_7 = PCIE9098_SCRATCH_7_REG,
|
||||||
|
.host_intr_mask = PCIE9098_HOST_INTR_MASK,
|
||||||
|
.host_intr_dnld_done = PCIE9098_HOST_INTR_DNLD_DONE,
|
||||||
|
.host_intr_upld_rdy = PCIE9098_HOST_INTR_UPLD_RDY,
|
||||||
|
.host_intr_cmd_done = PCIE9098_HOST_INTR_CMD_DONE,
|
||||||
|
.host_intr_event_rdy = PCIE9098_HOST_INTR_EVENT_RDY,
|
||||||
|
.host_intr_cmd_dnld = PCIE9098_HOST_INTR_CMD_DNLD,
|
||||||
|
.use_adma = MTRUE,
|
||||||
|
.msi_int_wr_clr = MTRUE,
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(PCIE9098) || defined(PCIE9097)
|
||||||
|
static const struct _mlan_pcie_card_reg mlan_reg_pcie9098 = {
|
||||||
|
.reg_txbd_rdptr = PCIE9098_TXBD_RDPTR,
|
||||||
|
.reg_txbd_wrptr = PCIE9098_TXBD_WRPTR,
|
||||||
|
.reg_rxbd_rdptr = PCIE9098_RXBD_RDPTR,
|
||||||
|
.reg_rxbd_wrptr = PCIE9098_RXBD_WRPTR,
|
||||||
|
.reg_evtbd_rdptr = PCIE9098_EVTBD_RDPTR,
|
||||||
|
.reg_evtbd_wrptr = PCIE9098_EVTBD_WRPTR,
|
||||||
|
.reg_host_int_mask = PCIE9098_HOST_INT_MASK,
|
||||||
|
.reg_host_int_status_mask = PCIE9098_HOST_INT_STATUS_MASK,
|
||||||
|
.reg_host_int_status = PCIE9098_HOST_INT_STATUS,
|
||||||
|
.reg_host_int_clr_sel = PCIE9098_HOST_INT_CLR_SEL,
|
||||||
|
.reg_cpu_int_event = PCIE9098_CPU_INT_EVENT,
|
||||||
|
.reg_ip_rev = PCIE9098_DEV_ID_REG,
|
||||||
|
.reg_drv_ready = PCIE9098_DRV_READY,
|
||||||
|
.reg_cpu_int_status = PCIE9098_CPU_INT_STATUS,
|
||||||
|
.reg_rev_id = PCIE9098_REV_ID_REG,
|
||||||
|
.reg_scratch_0 = PCIE9098_SCRATCH_0_REG,
|
||||||
|
.reg_scratch_1 = PCIE9098_SCRATCH_1_REG,
|
||||||
|
.reg_scratch_2 = PCIE9098_SCRATCH_2_REG,
|
||||||
|
.reg_scratch_3 = PCIE9098_SCRATCH_3_REG,
|
||||||
|
.reg_scratch_6 = PCIE9098_SCRATCH_6_REG,
|
||||||
|
.reg_scratch_7 = PCIE9098_SCRATCH_7_REG,
|
||||||
|
.host_intr_mask = PCIE9098_HOST_INTR_MASK,
|
||||||
|
.host_intr_dnld_done = PCIE9098_HOST_INTR_DNLD_DONE,
|
||||||
|
.host_intr_upld_rdy = PCIE9098_HOST_INTR_UPLD_RDY,
|
||||||
|
.host_intr_cmd_done = PCIE9098_HOST_INTR_CMD_DONE,
|
||||||
|
.host_intr_event_rdy = PCIE9098_HOST_INTR_EVENT_RDY,
|
||||||
|
.host_intr_cmd_dnld = PCIE9098_HOST_INTR_CMD_DNLD,
|
||||||
|
.use_adma = MTRUE,
|
||||||
|
.msi_int_wr_clr = MTRUE,
|
||||||
|
};
|
||||||
|
|
||||||
|
static const struct _mlan_card_info mlan_card_info_pcie9098 = {
|
||||||
|
.max_tx_buf_size = MLAN_TX_DATA_BUF_SIZE_4K,
|
||||||
|
.v16_fw_api = 1,
|
||||||
|
.v17_fw_api = 1,
|
||||||
|
.supp_ps_handshake = 0,
|
||||||
|
.default_11n_tx_bf_cap = DEFAULT_11N_TX_BF_CAP_2X2,
|
||||||
|
};
|
||||||
|
#endif
|
||||||
/********************************************************
|
/********************************************************
|
||||||
Global Variables
|
Global Variables
|
||||||
********************************************************/
|
********************************************************/
|
||||||
|
@ -2464,7 +2616,14 @@ static mlan_status wlan_pcie_process_cmd_resp(mlan_adapter *pmadapter)
|
||||||
|
|
||||||
pmadapter->upld_len = wlan_le16_to_cpu(resp_len);
|
pmadapter->upld_len = wlan_le16_to_cpu(resp_len);
|
||||||
pmadapter->upld_len -= PCIE_INTF_HEADER_LEN;
|
pmadapter->upld_len -= PCIE_INTF_HEADER_LEN;
|
||||||
|
cmd_buf = pmadapter->pcard_pcie->cmd_buf;
|
||||||
|
if (cmd_buf) {
|
||||||
|
pcb->moal_unmap_memory(pmadapter->pmoal_handle,
|
||||||
|
cmd_buf->pbuf + cmd_buf->data_offset,
|
||||||
|
cmd_buf->buf_pa, WLAN_UPLD_SIZE,
|
||||||
|
PCI_DMA_TODEVICE);
|
||||||
|
pmadapter->pcard_pcie->cmd_buf = MNULL;
|
||||||
|
}
|
||||||
if (!pmadapter->curr_cmd) {
|
if (!pmadapter->curr_cmd) {
|
||||||
if (pmadapter->ps_state == PS_STATE_SLEEP_CFM) {
|
if (pmadapter->ps_state == PS_STATE_SLEEP_CFM) {
|
||||||
wlan_process_sleep_confirm_resp(
|
wlan_process_sleep_confirm_resp(
|
||||||
|
@ -2500,15 +2659,6 @@ static mlan_status wlan_pcie_process_cmd_resp(mlan_adapter *pmadapter)
|
||||||
mlan_delay_for_sleep_cookie(pmadapter,
|
mlan_delay_for_sleep_cookie(pmadapter,
|
||||||
MAX_DELAY_LOOP_COUNT);
|
MAX_DELAY_LOOP_COUNT);
|
||||||
#endif
|
#endif
|
||||||
cmd_buf = pmadapter->pcard_pcie->cmd_buf;
|
|
||||||
if (cmd_buf) {
|
|
||||||
pcb->moal_unmap_memory(
|
|
||||||
pmadapter->pmoal_handle,
|
|
||||||
cmd_buf->pbuf + cmd_buf->data_offset,
|
|
||||||
cmd_buf->buf_pa, WLAN_UPLD_SIZE,
|
|
||||||
PCI_DMA_TODEVICE);
|
|
||||||
pmadapter->pcard_pcie->cmd_buf = MNULL;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
memcpy_ext(pmadapter, pmadapter->upld_buf,
|
memcpy_ext(pmadapter, pmadapter->upld_buf,
|
||||||
pmbuf->pbuf + pmbuf->data_offset +
|
pmbuf->pbuf + pmbuf->data_offset +
|
||||||
|
@ -2580,9 +2730,6 @@ static mlan_status wlan_pcie_cmdrsp_complete(mlan_adapter *pmadapter,
|
||||||
mlan_buffer *pmbuf,
|
mlan_buffer *pmbuf,
|
||||||
mlan_status status)
|
mlan_status status)
|
||||||
{
|
{
|
||||||
mlan_buffer *pcmdmbuf;
|
|
||||||
pmlan_callbacks pcb = &pmadapter->callbacks;
|
|
||||||
|
|
||||||
ENTER();
|
ENTER();
|
||||||
|
|
||||||
/*return the cmd response pmbuf*/
|
/*return the cmd response pmbuf*/
|
||||||
|
@ -2592,18 +2739,6 @@ static mlan_status wlan_pcie_cmdrsp_complete(mlan_adapter *pmadapter,
|
||||||
pmadapter->pcard_pcie->cmdrsp_buf = pmbuf;
|
pmadapter->pcard_pcie->cmdrsp_buf = pmbuf;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*unmap the cmd pmbuf, so the cpu can not access the memory in the
|
|
||||||
* command node*/
|
|
||||||
pcmdmbuf = pmadapter->pcard_pcie->cmd_buf;
|
|
||||||
|
|
||||||
if (pcmdmbuf) {
|
|
||||||
pcb->moal_unmap_memory(pmadapter->pmoal_handle,
|
|
||||||
pcmdmbuf->pbuf + pcmdmbuf->data_offset,
|
|
||||||
pcmdmbuf->buf_pa, WLAN_UPLD_SIZE,
|
|
||||||
PCI_DMA_TODEVICE);
|
|
||||||
pmadapter->pcard_pcie->cmd_buf = MNULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
LEAVE();
|
LEAVE();
|
||||||
return MLAN_STATUS_SUCCESS;
|
return MLAN_STATUS_SUCCESS;
|
||||||
}
|
}
|
||||||
|
@ -3437,13 +3572,15 @@ static mlan_status wlan_pcie_interrupt(t_u16 msg_id, pmlan_adapter pmadapter)
|
||||||
pmoal_handle,
|
pmoal_handle,
|
||||||
pmadapter->pcard_pcie->reg->reg_host_int_status,
|
pmadapter->pcard_pcie->reg->reg_host_int_status,
|
||||||
&pcie_ireg)) {
|
&pcie_ireg)) {
|
||||||
PRINTM(MWARN, "Read register failed\n");
|
PRINTM(MERROR, "Read func%d register failed\n",
|
||||||
|
pmadapter->pcard_pcie->func_num);
|
||||||
LEAVE();
|
LEAVE();
|
||||||
return MLAN_STATUS_FAILURE;
|
return MLAN_STATUS_FAILURE;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((pcie_ireg != 0xFFFFFFFF) && (pcie_ireg)) {
|
if ((pcie_ireg != 0xFFFFFFFF) && (pcie_ireg)) {
|
||||||
PRINTM(MINTR, "pcie_ireg=0x%x\n", pcie_ireg);
|
PRINTM(MINTR, "func%d: pcie_ireg=0x%x\n",
|
||||||
|
pmadapter->pcard_pcie->func_num, pcie_ireg);
|
||||||
if (!pmadapter->pps_uapsd_mode &&
|
if (!pmadapter->pps_uapsd_mode &&
|
||||||
(pmadapter->ps_state == PS_STATE_SLEEP)) {
|
(pmadapter->ps_state == PS_STATE_SLEEP)) {
|
||||||
/* Potentially for PCIe we could get other
|
/* Potentially for PCIe we could get other
|
||||||
|
@ -3573,20 +3710,22 @@ static mlan_status wlan_process_pcie_int_status(mlan_adapter *pmadapter)
|
||||||
pmadapter->pmoal_handle,
|
pmadapter->pmoal_handle,
|
||||||
pmadapter->pcard_pcie->reg->reg_host_int_status,
|
pmadapter->pcard_pcie->reg->reg_host_int_status,
|
||||||
&pcie_ireg)) {
|
&pcie_ireg)) {
|
||||||
PRINTM(MWARN, "Read register failed\n");
|
PRINTM(MERROR, "Read func%d register failed\n",
|
||||||
|
pmadapter->pcard_pcie->func_num);
|
||||||
ret = MLAN_STATUS_FAILURE;
|
ret = MLAN_STATUS_FAILURE;
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((pcie_ireg != 0xFFFFFFFF) && (pcie_ireg)) {
|
if ((pcie_ireg != 0xFFFFFFFF) && (pcie_ireg)) {
|
||||||
PRINTM(MINTR, "pcie_ireg=0x%x\n", pcie_ireg);
|
PRINTM(MINTR, "func%d: pcie_ireg=0x%x\n",
|
||||||
|
pmadapter->pcard_pcie->func_num, pcie_ireg);
|
||||||
if (pmadapter->pcard_pcie->reg->msi_int_wr_clr) {
|
if (pmadapter->pcard_pcie->reg->msi_int_wr_clr) {
|
||||||
if (pcb->moal_write_reg(
|
if (pcb->moal_write_reg(
|
||||||
pmadapter->pmoal_handle,
|
pmadapter->pmoal_handle,
|
||||||
pmadapter->pcard_pcie->reg
|
pmadapter->pcard_pcie->reg
|
||||||
->reg_host_int_status,
|
->reg_host_int_status,
|
||||||
~pcie_ireg)) {
|
~pcie_ireg)) {
|
||||||
PRINTM(MWARN,
|
PRINTM(MERROR,
|
||||||
"Write register failed\n");
|
"Write register failed\n");
|
||||||
ret = MLAN_STATUS_FAILURE;
|
ret = MLAN_STATUS_FAILURE;
|
||||||
goto done;
|
goto done;
|
||||||
|
@ -3671,13 +3810,15 @@ static mlan_status wlan_process_pcie_int_status(mlan_adapter *pmadapter)
|
||||||
pmadapter->pmoal_handle,
|
pmadapter->pmoal_handle,
|
||||||
pmadapter->pcard_pcie->reg->reg_host_int_status,
|
pmadapter->pcard_pcie->reg->reg_host_int_status,
|
||||||
&pcie_ireg)) {
|
&pcie_ireg)) {
|
||||||
PRINTM(MWARN, "Read register failed\n");
|
PRINTM(MERROR, "Read func%d register failed\n",
|
||||||
|
pmadapter->pcard_pcie->func_num);
|
||||||
ret = MLAN_STATUS_FAILURE;
|
ret = MLAN_STATUS_FAILURE;
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((pcie_ireg != 0xFFFFFFFF) && (pcie_ireg)) {
|
if ((pcie_ireg != 0xFFFFFFFF) && (pcie_ireg)) {
|
||||||
PRINTM(MINTR, "Poll: pcie_ireg=0x%x\n", pcie_ireg);
|
PRINTM(MINTR, "func%d: Poll pcie_ireg=0x%x\n",
|
||||||
|
pmadapter->pcard_pcie->func_num, pcie_ireg);
|
||||||
if ((pmadapter->pcard_pcie->pcie_int_mode ==
|
if ((pmadapter->pcard_pcie->pcie_int_mode ==
|
||||||
PCIE_INT_MODE_LEGACY) ||
|
PCIE_INT_MODE_LEGACY) ||
|
||||||
pmadapter->pcard_pcie->reg->msi_int_wr_clr) {
|
pmadapter->pcard_pcie->reg->msi_int_wr_clr) {
|
||||||
|
@ -4287,7 +4428,8 @@ static mlan_status wlan_pm_pcie_wakeup_card(pmlan_adapter pmadapter,
|
||||||
t_u32 age_ts_usec;
|
t_u32 age_ts_usec;
|
||||||
|
|
||||||
ENTER();
|
ENTER();
|
||||||
PRINTM(MEVENT, "Wakeup device...\n");
|
PRINTM(MEVENT, "func%d: Wakeup device...\n",
|
||||||
|
pmadapter->pcard_pcie->func_num);
|
||||||
pmadapter->callbacks.moal_get_system_time(pmadapter->pmoal_handle,
|
pmadapter->callbacks.moal_get_system_time(pmadapter->pmoal_handle,
|
||||||
&pmadapter->pm_wakeup_in_secs,
|
&pmadapter->pm_wakeup_in_secs,
|
||||||
&age_ts_usec);
|
&age_ts_usec);
|
||||||
|
|
|
@ -458,160 +458,6 @@ Change log:
|
||||||
/** Max interrupt status register read limit */
|
/** Max interrupt status register read limit */
|
||||||
#define MAX_READ_REG_RETRY 10000
|
#define MAX_READ_REG_RETRY 10000
|
||||||
|
|
||||||
#ifdef PCIE8897
|
|
||||||
static const struct _mlan_pcie_card_reg mlan_reg_pcie8897 = {
|
|
||||||
.reg_txbd_rdptr = PCIE8897_RD_DATA_PTR_Q0_Q1,
|
|
||||||
.reg_txbd_wrptr = PCIE8897_WR_DATA_PTR_Q0_Q1,
|
|
||||||
.reg_rxbd_rdptr = PCIE8897_RD_DATA_PTR_Q0_Q1,
|
|
||||||
.reg_rxbd_wrptr = PCIE8897_WR_DATA_PTR_Q0_Q1,
|
|
||||||
.reg_evtbd_rdptr = REG_EVTBD_RDPTR,
|
|
||||||
.reg_evtbd_wrptr = REG_EVTBD_WRPTR,
|
|
||||||
.reg_host_int_mask = PCIE_HOST_INT_MASK,
|
|
||||||
.reg_host_int_status_mask = PCIE_HOST_INT_STATUS_MASK,
|
|
||||||
.reg_host_int_status = PCIE_HOST_INT_STATUS,
|
|
||||||
.reg_cpu_int_event = PCIE_CPU_INT_EVENT,
|
|
||||||
.reg_ip_rev = PCIE_IP_REV_REG,
|
|
||||||
.reg_drv_ready = REG_DRV_READY,
|
|
||||||
.reg_cpu_int_status = PCIE_CPU_INT_STATUS,
|
|
||||||
.reg_scratch_0 = PCIE_SCRATCH_0_REG,
|
|
||||||
.reg_scratch_1 = PCIE_SCRATCH_1_REG,
|
|
||||||
.reg_scratch_2 = PCIE_SCRATCH_2_REG,
|
|
||||||
.reg_scratch_3 = PCIE_SCRATCH_3_REG,
|
|
||||||
.host_intr_mask = HOST_INTR_MASK,
|
|
||||||
.host_intr_dnld_done = HOST_INTR_DNLD_DONE,
|
|
||||||
.host_intr_upld_rdy = HOST_INTR_UPLD_RDY,
|
|
||||||
.host_intr_cmd_done = HOST_INTR_CMD_DONE,
|
|
||||||
.host_intr_event_rdy = HOST_INTR_EVENT_RDY,
|
|
||||||
.txrx_rw_ptr_mask = 0x000003FF,
|
|
||||||
.txrx_rw_ptr_wrap_mask = 0x000007FF,
|
|
||||||
.txrx_rw_ptr_rollover_ind = MBIT(10),
|
|
||||||
.use_adma = MFALSE,
|
|
||||||
.msi_int_wr_clr = MTRUE,
|
|
||||||
};
|
|
||||||
|
|
||||||
static const struct _mlan_card_info mlan_card_info_pcie8897 = {
|
|
||||||
.max_tx_buf_size = MLAN_TX_DATA_BUF_SIZE_4K,
|
|
||||||
.v16_fw_api = 0,
|
|
||||||
.supp_ps_handshake = 0,
|
|
||||||
.default_11n_tx_bf_cap = DEFAULT_11N_TX_BF_CAP_2X2,
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef PCIE8997
|
|
||||||
static const struct _mlan_pcie_card_reg mlan_reg_pcie8997 = {
|
|
||||||
.reg_txbd_rdptr = PCIE8997_RD_DATA_PTR_Q0_Q1,
|
|
||||||
.reg_txbd_wrptr = PCIE8997_WR_DATA_PTR_Q0_Q1,
|
|
||||||
.reg_rxbd_rdptr = PCIE8997_RD_DATA_PTR_Q0_Q1,
|
|
||||||
.reg_rxbd_wrptr = PCIE8997_WR_DATA_PTR_Q0_Q1,
|
|
||||||
.reg_evtbd_rdptr = REG_EVTBD_RDPTR,
|
|
||||||
.reg_evtbd_wrptr = REG_EVTBD_WRPTR,
|
|
||||||
.reg_host_int_mask = PCIE_HOST_INT_MASK,
|
|
||||||
.reg_host_int_status_mask = PCIE_HOST_INT_STATUS_MASK,
|
|
||||||
.reg_host_int_status = PCIE_HOST_INT_STATUS,
|
|
||||||
.reg_cpu_int_event = PCIE_CPU_INT_EVENT,
|
|
||||||
.reg_ip_rev = PCIE_IP_REV_REG,
|
|
||||||
.reg_drv_ready = REG_DRV_READY,
|
|
||||||
.reg_cpu_int_status = PCIE_CPU_INT_STATUS,
|
|
||||||
.reg_scratch_0 = PCIE_SCRATCH_0_REG,
|
|
||||||
.reg_scratch_1 = PCIE_SCRATCH_1_REG,
|
|
||||||
.reg_scratch_2 = PCIE_SCRATCH_2_REG,
|
|
||||||
.reg_scratch_3 = PCIE_SCRATCH_3_REG,
|
|
||||||
.host_intr_mask = HOST_INTR_MASK,
|
|
||||||
.host_intr_dnld_done = HOST_INTR_DNLD_DONE,
|
|
||||||
.host_intr_upld_rdy = HOST_INTR_UPLD_RDY,
|
|
||||||
.host_intr_cmd_done = HOST_INTR_CMD_DONE,
|
|
||||||
.host_intr_event_rdy = HOST_INTR_EVENT_RDY,
|
|
||||||
.txrx_rw_ptr_mask = 0x00000FFF,
|
|
||||||
.txrx_rw_ptr_wrap_mask = 0x00001FFF,
|
|
||||||
.txrx_rw_ptr_rollover_ind = MBIT(12),
|
|
||||||
.use_adma = MFALSE,
|
|
||||||
.msi_int_wr_clr = MTRUE,
|
|
||||||
};
|
|
||||||
|
|
||||||
static const struct _mlan_card_info mlan_card_info_pcie8997 = {
|
|
||||||
.max_tx_buf_size = MLAN_TX_DATA_BUF_SIZE_4K,
|
|
||||||
.v16_fw_api = 1,
|
|
||||||
.supp_ps_handshake = 0,
|
|
||||||
.default_11n_tx_bf_cap = DEFAULT_11N_TX_BF_CAP_2X2,
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(PCIE9098) || defined(PCIE9097)
|
|
||||||
static const struct _mlan_pcie_card_reg mlan_reg_pcie9098 = {
|
|
||||||
.reg_txbd_rdptr = PCIE9098_TXBD_RDPTR,
|
|
||||||
.reg_txbd_wrptr = PCIE9098_TXBD_WRPTR,
|
|
||||||
.reg_rxbd_rdptr = PCIE9098_RXBD_RDPTR,
|
|
||||||
.reg_rxbd_wrptr = PCIE9098_RXBD_WRPTR,
|
|
||||||
.reg_evtbd_rdptr = PCIE9098_EVTBD_RDPTR,
|
|
||||||
.reg_evtbd_wrptr = PCIE9098_EVTBD_WRPTR,
|
|
||||||
.reg_host_int_mask = PCIE9098_HOST_INT_MASK,
|
|
||||||
.reg_host_int_status_mask = PCIE9098_HOST_INT_STATUS_MASK,
|
|
||||||
.reg_host_int_status = PCIE9098_HOST_INT_STATUS,
|
|
||||||
.reg_host_int_clr_sel = PCIE9098_HOST_INT_CLR_SEL,
|
|
||||||
.reg_cpu_int_event = PCIE9098_CPU_INT_EVENT,
|
|
||||||
.reg_ip_rev = PCIE9098_DEV_ID_REG,
|
|
||||||
.reg_drv_ready = PCIE9098_DRV_READY,
|
|
||||||
.reg_cpu_int_status = PCIE9098_CPU_INT_STATUS,
|
|
||||||
.reg_rev_id = PCIE9098_REV_ID_REG,
|
|
||||||
.reg_scratch_0 = PCIE9098_SCRATCH_0_REG,
|
|
||||||
.reg_scratch_1 = PCIE9098_SCRATCH_1_REG,
|
|
||||||
.reg_scratch_2 = PCIE9098_SCRATCH_2_REG,
|
|
||||||
.reg_scratch_3 = PCIE9098_SCRATCH_3_REG,
|
|
||||||
.reg_scratch_6 = PCIE9098_SCRATCH_6_REG,
|
|
||||||
.reg_scratch_7 = PCIE9098_SCRATCH_7_REG,
|
|
||||||
.host_intr_mask = PCIE9098_HOST_INTR_MASK,
|
|
||||||
.host_intr_dnld_done = PCIE9098_HOST_INTR_DNLD_DONE,
|
|
||||||
.host_intr_upld_rdy = PCIE9098_HOST_INTR_UPLD_RDY,
|
|
||||||
.host_intr_cmd_done = PCIE9098_HOST_INTR_CMD_DONE,
|
|
||||||
.host_intr_event_rdy = PCIE9098_HOST_INTR_EVENT_RDY,
|
|
||||||
.host_intr_cmd_dnld = PCIE9098_HOST_INTR_CMD_DNLD,
|
|
||||||
.use_adma = MTRUE,
|
|
||||||
.msi_int_wr_clr = MTRUE,
|
|
||||||
};
|
|
||||||
|
|
||||||
static const struct _mlan_card_info mlan_card_info_pcie9098 = {
|
|
||||||
.max_tx_buf_size = MLAN_TX_DATA_BUF_SIZE_4K,
|
|
||||||
.v16_fw_api = 1,
|
|
||||||
.v17_fw_api = 1,
|
|
||||||
.supp_ps_handshake = 0,
|
|
||||||
.default_11n_tx_bf_cap = DEFAULT_11N_TX_BF_CAP_2X2,
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef PCIE9097
|
|
||||||
static const struct _mlan_pcie_card_reg mlan_reg_pcie9097_b0 = {
|
|
||||||
.reg_txbd_rdptr = PCIE9098_TXBD_RDPTR,
|
|
||||||
.reg_txbd_wrptr = PCIE9098_TXBD_WRPTR,
|
|
||||||
.reg_rxbd_rdptr = PCIE9098_RXBD_RDPTR,
|
|
||||||
.reg_rxbd_wrptr = PCIE9098_RXBD_WRPTR,
|
|
||||||
.reg_evtbd_rdptr = PCIE9098_EVTBD_RDPTR,
|
|
||||||
.reg_evtbd_wrptr = PCIE9098_EVTBD_WRPTR,
|
|
||||||
.reg_host_int_mask = PCIE9097_B0_HOST_INT_MASK,
|
|
||||||
.reg_host_int_status_mask = PCIE9097_B0_HOST_INT_STATUS_MASK,
|
|
||||||
.reg_host_int_status = PCIE9097_B0_HOST_INT_STATUS,
|
|
||||||
.reg_host_int_clr_sel = PCIE9097_B0_HOST_INT_CLR_SEL,
|
|
||||||
.reg_cpu_int_event = PCIE9098_CPU_INT_EVENT,
|
|
||||||
.reg_ip_rev = PCIE9098_DEV_ID_REG,
|
|
||||||
.reg_drv_ready = PCIE9098_DRV_READY,
|
|
||||||
.reg_cpu_int_status = PCIE9098_CPU_INT_STATUS,
|
|
||||||
.reg_rev_id = PCIE9098_REV_ID_REG,
|
|
||||||
.reg_scratch_0 = PCIE9098_SCRATCH_0_REG,
|
|
||||||
.reg_scratch_1 = PCIE9098_SCRATCH_1_REG,
|
|
||||||
.reg_scratch_2 = PCIE9098_SCRATCH_2_REG,
|
|
||||||
.reg_scratch_3 = PCIE9098_SCRATCH_3_REG,
|
|
||||||
.reg_scratch_6 = PCIE9098_SCRATCH_6_REG,
|
|
||||||
.reg_scratch_7 = PCIE9098_SCRATCH_7_REG,
|
|
||||||
.host_intr_mask = PCIE9098_HOST_INTR_MASK,
|
|
||||||
.host_intr_dnld_done = PCIE9098_HOST_INTR_DNLD_DONE,
|
|
||||||
.host_intr_upld_rdy = PCIE9098_HOST_INTR_UPLD_RDY,
|
|
||||||
.host_intr_cmd_done = PCIE9098_HOST_INTR_CMD_DONE,
|
|
||||||
.host_intr_event_rdy = PCIE9098_HOST_INTR_EVENT_RDY,
|
|
||||||
.host_intr_cmd_dnld = PCIE9098_HOST_INTR_CMD_DNLD,
|
|
||||||
.use_adma = MTRUE,
|
|
||||||
.msi_int_wr_clr = MTRUE,
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
extern mlan_adapter_operations mlan_pcie_ops;
|
extern mlan_adapter_operations mlan_pcie_ops;
|
||||||
|
|
||||||
/* Get pcie device from card type */
|
/* Get pcie device from card type */
|
||||||
|
|
|
@ -496,6 +496,10 @@ static t_void wlan_scan_create_channel_list(
|
||||||
if (radio_type && (pscan_region->band != BAND_A))
|
if (radio_type && (pscan_region->band != BAND_A))
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
PRINTM(MCMD_D,
|
||||||
|
"create_channel_list: region=%d band=%d num_cfp=%d\n",
|
||||||
|
pscan_region->region, pscan_region->band,
|
||||||
|
pscan_region->num_cfp);
|
||||||
if ((puser_scan_in &&
|
if ((puser_scan_in &&
|
||||||
(puser_scan_in->bss_mode == MLAN_SCAN_MODE_IBSS)) ||
|
(puser_scan_in->bss_mode == MLAN_SCAN_MODE_IBSS)) ||
|
||||||
pmpriv->bss_mode == MLAN_BSS_MODE_IBSS)
|
pmpriv->bss_mode == MLAN_BSS_MODE_IBSS)
|
||||||
|
@ -586,7 +590,7 @@ static t_void wlan_scan_create_channel_list(
|
||||||
|
|
||||||
pscan_chan_list[chan_idx].chan_number =
|
pscan_chan_list[chan_idx].chan_number =
|
||||||
(t_u8)cfp->channel;
|
(t_u8)cfp->channel;
|
||||||
PRINTM(MINFO,
|
PRINTM(MCMD_D,
|
||||||
"chan=%d, mode=%d, passive_to_active=%d\n",
|
"chan=%d, mode=%d, passive_to_active=%d\n",
|
||||||
pscan_chan_list[chan_idx].chan_number,
|
pscan_chan_list[chan_idx].chan_number,
|
||||||
pscan_chan_list[chan_idx]
|
pscan_chan_list[chan_idx]
|
||||||
|
@ -737,6 +741,8 @@ wlan_scan_channel_list(mlan_private *pmpriv, t_void *pioctl_buf,
|
||||||
radio_type_to_band(
|
radio_type_to_band(
|
||||||
ptmp_chan_list->bandcfg.chanBand),
|
ptmp_chan_list->bandcfg.chanBand),
|
||||||
ptmp_chan_list->chan_number)) {
|
ptmp_chan_list->chan_number)) {
|
||||||
|
PRINTM(MCMND, "Block scan chan = %d\n",
|
||||||
|
ptmp_chan_list->chan_number);
|
||||||
ptmp_chan_list++;
|
ptmp_chan_list++;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
@ -747,7 +753,7 @@ wlan_scan_channel_list(mlan_private *pmpriv, t_void *pioctl_buf,
|
||||||
first_chan = 0;
|
first_chan = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
PRINTM(MINFO,
|
PRINTM(MCMD_D,
|
||||||
"Scan: Chan(%3d), bandcfg(%x), Mode(%d,%d), Dur(%d)\n",
|
"Scan: Chan(%3d), bandcfg(%x), Mode(%d,%d), Dur(%d)\n",
|
||||||
ptmp_chan_list->chan_number,
|
ptmp_chan_list->chan_number,
|
||||||
ptmp_chan_list->bandcfg,
|
ptmp_chan_list->bandcfg,
|
||||||
|
@ -2439,7 +2445,7 @@ static t_void wlan_ret_802_11_scan_store_beacon(mlan_private *pmpriv,
|
||||||
t_u32 adj_idx;
|
t_u32 adj_idx;
|
||||||
mlan_status ret = MLAN_STATUS_SUCCESS;
|
mlan_status ret = MLAN_STATUS_SUCCESS;
|
||||||
t_u8 *tmp_buf;
|
t_u8 *tmp_buf;
|
||||||
t_u16 bcn_size = 0;
|
t_u32 bcn_size = 0;
|
||||||
t_u32 bcn_offset = 0;
|
t_u32 bcn_offset = 0;
|
||||||
|
|
||||||
ENTER();
|
ENTER();
|
||||||
|
@ -2714,6 +2720,14 @@ static t_void wlan_ret_802_11_scan_store_beacon(mlan_private *pmpriv,
|
||||||
(pmadapter->bcn_buf + pmadapter->bcn_buf_size)) &&
|
(pmadapter->bcn_buf + pmadapter->bcn_buf_size)) &&
|
||||||
(pmadapter->bcn_buf_size < MAX_SCAN_BEACON_BUFFER)) {
|
(pmadapter->bcn_buf_size < MAX_SCAN_BEACON_BUFFER)) {
|
||||||
/* no space for this entry, realloc bcn buffer */
|
/* no space for this entry, realloc bcn buffer */
|
||||||
|
if (pmadapter->callbacks.moal_vmalloc &&
|
||||||
|
pmadapter->callbacks.moal_vfree)
|
||||||
|
ret = pmadapter->callbacks.moal_vmalloc(
|
||||||
|
pmadapter->pmoal_handle,
|
||||||
|
pmadapter->bcn_buf_size +
|
||||||
|
DEFAULT_SCAN_BEACON_BUFFER,
|
||||||
|
(t_u8 **)&tmp_buf);
|
||||||
|
else
|
||||||
ret = pmadapter->callbacks.moal_malloc(
|
ret = pmadapter->callbacks.moal_malloc(
|
||||||
pmadapter->pmoal_handle,
|
pmadapter->pmoal_handle,
|
||||||
pmadapter->bcn_buf_size +
|
pmadapter->bcn_buf_size +
|
||||||
|
@ -2747,6 +2761,12 @@ static t_void wlan_ret_802_11_scan_store_beacon(mlan_private *pmpriv,
|
||||||
&pmadapter->pscan_table[adj_idx]);
|
&pmadapter->pscan_table[adj_idx]);
|
||||||
}
|
}
|
||||||
pmadapter->pbcn_buf_end = tmp_buf + bcn_size;
|
pmadapter->pbcn_buf_end = tmp_buf + bcn_size;
|
||||||
|
if (pmadapter->callbacks.moal_vmalloc &&
|
||||||
|
pmadapter->callbacks.moal_vfree)
|
||||||
|
pmadapter->callbacks.moal_vfree(
|
||||||
|
pmadapter->pmoal_handle,
|
||||||
|
(t_u8 *)pmadapter->bcn_buf);
|
||||||
|
else
|
||||||
pmadapter->callbacks.moal_mfree(
|
pmadapter->callbacks.moal_mfree(
|
||||||
pmadapter->pmoal_handle,
|
pmadapter->pmoal_handle,
|
||||||
(t_u8 *)pmadapter->bcn_buf);
|
(t_u8 *)pmadapter->bcn_buf);
|
||||||
|
@ -3557,6 +3577,44 @@ static t_void wlan_scan_delete_table_entry(mlan_private *pmpriv,
|
||||||
LEAVE();
|
LEAVE();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Delete all entry's age out
|
||||||
|
*
|
||||||
|
* @param pmpriv A pointer to mlan_private structure
|
||||||
|
*
|
||||||
|
* @return N/A
|
||||||
|
*/
|
||||||
|
static void wlan_scan_delete_ageout_entry(mlan_private *pmpriv)
|
||||||
|
{
|
||||||
|
BSSDescriptor_t *pbss_entry;
|
||||||
|
mlan_adapter *pmadapter = pmpriv->adapter;
|
||||||
|
t_s32 table_idx = pmadapter->num_in_scan_table - 1;
|
||||||
|
t_u32 i = 0;
|
||||||
|
t_u32 age_in_secs = 0;
|
||||||
|
t_u32 age_ts_usec = 0;
|
||||||
|
|
||||||
|
ENTER();
|
||||||
|
#define SCAN_RESULT_AGEOUT 10
|
||||||
|
pmadapter->callbacks.moal_get_system_time(pmadapter->pmoal_handle,
|
||||||
|
&age_in_secs, &age_ts_usec);
|
||||||
|
|
||||||
|
for (i = 0; i < pmadapter->num_in_scan_table; i++) {
|
||||||
|
pbss_entry = &pmadapter->pscan_table[table_idx];
|
||||||
|
if (age_in_secs >
|
||||||
|
(pbss_entry->age_in_secs + SCAN_RESULT_AGEOUT)) {
|
||||||
|
PRINTM(MCMND,
|
||||||
|
"SCAN: ageout AP MAC Addr-" MACSTR
|
||||||
|
" ssid: %-32s\n",
|
||||||
|
MAC2STR(pbss_entry->mac_address),
|
||||||
|
pbss_entry->ssid.ssid);
|
||||||
|
wlan_scan_delete_table_entry(pmpriv, table_idx);
|
||||||
|
}
|
||||||
|
table_idx--;
|
||||||
|
}
|
||||||
|
LEAVE();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Delete all occurrences of a given SSID from the scan table
|
* @brief Delete all occurrences of a given SSID from the scan table
|
||||||
*
|
*
|
||||||
|
@ -4089,6 +4147,8 @@ mlan_status wlan_scan_networks(mlan_private *pmpriv, t_void *pioctl_buf,
|
||||||
sizeof(BSSDescriptor_t) * MRVDRV_MAX_BSSID_LIST);
|
sizeof(BSSDescriptor_t) * MRVDRV_MAX_BSSID_LIST);
|
||||||
pmadapter->num_in_scan_table = 0;
|
pmadapter->num_in_scan_table = 0;
|
||||||
pmadapter->pbcn_buf_end = pmadapter->bcn_buf;
|
pmadapter->pbcn_buf_end = pmadapter->bcn_buf;
|
||||||
|
} else {
|
||||||
|
wlan_scan_delete_ageout_entry(pmpriv);
|
||||||
}
|
}
|
||||||
for (i = 0; i < pmadapter->num_in_chan_stats; i++)
|
for (i = 0; i < pmadapter->num_in_chan_stats; i++)
|
||||||
pmadapter->pchan_stats[i].cca_scan_duration = 0;
|
pmadapter->pchan_stats[i].cca_scan_duration = 0;
|
||||||
|
@ -4416,6 +4476,10 @@ mlan_status wlan_ret_802_11_scan(mlan_private *pmpriv, HostCmd_DS_COMMAND *resp,
|
||||||
PRINTM(MINFO, "SCAN_RESP: returned %d APs before parsing\n",
|
PRINTM(MINFO, "SCAN_RESP: returned %d APs before parsing\n",
|
||||||
pscan_rsp->number_of_sets);
|
pscan_rsp->number_of_sets);
|
||||||
|
|
||||||
|
/* Update the age_in_second */
|
||||||
|
pmadapter->callbacks.moal_get_system_time(
|
||||||
|
pmadapter->pmoal_handle, &pmadapter->age_in_secs, &age_ts_usec);
|
||||||
|
|
||||||
num_in_table = pmadapter->num_in_scan_table;
|
num_in_table = pmadapter->num_in_scan_table;
|
||||||
pbss_info = pscan_rsp->bss_desc_and_tlv_buffer;
|
pbss_info = pscan_rsp->bss_desc_and_tlv_buffer;
|
||||||
|
|
||||||
|
@ -4499,7 +4563,7 @@ mlan_status wlan_ret_802_11_scan(mlan_private *pmpriv, HostCmd_DS_COMMAND *resp,
|
||||||
* for use in join
|
* for use in join
|
||||||
*/
|
*/
|
||||||
bss_new_entry->bss_band = band;
|
bss_new_entry->bss_band = band;
|
||||||
|
bss_new_entry->age_in_secs = pmadapter->age_in_secs;
|
||||||
cfp = wlan_find_cfp_by_band_and_channel(
|
cfp = wlan_find_cfp_by_band_and_channel(
|
||||||
pmadapter, (t_u8)bss_new_entry->bss_band,
|
pmadapter, (t_u8)bss_new_entry->bss_band,
|
||||||
(t_u16)bss_new_entry->channel);
|
(t_u16)bss_new_entry->channel);
|
||||||
|
@ -4645,9 +4709,6 @@ mlan_status wlan_ret_802_11_scan(mlan_private *pmpriv, HostCmd_DS_COMMAND *resp,
|
||||||
|
|
||||||
/* Update the total number of BSSIDs in the scan table */
|
/* Update the total number of BSSIDs in the scan table */
|
||||||
pmadapter->num_in_scan_table = num_in_table;
|
pmadapter->num_in_scan_table = num_in_table;
|
||||||
/* Update the age_in_second */
|
|
||||||
pmadapter->callbacks.moal_get_system_time(
|
|
||||||
pmadapter->pmoal_handle, &pmadapter->age_in_secs, &age_ts_usec);
|
|
||||||
if (is_bgscan_resp)
|
if (is_bgscan_resp)
|
||||||
goto done;
|
goto done;
|
||||||
wlan_request_cmd_lock(pmadapter);
|
wlan_request_cmd_lock(pmadapter);
|
||||||
|
@ -4771,6 +4832,7 @@ 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;
|
||||||
}
|
}
|
||||||
|
@ -4840,6 +4902,7 @@ 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,
|
||||||
|
@ -4989,16 +5052,18 @@ done:
|
||||||
*
|
*
|
||||||
* @return MLAN_STATUS_FAILURE/MLAN_STATUS_SUCCESS
|
* @return MLAN_STATUS_FAILURE/MLAN_STATUS_SUCCESS
|
||||||
*/
|
*/
|
||||||
static mlan_status wlan_update_ssid_in_beacon_buf(mlan_adapter *pmadapter,
|
static mlan_status wlan_update_ssid_in_beacon_buf(
|
||||||
BSSDescriptor_t *pbss_entry,
|
mlan_adapter *pmadapter, BSSDescriptor_t *pbss_entry,
|
||||||
BSSDescriptor_t *pnew_entry,
|
BSSDescriptor_t *pnew_entry, IEEEtypes_Ssid_t *pssid,
|
||||||
IEEEtypes_Ssid_t *pssid)
|
IEEEtypes_ExtCap_t *pnew_extcap, IEEEtypes_Generic_t *pnew_rsnx)
|
||||||
{
|
{
|
||||||
mlan_callbacks *pcb = (pmlan_callbacks)&pmadapter->callbacks;
|
mlan_callbacks *pcb = (pmlan_callbacks)&pmadapter->callbacks;
|
||||||
t_u8 *pbeacon_buf = MNULL;
|
t_u8 *pbeacon_buf = MNULL;
|
||||||
t_u32 beacon_buf_size = 0;
|
t_u32 beacon_buf_size = 0;
|
||||||
t_s8 offset = pnew_entry->ssid.ssid_len - pbss_entry->ssid.ssid_len;
|
t_s8 offset = pnew_entry->ssid.ssid_len - pbss_entry->ssid.ssid_len;
|
||||||
|
IEEEtypes_ExtCap_t *pextcap;
|
||||||
mlan_status ret = MLAN_STATUS_FAILURE;
|
mlan_status ret = MLAN_STATUS_FAILURE;
|
||||||
|
t_u32 rsnx_offset = 0;
|
||||||
|
|
||||||
if (pnew_entry->ssid.ssid_len >= pbss_entry->ssid.ssid_len)
|
if (pnew_entry->ssid.ssid_len >= pbss_entry->ssid.ssid_len)
|
||||||
beacon_buf_size =
|
beacon_buf_size =
|
||||||
|
@ -5009,6 +5074,11 @@ static mlan_status wlan_update_ssid_in_beacon_buf(mlan_adapter *pmadapter,
|
||||||
pbss_entry->beacon_buf_size -
|
pbss_entry->beacon_buf_size -
|
||||||
(pbss_entry->ssid.ssid_len - pnew_entry->ssid.ssid_len);
|
(pbss_entry->ssid.ssid_len - pnew_entry->ssid.ssid_len);
|
||||||
|
|
||||||
|
rsnx_offset = beacon_buf_size;
|
||||||
|
if (pnew_rsnx)
|
||||||
|
beacon_buf_size +=
|
||||||
|
pnew_rsnx->ieee_hdr.len + sizeof(IEEEtypes_Header_t);
|
||||||
|
|
||||||
ret = pcb->moal_malloc(pmadapter->pmoal_handle, beacon_buf_size,
|
ret = pcb->moal_malloc(pmadapter->pmoal_handle, beacon_buf_size,
|
||||||
MLAN_MEM_DEF, (t_u8 **)&pbeacon_buf);
|
MLAN_MEM_DEF, (t_u8 **)&pbeacon_buf);
|
||||||
if (ret != MLAN_STATUS_SUCCESS || !pbeacon_buf) {
|
if (ret != MLAN_STATUS_SUCCESS || !pbeacon_buf) {
|
||||||
|
@ -5057,8 +5127,21 @@ static mlan_status wlan_update_ssid_in_beacon_buf(mlan_adapter *pmadapter,
|
||||||
pnew_entry->ht_info_offset += offset;
|
pnew_entry->ht_info_offset += offset;
|
||||||
if (pnew_entry->pbss_co_2040)
|
if (pnew_entry->pbss_co_2040)
|
||||||
pnew_entry->bss_co_2040_offset += offset;
|
pnew_entry->bss_co_2040_offset += offset;
|
||||||
if (pnew_entry->pext_cap)
|
if (pnew_entry->pext_cap) {
|
||||||
pnew_entry->ext_cap_offset += offset;
|
pnew_entry->ext_cap_offset += offset;
|
||||||
|
if (pnew_extcap) {
|
||||||
|
pextcap = (IEEEtypes_ExtCap_t
|
||||||
|
*)(pnew_entry->pbeacon_buf +
|
||||||
|
pnew_entry->ext_cap_offset);
|
||||||
|
memcpy_ext(pmadapter,
|
||||||
|
pbeacon_buf + pnew_entry->ext_cap_offset,
|
||||||
|
(t_u8 *)pnew_extcap,
|
||||||
|
pnew_extcap->ieee_hdr.len +
|
||||||
|
sizeof(IEEEtypes_Header_t),
|
||||||
|
pextcap->ieee_hdr.len +
|
||||||
|
sizeof(IEEEtypes_Header_t));
|
||||||
|
}
|
||||||
|
}
|
||||||
if (pnew_entry->poverlap_bss_scan_param)
|
if (pnew_entry->poverlap_bss_scan_param)
|
||||||
pnew_entry->overlap_bss_offset += offset;
|
pnew_entry->overlap_bss_offset += offset;
|
||||||
if (pnew_entry->pvht_cap)
|
if (pnew_entry->pvht_cap)
|
||||||
|
@ -5079,6 +5162,12 @@ static mlan_status wlan_update_ssid_in_beacon_buf(mlan_adapter *pmadapter,
|
||||||
pnew_entry->he_cap_offset += offset;
|
pnew_entry->he_cap_offset += offset;
|
||||||
if (pnew_entry->phe_oprat)
|
if (pnew_entry->phe_oprat)
|
||||||
pnew_entry->he_oprat_offset += offset;
|
pnew_entry->he_oprat_offset += offset;
|
||||||
|
if (pnew_rsnx)
|
||||||
|
memcpy_ext(
|
||||||
|
pmadapter, pbeacon_buf + rsnx_offset, (t_u8 *)pnew_rsnx,
|
||||||
|
pnew_rsnx->ieee_hdr.len + sizeof(IEEEtypes_Header_t),
|
||||||
|
pnew_rsnx->ieee_hdr.len + sizeof(IEEEtypes_Header_t));
|
||||||
|
DBG_HEXDUMP(MCMD_D, "MBSSID beacon buf", pbeacon_buf, beacon_buf_size);
|
||||||
ret = MLAN_STATUS_SUCCESS;
|
ret = MLAN_STATUS_SUCCESS;
|
||||||
done:
|
done:
|
||||||
return ret;
|
return ret;
|
||||||
|
@ -5097,14 +5186,25 @@ done:
|
||||||
static void wlan_gen_multi_bssid_by_bssid_index(pmlan_adapter pmadapter,
|
static void wlan_gen_multi_bssid_by_bssid_index(pmlan_adapter pmadapter,
|
||||||
BSSDescriptor_t *pbss_entry,
|
BSSDescriptor_t *pbss_entry,
|
||||||
BSSDescriptor_t *pnew_entry,
|
BSSDescriptor_t *pnew_entry,
|
||||||
t_u8 bssid_index)
|
t_u8 bssid_index,
|
||||||
|
t_u8 max_bssid_indicator)
|
||||||
{
|
{
|
||||||
t_u8 mask = 0xff;
|
t_u8 mask = 0xff;
|
||||||
t_u8 new_bssid[6];
|
t_u8 new_bssid[6];
|
||||||
|
t_u8 bssid_a;
|
||||||
|
t_u8 src_bssid[6];
|
||||||
|
|
||||||
|
memcpy_ext(pmadapter, (t_u8 *)src_bssid, pbss_entry->mac_address,
|
||||||
|
sizeof(mlan_802_11_mac_addr), sizeof(src_bssid));
|
||||||
memcpy_ext(pmadapter, (t_u8 *)new_bssid,
|
memcpy_ext(pmadapter, (t_u8 *)new_bssid,
|
||||||
(t_u8 *)&pbss_entry->mac_address,
|
(t_u8 *)&pbss_entry->mac_address,
|
||||||
sizeof(mlan_802_11_mac_addr), sizeof(new_bssid));
|
sizeof(mlan_802_11_mac_addr), sizeof(new_bssid));
|
||||||
new_bssid[5] = (new_bssid[5] + bssid_index) & mask;
|
|
||||||
|
mask = (mask >> (8 - max_bssid_indicator));
|
||||||
|
bssid_a = src_bssid[5] & (~mask);
|
||||||
|
src_bssid[5] = (src_bssid[5] + bssid_index) & mask;
|
||||||
|
new_bssid[5] = bssid_a | src_bssid[5];
|
||||||
|
|
||||||
memcpy_ext(pmadapter, (t_u8 *)&pnew_entry->mac_address, new_bssid,
|
memcpy_ext(pmadapter, (t_u8 *)&pnew_entry->mac_address, new_bssid,
|
||||||
sizeof(new_bssid), sizeof(mlan_802_11_mac_addr));
|
sizeof(new_bssid), sizeof(mlan_802_11_mac_addr));
|
||||||
memcpy_ext(pmadapter, (t_u8 *)&pnew_entry->multi_bssid_ap_addr,
|
memcpy_ext(pmadapter, (t_u8 *)&pnew_entry->multi_bssid_ap_addr,
|
||||||
|
@ -5121,12 +5221,14 @@ static void wlan_gen_multi_bssid_by_bssid_index(pmlan_adapter pmadapter,
|
||||||
* @param pbss_profile A pointer to IEEEtypes_NonTransBSSIDprofile_t
|
* @param pbss_profile A pointer to IEEEtypes_NonTransBSSIDprofile_t
|
||||||
* @param num_in_table A pointer to buffer to save num of entry in scan
|
* @param num_in_table A pointer to buffer to save num of entry in scan
|
||||||
* table.
|
* table.
|
||||||
|
* @param max_bssid_indicator max bssid indicator
|
||||||
*
|
*
|
||||||
* @return N/A
|
* @return N/A
|
||||||
*/
|
*/
|
||||||
static t_void wlan_parse_non_trans_bssid_profile(
|
static t_void wlan_parse_non_trans_bssid_profile(
|
||||||
mlan_private *pmpriv, BSSDescriptor_t *pbss_entry,
|
mlan_private *pmpriv, BSSDescriptor_t *pbss_entry,
|
||||||
IEEEtypes_NonTransBSSIDProfile_t *pbss_profile, t_u32 *num_in_table)
|
IEEEtypes_NonTransBSSIDProfile_t *pbss_profile, t_u32 *num_in_table,
|
||||||
|
t_u8 max_bssid_indicator)
|
||||||
{
|
{
|
||||||
mlan_adapter *pmadapter = pmpriv->adapter;
|
mlan_adapter *pmadapter = pmpriv->adapter;
|
||||||
IEEEtypes_Header_t *pheader =
|
IEEEtypes_Header_t *pheader =
|
||||||
|
@ -5141,6 +5243,8 @@ static t_void wlan_parse_non_trans_bssid_profile(
|
||||||
mlan_callbacks *pcb = (pmlan_callbacks)&pmadapter->callbacks;
|
mlan_callbacks *pcb = (pmlan_callbacks)&pmadapter->callbacks;
|
||||||
BSSDescriptor_t *bss_new_entry = MNULL;
|
BSSDescriptor_t *bss_new_entry = MNULL;
|
||||||
t_u8 *pbeacon_buf = MNULL;
|
t_u8 *pbeacon_buf = MNULL;
|
||||||
|
IEEEtypes_ExtCap_t *pextcap = MNULL;
|
||||||
|
IEEEtypes_Generic_t *prsnx = MNULL;
|
||||||
|
|
||||||
ENTER();
|
ENTER();
|
||||||
|
|
||||||
|
@ -5176,6 +5280,18 @@ static t_void wlan_parse_non_trans_bssid_profile(
|
||||||
pbssid_index->bssid_index);
|
pbssid_index->bssid_index);
|
||||||
ret = MTRUE;
|
ret = MTRUE;
|
||||||
break;
|
break;
|
||||||
|
case EXT_CAPABILITY:
|
||||||
|
pextcap = (IEEEtypes_ExtCap_t *)pos;
|
||||||
|
DBG_HEXDUMP(MCMD_D, "MBSSID extcap", pos,
|
||||||
|
pextcap->ieee_hdr.len +
|
||||||
|
sizeof(IEEEtypes_Header_t));
|
||||||
|
break;
|
||||||
|
case RSNX_IE:
|
||||||
|
prsnx = (IEEEtypes_Generic_t *)pos;
|
||||||
|
DBG_HEXDUMP(MCMD_D, "MBSSID RSNX", pos,
|
||||||
|
prsnx->ieee_hdr.len +
|
||||||
|
sizeof(IEEEtypes_Header_t));
|
||||||
|
break;
|
||||||
case SSID:
|
case SSID:
|
||||||
pssid = (IEEEtypes_Ssid_t *)pos;
|
pssid = (IEEEtypes_Ssid_t *)pos;
|
||||||
PRINTM(MCMND, "MBSSID: Find mbssid ssid=%s\n",
|
PRINTM(MCMND, "MBSSID: Find mbssid ssid=%s\n",
|
||||||
|
@ -5200,7 +5316,8 @@ static t_void wlan_parse_non_trans_bssid_profile(
|
||||||
sizeof(BSSDescriptor_t), sizeof(BSSDescriptor_t));
|
sizeof(BSSDescriptor_t), sizeof(BSSDescriptor_t));
|
||||||
wlan_gen_multi_bssid_by_bssid_index(pmadapter, pbss_entry,
|
wlan_gen_multi_bssid_by_bssid_index(pmadapter, pbss_entry,
|
||||||
bss_new_entry,
|
bss_new_entry,
|
||||||
pbssid_index->bssid_index);
|
pbssid_index->bssid_index,
|
||||||
|
max_bssid_indicator);
|
||||||
if (pssid) {
|
if (pssid) {
|
||||||
memset(pmadapter, (t_u8 *)&bss_new_entry->ssid, 0,
|
memset(pmadapter, (t_u8 *)&bss_new_entry->ssid, 0,
|
||||||
sizeof(mlan_802_11_ssid));
|
sizeof(mlan_802_11_ssid));
|
||||||
|
@ -5210,8 +5327,8 @@ static t_void wlan_parse_non_trans_bssid_profile(
|
||||||
MLAN_MAX_SSID_LENGTH);
|
MLAN_MAX_SSID_LENGTH);
|
||||||
if (MLAN_STATUS_SUCCESS !=
|
if (MLAN_STATUS_SUCCESS !=
|
||||||
wlan_update_ssid_in_beacon_buf(
|
wlan_update_ssid_in_beacon_buf(
|
||||||
pmadapter, pbss_entry, bss_new_entry,
|
pmadapter, pbss_entry, bss_new_entry, pssid,
|
||||||
pssid)) {
|
pextcap, prsnx)) {
|
||||||
PRINTM(MERROR,
|
PRINTM(MERROR,
|
||||||
"Fail to update MBSSID beacon buf\n");
|
"Fail to update MBSSID beacon buf\n");
|
||||||
pcb->moal_mfree(pmadapter->pmoal_handle,
|
pcb->moal_mfree(pmadapter->pmoal_handle,
|
||||||
|
@ -5273,7 +5390,8 @@ static t_void wlan_parse_multi_bssid_ie(mlan_private *pmpriv,
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
wlan_parse_non_trans_bssid_profile(
|
wlan_parse_non_trans_bssid_profile(
|
||||||
pmpriv, pbss_entry, pbssid_profile, num_in_table);
|
pmpriv, pbss_entry, pbssid_profile, num_in_table,
|
||||||
|
pmulti_bssid->max_bssid_indicator);
|
||||||
pcurrent_ptr += pbssid_profile->ieee_hdr.len + 2;
|
pcurrent_ptr += pbssid_profile->ieee_hdr.len + 2;
|
||||||
bytes_left -= pbssid_profile->ieee_hdr.len + 2;
|
bytes_left -= pbssid_profile->ieee_hdr.len + 2;
|
||||||
}
|
}
|
||||||
|
@ -5378,6 +5496,9 @@ static mlan_status wlan_parse_ext_scan_result(mlan_private *pmpriv,
|
||||||
PRINTM(MINFO, "EXT_SCAN: bss_descript_size %d\n", scan_resp_size);
|
PRINTM(MINFO, "EXT_SCAN: bss_descript_size %d\n", scan_resp_size);
|
||||||
PRINTM(MINFO, "EXT_SCAN: returned %d APs before parsing\n",
|
PRINTM(MINFO, "EXT_SCAN: returned %d APs before parsing\n",
|
||||||
number_of_sets);
|
number_of_sets);
|
||||||
|
/* Update the age_in_second */
|
||||||
|
pmadapter->callbacks.moal_get_system_time(
|
||||||
|
pmadapter->pmoal_handle, &pmadapter->age_in_secs, &age_ts_usec);
|
||||||
|
|
||||||
num_in_table = pmadapter->num_in_scan_table;
|
num_in_table = pmadapter->num_in_scan_table;
|
||||||
ptlv = (MrvlIEtypes_Data_t *)pscan_resp;
|
ptlv = (MrvlIEtypes_Data_t *)pscan_resp;
|
||||||
|
@ -5511,6 +5632,7 @@ static mlan_status wlan_parse_ext_scan_result(mlan_private *pmpriv,
|
||||||
/* Save the band designation for this entry for use in
|
/* Save the band designation for this entry for use in
|
||||||
* join */
|
* join */
|
||||||
bss_new_entry->bss_band = band;
|
bss_new_entry->bss_band = band;
|
||||||
|
bss_new_entry->age_in_secs = pmadapter->age_in_secs;
|
||||||
|
|
||||||
cfp = wlan_find_cfp_by_band_and_channel(
|
cfp = wlan_find_cfp_by_band_and_channel(
|
||||||
pmadapter, (t_u8)bss_new_entry->bss_band,
|
pmadapter, (t_u8)bss_new_entry->bss_band,
|
||||||
|
|
|
@ -40,6 +40,310 @@ Change log:
|
||||||
/********************************************************
|
/********************************************************
|
||||||
Local Variables
|
Local Variables
|
||||||
********************************************************/
|
********************************************************/
|
||||||
|
#ifdef SD8887
|
||||||
|
static const struct _mlan_sdio_card_reg mlan_reg_sd8887 = {
|
||||||
|
.start_rd_port = 0,
|
||||||
|
.start_wr_port = 0,
|
||||||
|
.base_0_reg = 0x6C,
|
||||||
|
.base_1_reg = 0x6D,
|
||||||
|
.poll_reg = 0x5C,
|
||||||
|
.host_int_enable = UP_LD_HOST_INT_MASK | DN_LD_HOST_INT_MASK |
|
||||||
|
CMD_PORT_UPLD_INT_MASK | CMD_PORT_DNLD_INT_MASK,
|
||||||
|
.host_int_status = DN_LD_HOST_INT_STATUS | UP_LD_HOST_INT_STATUS |
|
||||||
|
DN_LD_CMD_PORT_HOST_INT_STATUS |
|
||||||
|
UP_LD_CMD_PORT_HOST_INT_STATUS,
|
||||||
|
.status_reg_0 = 0x90,
|
||||||
|
.status_reg_1 = 0x91,
|
||||||
|
.sdio_int_mask = 0xff,
|
||||||
|
.data_port_mask = 0xffffffff,
|
||||||
|
.max_mp_regs = 196,
|
||||||
|
.rd_bitmap_l = 0x10,
|
||||||
|
.rd_bitmap_u = 0x11,
|
||||||
|
.rd_bitmap_1l = 0x12,
|
||||||
|
.rd_bitmap_1u = 0x13,
|
||||||
|
.wr_bitmap_l = 0x14,
|
||||||
|
.wr_bitmap_u = 0x15,
|
||||||
|
.wr_bitmap_1l = 0x16,
|
||||||
|
.wr_bitmap_1u = 0x17,
|
||||||
|
.rd_len_p0_l = 0x18,
|
||||||
|
.rd_len_p0_u = 0x19,
|
||||||
|
.card_config_2_1_reg = 0xD9,
|
||||||
|
.cmd_config_0 = 0xC4,
|
||||||
|
.cmd_config_1 = 0xC5,
|
||||||
|
.cmd_config_2 = 0xC6,
|
||||||
|
.cmd_config_3 = 0xC7,
|
||||||
|
.cmd_rd_len_0 = 0xC0,
|
||||||
|
.cmd_rd_len_1 = 0xC1,
|
||||||
|
.cmd_rd_len_2 = 0xC2,
|
||||||
|
.cmd_rd_len_3 = 0xC3,
|
||||||
|
.io_port_0_reg = 0xE4,
|
||||||
|
.io_port_1_reg = 0xE5,
|
||||||
|
.io_port_2_reg = 0xE6,
|
||||||
|
.host_int_rsr_reg = 0x04,
|
||||||
|
.host_int_mask_reg = 0x08,
|
||||||
|
.host_int_status_reg = 0x0C,
|
||||||
|
.host_restart_reg = 0x58,
|
||||||
|
.card_to_host_event_reg = 0x5C,
|
||||||
|
.host_interrupt_mask_reg = 0x60,
|
||||||
|
.card_interrupt_status_reg = 0x64,
|
||||||
|
.card_interrupt_rsr_reg = 0x68,
|
||||||
|
.card_revision_reg = 0xC8,
|
||||||
|
.card_ocr_0_reg = 0xD4,
|
||||||
|
.card_ocr_1_reg = 0xD5,
|
||||||
|
.card_ocr_3_reg = 0xD6,
|
||||||
|
.card_config_reg = 0xD7,
|
||||||
|
.card_misc_cfg_reg = 0xD8,
|
||||||
|
.debug_0_reg = 0xDC,
|
||||||
|
.debug_1_reg = 0xDD,
|
||||||
|
.debug_2_reg = 0xDE,
|
||||||
|
.debug_3_reg = 0xDF,
|
||||||
|
.fw_reset_reg = 0x0B6,
|
||||||
|
.fw_reset_val = 1,
|
||||||
|
.winner_check_reg = 0x90,
|
||||||
|
};
|
||||||
|
|
||||||
|
static const struct _mlan_card_info mlan_card_info_sd8887 = {
|
||||||
|
.max_tx_buf_size = MLAN_TX_DATA_BUF_SIZE_2K,
|
||||||
|
.v16_fw_api = 0,
|
||||||
|
.supp_ps_handshake = 0,
|
||||||
|
.default_11n_tx_bf_cap = DEFAULT_11N_TX_BF_CAP_1X1,
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef SD8801
|
||||||
|
static const struct _mlan_sdio_card_reg mlan_reg_sd8801 = {
|
||||||
|
.start_rd_port = 1,
|
||||||
|
.start_wr_port = 1,
|
||||||
|
.base_0_reg = 0x40,
|
||||||
|
.base_1_reg = 0x41,
|
||||||
|
.poll_reg = 0x30,
|
||||||
|
.host_int_enable = UP_LD_HOST_INT_MASK | DN_LD_HOST_INT_MASK,
|
||||||
|
.host_int_status = DN_LD_HOST_INT_STATUS | UP_LD_HOST_INT_STATUS,
|
||||||
|
.status_reg_0 = 0x60,
|
||||||
|
.status_reg_1 = 0x61,
|
||||||
|
.sdio_int_mask = 0x3f,
|
||||||
|
.data_port_mask = 0x0000fffe,
|
||||||
|
.max_mp_regs = 64,
|
||||||
|
.rd_bitmap_l = 0x4,
|
||||||
|
.rd_bitmap_u = 0x5,
|
||||||
|
.wr_bitmap_l = 0x6,
|
||||||
|
.wr_bitmap_u = 0x7,
|
||||||
|
.rd_len_p0_l = 0x8,
|
||||||
|
.rd_len_p0_u = 0x9,
|
||||||
|
.io_port_0_reg = 0x78,
|
||||||
|
.io_port_1_reg = 0x79,
|
||||||
|
.io_port_2_reg = 0x7A,
|
||||||
|
.host_int_rsr_reg = 0x01,
|
||||||
|
.host_int_mask_reg = 0x02,
|
||||||
|
.host_int_status_reg = 0x03,
|
||||||
|
.card_misc_cfg_reg = 0x6c,
|
||||||
|
.fw_reset_reg = 0x64,
|
||||||
|
.fw_reset_val = 0,
|
||||||
|
};
|
||||||
|
|
||||||
|
static const struct _mlan_card_info mlan_card_info_sd8801 = {
|
||||||
|
.max_tx_buf_size = MLAN_TX_DATA_BUF_SIZE_2K,
|
||||||
|
.v14_fw_api = 1,
|
||||||
|
.v16_fw_api = 0,
|
||||||
|
.supp_ps_handshake = 0,
|
||||||
|
.default_11n_tx_bf_cap = DEFAULT_11N_TX_BF_CAP_1X1,
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef SD8897
|
||||||
|
static const struct _mlan_sdio_card_reg mlan_reg_sd8897 = {
|
||||||
|
.start_rd_port = 0,
|
||||||
|
.start_wr_port = 0,
|
||||||
|
.base_0_reg = 0x60,
|
||||||
|
.base_1_reg = 0x61,
|
||||||
|
.poll_reg = 0x50,
|
||||||
|
.host_int_enable = UP_LD_HOST_INT_MASK | DN_LD_HOST_INT_MASK |
|
||||||
|
CMD_PORT_UPLD_INT_MASK | CMD_PORT_DNLD_INT_MASK,
|
||||||
|
.host_int_status = DN_LD_HOST_INT_STATUS | UP_LD_HOST_INT_STATUS |
|
||||||
|
DN_LD_CMD_PORT_HOST_INT_STATUS |
|
||||||
|
UP_LD_CMD_PORT_HOST_INT_STATUS,
|
||||||
|
.status_reg_0 = 0xC0,
|
||||||
|
.status_reg_1 = 0xC1,
|
||||||
|
.sdio_int_mask = 0xff,
|
||||||
|
.data_port_mask = 0xffffffff,
|
||||||
|
.max_mp_regs = 184,
|
||||||
|
.rd_bitmap_l = 0x04,
|
||||||
|
.rd_bitmap_u = 0x05,
|
||||||
|
.rd_bitmap_1l = 0x06,
|
||||||
|
.rd_bitmap_1u = 0x07,
|
||||||
|
.wr_bitmap_l = 0x08,
|
||||||
|
.wr_bitmap_u = 0x09,
|
||||||
|
.wr_bitmap_1l = 0x0A,
|
||||||
|
.wr_bitmap_1u = 0x0B,
|
||||||
|
.rd_len_p0_l = 0x0C,
|
||||||
|
.rd_len_p0_u = 0x0D,
|
||||||
|
.card_config_2_1_reg = 0xCD,
|
||||||
|
.cmd_config_0 = 0xB8,
|
||||||
|
.cmd_config_1 = 0xB9,
|
||||||
|
.cmd_config_2 = 0xBA,
|
||||||
|
.cmd_config_3 = 0xBB,
|
||||||
|
.cmd_rd_len_0 = 0xB4,
|
||||||
|
.cmd_rd_len_1 = 0xB5,
|
||||||
|
.cmd_rd_len_2 = 0xB6,
|
||||||
|
.cmd_rd_len_3 = 0xB7,
|
||||||
|
.io_port_0_reg = 0xD8,
|
||||||
|
.io_port_1_reg = 0xD9,
|
||||||
|
.io_port_2_reg = 0xDA,
|
||||||
|
.host_int_rsr_reg = 0x01,
|
||||||
|
.host_int_mask_reg = 0x02,
|
||||||
|
.host_int_status_reg = 0x03,
|
||||||
|
.host_restart_reg = 0x4C,
|
||||||
|
.card_to_host_event_reg = 0x50,
|
||||||
|
.host_interrupt_mask_reg = 0x54,
|
||||||
|
.card_interrupt_status_reg = 0x58,
|
||||||
|
.card_interrupt_rsr_reg = 0x5C,
|
||||||
|
.card_revision_reg = 0xBC,
|
||||||
|
.card_ocr_0_reg = 0xC8,
|
||||||
|
.card_ocr_1_reg = 0xC9,
|
||||||
|
.card_ocr_3_reg = 0xCA,
|
||||||
|
.card_config_reg = 0xCB,
|
||||||
|
.card_misc_cfg_reg = 0xCC,
|
||||||
|
.debug_0_reg = 0xD0,
|
||||||
|
.debug_1_reg = 0xD1,
|
||||||
|
.debug_2_reg = 0xD2,
|
||||||
|
.debug_3_reg = 0xD3,
|
||||||
|
.fw_reset_reg = 0x0E8,
|
||||||
|
.fw_reset_val = 1,
|
||||||
|
.winner_check_reg = 0xC0,
|
||||||
|
};
|
||||||
|
|
||||||
|
static const struct _mlan_card_info mlan_card_info_sd8897 = {
|
||||||
|
.max_tx_buf_size = MLAN_TX_DATA_BUF_SIZE_4K,
|
||||||
|
.v16_fw_api = 0,
|
||||||
|
.supp_ps_handshake = 0,
|
||||||
|
.default_11n_tx_bf_cap = DEFAULT_11N_TX_BF_CAP_2X2,
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(SD8977) || defined(SD8997) || defined(SD8987) || \
|
||||||
|
defined(SD9098) || defined(SD9097) || defined(SD8978) || \
|
||||||
|
defined(SD9177)
|
||||||
|
static const struct _mlan_sdio_card_reg mlan_reg_sd8977_sd8997 = {
|
||||||
|
.start_rd_port = 0,
|
||||||
|
.start_wr_port = 0,
|
||||||
|
.base_0_reg = 0xf8,
|
||||||
|
.base_1_reg = 0xf9,
|
||||||
|
.poll_reg = 0x5C,
|
||||||
|
.host_int_enable = UP_LD_HOST_INT_MASK | DN_LD_HOST_INT_MASK |
|
||||||
|
CMD_PORT_UPLD_INT_MASK | CMD_PORT_DNLD_INT_MASK,
|
||||||
|
.host_int_status = DN_LD_HOST_INT_STATUS | UP_LD_HOST_INT_STATUS |
|
||||||
|
DN_LD_CMD_PORT_HOST_INT_STATUS |
|
||||||
|
UP_LD_CMD_PORT_HOST_INT_STATUS,
|
||||||
|
.status_reg_0 = 0xe8,
|
||||||
|
.status_reg_1 = 0xe9,
|
||||||
|
.sdio_int_mask = 0xff,
|
||||||
|
.data_port_mask = 0xffffffff,
|
||||||
|
.max_mp_regs = 196,
|
||||||
|
.rd_bitmap_l = 0x10,
|
||||||
|
.rd_bitmap_u = 0x11,
|
||||||
|
.rd_bitmap_1l = 0x12,
|
||||||
|
.rd_bitmap_1u = 0x13,
|
||||||
|
.wr_bitmap_l = 0x14,
|
||||||
|
.wr_bitmap_u = 0x15,
|
||||||
|
.wr_bitmap_1l = 0x16,
|
||||||
|
.wr_bitmap_1u = 0x17,
|
||||||
|
.rd_len_p0_l = 0x18,
|
||||||
|
.rd_len_p0_u = 0x19,
|
||||||
|
.card_config_2_1_reg = 0xD9,
|
||||||
|
.cmd_config_0 = 0xC4,
|
||||||
|
.cmd_config_1 = 0xC5,
|
||||||
|
.cmd_config_2 = 0xC6,
|
||||||
|
.cmd_config_3 = 0xC7,
|
||||||
|
.cmd_rd_len_0 = 0xC0,
|
||||||
|
.cmd_rd_len_1 = 0xC1,
|
||||||
|
.cmd_rd_len_2 = 0xC2,
|
||||||
|
.cmd_rd_len_3 = 0xC3,
|
||||||
|
.io_port_0_reg = 0xE4,
|
||||||
|
.io_port_1_reg = 0xE5,
|
||||||
|
.io_port_2_reg = 0xE6,
|
||||||
|
.host_int_rsr_reg = 0x04,
|
||||||
|
.host_int_mask_reg = 0x08,
|
||||||
|
.host_int_status_reg = 0x0C,
|
||||||
|
.host_restart_reg = 0x58,
|
||||||
|
.card_to_host_event_reg = 0x5C,
|
||||||
|
.host_interrupt_mask_reg = 0x60,
|
||||||
|
.card_interrupt_status_reg = 0x64,
|
||||||
|
.card_interrupt_rsr_reg = 0x68,
|
||||||
|
.card_revision_reg = 0xC8,
|
||||||
|
.card_ocr_0_reg = 0xD4,
|
||||||
|
.card_ocr_1_reg = 0xD5,
|
||||||
|
.card_ocr_3_reg = 0xD6,
|
||||||
|
.card_config_reg = 0xD7,
|
||||||
|
.card_misc_cfg_reg = 0xD8,
|
||||||
|
.debug_0_reg = 0xDC,
|
||||||
|
.debug_1_reg = 0xDD,
|
||||||
|
.debug_2_reg = 0xDE,
|
||||||
|
.debug_3_reg = 0xDF,
|
||||||
|
.fw_reset_reg = 0x0EE,
|
||||||
|
.fw_reset_val = 0x99,
|
||||||
|
.fw_dnld_offset_0_reg = 0xEC,
|
||||||
|
.fw_dnld_offset_1_reg = 0xED,
|
||||||
|
.fw_dnld_offset_2_reg = 0xEE,
|
||||||
|
.fw_dnld_offset_3_reg = 0xEF,
|
||||||
|
.fw_dnld_status_0_reg = 0xE8,
|
||||||
|
.fw_dnld_status_1_reg = 0xE9,
|
||||||
|
.winner_check_reg = 0xFC,
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
#ifdef SD8997
|
||||||
|
static const struct _mlan_card_info mlan_card_info_sd8997 = {
|
||||||
|
.max_tx_buf_size = MLAN_TX_DATA_BUF_SIZE_4K,
|
||||||
|
.v16_fw_api = 1,
|
||||||
|
.supp_ps_handshake = 0,
|
||||||
|
.default_11n_tx_bf_cap = DEFAULT_11N_TX_BF_CAP_2X2,
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef SD9097
|
||||||
|
static const struct _mlan_card_info mlan_card_info_sd9097 = {
|
||||||
|
.max_tx_buf_size = MLAN_TX_DATA_BUF_SIZE_4K,
|
||||||
|
.v16_fw_api = 1,
|
||||||
|
.v17_fw_api = 1,
|
||||||
|
.supp_ps_handshake = 0,
|
||||||
|
.default_11n_tx_bf_cap = DEFAULT_11N_TX_BF_CAP_2X2,
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
#ifdef SD9098
|
||||||
|
static const struct _mlan_card_info mlan_card_info_sd9098 = {
|
||||||
|
.max_tx_buf_size = MLAN_TX_DATA_BUF_SIZE_4K,
|
||||||
|
.v16_fw_api = 1,
|
||||||
|
.v17_fw_api = 1,
|
||||||
|
.supp_ps_handshake = 0,
|
||||||
|
.default_11n_tx_bf_cap = DEFAULT_11N_TX_BF_CAP_2X2,
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
#ifdef SD9177
|
||||||
|
static const struct _mlan_card_info mlan_card_info_sd9177 = {
|
||||||
|
.max_tx_buf_size = MLAN_TX_DATA_BUF_SIZE_4K,
|
||||||
|
.v16_fw_api = 1,
|
||||||
|
.v17_fw_api = 1,
|
||||||
|
.supp_ps_handshake = 0,
|
||||||
|
.default_11n_tx_bf_cap = DEFAULT_11N_TX_BF_CAP_1X1,
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(SD8977) || defined(SD8978)
|
||||||
|
static const struct _mlan_card_info mlan_card_info_sd8977 = {
|
||||||
|
.max_tx_buf_size = MLAN_TX_DATA_BUF_SIZE_2K,
|
||||||
|
.v16_fw_api = 1,
|
||||||
|
.supp_ps_handshake = 0,
|
||||||
|
.default_11n_tx_bf_cap = DEFAULT_11N_TX_BF_CAP_1X1,
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef SD8987
|
||||||
|
static const struct _mlan_card_info mlan_card_info_sd8987 = {
|
||||||
|
.max_tx_buf_size = MLAN_TX_DATA_BUF_SIZE_2K,
|
||||||
|
.v16_fw_api = 1,
|
||||||
|
.supp_ps_handshake = 0,
|
||||||
|
.default_11n_tx_bf_cap = DEFAULT_11N_TX_BF_CAP_1X1,
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
/********************************************************
|
/********************************************************
|
||||||
Global Variables
|
Global Variables
|
||||||
|
|
|
@ -350,312 +350,6 @@ Change log:
|
||||||
/** max aggr buf size 64k-256 */
|
/** max aggr buf size 64k-256 */
|
||||||
#define SDIO_MP_AGGR_BUF_SIZE_MAX (65280)
|
#define SDIO_MP_AGGR_BUF_SIZE_MAX (65280)
|
||||||
|
|
||||||
#ifdef SD8887
|
|
||||||
static const struct _mlan_sdio_card_reg mlan_reg_sd8887 = {
|
|
||||||
.start_rd_port = 0,
|
|
||||||
.start_wr_port = 0,
|
|
||||||
.base_0_reg = 0x6C,
|
|
||||||
.base_1_reg = 0x6D,
|
|
||||||
.poll_reg = 0x5C,
|
|
||||||
.host_int_enable = UP_LD_HOST_INT_MASK | DN_LD_HOST_INT_MASK |
|
|
||||||
CMD_PORT_UPLD_INT_MASK | CMD_PORT_DNLD_INT_MASK,
|
|
||||||
.host_int_status = DN_LD_HOST_INT_STATUS | UP_LD_HOST_INT_STATUS |
|
|
||||||
DN_LD_CMD_PORT_HOST_INT_STATUS |
|
|
||||||
UP_LD_CMD_PORT_HOST_INT_STATUS,
|
|
||||||
.status_reg_0 = 0x90,
|
|
||||||
.status_reg_1 = 0x91,
|
|
||||||
.sdio_int_mask = 0xff,
|
|
||||||
.data_port_mask = 0xffffffff,
|
|
||||||
.max_mp_regs = 196,
|
|
||||||
.rd_bitmap_l = 0x10,
|
|
||||||
.rd_bitmap_u = 0x11,
|
|
||||||
.rd_bitmap_1l = 0x12,
|
|
||||||
.rd_bitmap_1u = 0x13,
|
|
||||||
.wr_bitmap_l = 0x14,
|
|
||||||
.wr_bitmap_u = 0x15,
|
|
||||||
.wr_bitmap_1l = 0x16,
|
|
||||||
.wr_bitmap_1u = 0x17,
|
|
||||||
.rd_len_p0_l = 0x18,
|
|
||||||
.rd_len_p0_u = 0x19,
|
|
||||||
.card_config_2_1_reg = 0xD9,
|
|
||||||
.cmd_config_0 = 0xC4,
|
|
||||||
.cmd_config_1 = 0xC5,
|
|
||||||
.cmd_config_2 = 0xC6,
|
|
||||||
.cmd_config_3 = 0xC7,
|
|
||||||
.cmd_rd_len_0 = 0xC0,
|
|
||||||
.cmd_rd_len_1 = 0xC1,
|
|
||||||
.cmd_rd_len_2 = 0xC2,
|
|
||||||
.cmd_rd_len_3 = 0xC3,
|
|
||||||
.io_port_0_reg = 0xE4,
|
|
||||||
.io_port_1_reg = 0xE5,
|
|
||||||
.io_port_2_reg = 0xE6,
|
|
||||||
.host_int_rsr_reg = 0x04,
|
|
||||||
.host_int_mask_reg = 0x08,
|
|
||||||
.host_int_status_reg = 0x0C,
|
|
||||||
.host_restart_reg = 0x58,
|
|
||||||
.card_to_host_event_reg = 0x5C,
|
|
||||||
.host_interrupt_mask_reg = 0x60,
|
|
||||||
.card_interrupt_status_reg = 0x64,
|
|
||||||
.card_interrupt_rsr_reg = 0x68,
|
|
||||||
.card_revision_reg = 0xC8,
|
|
||||||
.card_ocr_0_reg = 0xD4,
|
|
||||||
.card_ocr_1_reg = 0xD5,
|
|
||||||
.card_ocr_3_reg = 0xD6,
|
|
||||||
.card_config_reg = 0xD7,
|
|
||||||
.card_misc_cfg_reg = 0xD8,
|
|
||||||
.debug_0_reg = 0xDC,
|
|
||||||
.debug_1_reg = 0xDD,
|
|
||||||
.debug_2_reg = 0xDE,
|
|
||||||
.debug_3_reg = 0xDF,
|
|
||||||
.fw_reset_reg = 0x0B6,
|
|
||||||
.fw_reset_val = 1,
|
|
||||||
.winner_check_reg = 0x90,
|
|
||||||
};
|
|
||||||
|
|
||||||
static const struct _mlan_card_info mlan_card_info_sd8887 = {
|
|
||||||
.max_tx_buf_size = MLAN_TX_DATA_BUF_SIZE_2K,
|
|
||||||
.v16_fw_api = 0,
|
|
||||||
.supp_ps_handshake = 0,
|
|
||||||
.default_11n_tx_bf_cap = DEFAULT_11N_TX_BF_CAP_1X1,
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef SD8801
|
|
||||||
static const struct _mlan_sdio_card_reg mlan_reg_sd8801 = {
|
|
||||||
.start_rd_port = 1,
|
|
||||||
.start_wr_port = 1,
|
|
||||||
.base_0_reg = 0x40,
|
|
||||||
.base_1_reg = 0x41,
|
|
||||||
.poll_reg = 0x30,
|
|
||||||
.host_int_enable = UP_LD_HOST_INT_MASK | DN_LD_HOST_INT_MASK,
|
|
||||||
.host_int_status = DN_LD_HOST_INT_STATUS | UP_LD_HOST_INT_STATUS,
|
|
||||||
.status_reg_0 = 0x60,
|
|
||||||
.status_reg_1 = 0x61,
|
|
||||||
.sdio_int_mask = 0x3f,
|
|
||||||
.data_port_mask = 0x0000fffe,
|
|
||||||
.max_mp_regs = 64,
|
|
||||||
.rd_bitmap_l = 0x4,
|
|
||||||
.rd_bitmap_u = 0x5,
|
|
||||||
.wr_bitmap_l = 0x6,
|
|
||||||
.wr_bitmap_u = 0x7,
|
|
||||||
.rd_len_p0_l = 0x8,
|
|
||||||
.rd_len_p0_u = 0x9,
|
|
||||||
.io_port_0_reg = 0x78,
|
|
||||||
.io_port_1_reg = 0x79,
|
|
||||||
.io_port_2_reg = 0x7A,
|
|
||||||
.host_int_rsr_reg = 0x01,
|
|
||||||
.host_int_mask_reg = 0x02,
|
|
||||||
.host_int_status_reg = 0x03,
|
|
||||||
.card_misc_cfg_reg = 0x6c,
|
|
||||||
.fw_reset_reg = 0x64,
|
|
||||||
.fw_reset_val = 0,
|
|
||||||
};
|
|
||||||
|
|
||||||
static const struct _mlan_card_info mlan_card_info_sd8801 = {
|
|
||||||
.max_tx_buf_size = MLAN_TX_DATA_BUF_SIZE_2K,
|
|
||||||
.v14_fw_api = 1,
|
|
||||||
.v16_fw_api = 0,
|
|
||||||
.supp_ps_handshake = 0,
|
|
||||||
.default_11n_tx_bf_cap = DEFAULT_11N_TX_BF_CAP_1X1,
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef SD8897
|
|
||||||
static const struct _mlan_sdio_card_reg mlan_reg_sd8897 = {
|
|
||||||
.start_rd_port = 0,
|
|
||||||
.start_wr_port = 0,
|
|
||||||
.base_0_reg = 0x60,
|
|
||||||
.base_1_reg = 0x61,
|
|
||||||
.poll_reg = 0x50,
|
|
||||||
.host_int_enable = UP_LD_HOST_INT_MASK | DN_LD_HOST_INT_MASK |
|
|
||||||
CMD_PORT_UPLD_INT_MASK | CMD_PORT_DNLD_INT_MASK,
|
|
||||||
.host_int_status = DN_LD_HOST_INT_STATUS | UP_LD_HOST_INT_STATUS |
|
|
||||||
DN_LD_CMD_PORT_HOST_INT_STATUS |
|
|
||||||
UP_LD_CMD_PORT_HOST_INT_STATUS,
|
|
||||||
.status_reg_0 = 0xC0,
|
|
||||||
.status_reg_1 = 0xC1,
|
|
||||||
.sdio_int_mask = 0xff,
|
|
||||||
.data_port_mask = 0xffffffff,
|
|
||||||
.max_mp_regs = 184,
|
|
||||||
.rd_bitmap_l = 0x04,
|
|
||||||
.rd_bitmap_u = 0x05,
|
|
||||||
.rd_bitmap_1l = 0x06,
|
|
||||||
.rd_bitmap_1u = 0x07,
|
|
||||||
.wr_bitmap_l = 0x08,
|
|
||||||
.wr_bitmap_u = 0x09,
|
|
||||||
.wr_bitmap_1l = 0x0A,
|
|
||||||
.wr_bitmap_1u = 0x0B,
|
|
||||||
.rd_len_p0_l = 0x0C,
|
|
||||||
.rd_len_p0_u = 0x0D,
|
|
||||||
.card_config_2_1_reg = 0xCD,
|
|
||||||
.cmd_config_0 = 0xB8,
|
|
||||||
.cmd_config_1 = 0xB9,
|
|
||||||
.cmd_config_2 = 0xBA,
|
|
||||||
.cmd_config_3 = 0xBB,
|
|
||||||
.cmd_rd_len_0 = 0xB4,
|
|
||||||
.cmd_rd_len_1 = 0xB5,
|
|
||||||
.cmd_rd_len_2 = 0xB6,
|
|
||||||
.cmd_rd_len_3 = 0xB7,
|
|
||||||
.io_port_0_reg = 0xD8,
|
|
||||||
.io_port_1_reg = 0xD9,
|
|
||||||
.io_port_2_reg = 0xDA,
|
|
||||||
.host_int_rsr_reg = 0x01,
|
|
||||||
.host_int_mask_reg = 0x02,
|
|
||||||
.host_int_status_reg = 0x03,
|
|
||||||
.host_restart_reg = 0x4C,
|
|
||||||
.card_to_host_event_reg = 0x50,
|
|
||||||
.host_interrupt_mask_reg = 0x54,
|
|
||||||
.card_interrupt_status_reg = 0x58,
|
|
||||||
.card_interrupt_rsr_reg = 0x5C,
|
|
||||||
.card_revision_reg = 0xBC,
|
|
||||||
.card_ocr_0_reg = 0xC8,
|
|
||||||
.card_ocr_1_reg = 0xC9,
|
|
||||||
.card_ocr_3_reg = 0xCA,
|
|
||||||
.card_config_reg = 0xCB,
|
|
||||||
.card_misc_cfg_reg = 0xCC,
|
|
||||||
.debug_0_reg = 0xD0,
|
|
||||||
.debug_1_reg = 0xD1,
|
|
||||||
.debug_2_reg = 0xD2,
|
|
||||||
.debug_3_reg = 0xD3,
|
|
||||||
.fw_reset_reg = 0x0E8,
|
|
||||||
.fw_reset_val = 1,
|
|
||||||
.winner_check_reg = 0xC0,
|
|
||||||
};
|
|
||||||
|
|
||||||
static const struct _mlan_card_info mlan_card_info_sd8897 = {
|
|
||||||
.max_tx_buf_size = MLAN_TX_DATA_BUF_SIZE_4K,
|
|
||||||
.v16_fw_api = 0,
|
|
||||||
.supp_ps_handshake = 0,
|
|
||||||
.default_11n_tx_bf_cap = DEFAULT_11N_TX_BF_CAP_2X2,
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(SD8977) || defined(SD8997) || defined(SD8987) || \
|
|
||||||
defined(SD9098) || defined(SD9097) || defined(SD8978) || \
|
|
||||||
defined(SD9177)
|
|
||||||
static const struct _mlan_sdio_card_reg mlan_reg_sd8977_sd8997 = {
|
|
||||||
.start_rd_port = 0,
|
|
||||||
.start_wr_port = 0,
|
|
||||||
.base_0_reg = 0xf8,
|
|
||||||
.base_1_reg = 0xf9,
|
|
||||||
.poll_reg = 0x5C,
|
|
||||||
.host_int_enable = UP_LD_HOST_INT_MASK | DN_LD_HOST_INT_MASK |
|
|
||||||
CMD_PORT_UPLD_INT_MASK | CMD_PORT_DNLD_INT_MASK,
|
|
||||||
.host_int_status = DN_LD_HOST_INT_STATUS | UP_LD_HOST_INT_STATUS |
|
|
||||||
DN_LD_CMD_PORT_HOST_INT_STATUS |
|
|
||||||
UP_LD_CMD_PORT_HOST_INT_STATUS,
|
|
||||||
.status_reg_0 = 0xe8,
|
|
||||||
.status_reg_1 = 0xe9,
|
|
||||||
.sdio_int_mask = 0xff,
|
|
||||||
.data_port_mask = 0xffffffff,
|
|
||||||
.max_mp_regs = 196,
|
|
||||||
.rd_bitmap_l = 0x10,
|
|
||||||
.rd_bitmap_u = 0x11,
|
|
||||||
.rd_bitmap_1l = 0x12,
|
|
||||||
.rd_bitmap_1u = 0x13,
|
|
||||||
.wr_bitmap_l = 0x14,
|
|
||||||
.wr_bitmap_u = 0x15,
|
|
||||||
.wr_bitmap_1l = 0x16,
|
|
||||||
.wr_bitmap_1u = 0x17,
|
|
||||||
.rd_len_p0_l = 0x18,
|
|
||||||
.rd_len_p0_u = 0x19,
|
|
||||||
.card_config_2_1_reg = 0xD9,
|
|
||||||
.cmd_config_0 = 0xC4,
|
|
||||||
.cmd_config_1 = 0xC5,
|
|
||||||
.cmd_config_2 = 0xC6,
|
|
||||||
.cmd_config_3 = 0xC7,
|
|
||||||
.cmd_rd_len_0 = 0xC0,
|
|
||||||
.cmd_rd_len_1 = 0xC1,
|
|
||||||
.cmd_rd_len_2 = 0xC2,
|
|
||||||
.cmd_rd_len_3 = 0xC3,
|
|
||||||
.io_port_0_reg = 0xE4,
|
|
||||||
.io_port_1_reg = 0xE5,
|
|
||||||
.io_port_2_reg = 0xE6,
|
|
||||||
.host_int_rsr_reg = 0x04,
|
|
||||||
.host_int_mask_reg = 0x08,
|
|
||||||
.host_int_status_reg = 0x0C,
|
|
||||||
.host_restart_reg = 0x58,
|
|
||||||
.card_to_host_event_reg = 0x5C,
|
|
||||||
.host_interrupt_mask_reg = 0x60,
|
|
||||||
.card_interrupt_status_reg = 0x64,
|
|
||||||
.card_interrupt_rsr_reg = 0x68,
|
|
||||||
.card_revision_reg = 0xC8,
|
|
||||||
.card_ocr_0_reg = 0xD4,
|
|
||||||
.card_ocr_1_reg = 0xD5,
|
|
||||||
.card_ocr_3_reg = 0xD6,
|
|
||||||
.card_config_reg = 0xD7,
|
|
||||||
.card_misc_cfg_reg = 0xD8,
|
|
||||||
.debug_0_reg = 0xDC,
|
|
||||||
.debug_1_reg = 0xDD,
|
|
||||||
.debug_2_reg = 0xDE,
|
|
||||||
.debug_3_reg = 0xDF,
|
|
||||||
.fw_reset_reg = 0x0EE,
|
|
||||||
.fw_reset_val = 0x99,
|
|
||||||
.fw_dnld_offset_0_reg = 0xEC,
|
|
||||||
.fw_dnld_offset_1_reg = 0xED,
|
|
||||||
.fw_dnld_offset_2_reg = 0xEE,
|
|
||||||
.fw_dnld_offset_3_reg = 0xEF,
|
|
||||||
.fw_dnld_status_0_reg = 0xE8,
|
|
||||||
.fw_dnld_status_1_reg = 0xE9,
|
|
||||||
.winner_check_reg = 0xFC,
|
|
||||||
};
|
|
||||||
|
|
||||||
#ifdef SD8997
|
|
||||||
static const struct _mlan_card_info mlan_card_info_sd8997 = {
|
|
||||||
.max_tx_buf_size = MLAN_TX_DATA_BUF_SIZE_4K,
|
|
||||||
.v16_fw_api = 1,
|
|
||||||
.supp_ps_handshake = 0,
|
|
||||||
.default_11n_tx_bf_cap = DEFAULT_11N_TX_BF_CAP_2X2,
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef SD9097
|
|
||||||
static const struct _mlan_card_info mlan_card_info_sd9097 = {
|
|
||||||
.max_tx_buf_size = MLAN_TX_DATA_BUF_SIZE_4K,
|
|
||||||
.v16_fw_api = 1,
|
|
||||||
.v17_fw_api = 1,
|
|
||||||
.supp_ps_handshake = 0,
|
|
||||||
.default_11n_tx_bf_cap = DEFAULT_11N_TX_BF_CAP_2X2,
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
#ifdef SD9098
|
|
||||||
static const struct _mlan_card_info mlan_card_info_sd9098 = {
|
|
||||||
.max_tx_buf_size = MLAN_TX_DATA_BUF_SIZE_4K,
|
|
||||||
.v16_fw_api = 1,
|
|
||||||
.v17_fw_api = 1,
|
|
||||||
.supp_ps_handshake = 0,
|
|
||||||
.default_11n_tx_bf_cap = DEFAULT_11N_TX_BF_CAP_2X2,
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
#ifdef SD9177
|
|
||||||
static const struct _mlan_card_info mlan_card_info_sd9177 = {
|
|
||||||
.max_tx_buf_size = MLAN_TX_DATA_BUF_SIZE_4K,
|
|
||||||
.v16_fw_api = 1,
|
|
||||||
.v17_fw_api = 1,
|
|
||||||
.supp_ps_handshake = 0,
|
|
||||||
.default_11n_tx_bf_cap = DEFAULT_11N_TX_BF_CAP_1X1,
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(SD8977) || defined(SD8978)
|
|
||||||
static const struct _mlan_card_info mlan_card_info_sd8977 = {
|
|
||||||
.max_tx_buf_size = MLAN_TX_DATA_BUF_SIZE_2K,
|
|
||||||
.v16_fw_api = 1,
|
|
||||||
.supp_ps_handshake = 0,
|
|
||||||
.default_11n_tx_bf_cap = DEFAULT_11N_TX_BF_CAP_1X1,
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef SD8987
|
|
||||||
static const struct _mlan_card_info mlan_card_info_sd8987 = {
|
|
||||||
.max_tx_buf_size = MLAN_TX_DATA_BUF_SIZE_2K,
|
|
||||||
.v16_fw_api = 1,
|
|
||||||
.supp_ps_handshake = 0,
|
|
||||||
.default_11n_tx_bf_cap = DEFAULT_11N_TX_BF_CAP_1X1,
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
extern mlan_adapter_operations mlan_sdio_ops;
|
extern mlan_adapter_operations mlan_sdio_ops;
|
||||||
|
|
||||||
/** Probe and initialization function */
|
/** Probe and initialization function */
|
||||||
|
|
|
@ -319,6 +319,7 @@ mlan_status mlan_register(pmlan_device pmdevice, t_void **ppmlan_adapter)
|
||||||
MASSERT(pcb->moal_spin_unlock);
|
MASSERT(pcb->moal_spin_unlock);
|
||||||
MASSERT(pcb->moal_hist_data_add);
|
MASSERT(pcb->moal_hist_data_add);
|
||||||
MASSERT(pcb->moal_updata_peer_signal);
|
MASSERT(pcb->moal_updata_peer_signal);
|
||||||
|
MASSERT(pcb->moal_do_div);
|
||||||
/* Save pmoal_handle */
|
/* Save pmoal_handle */
|
||||||
pmadapter->pmoal_handle = pmdevice->pmoal_handle;
|
pmadapter->pmoal_handle = pmdevice->pmoal_handle;
|
||||||
|
|
||||||
|
@ -1163,6 +1164,7 @@ 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)) {
|
||||||
|
@ -1222,6 +1224,7 @@ 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) {
|
||||||
|
|
|
@ -2553,7 +2553,9 @@ static mlan_status wlan_cmd_coalesce_config(pmlan_private pmpriv,
|
||||||
|
|
||||||
ENTER();
|
ENTER();
|
||||||
|
|
||||||
cmd->size = sizeof(HostCmd_DS_COALESCE_CONFIG) + S_DS_GEN;
|
cmd->size = (sizeof(HostCmd_DS_COALESCE_CONFIG) -
|
||||||
|
sizeof(struct coalesce_receive_filt_rule)) +
|
||||||
|
S_DS_GEN;
|
||||||
cmd->command = wlan_cpu_to_le16(HostCmd_CMD_COALESCE_CFG);
|
cmd->command = wlan_cpu_to_le16(HostCmd_CMD_COALESCE_CFG);
|
||||||
coalesce_config->action = wlan_cpu_to_le16(cmd_action);
|
coalesce_config->action = wlan_cpu_to_le16(cmd_action);
|
||||||
coalesce_config->num_of_rules = wlan_cpu_to_le16(cfg->num_of_rules);
|
coalesce_config->num_of_rules = wlan_cpu_to_le16(cfg->num_of_rules);
|
||||||
|
|
|
@ -742,6 +742,16 @@ static mlan_status wlan_ret_get_log(pmlan_private pmpriv,
|
||||||
wlan_le32_to_cpu(pget_log->gdma_abort_cnt);
|
wlan_le32_to_cpu(pget_log->gdma_abort_cnt);
|
||||||
pget_info->param.stats.g_reset_rx_mac_cnt =
|
pget_info->param.stats.g_reset_rx_mac_cnt =
|
||||||
wlan_le32_to_cpu(pget_log->g_reset_rx_mac_cnt);
|
wlan_le32_to_cpu(pget_log->g_reset_rx_mac_cnt);
|
||||||
|
// Ownership error counters
|
||||||
|
pget_info->param.stats.dwCtlErrCnt =
|
||||||
|
wlan_le32_to_cpu(pget_log->dwCtlErrCnt);
|
||||||
|
pget_info->param.stats.dwBcnErrCnt =
|
||||||
|
wlan_le32_to_cpu(pget_log->dwBcnErrCnt);
|
||||||
|
pget_info->param.stats.dwMgtErrCnt =
|
||||||
|
wlan_le32_to_cpu(pget_log->dwMgtErrCnt);
|
||||||
|
pget_info->param.stats.dwDatErrCnt =
|
||||||
|
wlan_le32_to_cpu(pget_log->dwDatErrCnt);
|
||||||
|
|
||||||
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);
|
||||||
|
@ -1864,7 +1874,7 @@ static mlan_status wlan_ret_tdls_config(pmlan_private pmpriv,
|
||||||
wlan_le16_to_cpu(link_ptr->data_rssi_avg);
|
wlan_le16_to_cpu(link_ptr->data_rssi_avg);
|
||||||
link_ptr->data_nf_avg =
|
link_ptr->data_nf_avg =
|
||||||
wlan_le16_to_cpu(link_ptr->data_nf_avg);
|
wlan_le16_to_cpu(link_ptr->data_nf_avg);
|
||||||
link_length = sizeof(tdls_each_link_status);
|
link_length = sizeof(tdls_each_link_status) - 1;
|
||||||
/* adjust as per open or secure network */
|
/* adjust as per open or secure network */
|
||||||
if (link_ptr->link_flags & 0x02) {
|
if (link_ptr->link_flags & 0x02) {
|
||||||
link_ptr->key_lifetime = wlan_le32_to_cpu(
|
link_ptr->key_lifetime = wlan_le32_to_cpu(
|
||||||
|
|
|
@ -1004,6 +1004,7 @@ 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:
|
||||||
|
|
|
@ -414,6 +414,8 @@ static mlan_status wlan_get_info_ioctl(pmlan_adapter pmadapter,
|
||||||
pioctl_req->data_read_written =
|
pioctl_req->data_read_written =
|
||||||
sizeof(mlan_fw_info) + MLAN_SUB_COMMAND_SIZE;
|
sizeof(mlan_fw_info) + MLAN_SUB_COMMAND_SIZE;
|
||||||
pget_info->param.fw_info.fw_ver = pmadapter->fw_release_number;
|
pget_info->param.fw_info.fw_ver = pmadapter->fw_release_number;
|
||||||
|
pget_info->param.fw_info.hotfix_version =
|
||||||
|
pmadapter->fw_hotfix_ver;
|
||||||
memcpy_ext(pmadapter, &pget_info->param.fw_info.mac_addr,
|
memcpy_ext(pmadapter, &pget_info->param.fw_info.mac_addr,
|
||||||
pmpriv->curr_addr, MLAN_MAC_ADDR_LENGTH,
|
pmpriv->curr_addr, MLAN_MAC_ADDR_LENGTH,
|
||||||
MLAN_MAC_ADDR_LENGTH);
|
MLAN_MAC_ADDR_LENGTH);
|
||||||
|
|
|
@ -3177,6 +3177,15 @@ static mlan_status wlan_uap_ret_get_log(pmlan_private pmpriv,
|
||||||
wlan_le32_to_cpu(pget_log->gdma_abort_cnt);
|
wlan_le32_to_cpu(pget_log->gdma_abort_cnt);
|
||||||
pget_info->param.stats.g_reset_rx_mac_cnt =
|
pget_info->param.stats.g_reset_rx_mac_cnt =
|
||||||
wlan_le32_to_cpu(pget_log->g_reset_rx_mac_cnt);
|
wlan_le32_to_cpu(pget_log->g_reset_rx_mac_cnt);
|
||||||
|
// Ownership error counters
|
||||||
|
pget_info->param.stats.dwCtlErrCnt =
|
||||||
|
wlan_le32_to_cpu(pget_log->dwCtlErrCnt);
|
||||||
|
pget_info->param.stats.dwBcnErrCnt =
|
||||||
|
wlan_le32_to_cpu(pget_log->dwBcnErrCnt);
|
||||||
|
pget_info->param.stats.dwMgtErrCnt =
|
||||||
|
wlan_le32_to_cpu(pget_log->dwMgtErrCnt);
|
||||||
|
pget_info->param.stats.dwDatErrCnt =
|
||||||
|
wlan_le32_to_cpu(pget_log->dwDatErrCnt);
|
||||||
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);
|
||||||
|
@ -3601,7 +3610,7 @@ static mlan_status wlan_uap_ret_sta_list(pmlan_private pmpriv,
|
||||||
} else
|
} else
|
||||||
info->param.sta_list.info[i].bandmode = 0xFF;
|
info->param.sta_list.info[i].bandmode = 0xFF;
|
||||||
pioctl_buf->data_read_written +=
|
pioctl_buf->data_read_written +=
|
||||||
sizeof(sta_info_data) +
|
sizeof(sta_info_data) - 1 +
|
||||||
info->param.sta_list.info[i].ie_len;
|
info->param.sta_list.info[i].ie_len;
|
||||||
buf += sizeof(MrvlIEtypes_sta_info_t) +
|
buf += sizeof(MrvlIEtypes_sta_info_t) +
|
||||||
info->param.sta_list.info[i].ie_len;
|
info->param.sta_list.info[i].ie_len;
|
||||||
|
|
|
@ -682,27 +682,10 @@ static mlan_status wlan_uap_bss_ioctl_deauth_sta(pmlan_adapter pmadapter,
|
||||||
mlan_status ret = MLAN_STATUS_SUCCESS;
|
mlan_status ret = MLAN_STATUS_SUCCESS;
|
||||||
pmlan_private pmpriv = pmadapter->priv[pioctl_req->bss_index];
|
pmlan_private pmpriv = pmadapter->priv[pioctl_req->bss_index];
|
||||||
mlan_ds_bss *bss = MNULL;
|
mlan_ds_bss *bss = MNULL;
|
||||||
const t_u8 bc_mac[] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
|
|
||||||
sta_node *sta_ptr = MNULL;
|
|
||||||
|
|
||||||
ENTER();
|
ENTER();
|
||||||
|
|
||||||
bss = (mlan_ds_bss *)pioctl_req->pbuf;
|
bss = (mlan_ds_bss *)pioctl_req->pbuf;
|
||||||
if (pmpriv->uap_host_based & UAP_FLAG_HOST_MLME) {
|
|
||||||
if (memcmp(pmpriv->adapter, bss->param.deauth_param.mac_addr,
|
|
||||||
bc_mac, MLAN_MAC_ADDR_LENGTH)) {
|
|
||||||
sta_ptr = wlan_get_station_entry(
|
|
||||||
pmpriv, bss->param.deauth_param.mac_addr);
|
|
||||||
if (!sta_ptr) {
|
|
||||||
PRINTM(MCMND,
|
|
||||||
"Skip deauth to station " MACSTR "\n",
|
|
||||||
MAC2STR(bss->param.deauth_param
|
|
||||||
.mac_addr));
|
|
||||||
LEAVE();
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
ret = wlan_prepare_cmd(pmpriv, HOST_CMD_APCMD_STA_DEAUTH,
|
ret = wlan_prepare_cmd(pmpriv, HOST_CMD_APCMD_STA_DEAUTH,
|
||||||
HostCmd_ACT_GEN_SET, 0, (t_void *)pioctl_req,
|
HostCmd_ACT_GEN_SET, 0, (t_void *)pioctl_req,
|
||||||
(t_void *)&bss->param.deauth_param);
|
(t_void *)&bss->param.deauth_param);
|
||||||
|
@ -1038,6 +1021,7 @@ wlan_uap_sec_ioctl_set_encrypt_key(pmlan_adapter pmadapter,
|
||||||
LEAVE();
|
LEAVE();
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = wlan_prepare_cmd(pmpriv, HostCmd_CMD_802_11_KEY_MATERIAL,
|
ret = wlan_prepare_cmd(pmpriv, HostCmd_CMD_802_11_KEY_MATERIAL,
|
||||||
HostCmd_ACT_GEN_SET, KEY_INFO_ENABLED,
|
HostCmd_ACT_GEN_SET, KEY_INFO_ENABLED,
|
||||||
(t_void *)pioctl_req, &sec->param.encrypt_key);
|
(t_void *)pioctl_req, &sec->param.encrypt_key);
|
||||||
|
@ -1920,6 +1904,8 @@ mlan_status wlan_ops_uap_ioctl(t_void *adapter, pmlan_ioctl_req pioctl_req)
|
||||||
MLAN_MAC_ADDR_LENGTH);
|
MLAN_MAC_ADDR_LENGTH);
|
||||||
pget_info->param.fw_info.fw_ver =
|
pget_info->param.fw_info.fw_ver =
|
||||||
pmadapter->fw_release_number;
|
pmadapter->fw_release_number;
|
||||||
|
pget_info->param.fw_info.hotfix_version =
|
||||||
|
pmadapter->fw_hotfix_ver;
|
||||||
pget_info->param.fw_info.fw_bands = pmadapter->fw_bands;
|
pget_info->param.fw_info.fw_bands = pmadapter->fw_bands;
|
||||||
pget_info->param.fw_info.ecsa_enable =
|
pget_info->param.fw_info.ecsa_enable =
|
||||||
pmadapter->ecsa_enable;
|
pmadapter->ecsa_enable;
|
||||||
|
|
|
@ -24,7 +24,7 @@
|
||||||
#define _MLAN_DECL_H_
|
#define _MLAN_DECL_H_
|
||||||
|
|
||||||
/** MLAN release version */
|
/** MLAN release version */
|
||||||
#define MLAN_RELEASE_VERSION "247.p5"
|
#define MLAN_RELEASE_VERSION "266"
|
||||||
|
|
||||||
/** Re-define generic data types for MLAN/MOAL */
|
/** Re-define generic data types for MLAN/MOAL */
|
||||||
/** Signed char (1-byte) */
|
/** Signed char (1-byte) */
|
||||||
|
@ -266,6 +266,7 @@ typedef t_s32 t_sval;
|
||||||
/** pcie card reset */
|
/** pcie card reset */
|
||||||
#define FW_RELOAD_PCIE_RESET 4
|
#define FW_RELOAD_PCIE_RESET 4
|
||||||
#endif
|
#endif
|
||||||
|
#define FW_RELOAD_SDIO_HW_RESET 5
|
||||||
|
|
||||||
#ifdef USB
|
#ifdef USB
|
||||||
#define MLAN_USB_BLOCK_SIZE (512)
|
#define MLAN_USB_BLOCK_SIZE (512)
|
||||||
|
@ -428,6 +429,8 @@ typedef t_u8 mlan_802_11_mac_addr[MLAN_MAC_ADDR_LENGTH];
|
||||||
#define CARD_SD8987 "SD8987"
|
#define CARD_SD8987 "SD8987"
|
||||||
/** SD9097 Card */
|
/** SD9097 Card */
|
||||||
#define CARD_SD9097 "SD9097"
|
#define CARD_SD9097 "SD9097"
|
||||||
|
/** SDIW620 Card */
|
||||||
|
#define CARD_SDIW620 "SDIW620"
|
||||||
/** SD9098 Card */
|
/** SD9098 Card */
|
||||||
#define CARD_SD9098 "SD9098"
|
#define CARD_SD9098 "SD9098"
|
||||||
/** SD9177 Card */
|
/** SD9177 Card */
|
||||||
|
@ -457,6 +460,8 @@ typedef t_u8 mlan_802_11_mac_addr[MLAN_MAC_ADDR_LENGTH];
|
||||||
#define CARD_PCIE8997 "PCIE8997"
|
#define CARD_PCIE8997 "PCIE8997"
|
||||||
/** PCIE9097 Card */
|
/** PCIE9097 Card */
|
||||||
#define CARD_PCIE9097 "PCIE9097"
|
#define CARD_PCIE9097 "PCIE9097"
|
||||||
|
/** PCIEIW620 Card */
|
||||||
|
#define CARD_PCIEIW620 "PCIEIW620"
|
||||||
/** PCIE9000S Card */
|
/** PCIE9000S Card */
|
||||||
#define CARD_PCIE9000S "PCIE9000S"
|
#define CARD_PCIE9000S "PCIE9000S"
|
||||||
/** PCIE9098 Card */
|
/** PCIE9098 Card */
|
||||||
|
@ -498,6 +503,8 @@ typedef t_u8 mlan_802_11_mac_addr[MLAN_MAC_ADDR_LENGTH];
|
||||||
#define CARD_USB9098 "USB9098"
|
#define CARD_USB9098 "USB9098"
|
||||||
/** USB9097 Card */
|
/** USB9097 Card */
|
||||||
#define CARD_USB9097 "USB9097"
|
#define CARD_USB9097 "USB9097"
|
||||||
|
/** USBIW620 Card */
|
||||||
|
#define CARD_USBIW620 "USBIW620"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define IS_CARD8801(ct) (CARD_TYPE_8801 == ((ct)&0xf))
|
#define IS_CARD8801(ct) (CARD_TYPE_8801 == ((ct)&0xf))
|
||||||
|
@ -1386,7 +1393,7 @@ typedef MLAN_PACK_START struct _tdls_each_link_status {
|
||||||
/** Key Length */
|
/** Key Length */
|
||||||
t_u8 key_length;
|
t_u8 key_length;
|
||||||
/** actual key */
|
/** actual key */
|
||||||
t_u8 key[];
|
t_u8 key[1];
|
||||||
} MLAN_PACK_END tdls_each_link_status;
|
} MLAN_PACK_END tdls_each_link_status;
|
||||||
|
|
||||||
/** TDLS configuration data */
|
/** TDLS configuration data */
|
||||||
|
@ -2021,6 +2028,7 @@ typedef struct _mlan_callbacks {
|
||||||
t_u8 antenna);
|
t_u8 antenna);
|
||||||
t_void (*moal_updata_peer_signal)(t_void *pmoal, t_u32 bss_index,
|
t_void (*moal_updata_peer_signal)(t_void *pmoal, t_u32 bss_index,
|
||||||
t_u8 *peer_addr, t_s8 snr, t_s8 nflr);
|
t_u8 *peer_addr, t_s8 snr, t_s8 nflr);
|
||||||
|
t_u64 (*moal_do_div)(t_u64 num, t_u32 base);
|
||||||
#if defined(DRV_EMBEDDED_AUTHENTICATOR) || defined(DRV_EMBEDDED_SUPPLICANT)
|
#if defined(DRV_EMBEDDED_AUTHENTICATOR) || defined(DRV_EMBEDDED_SUPPLICANT)
|
||||||
mlan_status (*moal_wait_hostcmd_complete)(t_void *pmoal,
|
mlan_status (*moal_wait_hostcmd_complete)(t_void *pmoal,
|
||||||
t_u32 bss_index);
|
t_u32 bss_index);
|
||||||
|
|
|
@ -132,6 +132,7 @@ typedef MLAN_PACK_START enum _IEEEtypes_ElementId_e {
|
||||||
VS_IE = VENDOR_SPECIFIC_221,
|
VS_IE = VENDOR_SPECIFIC_221,
|
||||||
WAPI_IE = 68,
|
WAPI_IE = 68,
|
||||||
FRAGMENT = 242,
|
FRAGMENT = 242,
|
||||||
|
RSNX_IE = 244,
|
||||||
EXTENSION = 255
|
EXTENSION = 255
|
||||||
} MLAN_PACK_END IEEEtypes_ElementId_e;
|
} MLAN_PACK_END IEEEtypes_ElementId_e;
|
||||||
|
|
||||||
|
@ -1994,7 +1995,8 @@ typedef struct _BSSDescriptor_t {
|
||||||
t_u32 beacon_buf_size;
|
t_u32 beacon_buf_size;
|
||||||
/** Max allocated size for updated scan response */
|
/** Max allocated size for updated scan response */
|
||||||
t_u32 beacon_buf_size_max;
|
t_u32 beacon_buf_size_max;
|
||||||
|
/** scan age in secs */
|
||||||
|
t_u32 age_in_secs;
|
||||||
} BSSDescriptor_t, *pBSSDescriptor_t;
|
} BSSDescriptor_t, *pBSSDescriptor_t;
|
||||||
|
|
||||||
#endif /* !_MLAN_IEEE_H_ */
|
#endif /* !_MLAN_IEEE_H_ */
|
||||||
|
|
|
@ -1259,8 +1259,9 @@ typedef MLAN_PACK_START struct _otp_region_info {
|
||||||
t_u8 country_code[2];
|
t_u8 country_code[2];
|
||||||
t_u8 region_code;
|
t_u8 region_code;
|
||||||
t_u8 environment;
|
t_u8 environment;
|
||||||
t_u16 force_reg : 1;
|
t_u8 force_reg : 1;
|
||||||
t_u16 reserved : 15;
|
t_u8 reserved : 7;
|
||||||
|
t_u8 dfs_region;
|
||||||
} MLAN_PACK_END otp_region_info_t;
|
} MLAN_PACK_END otp_region_info_t;
|
||||||
|
|
||||||
/** Type definition of mlan_ds_custom_reg_domain */
|
/** Type definition of mlan_ds_custom_reg_domain */
|
||||||
|
@ -1636,6 +1637,15 @@ typedef struct _mlan_ds_get_stats {
|
||||||
t_u32 gdma_abort_cnt;
|
t_u32 gdma_abort_cnt;
|
||||||
/** Rx Reset MAC Count */
|
/** Rx Reset MAC Count */
|
||||||
t_u32 g_reset_rx_mac_cnt;
|
t_u32 g_reset_rx_mac_cnt;
|
||||||
|
// Ownership error counters
|
||||||
|
/*Error Ownership error count*/
|
||||||
|
t_u32 dwCtlErrCnt;
|
||||||
|
/*Control Ownership error count*/
|
||||||
|
t_u32 dwBcnErrCnt;
|
||||||
|
/*Control Ownership error count*/
|
||||||
|
t_u32 dwMgtErrCnt;
|
||||||
|
/*Control Ownership error count*/
|
||||||
|
t_u32 dwDatErrCnt;
|
||||||
} 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 */
|
||||||
|
@ -1771,6 +1781,8 @@ typedef struct _mlan_ds_get_signal {
|
||||||
typedef struct _mlan_fw_info {
|
typedef struct _mlan_fw_info {
|
||||||
/** Firmware version */
|
/** Firmware version */
|
||||||
t_u32 fw_ver;
|
t_u32 fw_ver;
|
||||||
|
/** Firmware Hotfix version */
|
||||||
|
t_u8 hotfix_version;
|
||||||
/** MAC address */
|
/** MAC address */
|
||||||
mlan_802_11_mac_addr mac_addr;
|
mlan_802_11_mac_addr mac_addr;
|
||||||
/** 802.11n device capabilities */
|
/** 802.11n device capabilities */
|
||||||
|
@ -2402,7 +2414,7 @@ typedef struct _sta_info_data {
|
||||||
/** ie length */
|
/** ie length */
|
||||||
t_u16 ie_len;
|
t_u16 ie_len;
|
||||||
/** ie buffer */
|
/** ie buffer */
|
||||||
t_u8 ie_buf[];
|
t_u8 ie_buf[1];
|
||||||
} sta_info_data;
|
} sta_info_data;
|
||||||
|
|
||||||
/** mlan_ds_sta_list structure for MLAN_OID_UAP_STA_LIST */
|
/** mlan_ds_sta_list structure for MLAN_OID_UAP_STA_LIST */
|
||||||
|
@ -2933,7 +2945,9 @@ typedef struct _mlan_ds_beacon_stuck_param_cfg {
|
||||||
#define HOST_SLEEP_COND_IPV6_PACKET MBIT(31)
|
#define HOST_SLEEP_COND_IPV6_PACKET MBIT(31)
|
||||||
|
|
||||||
/** Host sleep config conditions: Default */
|
/** Host sleep config conditions: Default */
|
||||||
#define HOST_SLEEP_DEF_COND 0
|
#define HOST_SLEEP_DEF_COND \
|
||||||
|
(HOST_SLEEP_COND_BROADCAST_DATA | HOST_SLEEP_COND_UNICAST_DATA | \
|
||||||
|
HOST_SLEEP_COND_MAC_EVENT)
|
||||||
|
|
||||||
/** Host sleep config GPIO : Default */
|
/** Host sleep config GPIO : Default */
|
||||||
#define HOST_SLEEP_DEF_GPIO 0xff
|
#define HOST_SLEEP_DEF_GPIO 0xff
|
||||||
|
|
|
@ -1373,6 +1373,10 @@ int woal_cfg80211_add_key(struct wiphy *wiphy, struct net_device *netdev,
|
||||||
PRINTM(MINFO, "Skip set keys during ft connecting\n");
|
PRINTM(MINFO, "Skip set keys during ft connecting\n");
|
||||||
return -EFAULT;
|
return -EFAULT;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** cancel pending scan */
|
||||||
|
woal_cancel_scan(priv, MOAL_IOCTL_WAIT);
|
||||||
|
|
||||||
if (woal_cfg80211_set_key(priv, 0, params->cipher, params->key,
|
if (woal_cfg80211_set_key(priv, 0, params->cipher, params->key,
|
||||||
params->key_len, params->seq, params->seq_len,
|
params->key_len, params->seq, params->seq_len,
|
||||||
key_index, mac_addr, 0, MOAL_IOCTL_WAIT)) {
|
key_index, mac_addr, 0, MOAL_IOCTL_WAIT)) {
|
||||||
|
@ -2412,6 +2416,34 @@ void woal_cfg80211_mgmt_frame_register(struct wiphy *wiphy,
|
||||||
LEAVE();
|
LEAVE();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* @brief prepare and send WOAL_EVENT_CANCEL_CHANRPT
|
||||||
|
*
|
||||||
|
* @param priv A pointer moal_private structure
|
||||||
|
*
|
||||||
|
* @return N/A
|
||||||
|
*/
|
||||||
|
static void woal_cancel_chanrpt_event(moal_private *priv)
|
||||||
|
{
|
||||||
|
struct woal_event *evt;
|
||||||
|
unsigned long flags;
|
||||||
|
moal_handle *handle = priv->phandle;
|
||||||
|
|
||||||
|
evt = kzalloc(sizeof(struct woal_event), GFP_ATOMIC);
|
||||||
|
if (!evt) {
|
||||||
|
PRINTM(MERROR, "Fail to alloc memory for deauth event\n");
|
||||||
|
LEAVE();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
evt->priv = priv;
|
||||||
|
evt->type = WOAL_EVENT_CANCEL_CHANRPT;
|
||||||
|
INIT_LIST_HEAD(&evt->link);
|
||||||
|
spin_lock_irqsave(&handle->evt_lock, flags);
|
||||||
|
list_add_tail(&evt->link, &handle->evt_queue);
|
||||||
|
spin_unlock_irqrestore(&handle->evt_lock, flags);
|
||||||
|
queue_work(handle->evt_workqueue, &handle->evt_work);
|
||||||
|
}
|
||||||
|
|
||||||
#if KERNEL_VERSION(3, 2, 0) <= CFG80211_VERSION_CODE
|
#if KERNEL_VERSION(3, 2, 0) <= CFG80211_VERSION_CODE
|
||||||
#if KERNEL_VERSION(3, 3, 0) <= CFG80211_VERSION_CODE
|
#if KERNEL_VERSION(3, 3, 0) <= CFG80211_VERSION_CODE
|
||||||
#if KERNEL_VERSION(3, 6, 0) <= CFG80211_VERSION_CODE
|
#if KERNEL_VERSION(3, 6, 0) <= CFG80211_VERSION_CODE
|
||||||
|
@ -2610,6 +2642,9 @@ int woal_cfg80211_mgmt_tx(struct wiphy *wiphy,
|
||||||
PRINTM(MMSG,
|
PRINTM(MMSG,
|
||||||
"wlan: HostMlme %s send deauth/disassoc\n",
|
"wlan: HostMlme %s send deauth/disassoc\n",
|
||||||
priv->netdev->name);
|
priv->netdev->name);
|
||||||
|
if (priv->phandle->is_cac_timer_set)
|
||||||
|
woal_cancel_chanrpt_event(priv);
|
||||||
|
|
||||||
break;
|
break;
|
||||||
case IEEE80211_STYPE_ASSOC_RESP:
|
case IEEE80211_STYPE_ASSOC_RESP:
|
||||||
case IEEE80211_STYPE_REASSOC_RESP:
|
case IEEE80211_STYPE_REASSOC_RESP:
|
||||||
|
@ -2622,6 +2657,7 @@ int woal_cfg80211_mgmt_tx(struct wiphy *wiphy,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#if KERNEL_VERSION(2, 6, 39) <= CFG80211_VERSION_CODE
|
#if KERNEL_VERSION(2, 6, 39) <= CFG80211_VERSION_CODE
|
||||||
if ((ieee80211_is_action(((struct ieee80211_mgmt *)buf)->frame_control))
|
if ((ieee80211_is_action(((struct ieee80211_mgmt *)buf)->frame_control))
|
||||||
#if KERNEL_VERSION(3, 8, 0) <= CFG80211_VERSION_CODE
|
#if KERNEL_VERSION(3, 8, 0) <= CFG80211_VERSION_CODE
|
||||||
|
@ -3352,8 +3388,54 @@ static t_u16 woal_filter_beacon_ies(moal_private *priv, const t_u8 *ie, int len,
|
||||||
!moal_extflg_isset(priv->phandle, EXT_HOST_MLME))
|
!moal_extflg_isset(priv->phandle, EXT_HOST_MLME))
|
||||||
break;
|
break;
|
||||||
else {
|
else {
|
||||||
if ((out_len + length + 2) < (int)ie_out_len) {
|
#if CFG80211_VERSION_CODE < KERNEL_VERSION(4, 20, 0)
|
||||||
moal_memcpy_ext(priv->phandle,
|
if (ext_id == HE_CAPABILITY) {
|
||||||
|
mlan_ds_11ax_he_cfg he_cfg;
|
||||||
|
IEEEtypes_HECap_t *hecap_ie;
|
||||||
|
|
||||||
|
if (priv->channel <= 14)
|
||||||
|
he_cfg.band = MBIT(0);
|
||||||
|
else
|
||||||
|
he_cfg.band = MBIT(1);
|
||||||
|
|
||||||
|
PRINTM(MCMND,
|
||||||
|
"Retrieve 11ax cfg by channel=%d band=%d\n",
|
||||||
|
priv->channel, he_cfg.band);
|
||||||
|
|
||||||
|
if (0 == woal_11ax_cfg(priv,
|
||||||
|
MLAN_ACT_GET,
|
||||||
|
&he_cfg)) {
|
||||||
|
hecap_ie = (IEEEtypes_HECap_t
|
||||||
|
*)&he_cfg
|
||||||
|
.he_cap.len;
|
||||||
|
|
||||||
|
hecap_ie->ieee_hdr.len =
|
||||||
|
he_cfg.he_cap.len;
|
||||||
|
hecap_ie->ieee_hdr.element_id =
|
||||||
|
he_cfg.he_cap.id;
|
||||||
|
|
||||||
|
moal_memcpy_ext(
|
||||||
|
priv->phandle,
|
||||||
|
ie_out + out_len,
|
||||||
|
hecap_ie,
|
||||||
|
hecap_ie->ieee_hdr.len +
|
||||||
|
2,
|
||||||
|
ie_out_len - out_len);
|
||||||
|
|
||||||
|
out_len +=
|
||||||
|
hecap_ie->ieee_hdr.len +
|
||||||
|
2;
|
||||||
|
} else {
|
||||||
|
PRINTM(MERROR,
|
||||||
|
"Fail to get 11ax he_cap parameters\n");
|
||||||
|
}
|
||||||
|
} else
|
||||||
|
#endif
|
||||||
|
{
|
||||||
|
if ((out_len + length + 2) <
|
||||||
|
(int)ie_out_len) {
|
||||||
|
moal_memcpy_ext(
|
||||||
|
priv->phandle,
|
||||||
ie_out + out_len, pos,
|
ie_out + out_len, pos,
|
||||||
length + 2,
|
length + 2,
|
||||||
ie_out_len - out_len);
|
ie_out_len - out_len);
|
||||||
|
@ -3362,6 +3444,7 @@ static t_u16 woal_filter_beacon_ies(moal_private *priv, const t_u8 *ie, int len,
|
||||||
PRINTM(MERROR,
|
PRINTM(MERROR,
|
||||||
"IE too big, fail copy EXTENSION IE\n");
|
"IE too big, fail copy EXTENSION IE\n");
|
||||||
}
|
}
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case EXT_CAPABILITY:
|
case EXT_CAPABILITY:
|
||||||
|
@ -4634,49 +4717,137 @@ void woal_cfg80211_notify_antcfg(moal_private *priv, struct wiphy *wiphy,
|
||||||
if (IS_STA_OR_UAP_CFG80211(priv->phandle->params.cfg80211_wext) &&
|
if (IS_STA_OR_UAP_CFG80211(priv->phandle->params.cfg80211_wext) &&
|
||||||
wiphy) {
|
wiphy) {
|
||||||
if (wiphy->bands[IEEE80211_BAND_2GHZ]) {
|
if (wiphy->bands[IEEE80211_BAND_2GHZ]) {
|
||||||
|
struct ieee80211_supported_band *bands =
|
||||||
|
wiphy->bands[IEEE80211_BAND_2GHZ];
|
||||||
|
|
||||||
if (((radio->param.ant_cfg.tx_antenna & 0xFF) != 3 &&
|
if (((radio->param.ant_cfg.tx_antenna & 0xFF) != 3 &&
|
||||||
(radio->param.ant_cfg.tx_antenna & 0xFF) != 0) ||
|
(radio->param.ant_cfg.tx_antenna & 0xFF) != 0) ||
|
||||||
((radio->param.ant_cfg.rx_antenna & 0xFF) != 3 &&
|
((radio->param.ant_cfg.rx_antenna & 0xFF) != 3 &&
|
||||||
(radio->param.ant_cfg.rx_antenna & 0xFF) != 0))
|
(radio->param.ant_cfg.rx_antenna & 0xFF) != 0)) {
|
||||||
wiphy->bands[IEEE80211_BAND_2GHZ]
|
bands->ht_cap.mcs.rx_mask[1] = 0;
|
||||||
->ht_cap.mcs.rx_mask[1] = 0;
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(4, 20, 0)
|
||||||
else if ((radio->param.ant_cfg.tx_antenna & 0xFF) ==
|
if (bands->n_iftype_data &&
|
||||||
3 ||
|
bands->iftype_data &&
|
||||||
(radio->param.ant_cfg.rx_antenna & 0xFF) == 3)
|
bands->iftype_data->he_cap.has_he) {
|
||||||
wiphy->bands[IEEE80211_BAND_2GHZ]
|
t_u16 mcs_nss[2];
|
||||||
->ht_cap.mcs.rx_mask[1] = 0xff;
|
|
||||||
|
|
||||||
wiphy->bands[IEEE80211_BAND_2GHZ]
|
mcs_nss[0] = bands->iftype_data->he_cap
|
||||||
->ht_cap.mcs.rx_mask[4] = 0;
|
.he_mcs_nss_supp
|
||||||
|
.rx_mcs_80;
|
||||||
|
mcs_nss[1] = mcs_nss[0] |= 0x0c;
|
||||||
|
moal_memcpy_ext(
|
||||||
|
priv->phandle,
|
||||||
|
(t_void *)&bands->iftype_data
|
||||||
|
->he_cap.he_mcs_nss_supp
|
||||||
|
.rx_mcs_80,
|
||||||
|
(t_void *)&mcs_nss,
|
||||||
|
sizeof(mcs_nss),
|
||||||
|
sizeof(bands->iftype_data->he_cap
|
||||||
|
.he_mcs_nss_supp));
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
} else if ((radio->param.ant_cfg.tx_antenna & 0xFF) ==
|
||||||
|
3 ||
|
||||||
|
(radio->param.ant_cfg.rx_antenna & 0xFF) ==
|
||||||
|
3) {
|
||||||
|
bands->ht_cap.mcs.rx_mask[1] = 0xff;
|
||||||
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(4, 20, 0)
|
||||||
|
if (bands->n_iftype_data &&
|
||||||
|
bands->iftype_data &&
|
||||||
|
bands->iftype_data->he_cap.has_he) {
|
||||||
|
t_u16 mcs_nss[2];
|
||||||
|
|
||||||
|
mcs_nss[0] = bands->iftype_data->he_cap
|
||||||
|
.he_mcs_nss_supp
|
||||||
|
.rx_mcs_80;
|
||||||
|
mcs_nss[1] = mcs_nss[0] =
|
||||||
|
(mcs_nss[0] & ~0x0c) |
|
||||||
|
((mcs_nss[0] & 0x3) << 2);
|
||||||
|
|
||||||
|
moal_memcpy_ext(
|
||||||
|
priv->phandle,
|
||||||
|
(t_void *)&bands->iftype_data
|
||||||
|
->he_cap.he_mcs_nss_supp
|
||||||
|
.rx_mcs_80,
|
||||||
|
(t_void *)&mcs_nss,
|
||||||
|
sizeof(mcs_nss),
|
||||||
|
sizeof(bands->iftype_data->he_cap
|
||||||
|
.he_mcs_nss_supp));
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
bands->ht_cap.mcs.rx_mask[4] = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (wiphy->bands[IEEE80211_BAND_5GHZ]) {
|
if (wiphy->bands[IEEE80211_BAND_5GHZ]) {
|
||||||
|
struct ieee80211_supported_band *bands =
|
||||||
|
wiphy->bands[IEEE80211_BAND_5GHZ];
|
||||||
|
|
||||||
if (((radio->param.ant_cfg.tx_antenna & 0xFF00) !=
|
if (((radio->param.ant_cfg.tx_antenna & 0xFF00) !=
|
||||||
0x300 &&
|
0x300 &&
|
||||||
(radio->param.ant_cfg.tx_antenna & 0xFF00) != 0) ||
|
(radio->param.ant_cfg.tx_antenna & 0xFF00) != 0) ||
|
||||||
((radio->param.ant_cfg.rx_antenna & 0xFF00) !=
|
((radio->param.ant_cfg.rx_antenna & 0xFF00) !=
|
||||||
0x300 &&
|
0x300 &&
|
||||||
(radio->param.ant_cfg.rx_antenna & 0xFF00) != 0)) {
|
(radio->param.ant_cfg.rx_antenna & 0xFF00) != 0)) {
|
||||||
wiphy->bands[IEEE80211_BAND_5GHZ]
|
bands->ht_cap.mcs.rx_mask[1] = 0;
|
||||||
->ht_cap.mcs.rx_mask[1] = 0;
|
bands->vht_cap.vht_mcs.rx_mcs_map =
|
||||||
wiphy->bands[IEEE80211_BAND_5GHZ]
|
|
||||||
->vht_cap.vht_mcs.rx_mcs_map =
|
|
||||||
(__force __le16)0xfffe;
|
(__force __le16)0xfffe;
|
||||||
wiphy->bands[IEEE80211_BAND_5GHZ]
|
bands->vht_cap.vht_mcs.tx_mcs_map =
|
||||||
->vht_cap.vht_mcs.tx_mcs_map =
|
|
||||||
(__force __le16)0xfffe;
|
(__force __le16)0xfffe;
|
||||||
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(4, 20, 0)
|
||||||
|
if (bands->n_iftype_data &&
|
||||||
|
bands->iftype_data &&
|
||||||
|
bands->iftype_data->he_cap.has_he) {
|
||||||
|
t_u16 mcs_nss[2];
|
||||||
|
|
||||||
|
mcs_nss[0] = bands->iftype_data->he_cap
|
||||||
|
.he_mcs_nss_supp
|
||||||
|
.rx_mcs_80;
|
||||||
|
mcs_nss[1] = mcs_nss[0] |= 0x0c;
|
||||||
|
moal_memcpy_ext(
|
||||||
|
priv->phandle,
|
||||||
|
(t_void *)&bands->iftype_data
|
||||||
|
->he_cap.he_mcs_nss_supp
|
||||||
|
.rx_mcs_80,
|
||||||
|
(t_void *)&mcs_nss,
|
||||||
|
sizeof(mcs_nss),
|
||||||
|
sizeof(bands->iftype_data->he_cap
|
||||||
|
.he_mcs_nss_supp));
|
||||||
|
}
|
||||||
|
#endif
|
||||||
} else if ((radio->param.ant_cfg.tx_antenna & 0xFF00) ==
|
} else if ((radio->param.ant_cfg.tx_antenna & 0xFF00) ==
|
||||||
0x300 ||
|
0x300 ||
|
||||||
(radio->param.ant_cfg.rx_antenna & 0xFF00) ==
|
(radio->param.ant_cfg.rx_antenna & 0xFF00) ==
|
||||||
0x300) {
|
0x300) {
|
||||||
wiphy->bands[IEEE80211_BAND_5GHZ]
|
bands->ht_cap.mcs.rx_mask[1] = 0xff;
|
||||||
->ht_cap.mcs.rx_mask[1] = 0xff;
|
bands->vht_cap.vht_mcs.rx_mcs_map =
|
||||||
wiphy->bands[IEEE80211_BAND_5GHZ]
|
|
||||||
->vht_cap.vht_mcs.rx_mcs_map =
|
|
||||||
(__force __le16)0xfffa;
|
(__force __le16)0xfffa;
|
||||||
wiphy->bands[IEEE80211_BAND_5GHZ]
|
bands->vht_cap.vht_mcs.tx_mcs_map =
|
||||||
->vht_cap.vht_mcs.tx_mcs_map =
|
|
||||||
(__force __le16)0xfffa;
|
(__force __le16)0xfffa;
|
||||||
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(4, 20, 0)
|
||||||
|
if (bands->n_iftype_data &&
|
||||||
|
bands->iftype_data &&
|
||||||
|
bands->iftype_data->he_cap.has_he) {
|
||||||
|
t_u16 mcs_nss[2];
|
||||||
|
|
||||||
|
mcs_nss[0] = bands->iftype_data->he_cap
|
||||||
|
.he_mcs_nss_supp
|
||||||
|
.rx_mcs_80;
|
||||||
|
mcs_nss[1] = mcs_nss[0] =
|
||||||
|
(mcs_nss[0] & ~0x0c) |
|
||||||
|
((mcs_nss[0] & 0x3) << 2);
|
||||||
|
|
||||||
|
moal_memcpy_ext(
|
||||||
|
priv->phandle,
|
||||||
|
(t_void *)&bands->iftype_data
|
||||||
|
->he_cap.he_mcs_nss_supp
|
||||||
|
.rx_mcs_80,
|
||||||
|
(t_void *)&mcs_nss,
|
||||||
|
sizeof(mcs_nss),
|
||||||
|
sizeof(bands->iftype_data->he_cap
|
||||||
|
.he_mcs_nss_supp));
|
||||||
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -419,6 +419,7 @@ int woal_cfg80211_del_station(struct wiphy *wiphy, struct net_device *dev,
|
||||||
u8 *mac_addr);
|
u8 *mac_addr);
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if KERNEL_VERSION(3, 12, 0) <= CFG80211_VERSION_CODE
|
#if KERNEL_VERSION(3, 12, 0) <= CFG80211_VERSION_CODE
|
||||||
#if KERNEL_VERSION(3, 15, 0) <= CFG80211_VERSION_CODE
|
#if KERNEL_VERSION(3, 15, 0) <= CFG80211_VERSION_CODE
|
||||||
int woal_cfg80211_start_radar_detection(struct wiphy *wiphy,
|
int woal_cfg80211_start_radar_detection(struct wiphy *wiphy,
|
||||||
|
@ -434,6 +435,8 @@ int woal_cfg80211_start_radar_detection(struct wiphy *wiphy,
|
||||||
int woal_cfg80211_channel_switch(struct wiphy *wiphy, struct net_device *dev,
|
int woal_cfg80211_channel_switch(struct wiphy *wiphy, struct net_device *dev,
|
||||||
struct cfg80211_csa_settings *params);
|
struct cfg80211_csa_settings *params);
|
||||||
|
|
||||||
|
void woal_process_cancel_chanrpt_event(moal_private *priv);
|
||||||
|
|
||||||
void woal_cac_timer_func(void *context);
|
void woal_cac_timer_func(void *context);
|
||||||
void woal_csa_work_queue(struct work_struct *work);
|
void woal_csa_work_queue(struct work_struct *work);
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -2762,6 +2762,9 @@ 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) {
|
||||||
|
|
|
@ -1100,7 +1100,7 @@ static int woal_debug_read(struct seq_file *sfp, void *data)
|
||||||
seq_printf(
|
seq_printf(
|
||||||
sfp,
|
sfp,
|
||||||
"tid = %d, ta = %02x:%02x:%02x:%02x:%02x:%02x, start_win = %d, "
|
"tid = %d, ta = %02x:%02x:%02x:%02x:%02x:%02x, start_win = %d, "
|
||||||
"win_size = %d, amsdu=%d\n",
|
"win_size = %d, amsdu=%d",
|
||||||
(int)info->rx_tbl[i].tid, info->rx_tbl[i].ta[0],
|
(int)info->rx_tbl[i].tid, info->rx_tbl[i].ta[0],
|
||||||
info->rx_tbl[i].ta[1], info->rx_tbl[i].ta[2],
|
info->rx_tbl[i].ta[1], info->rx_tbl[i].ta[2],
|
||||||
info->rx_tbl[i].ta[3], info->rx_tbl[i].ta[4],
|
info->rx_tbl[i].ta[3], info->rx_tbl[i].ta[4],
|
||||||
|
@ -1108,6 +1108,8 @@ static int woal_debug_read(struct seq_file *sfp, void *data)
|
||||||
(int)info->rx_tbl[i].start_win,
|
(int)info->rx_tbl[i].start_win,
|
||||||
(int)info->rx_tbl[i].win_size,
|
(int)info->rx_tbl[i].win_size,
|
||||||
(int)info->rx_tbl[i].amsdu);
|
(int)info->rx_tbl[i].amsdu);
|
||||||
|
seq_printf(sfp, "\n");
|
||||||
|
|
||||||
seq_printf(sfp, "buffer: ");
|
seq_printf(sfp, "buffer: ");
|
||||||
for (j = 0; j < info->rx_tbl[i].win_size; j++) {
|
for (j = 0; j < info->rx_tbl[i].win_size; j++) {
|
||||||
if (info->rx_tbl[i].buffer[j] == MTRUE)
|
if (info->rx_tbl[i].buffer[j] == MTRUE)
|
||||||
|
|
|
@ -3714,11 +3714,16 @@ done:
|
||||||
static int woal_priv_setgettcpackenh(moal_private *priv, t_u8 *respbuf,
|
static int woal_priv_setgettcpackenh(moal_private *priv, t_u8 *respbuf,
|
||||||
t_u32 respbuflen)
|
t_u32 respbuflen)
|
||||||
{
|
{
|
||||||
t_u32 data[1];
|
t_u32 data[2] = {0, 0};
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
int user_data_len = 0;
|
int user_data_len = 0;
|
||||||
|
|
||||||
ENTER();
|
ENTER();
|
||||||
|
if (!priv || !priv->phandle) {
|
||||||
|
PRINTM(MERROR, "priv or handle is null\n");
|
||||||
|
ret = -EFAULT;
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
|
||||||
if (strlen(respbuf) == (strlen(CMD_NXP) + strlen(PRIV_CMD_TCPACKENH))) {
|
if (strlen(respbuf) == (strlen(CMD_NXP) + strlen(PRIV_CMD_TCPACKENH))) {
|
||||||
/* GET operation */
|
/* GET operation */
|
||||||
|
@ -3731,17 +3736,25 @@ static int woal_priv_setgettcpackenh(moal_private *priv, t_u8 *respbuf,
|
||||||
data, ARRAY_SIZE(data), &user_data_len);
|
data, ARRAY_SIZE(data), &user_data_len);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (user_data_len >= 2) {
|
if (user_data_len == 0) {
|
||||||
|
/* get operation */
|
||||||
|
data[0] = priv->enable_tcp_ack_enh;
|
||||||
|
data[1] = priv->tcp_ack_max_hold;
|
||||||
|
moal_memcpy_ext(priv->phandle, respbuf, (t_u8 *)data,
|
||||||
|
sizeof(data), respbuflen);
|
||||||
|
ret = sizeof(data);
|
||||||
|
} else {
|
||||||
|
/* set operation */
|
||||||
|
if (user_data_len >= 3) {
|
||||||
PRINTM(MERROR, "Too many arguments\n");
|
PRINTM(MERROR, "Too many arguments\n");
|
||||||
ret = -EINVAL;
|
ret = -EINVAL;
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
|
if (data[0] > 1 || data[1] > TCP_ACK_MAX_HOLD) {
|
||||||
if (user_data_len == 0) {
|
PRINTM(MERROR, "Invalid argument\n");
|
||||||
/* get operation */
|
ret = -EINVAL;
|
||||||
respbuf[0] = priv->enable_tcp_ack_enh;
|
goto done;
|
||||||
} else {
|
}
|
||||||
/* set operation */
|
|
||||||
if (data[0] == MTRUE) {
|
if (data[0] == MTRUE) {
|
||||||
PRINTM(MINFO, "Enabling TCP Ack enhancement\n");
|
PRINTM(MINFO, "Enabling TCP Ack enhancement\n");
|
||||||
priv->enable_tcp_ack_enh = MTRUE;
|
priv->enable_tcp_ack_enh = MTRUE;
|
||||||
|
@ -3750,14 +3763,17 @@ static int woal_priv_setgettcpackenh(moal_private *priv, t_u8 *respbuf,
|
||||||
priv->enable_tcp_ack_enh = MFALSE;
|
priv->enable_tcp_ack_enh = MFALSE;
|
||||||
/* release the tcp sessions if any */
|
/* release the tcp sessions if any */
|
||||||
woal_flush_tcp_sess_queue(priv);
|
woal_flush_tcp_sess_queue(priv);
|
||||||
} else {
|
|
||||||
PRINTM(MERROR, "Unknown option = %u\n", data[0]);
|
|
||||||
ret = -EINVAL;
|
|
||||||
goto done;
|
|
||||||
}
|
}
|
||||||
respbuf[0] = priv->enable_tcp_ack_enh;
|
if (user_data_len >= 2) {
|
||||||
|
PRINTM(MINFO, "TCP drop Ack configure: %d\n", data[1]);
|
||||||
|
priv->tcp_ack_max_hold = data[1];
|
||||||
|
}
|
||||||
|
data[0] = priv->enable_tcp_ack_enh;
|
||||||
|
data[1] = priv->tcp_ack_max_hold;
|
||||||
|
moal_memcpy_ext(priv->phandle, respbuf, (t_u8 *)data,
|
||||||
|
sizeof(data), respbuflen);
|
||||||
|
ret = sizeof(data);
|
||||||
}
|
}
|
||||||
ret = 1;
|
|
||||||
|
|
||||||
done:
|
done:
|
||||||
LEAVE();
|
LEAVE();
|
||||||
|
@ -5549,6 +5565,12 @@ static int woal_priv_set_get_psmode(moal_private *priv, t_u8 *respbuf,
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (data != 0 && data != 1) {
|
||||||
|
PRINTM(MERROR, "Invalid psmode=%d\n", data);
|
||||||
|
ret = -EINVAL;
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
|
||||||
/* Flip the value */
|
/* Flip the value */
|
||||||
data = !data;
|
data = !data;
|
||||||
|
|
||||||
|
@ -6863,7 +6885,8 @@ static int woal_priv_get_txpwrlimit(moal_private *priv, t_u8 *respbuf,
|
||||||
header_len = strlen(PRIV_CMD_GET_TXPWR_LIMIT);
|
header_len = strlen(PRIV_CMD_GET_TXPWR_LIMIT);
|
||||||
trpc_cfg = (mlan_ds_misc_chan_trpc_cfg *)(respbuf + header_len);
|
trpc_cfg = (mlan_ds_misc_chan_trpc_cfg *)(respbuf + header_len);
|
||||||
if ((trpc_cfg->sub_band != 0) && (trpc_cfg->sub_band != 0x10) &&
|
if ((trpc_cfg->sub_band != 0) && (trpc_cfg->sub_band != 0x10) &&
|
||||||
(trpc_cfg->sub_band != 0x11) && (trpc_cfg->sub_band != 0x12)) {
|
(trpc_cfg->sub_band != 0x11) && (trpc_cfg->sub_band != 0x12) &&
|
||||||
|
(trpc_cfg->sub_band != 0x13)) {
|
||||||
PRINTM(MERROR, "Invalid subband=0x%x\n", trpc_cfg->sub_band);
|
PRINTM(MERROR, "Invalid subband=0x%x\n", trpc_cfg->sub_band);
|
||||||
ret = -EINVAL;
|
ret = -EINVAL;
|
||||||
goto done;
|
goto done;
|
||||||
|
|
|
@ -76,6 +76,7 @@ typedef struct _region_code_mapping_t {
|
||||||
|
|
||||||
/** Region code mapping table */
|
/** Region code mapping table */
|
||||||
static region_code_mapping_t region_code_mapping[] = {
|
static region_code_mapping_t region_code_mapping[] = {
|
||||||
|
{"00", 0x00}, /* World */
|
||||||
{"US", 0x10}, /* US FCC */
|
{"US", 0x10}, /* US FCC */
|
||||||
{"CA", 0x20}, /* IC Canada */
|
{"CA", 0x20}, /* IC Canada */
|
||||||
{"SG", 0x10}, /* Singapore */
|
{"SG", 0x10}, /* Singapore */
|
||||||
|
@ -94,6 +95,7 @@ static region_code_mapping_t region_code_mapping[] = {
|
||||||
|
|
||||||
/** EEPROM Region code mapping table */
|
/** EEPROM Region code mapping table */
|
||||||
static region_code_mapping_t hw_region_code_mapping[] = {
|
static region_code_mapping_t hw_region_code_mapping[] = {
|
||||||
|
{"00 ", 0x00}, /* World */
|
||||||
{"US ", 0x10}, /* US FCC */
|
{"US ", 0x10}, /* US FCC */
|
||||||
{"CA ", 0x20}, /* IC Canada */
|
{"CA ", 0x20}, /* IC Canada */
|
||||||
{"KR ", 0x30}, /* Korea */
|
{"KR ", 0x30}, /* Korea */
|
||||||
|
@ -894,9 +896,9 @@ void woal_request_set_multicast_list(moal_private *priv, struct net_device *dev)
|
||||||
if (mc_count > MLAN_MAX_MULTICAST_LIST_SIZE)
|
if (mc_count > MLAN_MAX_MULTICAST_LIST_SIZE)
|
||||||
bss->param.multicast_list.mode = MLAN_ALL_MULTI_MODE;
|
bss->param.multicast_list.mode = MLAN_ALL_MULTI_MODE;
|
||||||
}
|
}
|
||||||
|
PRINTM(MCMND, "%s set multicast_list\n", dev->name);
|
||||||
/* Send IOCTL request to MLAN */
|
/* Send IOCTL request to MLAN */
|
||||||
status = woal_request_ioctl(priv, req, MOAL_NO_WAIT);
|
status = woal_request_ioctl(priv, req, MOAL_IOCTL_WAIT);
|
||||||
if (status != MLAN_STATUS_PENDING)
|
if (status != MLAN_STATUS_PENDING)
|
||||||
kfree(req);
|
kfree(req);
|
||||||
done:
|
done:
|
||||||
|
@ -1860,6 +1862,8 @@ mlan_status woal_request_get_fw_info(moal_private *priv, t_u8 wait_option,
|
||||||
status = woal_request_ioctl(priv, req, wait_option);
|
status = woal_request_ioctl(priv, req, wait_option);
|
||||||
if (status == MLAN_STATUS_SUCCESS) {
|
if (status == MLAN_STATUS_SUCCESS) {
|
||||||
priv->phandle->fw_release_number = info->param.fw_info.fw_ver;
|
priv->phandle->fw_release_number = info->param.fw_info.fw_ver;
|
||||||
|
priv->phandle->fw_hotfix_version =
|
||||||
|
info->param.fw_info.hotfix_version;
|
||||||
priv->phandle->fw_ecsa_enable = info->param.fw_info.ecsa_enable;
|
priv->phandle->fw_ecsa_enable = info->param.fw_info.ecsa_enable;
|
||||||
priv->phandle->fw_getlog_enable =
|
priv->phandle->fw_getlog_enable =
|
||||||
info->param.fw_info.getlog_enable;
|
info->param.fw_info.getlog_enable;
|
||||||
|
@ -3246,6 +3250,7 @@ done:
|
||||||
*/
|
*/
|
||||||
void woal_get_version(moal_handle *handle, char *version, int max_len)
|
void woal_get_version(moal_handle *handle, char *version, int max_len)
|
||||||
{
|
{
|
||||||
|
t_u8 hotfix_ver = 0;
|
||||||
union {
|
union {
|
||||||
t_u32 l;
|
t_u32 l;
|
||||||
t_u8 c[4];
|
t_u8 c[4];
|
||||||
|
@ -3254,9 +3259,17 @@ void woal_get_version(moal_handle *handle, char *version, int max_len)
|
||||||
|
|
||||||
ENTER();
|
ENTER();
|
||||||
|
|
||||||
|
hotfix_ver = handle->fw_hotfix_version;
|
||||||
ver.l = handle->fw_release_number;
|
ver.l = handle->fw_release_number;
|
||||||
snprintf(fw_ver, sizeof(fw_ver), "%u.%u.%u.p%u", ver.c[2], ver.c[1],
|
|
||||||
ver.c[0], ver.c[3]);
|
if (hotfix_ver) {
|
||||||
|
snprintf(fw_ver, sizeof(fw_ver), "%u.%u.%u.p%u.%u", ver.c[2],
|
||||||
|
ver.c[1], ver.c[0], ver.c[3], hotfix_ver);
|
||||||
|
|
||||||
|
} else {
|
||||||
|
snprintf(fw_ver, sizeof(fw_ver), "%u.%u.%u.p%u", ver.c[2],
|
||||||
|
ver.c[1], ver.c[0], ver.c[3]);
|
||||||
|
}
|
||||||
|
|
||||||
snprintf(version, max_len, handle->driver_version, fw_ver);
|
snprintf(version, max_len, handle->driver_version, fw_ver);
|
||||||
|
|
||||||
|
@ -3906,7 +3919,7 @@ int woal_11h_cancel_chan_report_ioctl(moal_private *priv, t_u8 wait_option)
|
||||||
mlan_status status = MLAN_STATUS_SUCCESS;
|
mlan_status status = MLAN_STATUS_SUCCESS;
|
||||||
|
|
||||||
ENTER();
|
ENTER();
|
||||||
|
PRINTM(MCMND, "wlan: woal_11h_cancel_chan_report\n");
|
||||||
req = woal_alloc_mlan_ioctl_req(sizeof(mlan_ds_11h_cfg));
|
req = woal_alloc_mlan_ioctl_req(sizeof(mlan_ds_11h_cfg));
|
||||||
if (req == NULL) {
|
if (req == NULL) {
|
||||||
ret = -ENOMEM;
|
ret = -ENOMEM;
|
||||||
|
|
|
@ -717,6 +717,7 @@ static mlan_callbacks woal_callbacks = {
|
||||||
.moal_assert = moal_assert,
|
.moal_assert = moal_assert,
|
||||||
.moal_hist_data_add = moal_hist_data_add,
|
.moal_hist_data_add = moal_hist_data_add,
|
||||||
.moal_updata_peer_signal = moal_updata_peer_signal,
|
.moal_updata_peer_signal = moal_updata_peer_signal,
|
||||||
|
.moal_do_div = moal_do_div,
|
||||||
#if defined(DRV_EMBEDDED_AUTHENTICATOR) || defined(DRV_EMBEDDED_SUPPLICANT)
|
#if defined(DRV_EMBEDDED_AUTHENTICATOR) || defined(DRV_EMBEDDED_SUPPLICANT)
|
||||||
.moal_wait_hostcmd_complete = moal_wait_hostcmd_complete,
|
.moal_wait_hostcmd_complete = moal_wait_hostcmd_complete,
|
||||||
.moal_notify_hostcmd_complete = moal_notify_hostcmd_complete,
|
.moal_notify_hostcmd_complete = moal_notify_hostcmd_complete,
|
||||||
|
@ -3102,6 +3103,8 @@ static mlan_status woal_req_txpwr_data(moal_handle *handle,
|
||||||
ENTER();
|
ENTER();
|
||||||
|
|
||||||
if (txpwrlimit_cfg && strncmp(txpwrlimit_cfg, "none", strlen("none"))) {
|
if (txpwrlimit_cfg && strncmp(txpwrlimit_cfg, "none", strlen("none"))) {
|
||||||
|
PRINTM(MMSG, "Download txpwrlimit_cfg=%s\n",
|
||||||
|
handle->params.txpwrlimit_cfg);
|
||||||
if (req_fw_nowait) {
|
if (req_fw_nowait) {
|
||||||
#if LINUX_VERSION_CODE >= KERNEL_VERSION(5, 13, 0)
|
#if LINUX_VERSION_CODE >= KERNEL_VERSION(5, 13, 0)
|
||||||
if ((request_firmware_nowait(
|
if ((request_firmware_nowait(
|
||||||
|
@ -3717,18 +3720,7 @@ void woal_fill_mlan_buffer(moal_private *priv, mlan_buffer *pmbuf,
|
||||||
* and MSDU lifetime expiry.
|
* and MSDU lifetime expiry.
|
||||||
*/
|
*/
|
||||||
woal_get_monotonic_time(&tstamp);
|
woal_get_monotonic_time(&tstamp);
|
||||||
#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 22)
|
skb->tstamp = ktime_get_real();
|
||||||
#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 17, 0)
|
|
||||||
skb->tstamp = ktime_get_raw();
|
|
||||||
#else
|
|
||||||
skb->tstamp = timeval_to_ktime(tstamp);
|
|
||||||
#endif
|
|
||||||
#elif LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 14)
|
|
||||||
skb_set_timestamp(skb, &tstamp);
|
|
||||||
#else
|
|
||||||
moal_memcpy_ext(priv->phandle, &skb->stamp, &tstamp, sizeof(skb->stamp),
|
|
||||||
sizeof(skb->stamp));
|
|
||||||
#endif
|
|
||||||
|
|
||||||
pmbuf->pdesc = skb;
|
pmbuf->pdesc = skb;
|
||||||
pmbuf->pbuf = skb->head + sizeof(mlan_buffer);
|
pmbuf->pbuf = skb->head + sizeof(mlan_buffer);
|
||||||
|
@ -4142,6 +4134,20 @@ moal_private *woal_add_interface(moal_handle *handle, t_u8 bss_index,
|
||||||
#endif
|
#endif
|
||||||
#endif /*UAP_CFG80211 */
|
#endif /*UAP_CFG80211 */
|
||||||
|
|
||||||
|
/* Create workqueue for main process */
|
||||||
|
#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 36)
|
||||||
|
priv->mclist_workqueue =
|
||||||
|
alloc_workqueue("MCLIST_WORK_QUEUE",
|
||||||
|
WQ_HIGHPRI | WQ_MEM_RECLAIM | WQ_UNBOUND, 1);
|
||||||
|
#else
|
||||||
|
priv->mclist_workqueue = create_workqueue("MCLIST_WORK_QUEUE");
|
||||||
|
#endif
|
||||||
|
if (!priv->mclist_workqueue) {
|
||||||
|
PRINTM(MERROR, "cannot alloc mclist workqueue \n");
|
||||||
|
goto error;
|
||||||
|
}
|
||||||
|
MLAN_INIT_WORK(&priv->mclist_work, woal_mclist_work_queue);
|
||||||
|
|
||||||
/* Initialize priv structure */
|
/* Initialize priv structure */
|
||||||
woal_init_priv(priv, MOAL_IOCTL_WAIT);
|
woal_init_priv(priv, MOAL_IOCTL_WAIT);
|
||||||
|
|
||||||
|
@ -4207,9 +4213,14 @@ moal_private *woal_add_interface(moal_handle *handle, t_u8 bss_index,
|
||||||
return priv;
|
return priv;
|
||||||
error:
|
error:
|
||||||
handle->priv_num = bss_index;
|
handle->priv_num = bss_index;
|
||||||
#if defined(STA_CFG80211) || defined(UAP_CFG80211)
|
|
||||||
/* Unregister wiphy device and free */
|
/* Unregister wiphy device and free */
|
||||||
if (priv) {
|
if (priv) {
|
||||||
|
if (priv->mclist_workqueue) {
|
||||||
|
flush_workqueue(priv->mclist_workqueue);
|
||||||
|
destroy_workqueue(priv->mclist_workqueue);
|
||||||
|
priv->mclist_workqueue = NULL;
|
||||||
|
}
|
||||||
|
#if defined(STA_CFG80211) || defined(UAP_CFG80211)
|
||||||
if (priv->wdev &&
|
if (priv->wdev &&
|
||||||
IS_STA_OR_UAP_CFG80211(handle->params.cfg80211_wext))
|
IS_STA_OR_UAP_CFG80211(handle->params.cfg80211_wext))
|
||||||
priv->wdev = NULL;
|
priv->wdev = NULL;
|
||||||
|
@ -4221,8 +4232,8 @@ error:
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
|
}
|
||||||
if (dev && dev->reg_state == NETREG_REGISTERED)
|
if (dev && dev->reg_state == NETREG_REGISTERED)
|
||||||
unregister_netdev(dev);
|
unregister_netdev(dev);
|
||||||
if (dev)
|
if (dev)
|
||||||
|
@ -4310,6 +4321,12 @@ void woal_remove_interface(moal_handle *handle, t_u8 bss_index)
|
||||||
if (dev->reg_state == NETREG_REGISTERED)
|
if (dev->reg_state == NETREG_REGISTERED)
|
||||||
unregister_netdev(dev);
|
unregister_netdev(dev);
|
||||||
|
|
||||||
|
if (priv->mclist_workqueue) {
|
||||||
|
flush_workqueue(priv->mclist_workqueue);
|
||||||
|
destroy_workqueue(priv->mclist_workqueue);
|
||||||
|
priv->mclist_workqueue = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
#if defined(STA_CFG80211) || defined(UAP_CFG80211)
|
#if defined(STA_CFG80211) || defined(UAP_CFG80211)
|
||||||
/* Unregister wiphy device and free */
|
/* Unregister wiphy device and free */
|
||||||
if (priv->wdev && IS_STA_OR_UAP_CFG80211(handle->params.cfg80211_wext))
|
if (priv->wdev && IS_STA_OR_UAP_CFG80211(handle->params.cfg80211_wext))
|
||||||
|
@ -4640,13 +4657,13 @@ int woal_open(struct net_device *dev)
|
||||||
{
|
{
|
||||||
moal_private *priv = (moal_private *)netdev_priv(dev);
|
moal_private *priv = (moal_private *)netdev_priv(dev);
|
||||||
#if defined(USB)
|
#if defined(USB)
|
||||||
#if LINUX_VERSION_CODE > KERNEL_VERSION(5, 0, 0)
|
#if LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 34)
|
||||||
struct usb_device *udev =
|
|
||||||
((struct usb_card_rec *)(priv->phandle->card))->udev;
|
|
||||||
#else
|
|
||||||
struct usb_interface *intf =
|
struct usb_interface *intf =
|
||||||
((struct usb_card_rec *)priv->phandle->card)->intf;
|
((struct usb_card_rec *)priv->phandle->card)->intf;
|
||||||
#endif /* >= 5.0.0 */
|
#else
|
||||||
|
struct usb_device *udev =
|
||||||
|
((struct usb_card_rec *)(priv->phandle->card))->udev;
|
||||||
|
#endif /* < 2.6.34 */
|
||||||
#endif /* USB_SUSPEND_RESUME */
|
#endif /* USB_SUSPEND_RESUME */
|
||||||
t_u8 carrier_on = MFALSE;
|
t_u8 carrier_on = MFALSE;
|
||||||
|
|
||||||
|
@ -4660,19 +4677,15 @@ int woal_open(struct net_device *dev)
|
||||||
}
|
}
|
||||||
#if defined(USB)
|
#if defined(USB)
|
||||||
if (IS_USB(priv->phandle->card_type)) {
|
if (IS_USB(priv->phandle->card_type)) {
|
||||||
#if LINUX_VERSION_CODE < KERNEL_VERSION(5, 0, 0)
|
|
||||||
#if LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 34)
|
#if LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 34)
|
||||||
/* Error enabling PM on interface */
|
/* Error enabling PM on interface */
|
||||||
if (usb_autopm_get_interface(intf)) {
|
if (usb_autopm_get_interface(intf)) {
|
||||||
LEAVE();
|
LEAVE();
|
||||||
return -EIO;
|
return -EIO;
|
||||||
}
|
}
|
||||||
#else
|
|
||||||
atomic_set(&intf->pm_usage_cnt, 1);
|
|
||||||
#endif /* < 2.6.34 */
|
|
||||||
#else
|
#else
|
||||||
atomic_set(&udev->dev.power.usage_count, 1);
|
atomic_set(&udev->dev.power.usage_count, 1);
|
||||||
#endif /* 5.0. 0 */
|
#endif /* < 2.6.34 */
|
||||||
}
|
}
|
||||||
#endif /* USB_SUSPEND_RESUME */
|
#endif /* USB_SUSPEND_RESUME */
|
||||||
|
|
||||||
|
@ -4743,13 +4756,13 @@ int woal_close(struct net_device *dev)
|
||||||
{
|
{
|
||||||
moal_private *priv = (moal_private *)netdev_priv(dev);
|
moal_private *priv = (moal_private *)netdev_priv(dev);
|
||||||
#if defined(USB)
|
#if defined(USB)
|
||||||
#if LINUX_VERSION_CODE > KERNEL_VERSION(5, 0, 0)
|
#if LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 34)
|
||||||
struct usb_device *udev =
|
|
||||||
((struct usb_card_rec *)(priv->phandle->card))->udev;
|
|
||||||
#else
|
|
||||||
struct usb_interface *intf =
|
struct usb_interface *intf =
|
||||||
((struct usb_card_rec *)priv->phandle->card)->intf;
|
((struct usb_card_rec *)priv->phandle->card)->intf;
|
||||||
#endif /* < 5.0.0 */
|
#else
|
||||||
|
struct usb_device *udev =
|
||||||
|
((struct usb_card_rec *)(priv->phandle->card))->udev;
|
||||||
|
#endif /* < 2.6.34 */
|
||||||
#endif /* USB_SUSPEND_RESUME */
|
#endif /* USB_SUSPEND_RESUME */
|
||||||
#ifdef STA_CFG80211
|
#ifdef STA_CFG80211
|
||||||
int cfg80211_wext = priv->phandle->params.cfg80211_wext;
|
int cfg80211_wext = priv->phandle->params.cfg80211_wext;
|
||||||
|
@ -4797,15 +4810,11 @@ int woal_close(struct net_device *dev)
|
||||||
MODULE_PUT;
|
MODULE_PUT;
|
||||||
#if defined(USB)
|
#if defined(USB)
|
||||||
if (IS_USB(priv->phandle->card_type)) {
|
if (IS_USB(priv->phandle->card_type)) {
|
||||||
#if LINUX_VERSION_CODE < KERNEL_VERSION(5, 0, 0)
|
|
||||||
#if LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 34)
|
#if LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 34)
|
||||||
usb_autopm_put_interface(intf);
|
usb_autopm_put_interface(intf);
|
||||||
#else
|
|
||||||
atomic_set(&intf->pm_usage_cnt, 0);
|
|
||||||
#endif /* < 2.6.34 */
|
|
||||||
#else
|
#else
|
||||||
atomic_set(&udev->dev.power.usage_count, 0);
|
atomic_set(&udev->dev.power.usage_count, 0);
|
||||||
#endif /* < 5.0.0 */
|
#endif /* < 2.6.34 */
|
||||||
}
|
}
|
||||||
#endif /* USB_SUSPEND_RESUME */
|
#endif /* USB_SUSPEND_RESUME */
|
||||||
|
|
||||||
|
@ -5104,6 +5113,7 @@ void woal_mlan_debug_info(moal_private *priv)
|
||||||
PRINTM(MERROR, "max_tx_buf_size = %d\n", info->max_tx_buf_size);
|
PRINTM(MERROR, "max_tx_buf_size = %d\n", info->max_tx_buf_size);
|
||||||
PRINTM(MERROR, "tx_buf_size = %d\n", info->tx_buf_size);
|
PRINTM(MERROR, "tx_buf_size = %d\n", info->tx_buf_size);
|
||||||
PRINTM(MERROR, "curr_tx_buf_size = %d\n", info->curr_tx_buf_size);
|
PRINTM(MERROR, "curr_tx_buf_size = %d\n", info->curr_tx_buf_size);
|
||||||
|
PRINTM(MERROR, "bypass_pkt_count=%d\n", info->bypass_pkt_count);
|
||||||
|
|
||||||
PRINTM(MERROR, "data_sent=%d cmd_sent=%d\n", info->data_sent,
|
PRINTM(MERROR, "data_sent=%d cmd_sent=%d\n", info->data_sent,
|
||||||
info->cmd_sent);
|
info->cmd_sent);
|
||||||
|
@ -5756,9 +5766,7 @@ static int woal_process_tcp_ack(moal_private *priv, mlan_buffer *pmbuf)
|
||||||
tcp_session->ack_seq = ack_seq;
|
tcp_session->ack_seq = ack_seq;
|
||||||
ret = DROP_TCP_ACK;
|
ret = DROP_TCP_ACK;
|
||||||
skb->cb[0]++;
|
skb->cb[0]++;
|
||||||
// We will drop 90% tcp ack
|
if (skb->cb[0] >= priv->tcp_ack_max_hold)
|
||||||
#define TCP_ACK_MAX_HOLD 9
|
|
||||||
if (skb->cb[0] >= TCP_ACK_MAX_HOLD)
|
|
||||||
woal_send_tcp_ack(priv, tcp_session);
|
woal_send_tcp_ack(priv, tcp_session);
|
||||||
spin_unlock_irqrestore(&priv->tcp_sess_lock, flags);
|
spin_unlock_irqrestore(&priv->tcp_sess_lock, flags);
|
||||||
skb = (struct sk_buff *)pmbuf->pdesc;
|
skb = (struct sk_buff *)pmbuf->pdesc;
|
||||||
|
@ -5806,7 +5814,9 @@ static int woal_start_xmit(moal_private *priv, struct sk_buff *skb)
|
||||||
}
|
}
|
||||||
// kernel crash with cloned skb without copy
|
// kernel crash with cloned skb without copy
|
||||||
// uap0 <-->muap0 bridge
|
// uap0 <-->muap0 bridge
|
||||||
if ((skb->cloned &&
|
/* STA role need skb copy to improve throughput.but uAP unicast not */
|
||||||
|
if ((skb->cloned && priv->bss_role == MLAN_BSS_ROLE_STA) ||
|
||||||
|
(skb->cloned && priv->bss_role == MLAN_BSS_ROLE_UAP &&
|
||||||
(!is_unicast_ether_addr(((struct ethhdr *)skb->data)->h_dest))) ||
|
(!is_unicast_ether_addr(((struct ethhdr *)skb->data)->h_dest))) ||
|
||||||
(skb_headroom(skb) <
|
(skb_headroom(skb) <
|
||||||
(MLAN_MIN_DATA_HEADER_LEN + sizeof(mlan_buffer) +
|
(MLAN_MIN_DATA_HEADER_LEN + sizeof(mlan_buffer) +
|
||||||
|
@ -6145,7 +6155,7 @@ void woal_set_multicast_list(struct net_device *dev)
|
||||||
{
|
{
|
||||||
moal_private *priv = (moal_private *)netdev_priv(dev);
|
moal_private *priv = (moal_private *)netdev_priv(dev);
|
||||||
ENTER();
|
ENTER();
|
||||||
woal_request_set_multicast_list(priv, dev);
|
queue_work(priv->mclist_workqueue, &priv->mclist_work);
|
||||||
LEAVE();
|
LEAVE();
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -6226,6 +6236,7 @@ void woal_init_priv(moal_private *priv, t_u8 wait_option)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
priv->enable_tcp_ack_enh = MTRUE;
|
priv->enable_tcp_ack_enh = MTRUE;
|
||||||
|
priv->tcp_ack_max_hold = TCP_ACK_MAX_HOLD;
|
||||||
|
|
||||||
priv->enable_auto_tdls = MFALSE;
|
priv->enable_auto_tdls = MFALSE;
|
||||||
priv->tdls_check_tx = MFALSE;
|
priv->tdls_check_tx = MFALSE;
|
||||||
|
@ -6611,6 +6622,7 @@ static int woal_get_card_info(moal_handle *phandle)
|
||||||
#ifdef SD9177
|
#ifdef SD9177
|
||||||
case CARD_TYPE_SD9177:
|
case CARD_TYPE_SD9177:
|
||||||
phandle->card_info = &card_info_SD9177;
|
phandle->card_info = &card_info_SD9177;
|
||||||
|
phandle->event_fw_dump = MFALSE;
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
#ifdef PCIE8997
|
#ifdef PCIE8997
|
||||||
|
@ -7397,10 +7409,10 @@ t_void woal_store_ssu_dump(moal_handle *phandle, mlan_event *pmevent)
|
||||||
#else
|
#else
|
||||||
vfs_mkdir(&init_user_ns, path.dentry->d_inode, dentry, 0777);
|
vfs_mkdir(&init_user_ns, path.dentry->d_inode, dentry, 0777);
|
||||||
#endif
|
#endif
|
||||||
#if LINUX_VERSION_CODE < KERNEL_VERSION(4, 7, 0)
|
#if LINUX_VERSION_CODE < KERNEL_VERSION(3, 6, 0)
|
||||||
mutex_unlock(&path.dentry->d_inode->i_mutex);
|
mutex_unlock(&path.dentry->d_inode->i_mutex);
|
||||||
#else
|
#else
|
||||||
inode_unlock(path.dentry->d_inode);
|
done_path_create(&path, dentry);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
save_ssudump:
|
save_ssudump:
|
||||||
|
@ -7863,6 +7875,7 @@ static int woal_dump_mlan_drv_info(moal_private *priv, t_u8 *buf)
|
||||||
ptr += sprintf(ptr, "max_tx_buf_size = %d\n", info->max_tx_buf_size);
|
ptr += sprintf(ptr, "max_tx_buf_size = %d\n", info->max_tx_buf_size);
|
||||||
ptr += sprintf(ptr, "tx_buf_size = %d\n", info->tx_buf_size);
|
ptr += sprintf(ptr, "tx_buf_size = %d\n", info->tx_buf_size);
|
||||||
ptr += sprintf(ptr, "curr_tx_buf_size = %d\n", info->curr_tx_buf_size);
|
ptr += sprintf(ptr, "curr_tx_buf_size = %d\n", info->curr_tx_buf_size);
|
||||||
|
ptr += sprintf(ptr, "bypass_pkt_count=%d\n", info->bypass_pkt_count);
|
||||||
|
|
||||||
ptr += sprintf(ptr, "data_sent=%d cmd_sent=%d\n", info->data_sent,
|
ptr += sprintf(ptr, "data_sent=%d cmd_sent=%d\n", info->data_sent,
|
||||||
info->cmd_sent);
|
info->cmd_sent);
|
||||||
|
@ -8010,7 +8023,10 @@ static int woal_dump_moal_hex(moal_handle *phandle, t_u8 *buf)
|
||||||
ptr += sprintf(ptr, "<--moal_handle End-->\n");
|
ptr += sprintf(ptr, "<--moal_handle End-->\n");
|
||||||
|
|
||||||
for (i = 0; i < phandle->priv_num; i++) {
|
for (i = 0; i < phandle->priv_num; i++) {
|
||||||
ptr += sprintf(ptr, "<--moal_private(%d)-->\n", i);
|
if (!phandle->priv[i])
|
||||||
|
continue;
|
||||||
|
ptr += sprintf(ptr, "<--moal_private(%d) %s-->\n", i,
|
||||||
|
phandle->priv[i]->netdev->name);
|
||||||
ptr += sprintf(ptr, "moal_private=%p, size=%ld(0x%lx)\n",
|
ptr += sprintf(ptr, "moal_private=%p, size=%ld(0x%lx)\n",
|
||||||
phandle->priv[i],
|
phandle->priv[i],
|
||||||
(long int)sizeof(*(phandle->priv[i])),
|
(long int)sizeof(*(phandle->priv[i])),
|
||||||
|
@ -8133,10 +8149,10 @@ void woal_create_dump_dir(moal_handle *phandle, char *dir_buf, int buf_size)
|
||||||
#else
|
#else
|
||||||
ret = vfs_mkdir(&init_user_ns, path.dentry->d_inode, dentry, 0777);
|
ret = vfs_mkdir(&init_user_ns, path.dentry->d_inode, dentry, 0777);
|
||||||
#endif
|
#endif
|
||||||
#if LINUX_VERSION_CODE < KERNEL_VERSION(4, 7, 0)
|
#if LINUX_VERSION_CODE < KERNEL_VERSION(3, 6, 0)
|
||||||
mutex_unlock(&path.dentry->d_inode->i_mutex);
|
mutex_unlock(&path.dentry->d_inode->i_mutex);
|
||||||
#else
|
#else
|
||||||
inode_unlock(path.dentry->d_inode);
|
done_path_create(&path, dentry);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
|
@ -8439,16 +8455,21 @@ void woal_moal_debug_info(moal_private *priv, moal_handle *handle, u8 flag)
|
||||||
if (IS_SD(phandle->card_type)) {
|
if (IS_SD(phandle->card_type)) {
|
||||||
if (flag && ((phandle->main_state == MOAL_END_MAIN_PROCESS) ||
|
if (flag && ((phandle->main_state == MOAL_END_MAIN_PROCESS) ||
|
||||||
(phandle->main_state == MOAL_STATE_IDLE))) {
|
(phandle->main_state == MOAL_STATE_IDLE))) {
|
||||||
if (phandle->ops.reg_dbg && (drvdbg & (MREG_D | MFW_D)))
|
if (phandle->ops.reg_dbg &&
|
||||||
|
(drvdbg & (MREG_D | MFW_D))) {
|
||||||
|
if (!phandle->event_fw_dump)
|
||||||
phandle->ops.reg_dbg(phandle);
|
phandle->ops.reg_dbg(phandle);
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
if (drvdbg & (MREG_D | MFW_D)) {
|
if (drvdbg & (MREG_D | MFW_D)) {
|
||||||
|
if (!phandle->event_fw_dump) {
|
||||||
phandle->reg_dbg = MTRUE;
|
phandle->reg_dbg = MTRUE;
|
||||||
queue_work(phandle->workqueue,
|
queue_work(phandle->workqueue,
|
||||||
&phandle->main_work);
|
&phandle->main_work);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
#ifdef DEBUG_LEVEL1
|
#ifdef DEBUG_LEVEL1
|
||||||
if (drvdbg & MFW_D) {
|
if (drvdbg & MFW_D) {
|
||||||
|
@ -8590,6 +8611,19 @@ static int woal_netdev_poll_rx(struct napi_struct *napi, int budget)
|
||||||
return recv;
|
return recv;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief This workqueue function handles set multicast_list
|
||||||
|
*
|
||||||
|
* @param work A pointer to work_struct
|
||||||
|
*
|
||||||
|
* @return N/A
|
||||||
|
*/
|
||||||
|
t_void woal_mclist_work_queue(struct work_struct *work)
|
||||||
|
{
|
||||||
|
moal_private *priv = container_of(work, moal_private, mclist_work);
|
||||||
|
woal_request_set_multicast_list(priv, priv->netdev);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief This workqueue function handles woal event queue
|
* @brief This workqueue function handles woal event queue
|
||||||
*
|
*
|
||||||
|
@ -8661,6 +8695,14 @@ t_void woal_evt_work_queue(struct work_struct *work)
|
||||||
(moal_private *)evt->priv, &evt->assoc_resp);
|
(moal_private *)evt->priv, &evt->assoc_resp);
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
|
#endif
|
||||||
|
#ifdef UAP_CFG80211
|
||||||
|
#if KERNEL_VERSION(3, 12, 0) <= CFG80211_VERSION_CODE
|
||||||
|
case WOAL_EVENT_CANCEL_CHANRPT:
|
||||||
|
woal_process_cancel_chanrpt_event(
|
||||||
|
(moal_private *)evt->priv);
|
||||||
|
break;
|
||||||
|
#endif
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
kfree(evt);
|
kfree(evt);
|
||||||
|
@ -8862,10 +8904,6 @@ void woal_regist_oob_wakeup_irq(moal_handle *handle)
|
||||||
}
|
}
|
||||||
|
|
||||||
disable_irq(handle->irq_oob_wakeup);
|
disable_irq(handle->irq_oob_wakeup);
|
||||||
if (device_init_wakeup(dev, true)) {
|
|
||||||
dev_err(dev, "fail to init irq_oob_wakeup\n");
|
|
||||||
goto err_exit;
|
|
||||||
}
|
|
||||||
|
|
||||||
LEAVE();
|
LEAVE();
|
||||||
return;
|
return;
|
||||||
|
@ -8887,7 +8925,6 @@ void woal_unregist_oob_wakeup_irq(moal_handle *handle)
|
||||||
|
|
||||||
ENTER();
|
ENTER();
|
||||||
if (handle->irq_oob_wakeup >= 0) {
|
if (handle->irq_oob_wakeup >= 0) {
|
||||||
device_init_wakeup(dev, false);
|
|
||||||
devm_free_irq(dev, handle->irq_oob_wakeup, handle);
|
devm_free_irq(dev, handle->irq_oob_wakeup, handle);
|
||||||
}
|
}
|
||||||
LEAVE();
|
LEAVE();
|
||||||
|
@ -9238,7 +9275,7 @@ moal_handle *woal_add_card(void *card, struct device *dev, moal_if_ops *if_ops,
|
||||||
PRINTM(MFATAL, "Firmware Init Failed\n");
|
PRINTM(MFATAL, "Firmware Init Failed\n");
|
||||||
goto err_init_fw;
|
goto err_init_fw;
|
||||||
}
|
}
|
||||||
|
device_init_wakeup(dev, true);
|
||||||
#ifdef SD8887
|
#ifdef SD8887
|
||||||
if (IS_SD8887(handle->card_type)) {
|
if (IS_SD8887(handle->card_type)) {
|
||||||
union {
|
union {
|
||||||
|
@ -9325,6 +9362,7 @@ mlan_status woal_remove_card(void *card)
|
||||||
}
|
}
|
||||||
if (!handle)
|
if (!handle)
|
||||||
goto exit_remove;
|
goto exit_remove;
|
||||||
|
device_init_wakeup(handle->hotplug_device, false);
|
||||||
#ifdef MFG_CMD_SUPPORT
|
#ifdef MFG_CMD_SUPPORT
|
||||||
if (handle->params.mfg_mode == MLAN_INIT_PARA_ENABLED
|
if (handle->params.mfg_mode == MLAN_INIT_PARA_ENABLED
|
||||||
#if defined(USB)
|
#if defined(USB)
|
||||||
|
@ -9589,10 +9627,11 @@ exit_sem_err:
|
||||||
* @brief This function reload fw
|
* @brief This function reload fw
|
||||||
*
|
*
|
||||||
* @param handle A pointer to moal_handle structure
|
* @param handle A pointer to moal_handle structure
|
||||||
|
* @param mode FW_RELOAD_SDIO_INBAND_RESET or FW_RELOAD_SDIO_HW_RESET
|
||||||
*
|
*
|
||||||
* @return 0--success, otherwise failure
|
* @return 0--success, otherwise failure
|
||||||
*/
|
*/
|
||||||
static int woal_reset_and_reload_fw(moal_handle *handle)
|
static int woal_reset_and_reload_fw(moal_handle *handle, t_u8 mode)
|
||||||
{
|
{
|
||||||
int ret = 0, tries = 0;
|
int ret = 0, tries = 0;
|
||||||
t_u32 value = 1;
|
t_u32 value = 1;
|
||||||
|
@ -9600,7 +9639,11 @@ static int woal_reset_and_reload_fw(moal_handle *handle)
|
||||||
t_u8 reset_val = handle->card_info->fw_reset_val;
|
t_u8 reset_val = handle->card_info->fw_reset_val;
|
||||||
|
|
||||||
ENTER();
|
ENTER();
|
||||||
|
if (mode == FW_RELOAD_SDIO_HW_RESET) {
|
||||||
|
PRINTM(MCMND, "woal_sdio_reset_fw...\n");
|
||||||
|
woal_sdio_reset_hw(handle);
|
||||||
|
goto reload_fw;
|
||||||
|
}
|
||||||
if (!IS_SD9098(handle->card_type) && !IS_SD9097(handle->card_type) &&
|
if (!IS_SD9098(handle->card_type) && !IS_SD9097(handle->card_type) &&
|
||||||
!IS_SD9177(handle->card_type)) {
|
!IS_SD9177(handle->card_type)) {
|
||||||
mlan_pm_wakeup_card(handle->pmlan_adapter, MTRUE);
|
mlan_pm_wakeup_card(handle->pmlan_adapter, MTRUE);
|
||||||
|
@ -9647,6 +9690,7 @@ static int woal_reset_and_reload_fw(moal_handle *handle)
|
||||||
if (!IS_SD9098(handle->card_type) && !IS_SD9097(handle->card_type) &&
|
if (!IS_SD9098(handle->card_type) && !IS_SD9097(handle->card_type) &&
|
||||||
!IS_SD9177(handle->card_type))
|
!IS_SD9177(handle->card_type))
|
||||||
mlan_pm_wakeup_card(handle->pmlan_adapter, MFALSE);
|
mlan_pm_wakeup_card(handle->pmlan_adapter, MFALSE);
|
||||||
|
reload_fw:
|
||||||
/* Download FW */
|
/* Download FW */
|
||||||
ret = woal_request_fw(handle);
|
ret = woal_request_fw(handle);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
|
@ -9828,9 +9872,10 @@ void woal_request_fw_reload(moal_handle *phandle, t_u8 mode)
|
||||||
woal_reload_fw(ref_handle);
|
woal_reload_fw(ref_handle);
|
||||||
}
|
}
|
||||||
#ifdef SDIO_MMC
|
#ifdef SDIO_MMC
|
||||||
else if (mode == FW_RELOAD_SDIO_INBAND_RESET &&
|
else if ((mode == FW_RELOAD_SDIO_INBAND_RESET ||
|
||||||
|
mode == FW_RELOAD_SDIO_HW_RESET) &&
|
||||||
IS_SD(handle->card_type)) {
|
IS_SD(handle->card_type)) {
|
||||||
ret = woal_reset_and_reload_fw(handle);
|
ret = woal_reset_and_reload_fw(handle, mode);
|
||||||
if (ref_handle)
|
if (ref_handle)
|
||||||
woal_reload_fw(ref_handle);
|
woal_reload_fw(ref_handle);
|
||||||
}
|
}
|
||||||
|
|
|
@ -231,6 +231,7 @@ typedef t_u8 BOOLEAN;
|
||||||
#define V15 "15"
|
#define V15 "15"
|
||||||
#define V16 "16"
|
#define V16 "16"
|
||||||
#define V17 "17"
|
#define V17 "17"
|
||||||
|
#define V18 "18"
|
||||||
|
|
||||||
/** Chip Magic Value */
|
/** Chip Magic Value */
|
||||||
#define CHIP_MAGIC_VALUE 0x24
|
#define CHIP_MAGIC_VALUE 0x24
|
||||||
|
@ -954,7 +955,7 @@ typedef struct _wait_queue {
|
||||||
/**
|
/**
|
||||||
* the maximum number of adapter supported
|
* the maximum number of adapter supported
|
||||||
**/
|
**/
|
||||||
#define MAX_MLAN_ADAPTER 3
|
#define MAX_MLAN_ADAPTER 4
|
||||||
|
|
||||||
typedef struct _moal_drv_mode {
|
typedef struct _moal_drv_mode {
|
||||||
/** driver mode */
|
/** driver mode */
|
||||||
|
@ -1013,6 +1014,7 @@ struct debug_data_priv {
|
||||||
/** IP address operation: Remove */
|
/** IP address operation: Remove */
|
||||||
#define IPADDR_OP_REMOVE 0
|
#define IPADDR_OP_REMOVE 0
|
||||||
|
|
||||||
|
#define TCP_ACK_MAX_HOLD 9
|
||||||
#define DROP_TCP_ACK 1
|
#define DROP_TCP_ACK 1
|
||||||
#define HOLD_TCP_ACK 2
|
#define HOLD_TCP_ACK 2
|
||||||
struct tcp_sess {
|
struct tcp_sess {
|
||||||
|
@ -1059,6 +1061,11 @@ enum woal_event_type {
|
||||||
WOAL_EVENT_ASSOC_RESP,
|
WOAL_EVENT_ASSOC_RESP,
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
#ifdef UAP_CFG80211
|
||||||
|
#if KERNEL_VERSION(3, 12, 0) <= CFG80211_VERSION_CODE
|
||||||
|
WOAL_EVENT_CANCEL_CHANRPT,
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef struct _woal_evt_buf {
|
typedef struct _woal_evt_buf {
|
||||||
|
@ -1257,6 +1264,10 @@ struct _moal_private {
|
||||||
t_u8 current_addr[ETH_ALEN];
|
t_u8 current_addr[ETH_ALEN];
|
||||||
/** Media connection status */
|
/** Media connection status */
|
||||||
BOOLEAN media_connected;
|
BOOLEAN media_connected;
|
||||||
|
/** mclist work queue */
|
||||||
|
struct workqueue_struct *mclist_workqueue;
|
||||||
|
/** csa 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 */
|
||||||
|
@ -1327,6 +1338,8 @@ struct _moal_private {
|
||||||
t_u8 conn_wep_key[MAX_WEP_KEY_SIZE];
|
t_u8 conn_wep_key[MAX_WEP_KEY_SIZE];
|
||||||
/** connection param */
|
/** connection param */
|
||||||
struct cfg80211_connect_params sme_current;
|
struct cfg80211_connect_params sme_current;
|
||||||
|
/** station info */
|
||||||
|
struct station_info *sinfo;
|
||||||
/* associcate bss */
|
/* associcate bss */
|
||||||
struct cfg80211_bss *assoc_bss;
|
struct cfg80211_bss *assoc_bss;
|
||||||
#endif
|
#endif
|
||||||
|
@ -1501,6 +1514,8 @@ struct _moal_private {
|
||||||
struct list_head tcp_sess_queue;
|
struct list_head tcp_sess_queue;
|
||||||
/** TCP Ack enhance flag */
|
/** TCP Ack enhance flag */
|
||||||
t_u8 enable_tcp_ack_enh;
|
t_u8 enable_tcp_ack_enh;
|
||||||
|
/** TCP Ack drop count */
|
||||||
|
t_u8 tcp_ack_max_hold;
|
||||||
/** TCP session spin lock */
|
/** TCP session spin lock */
|
||||||
spinlock_t tcp_sess_lock;
|
spinlock_t tcp_sess_lock;
|
||||||
/** tcp list */
|
/** tcp list */
|
||||||
|
@ -1882,6 +1897,8 @@ struct _moal_handle {
|
||||||
BOOLEAN surprise_removed;
|
BOOLEAN surprise_removed;
|
||||||
/** Firmware release number */
|
/** Firmware release number */
|
||||||
t_u32 fw_release_number;
|
t_u32 fw_release_number;
|
||||||
|
/** Firmware Hotfix version */
|
||||||
|
t_u8 fw_hotfix_version;
|
||||||
/** ECSA support */
|
/** ECSA support */
|
||||||
t_u8 fw_ecsa_enable;
|
t_u8 fw_ecsa_enable;
|
||||||
/** Getlog support */
|
/** Getlog support */
|
||||||
|
@ -3165,6 +3182,7 @@ void woal_reassoc_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);
|
||||||
|
t_void woal_mclist_work_queue(struct work_struct *work);
|
||||||
|
|
||||||
netdev_tx_t woal_hard_start_xmit(struct sk_buff *skb, struct net_device *dev);
|
netdev_tx_t woal_hard_start_xmit(struct sk_buff *skb, struct net_device *dev);
|
||||||
#ifdef STA_SUPPORT
|
#ifdef STA_SUPPORT
|
||||||
|
|
|
@ -163,8 +163,8 @@ static t_u16 woal_update_card_type(t_void *card)
|
||||||
#ifdef PCIE9097
|
#ifdef PCIE9097
|
||||||
if (cardp_pcie->dev->device == PCIE_DEVICE_ID_NXP_88W9097) {
|
if (cardp_pcie->dev->device == PCIE_DEVICE_ID_NXP_88W9097) {
|
||||||
card_type = CARD_TYPE_PCIE9097;
|
card_type = CARD_TYPE_PCIE9097;
|
||||||
moal_memcpy_ext(NULL, driver_version, CARD_PCIE9097,
|
moal_memcpy_ext(NULL, driver_version, CARD_PCIEIW620,
|
||||||
strlen(CARD_PCIE9097), strlen(driver_version));
|
strlen(CARD_PCIEIW620), strlen(driver_version));
|
||||||
moal_memcpy_ext(NULL,
|
moal_memcpy_ext(NULL,
|
||||||
driver_version + strlen(INTF_CARDTYPE) +
|
driver_version + strlen(INTF_CARDTYPE) +
|
||||||
strlen(KERN_VERSION),
|
strlen(KERN_VERSION),
|
||||||
|
@ -498,6 +498,7 @@ static int woal_pcie_suspend(struct pci_dev *pdev, pm_message_t state)
|
||||||
{
|
{
|
||||||
pcie_service_card *cardp;
|
pcie_service_card *cardp;
|
||||||
moal_handle *handle = NULL;
|
moal_handle *handle = NULL;
|
||||||
|
moal_handle *ref_handle = NULL;
|
||||||
int i;
|
int i;
|
||||||
int ret = MLAN_STATUS_SUCCESS;
|
int ret = MLAN_STATUS_SUCCESS;
|
||||||
int hs_actived;
|
int hs_actived;
|
||||||
|
@ -505,7 +506,6 @@ static int woal_pcie_suspend(struct pci_dev *pdev, pm_message_t state)
|
||||||
int keep_power = 0;
|
int keep_power = 0;
|
||||||
|
|
||||||
ENTER();
|
ENTER();
|
||||||
PRINTM(MCMND, "<--- Enter woal_pcie_suspend --->\n");
|
|
||||||
if (pdev) {
|
if (pdev) {
|
||||||
cardp = (pcie_service_card *)pci_get_drvdata(pdev);
|
cardp = (pcie_service_card *)pci_get_drvdata(pdev);
|
||||||
if (!cardp || !cardp->handle) {
|
if (!cardp || !cardp->handle) {
|
||||||
|
@ -519,6 +519,10 @@ static int woal_pcie_suspend(struct pci_dev *pdev, pm_message_t state)
|
||||||
}
|
}
|
||||||
|
|
||||||
handle = cardp->handle;
|
handle = cardp->handle;
|
||||||
|
if (handle->second_mac)
|
||||||
|
PRINTM(MCMND, "<--- Enter woal_pcie_suspend# --->\n");
|
||||||
|
else
|
||||||
|
PRINTM(MCMND, "<--- Enter woal_pcie_suspend --->\n");
|
||||||
if (handle->is_suspended == MTRUE) {
|
if (handle->is_suspended == MTRUE) {
|
||||||
PRINTM(MWARN, "Device already suspended\n");
|
PRINTM(MWARN, "Device already suspended\n");
|
||||||
LEAVE();
|
LEAVE();
|
||||||
|
@ -533,23 +537,6 @@ static int woal_pcie_suspend(struct pci_dev *pdev, pm_message_t state)
|
||||||
if (handle->priv[i] &&
|
if (handle->priv[i] &&
|
||||||
(GET_BSS_ROLE(handle->priv[i]) == MLAN_BSS_ROLE_STA))
|
(GET_BSS_ROLE(handle->priv[i]) == MLAN_BSS_ROLE_STA))
|
||||||
woal_cancel_scan(handle->priv[i], MOAL_IOCTL_WAIT);
|
woal_cancel_scan(handle->priv[i], MOAL_IOCTL_WAIT);
|
||||||
|
|
||||||
#ifdef PCIE9098
|
|
||||||
if (IS_PCIE9098(handle->card_type)) {
|
|
||||||
if ((cardp->dev->device ==
|
|
||||||
PCIE_DEVICE_ID_NXP_88W9098P_FN0) ||
|
|
||||||
(cardp->dev->device ==
|
|
||||||
PCIE_DEVICE_ID_NXP_88W9098P_FN1)) {
|
|
||||||
if (handle->priv[i] &&
|
|
||||||
handle->priv[i]->media_connected) {
|
|
||||||
PRINTM(MMSG,
|
|
||||||
"Suspend not allowed while connected\n");
|
|
||||||
ret = -EBUSY;
|
|
||||||
goto done;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
handle->suspend_fail = MFALSE;
|
handle->suspend_fail = MFALSE;
|
||||||
memset(&pm_info, 0, sizeof(pm_info));
|
memset(&pm_info, 0, sizeof(pm_info));
|
||||||
|
@ -611,6 +598,8 @@ static int woal_pcie_suspend(struct pci_dev *pdev, pm_message_t state)
|
||||||
#endif /* IMX_SUPPORT */
|
#endif /* IMX_SUPPORT */
|
||||||
pci_enable_wake(pdev, pci_choose_state(pdev, state), 1);
|
pci_enable_wake(pdev, pci_choose_state(pdev, state), 1);
|
||||||
pci_save_state(pdev);
|
pci_save_state(pdev);
|
||||||
|
ref_handle = (moal_handle *)handle->pref_mac;
|
||||||
|
if (ref_handle && ref_handle->is_suspended)
|
||||||
pci_set_power_state(pdev, pci_choose_state(pdev, state));
|
pci_set_power_state(pdev, pci_choose_state(pdev, state));
|
||||||
done:
|
done:
|
||||||
PRINTM(MCMND, "<--- Leave woal_pcie_suspend --->\n");
|
PRINTM(MCMND, "<--- Leave woal_pcie_suspend --->\n");
|
||||||
|
@ -633,8 +622,6 @@ static int woal_pcie_resume(struct pci_dev *pdev)
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
ENTER();
|
ENTER();
|
||||||
|
|
||||||
PRINTM(MCMND, "<--- Enter woal_pcie_resume --->\n");
|
|
||||||
if (pdev) {
|
if (pdev) {
|
||||||
cardp = (pcie_service_card *)pci_get_drvdata(pdev);
|
cardp = (pcie_service_card *)pci_get_drvdata(pdev);
|
||||||
if (!cardp || !cardp->handle) {
|
if (!cardp || !cardp->handle) {
|
||||||
|
@ -648,6 +635,10 @@ static int woal_pcie_resume(struct pci_dev *pdev)
|
||||||
return -ENOSYS;
|
return -ENOSYS;
|
||||||
}
|
}
|
||||||
handle = cardp->handle;
|
handle = cardp->handle;
|
||||||
|
if (handle->second_mac)
|
||||||
|
PRINTM(MCMND, "<--- Enter woal_pcie_resume# --->\n");
|
||||||
|
else
|
||||||
|
PRINTM(MCMND, "<--- Enter woal_pcie_resume --->\n");
|
||||||
if (handle->is_suspended == MFALSE) {
|
if (handle->is_suspended == MFALSE) {
|
||||||
PRINTM(MWARN, "Device already resumed\n");
|
PRINTM(MWARN, "Device already resumed\n");
|
||||||
goto done;
|
goto done;
|
||||||
|
@ -1003,9 +994,16 @@ static irqreturn_t woal_pcie_interrupt(int irq, void *dev_id)
|
||||||
}
|
}
|
||||||
PRINTM(MINFO, "*** IN PCIE IRQ ***\n");
|
PRINTM(MINFO, "*** IN PCIE IRQ ***\n");
|
||||||
handle->main_state = MOAL_RECV_INT;
|
handle->main_state = MOAL_RECV_INT;
|
||||||
|
if (handle->second_mac)
|
||||||
|
PRINTM(MINTR, "**\n");
|
||||||
|
else
|
||||||
PRINTM(MINTR, "*\n");
|
PRINTM(MINTR, "*\n");
|
||||||
|
|
||||||
ret = mlan_interrupt(0xffff, handle->pmlan_adapter);
|
ret = mlan_interrupt(0xffff, handle->pmlan_adapter);
|
||||||
|
if (handle->is_suspended) {
|
||||||
|
PRINTM(MINTR, "Receive interrupt in hs_suspended\n");
|
||||||
|
goto exit;
|
||||||
|
}
|
||||||
queue_work(handle->workqueue, &handle->main_work);
|
queue_work(handle->workqueue, &handle->main_work);
|
||||||
|
|
||||||
exit:
|
exit:
|
||||||
|
@ -1056,6 +1054,9 @@ static irqreturn_t woal_pcie_msix_interrupt(int irq, void *dev_id)
|
||||||
}
|
}
|
||||||
PRINTM(MINFO, "*** IN PCIE IRQ ***\n");
|
PRINTM(MINFO, "*** IN PCIE IRQ ***\n");
|
||||||
handle->main_state = MOAL_RECV_INT;
|
handle->main_state = MOAL_RECV_INT;
|
||||||
|
if (handle->second_mac)
|
||||||
|
PRINTM(MINTR, "**\n");
|
||||||
|
else
|
||||||
PRINTM(MINTR, "*\n");
|
PRINTM(MINTR, "*\n");
|
||||||
ret = mlan_interrupt(ctx->msg_id, handle->pmlan_adapter);
|
ret = mlan_interrupt(ctx->msg_id, handle->pmlan_adapter);
|
||||||
queue_work(handle->workqueue, &handle->main_work);
|
queue_work(handle->workqueue, &handle->main_work);
|
||||||
|
|
|
@ -97,13 +97,13 @@ Change log:
|
||||||
#define PCIE9097_A0 0x00
|
#define PCIE9097_A0 0x00
|
||||||
#define PCIE9097_B0 0x01
|
#define PCIE9097_B0 0x01
|
||||||
#define PCIE9097_B1 0x02
|
#define PCIE9097_B1 0x02
|
||||||
#define PCIE9097_DEFAULT_COMBO_FW_NAME "nxp/pcieusb9097_combo.bin"
|
#define PCIE9097_DEFAULT_COMBO_FW_NAME "nxp/pcieusbiw620_combo.bin"
|
||||||
#define PCIEUART9097_DEFAULT_COMBO_FW_NAME "nxp/pcieuart9097_combo.bin"
|
#define PCIEUART9097_DEFAULT_COMBO_FW_NAME "nxp/pcieuartiw620_combo.bin"
|
||||||
#define PCIEUSB9097_DEFAULT_COMBO_FW_NAME "nxp/pcieusb9097_combo.bin"
|
#define PCIEUSB9097_DEFAULT_COMBO_FW_NAME "nxp/pcieusbiw620_combo.bin"
|
||||||
#define PCIEUART9097_COMBO_V1_FW_NAME "nxp/pcieuart9097_combo_v1.bin"
|
#define PCIEUART9097_COMBO_V1_FW_NAME "nxp/pcieuartiw620_combo_v1.bin"
|
||||||
#define PCIEUSB9097_COMBO_V1_FW_NAME "nxp/pcieusb9097_combo_v1.bin"
|
#define PCIEUSB9097_COMBO_V1_FW_NAME "nxp/pcieusbiw620_combo_v1.bin"
|
||||||
#define PCIE9097_DEFAULT_WLAN_FW_NAME "nxp/pcie9097_wlan.bin"
|
#define PCIE9097_DEFAULT_WLAN_FW_NAME "nxp/pcieiw620_wlan.bin"
|
||||||
#define PCIE9097_WLAN_V1_FW_NAME "nxp/pcie9097_wlan_v1.bin"
|
#define PCIE9097_WLAN_V1_FW_NAME "nxp/pcieiw620_wlan_v1.bin"
|
||||||
#endif /* PCIE9097 */
|
#endif /* PCIE9097 */
|
||||||
|
|
||||||
#if defined(PCIE9098) || defined(PCIE9097)
|
#if defined(PCIE9098) || defined(PCIE9097)
|
||||||
|
|
|
@ -276,200 +276,6 @@ Change log:
|
||||||
#define WOAL_FROYO_STOP (WOAL_IOCTL + 30)
|
#define WOAL_FROYO_STOP (WOAL_IOCTL + 30)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/**
|
|
||||||
* iwpriv ioctl handlers
|
|
||||||
*/
|
|
||||||
static const struct iw_priv_args woal_private_args[] = {
|
|
||||||
{WOAL_SETONEINT_GETWORDCHAR, IW_PRIV_TYPE_INT | 1,
|
|
||||||
IW_PRIV_TYPE_CHAR | 128, ""},
|
|
||||||
{WOAL_VERSION, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_CHAR | 128,
|
|
||||||
"version"},
|
|
||||||
{WOAL_VEREXT, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_CHAR | 128, "verext"},
|
|
||||||
{WOAL_SETNONE_GETNONE, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_NONE, ""},
|
|
||||||
{WOAL_WARMRESET, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_NONE, "warmreset"},
|
|
||||||
#ifdef CONFIG_USB_SUSPEND
|
|
||||||
{WOAL_USB_SUSPEND, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_NONE, "usbsuspend"},
|
|
||||||
{WOAL_USB_RESUME, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_NONE, "usbresume"},
|
|
||||||
#endif /* CONFIG_USB_SUSPEND */
|
|
||||||
{WOAL_SETONEINT_GETONEINT, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_INT | 1,
|
|
||||||
""},
|
|
||||||
{WOAL_SET_GET_TXRATE, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_INT | 1,
|
|
||||||
"txratecfg"},
|
|
||||||
{WOAL_SET_GET_REGIONCODE, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_INT | 1,
|
|
||||||
"regioncode"},
|
|
||||||
{WOAL_SET_RADIO, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_INT | 1,
|
|
||||||
"radioctrl"},
|
|
||||||
{WOAL_WMM_ENABLE, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_INT | 1, "wmmcfg"},
|
|
||||||
{WOAL_11D_ENABLE, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_INT | 1, "11dcfg"},
|
|
||||||
{WOAL_11D_CLR_CHAN_TABLE, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_NONE,
|
|
||||||
"11dclrtbl"},
|
|
||||||
{WOAL_SET_GET_QOS_CFG, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_INT | 1,
|
|
||||||
"qoscfg"},
|
|
||||||
#ifndef OPCHAN
|
|
||||||
{WOAL_SET_GET_WWS_CFG, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_INT | 1,
|
|
||||||
"wwscfg"},
|
|
||||||
#endif
|
|
||||||
#if defined(REASSOCIATION)
|
|
||||||
{WOAL_SET_GET_REASSOC, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_INT | 1,
|
|
||||||
"reassoctrl"},
|
|
||||||
#endif
|
|
||||||
{WOAL_TXBUF_CFG, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_INT | 1,
|
|
||||||
"txbufcfg"},
|
|
||||||
{WOAL_SLEEP_PD, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_INT | 1, "sleeppd"},
|
|
||||||
{WOAL_AUTH_TYPE, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_INT | 1,
|
|
||||||
"authtype"},
|
|
||||||
{WOAL_PORT_CTRL, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_INT | 1,
|
|
||||||
"port_ctrl"},
|
|
||||||
#ifdef WIFI_DIRECT_SUPPORT
|
|
||||||
#if defined(STA_SUPPORT) && defined(UAP_SUPPORT)
|
|
||||||
{WOAL_SET_GET_BSS_ROLE, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_INT | 1,
|
|
||||||
"bssrole"},
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
{WOAL_SET_GET_11H_LOCAL_PWR_CONSTRAINT, IW_PRIV_TYPE_INT | 1,
|
|
||||||
IW_PRIV_TYPE_INT | 1, "powercons"},
|
|
||||||
{WOAL_HT_STREAM_CFG, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_INT | 1,
|
|
||||||
"htstreamcfg"},
|
|
||||||
{WOAL_MAC_CONTROL, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_INT | 1,
|
|
||||||
"macctrl"},
|
|
||||||
{WOAL_THERMAL, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_INT | 1, "thermal"},
|
|
||||||
{WOAL_CFG_HOTSPOT, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_INT | 1,
|
|
||||||
"hotspotcfg"},
|
|
||||||
{WOAL_SET_GET_SIXTEEN_INT, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
|
||||||
""},
|
|
||||||
{WOAL_TX_POWERCFG, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
|
||||||
"txpowercfg"},
|
|
||||||
#ifdef DEBUG_LEVEL1
|
|
||||||
{WOAL_DRV_DBG, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16, "drvdbg"},
|
|
||||||
#endif
|
|
||||||
{WOAL_BEACON_INTERVAL, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
|
||||||
"bcninterval"},
|
|
||||||
{WOAL_SIGNAL, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
|
||||||
"getsignal"},
|
|
||||||
{
|
|
||||||
WOAL_DEEP_SLEEP,
|
|
||||||
IW_PRIV_TYPE_INT | 16,
|
|
||||||
IW_PRIV_TYPE_INT | 16,
|
|
||||||
"deepsleep",
|
|
||||||
},
|
|
||||||
{WOAL_11N_TX_CFG, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
|
||||||
"httxcfg"},
|
|
||||||
{WOAL_11N_HTCAP_CFG, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
|
||||||
"htcapinfo"},
|
|
||||||
{WOAL_PRIO_TBL, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
|
||||||
"aggrpriotbl"},
|
|
||||||
{WOAL_11N_AMSDU_AGGR_CTRL, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
|
||||||
"amsduaggrctrl"},
|
|
||||||
{WOAL_ADDBA_UPDT, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
|
||||||
"addbapara"},
|
|
||||||
{WOAL_ADDBA_REJECT, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
|
||||||
"addbareject"},
|
|
||||||
{WOAL_TX_BF_CAP, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
|
||||||
"httxbfcap"},
|
|
||||||
{WOAL_HS_CFG, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16, "hscfg"},
|
|
||||||
{WOAL_HS_SETPARA, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
|
||||||
"hssetpara"},
|
|
||||||
{WOAL_REG_READ_WRITE, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
|
||||||
"regrdwr"},
|
|
||||||
{WOAL_BAND_CFG, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
|
||||||
"bandcfg"},
|
|
||||||
{WOAL_INACTIVITY_TIMEOUT_EXT, IW_PRIV_TYPE_INT | 16,
|
|
||||||
IW_PRIV_TYPE_INT | 16, "inactivityto"},
|
|
||||||
#ifdef SDIO
|
|
||||||
{WOAL_SDIO_CLOCK, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
|
||||||
"sdioclock"},
|
|
||||||
{WOAL_CMD_52RDWR, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
|
||||||
"sdcmd52rw"},
|
|
||||||
#endif
|
|
||||||
{WOAL_SCAN_CFG, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
|
||||||
"scancfg"},
|
|
||||||
{WOAL_PS_CFG, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16, "pscfg"},
|
|
||||||
{WOAL_MEM_READ_WRITE, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
|
||||||
"memrdwr"},
|
|
||||||
#ifdef SDIO
|
|
||||||
{WOAL_SDIO_MPA_CTRL, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
|
||||||
"mpactrl"},
|
|
||||||
#endif
|
|
||||||
{WOAL_SLEEP_PARAMS, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
|
||||||
"sleepparams"},
|
|
||||||
{WOAL_DFS_TESTING, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
|
||||||
"dfstesting"},
|
|
||||||
{WOAL_MGMT_FRAME_CTRL, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
|
||||||
"mgmtframectrl"},
|
|
||||||
{WOAL_CFP_CODE, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
|
||||||
"cfpcode"},
|
|
||||||
{WOAL_SET_GET_TX_RX_ANT, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
|
||||||
"antcfg"},
|
|
||||||
{WOAL_IND_RST_CFG, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
|
||||||
"indrstcfg"},
|
|
||||||
{WOALGETLOG, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_CHAR | GETLOG_BUFSIZE,
|
|
||||||
"getlog"},
|
|
||||||
{WOAL_SETADDR_GETNONE, IW_PRIV_TYPE_ADDR | 1, IW_PRIV_TYPE_NONE, ""},
|
|
||||||
{WOAL_DEAUTH, IW_PRIV_TYPE_ADDR | 1, IW_PRIV_TYPE_NONE, "deauth"},
|
|
||||||
{WOAL_SET_GET_256_CHAR, IW_PRIV_TYPE_CHAR | 256,
|
|
||||||
IW_PRIV_TYPE_CHAR | 256, ""},
|
|
||||||
{WOAL_PASSPHRASE, IW_PRIV_TYPE_CHAR | 256, IW_PRIV_TYPE_CHAR | 256,
|
|
||||||
"passphrase"},
|
|
||||||
{WOAL_GET_KEY, IW_PRIV_TYPE_CHAR | 256, IW_PRIV_TYPE_CHAR | 256,
|
|
||||||
"getkey"},
|
|
||||||
{WOAL_ASSOCIATE, IW_PRIV_TYPE_CHAR | 256, IW_PRIV_TYPE_CHAR | 256,
|
|
||||||
"associate"},
|
|
||||||
{WOAL_WMM_QUEUE_STATUS, IW_PRIV_TYPE_CHAR | 256,
|
|
||||||
IW_PRIV_TYPE_CHAR | 256, "qstatus"},
|
|
||||||
{WOAL_WMM_TS_STATUS, IW_PRIV_TYPE_CHAR | 256, IW_PRIV_TYPE_CHAR | 256,
|
|
||||||
"ts_status"},
|
|
||||||
{WOAL_IP_ADDRESS, IW_PRIV_TYPE_CHAR | 256, IW_PRIV_TYPE_CHAR | 256,
|
|
||||||
"ipaddr"},
|
|
||||||
{WOAL_TX_BF_CFG, IW_PRIV_TYPE_CHAR | 256, IW_PRIV_TYPE_CHAR | 256,
|
|
||||||
"httxbfcfg"},
|
|
||||||
{WOAL_SETNONE_GETTWELVE_CHAR, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_CHAR | 12,
|
|
||||||
""},
|
|
||||||
{WOAL_WPS_SESSION, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_CHAR | 12,
|
|
||||||
"wpssession"},
|
|
||||||
{WOAL_SETNONE_GET_FOUR_INT, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_INT | 4,
|
|
||||||
""},
|
|
||||||
{WOAL_DATA_RATE, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_INT | 4,
|
|
||||||
"getdatarate"},
|
|
||||||
{WOAL_ESUPP_MODE, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_INT | 4, "esuppmode"},
|
|
||||||
{WOAL_SET_GET_64_INT, IW_PRIV_TYPE_INT | 64, IW_PRIV_TYPE_INT | 64, ""},
|
|
||||||
{WOAL_ECL_SYS_CLOCK, IW_PRIV_TYPE_INT | 64, IW_PRIV_TYPE_INT | 64,
|
|
||||||
"sysclock"},
|
|
||||||
{WOAL_HOST_CMD, IW_PRIV_TYPE_BYTE | 2047, IW_PRIV_TYPE_BYTE | 2047,
|
|
||||||
"hostcmd"},
|
|
||||||
{WOAL_SET_INTS_GET_CHARS, IW_PRIV_TYPE_INT | 16,
|
|
||||||
IW_PRIV_TYPE_BYTE | 256, ""},
|
|
||||||
{WOAL_READ_EEPROM, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_BYTE | 256,
|
|
||||||
"rdeeprom"},
|
|
||||||
{WOAL_SET_GET_2K_BYTES, IW_PRIV_TYPE_BYTE | WOAL_2K_BYTES,
|
|
||||||
IW_PRIV_TYPE_BYTE | WOAL_2K_BYTES, ""},
|
|
||||||
#if defined(SDIO)
|
|
||||||
{WOAL_CMD_53RDWR, IW_PRIV_TYPE_BYTE | WOAL_2K_BYTES,
|
|
||||||
IW_PRIV_TYPE_BYTE | WOAL_2K_BYTES, "sdcmd53rw"},
|
|
||||||
#endif
|
|
||||||
{WOAL_SET_USER_SCAN, IW_PRIV_TYPE_BYTE | WOAL_2K_BYTES,
|
|
||||||
IW_PRIV_TYPE_BYTE | WOAL_2K_BYTES, "setuserscan"},
|
|
||||||
{WOAL_GET_SCAN_TABLE, IW_PRIV_TYPE_BYTE | WOAL_2K_BYTES,
|
|
||||||
IW_PRIV_TYPE_BYTE | WOAL_2K_BYTES, "getscantable"},
|
|
||||||
{WOAL_SET_USER_SCAN_EXT, IW_PRIV_TYPE_BYTE | WOAL_2K_BYTES,
|
|
||||||
IW_PRIV_TYPE_BYTE | WOAL_2K_BYTES, "setuserscanext"},
|
|
||||||
{WOAL_WMM_ADDTS, IW_PRIV_TYPE_BYTE | WOAL_2K_BYTES,
|
|
||||||
IW_PRIV_TYPE_BYTE | WOAL_2K_BYTES, "addts"},
|
|
||||||
{WOAL_WMM_DELTS, IW_PRIV_TYPE_BYTE | WOAL_2K_BYTES,
|
|
||||||
IW_PRIV_TYPE_BYTE | WOAL_2K_BYTES, "delts"},
|
|
||||||
{WOAL_WMM_QUEUE_CONFIG, IW_PRIV_TYPE_BYTE | WOAL_2K_BYTES,
|
|
||||||
IW_PRIV_TYPE_BYTE | WOAL_2K_BYTES, "qconfig"},
|
|
||||||
{WOAL_WMM_QUEUE_STATS, IW_PRIV_TYPE_BYTE | WOAL_2K_BYTES,
|
|
||||||
IW_PRIV_TYPE_BYTE | WOAL_2K_BYTES, "qstats"},
|
|
||||||
{WOAL_BYPASSED_PACKET, IW_PRIV_TYPE_BYTE | WOAL_2K_BYTES,
|
|
||||||
IW_PRIV_TYPE_BYTE | WOAL_2K_BYTES, "pb_bypass"},
|
|
||||||
#ifdef UAP_WEXT
|
|
||||||
{WOAL_FROYO_START, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_NONE, "START"},
|
|
||||||
{WOAL_FROYO_STOP, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_NONE, "STOP"},
|
|
||||||
{WOAL_FROYO_WL_FW_RELOAD, IW_PRIV_TYPE_CHAR | 256,
|
|
||||||
IW_PRIV_TYPE_CHAR | 256, "WL_FW_RELOAD"},
|
|
||||||
#endif
|
|
||||||
};
|
|
||||||
|
|
||||||
/** moal_802_11_rates */
|
/** moal_802_11_rates */
|
||||||
typedef struct _moal_802_11_rates {
|
typedef struct _moal_802_11_rates {
|
||||||
/** Num of rates */
|
/** Num of rates */
|
||||||
|
|
|
@ -512,6 +512,8 @@ 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");
|
||||||
|
handle->driver_status = MTRUE;
|
||||||
ref_handle = (moal_handle *)handle->pref_mac;
|
ref_handle = (moal_handle *)handle->pref_mac;
|
||||||
if (ref_handle) {
|
if (ref_handle) {
|
||||||
priv = woal_get_priv(ref_handle, MLAN_BSS_ROLE_ANY);
|
priv = woal_get_priv(ref_handle, MLAN_BSS_ROLE_ANY);
|
||||||
|
@ -525,7 +527,6 @@ static ssize_t woal_config_write(struct file *f, const char __user *buf,
|
||||||
}
|
}
|
||||||
priv = woal_get_priv(handle, MLAN_BSS_ROLE_ANY);
|
priv = woal_get_priv(handle, MLAN_BSS_ROLE_ANY);
|
||||||
if (priv) {
|
if (priv) {
|
||||||
PRINTM(MERROR, "Recevie debug_dump command\n");
|
|
||||||
#ifdef DEBUG_LEVEL1
|
#ifdef DEBUG_LEVEL1
|
||||||
drvdbg &= ~MFW_D;
|
drvdbg &= ~MFW_D;
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -108,10 +108,10 @@ Change log:
|
||||||
#endif /* SD8897 */
|
#endif /* SD8897 */
|
||||||
|
|
||||||
#ifdef SD8978
|
#ifdef SD8978
|
||||||
#define SD8978_DEFAULT_COMBO_FW_NAME "nxp/sdsd8978_combo.bin"
|
#define SD8978_DEFAULT_COMBO_FW_NAME "nxp/sdsdiw416_combo.bin"
|
||||||
#define SDUART8978_DEFAULT_COMBO_FW_NAME "nxp/sduart8978_combo.bin"
|
#define SDUART8978_DEFAULT_COMBO_FW_NAME "nxp/sduartiw416_combo.bin"
|
||||||
#define SDSD8978_DEFAULT_COMBO_FW_NAME "nxp/sdsd8978_combo.bin"
|
#define SDSD8978_DEFAULT_COMBO_FW_NAME "nxp/sdsdiw416_combo.bin"
|
||||||
#define SD8978_DEFAULT_WLAN_FW_NAME "nxp/sd8978_wlan.bin"
|
#define SD8978_DEFAULT_WLAN_FW_NAME "nxp/sdiw416_wlan.bin"
|
||||||
#endif /* SD8978 */
|
#endif /* SD8978 */
|
||||||
|
|
||||||
#ifdef SD9098
|
#ifdef SD9098
|
||||||
|
@ -131,20 +131,20 @@ Change log:
|
||||||
#ifdef SD9097
|
#ifdef SD9097
|
||||||
#define SD9097_B0 0x01
|
#define SD9097_B0 0x01
|
||||||
#define SD9097_B1 0x02
|
#define SD9097_B1 0x02
|
||||||
#define SD9097_DEFAULT_COMBO_FW_NAME "nxp/sdsd9097_combo_v1.bin"
|
#define SD9097_DEFAULT_COMBO_FW_NAME "nxp/sdsdiw620_combo_v1.bin"
|
||||||
|
|
||||||
#define SD9097_DEFAULT_WLAN_FW_NAME "nxp/sd9097_wlan_v1.bin"
|
#define SD9097_DEFAULT_WLAN_FW_NAME "nxp/sdiw620_wlan_v1.bin"
|
||||||
#define SDUART9097_COMBO_V1_FW_NAME "nxp/sduart9097_combo_v1.bin"
|
#define SDUART9097_COMBO_V1_FW_NAME "nxp/sduartiw620_combo_v1.bin"
|
||||||
#define SDSD9097_COMBO_V1_FW_NAME "nxp/sdsd9097_combo_v1.bin"
|
#define SDSD9097_COMBO_V1_FW_NAME "nxp/sdsdiw620_combo_v1.bin"
|
||||||
#define SD9097_WLAN_V1_FW_NAME "nxp/sd9097_wlan_v1.bin"
|
#define SD9097_WLAN_V1_FW_NAME "nxp/sdiw620_wlan_v1.bin"
|
||||||
#endif /* SD9097 */
|
#endif /* SD9097 */
|
||||||
|
|
||||||
#ifdef SD9177
|
#ifdef SD9177
|
||||||
#define SD9177_A0 0x01
|
#define SD9177_A0 0x01
|
||||||
#define SD9177_DEFAULT_COMBO_FW_NAME "nxp/sdsd9177_combo.bin"
|
#define SD9177_DEFAULT_COMBO_FW_NAME "nxp/sdsd_nw61x.bin"
|
||||||
#define SDUART9177_DEFAULT_COMBO_FW_NAME "nxp/sduart9177_combo.bin"
|
#define SDUART9177_DEFAULT_COMBO_FW_NAME "nxp/sduart_nw61x.bin"
|
||||||
#define SDSD9177_DEFAULT_COMBO_FW_NAME "nxp/sdsd9177_combo.bin"
|
#define SDSD9177_DEFAULT_COMBO_FW_NAME "sdsd_nw61x.bin"
|
||||||
#define SD9177_DEFAULT_WLAN_FW_NAME "nxp/sd9177_wlan.bin"
|
#define SD9177_DEFAULT_WLAN_FW_NAME "nxp/sd_w61x.bin"
|
||||||
/** Device ID for SD9177 */
|
/** Device ID for SD9177 */
|
||||||
#define SD_DEVICE_ID_9177 (0x0205)
|
#define SD_DEVICE_ID_9177 (0x0205)
|
||||||
#endif /* SD9177 */
|
#endif /* SD9177 */
|
||||||
|
@ -180,6 +180,7 @@ struct sdio_mmc_card {
|
||||||
/** saved host clock value */
|
/** saved host clock value */
|
||||||
unsigned int host_clock;
|
unsigned int host_clock;
|
||||||
};
|
};
|
||||||
|
void woal_sdio_reset_hw(moal_handle *handle);
|
||||||
#endif /* SDIO_MMC */
|
#endif /* SDIO_MMC */
|
||||||
|
|
||||||
/** cmd52 read write */
|
/** cmd52 read write */
|
||||||
|
|
|
@ -342,8 +342,8 @@ static t_u16 woal_update_card_type(t_void *card)
|
||||||
#ifdef SD8978
|
#ifdef SD8978
|
||||||
if (cardp_sd->func->device == SD_DEVICE_ID_8978) {
|
if (cardp_sd->func->device == SD_DEVICE_ID_8978) {
|
||||||
card_type = CARD_TYPE_SD8978;
|
card_type = CARD_TYPE_SD8978;
|
||||||
moal_memcpy_ext(NULL, driver_version, CARD_SD8978,
|
moal_memcpy_ext(NULL, driver_version, "SDIW416",
|
||||||
strlen(CARD_SD8978), strlen(driver_version));
|
strlen("SDIW416"), strlen(driver_version));
|
||||||
moal_memcpy_ext(
|
moal_memcpy_ext(
|
||||||
NULL,
|
NULL,
|
||||||
driver_version + strlen(INTF_CARDTYPE) +
|
driver_version + strlen(INTF_CARDTYPE) +
|
||||||
|
@ -419,7 +419,7 @@ static t_u16 woal_update_card_type(t_void *card)
|
||||||
NULL,
|
NULL,
|
||||||
driver_version + strlen(INTF_CARDTYPE) +
|
driver_version + strlen(INTF_CARDTYPE) +
|
||||||
strlen(KERN_VERSION),
|
strlen(KERN_VERSION),
|
||||||
V17, strlen(V17),
|
V18, strlen(V18),
|
||||||
strlen(driver_version) -
|
strlen(driver_version) -
|
||||||
(strlen(INTF_CARDTYPE) + strlen(KERN_VERSION)));
|
(strlen(INTF_CARDTYPE) + strlen(KERN_VERSION)));
|
||||||
}
|
}
|
||||||
|
@ -494,6 +494,10 @@ int woal_sdio_probe(struct sdio_func *func, const struct sdio_device_id *id)
|
||||||
goto err;
|
goto err;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef IMX_SUPPORT
|
||||||
|
woal_regist_oob_wakeup_irq(card->handle);
|
||||||
|
#endif /* IMX_SUPPORT */
|
||||||
|
|
||||||
LEAVE();
|
LEAVE();
|
||||||
return ret;
|
return ret;
|
||||||
err:
|
err:
|
||||||
|
@ -521,6 +525,9 @@ void woal_sdio_remove(struct sdio_func *func)
|
||||||
PRINTM(MINFO, "SDIO func=%d\n", func->num);
|
PRINTM(MINFO, "SDIO func=%d\n", func->num);
|
||||||
card = sdio_get_drvdata(func);
|
card = sdio_get_drvdata(func);
|
||||||
if (card) {
|
if (card) {
|
||||||
|
#ifdef IMX_SUPPORT
|
||||||
|
woal_unregist_oob_wakeup_irq(card->handle);
|
||||||
|
#endif /* IMX_SUPPORT */
|
||||||
woal_remove_card(card);
|
woal_remove_card(card);
|
||||||
kfree(card);
|
kfree(card);
|
||||||
}
|
}
|
||||||
|
@ -717,6 +724,15 @@ int woal_sdio_suspend(struct device *dev)
|
||||||
handle->suspend_notify_req = MFALSE;
|
handle->suspend_notify_req = MFALSE;
|
||||||
#endif
|
#endif
|
||||||
if (hs_actived) {
|
if (hs_actived) {
|
||||||
|
#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 3, 4)
|
||||||
|
if (pm_flags & MMC_PM_WAKE_SDIO_IRQ) {
|
||||||
|
ret = sdio_set_host_pm_flags(
|
||||||
|
func, MMC_PM_WAKE_SDIO_IRQ);
|
||||||
|
PRINTM(MCMND,
|
||||||
|
"suspend with MMC_PM_WAKE_SDIO_IRQ ret=%d\n",
|
||||||
|
ret);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
#ifdef MMC_PM_SKIP_RESUME_PROBE
|
#ifdef MMC_PM_SKIP_RESUME_PROBE
|
||||||
PRINTM(MCMND,
|
PRINTM(MCMND,
|
||||||
"suspend with MMC_PM_KEEP_POWER and MMC_PM_SKIP_RESUME_PROBE\n");
|
"suspend with MMC_PM_KEEP_POWER and MMC_PM_SKIP_RESUME_PROBE\n");
|
||||||
|
@ -739,6 +755,9 @@ int woal_sdio_suspend(struct device *dev)
|
||||||
|
|
||||||
/* Indicate device suspended */
|
/* Indicate device suspended */
|
||||||
handle->is_suspended = MTRUE;
|
handle->is_suspended = MTRUE;
|
||||||
|
#ifdef IMX_SUPPORT
|
||||||
|
woal_enable_oob_wakeup_irq(handle);
|
||||||
|
#endif /* IMX_SUPPORT */
|
||||||
done:
|
done:
|
||||||
PRINTM(MCMND, "<--- Leave woal_sdio_suspend --->\n");
|
PRINTM(MCMND, "<--- Leave woal_sdio_suspend --->\n");
|
||||||
LEAVE();
|
LEAVE();
|
||||||
|
@ -787,6 +806,9 @@ int woal_sdio_resume(struct device *dev)
|
||||||
|
|
||||||
/* Disable Host Sleep */
|
/* Disable Host Sleep */
|
||||||
woal_cancel_hs(woal_get_priv(handle, MLAN_BSS_ROLE_ANY), MOAL_NO_WAIT);
|
woal_cancel_hs(woal_get_priv(handle, MLAN_BSS_ROLE_ANY), MOAL_NO_WAIT);
|
||||||
|
#ifdef IMX_SUPPORT
|
||||||
|
woal_disable_oob_wakeup_irq(handle);
|
||||||
|
#endif /* IMX_SUPPORT */
|
||||||
PRINTM(MCMND, "<--- Leave woal_sdio_resume --->\n");
|
PRINTM(MCMND, "<--- Leave woal_sdio_resume --->\n");
|
||||||
LEAVE();
|
LEAVE();
|
||||||
return MLAN_STATUS_SUCCESS;
|
return MLAN_STATUS_SUCCESS;
|
||||||
|
@ -1131,10 +1153,14 @@ static void woal_sdiommc_unregister_dev(moal_handle *handle)
|
||||||
ENTER();
|
ENTER();
|
||||||
if (handle->card) {
|
if (handle->card) {
|
||||||
struct sdio_mmc_card *card = handle->card;
|
struct sdio_mmc_card *card = handle->card;
|
||||||
|
struct sdio_func *func = card->func;
|
||||||
|
|
||||||
/* Release the SDIO IRQ */
|
/* Release the SDIO IRQ */
|
||||||
sdio_claim_host(card->func);
|
sdio_claim_host(card->func);
|
||||||
sdio_release_irq(card->func);
|
sdio_release_irq(card->func);
|
||||||
sdio_disable_func(card->func);
|
sdio_disable_func(card->func);
|
||||||
|
if (handle->driver_status)
|
||||||
|
mmc_hw_reset(func->card->host);
|
||||||
sdio_release_host(card->func);
|
sdio_release_host(card->func);
|
||||||
|
|
||||||
sdio_set_drvdata(card->func, NULL);
|
sdio_set_drvdata(card->func, NULL);
|
||||||
|
@ -1570,11 +1596,23 @@ static rdwr_status woal_cmd52_rdwr_firmware(moal_handle *phandle, t_u8 doneflag)
|
||||||
t_u8 dbg_dump_ctrl_reg = phandle->card_info->dump_fw_ctrl_reg;
|
t_u8 dbg_dump_ctrl_reg = phandle->card_info->dump_fw_ctrl_reg;
|
||||||
t_u8 debug_host_ready = phandle->card_info->dump_fw_host_ready;
|
t_u8 debug_host_ready = phandle->card_info->dump_fw_host_ready;
|
||||||
|
|
||||||
|
#ifdef SD9177
|
||||||
|
if (IS_SD9177(phandle->card_type)) {
|
||||||
|
if (phandle->event_fw_dump)
|
||||||
|
debug_host_ready = 0xAA;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
ret = woal_sdio_writeb(phandle, dbg_dump_ctrl_reg, debug_host_ready);
|
ret = woal_sdio_writeb(phandle, dbg_dump_ctrl_reg, debug_host_ready);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
PRINTM(MERROR, "SDIO Write ERR\n");
|
PRINTM(MERROR, "SDIO Write ERR\n");
|
||||||
return RDWR_STATUS_FAILURE;
|
return RDWR_STATUS_FAILURE;
|
||||||
}
|
}
|
||||||
|
#ifdef SD9177
|
||||||
|
if (IS_SD9177(phandle->card_type)) {
|
||||||
|
if (phandle->event_fw_dump)
|
||||||
|
return RDWR_STATUS_SUCCESS;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
for (tries = 0; tries < MAX_POLL_TRIES; tries++) {
|
for (tries = 0; tries < MAX_POLL_TRIES; tries++) {
|
||||||
ret = woal_sdio_readb(phandle, dbg_dump_ctrl_reg, &ctrl_data);
|
ret = woal_sdio_readb(phandle, dbg_dump_ctrl_reg, &ctrl_data);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
|
@ -2039,6 +2077,18 @@ void woal_dump_firmware_info_v3(moal_handle *phandle)
|
||||||
PRINTM(MERROR, "Could not dump firmwware info\n");
|
PRINTM(MERROR, "Could not dump firmwware info\n");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
#ifdef SD9177
|
||||||
|
if (IS_SD9177(phandle->card_type)) {
|
||||||
|
if (phandle->event_fw_dump) {
|
||||||
|
if (RDWR_STATUS_FAILURE !=
|
||||||
|
woal_cmd52_rdwr_firmware(phandle, doneflag)) {
|
||||||
|
PRINTM(MMSG,
|
||||||
|
"====SDIO FW DUMP EVENT MODE START ====\n");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
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;
|
||||||
|
@ -2276,6 +2326,11 @@ static void woal_sdiommc_dump_fw_info(moal_handle *phandle)
|
||||||
woal_dump_firmware_info_v2(phandle);
|
woal_dump_firmware_info_v2(phandle);
|
||||||
} else if (phandle->card_info->dump_fw_info == DUMP_FW_SDIO_V3) {
|
} else if (phandle->card_info->dump_fw_info == DUMP_FW_SDIO_V3) {
|
||||||
woal_dump_firmware_info_v3(phandle);
|
woal_dump_firmware_info_v3(phandle);
|
||||||
|
if (phandle->event_fw_dump) {
|
||||||
|
phandle->event_fw_dump = MFALSE;
|
||||||
|
queue_work(phandle->workqueue, &phandle->main_work);
|
||||||
|
return;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
#ifdef SD8801
|
#ifdef SD8801
|
||||||
else {
|
else {
|
||||||
|
@ -2385,6 +2440,45 @@ static int woal_sdiommc_dump_reg_info(moal_handle *phandle, t_u8 *drv_buf)
|
||||||
return drv_ptr - (char *)drv_buf;
|
return drv_ptr - (char *)drv_buf;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief This function reset sdio through sdio bus driver
|
||||||
|
*
|
||||||
|
* @param phandle A pointer to moal_handle
|
||||||
|
*
|
||||||
|
* @return N/A
|
||||||
|
*/
|
||||||
|
void woal_sdio_reset_hw(moal_handle *handle)
|
||||||
|
{
|
||||||
|
struct sdio_mmc_card *card = handle->card;
|
||||||
|
struct sdio_func *func = card->func;
|
||||||
|
ENTER();
|
||||||
|
sdio_claim_host(func);
|
||||||
|
sdio_release_irq(card->func);
|
||||||
|
sdio_disable_func(card->func);
|
||||||
|
mmc_hw_reset(func->card->host);
|
||||||
|
#ifdef MMC_QUIRK_BLKSZ_FOR_BYTE_MODE
|
||||||
|
/* The byte mode patch is available in kernel MMC driver
|
||||||
|
* which fixes one issue in MP-A transfer.
|
||||||
|
* bit1: use func->cur_blksize for byte mode
|
||||||
|
*/
|
||||||
|
func->card->quirks |= MMC_QUIRK_BLKSZ_FOR_BYTE_MODE;
|
||||||
|
#endif
|
||||||
|
#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0)
|
||||||
|
func->card->quirks |= MMC_QUIRK_LENIENT_FN0;
|
||||||
|
#endif
|
||||||
|
#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 27)
|
||||||
|
/* wait for chip fully wake up */
|
||||||
|
if (!func->enable_timeout)
|
||||||
|
func->enable_timeout = 200;
|
||||||
|
#endif
|
||||||
|
sdio_enable_func(func);
|
||||||
|
sdio_claim_irq(func, woal_sdio_interrupt);
|
||||||
|
sdio_set_block_size(card->func, MLAN_SDIO_BLOCK_SIZE);
|
||||||
|
sdio_release_host(func);
|
||||||
|
LEAVE();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
static moal_if_ops sdiommc_ops = {
|
static moal_if_ops sdiommc_ops = {
|
||||||
.register_dev = woal_sdiommc_register_dev,
|
.register_dev = woal_sdiommc_register_dev,
|
||||||
.unregister_dev = woal_sdiommc_unregister_dev,
|
.unregister_dev = woal_sdiommc_unregister_dev,
|
||||||
|
|
|
@ -201,19 +201,21 @@ mlan_status moal_malloc_consistent(t_void *pmoal, t_u32 size, t_u8 **ppbuf,
|
||||||
{
|
{
|
||||||
moal_handle *handle = (moal_handle *)pmoal;
|
moal_handle *handle = (moal_handle *)pmoal;
|
||||||
pcie_service_card *card = (pcie_service_card *)handle->card;
|
pcie_service_card *card = (pcie_service_card *)handle->card;
|
||||||
|
dma_addr_t dma;
|
||||||
*pbuf_pa = 0;
|
*pbuf_pa = 0;
|
||||||
|
|
||||||
if (!card)
|
if (!card)
|
||||||
return MLAN_STATUS_FAILURE;
|
return MLAN_STATUS_FAILURE;
|
||||||
|
|
||||||
*ppbuf = (t_u8 *)pci_alloc_consistent(card->dev, size,
|
*ppbuf = (t_u8 *)pci_alloc_consistent(card->dev, size,
|
||||||
(dma_addr_t *)pbuf_pa);
|
(dma_addr_t *)&dma);
|
||||||
if (*ppbuf == NULL) {
|
if (*ppbuf == NULL) {
|
||||||
PRINTM(MERROR,
|
PRINTM(MERROR,
|
||||||
"%s: allocate consistent memory (%d bytes) failed!\n",
|
"%s: allocate consistent memory (%d bytes) failed!\n",
|
||||||
__func__, (int)size);
|
__func__, (int)size);
|
||||||
return MLAN_STATUS_FAILURE;
|
return MLAN_STATUS_FAILURE;
|
||||||
}
|
}
|
||||||
|
*pbuf_pa = (t_u64)dma;
|
||||||
atomic_inc(&handle->malloc_cons_count);
|
atomic_inc(&handle->malloc_cons_count);
|
||||||
|
|
||||||
return MLAN_STATUS_SUCCESS;
|
return MLAN_STATUS_SUCCESS;
|
||||||
|
@ -1644,6 +1646,8 @@ static void moal_connection_status_check_pmqos(t_void *pmoal)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if defined(STA_CFG80211) || defined(UAP_CFG80211)
|
||||||
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 11, 0)
|
||||||
/**
|
/**
|
||||||
* @brief Handle RX MGMT PKT event
|
* @brief Handle RX MGMT PKT event
|
||||||
*
|
*
|
||||||
|
@ -1673,6 +1677,8 @@ static void woal_rx_mgmt_pkt_event(moal_private *priv, t_u8 *pkt, t_u16 len)
|
||||||
queue_work(handle->evt_workqueue, &handle->evt_work);
|
queue_work(handle->evt_workqueue, &handle->evt_work);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief This function handles event receive
|
* @brief This function handles event receive
|
||||||
|
|
|
@ -418,6 +418,8 @@ static const struct ieee80211_regdomain mrvl_regdom = {
|
||||||
/* IEEE 802.11a, channel 100..165 */
|
/* IEEE 802.11a, channel 100..165 */
|
||||||
REG_RULE(5470 - 10, 5850 + 10, 80, 6, 20, 0),
|
REG_RULE(5470 - 10, 5850 + 10, 80, 6, 20, 0),
|
||||||
}};
|
}};
|
||||||
|
|
||||||
|
#define AUTH_TX_DEFAULT_WAIT_TIME 2400
|
||||||
/********************************************************
|
/********************************************************
|
||||||
Local Variables
|
Local Variables
|
||||||
********************************************************/
|
********************************************************/
|
||||||
|
@ -1062,14 +1064,7 @@ static mlan_status woal_send_domain_info_cmd_fw(moal_private *priv,
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (MTRUE ==
|
PRINTM(MCMD_D, "Send domain info: country=%c%c band=%d\n",
|
||||||
is_cfg80211_special_region_code(priv->phandle->country_code)) {
|
|
||||||
PRINTM(MIOCTL,
|
|
||||||
"skip region code config, cfg80211 special region code: %s\n",
|
|
||||||
priv->phandle->country_code);
|
|
||||||
goto done;
|
|
||||||
}
|
|
||||||
PRINTM(MIOCTL, "Send domain info: country=%c%c band=%d\n",
|
|
||||||
priv->phandle->country_code[0], priv->phandle->country_code[1],
|
priv->phandle->country_code[0], priv->phandle->country_code[1],
|
||||||
band);
|
band);
|
||||||
/* Allocate an IOCTL request buffer */
|
/* Allocate an IOCTL request buffer */
|
||||||
|
@ -1083,11 +1078,17 @@ static mlan_status woal_send_domain_info_cmd_fw(moal_private *priv,
|
||||||
req->req_id = MLAN_IOCTL_11D_CFG;
|
req->req_id = MLAN_IOCTL_11D_CFG;
|
||||||
req->action = MLAN_ACT_SET;
|
req->action = MLAN_ACT_SET;
|
||||||
|
|
||||||
|
if (is_cfg80211_special_region_code(priv->phandle->country_code)) {
|
||||||
|
/* Set country code */
|
||||||
|
cfg_11d->param.domain_info.country_code[0] = 'W';
|
||||||
|
cfg_11d->param.domain_info.country_code[1] = 'W';
|
||||||
|
} else {
|
||||||
/* Set country code */
|
/* Set country code */
|
||||||
cfg_11d->param.domain_info.country_code[0] =
|
cfg_11d->param.domain_info.country_code[0] =
|
||||||
priv->phandle->country_code[0];
|
priv->phandle->country_code[0];
|
||||||
cfg_11d->param.domain_info.country_code[1] =
|
cfg_11d->param.domain_info.country_code[1] =
|
||||||
priv->phandle->country_code[1];
|
priv->phandle->country_code[1];
|
||||||
|
}
|
||||||
cfg_11d->param.domain_info.country_code[2] = ' ';
|
cfg_11d->param.domain_info.country_code[2] = ' ';
|
||||||
cfg_11d->param.domain_info.band = band;
|
cfg_11d->param.domain_info.band = band;
|
||||||
|
|
||||||
|
@ -1834,6 +1835,101 @@ static void woal_save_auth_params(moal_private *priv,
|
||||||
LEAVE();
|
LEAVE();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Request scan based on auth_request parameter
|
||||||
|
*
|
||||||
|
* @param priv A pointer to moal_private structure
|
||||||
|
* @param req A pointer to cfg80211_auth_request
|
||||||
|
* @param wait_option wait option
|
||||||
|
*
|
||||||
|
* @return 0 -- success, otherwise fail
|
||||||
|
*/
|
||||||
|
static int woal_cfg80211_auth_scan(moal_private *priv,
|
||||||
|
struct cfg80211_auth_request *req,
|
||||||
|
t_u8 wait_option)
|
||||||
|
{
|
||||||
|
moal_handle *handle = priv->phandle;
|
||||||
|
int ret = 0;
|
||||||
|
wlan_user_scan_cfg scan_req;
|
||||||
|
enum ieee80211_band band;
|
||||||
|
struct ieee80211_supported_band *sband;
|
||||||
|
struct ieee80211_channel *ch;
|
||||||
|
int chan_idx = 0, i;
|
||||||
|
const u8 *ssid;
|
||||||
|
|
||||||
|
ENTER();
|
||||||
|
if (handle->scan_pending_on_block == MTRUE) {
|
||||||
|
PRINTM(MINFO, "scan already in processing...\n");
|
||||||
|
LEAVE();
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
#ifdef REASSOCIATION
|
||||||
|
if (MOAL_ACQ_SEMAPHORE_BLOCK(&handle->reassoc_sem)) {
|
||||||
|
PRINTM(MERROR, "Acquire semaphore error, woal_do_combo_scan\n");
|
||||||
|
LEAVE();
|
||||||
|
return -EBUSY;
|
||||||
|
}
|
||||||
|
#endif /* REASSOCIATION */
|
||||||
|
priv->report_scan_result = MTRUE;
|
||||||
|
memset(&scan_req, 0x00, sizeof(scan_req));
|
||||||
|
rcu_read_lock();
|
||||||
|
ssid = ieee80211_bss_get_ie(req->bss, WLAN_EID_SSID);
|
||||||
|
if (ssid) {
|
||||||
|
moal_memcpy_ext(priv->phandle, scan_req.ssid_list[0].ssid,
|
||||||
|
ssid + 2, ssid[1],
|
||||||
|
sizeof(scan_req.ssid_list[0].ssid));
|
||||||
|
scan_req.ssid_list[0].max_len = 0;
|
||||||
|
}
|
||||||
|
rcu_read_unlock();
|
||||||
|
moal_memcpy_ext(priv->phandle, scan_req.specific_bssid, req->bss->bssid,
|
||||||
|
ETH_ALEN, ETH_ALEN);
|
||||||
|
if (req->bss->channel) {
|
||||||
|
scan_req.chan_list[0].chan_number = req->bss->channel->hw_value;
|
||||||
|
scan_req.chan_list[0].radio_type = req->bss->channel->band;
|
||||||
|
if (req->bss->channel->flags & IEEE80211_CHAN_PASSIVE_SCAN)
|
||||||
|
scan_req.chan_list[0].scan_type =
|
||||||
|
MLAN_SCAN_TYPE_PASSIVE;
|
||||||
|
else if (req->bss->channel->flags & IEEE80211_CHAN_RADAR)
|
||||||
|
scan_req.chan_list[0].scan_type =
|
||||||
|
MLAN_SCAN_TYPE_PASSIVE_TO_ACTIVE;
|
||||||
|
else
|
||||||
|
scan_req.chan_list[0].scan_type = MLAN_SCAN_TYPE_ACTIVE;
|
||||||
|
scan_req.chan_list[0].scan_time = 0;
|
||||||
|
} else {
|
||||||
|
for (band = 0; (band < IEEE80211_NUM_BANDS); band++) {
|
||||||
|
if (!priv->wdev->wiphy->bands[band])
|
||||||
|
continue;
|
||||||
|
sband = priv->wdev->wiphy->bands[band];
|
||||||
|
for (i = 0; (i < sband->n_channels); i++) {
|
||||||
|
ch = &sband->channels[i];
|
||||||
|
if (ch->flags & IEEE80211_CHAN_DISABLED)
|
||||||
|
continue;
|
||||||
|
scan_req.chan_list[chan_idx].radio_type = band;
|
||||||
|
if (ch->flags & IEEE80211_CHAN_PASSIVE_SCAN)
|
||||||
|
scan_req.chan_list[chan_idx].scan_type =
|
||||||
|
MLAN_SCAN_TYPE_PASSIVE;
|
||||||
|
else if (ch->flags & IEEE80211_CHAN_RADAR)
|
||||||
|
scan_req.chan_list[chan_idx].scan_type =
|
||||||
|
MLAN_SCAN_TYPE_PASSIVE_TO_ACTIVE;
|
||||||
|
else
|
||||||
|
scan_req.chan_list[chan_idx].scan_type =
|
||||||
|
MLAN_SCAN_TYPE_ACTIVE;
|
||||||
|
scan_req.chan_list[chan_idx].chan_number =
|
||||||
|
(u32)ch->hw_value;
|
||||||
|
chan_idx++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
moal_memcpy_ext(priv->phandle, scan_req.random_mac, priv->random_mac,
|
||||||
|
ETH_ALEN, sizeof(scan_req.random_mac));
|
||||||
|
ret = woal_request_userscan(priv, wait_option, &scan_req);
|
||||||
|
#ifdef REASSOCIATION
|
||||||
|
MOAL_REL_SEMAPHORE(&handle->reassoc_sem);
|
||||||
|
#endif
|
||||||
|
LEAVE();
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief This function is authentication handler when host MLME
|
* @brief This function is authentication handler when host MLME
|
||||||
* enable.
|
* enable.
|
||||||
|
@ -1910,11 +2006,15 @@ static int woal_cfg80211_authenticate(struct wiphy *wiphy,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (MLAN_STATUS_SUCCESS != woal_find_bssid(priv, req->bss->bssid)) {
|
if (MLAN_STATUS_SUCCESS != woal_find_bssid(priv, req->bss->bssid)) {
|
||||||
|
woal_cfg80211_auth_scan(priv, req, MOAL_IOCTL_WAIT);
|
||||||
|
if (MLAN_STATUS_SUCCESS !=
|
||||||
|
woal_find_bssid(priv, req->bss->bssid)) {
|
||||||
PRINTM(MMSG, "bssid not find in scan list\n");
|
PRINTM(MMSG, "bssid not find in scan list\n");
|
||||||
kfree(ssid_bssid);
|
kfree(ssid_bssid);
|
||||||
LEAVE();
|
LEAVE();
|
||||||
return -EFAULT;
|
return -EFAULT;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
kfree(ssid_bssid);
|
kfree(ssid_bssid);
|
||||||
|
|
||||||
if ((priv->auth_alg != WLAN_AUTH_SAE) &&
|
if ((priv->auth_alg != WLAN_AUTH_SAE) &&
|
||||||
|
@ -2041,7 +2141,6 @@ static int woal_cfg80211_authenticate(struct wiphy *wiphy,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#define AUTH_TX_DEFAULT_WAIT_TIME 1200
|
|
||||||
if (priv->auth_flag == 0) {
|
if (priv->auth_flag == 0) {
|
||||||
if (woal_cfg80211_remain_on_channel_cfg(
|
if (woal_cfg80211_remain_on_channel_cfg(
|
||||||
priv, MOAL_IOCTL_WAIT, MFALSE, (t_u8 *)&status,
|
priv, MOAL_IOCTL_WAIT, MFALSE, (t_u8 *)&status,
|
||||||
|
@ -3152,6 +3251,15 @@ static mlan_status woal_cfg80211_dump_station_info(moal_private *priv,
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
ENTER();
|
ENTER();
|
||||||
|
|
||||||
|
if (priv->phandle->scan_pending_on_block) {
|
||||||
|
if (priv->sinfo)
|
||||||
|
moal_memcpy_ext(priv->phandle, sinfo, priv->sinfo,
|
||||||
|
sizeof(struct station_info),
|
||||||
|
sizeof(struct station_info));
|
||||||
|
LEAVE();
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(4, 0, 0)
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(4, 0, 0)
|
||||||
sinfo->filled = MBIT(NL80211_STA_INFO_RX_BYTES) |
|
sinfo->filled = MBIT(NL80211_STA_INFO_RX_BYTES) |
|
||||||
MBIT(NL80211_STA_INFO_TX_BYTES) |
|
MBIT(NL80211_STA_INFO_TX_BYTES) |
|
||||||
|
@ -3227,6 +3335,11 @@ static mlan_status woal_cfg80211_dump_station_info(moal_private *priv,
|
||||||
sinfo->bss_param.dtim_period = dtim_period;
|
sinfo->bss_param.dtim_period = dtim_period;
|
||||||
#endif
|
#endif
|
||||||
woal_cfg80211_fill_rate_info(priv, sinfo);
|
woal_cfg80211_fill_rate_info(priv, sinfo);
|
||||||
|
if (priv->sinfo)
|
||||||
|
moal_memcpy_ext(priv->phandle, priv->sinfo, sinfo,
|
||||||
|
sizeof(struct station_info),
|
||||||
|
sizeof(struct station_info));
|
||||||
|
|
||||||
done:
|
done:
|
||||||
LEAVE();
|
LEAVE();
|
||||||
return ret;
|
return ret;
|
||||||
|
@ -3439,10 +3552,8 @@ create_custom_regdomain(mlan_ds_custom_reg_domain *custom_reg)
|
||||||
rule->power_rule.max_eirp = DBM_TO_MBM(19);
|
rule->power_rule.max_eirp = DBM_TO_MBM(19);
|
||||||
rule->flags = 0;
|
rule->flags = 0;
|
||||||
|
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 14, 0)
|
|
||||||
if (chflags & NXP_CHANNEL_PASSIVE)
|
if (chflags & NXP_CHANNEL_PASSIVE)
|
||||||
rule->flags |= NL80211_RRF_NO_IR;
|
rule->flags |= NL80211_RRF_NO_IR;
|
||||||
#endif
|
|
||||||
if (chflags & NXP_CHANNEL_DFS)
|
if (chflags & NXP_CHANNEL_DFS)
|
||||||
rule->flags |= NL80211_RRF_DFS;
|
rule->flags |= NL80211_RRF_DFS;
|
||||||
if (chflags & NXP_CHANNEL_NO_OFDM)
|
if (chflags & NXP_CHANNEL_NO_OFDM)
|
||||||
|
@ -3461,8 +3572,24 @@ create_custom_regdomain(mlan_ds_custom_reg_domain *custom_reg)
|
||||||
regd->alpha2[0] = custom_reg->region.country_code[0];
|
regd->alpha2[0] = custom_reg->region.country_code[0];
|
||||||
regd->alpha2[1] = custom_reg->region.country_code[1];
|
regd->alpha2[1] = custom_reg->region.country_code[1];
|
||||||
}
|
}
|
||||||
PRINTM(MCMND, "create_custom_regdomain: %c%c rules=%d\n",
|
|
||||||
regd->alpha2[0], regd->alpha2[1], valid_rules);
|
switch (custom_reg->region.dfs_region) {
|
||||||
|
case 1:
|
||||||
|
regd->dfs_region = NL80211_DFS_FCC;
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
regd->dfs_region = NL80211_DFS_ETSI;
|
||||||
|
break;
|
||||||
|
case 3:
|
||||||
|
regd->dfs_region = NL80211_DFS_JP;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
regd->dfs_region = NL80211_DFS_UNSET;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
PRINTM(MCMND, "create_custom_regdomain: %c%c rules=%d dfs_region=%d\n",
|
||||||
|
regd->alpha2[0], regd->alpha2[1], valid_rules, regd->dfs_region);
|
||||||
for (idx = 0; idx < (int)regd->n_reg_rules; idx++) {
|
for (idx = 0; idx < (int)regd->n_reg_rules; idx++) {
|
||||||
rule = ®d->reg_rules[idx];
|
rule = ®d->reg_rules[idx];
|
||||||
freq_range = &rule->freq_range;
|
freq_range = &rule->freq_range;
|
||||||
|
@ -3473,6 +3600,10 @@ create_custom_regdomain(mlan_ds_custom_reg_domain *custom_reg)
|
||||||
freq_range->end_freq_khz - freq_range->start_freq_khz,
|
freq_range->end_freq_khz - freq_range->start_freq_khz,
|
||||||
freq_range->max_bandwidth_khz);
|
freq_range->max_bandwidth_khz);
|
||||||
}
|
}
|
||||||
|
if (!regd->n_reg_rules) {
|
||||||
|
kfree(regd);
|
||||||
|
regd = NULL;
|
||||||
|
}
|
||||||
return regd;
|
return regd;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3535,12 +3666,10 @@ static int woal_update_custom_regdomain(moal_private *priv, struct wiphy *wiphy)
|
||||||
country_code[0] ||
|
country_code[0] ||
|
||||||
misc->param.custom_reg_domain.region.country_code[1] !=
|
misc->param.custom_reg_domain.region.country_code[1] !=
|
||||||
country_code[1]) {
|
country_code[1]) {
|
||||||
PRINTM(MERROR, "country code %c%c not match %c%c\n",
|
PRINTM(MCMND, "FW country code %c%c not match %c%c\n",
|
||||||
misc->param.custom_reg_domain.region.country_code[0],
|
misc->param.custom_reg_domain.region.country_code[0],
|
||||||
misc->param.custom_reg_domain.region.country_code[1],
|
misc->param.custom_reg_domain.region.country_code[1],
|
||||||
country_code[0], country_code[1]);
|
country_code[0], country_code[1]);
|
||||||
ret = -EFAULT;
|
|
||||||
goto done;
|
|
||||||
}
|
}
|
||||||
regd = create_custom_regdomain(&misc->param.custom_reg_domain);
|
regd = create_custom_regdomain(&misc->param.custom_reg_domain);
|
||||||
if (regd) {
|
if (regd) {
|
||||||
|
@ -3675,6 +3804,10 @@ woal_cfg80211_reg_notifier(struct wiphy *wiphy,
|
||||||
break;
|
break;
|
||||||
case NL80211_REGDOM_SET_BY_CORE:
|
case NL80211_REGDOM_SET_BY_CORE:
|
||||||
PRINTM(MCMND, "Regulatory domain BY_CORE\n");
|
PRINTM(MCMND, "Regulatory domain BY_CORE\n");
|
||||||
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(4, 0, 0)
|
||||||
|
if (handle->params.cntry_txpwr == CNTRY_RGPOWER_MODE)
|
||||||
|
woal_update_custom_regdomain(priv, wiphy);
|
||||||
|
#endif
|
||||||
break;
|
break;
|
||||||
case NL80211_REGDOM_SET_BY_USER:
|
case NL80211_REGDOM_SET_BY_USER:
|
||||||
PRINTM(MCMND, "Regulatory domain BY_USER\n");
|
PRINTM(MCMND, "Regulatory domain BY_USER\n");
|
||||||
|
@ -3688,8 +3821,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);
|
||||||
|
@ -3933,6 +4065,36 @@ static t_u8 woal_is_scan_result_expired(moal_private *priv)
|
||||||
return MFALSE;
|
return MFALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief check if the scan result ageout
|
||||||
|
*
|
||||||
|
* @param priv A pointer to moal_private
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return MTRUE/MFALSE;
|
||||||
|
*/
|
||||||
|
t_u8 wlan_check_scan_table_ageout(moal_private *priv)
|
||||||
|
{
|
||||||
|
mlan_scan_resp scan_resp;
|
||||||
|
wifi_timeval t;
|
||||||
|
ENTER();
|
||||||
|
if (MLAN_STATUS_SUCCESS !=
|
||||||
|
woal_get_scan_table(priv, MOAL_IOCTL_WAIT, &scan_resp)) {
|
||||||
|
LEAVE();
|
||||||
|
return MFALSE;
|
||||||
|
}
|
||||||
|
woal_get_monotonic_time(&t);
|
||||||
|
#define CFG80211_SCAN_RESULT_AGEOUT 10
|
||||||
|
if (t.time_sec >
|
||||||
|
(scan_resp.age_in_secs + CFG80211_SCAN_RESULT_AGEOUT)) {
|
||||||
|
LEAVE();
|
||||||
|
return MFALSE;
|
||||||
|
}
|
||||||
|
PRINTM(MCMND, "Scan: Keep Previous result\n");
|
||||||
|
LEAVE();
|
||||||
|
return MTRUE;
|
||||||
|
}
|
||||||
|
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 6, 0)
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 6, 0)
|
||||||
/**
|
/**
|
||||||
* @brief Request the driver to do a scan. Always returning
|
* @brief Request the driver to do a scan. Always returning
|
||||||
|
@ -4049,16 +4211,13 @@ static int woal_cfg80211_scan(struct wiphy *wiphy, struct net_device *dev,
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (priv->phandle->scan_request->n_channels <= 38)
|
|
||||||
scan_req->ext_scan_type = EXT_SCAN_ENHANCE;
|
|
||||||
|
|
||||||
memset(&scan_cfg, 0, sizeof(mlan_scan_cfg));
|
memset(&scan_cfg, 0, sizeof(mlan_scan_cfg));
|
||||||
|
woal_get_scan_config(priv, &scan_cfg);
|
||||||
#ifdef WIFI_DIRECT_SUPPORT
|
#ifdef WIFI_DIRECT_SUPPORT
|
||||||
if (priv->phandle->miracast_mode)
|
if (priv->phandle->miracast_mode)
|
||||||
scan_req->scan_chan_gap = priv->phandle->scan_chan_gap;
|
scan_req->scan_chan_gap = priv->phandle->scan_chan_gap;
|
||||||
else {
|
else {
|
||||||
#endif
|
#endif
|
||||||
woal_get_scan_config(priv, &scan_cfg);
|
|
||||||
if (scan_cfg.scan_chan_gap)
|
if (scan_cfg.scan_chan_gap)
|
||||||
scan_req->scan_chan_gap = scan_cfg.scan_chan_gap;
|
scan_req->scan_chan_gap = scan_cfg.scan_chan_gap;
|
||||||
else if (woal_is_any_interface_active(priv->phandle))
|
else if (woal_is_any_interface_active(priv->phandle))
|
||||||
|
@ -4072,6 +4231,12 @@ 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 &&
|
||||||
|
!woal_is_any_interface_active(priv->phandle)) {
|
||||||
|
if (scan_cfg.ext_scan == 3)
|
||||||
|
scan_req->ext_scan_type = EXT_SCAN_ENHANCE;
|
||||||
|
}
|
||||||
|
|
||||||
for (i = 0; i < priv->phandle->scan_request->n_ssids; i++) {
|
for (i = 0; i < priv->phandle->scan_request->n_ssids; i++) {
|
||||||
moal_memcpy_ext(priv->phandle, scan_req->ssid_list[i].ssid,
|
moal_memcpy_ext(priv->phandle, scan_req->ssid_list[i].ssid,
|
||||||
priv->phandle->scan_request->ssids[i].ssid,
|
priv->phandle->scan_request->ssids[i].ssid,
|
||||||
|
@ -4108,6 +4273,8 @@ static int woal_cfg80211_scan(struct wiphy *wiphy, struct net_device *dev,
|
||||||
else
|
else
|
||||||
scan_req->chan_list[i].scan_type =
|
scan_req->chan_list[i].scan_type =
|
||||||
MLAN_SCAN_TYPE_ACTIVE;
|
MLAN_SCAN_TYPE_ACTIVE;
|
||||||
|
PRINTM(MCMD_D, "cfg80211_scan: chan=%d chan->flag=0x%x\n",
|
||||||
|
chan->hw_value, chan->flags);
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(4, 8, 0)
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(4, 8, 0)
|
||||||
scan_req->chan_list[i].scan_time =
|
scan_req->chan_list[i].scan_time =
|
||||||
priv->phandle->scan_request->duration;
|
priv->phandle->scan_request->duration;
|
||||||
|
@ -4203,6 +4370,8 @@ static int woal_cfg80211_scan(struct wiphy *wiphy, struct net_device *dev,
|
||||||
|
|
||||||
PRINTM(MCMND, "wlan:random_mac " MACSTR "\n",
|
PRINTM(MCMND, "wlan:random_mac " MACSTR "\n",
|
||||||
MAC2STR(scan_req->random_mac));
|
MAC2STR(scan_req->random_mac));
|
||||||
|
scan_req->keep_previous_scan = wlan_check_scan_table_ageout(priv);
|
||||||
|
|
||||||
if (MLAN_STATUS_SUCCESS != woal_do_scan(priv, scan_req)) {
|
if (MLAN_STATUS_SUCCESS != woal_do_scan(priv, scan_req)) {
|
||||||
PRINTM(MERROR, "woal_do_scan fails!\n");
|
PRINTM(MERROR, "woal_do_scan fails!\n");
|
||||||
ret = -EAGAIN;
|
ret = -EAGAIN;
|
||||||
|
@ -4474,7 +4643,6 @@ static int woal_connect_ft_over_air(moal_private *priv, t_u8 *bssid,
|
||||||
woal_mgmt_frame_register(priv, IEEE80211_STYPE_AUTH, MTRUE);
|
woal_mgmt_frame_register(priv, IEEE80211_STYPE_AUTH, MTRUE);
|
||||||
|
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(2, 6, 39)
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(2, 6, 39)
|
||||||
#define AUTH_TX_DEFAULT_WAIT_TIME 1200
|
|
||||||
woal_cfg80211_remain_on_channel_cfg(priv, wait_option, MFALSE, &status,
|
woal_cfg80211_remain_on_channel_cfg(priv, wait_option, MFALSE, &status,
|
||||||
chan, 0, AUTH_TX_DEFAULT_WAIT_TIME);
|
chan, 0, AUTH_TX_DEFAULT_WAIT_TIME);
|
||||||
#endif
|
#endif
|
||||||
|
@ -8191,6 +8359,10 @@ void woal_save_conn_params(moal_private *priv,
|
||||||
sme->key, sme->key_len,
|
sme->key, sme->key_len,
|
||||||
sizeof(priv->conn_wep_key));
|
sizeof(priv->conn_wep_key));
|
||||||
}
|
}
|
||||||
|
if (priv->sinfo)
|
||||||
|
memset(priv->sinfo, 0, sizeof(struct station_info));
|
||||||
|
else
|
||||||
|
priv->sinfo = kzalloc(sizeof(struct station_info), GFP_KERNEL);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -8206,6 +8378,10 @@ void woal_clear_conn_params(moal_private *priv)
|
||||||
memset(&priv->sme_current, 0, sizeof(struct cfg80211_connect_params));
|
memset(&priv->sme_current, 0, sizeof(struct cfg80211_connect_params));
|
||||||
priv->roaming_required = MFALSE;
|
priv->roaming_required = MFALSE;
|
||||||
priv->assoc_bss = NULL;
|
priv->assoc_bss = NULL;
|
||||||
|
if (priv->sinfo) {
|
||||||
|
kfree(priv->sinfo);
|
||||||
|
priv->sinfo = NULL;
|
||||||
|
}
|
||||||
LEAVE();
|
LEAVE();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -8850,6 +9026,7 @@ mlan_status woal_register_sta_cfg80211(struct net_device *dev, t_u8 bss_type)
|
||||||
moal_private *priv = (moal_private *)netdev_priv(dev);
|
moal_private *priv = (moal_private *)netdev_priv(dev);
|
||||||
struct wireless_dev *wdev = NULL;
|
struct wireless_dev *wdev = NULL;
|
||||||
int psmode = 0;
|
int psmode = 0;
|
||||||
|
enum ieee80211_band band;
|
||||||
|
|
||||||
ENTER();
|
ENTER();
|
||||||
|
|
||||||
|
@ -8887,6 +9064,14 @@ mlan_status woal_register_sta_cfg80211(struct net_device *dev, t_u8 bss_type)
|
||||||
else
|
else
|
||||||
priv->wdev->ps = MFALSE;
|
priv->wdev->ps = MFALSE;
|
||||||
}
|
}
|
||||||
|
if (priv->phandle->country_code[0] && priv->phandle->country_code[1]) {
|
||||||
|
band = priv->phandle->band;
|
||||||
|
priv->phandle->band = IEEE80211_BAND_2GHZ;
|
||||||
|
woal_send_domain_info_cmd_fw(priv, MOAL_IOCTL_WAIT);
|
||||||
|
priv->phandle->band = IEEE80211_BAND_5GHZ;
|
||||||
|
woal_send_domain_info_cmd_fw(priv, MOAL_IOCTL_WAIT);
|
||||||
|
priv->phandle->band = band;
|
||||||
|
}
|
||||||
LEAVE();
|
LEAVE();
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
@ -9368,9 +9553,8 @@ mlan_status woal_register_cfg80211(moal_private *priv)
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
priv->phandle->country_code[0] = '0';
|
memset(&priv->phandle->country_code, 0,
|
||||||
priv->phandle->country_code[1] = '0';
|
sizeof(priv->phandle->country_code));
|
||||||
priv->phandle->country_code[2] = ' ';
|
|
||||||
|
|
||||||
if (reg_alpha2 && !strncmp(reg_alpha2, "99", strlen("99"))) {
|
if (reg_alpha2 && !strncmp(reg_alpha2, "99", strlen("99"))) {
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 14, 0)
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 14, 0)
|
||||||
|
|
|
@ -83,6 +83,65 @@ done:
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief send deauth to station, that has been added and associated
|
||||||
|
*
|
||||||
|
* @param A pointer to moal_private
|
||||||
|
* @param mac A pointer to station mac address
|
||||||
|
* @param reason_code ieee deauth reason code
|
||||||
|
* @return 0 -- success, otherwise fail
|
||||||
|
*/
|
||||||
|
static int woal_deauth_assoc_station(moal_private *priv, u8 *mac_addr,
|
||||||
|
u16 reason_code)
|
||||||
|
{
|
||||||
|
int ret = -EFAULT;
|
||||||
|
int i = 0;
|
||||||
|
mlan_ds_get_info *info = NULL;
|
||||||
|
mlan_ioctl_req *ioctl_req = NULL;
|
||||||
|
mlan_status status = MLAN_STATUS_SUCCESS;
|
||||||
|
|
||||||
|
ENTER();
|
||||||
|
|
||||||
|
if (!mac_addr) {
|
||||||
|
LEAVE();
|
||||||
|
return -EINVAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
ioctl_req = (mlan_ioctl_req *)woal_alloc_mlan_ioctl_req(
|
||||||
|
sizeof(mlan_ds_get_info));
|
||||||
|
if (ioctl_req == NULL) {
|
||||||
|
LEAVE();
|
||||||
|
return -ENOMEM;
|
||||||
|
}
|
||||||
|
|
||||||
|
info = (mlan_ds_get_info *)ioctl_req->pbuf;
|
||||||
|
info->sub_command = MLAN_OID_UAP_STA_LIST;
|
||||||
|
ioctl_req->req_id = MLAN_IOCTL_GET_INFO;
|
||||||
|
ioctl_req->action = MLAN_ACT_GET;
|
||||||
|
|
||||||
|
status = woal_request_ioctl(priv, ioctl_req, MOAL_IOCTL_WAIT);
|
||||||
|
if (status != MLAN_STATUS_SUCCESS)
|
||||||
|
goto done;
|
||||||
|
if (!info->param.sta_list.sta_count) {
|
||||||
|
PRINTM(MCMND, "wlan: skip deauth to station " MACSTR "\n",
|
||||||
|
MAC2STR(mac_addr));
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (i = 0; i < info->param.sta_list.sta_count; i++) {
|
||||||
|
if (!memcmp(info->param.sta_list.info[i].mac_address, mac_addr,
|
||||||
|
ETH_ALEN))
|
||||||
|
ret = woal_deauth_station(priv, mac_addr, reason_code);
|
||||||
|
}
|
||||||
|
|
||||||
|
done:
|
||||||
|
if (status != MLAN_STATUS_PENDING)
|
||||||
|
kfree(ioctl_req);
|
||||||
|
|
||||||
|
LEAVE();
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief send deauth to all station
|
* @brief send deauth to all station
|
||||||
*
|
*
|
||||||
|
@ -569,6 +628,26 @@ static IEEEtypes_VHTCap_t *woal_get_vhtcap_info(const t_u8 *ie, int len)
|
||||||
return vhtcap_ie;
|
return vhtcap_ie;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief get vht_oper from beacon ie
|
||||||
|
*
|
||||||
|
* @param ie Pointer to IEs
|
||||||
|
* @param len Total length of ie
|
||||||
|
*
|
||||||
|
* @return Pointer to vht_opr ie
|
||||||
|
*/
|
||||||
|
static IEEEtypes_VHTOprat_t *woal_get_vht_oprat_ie(const t_u8 *ie, int len)
|
||||||
|
{
|
||||||
|
IEEEtypes_VHTOprat_t *vht_oprat_ie = NULL;
|
||||||
|
vht_oprat_ie = (IEEEtypes_VHTOprat_t *)woal_parse_ie_tlv(ie, len,
|
||||||
|
VHT_OPERATION);
|
||||||
|
if (vht_oprat_ie)
|
||||||
|
PRINTM(MMSG,
|
||||||
|
"Get vht_oprat_ie from beacon ies: chan_width=%d\n",
|
||||||
|
vht_oprat_ie->chan_width);
|
||||||
|
return vht_oprat_ie;
|
||||||
|
}
|
||||||
|
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 12, 0)
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 12, 0)
|
||||||
/** Starting Frequency for 11A band */
|
/** Starting Frequency for 11A band */
|
||||||
#define START_FREQ_11A_BAND 5000 /* in MHz */
|
#define START_FREQ_11A_BAND 5000 /* in MHz */
|
||||||
|
@ -753,6 +832,7 @@ static int woal_cfg80211_beacon_config(moal_private *priv,
|
||||||
t_u8 enable_11ac = MFALSE;
|
t_u8 enable_11ac = MFALSE;
|
||||||
t_u8 vht20_40 = MFALSE;
|
t_u8 vht20_40 = MFALSE;
|
||||||
IEEEtypes_VHTCap_t *vhtcap_ie = NULL;
|
IEEEtypes_VHTCap_t *vhtcap_ie = NULL;
|
||||||
|
IEEEtypes_VHTOprat_t *vhtopr_ie = NULL;
|
||||||
IEEEtypes_HECap_t *hecap_ie = NULL;
|
IEEEtypes_HECap_t *hecap_ie = NULL;
|
||||||
t_u8 enable_11ax = MFALSE;
|
t_u8 enable_11ax = MFALSE;
|
||||||
t_u8 *wapi_ie = NULL;
|
t_u8 *wapi_ie = NULL;
|
||||||
|
@ -1025,7 +1105,6 @@ static int woal_cfg80211_beacon_config(moal_private *priv,
|
||||||
} else {
|
} else {
|
||||||
sys_config->bandcfg.chan2Offset = 0;
|
sys_config->bandcfg.chan2Offset = 0;
|
||||||
}
|
}
|
||||||
if (priv->bss_type == MLAN_BSS_TYPE_UAP) {
|
|
||||||
ht_cap = woal_get_htcap_info(ie, ie_len);
|
ht_cap = woal_get_htcap_info(ie, ie_len);
|
||||||
if (ht_cap) {
|
if (ht_cap) {
|
||||||
if (sys_config->bandcfg.chanBand == BAND_2GHZ)
|
if (sys_config->bandcfg.chanBand == BAND_2GHZ)
|
||||||
|
@ -1045,13 +1124,12 @@ static int woal_cfg80211_beacon_config(moal_private *priv,
|
||||||
}
|
}
|
||||||
PRINTM(MCMND,
|
PRINTM(MCMND,
|
||||||
"11n=%d, ht_cap=0x%x, channel=%d, bandcfg:chanBand=0x%x chanWidth=0x%x chan2Offset=0x%x scanMode=0x%x\n",
|
"11n=%d, ht_cap=0x%x, channel=%d, bandcfg:chanBand=0x%x chanWidth=0x%x chan2Offset=0x%x scanMode=0x%x\n",
|
||||||
enable_11n, sys_config->ht_cap_info,
|
enable_11n, sys_config->ht_cap_info, priv->channel,
|
||||||
priv->channel, sys_config->bandcfg.chanBand,
|
sys_config->bandcfg.chanBand,
|
||||||
sys_config->bandcfg.chanWidth,
|
sys_config->bandcfg.chanWidth,
|
||||||
sys_config->bandcfg.chan2Offset,
|
sys_config->bandcfg.chan2Offset,
|
||||||
sys_config->bandcfg.scanMode);
|
sys_config->bandcfg.scanMode);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 2, 0)
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 2, 0)
|
||||||
if (!params->ssid || !params->ssid_len) {
|
if (!params->ssid || !params->ssid_len) {
|
||||||
ret = -EINVAL;
|
ret = -EINVAL;
|
||||||
|
@ -1260,6 +1338,10 @@ static int woal_cfg80211_beacon_config(moal_private *priv,
|
||||||
}
|
}
|
||||||
if (enable_11ac && enable_11n) {
|
if (enable_11ac && enable_11n) {
|
||||||
vhtcap_ie = woal_get_vhtcap_info(ie, ie_len);
|
vhtcap_ie = woal_get_vhtcap_info(ie, ie_len);
|
||||||
|
vhtopr_ie = woal_get_vht_oprat_ie(ie, ie_len);
|
||||||
|
// Enable VHT80
|
||||||
|
if (vhtopr_ie && vhtopr_ie->chan_width)
|
||||||
|
vht20_40 = 0;
|
||||||
woal_uap_set_11ac_status(priv, MLAN_ACT_ENABLE, vht20_40,
|
woal_uap_set_11ac_status(priv, MLAN_ACT_ENABLE, vht20_40,
|
||||||
vhtcap_ie);
|
vhtcap_ie);
|
||||||
} else {
|
} else {
|
||||||
|
@ -1546,6 +1628,20 @@ int woal_cfg80211_add_virt_if(struct wiphy *wiphy,
|
||||||
new_priv->bss_virtual = MTRUE;
|
new_priv->bss_virtual = MTRUE;
|
||||||
new_priv->pa_netdev = priv->netdev;
|
new_priv->pa_netdev = priv->netdev;
|
||||||
|
|
||||||
|
/* Create workqueue for main process */
|
||||||
|
#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 36)
|
||||||
|
new_priv->mclist_workqueue =
|
||||||
|
alloc_workqueue("MCLIST_WORK_QUEUE",
|
||||||
|
WQ_HIGHPRI | WQ_MEM_RECLAIM | WQ_UNBOUND, 1);
|
||||||
|
#else
|
||||||
|
new_priv->mclist_workqueue = create_workqueue("MCLIST_WORK_QUEUE");
|
||||||
|
#endif
|
||||||
|
if (!new_priv->mclist_workqueue) {
|
||||||
|
PRINTM(MERROR, "cannot alloc mclist workqueue \n");
|
||||||
|
return -EFAULT;
|
||||||
|
}
|
||||||
|
MLAN_INIT_WORK(&new_priv->mclist_work, woal_mclist_work_queue);
|
||||||
|
|
||||||
woal_init_sta_dev(ndev, new_priv);
|
woal_init_sta_dev(ndev, new_priv);
|
||||||
|
|
||||||
/* Initialize priv structure */
|
/* Initialize priv structure */
|
||||||
|
@ -1717,7 +1813,11 @@ int woal_cfg80211_del_virt_if(struct wiphy *wiphy, struct net_device *dev)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
if (vir_priv->mclist_workqueue) {
|
||||||
|
flush_workqueue(vir_priv->mclist_workqueue);
|
||||||
|
destroy_workqueue(vir_priv->mclist_workqueue);
|
||||||
|
vir_priv->mclist_workqueue = NULL;
|
||||||
|
}
|
||||||
woal_clear_all_mgmt_ies(vir_priv, MOAL_IOCTL_WAIT);
|
woal_clear_all_mgmt_ies(vir_priv, MOAL_IOCTL_WAIT);
|
||||||
woal_cfg80211_deinit_p2p(vir_priv);
|
woal_cfg80211_deinit_p2p(vir_priv);
|
||||||
woal_bss_remove(vir_priv);
|
woal_bss_remove(vir_priv);
|
||||||
|
@ -2537,7 +2637,8 @@ int woal_cfg80211_del_station(struct wiphy *wiphy, struct net_device *dev,
|
||||||
#ifdef WIFI_DIRECT_SUPPORT
|
#ifdef WIFI_DIRECT_SUPPORT
|
||||||
if (!priv->phandle->is_go_timer_set)
|
if (!priv->phandle->is_go_timer_set)
|
||||||
#endif
|
#endif
|
||||||
woal_deauth_station(priv, (u8 *)mac_addr, reason_code);
|
woal_deauth_assoc_station(priv, (u8 *)mac_addr,
|
||||||
|
reason_code);
|
||||||
} else {
|
} else {
|
||||||
PRINTM(MIOCTL, "del all station\n");
|
PRINTM(MIOCTL, "del all station\n");
|
||||||
}
|
}
|
||||||
|
@ -3011,6 +3112,36 @@ void woal_csa_work_queue(struct work_struct *work)
|
||||||
LEAVE();
|
LEAVE();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* @brief handle WOAL_EVENT_CANCEL_CHANRPT
|
||||||
|
*
|
||||||
|
* @param priv A pointer moal_private structure
|
||||||
|
*
|
||||||
|
* @return N/A
|
||||||
|
*/
|
||||||
|
void woal_process_cancel_chanrpt_event(moal_private *priv)
|
||||||
|
{
|
||||||
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 12, 0)
|
||||||
|
if (priv->phandle->is_cac_timer_set &&
|
||||||
|
priv->bss_index == priv->phandle->cac_bss_index) {
|
||||||
|
woal_cancel_timer(&priv->phandle->cac_timer);
|
||||||
|
priv->phandle->is_cac_timer_set = MFALSE;
|
||||||
|
/* Make sure Chan Report is cancelled */
|
||||||
|
woal_11h_cancel_chan_report_ioctl(priv, MOAL_IOCTL_WAIT);
|
||||||
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 14, 0)
|
||||||
|
cfg80211_cac_event(priv->netdev, &priv->phandle->dfs_channel,
|
||||||
|
NL80211_RADAR_CAC_ABORTED, GFP_KERNEL);
|
||||||
|
#else
|
||||||
|
cfg80211_cac_event(priv->netdev, NL80211_RADAR_CAC_ABORTED,
|
||||||
|
GFP_KERNEL);
|
||||||
|
#endif
|
||||||
|
memset(&priv->phandle->dfs_channel, 0,
|
||||||
|
sizeof(struct cfg80211_chan_def));
|
||||||
|
priv->phandle->cac_bss_index = 0xff;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 15, 0)
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 15, 0)
|
||||||
/**
|
/**
|
||||||
* @brief start radar detection
|
* @brief start radar detection
|
||||||
|
|
|
@ -82,47 +82,4 @@ Change log:
|
||||||
/** Private command ID to stop driver */
|
/** Private command ID to stop driver */
|
||||||
#define WOAL_UAP_FROYO_STOP (WOAL_UAP_IOCTL + 30)
|
#define WOAL_UAP_FROYO_STOP (WOAL_UAP_IOCTL + 30)
|
||||||
|
|
||||||
/**
|
|
||||||
* iwpriv ioctl handlers
|
|
||||||
*/
|
|
||||||
static const struct iw_priv_args woal_uap_priv_args[] = {
|
|
||||||
{WOAL_UAP_SETNONE_GETNONE, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_NONE, ""},
|
|
||||||
{WOAL_UAP_START, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_NONE, "start"},
|
|
||||||
{WOAL_UAP_STOP, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_NONE, "stop"},
|
|
||||||
{WOAL_AP_BSS_START, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_NONE, "bssstart"},
|
|
||||||
{WOAL_AP_BSS_STOP, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_NONE, "bssstop"},
|
|
||||||
{WOAL_UAP_SETONEINT_GETWORDCHAR, IW_PRIV_TYPE_INT | 1,
|
|
||||||
IW_PRIV_TYPE_CHAR | 128, ""},
|
|
||||||
{WOAL_UAP_VERSION, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_CHAR | 128,
|
|
||||||
"version"},
|
|
||||||
{WOAL_UAP_VEREXT, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_CHAR | 128,
|
|
||||||
"verext"},
|
|
||||||
#ifdef WIFI_DIRECT_SUPPORT
|
|
||||||
#if defined(STA_SUPPORT) && defined(UAP_SUPPORT)
|
|
||||||
{WOAL_UAP_SETONEINT_GETONEINT, 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"},
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
{WOAL_UAP_SET_GET_256_CHAR, IW_PRIV_TYPE_CHAR | 256,
|
|
||||||
IW_PRIV_TYPE_CHAR | 256, ""},
|
|
||||||
{WOAL_WL_FW_RELOAD, IW_PRIV_TYPE_CHAR | 256, IW_PRIV_TYPE_CHAR | 256,
|
|
||||||
"fwreload"},
|
|
||||||
{WOAL_AP_SET_CFG, IW_PRIV_TYPE_CHAR | 256, IW_PRIV_TYPE_CHAR | 256,
|
|
||||||
"apcfg"},
|
|
||||||
{WOAL_UAP_HOST_CMD, IW_PRIV_TYPE_BYTE | 2047, IW_PRIV_TYPE_BYTE | 2047,
|
|
||||||
"hostcmd"},
|
|
||||||
{WOAL_UAP_FROYO_START, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_NONE, "START"},
|
|
||||||
{WOAL_UAP_FROYO_STOP, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_NONE, "STOP"},
|
|
||||||
{WOAL_UAP_FROYO_AP_BSS_START, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_NONE,
|
|
||||||
"AP_BSS_START"},
|
|
||||||
{WOAL_UAP_FROYO_AP_BSS_STOP, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_NONE,
|
|
||||||
"AP_BSS_STOP"},
|
|
||||||
{WOAL_UAP_FROYO_WL_FW_RELOAD, IW_PRIV_TYPE_CHAR | 256,
|
|
||||||
IW_PRIV_TYPE_CHAR | 256, "WL_FW_RELOAD"},
|
|
||||||
{WOAL_UAP_FROYO_AP_SET_CFG, IW_PRIV_TYPE_CHAR | 256,
|
|
||||||
IW_PRIV_TYPE_CHAR | 256, "AP_SET_CFG"},
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif /* _MOAL_UAP_PRIV_H_ */
|
#endif /* _MOAL_UAP_PRIV_H_ */
|
||||||
|
|
|
@ -60,6 +60,49 @@ static const chan_to_freq_t chan_to_freq[] = {
|
||||||
{165, 5825, 1},
|
{165, 5825, 1},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* iwpriv ioctl handlers
|
||||||
|
*/
|
||||||
|
static const struct iw_priv_args woal_uap_priv_args[] = {
|
||||||
|
{WOAL_UAP_SETNONE_GETNONE, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_NONE, ""},
|
||||||
|
{WOAL_UAP_START, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_NONE, "start"},
|
||||||
|
{WOAL_UAP_STOP, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_NONE, "stop"},
|
||||||
|
{WOAL_AP_BSS_START, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_NONE, "bssstart"},
|
||||||
|
{WOAL_AP_BSS_STOP, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_NONE, "bssstop"},
|
||||||
|
{WOAL_UAP_SETONEINT_GETWORDCHAR, IW_PRIV_TYPE_INT | 1,
|
||||||
|
IW_PRIV_TYPE_CHAR | 128, ""},
|
||||||
|
{WOAL_UAP_VERSION, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_CHAR | 128,
|
||||||
|
"version"},
|
||||||
|
{WOAL_UAP_VEREXT, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_CHAR | 128,
|
||||||
|
"verext"},
|
||||||
|
#ifdef WIFI_DIRECT_SUPPORT
|
||||||
|
#if defined(STA_SUPPORT) && defined(UAP_SUPPORT)
|
||||||
|
{WOAL_UAP_SETONEINT_GETONEINT, 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"},
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
{WOAL_UAP_SET_GET_256_CHAR, IW_PRIV_TYPE_CHAR | 256,
|
||||||
|
IW_PRIV_TYPE_CHAR | 256, ""},
|
||||||
|
{WOAL_WL_FW_RELOAD, IW_PRIV_TYPE_CHAR | 256, IW_PRIV_TYPE_CHAR | 256,
|
||||||
|
"fwreload"},
|
||||||
|
{WOAL_AP_SET_CFG, IW_PRIV_TYPE_CHAR | 256, IW_PRIV_TYPE_CHAR | 256,
|
||||||
|
"apcfg"},
|
||||||
|
{WOAL_UAP_HOST_CMD, IW_PRIV_TYPE_BYTE | 2047, IW_PRIV_TYPE_BYTE | 2047,
|
||||||
|
"hostcmd"},
|
||||||
|
{WOAL_UAP_FROYO_START, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_NONE, "START"},
|
||||||
|
{WOAL_UAP_FROYO_STOP, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_NONE, "STOP"},
|
||||||
|
{WOAL_UAP_FROYO_AP_BSS_START, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_NONE,
|
||||||
|
"AP_BSS_START"},
|
||||||
|
{WOAL_UAP_FROYO_AP_BSS_STOP, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_NONE,
|
||||||
|
"AP_BSS_STOP"},
|
||||||
|
{WOAL_UAP_FROYO_WL_FW_RELOAD, IW_PRIV_TYPE_CHAR | 256,
|
||||||
|
IW_PRIV_TYPE_CHAR | 256, "WL_FW_RELOAD"},
|
||||||
|
{WOAL_UAP_FROYO_AP_SET_CFG, IW_PRIV_TYPE_CHAR | 256,
|
||||||
|
IW_PRIV_TYPE_CHAR | 256, "AP_SET_CFG"},
|
||||||
|
};
|
||||||
|
|
||||||
/** Convertion from frequency to channel */
|
/** Convertion from frequency to channel */
|
||||||
#define freq_to_chan(x) ((((x)-2412) / 5) + 1)
|
#define freq_to_chan(x) ((((x)-2412) / 5) + 1)
|
||||||
|
|
||||||
|
|
|
@ -681,9 +681,9 @@ static t_u16 woal_update_card_type(t_void *card)
|
||||||
/* Update card type */
|
/* Update card type */
|
||||||
#ifdef USB8801
|
#ifdef USB8801
|
||||||
if (woal_cpu_to_le16(cardp_usb->udev->descriptor.idProduct) ==
|
if (woal_cpu_to_le16(cardp_usb->udev->descriptor.idProduct) ==
|
||||||
USB8801_PID_1 ||
|
(__force __le16)USB8801_PID_1 ||
|
||||||
woal_cpu_to_le16(cardp_usb->udev->descriptor.idProduct) ==
|
woal_cpu_to_le16(cardp_usb->udev->descriptor.idProduct) ==
|
||||||
USB8801_PID_2) {
|
(__force __le16)USB8801_PID_2) {
|
||||||
card_type = CARD_TYPE_USB8801;
|
card_type = CARD_TYPE_USB8801;
|
||||||
moal_memcpy_ext(NULL, driver_version, CARD_USB8801,
|
moal_memcpy_ext(NULL, driver_version, CARD_USB8801,
|
||||||
strlen(CARD_USB8801), strlen(driver_version));
|
strlen(CARD_USB8801), strlen(driver_version));
|
||||||
|
@ -697,9 +697,9 @@ static t_u16 woal_update_card_type(t_void *card)
|
||||||
#endif
|
#endif
|
||||||
#ifdef USB8897
|
#ifdef USB8897
|
||||||
if (woal_cpu_to_le16(cardp_usb->udev->descriptor.idProduct) ==
|
if (woal_cpu_to_le16(cardp_usb->udev->descriptor.idProduct) ==
|
||||||
USB8897_PID_1 ||
|
(__force __le16)USB8897_PID_1 ||
|
||||||
woal_cpu_to_le16(cardp_usb->udev->descriptor.idProduct) ==
|
woal_cpu_to_le16(cardp_usb->udev->descriptor.idProduct) ==
|
||||||
USB8897_PID_2) {
|
(__force __le16)USB8897_PID_2) {
|
||||||
card_type = CARD_TYPE_USB8897;
|
card_type = CARD_TYPE_USB8897;
|
||||||
moal_memcpy_ext(NULL, driver_version, CARD_USB8897,
|
moal_memcpy_ext(NULL, driver_version, CARD_USB8897,
|
||||||
strlen(CARD_USB8897), strlen(driver_version));
|
strlen(CARD_USB8897), strlen(driver_version));
|
||||||
|
@ -713,19 +713,19 @@ static t_u16 woal_update_card_type(t_void *card)
|
||||||
#endif
|
#endif
|
||||||
#ifdef USB8997
|
#ifdef USB8997
|
||||||
if (woal_cpu_to_le16(cardp_usb->udev->descriptor.idProduct) ==
|
if (woal_cpu_to_le16(cardp_usb->udev->descriptor.idProduct) ==
|
||||||
USB8997_PID_1 ||
|
(__force __le16)USB8997_PID_1 ||
|
||||||
woal_cpu_to_le16(cardp_usb->udev->descriptor.idProduct) ==
|
woal_cpu_to_le16(cardp_usb->udev->descriptor.idProduct) ==
|
||||||
USB8997_PID_2 ||
|
(__force __le16)USB8997_PID_2 ||
|
||||||
woal_cpu_to_le16(cardp_usb->udev->descriptor.idProduct) ==
|
woal_cpu_to_le16(cardp_usb->udev->descriptor.idProduct) ==
|
||||||
USB8997_PID_3 ||
|
(__force __le16)USB8997_PID_3 ||
|
||||||
woal_cpu_to_le16(cardp_usb->udev->descriptor.idProduct) ==
|
woal_cpu_to_le16(cardp_usb->udev->descriptor.idProduct) ==
|
||||||
USB8997_PID_4 ||
|
(__force __le16)USB8997_PID_4 ||
|
||||||
woal_cpu_to_le16(cardp_usb->udev->descriptor.idProduct) ==
|
woal_cpu_to_le16(cardp_usb->udev->descriptor.idProduct) ==
|
||||||
USB8997_PID_5 ||
|
(__force __le16)USB8997_PID_5 ||
|
||||||
woal_cpu_to_le16(cardp_usb->udev->descriptor.idProduct) ==
|
woal_cpu_to_le16(cardp_usb->udev->descriptor.idProduct) ==
|
||||||
USB8997_PID_6 ||
|
(__force __le16)USB8997_PID_6 ||
|
||||||
woal_cpu_to_le16(cardp_usb->udev->descriptor.idProduct) ==
|
woal_cpu_to_le16(cardp_usb->udev->descriptor.idProduct) ==
|
||||||
USB8997V2_PID_1) {
|
(__force __le16)USB8997V2_PID_1) {
|
||||||
card_type = CARD_TYPE_USB8997;
|
card_type = CARD_TYPE_USB8997;
|
||||||
moal_memcpy_ext(NULL, driver_version, CARD_USB8997,
|
moal_memcpy_ext(NULL, driver_version, CARD_USB8997,
|
||||||
strlen(CARD_USB8997), strlen(driver_version));
|
strlen(CARD_USB8997), strlen(driver_version));
|
||||||
|
@ -739,12 +739,12 @@ static t_u16 woal_update_card_type(t_void *card)
|
||||||
#endif
|
#endif
|
||||||
#ifdef USB8978
|
#ifdef USB8978
|
||||||
if (woal_cpu_to_le16(cardp_usb->udev->descriptor.idProduct) ==
|
if (woal_cpu_to_le16(cardp_usb->udev->descriptor.idProduct) ==
|
||||||
USB8978_PID_1 ||
|
(__force __le16)USB8978_PID_1 ||
|
||||||
woal_cpu_to_le16(cardp_usb->udev->descriptor.idProduct) ==
|
woal_cpu_to_le16(cardp_usb->udev->descriptor.idProduct) ==
|
||||||
USB8978_PID_2) {
|
(__force __le16)USB8978_PID_2) {
|
||||||
card_type = CARD_TYPE_USB8978;
|
card_type = CARD_TYPE_USB8978;
|
||||||
moal_memcpy_ext(NULL, driver_version, CARD_USB8978,
|
moal_memcpy_ext(NULL, driver_version, "USBIW416",
|
||||||
strlen(CARD_USB8978), strlen(driver_version));
|
strlen("USBIW416"), strlen(driver_version));
|
||||||
moal_memcpy_ext(NULL,
|
moal_memcpy_ext(NULL,
|
||||||
driver_version + strlen(INTF_CARDTYPE) +
|
driver_version + strlen(INTF_CARDTYPE) +
|
||||||
strlen(KERN_VERSION),
|
strlen(KERN_VERSION),
|
||||||
|
@ -755,9 +755,9 @@ static t_u16 woal_update_card_type(t_void *card)
|
||||||
#endif
|
#endif
|
||||||
#ifdef USB9098
|
#ifdef USB9098
|
||||||
if (woal_cpu_to_le16(cardp_usb->udev->descriptor.idProduct) ==
|
if (woal_cpu_to_le16(cardp_usb->udev->descriptor.idProduct) ==
|
||||||
USB9098_PID_1 ||
|
(__force __le16)USB9098_PID_1 ||
|
||||||
woal_cpu_to_le16(cardp_usb->udev->descriptor.idProduct) ==
|
woal_cpu_to_le16(cardp_usb->udev->descriptor.idProduct) ==
|
||||||
USB9098_PID_2) {
|
(__force __le16)USB9098_PID_2) {
|
||||||
card_type = CARD_TYPE_USB9098;
|
card_type = CARD_TYPE_USB9098;
|
||||||
moal_memcpy_ext(NULL, driver_version, CARD_USB9098,
|
moal_memcpy_ext(NULL, driver_version, CARD_USB9098,
|
||||||
strlen(CARD_USB9098), strlen(driver_version));
|
strlen(CARD_USB9098), strlen(driver_version));
|
||||||
|
@ -771,12 +771,12 @@ static t_u16 woal_update_card_type(t_void *card)
|
||||||
#endif
|
#endif
|
||||||
#ifdef USB9097
|
#ifdef USB9097
|
||||||
if (woal_cpu_to_le16(cardp_usb->udev->descriptor.idProduct) ==
|
if (woal_cpu_to_le16(cardp_usb->udev->descriptor.idProduct) ==
|
||||||
USB9097_PID_1 ||
|
(__force __le16)USB9097_PID_1 ||
|
||||||
woal_cpu_to_le16(cardp_usb->udev->descriptor.idProduct) ==
|
woal_cpu_to_le16(cardp_usb->udev->descriptor.idProduct) ==
|
||||||
USB9097_PID_2) {
|
(__force __le16)USB9097_PID_2) {
|
||||||
card_type = CARD_TYPE_USB9097;
|
card_type = CARD_TYPE_USB9097;
|
||||||
moal_memcpy_ext(NULL, driver_version, CARD_USB9097,
|
moal_memcpy_ext(NULL, driver_version, CARD_USBIW620,
|
||||||
strlen(CARD_USB9097), strlen(driver_version));
|
strlen(CARD_USBIW620), strlen(driver_version));
|
||||||
moal_memcpy_ext(NULL,
|
moal_memcpy_ext(NULL,
|
||||||
driver_version + strlen(INTF_CARDTYPE) +
|
driver_version + strlen(INTF_CARDTYPE) +
|
||||||
strlen(KERN_VERSION),
|
strlen(KERN_VERSION),
|
||||||
|
@ -824,33 +824,33 @@ static int woal_usb_probe(struct usb_interface *intf,
|
||||||
/* Check probe is for our device */
|
/* Check probe is for our device */
|
||||||
for (i = 0; woal_usb_table[i].idVendor; i++) {
|
for (i = 0; woal_usb_table[i].idVendor; i++) {
|
||||||
if (woal_cpu_to_le16(udev->descriptor.idVendor) ==
|
if (woal_cpu_to_le16(udev->descriptor.idVendor) ==
|
||||||
woal_usb_table[i].idVendor &&
|
(__force __le16)woal_usb_table[i].idVendor &&
|
||||||
woal_cpu_to_le16(udev->descriptor.idProduct) ==
|
woal_cpu_to_le16(udev->descriptor.idProduct) ==
|
||||||
woal_usb_table[i].idProduct) {
|
(__force __le16)woal_usb_table[i].idProduct) {
|
||||||
PRINTM(MMSG, "VID/PID = %X/%X, Boot2 version = %X\n",
|
PRINTM(MMSG, "VID/PID = %X/%X, Boot2 version = %X\n",
|
||||||
woal_cpu_to_le16(udev->descriptor.idVendor),
|
woal_cpu_to_le16(udev->descriptor.idVendor),
|
||||||
woal_cpu_to_le16(udev->descriptor.idProduct),
|
woal_cpu_to_le16(udev->descriptor.idProduct),
|
||||||
woal_cpu_to_le16(udev->descriptor.bcdDevice));
|
woal_cpu_to_le16(udev->descriptor.bcdDevice));
|
||||||
switch (woal_cpu_to_le16(udev->descriptor.idProduct)) {
|
switch (woal_cpu_to_le16(udev->descriptor.idProduct)) {
|
||||||
#ifdef USB8801
|
#ifdef USB8801
|
||||||
case USB8801_PID_1:
|
case (__force __le16)USB8801_PID_1:
|
||||||
#endif /* USB8801 */
|
#endif /* USB8801 */
|
||||||
#ifdef USB8897
|
#ifdef USB8897
|
||||||
case USB8897_PID_1:
|
case (__force __le16)USB8897_PID_1:
|
||||||
#endif /* USB8897 */
|
#endif /* USB8897 */
|
||||||
#ifdef USB8997
|
#ifdef USB8997
|
||||||
case USB8997_PID_1:
|
case (__force __le16)USB8997_PID_1:
|
||||||
case USB8997V2_PID_1:
|
case (__force __le16)USB8997V2_PID_1:
|
||||||
#endif /* USB8997 */
|
#endif /* USB8997 */
|
||||||
#ifdef USB8978
|
#ifdef USB8978
|
||||||
case USB8978_PID_1:
|
case (__force __le16)USB8978_PID_1:
|
||||||
case USB8978_PID_1_BT:
|
case (__force __le16)USB8978_PID_1_BT:
|
||||||
#endif /* USB8978 */
|
#endif /* USB8978 */
|
||||||
#ifdef USB9098
|
#ifdef USB9098
|
||||||
case USB9098_PID_1:
|
case (__force __le16)USB9098_PID_1:
|
||||||
#endif /* USB9098 */
|
#endif /* USB9098 */
|
||||||
#ifdef USB9097
|
#ifdef USB9097
|
||||||
case USB9097_PID_1:
|
case (__force __le16)USB9097_PID_1:
|
||||||
#endif /* USB9097 */
|
#endif /* USB9097 */
|
||||||
/* If skip FW is set, we must return error so
|
/* If skip FW is set, we must return error so
|
||||||
* the next driver can download the FW */
|
* the next driver can download the FW */
|
||||||
|
@ -860,23 +860,23 @@ static int woal_usb_probe(struct usb_interface *intf,
|
||||||
usb_cardp->boot_state = USB_FW_DNLD;
|
usb_cardp->boot_state = USB_FW_DNLD;
|
||||||
break;
|
break;
|
||||||
#ifdef USB8801
|
#ifdef USB8801
|
||||||
case USB8801_PID_2:
|
case (__force __le16)USB8801_PID_2:
|
||||||
#endif /* USB8801 */
|
#endif /* USB8801 */
|
||||||
#ifdef USB8897
|
#ifdef USB8897
|
||||||
case USB8897_PID_2:
|
case (__force __le16)USB8897_PID_2:
|
||||||
#endif /* USB8897 */
|
#endif /* USB8897 */
|
||||||
#ifdef USB8997
|
#ifdef USB8997
|
||||||
case USB8997_PID_2:
|
case (__force __le16)USB8997_PID_2:
|
||||||
#endif /* USB8997 */
|
#endif /* USB8997 */
|
||||||
#ifdef USB8978
|
#ifdef USB8978
|
||||||
case USB8978_PID_2:
|
case (__force __le16)USB8978_PID_2:
|
||||||
case USB8978_PID_2_BT:
|
case (__force __le16)USB8978_PID_2_BT:
|
||||||
#endif /* USB8978 */
|
#endif /* USB8978 */
|
||||||
#ifdef USB9098
|
#ifdef USB9098
|
||||||
case USB9098_PID_2:
|
case (__force __le16)USB9098_PID_2:
|
||||||
#endif /* USB9098 */
|
#endif /* USB9098 */
|
||||||
#ifdef USB9097
|
#ifdef USB9097
|
||||||
case USB9097_PID_2:
|
case (__force __le16)USB9097_PID_2:
|
||||||
#endif /* USB9097 */
|
#endif /* USB9097 */
|
||||||
usb_cardp->boot_state = USB_FW_READY;
|
usb_cardp->boot_state = USB_FW_READY;
|
||||||
break;
|
break;
|
||||||
|
@ -964,7 +964,7 @@ static int woal_usb_probe(struct usb_interface *intf,
|
||||||
endpoint->bEndpointAddress;
|
endpoint->bEndpointAddress;
|
||||||
atomic_set(&usb_cardp->tx_data_urb_pending, 0);
|
atomic_set(&usb_cardp->tx_data_urb_pending, 0);
|
||||||
usb_cardp->tx_data_maxpktsize =
|
usb_cardp->tx_data_maxpktsize =
|
||||||
woal_le16_to_cpu(
|
(__force int)woal_le16_to_cpu(
|
||||||
endpoint->wMaxPacketSize);
|
endpoint->wMaxPacketSize);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -988,7 +988,8 @@ static int woal_usb_probe(struct usb_interface *intf,
|
||||||
usb_cardp->tx_cmd_ep =
|
usb_cardp->tx_cmd_ep =
|
||||||
endpoint->bEndpointAddress;
|
endpoint->bEndpointAddress;
|
||||||
atomic_set(&usb_cardp->tx_cmd_urb_pending, 0);
|
atomic_set(&usb_cardp->tx_cmd_urb_pending, 0);
|
||||||
usb_cardp->tx_cmd_maxpktsize = woal_le16_to_cpu(
|
usb_cardp->tx_cmd_maxpktsize =
|
||||||
|
(__force int)woal_le16_to_cpu(
|
||||||
endpoint->wMaxPacketSize);
|
endpoint->wMaxPacketSize);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,7 +4,7 @@
|
||||||
* driver.
|
* driver.
|
||||||
*
|
*
|
||||||
*
|
*
|
||||||
* Copyright 2008-2020 NXP
|
* Copyright 2008-2021 NXP
|
||||||
*
|
*
|
||||||
* This software file (the File) is distributed by NXP
|
* This software file (the File) is distributed by NXP
|
||||||
* under the terms of the GNU General Public License Version 2, June 1991
|
* under the terms of the GNU General Public License Version 2, June 1991
|
||||||
|
@ -127,10 +127,10 @@ Change Log:
|
||||||
#endif /* USB8997 */
|
#endif /* USB8997 */
|
||||||
|
|
||||||
#ifdef USB8978
|
#ifdef USB8978
|
||||||
#define USB8978_DEFAULT_COMBO_FW_NAME "nxp/usbusb8978_combo.bin"
|
#define USB8978_DEFAULT_COMBO_FW_NAME "nxp/usbusbiw416_combo.bin"
|
||||||
#define USB8978_DEFAULT_WLAN_FW_NAME "nxp/usb8978_wlan.bin"
|
#define USB8978_DEFAULT_WLAN_FW_NAME "nxp/usbiw416_wlan.bin"
|
||||||
#define USBUART8978_DEFAULT_COMBO_FW_NAME "nxp/usbuart8978_combo.bin"
|
#define USBUART8978_DEFAULT_COMBO_FW_NAME "nxp/usbuartiw416_combo.bin"
|
||||||
#define USBUSB8978_DEFAULT_COMBO_FW_NAME "nxp/usbusb8978_combo.bin"
|
#define USBUSB8978_DEFAULT_COMBO_FW_NAME "nxp/usbusbiw416_combo.bin"
|
||||||
#endif /* USB8978 */
|
#endif /* USB8978 */
|
||||||
|
|
||||||
#ifdef USB8897
|
#ifdef USB8897
|
||||||
|
@ -155,11 +155,11 @@ Change Log:
|
||||||
#ifdef USB9097
|
#ifdef USB9097
|
||||||
#define USB9097_B0 0x01
|
#define USB9097_B0 0x01
|
||||||
#define USB9097_B1 0x02
|
#define USB9097_B1 0x02
|
||||||
#define USB9097_DEFAULT_COMBO_FW_NAME "nxp/usbusb9097_combo_v1.bin"
|
#define USB9097_DEFAULT_COMBO_FW_NAME "nxp/usbusbiw620_combo_v1.bin"
|
||||||
#define USB9097_DEFAULT_WLAN_FW_NAME "nxp/usb9097_wlan_v1.bin"
|
#define USB9097_DEFAULT_WLAN_FW_NAME "nxp/usbiw620_wlan_v1.bin"
|
||||||
#define USB9097_WLAN_V1_FW_NAME "nxp/usb9097_wlan_v1.bin"
|
#define USB9097_WLAN_V1_FW_NAME "nxp/usbiw620_wlan_v1.bin"
|
||||||
#define USBUART9097_COMBO_V1_FW_NAME "nxp/usbuart9097_combo_v1.bin"
|
#define USBUART9097_COMBO_V1_FW_NAME "nxp/usbuartiw620_combo_v1.bin"
|
||||||
#define USBUSB9097_COMBO_V1_FW_NAME "nxp/usbusb9097_combo_v1.bin"
|
#define USBUSB9097_COMBO_V1_FW_NAME "nxp/usbusbiw620_combo_v1.bin"
|
||||||
#endif /* USB9097 */
|
#endif /* USB9097 */
|
||||||
|
|
||||||
/** urb context */
|
/** urb context */
|
||||||
|
|
|
@ -34,6 +34,203 @@ Change log:
|
||||||
IW_EV_FREQ_LEN + IW_EV_QUAL_LEN + MLAN_MAX_SSID_LENGTH + \
|
IW_EV_FREQ_LEN + IW_EV_QUAL_LEN + MLAN_MAX_SSID_LENGTH + \
|
||||||
IW_EV_PARAM_LEN + 40) /* 40 for WPAIE */
|
IW_EV_PARAM_LEN + 40) /* 40 for WPAIE */
|
||||||
|
|
||||||
|
/********************************************************
|
||||||
|
Local Variables
|
||||||
|
********************************************************/
|
||||||
|
/**
|
||||||
|
* iwpriv ioctl handlers
|
||||||
|
*/
|
||||||
|
static const struct iw_priv_args woal_private_args[] = {
|
||||||
|
{WOAL_SETONEINT_GETWORDCHAR, IW_PRIV_TYPE_INT | 1,
|
||||||
|
IW_PRIV_TYPE_CHAR | 128, ""},
|
||||||
|
{WOAL_VERSION, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_CHAR | 128,
|
||||||
|
"version"},
|
||||||
|
{WOAL_VEREXT, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_CHAR | 128, "verext"},
|
||||||
|
{WOAL_SETNONE_GETNONE, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_NONE, ""},
|
||||||
|
{WOAL_WARMRESET, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_NONE, "warmreset"},
|
||||||
|
#ifdef CONFIG_USB_SUSPEND
|
||||||
|
{WOAL_USB_SUSPEND, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_NONE, "usbsuspend"},
|
||||||
|
{WOAL_USB_RESUME, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_NONE, "usbresume"},
|
||||||
|
#endif /* CONFIG_USB_SUSPEND */
|
||||||
|
{WOAL_SETONEINT_GETONEINT, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_INT | 1,
|
||||||
|
""},
|
||||||
|
{WOAL_SET_GET_TXRATE, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_INT | 1,
|
||||||
|
"txratecfg"},
|
||||||
|
{WOAL_SET_GET_REGIONCODE, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_INT | 1,
|
||||||
|
"regioncode"},
|
||||||
|
{WOAL_SET_RADIO, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_INT | 1,
|
||||||
|
"radioctrl"},
|
||||||
|
{WOAL_WMM_ENABLE, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_INT | 1, "wmmcfg"},
|
||||||
|
{WOAL_11D_ENABLE, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_INT | 1, "11dcfg"},
|
||||||
|
{WOAL_11D_CLR_CHAN_TABLE, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_NONE,
|
||||||
|
"11dclrtbl"},
|
||||||
|
{WOAL_SET_GET_QOS_CFG, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_INT | 1,
|
||||||
|
"qoscfg"},
|
||||||
|
#ifndef OPCHAN
|
||||||
|
{WOAL_SET_GET_WWS_CFG, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_INT | 1,
|
||||||
|
"wwscfg"},
|
||||||
|
#endif
|
||||||
|
#if defined(REASSOCIATION)
|
||||||
|
{WOAL_SET_GET_REASSOC, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_INT | 1,
|
||||||
|
"reassoctrl"},
|
||||||
|
#endif
|
||||||
|
{WOAL_TXBUF_CFG, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_INT | 1,
|
||||||
|
"txbufcfg"},
|
||||||
|
{WOAL_SLEEP_PD, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_INT | 1, "sleeppd"},
|
||||||
|
{WOAL_AUTH_TYPE, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_INT | 1,
|
||||||
|
"authtype"},
|
||||||
|
{WOAL_PORT_CTRL, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_INT | 1,
|
||||||
|
"port_ctrl"},
|
||||||
|
#ifdef WIFI_DIRECT_SUPPORT
|
||||||
|
#if defined(STA_SUPPORT) && defined(UAP_SUPPORT)
|
||||||
|
{WOAL_SET_GET_BSS_ROLE, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_INT | 1,
|
||||||
|
"bssrole"},
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
{WOAL_SET_GET_11H_LOCAL_PWR_CONSTRAINT, IW_PRIV_TYPE_INT | 1,
|
||||||
|
IW_PRIV_TYPE_INT | 1, "powercons"},
|
||||||
|
{WOAL_HT_STREAM_CFG, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_INT | 1,
|
||||||
|
"htstreamcfg"},
|
||||||
|
{WOAL_MAC_CONTROL, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_INT | 1,
|
||||||
|
"macctrl"},
|
||||||
|
{WOAL_THERMAL, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_INT | 1, "thermal"},
|
||||||
|
{WOAL_CFG_HOTSPOT, IW_PRIV_TYPE_INT | 1, IW_PRIV_TYPE_INT | 1,
|
||||||
|
"hotspotcfg"},
|
||||||
|
{WOAL_SET_GET_SIXTEEN_INT, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
||||||
|
""},
|
||||||
|
{WOAL_TX_POWERCFG, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
||||||
|
"txpowercfg"},
|
||||||
|
#ifdef DEBUG_LEVEL1
|
||||||
|
{WOAL_DRV_DBG, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16, "drvdbg"},
|
||||||
|
#endif
|
||||||
|
{WOAL_BEACON_INTERVAL, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
||||||
|
"bcninterval"},
|
||||||
|
{WOAL_SIGNAL, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
||||||
|
"getsignal"},
|
||||||
|
{
|
||||||
|
WOAL_DEEP_SLEEP,
|
||||||
|
IW_PRIV_TYPE_INT | 16,
|
||||||
|
IW_PRIV_TYPE_INT | 16,
|
||||||
|
"deepsleep",
|
||||||
|
},
|
||||||
|
{WOAL_11N_TX_CFG, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
||||||
|
"httxcfg"},
|
||||||
|
{WOAL_11N_HTCAP_CFG, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
||||||
|
"htcapinfo"},
|
||||||
|
{WOAL_PRIO_TBL, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
||||||
|
"aggrpriotbl"},
|
||||||
|
{WOAL_11N_AMSDU_AGGR_CTRL, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
||||||
|
"amsduaggrctrl"},
|
||||||
|
{WOAL_ADDBA_UPDT, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
||||||
|
"addbapara"},
|
||||||
|
{WOAL_ADDBA_REJECT, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
||||||
|
"addbareject"},
|
||||||
|
{WOAL_TX_BF_CAP, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
||||||
|
"httxbfcap"},
|
||||||
|
{WOAL_HS_CFG, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16, "hscfg"},
|
||||||
|
{WOAL_HS_SETPARA, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
||||||
|
"hssetpara"},
|
||||||
|
{WOAL_REG_READ_WRITE, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
||||||
|
"regrdwr"},
|
||||||
|
{WOAL_BAND_CFG, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
||||||
|
"bandcfg"},
|
||||||
|
{WOAL_INACTIVITY_TIMEOUT_EXT, IW_PRIV_TYPE_INT | 16,
|
||||||
|
IW_PRIV_TYPE_INT | 16, "inactivityto"},
|
||||||
|
#ifdef SDIO
|
||||||
|
{WOAL_SDIO_CLOCK, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
||||||
|
"sdioclock"},
|
||||||
|
{WOAL_CMD_52RDWR, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
||||||
|
"sdcmd52rw"},
|
||||||
|
#endif
|
||||||
|
{WOAL_SCAN_CFG, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
||||||
|
"scancfg"},
|
||||||
|
{WOAL_PS_CFG, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16, "pscfg"},
|
||||||
|
{WOAL_MEM_READ_WRITE, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
||||||
|
"memrdwr"},
|
||||||
|
#ifdef SDIO
|
||||||
|
{WOAL_SDIO_MPA_CTRL, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
||||||
|
"mpactrl"},
|
||||||
|
#endif
|
||||||
|
{WOAL_SLEEP_PARAMS, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
||||||
|
"sleepparams"},
|
||||||
|
{WOAL_DFS_TESTING, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
||||||
|
"dfstesting"},
|
||||||
|
{WOAL_MGMT_FRAME_CTRL, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
||||||
|
"mgmtframectrl"},
|
||||||
|
{WOAL_CFP_CODE, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
||||||
|
"cfpcode"},
|
||||||
|
{WOAL_SET_GET_TX_RX_ANT, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
||||||
|
"antcfg"},
|
||||||
|
{WOAL_IND_RST_CFG, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_INT | 16,
|
||||||
|
"indrstcfg"},
|
||||||
|
{WOALGETLOG, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_CHAR | GETLOG_BUFSIZE,
|
||||||
|
"getlog"},
|
||||||
|
{WOAL_SETADDR_GETNONE, IW_PRIV_TYPE_ADDR | 1, IW_PRIV_TYPE_NONE, ""},
|
||||||
|
{WOAL_DEAUTH, IW_PRIV_TYPE_ADDR | 1, IW_PRIV_TYPE_NONE, "deauth"},
|
||||||
|
{WOAL_SET_GET_256_CHAR, IW_PRIV_TYPE_CHAR | 256,
|
||||||
|
IW_PRIV_TYPE_CHAR | 256, ""},
|
||||||
|
{WOAL_PASSPHRASE, IW_PRIV_TYPE_CHAR | 256, IW_PRIV_TYPE_CHAR | 256,
|
||||||
|
"passphrase"},
|
||||||
|
{WOAL_GET_KEY, IW_PRIV_TYPE_CHAR | 256, IW_PRIV_TYPE_CHAR | 256,
|
||||||
|
"getkey"},
|
||||||
|
{WOAL_ASSOCIATE, IW_PRIV_TYPE_CHAR | 256, IW_PRIV_TYPE_CHAR | 256,
|
||||||
|
"associate"},
|
||||||
|
{WOAL_WMM_QUEUE_STATUS, IW_PRIV_TYPE_CHAR | 256,
|
||||||
|
IW_PRIV_TYPE_CHAR | 256, "qstatus"},
|
||||||
|
{WOAL_WMM_TS_STATUS, IW_PRIV_TYPE_CHAR | 256, IW_PRIV_TYPE_CHAR | 256,
|
||||||
|
"ts_status"},
|
||||||
|
{WOAL_IP_ADDRESS, IW_PRIV_TYPE_CHAR | 256, IW_PRIV_TYPE_CHAR | 256,
|
||||||
|
"ipaddr"},
|
||||||
|
{WOAL_TX_BF_CFG, IW_PRIV_TYPE_CHAR | 256, IW_PRIV_TYPE_CHAR | 256,
|
||||||
|
"httxbfcfg"},
|
||||||
|
{WOAL_SETNONE_GETTWELVE_CHAR, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_CHAR | 12,
|
||||||
|
""},
|
||||||
|
{WOAL_WPS_SESSION, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_CHAR | 12,
|
||||||
|
"wpssession"},
|
||||||
|
{WOAL_SETNONE_GET_FOUR_INT, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_INT | 4,
|
||||||
|
""},
|
||||||
|
{WOAL_DATA_RATE, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_INT | 4,
|
||||||
|
"getdatarate"},
|
||||||
|
{WOAL_ESUPP_MODE, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_INT | 4, "esuppmode"},
|
||||||
|
{WOAL_SET_GET_64_INT, IW_PRIV_TYPE_INT | 64, IW_PRIV_TYPE_INT | 64, ""},
|
||||||
|
{WOAL_ECL_SYS_CLOCK, IW_PRIV_TYPE_INT | 64, IW_PRIV_TYPE_INT | 64,
|
||||||
|
"sysclock"},
|
||||||
|
{WOAL_HOST_CMD, IW_PRIV_TYPE_BYTE | 2047, IW_PRIV_TYPE_BYTE | 2047,
|
||||||
|
"hostcmd"},
|
||||||
|
{WOAL_SET_INTS_GET_CHARS, IW_PRIV_TYPE_INT | 16,
|
||||||
|
IW_PRIV_TYPE_BYTE | 256, ""},
|
||||||
|
{WOAL_READ_EEPROM, IW_PRIV_TYPE_INT | 16, IW_PRIV_TYPE_BYTE | 256,
|
||||||
|
"rdeeprom"},
|
||||||
|
{WOAL_SET_GET_2K_BYTES, IW_PRIV_TYPE_BYTE | WOAL_2K_BYTES,
|
||||||
|
IW_PRIV_TYPE_BYTE | WOAL_2K_BYTES, ""},
|
||||||
|
#if defined(SDIO)
|
||||||
|
{WOAL_CMD_53RDWR, IW_PRIV_TYPE_BYTE | WOAL_2K_BYTES,
|
||||||
|
IW_PRIV_TYPE_BYTE | WOAL_2K_BYTES, "sdcmd53rw"},
|
||||||
|
#endif
|
||||||
|
{WOAL_SET_USER_SCAN, IW_PRIV_TYPE_BYTE | WOAL_2K_BYTES,
|
||||||
|
IW_PRIV_TYPE_BYTE | WOAL_2K_BYTES, "setuserscan"},
|
||||||
|
{WOAL_GET_SCAN_TABLE, IW_PRIV_TYPE_BYTE | WOAL_2K_BYTES,
|
||||||
|
IW_PRIV_TYPE_BYTE | WOAL_2K_BYTES, "getscantable"},
|
||||||
|
{WOAL_SET_USER_SCAN_EXT, IW_PRIV_TYPE_BYTE | WOAL_2K_BYTES,
|
||||||
|
IW_PRIV_TYPE_BYTE | WOAL_2K_BYTES, "setuserscanext"},
|
||||||
|
{WOAL_WMM_ADDTS, IW_PRIV_TYPE_BYTE | WOAL_2K_BYTES,
|
||||||
|
IW_PRIV_TYPE_BYTE | WOAL_2K_BYTES, "addts"},
|
||||||
|
{WOAL_WMM_DELTS, IW_PRIV_TYPE_BYTE | WOAL_2K_BYTES,
|
||||||
|
IW_PRIV_TYPE_BYTE | WOAL_2K_BYTES, "delts"},
|
||||||
|
{WOAL_WMM_QUEUE_CONFIG, IW_PRIV_TYPE_BYTE | WOAL_2K_BYTES,
|
||||||
|
IW_PRIV_TYPE_BYTE | WOAL_2K_BYTES, "qconfig"},
|
||||||
|
{WOAL_WMM_QUEUE_STATS, IW_PRIV_TYPE_BYTE | WOAL_2K_BYTES,
|
||||||
|
IW_PRIV_TYPE_BYTE | WOAL_2K_BYTES, "qstats"},
|
||||||
|
{WOAL_BYPASSED_PACKET, IW_PRIV_TYPE_BYTE | WOAL_2K_BYTES,
|
||||||
|
IW_PRIV_TYPE_BYTE | WOAL_2K_BYTES, "pb_bypass"},
|
||||||
|
#ifdef UAP_WEXT
|
||||||
|
{WOAL_FROYO_START, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_NONE, "START"},
|
||||||
|
{WOAL_FROYO_STOP, IW_PRIV_TYPE_NONE, IW_PRIV_TYPE_NONE, "STOP"},
|
||||||
|
{WOAL_FROYO_WL_FW_RELOAD, IW_PRIV_TYPE_CHAR | 256,
|
||||||
|
IW_PRIV_TYPE_CHAR | 256, "WL_FW_RELOAD"},
|
||||||
|
#endif
|
||||||
|
};
|
||||||
|
|
||||||
/********************************************************
|
/********************************************************
|
||||||
Local Functions
|
Local Functions
|
||||||
********************************************************/
|
********************************************************/
|
||||||
|
|
Loading…
Reference in a new issue