mirror of
https://github.com/nxp-imx/mwifiex.git
synced 2025-01-26 21:40:08 +00:00
MA-20857 WCS MM5X17366 - Q4-2022 RC1 patch integrate
Reason: WiFi driver integrate Test: on i.MX8MQ with 9098 module Change-Id: I85fd1d140e529fe055209f1aca24b57f494a1d02 Signed-off-by: yunjie <yunjie.jia@nxp.com>
This commit is contained in:
parent
ecb4c6f27f
commit
b75d3eed93
24 changed files with 1148 additions and 194 deletions
mxm_wifiex/wlan_src
|
@ -1,27 +1,19 @@
|
||||||
# File: Makefile
|
# File: Makefile
|
||||||
#
|
#
|
||||||
# Copyright 2014-2022 NXP
|
# Copyright 2008-2022 NXP
|
||||||
#
|
#
|
||||||
# NXP CONFIDENTIAL
|
# This software file (the File) is distributed by NXP
|
||||||
# The source code contained or described herein and all documents related to
|
# under the terms of the GNU General Public License Version 2, June 1991
|
||||||
# the source code (Materials) are owned by NXP, its
|
# (the License). You may use, redistribute and/or modify the File in
|
||||||
# suppliers and/or its licensors. Title to the Materials remains with NXP,
|
# accordance with the terms and conditions of the License, a copy of which
|
||||||
# its suppliers and/or its licensors. The Materials contain
|
# is available by writing to the Free Software Foundation, Inc.,
|
||||||
# trade secrets and proprietary and confidential information of NXP, its
|
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA or on the
|
||||||
# suppliers and/or its licensors. The Materials are protected by worldwide copyright
|
# worldwide web at http://www.gnu.org/licenses/old-licenses/gpl-2.0.txt.
|
||||||
# and trade secret laws and treaty provisions. No part of the Materials may be
|
|
||||||
# used, copied, reproduced, modified, published, uploaded, posted,
|
|
||||||
# transmitted, distributed, or disclosed in any way without NXP's prior
|
|
||||||
# express written permission.
|
|
||||||
#
|
#
|
||||||
# No license under any patent, copyright, trade secret or other intellectual
|
# THE FILE IS DISTRIBUTED AS-IS, WITHOUT WARRANTY OF ANY KIND, AND THE
|
||||||
# property right is granted to or conferred upon you by disclosure or delivery
|
# IMPLIED WARRANTIES OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE
|
||||||
# of the Materials, either expressly, by implication, inducement, estoppel or
|
# ARE EXPRESSLY DISCLAIMED. The License provides additional details about
|
||||||
# otherwise. Any license under such intellectual property rights must be
|
# this warranty disclaimer.
|
||||||
# express and approved by NXP in writing.
|
|
||||||
#
|
|
||||||
# Alternatively, this software may be distributed under the terms of GPL v2.
|
|
||||||
# SPDX-License-Identifier: GPL-2.0
|
|
||||||
#
|
#
|
||||||
|
|
||||||
CONFIG_COMPATDIR=n
|
CONFIG_COMPATDIR=n
|
||||||
|
@ -93,6 +85,9 @@ CONFIG_MFG_CMD_SUPPORT=y
|
||||||
# OpenWrt support
|
# OpenWrt support
|
||||||
CONFIG_OPENWRT_SUPPORT=n
|
CONFIG_OPENWRT_SUPPORT=n
|
||||||
|
|
||||||
|
# Big-endian platform
|
||||||
|
CONFIG_BIG_ENDIAN=n
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
ifeq ($(CONFIG_DRV_EMBEDDED_SUPPLICANT), y)
|
ifeq ($(CONFIG_DRV_EMBEDDED_SUPPLICANT), y)
|
||||||
|
@ -135,6 +130,9 @@ ARCH ?= arm64
|
||||||
CONFIG_IMX_SUPPORT=y
|
CONFIG_IMX_SUPPORT=y
|
||||||
ifeq ($(CONFIG_IMX_SUPPORT),y)
|
ifeq ($(CONFIG_IMX_SUPPORT),y)
|
||||||
ccflags-y += -DIMX_SUPPORT
|
ccflags-y += -DIMX_SUPPORT
|
||||||
|
ifneq ($(ANDROID_PRODUCT_OUT),)
|
||||||
|
ccflags-y += -DIMX_ANDROID
|
||||||
|
endif
|
||||||
endif
|
endif
|
||||||
KERNELDIR ?= /usr/src/arm/linux_5_10_y_kernel/linux-nxp
|
KERNELDIR ?= /usr/src/arm/linux_5_10_y_kernel/linux-nxp
|
||||||
CROSS_COMPILE ?= /opt/fsl-imx-internal-xwayland/5.10-gatesgarth/sysroots/x86_64-pokysdk-linux/usr/bin/aarch64-poky-linux/aarch64-poky-linux-
|
CROSS_COMPILE ?= /opt/fsl-imx-internal-xwayland/5.10-gatesgarth/sysroots/x86_64-pokysdk-linux/usr/bin/aarch64-poky-linux/aarch64-poky-linux-
|
||||||
|
@ -193,6 +191,10 @@ ifeq ($(CONFIG_MFG_CMD_SUPPORT),y)
|
||||||
ccflags-y += -DMFG_CMD_SUPPORT
|
ccflags-y += -DMFG_CMD_SUPPORT
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
ifeq ($(CONFIG_BIG_ENDIAN),y)
|
||||||
|
ccflags-y += -DBIG_ENDIAN_SUPPORT
|
||||||
|
endif
|
||||||
|
|
||||||
ifeq ($(CONFIG_USERSPACE_32BIT_OVER_KERNEL_64BIT),y)
|
ifeq ($(CONFIG_USERSPACE_32BIT_OVER_KERNEL_64BIT),y)
|
||||||
ccflags-y += -DUSERSPACE_32BIT_OVER_KERNEL_64BIT
|
ccflags-y += -DUSERSPACE_32BIT_OVER_KERNEL_64BIT
|
||||||
endif
|
endif
|
||||||
|
|
|
@ -2903,11 +2903,13 @@ t_s32 wlan_11h_process_join(mlan_private *priv, t_u8 **ppbuffer,
|
||||||
priv, ppbuffer, band, channel, p11h_bss_info);
|
priv, ppbuffer, band, channel, p11h_bss_info);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
if (pcap_info->ibss) {
|
||||||
/* Deactivate 11h functions in the firmware */
|
/* Deactivate 11h functions in the firmware */
|
||||||
wlan_11h_activate(priv, MNULL, MFALSE);
|
wlan_11h_activate(priv, MNULL, MFALSE);
|
||||||
pcap_info->spectrum_mgmt = MFALSE;
|
pcap_info->spectrum_mgmt = MFALSE;
|
||||||
wlan_11h_check_update_radar_det_state(priv);
|
wlan_11h_check_update_radar_det_state(priv);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
LEAVE();
|
LEAVE();
|
||||||
return ret;
|
return ret;
|
||||||
|
|
|
@ -24,7 +24,7 @@
|
||||||
#define _MLAN_DECL_H_
|
#define _MLAN_DECL_H_
|
||||||
|
|
||||||
/** MLAN release version */
|
/** MLAN release version */
|
||||||
#define MLAN_RELEASE_VERSION "362"
|
#define MLAN_RELEASE_VERSION "366"
|
||||||
|
|
||||||
/** Re-define generic data types for MLAN/MOAL */
|
/** Re-define generic data types for MLAN/MOAL */
|
||||||
/** Signed char (1-byte) */
|
/** Signed char (1-byte) */
|
||||||
|
@ -967,6 +967,16 @@ typedef enum _dfs_moe_t {
|
||||||
|
|
||||||
/** Band_Config_t */
|
/** Band_Config_t */
|
||||||
typedef MLAN_PACK_START struct _Band_Config_t {
|
typedef MLAN_PACK_START struct _Band_Config_t {
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
/** Channel Selection Mode - (00)=manual, (01)=ACS, (02)=user*/
|
||||||
|
t_u8 scanMode : 2;
|
||||||
|
/** Secondary Channel Offset - (00)=None, (01)=Above, (11)=Below */
|
||||||
|
t_u8 chan2Offset : 2;
|
||||||
|
/** Channel Width - (00)=20MHz, (10)=40MHz, (11)=80MHz */
|
||||||
|
t_u8 chanWidth : 2;
|
||||||
|
/** Band Info - (00)=2.4GHz, (01)=5GHz */
|
||||||
|
t_u8 chanBand : 2;
|
||||||
|
#else
|
||||||
/** Band Info - (00)=2.4GHz, (01)=5GHz */
|
/** Band Info - (00)=2.4GHz, (01)=5GHz */
|
||||||
t_u8 chanBand : 2;
|
t_u8 chanBand : 2;
|
||||||
/** Channel Width - (00)=20MHz, (10)=40MHz, (11)=80MHz */
|
/** Channel Width - (00)=20MHz, (10)=40MHz, (11)=80MHz */
|
||||||
|
@ -975,6 +985,7 @@ typedef MLAN_PACK_START struct _Band_Config_t {
|
||||||
t_u8 chan2Offset : 2;
|
t_u8 chan2Offset : 2;
|
||||||
/** Channel Selection Mode - (00)=manual, (01)=ACS, (02)=Adoption mode*/
|
/** Channel Selection Mode - (00)=manual, (01)=ACS, (02)=Adoption mode*/
|
||||||
t_u8 scanMode : 2;
|
t_u8 scanMode : 2;
|
||||||
|
#endif
|
||||||
} MLAN_PACK_END Band_Config_t;
|
} MLAN_PACK_END Band_Config_t;
|
||||||
|
|
||||||
/** channel_band_t */
|
/** channel_band_t */
|
||||||
|
@ -1176,6 +1187,16 @@ typedef MLAN_PACK_START struct _radiotap_info {
|
||||||
|
|
||||||
/** txpower structure */
|
/** txpower structure */
|
||||||
typedef MLAN_PACK_START struct {
|
typedef MLAN_PACK_START struct {
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
/** Host tx power ctrl:
|
||||||
|
0x0: use fw setting for TX power
|
||||||
|
0x1: value specified in bit[6] and bit[5:0] are valid */
|
||||||
|
t_u8 hostctl : 1;
|
||||||
|
/** Sign of the power specified in bit[5:0] */
|
||||||
|
t_u8 sign : 1;
|
||||||
|
/** Power to be used for transmission(in dBm) */
|
||||||
|
t_u8 abs_val : 6;
|
||||||
|
#else
|
||||||
/** Power to be used for transmission(in dBm) */
|
/** Power to be used for transmission(in dBm) */
|
||||||
t_u8 abs_val : 6;
|
t_u8 abs_val : 6;
|
||||||
/** Sign of the power specified in bit[5:0] */
|
/** Sign of the power specified in bit[5:0] */
|
||||||
|
@ -1184,6 +1205,7 @@ typedef MLAN_PACK_START struct {
|
||||||
0x0: use fw setting for TX power
|
0x0: use fw setting for TX power
|
||||||
0x1: value specified in bit[6] and bit[5:0] are valid */
|
0x1: value specified in bit[6] and bit[5:0] are valid */
|
||||||
t_u8 hostctl : 1;
|
t_u8 hostctl : 1;
|
||||||
|
#endif
|
||||||
} MLAN_PACK_END tx_power_t;
|
} MLAN_PACK_END tx_power_t;
|
||||||
/* pkt_txctrl */
|
/* pkt_txctrl */
|
||||||
typedef MLAN_PACK_START struct _pkt_txctrl {
|
typedef MLAN_PACK_START struct _pkt_txctrl {
|
||||||
|
|
|
@ -2266,6 +2266,43 @@ typedef MLAN_PACK_START struct _MrvlIEtypes_TDLS_Idle_Timeout_t {
|
||||||
#define TXPD_RETRY_ENABLE MBIT(12)
|
#define TXPD_RETRY_ENABLE MBIT(12)
|
||||||
|
|
||||||
/** tx_control*/
|
/** tx_control*/
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
typedef MLAN_PACK_START struct _tx_ctrl {
|
||||||
|
/** reserved */
|
||||||
|
t_u32 reserved : 3;
|
||||||
|
/** mc retry packet */
|
||||||
|
t_u32 mc_pkt_retry : 1;
|
||||||
|
/** end of mc AMPDU */
|
||||||
|
t_u32 mc_ampdu_end : 1;
|
||||||
|
/** start of mc AMPDU */
|
||||||
|
t_u32 mc_ampdu_start : 1;
|
||||||
|
/** End of mc cycle */
|
||||||
|
t_u32 mc_cycle_end : 1;
|
||||||
|
/** start of mc cycle */
|
||||||
|
t_u32 mc_cycle_start : 1;
|
||||||
|
/** bw 0-20MHz, 1-40MHz */
|
||||||
|
t_u32 bw : 3;
|
||||||
|
/** Rate used for transmission MCS0-7*/
|
||||||
|
t_u32 tx_rate : 5;
|
||||||
|
/** Control the use of txRate. 0 - use FW setting, 1 - use the specified
|
||||||
|
* txRate;*/
|
||||||
|
t_u32 host_txrate_ctrl : 1;
|
||||||
|
/** 0/1 - use FW setting, 2 - ACK_IMMD, 3 - NO_ACK.*/
|
||||||
|
t_u32 ack_policy : 2;
|
||||||
|
/** Control the use of retryLimit. 0 - use FW setting, 1 - use the
|
||||||
|
* specified retryLimit.*/
|
||||||
|
t_u32 host_retry_ctrl : 1;
|
||||||
|
/** retry limit */
|
||||||
|
t_u32 retry_limit : 4;
|
||||||
|
/** Control the use of txPower. 0 - use FW power setting, 1 - use the
|
||||||
|
* specified txPower.*/
|
||||||
|
t_u32 host_tx_powerctrl : 1;
|
||||||
|
/** Sign of the txPower, 0 - positive_sign(+), 1 - negative_sign(-). */
|
||||||
|
t_u32 tx_power_sign : 1;
|
||||||
|
/** Power used for transmission(in dBm); */
|
||||||
|
t_u32 tx_power : 6;
|
||||||
|
} MLAN_PACK_END tx_ctrl;
|
||||||
|
#else
|
||||||
typedef MLAN_PACK_START struct _tx_ctrl {
|
typedef MLAN_PACK_START struct _tx_ctrl {
|
||||||
/** Power used for transmission(in dBm); */
|
/** Power used for transmission(in dBm); */
|
||||||
t_u32 tx_power : 6;
|
t_u32 tx_power : 6;
|
||||||
|
@ -2301,6 +2338,7 @@ typedef MLAN_PACK_START struct _tx_ctrl {
|
||||||
/** reserved */
|
/** reserved */
|
||||||
t_u32 reserved : 3;
|
t_u32 reserved : 3;
|
||||||
} MLAN_PACK_END tx_ctrl;
|
} MLAN_PACK_END tx_ctrl;
|
||||||
|
#endif
|
||||||
|
|
||||||
/** mc tx ctrl */
|
/** mc tx ctrl */
|
||||||
typedef MLAN_PACK_START struct _mc_tx_ctrl {
|
typedef MLAN_PACK_START struct _mc_tx_ctrl {
|
||||||
|
@ -2383,6 +2421,32 @@ typedef MLAN_PACK_START struct _RxPD {
|
||||||
} MLAN_PACK_END RxPD, *PRxPD;
|
} MLAN_PACK_END RxPD, *PRxPD;
|
||||||
|
|
||||||
/** IEEEtypes_FrameCtl_t*/
|
/** IEEEtypes_FrameCtl_t*/
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
typedef MLAN_PACK_START struct _IEEEtypes_FrameCtl_t {
|
||||||
|
/** Order */
|
||||||
|
t_u8 order : 1;
|
||||||
|
/** Wep */
|
||||||
|
t_u8 wep : 1;
|
||||||
|
/** More Data */
|
||||||
|
t_u8 more_data : 1;
|
||||||
|
/** Power Mgmt */
|
||||||
|
t_u8 pwr_mgmt : 1;
|
||||||
|
/** Retry */
|
||||||
|
t_u8 retry : 1;
|
||||||
|
/** More Frag */
|
||||||
|
t_u8 more_frag : 1;
|
||||||
|
/** From DS */
|
||||||
|
t_u8 from_ds : 1;
|
||||||
|
/** To DS */
|
||||||
|
t_u8 to_ds : 1;
|
||||||
|
/** Sub Type */
|
||||||
|
t_u8 sub_type : 4;
|
||||||
|
/** Type */
|
||||||
|
t_u8 type : 2;
|
||||||
|
/** Protocol Version */
|
||||||
|
t_u8 protocol_version : 2;
|
||||||
|
} MLAN_PACK_END IEEEtypes_FrameCtl_t;
|
||||||
|
#else
|
||||||
typedef MLAN_PACK_START struct _IEEEtypes_FrameCtl_t {
|
typedef MLAN_PACK_START struct _IEEEtypes_FrameCtl_t {
|
||||||
/** Protocol Version */
|
/** Protocol Version */
|
||||||
t_u8 protocol_version : 2;
|
t_u8 protocol_version : 2;
|
||||||
|
@ -2407,6 +2471,7 @@ typedef MLAN_PACK_START struct _IEEEtypes_FrameCtl_t {
|
||||||
/** Order */
|
/** Order */
|
||||||
t_u8 order : 1;
|
t_u8 order : 1;
|
||||||
} MLAN_PACK_END IEEEtypes_FrameCtl_t;
|
} MLAN_PACK_END IEEEtypes_FrameCtl_t;
|
||||||
|
#endif
|
||||||
|
|
||||||
/** MrvlIETypes_MgmtFrameSet_t */
|
/** MrvlIETypes_MgmtFrameSet_t */
|
||||||
typedef MLAN_PACK_START struct _MrvlIETypes_MgmtFrameSet_t {
|
typedef MLAN_PACK_START struct _MrvlIETypes_MgmtFrameSet_t {
|
||||||
|
@ -2517,6 +2582,24 @@ typedef MLAN_PACK_START struct _parsed_region_chan_11d {
|
||||||
|
|
||||||
/** ChanScanMode_t */
|
/** ChanScanMode_t */
|
||||||
typedef MLAN_PACK_START struct _ChanScanMode_t {
|
typedef MLAN_PACK_START struct _ChanScanMode_t {
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
/** Reserved */
|
||||||
|
t_u8 reserved_7 : 1;
|
||||||
|
/** First passive scan then active scan */
|
||||||
|
t_u8 passive_to_active_scan : 1;
|
||||||
|
/** First channel in scan */
|
||||||
|
t_u8 first_chan : 1;
|
||||||
|
/** Enable hidden ssid report */
|
||||||
|
t_u8 hidden_ssid_report : 1;
|
||||||
|
/** Enable probe response timeout */
|
||||||
|
t_u8 rsp_timeout_en : 1;
|
||||||
|
/** Multidomain scan mode */
|
||||||
|
t_u8 multidomain_scan : 1;
|
||||||
|
/** Disble channel filtering flag */
|
||||||
|
t_u8 disable_chan_filt : 1;
|
||||||
|
/** Channel scan mode passive flag */
|
||||||
|
t_u8 passive_scan : 1;
|
||||||
|
#else
|
||||||
/** Channel scan mode passive flag */
|
/** Channel scan mode passive flag */
|
||||||
t_u8 passive_scan : 1;
|
t_u8 passive_scan : 1;
|
||||||
/** Disble channel filtering flag */
|
/** Disble channel filtering flag */
|
||||||
|
@ -2533,6 +2616,7 @@ typedef MLAN_PACK_START struct _ChanScanMode_t {
|
||||||
t_u8 passive_to_active_scan : 1;
|
t_u8 passive_to_active_scan : 1;
|
||||||
/** Reserved */
|
/** Reserved */
|
||||||
t_u8 reserved_7 : 1;
|
t_u8 reserved_7 : 1;
|
||||||
|
#endif
|
||||||
} MLAN_PACK_END ChanScanMode_t;
|
} MLAN_PACK_END ChanScanMode_t;
|
||||||
|
|
||||||
/** ChanScanParamSet_t */
|
/** ChanScanParamSet_t */
|
||||||
|
@ -2989,24 +3073,50 @@ typedef MLAN_PACK_START struct _HostCmd_DS_GTK_REKEY_PARAMS {
|
||||||
|
|
||||||
/** Data structure of WMM QoS information */
|
/** Data structure of WMM QoS information */
|
||||||
typedef MLAN_PACK_START struct _WmmQosInfo_t {
|
typedef MLAN_PACK_START struct _WmmQosInfo_t {
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
/** QoS UAPSD */
|
||||||
|
t_u8 qos_uapsd : 1;
|
||||||
|
/** Reserved */
|
||||||
|
t_u8 reserved : 3;
|
||||||
|
/** Parameter set count */
|
||||||
|
t_u8 para_set_count : 4;
|
||||||
|
#else
|
||||||
/** Parameter set count */
|
/** Parameter set count */
|
||||||
t_u8 para_set_count : 4;
|
t_u8 para_set_count : 4;
|
||||||
/** Reserved */
|
/** Reserved */
|
||||||
t_u8 reserved : 3;
|
t_u8 reserved : 3;
|
||||||
/** QoS UAPSD */
|
/** QoS UAPSD */
|
||||||
t_u8 qos_uapsd : 1;
|
t_u8 qos_uapsd : 1;
|
||||||
|
#endif /* BIG_ENDIAN_SUPPORT */
|
||||||
} MLAN_PACK_END WmmQosInfo_t, *pWmmQosInfo_t;
|
} MLAN_PACK_END WmmQosInfo_t, *pWmmQosInfo_t;
|
||||||
|
|
||||||
/** Data structure of WMM ECW */
|
/** Data structure of WMM ECW */
|
||||||
typedef MLAN_PACK_START struct _WmmEcw_t {
|
typedef MLAN_PACK_START struct _WmmEcw_t {
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
/** Maximum Ecw */
|
||||||
|
t_u8 ecw_max : 4;
|
||||||
|
/** Minimum Ecw */
|
||||||
|
t_u8 ecw_min : 4;
|
||||||
|
#else
|
||||||
/** Minimum Ecw */
|
/** Minimum Ecw */
|
||||||
t_u8 ecw_min : 4;
|
t_u8 ecw_min : 4;
|
||||||
/** Maximum Ecw */
|
/** Maximum Ecw */
|
||||||
t_u8 ecw_max : 4;
|
t_u8 ecw_max : 4;
|
||||||
|
#endif /* BIG_ENDIAN_SUPPORT */
|
||||||
} MLAN_PACK_END WmmEcw_t, *pWmmEcw_t;
|
} MLAN_PACK_END WmmEcw_t, *pWmmEcw_t;
|
||||||
|
|
||||||
/** Data structure of WMM Aci/Aifsn */
|
/** Data structure of WMM Aci/Aifsn */
|
||||||
typedef MLAN_PACK_START struct _WmmAciAifsn_t {
|
typedef MLAN_PACK_START struct _WmmAciAifsn_t {
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
/** Reserved */
|
||||||
|
t_u8 reserved : 1;
|
||||||
|
/** Aci */
|
||||||
|
t_u8 aci : 2;
|
||||||
|
/** Acm */
|
||||||
|
t_u8 acm : 1;
|
||||||
|
/** Aifsn */
|
||||||
|
t_u8 aifsn : 4;
|
||||||
|
#else
|
||||||
/** Aifsn */
|
/** Aifsn */
|
||||||
t_u8 aifsn : 4;
|
t_u8 aifsn : 4;
|
||||||
/** Acm */
|
/** Acm */
|
||||||
|
@ -3015,6 +3125,7 @@ typedef MLAN_PACK_START struct _WmmAciAifsn_t {
|
||||||
t_u8 aci : 2;
|
t_u8 aci : 2;
|
||||||
/** Reserved */
|
/** Reserved */
|
||||||
t_u8 reserved : 1;
|
t_u8 reserved : 1;
|
||||||
|
#endif /* BIG_ENDIAN_SUPPORT */
|
||||||
} MLAN_PACK_END WmmAciAifsn_t, *pWmmAciAifsn_t;
|
} MLAN_PACK_END WmmAciAifsn_t, *pWmmAciAifsn_t;
|
||||||
|
|
||||||
/** Data structure of WMM AC parameters */
|
/** Data structure of WMM AC parameters */
|
||||||
|
@ -5292,9 +5403,15 @@ typedef MLAN_PACK_START struct {
|
||||||
*/
|
*/
|
||||||
typedef MLAN_PACK_START struct {
|
typedef MLAN_PACK_START struct {
|
||||||
mlan_wmm_queue_stats_action_e action; /**< Start, Stop, or Get */
|
mlan_wmm_queue_stats_action_e action; /**< Start, Stop, or Get */
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
t_u8 select_bin : 7; /**< WMM_AC_BK(0) to WMM_AC_VO(3), or TID */
|
||||||
|
t_u8 select_is_userpri : 1; /**< Set if select_bin is UP, Clear for AC
|
||||||
|
*/
|
||||||
|
#else
|
||||||
t_u8 select_is_userpri : 1; /**< Set if select_bin is UP, Clear for AC
|
t_u8 select_is_userpri : 1; /**< Set if select_bin is UP, Clear for AC
|
||||||
*/
|
*/
|
||||||
t_u8 select_bin : 7; /**< WMM_AC_BK(0) to WMM_AC_VO(3), or TID */
|
t_u8 select_bin : 7; /**< WMM_AC_BK(0) to WMM_AC_VO(3), or TID */
|
||||||
|
#endif
|
||||||
t_u16 pkt_count; /**< Number of successful packets transmitted */
|
t_u16 pkt_count; /**< Number of successful packets transmitted */
|
||||||
t_u16 pkt_loss; /**< Packets lost; not included in pktCount */
|
t_u16 pkt_loss; /**< Packets lost; not included in pktCount */
|
||||||
t_u32 avg_queue_delay; /**< Average Queue delay in microsec */
|
t_u32 avg_queue_delay; /**< Average Queue delay in microsec */
|
||||||
|
@ -7145,6 +7262,20 @@ typedef MLAN_PACK_START enum _MeasType_t {
|
||||||
* @brief Mode octet of the measurement request element (7.3.2.21)
|
* @brief Mode octet of the measurement request element (7.3.2.21)
|
||||||
*/
|
*/
|
||||||
typedef MLAN_PACK_START struct {
|
typedef MLAN_PACK_START struct {
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
/**< Reserved */
|
||||||
|
t_u8 rsvd5_7 : 3;
|
||||||
|
/**< 11k: duration spec. for meas. is mandatory */
|
||||||
|
t_u8 duration_mandatory : 1;
|
||||||
|
/**< 11h: en/disable report rcpt. of spec. type */
|
||||||
|
t_u8 report : 1;
|
||||||
|
/**< 11h: en/disable requests of specified type */
|
||||||
|
t_u8 request : 1;
|
||||||
|
/**< 11h: enable report/request bits */
|
||||||
|
t_u8 enable : 1;
|
||||||
|
/**< 11k: series or parallel with previous meas */
|
||||||
|
t_u8 parallel : 1;
|
||||||
|
#else
|
||||||
/**< 11k: series or parallel with previous meas */
|
/**< 11k: series or parallel with previous meas */
|
||||||
t_u8 parallel : 1;
|
t_u8 parallel : 1;
|
||||||
/**< 11h: enable report/request bits */
|
/**< 11h: enable report/request bits */
|
||||||
|
@ -7157,6 +7288,7 @@ typedef MLAN_PACK_START struct {
|
||||||
t_u8 duration_mandatory : 1;
|
t_u8 duration_mandatory : 1;
|
||||||
/**< Reserved */
|
/**< Reserved */
|
||||||
t_u8 rsvd5_7 : 3;
|
t_u8 rsvd5_7 : 3;
|
||||||
|
#endif /* BIG_ENDIAN_SUPPORT */
|
||||||
|
|
||||||
} MLAN_PACK_END MeasReqMode_t;
|
} MLAN_PACK_END MeasReqMode_t;
|
||||||
|
|
||||||
|
@ -7201,10 +7333,17 @@ typedef union {
|
||||||
* @brief Mode octet of the measurement report element (7.3.2.22)
|
* @brief Mode octet of the measurement report element (7.3.2.22)
|
||||||
*/
|
*/
|
||||||
typedef MLAN_PACK_START struct {
|
typedef MLAN_PACK_START struct {
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
t_u8 rsvd3_7 : 5; /**< Reserved */
|
||||||
|
t_u8 refused : 1; /**< Measurement refused */
|
||||||
|
t_u8 incapable : 1; /**< Incapable of performing measurement */
|
||||||
|
t_u8 late : 1; /**< Start TSF time missed for measurement */
|
||||||
|
#else
|
||||||
t_u8 late : 1; /**< Start TSF time missed for measurement */
|
t_u8 late : 1; /**< Start TSF time missed for measurement */
|
||||||
t_u8 incapable : 1; /**< Incapable of performing measurement */
|
t_u8 incapable : 1; /**< Incapable of performing measurement */
|
||||||
t_u8 refused : 1; /**< Measurement refused */
|
t_u8 refused : 1; /**< Measurement refused */
|
||||||
t_u8 rsvd3_7 : 5; /**< Reserved */
|
t_u8 rsvd3_7 : 5; /**< Reserved */
|
||||||
|
#endif /* BIG_ENDIAN_SUPPORT */
|
||||||
|
|
||||||
} MLAN_PACK_END MeasRptMode_t;
|
} MLAN_PACK_END MeasRptMode_t;
|
||||||
|
|
||||||
|
|
|
@ -46,10 +46,17 @@ typedef enum _WLAN_802_11_NETWORK_TYPE {
|
||||||
Wlan802_11NetworkTypeMax
|
Wlan802_11NetworkTypeMax
|
||||||
} WLAN_802_11_NETWORK_TYPE;
|
} WLAN_802_11_NETWORK_TYPE;
|
||||||
|
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
/** Frame control: Type Mgmt frame */
|
||||||
|
#define IEEE80211_FC_MGMT_FRAME_TYPE_MASK 0x3000
|
||||||
|
/** Frame control: SubType Mgmt frame */
|
||||||
|
#define IEEE80211_GET_FC_MGMT_FRAME_SUBTYPE(fc) (((fc)&0xF000) >> 12)
|
||||||
|
#else
|
||||||
/** Frame control: Type Mgmt frame */
|
/** Frame control: Type Mgmt frame */
|
||||||
#define IEEE80211_FC_MGMT_FRAME_TYPE_MASK 0x000C
|
#define IEEE80211_FC_MGMT_FRAME_TYPE_MASK 0x000C
|
||||||
/** Frame control: SubType Mgmt frame */
|
/** Frame control: SubType Mgmt frame */
|
||||||
#define IEEE80211_GET_FC_MGMT_FRAME_SUBTYPE(fc) (((fc)&0x00F0) >> 4)
|
#define IEEE80211_GET_FC_MGMT_FRAME_SUBTYPE(fc) (((fc)&0x00F0) >> 4)
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef PRAGMA_PACK
|
#ifdef PRAGMA_PACK
|
||||||
#pragma pack(push, 1)
|
#pragma pack(push, 1)
|
||||||
|
@ -172,12 +179,21 @@ typedef MLAN_PACK_START struct _IEEEtypes_Generic_t {
|
||||||
|
|
||||||
/**ft capability policy*/
|
/**ft capability policy*/
|
||||||
typedef MLAN_PACK_START struct _IEEEtypes_FtCapPolicy_t {
|
typedef MLAN_PACK_START struct _IEEEtypes_FtCapPolicy_t {
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
/** Reserved */
|
||||||
|
t_u8 reserved : 6;
|
||||||
|
/** RIC support */
|
||||||
|
t_u8 ric : 1;
|
||||||
|
/** FT over the DS capable */
|
||||||
|
t_u8 ft_over_ds : 1;
|
||||||
|
#else
|
||||||
/** FT over the DS capable */
|
/** FT over the DS capable */
|
||||||
t_u8 ft_over_ds : 1;
|
t_u8 ft_over_ds : 1;
|
||||||
/** RIC support */
|
/** RIC support */
|
||||||
t_u8 ric : 1;
|
t_u8 ric : 1;
|
||||||
/** Reserved */
|
/** Reserved */
|
||||||
t_u8 reserved : 6;
|
t_u8 reserved : 6;
|
||||||
|
#endif
|
||||||
} MLAN_PACK_END IEEEtypes_FtCapPolicy_t;
|
} MLAN_PACK_END IEEEtypes_FtCapPolicy_t;
|
||||||
|
|
||||||
/** Mobility domain IE */
|
/** Mobility domain IE */
|
||||||
|
@ -310,6 +326,25 @@ typedef MLAN_PACK_START struct _TLV_Generic_t {
|
||||||
#define CAPINFO_MASK (~(MBIT(15) | MBIT(14) | MBIT(11) | MBIT(9)))
|
#define CAPINFO_MASK (~(MBIT(15) | MBIT(14) | MBIT(11) | MBIT(9)))
|
||||||
|
|
||||||
/** Capability Bit Map*/
|
/** Capability Bit Map*/
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
typedef MLAN_PACK_START struct _IEEEtypes_CapInfo_t {
|
||||||
|
t_u8 rsrvd1 : 2;
|
||||||
|
t_u8 dsss_ofdm : 1;
|
||||||
|
t_u8 radio_measurement : 1;
|
||||||
|
t_u8 rsvrd2 : 1;
|
||||||
|
t_u8 short_slot_time : 1;
|
||||||
|
t_u8 rsrvd3 : 1;
|
||||||
|
t_u8 spectrum_mgmt : 1;
|
||||||
|
t_u8 chan_agility : 1;
|
||||||
|
t_u8 pbcc : 1;
|
||||||
|
t_u8 short_preamble : 1;
|
||||||
|
t_u8 privacy : 1;
|
||||||
|
t_u8 cf_poll_rqst : 1;
|
||||||
|
t_u8 cf_pollable : 1;
|
||||||
|
t_u8 ibss : 1;
|
||||||
|
t_u8 ess : 1;
|
||||||
|
} MLAN_PACK_END IEEEtypes_CapInfo_t, *pIEEEtypes_CapInfo_t;
|
||||||
|
#else
|
||||||
typedef MLAN_PACK_START struct _IEEEtypes_CapInfo_t {
|
typedef MLAN_PACK_START struct _IEEEtypes_CapInfo_t {
|
||||||
/** Capability Bit Map : ESS */
|
/** Capability Bit Map : ESS */
|
||||||
t_u8 ess : 1;
|
t_u8 ess : 1;
|
||||||
|
@ -342,6 +377,7 @@ typedef MLAN_PACK_START struct _IEEEtypes_CapInfo_t {
|
||||||
/** Capability Bit Map : Reserved */
|
/** Capability Bit Map : Reserved */
|
||||||
t_u8 rsrvd1 : 2;
|
t_u8 rsrvd1 : 2;
|
||||||
} MLAN_PACK_END IEEEtypes_CapInfo_t, *pIEEEtypes_CapInfo_t;
|
} MLAN_PACK_END IEEEtypes_CapInfo_t, *pIEEEtypes_CapInfo_t;
|
||||||
|
#endif /* BIG_ENDIAN_SUPPORT */
|
||||||
|
|
||||||
/** IEEEtypes_Ssid_t */
|
/** IEEEtypes_Ssid_t */
|
||||||
typedef MLAN_PACK_START struct _IEEEtypes_Ssid_t {
|
typedef MLAN_PACK_START struct _IEEEtypes_Ssid_t {
|
||||||
|
@ -556,16 +592,35 @@ typedef MLAN_PACK_START struct _IEEEtypes_Wpa_t {
|
||||||
|
|
||||||
/** Data structure of WMM QoS information */
|
/** Data structure of WMM QoS information */
|
||||||
typedef MLAN_PACK_START struct _IEEEtypes_WmmQosInfo_t {
|
typedef MLAN_PACK_START struct _IEEEtypes_WmmQosInfo_t {
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
/** QoS UAPSD */
|
||||||
|
t_u8 qos_uapsd : 1;
|
||||||
|
/** Reserved */
|
||||||
|
t_u8 reserved : 3;
|
||||||
|
/** Parameter set count */
|
||||||
|
t_u8 para_set_count : 4;
|
||||||
|
#else
|
||||||
/** Parameter set count */
|
/** Parameter set count */
|
||||||
t_u8 para_set_count : 4;
|
t_u8 para_set_count : 4;
|
||||||
/** Reserved */
|
/** Reserved */
|
||||||
t_u8 reserved : 3;
|
t_u8 reserved : 3;
|
||||||
/** QoS UAPSD */
|
/** QoS UAPSD */
|
||||||
t_u8 qos_uapsd : 1;
|
t_u8 qos_uapsd : 1;
|
||||||
|
#endif /* BIG_ENDIAN_SUPPORT */
|
||||||
} MLAN_PACK_END IEEEtypes_WmmQosInfo_t, *pIEEEtypes_WmmQosInfo_t;
|
} MLAN_PACK_END IEEEtypes_WmmQosInfo_t, *pIEEEtypes_WmmQosInfo_t;
|
||||||
|
|
||||||
/** Data structure of WMM Aci/Aifsn */
|
/** Data structure of WMM Aci/Aifsn */
|
||||||
typedef MLAN_PACK_START struct _IEEEtypes_WmmAciAifsn_t {
|
typedef MLAN_PACK_START struct _IEEEtypes_WmmAciAifsn_t {
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
/** Reserved */
|
||||||
|
t_u8 reserved : 1;
|
||||||
|
/** Aci */
|
||||||
|
t_u8 aci : 2;
|
||||||
|
/** Acm */
|
||||||
|
t_u8 acm : 1;
|
||||||
|
/** Aifsn */
|
||||||
|
t_u8 aifsn : 4;
|
||||||
|
#else
|
||||||
/** Aifsn */
|
/** Aifsn */
|
||||||
t_u8 aifsn : 4;
|
t_u8 aifsn : 4;
|
||||||
/** Acm */
|
/** Acm */
|
||||||
|
@ -574,14 +629,22 @@ typedef MLAN_PACK_START struct _IEEEtypes_WmmAciAifsn_t {
|
||||||
t_u8 aci : 2;
|
t_u8 aci : 2;
|
||||||
/** Reserved */
|
/** Reserved */
|
||||||
t_u8 reserved : 1;
|
t_u8 reserved : 1;
|
||||||
|
#endif /* BIG_ENDIAN_SUPPORT */
|
||||||
} MLAN_PACK_END IEEEtypes_WmmAciAifsn_t, *pIEEEtypes_WmmAciAifsn_t;
|
} MLAN_PACK_END IEEEtypes_WmmAciAifsn_t, *pIEEEtypes_WmmAciAifsn_t;
|
||||||
|
|
||||||
/** Data structure of WMM ECW */
|
/** Data structure of WMM ECW */
|
||||||
typedef MLAN_PACK_START struct _IEEEtypes_WmmEcw_t {
|
typedef MLAN_PACK_START struct _IEEEtypes_WmmEcw_t {
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
/** Maximum Ecw */
|
||||||
|
t_u8 ecw_max : 4;
|
||||||
|
/** Minimum Ecw */
|
||||||
|
t_u8 ecw_min : 4;
|
||||||
|
#else
|
||||||
/** Minimum Ecw */
|
/** Minimum Ecw */
|
||||||
t_u8 ecw_min : 4;
|
t_u8 ecw_min : 4;
|
||||||
/** Maximum Ecw */
|
/** Maximum Ecw */
|
||||||
t_u8 ecw_max : 4;
|
t_u8 ecw_max : 4;
|
||||||
|
#endif /* BIG_ENDIAN_SUPPORT */
|
||||||
} MLAN_PACK_END IEEEtypes_WmmEcw_t, *pIEEEtypes_WmmEcw_t;
|
} MLAN_PACK_END IEEEtypes_WmmEcw_t, *pIEEEtypes_WmmEcw_t;
|
||||||
|
|
||||||
/** Data structure of WMM AC parameters */
|
/** Data structure of WMM AC parameters */
|
||||||
|
@ -669,6 +732,22 @@ typedef MLAN_PACK_START enum _IEEEtypes_WMM_TSPEC_TS_TRAFFIC_TYPE_e {
|
||||||
|
|
||||||
/** Data structure of WMM TSPEC information */
|
/** Data structure of WMM TSPEC information */
|
||||||
typedef MLAN_PACK_START struct {
|
typedef MLAN_PACK_START struct {
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
t_u8 Reserved17_23 : 7; /* ! Reserved */
|
||||||
|
t_u8 Schedule : 1;
|
||||||
|
IEEEtypes_WMM_TSPEC_TS_Info_AckPolicy_e AckPolicy : 2;
|
||||||
|
t_u8 UserPri : 3; /* ! 802.1d User Priority */
|
||||||
|
// IEEEtypes_WMM_TSPEC_TS_Info_PSB_e PowerSaveBehavior : 1; /*
|
||||||
|
// !Legacy/Trigg*/
|
||||||
|
t_u8 PowerSaveBehavior : 1;
|
||||||
|
t_u8 Aggregation : 1; /* ! Reserved */
|
||||||
|
t_u8 AccessPolicy2 : 1; /* ! */
|
||||||
|
t_u8 AccessPolicy1 : 1; /* ! */
|
||||||
|
IEEEtypes_WMM_TSPEC_TS_Info_Direction_e Direction : 2;
|
||||||
|
t_u8 TID : 4; /* ! Unique identifier */
|
||||||
|
// IEEEtypes_WMM_TSPEC_TS_TRAFFIC_TYPE_e TrafficType : 1;
|
||||||
|
t_u8 TrafficType : 1;
|
||||||
|
#else
|
||||||
// IEEEtypes_WMM_TSPEC_TS_TRAFFIC_TYPE_e TrafficType : 1;
|
// IEEEtypes_WMM_TSPEC_TS_TRAFFIC_TYPE_e TrafficType : 1;
|
||||||
t_u8 TrafficType : 1;
|
t_u8 TrafficType : 1;
|
||||||
t_u8 TID : 4; /* ! Unique identifier */
|
t_u8 TID : 4; /* ! Unique identifier */
|
||||||
|
@ -683,19 +762,31 @@ typedef MLAN_PACK_START struct {
|
||||||
IEEEtypes_WMM_TSPEC_TS_Info_AckPolicy_e AckPolicy : 2;
|
IEEEtypes_WMM_TSPEC_TS_Info_AckPolicy_e AckPolicy : 2;
|
||||||
t_u8 Schedule : 1;
|
t_u8 Schedule : 1;
|
||||||
t_u8 Reserved17_23 : 7; /* ! Reserved */
|
t_u8 Reserved17_23 : 7; /* ! Reserved */
|
||||||
|
#endif
|
||||||
} MLAN_PACK_END IEEEtypes_WMM_TSPEC_TS_Info_t;
|
} MLAN_PACK_END IEEEtypes_WMM_TSPEC_TS_Info_t;
|
||||||
|
|
||||||
/** Data structure of WMM TSPEC Nominal Size */
|
/** Data structure of WMM TSPEC Nominal Size */
|
||||||
typedef MLAN_PACK_START struct {
|
typedef MLAN_PACK_START struct {
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
t_u16 Fixed : 1; /* ! 1: Fixed size given in Size, 0: Var, size is
|
||||||
|
nominal */
|
||||||
|
t_u16 Size : 15; /* ! Nominal size in octets */
|
||||||
|
#else
|
||||||
t_u16 Size : 15; /* ! Nominal size in octets */
|
t_u16 Size : 15; /* ! Nominal size in octets */
|
||||||
t_u16 Fixed : 1; /* ! 1: Fixed size given in Size, 0: Var, size is
|
t_u16 Fixed : 1; /* ! 1: Fixed size given in Size, 0: Var, size is
|
||||||
nominal */
|
nominal */
|
||||||
|
#endif
|
||||||
} MLAN_PACK_END IEEEtypes_WMM_TSPEC_NomMSDUSize_t;
|
} MLAN_PACK_END IEEEtypes_WMM_TSPEC_NomMSDUSize_t;
|
||||||
|
|
||||||
/** Data structure of WMM TSPEC SBWA */
|
/** Data structure of WMM TSPEC SBWA */
|
||||||
typedef MLAN_PACK_START struct {
|
typedef MLAN_PACK_START struct {
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
t_u16 Whole : 3; /* ! Whole portion */
|
||||||
|
t_u16 Fractional : 13; /* ! Fractional portion */
|
||||||
|
#else
|
||||||
t_u16 Fractional : 13; /* ! Fractional portion */
|
t_u16 Fractional : 13; /* ! Fractional portion */
|
||||||
t_u16 Whole : 3; /* ! Whole portion */
|
t_u16 Whole : 3; /* ! Whole portion */
|
||||||
|
#endif
|
||||||
} MLAN_PACK_END IEEEtypes_WMM_TSPEC_SBWA;
|
} MLAN_PACK_END IEEEtypes_WMM_TSPEC_SBWA;
|
||||||
|
|
||||||
/** Data structure of WMM TSPEC Body */
|
/** Data structure of WMM TSPEC Body */
|
||||||
|
@ -1036,6 +1127,26 @@ typedef MLAN_PACK_START struct _VHT_MCS_set {
|
||||||
/** VHT Capabilities info field, reference 802.11ac D1.4 p89 */
|
/** VHT Capabilities info field, reference 802.11ac D1.4 p89 */
|
||||||
typedef MLAN_PACK_START struct _VHT_capa {
|
typedef MLAN_PACK_START struct _VHT_capa {
|
||||||
#if 0
|
#if 0
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
t_u8 mpdu_max_len:2;
|
||||||
|
t_u8 chan_width:2;
|
||||||
|
t_u8 rx_LDPC:1;
|
||||||
|
t_u8 sgi_80:1;
|
||||||
|
t_u8 sgi_160:1;
|
||||||
|
t_u8 tx_STBC:1;
|
||||||
|
t_u8 rx_STBC:3;
|
||||||
|
t_u8 SU_beamformer_capa:1;
|
||||||
|
t_u8 SU_beamformee_capa:1;
|
||||||
|
t_u8 beamformer_ante_num:3;
|
||||||
|
t_u8 sounding_dim_num:3;
|
||||||
|
t_u8 MU_beamformer_capa:1;
|
||||||
|
t_u8 MU_beamformee_capa:1;
|
||||||
|
t_u8 VHT_TXOP_ps:1;
|
||||||
|
t_u8 HTC_VHT_capa:1;
|
||||||
|
t_u8 max_ampdu_len:3;
|
||||||
|
t_u8 link_apapt_capa:2;
|
||||||
|
t_u8 reserved_1:4;
|
||||||
|
#else
|
||||||
t_u8 reserved_1:4;
|
t_u8 reserved_1:4;
|
||||||
t_u8 link_apapt_capa:2;
|
t_u8 link_apapt_capa:2;
|
||||||
t_u8 max_ampdu_len:3;
|
t_u8 max_ampdu_len:3;
|
||||||
|
@ -1054,6 +1165,7 @@ typedef MLAN_PACK_START struct _VHT_capa {
|
||||||
t_u8 rx_LDPC:1;
|
t_u8 rx_LDPC:1;
|
||||||
t_u8 chan_width:2;
|
t_u8 chan_width:2;
|
||||||
t_u8 mpdu_max_len:2;
|
t_u8 mpdu_max_len:2;
|
||||||
|
#endif /* BIG_ENDIAN_SUPPORT */
|
||||||
#endif
|
#endif
|
||||||
t_u32 vht_cap_info;
|
t_u32 vht_cap_info;
|
||||||
VHT_MCS_set_t mcs_sets;
|
VHT_MCS_set_t mcs_sets;
|
||||||
|
@ -1162,6 +1274,24 @@ typedef MLAN_PACK_START struct _IEEEtypes_Extension_t {
|
||||||
} MLAN_PACK_END IEEEtypes_Extension_t, *pIEEEtypes_Extension_t;
|
} MLAN_PACK_END IEEEtypes_Extension_t, *pIEEEtypes_Extension_t;
|
||||||
|
|
||||||
typedef MLAN_PACK_START struct _IEEEtypes_HeMcsMap_t {
|
typedef MLAN_PACK_START struct _IEEEtypes_HeMcsMap_t {
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
/** Max HE-MAC for 8 SS */
|
||||||
|
t_u8 max_mcs_8ss : 2;
|
||||||
|
/** Max HE-MAC for 7 SS */
|
||||||
|
t_u8 max_mcs_7ss : 2;
|
||||||
|
/** Max HE-MAC for 6 SS */
|
||||||
|
t_u8 max_mcs_6ss : 2;
|
||||||
|
/** Max HE-MAC for 5 SS */
|
||||||
|
t_u8 max_mcs_5ss : 2;
|
||||||
|
/** Max HE-MAC for 4 SS */
|
||||||
|
t_u8 max_mcs_4ss : 2;
|
||||||
|
/** Max HE-MAC for 3 SS */
|
||||||
|
t_u8 max_mcs_3ss : 2;
|
||||||
|
/** Max HE-MAC for 2 SS */
|
||||||
|
t_u8 max_mcs_2ss : 2;
|
||||||
|
/** Max HE-MAC for 1 SS */
|
||||||
|
t_u8 max_mcs_1ss : 2;
|
||||||
|
#else
|
||||||
/** Max HE-MAC for 1 SS */
|
/** Max HE-MAC for 1 SS */
|
||||||
t_u8 max_mcs_1ss : 2;
|
t_u8 max_mcs_1ss : 2;
|
||||||
/** Max HE-MAC for 2 SS */
|
/** Max HE-MAC for 2 SS */
|
||||||
|
@ -1178,6 +1308,7 @@ typedef MLAN_PACK_START struct _IEEEtypes_HeMcsMap_t {
|
||||||
t_u8 max_mcs_7ss : 2;
|
t_u8 max_mcs_7ss : 2;
|
||||||
/** Max HE-MAC for 8 SS */
|
/** Max HE-MAC for 8 SS */
|
||||||
t_u8 max_mcs_8ss : 2;
|
t_u8 max_mcs_8ss : 2;
|
||||||
|
#endif
|
||||||
} MLAN_PACK_END IEEEtypes_HeMcsMap_t, *pIEEEtypes_HeMcsMap_t;
|
} MLAN_PACK_END IEEEtypes_HeMcsMap_t, *pIEEEtypes_HeMcsMap_t;
|
||||||
|
|
||||||
typedef MLAN_PACK_START struct _IEEEtypes_HeMcsNss_t {
|
typedef MLAN_PACK_START struct _IEEEtypes_HeMcsNss_t {
|
||||||
|
@ -1204,6 +1335,24 @@ typedef MLAN_PACK_START struct _IEEEtypes_HECap_t {
|
||||||
} MLAN_PACK_END IEEEtypes_HECap_t, *pIEEEtypes_HECap_t;
|
} MLAN_PACK_END IEEEtypes_HECap_t, *pIEEEtypes_HECap_t;
|
||||||
|
|
||||||
typedef MLAN_PACK_START struct _IEEEtypes_HeOpParam_t {
|
typedef MLAN_PACK_START struct _IEEEtypes_HeOpParam_t {
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
/** Reserved, including 6G Operation Info Pressent (bit17) */
|
||||||
|
t_u8 reserved : 6; /* bit 18-23 */
|
||||||
|
/* 6g operation info present */
|
||||||
|
t_u8 he_6g_op_info_present : 1; /* bit 17 */
|
||||||
|
/** ER SU Disable */
|
||||||
|
t_u8 er_su_disable : 1; /* bit 16 */
|
||||||
|
/** Co-Hosted BSS */
|
||||||
|
t_u16 co_located_bss : 1; /* bit 15 */
|
||||||
|
/** VHT Operation Info Present */
|
||||||
|
t_u16 vht_op_info_present : 1; /* bit 14 */
|
||||||
|
/** TXOP Duration RTS Threshold */
|
||||||
|
t_u16 txop_dur_rts_threshold : 10; /* bit 4-13 */
|
||||||
|
/** TWT Required */
|
||||||
|
t_u16 twt_req : 1; /* bit 3 */
|
||||||
|
/** Default PE Duration */
|
||||||
|
t_u16 default_pe_dur : 3; /* bit 0-2 */
|
||||||
|
#else
|
||||||
/** Default PE Duration */
|
/** Default PE Duration */
|
||||||
t_u16 default_pe_dur : 3; /* bit 0-2 */
|
t_u16 default_pe_dur : 3; /* bit 0-2 */
|
||||||
/** TWT Required */
|
/** TWT Required */
|
||||||
|
@ -1220,15 +1369,25 @@ typedef MLAN_PACK_START struct _IEEEtypes_HeOpParam_t {
|
||||||
t_u8 he_6g_op_info_present : 1; /* bit 17 */
|
t_u8 he_6g_op_info_present : 1; /* bit 17 */
|
||||||
/** Reserved bit 18-23 */
|
/** Reserved bit 18-23 */
|
||||||
t_u8 reserved : 6; /* bit 18-23 */
|
t_u8 reserved : 6; /* bit 18-23 */
|
||||||
|
#endif
|
||||||
} MLAN_PACK_END IEEEtypes_HeOpParam_t;
|
} MLAN_PACK_END IEEEtypes_HeOpParam_t;
|
||||||
|
|
||||||
typedef MLAN_PACK_START struct _IEEEtypes_HeBssColorInfo_t {
|
typedef MLAN_PACK_START struct _IEEEtypes_HeBssColorInfo_t {
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
/** BSS Color Disabled */
|
||||||
|
t_u8 bss_color_disabled : 1; /* bit 7 */
|
||||||
|
/** Partial BSS Color */
|
||||||
|
t_u8 partial_bss_color : 1; /* bit 6 */
|
||||||
|
/** BSS Color */
|
||||||
|
t_u8 bss_color : 6; /* bit 0-5 */
|
||||||
|
#else
|
||||||
/** BSS Color */
|
/** BSS Color */
|
||||||
t_u8 bss_color : 6; /* bit 0-5 */
|
t_u8 bss_color : 6; /* bit 0-5 */
|
||||||
/** Partial BSS Color */
|
/** Partial BSS Color */
|
||||||
t_u8 partial_bss_color : 1; /* bit 6 */
|
t_u8 partial_bss_color : 1; /* bit 6 */
|
||||||
/** BSS Color Disabled */
|
/** BSS Color Disabled */
|
||||||
t_u8 bss_color_disabled : 1; /* bit 7 */
|
t_u8 bss_color_disabled : 1; /* bit 7 */
|
||||||
|
#endif
|
||||||
} MLAN_PACK_END IEEEtypes_HeBssColorInfo_t;
|
} MLAN_PACK_END IEEEtypes_HeBssColorInfo_t;
|
||||||
|
|
||||||
typedef MLAN_PACK_START struct _IEEEtypes_HeOp_t {
|
typedef MLAN_PACK_START struct _IEEEtypes_HeOp_t {
|
||||||
|
@ -1390,6 +1549,20 @@ typedef MLAN_PACK_START struct {
|
||||||
*** @brief Map octet of the basic measurement report (7.3.2.22.1)
|
*** @brief Map octet of the basic measurement report (7.3.2.22.1)
|
||||||
**/
|
**/
|
||||||
typedef MLAN_PACK_START struct {
|
typedef MLAN_PACK_START struct {
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
/**< Reserved */
|
||||||
|
t_u8 rsvd5_7 : 3;
|
||||||
|
/**< Channel is unmeasured */
|
||||||
|
t_u8 unmeasured : 1;
|
||||||
|
/**< Radar detected on channel */
|
||||||
|
t_u8 radar : 1;
|
||||||
|
/**< Unidentified signal found on channel */
|
||||||
|
t_u8 unidentified_sig : 1;
|
||||||
|
/**< OFDM preamble detected on channel */
|
||||||
|
t_u8 ofdm_preamble : 1;
|
||||||
|
/**< At least one valid MPDU received on channel */
|
||||||
|
t_u8 bss : 1;
|
||||||
|
#else
|
||||||
/**< At least one valid MPDU received on channel */
|
/**< At least one valid MPDU received on channel */
|
||||||
t_u8 bss : 1;
|
t_u8 bss : 1;
|
||||||
/**< OFDM preamble detected on channel */
|
/**< OFDM preamble detected on channel */
|
||||||
|
@ -1402,6 +1575,7 @@ typedef MLAN_PACK_START struct {
|
||||||
t_u8 unmeasured : 1;
|
t_u8 unmeasured : 1;
|
||||||
/**< Reserved */
|
/**< Reserved */
|
||||||
t_u8 rsvd5_7 : 3;
|
t_u8 rsvd5_7 : 3;
|
||||||
|
#endif /* BIG_ENDIAN_SUPPORT */
|
||||||
|
|
||||||
} MLAN_PACK_END MeasRptBasicMap_t;
|
} MLAN_PACK_END MeasRptBasicMap_t;
|
||||||
|
|
||||||
|
|
|
@ -104,9 +104,22 @@ typedef MLAN_PACK_START struct _FWSyncPkt {
|
||||||
t_u32 fw_ready;
|
t_u32 fw_ready;
|
||||||
} MLAN_PACK_END FWSyncPkt;
|
} MLAN_PACK_END FWSyncPkt;
|
||||||
|
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
/** Convert sequence number and command fields
|
||||||
|
* of fwheader to correct endian format
|
||||||
|
*/
|
||||||
|
#define endian_convert_syncfwheader(x) \
|
||||||
|
{ \
|
||||||
|
(x)->cmd = wlan_le32_to_cpu((x)->cmd); \
|
||||||
|
(x)->seq_num = wlan_le32_to_cpu((x)->seq_num); \
|
||||||
|
(x)->status = wlan_le32_to_cpu((x)->status); \
|
||||||
|
(x)->offset = wlan_le32_to_cpu((x)->offset); \
|
||||||
|
}
|
||||||
|
#else
|
||||||
/** Convert sequence number and command fields
|
/** Convert sequence number and command fields
|
||||||
* of fwheader to correct endian format
|
* of fwheader to correct endian format
|
||||||
*/
|
*/
|
||||||
#define endian_convert_syncfwheader(x)
|
#define endian_convert_syncfwheader(x)
|
||||||
|
#endif /* BIG_ENDIAN_SUPPORT */
|
||||||
|
|
||||||
#endif /* _MLAN_INIT_H_ */
|
#endif /* _MLAN_INIT_H_ */
|
||||||
|
|
|
@ -770,14 +770,31 @@ typedef struct _mlan_ssid_bssid {
|
||||||
|
|
||||||
/** Data structure of WMM ECW */
|
/** Data structure of WMM ECW */
|
||||||
typedef struct _wmm_ecw_t {
|
typedef struct _wmm_ecw_t {
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
/** Maximum Ecw */
|
||||||
|
t_u8 ecw_max : 4;
|
||||||
|
/** Minimum Ecw */
|
||||||
|
t_u8 ecw_min : 4;
|
||||||
|
#else
|
||||||
/** Minimum Ecw */
|
/** Minimum Ecw */
|
||||||
t_u8 ecw_min : 4;
|
t_u8 ecw_min : 4;
|
||||||
/** Maximum Ecw */
|
/** Maximum Ecw */
|
||||||
t_u8 ecw_max : 4;
|
t_u8 ecw_max : 4;
|
||||||
|
#endif /* BIG_ENDIAN_SUPPORT */
|
||||||
} wmm_ecw_t, *pwmm_ecw_t;
|
} wmm_ecw_t, *pwmm_ecw_t;
|
||||||
|
|
||||||
/** Data structure of WMM Aci/Aifsn */
|
/** Data structure of WMM Aci/Aifsn */
|
||||||
typedef struct _wmm_aci_aifsn_t {
|
typedef struct _wmm_aci_aifsn_t {
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
/** Reserved */
|
||||||
|
t_u8 reserved : 1;
|
||||||
|
/** Aci */
|
||||||
|
t_u8 aci : 2;
|
||||||
|
/** Acm */
|
||||||
|
t_u8 acm : 1;
|
||||||
|
/** Aifsn */
|
||||||
|
t_u8 aifsn : 4;
|
||||||
|
#else
|
||||||
/** Aifsn */
|
/** Aifsn */
|
||||||
t_u8 aifsn : 4;
|
t_u8 aifsn : 4;
|
||||||
/** Acm */
|
/** Acm */
|
||||||
|
@ -786,6 +803,7 @@ typedef struct _wmm_aci_aifsn_t {
|
||||||
t_u8 aci : 2;
|
t_u8 aci : 2;
|
||||||
/** Reserved */
|
/** Reserved */
|
||||||
t_u8 reserved : 1;
|
t_u8 reserved : 1;
|
||||||
|
#endif /* BIG_ENDIAN_SUPPORT */
|
||||||
} wmm_aci_aifsn_t, *pwmm_aci_aifsn_t;
|
} wmm_aci_aifsn_t, *pwmm_aci_aifsn_t;
|
||||||
|
|
||||||
/** Data structure of WMM AC parameters */
|
/** Data structure of WMM AC parameters */
|
||||||
|
@ -992,12 +1010,21 @@ typedef struct _wep_param {
|
||||||
|
|
||||||
/** Data structure of WMM QoS information */
|
/** Data structure of WMM QoS information */
|
||||||
typedef struct _wmm_qos_info_t {
|
typedef struct _wmm_qos_info_t {
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
/** QoS UAPSD */
|
||||||
|
t_u8 qos_uapsd : 1;
|
||||||
|
/** Reserved */
|
||||||
|
t_u8 reserved : 3;
|
||||||
|
/** Parameter set count */
|
||||||
|
t_u8 para_set_count : 4;
|
||||||
|
#else
|
||||||
/** Parameter set count */
|
/** Parameter set count */
|
||||||
t_u8 para_set_count : 4;
|
t_u8 para_set_count : 4;
|
||||||
/** Reserved */
|
/** Reserved */
|
||||||
t_u8 reserved : 3;
|
t_u8 reserved : 3;
|
||||||
/** QoS UAPSD */
|
/** QoS UAPSD */
|
||||||
t_u8 qos_uapsd : 1;
|
t_u8 qos_uapsd : 1;
|
||||||
|
#endif /* BIG_ENDIAN_SUPPORT */
|
||||||
} wmm_qos_info_t, *pwmm_qos_info_t;
|
} wmm_qos_info_t, *pwmm_qos_info_t;
|
||||||
|
|
||||||
/** Data structure of WMM parameter IE */
|
/** Data structure of WMM parameter IE */
|
||||||
|
@ -1913,6 +1940,100 @@ typedef struct _mlan_ver_ext {
|
||||||
char version_str[MLAN_MAX_VER_STR_LEN];
|
char version_str[MLAN_MAX_VER_STR_LEN];
|
||||||
} mlan_ver_ext, *pmlan_ver_ext;
|
} mlan_ver_ext, *pmlan_ver_ext;
|
||||||
|
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
/** Extended Capabilities Data */
|
||||||
|
typedef struct MLAN_PACK_START _ExtCap_t {
|
||||||
|
/** Extended Capabilities value */
|
||||||
|
t_u8 rsvdBit87 : 1; /* bit 87 */
|
||||||
|
t_u8 rsvdBit86 : 1; /* bit 86 */
|
||||||
|
t_u8 rsvdBit85 : 1; /* bit 85 */
|
||||||
|
t_u8 beacon_prot : 1; /* bit 84 */
|
||||||
|
t_u8 rsvdBit83 : 1; /* bit 83 */
|
||||||
|
t_u8 rsvdBit82 : 1; /* bit 82 */
|
||||||
|
t_u8 rsvdBit81 : 1; /* bit 81 */
|
||||||
|
t_u8 rsvdBit80 : 1; /* bit 80 */
|
||||||
|
t_u8 rsvdBit79 : 1; /* bit 79 */
|
||||||
|
t_u8 TWTResp : 1; /* bit 78 */
|
||||||
|
t_u8 TWTReq : 1; /* bit 77 */
|
||||||
|
t_u8 rsvdBit76 : 1; /* bit 76 */
|
||||||
|
t_u8 rsvdBit75 : 1; /* bit 75 */
|
||||||
|
t_u8 rsvdBit74 : 1; /* bit 74 */
|
||||||
|
t_u8 rsvdBit73 : 1; /* bit 73 */
|
||||||
|
t_u8 FILS : 1; /* bit 72 */
|
||||||
|
t_u8 FTMI : 1; /* bit 71 */
|
||||||
|
t_u8 FTMR : 1; /* bit 70 */
|
||||||
|
t_u8 CAQ : 1; /* bit 69 */
|
||||||
|
t_u8 rsvdBit68 : 1; /* bit 68 */
|
||||||
|
t_u8 NCC : 1; /* bit 67 */
|
||||||
|
t_u8 rsvdBit66 : 1; /* bit 66 */
|
||||||
|
t_u8 chanSchedMgnt : 1; /* bit 65 */
|
||||||
|
t_u8 MaxAMSDU1 : 1; /* bit 64 */
|
||||||
|
t_u8 MaxAMSDU0 : 1; /* bit 63 */
|
||||||
|
t_u8 OperModeNtf : 1; /* bit 62 */
|
||||||
|
t_u8 TDLSWildBandwidth : 1; /* bit 61 */
|
||||||
|
t_u8 rsvdBit60 : 1; /* bit 60 */
|
||||||
|
t_u8 rsvdBit59 : 1; /* bit 59 */
|
||||||
|
t_u8 rsvdBit58 : 1; /* bit 58 */
|
||||||
|
t_u8 rsvdBit57 : 1; /* bit 57 */
|
||||||
|
t_u8 rsvdBit56 : 1; /* bit 56 */
|
||||||
|
t_u8 rsvdBit55 : 1; /* bit 55 */
|
||||||
|
t_u8 rsvdBit54 : 1; /* bit 54 */
|
||||||
|
t_u8 rsvdBit53 : 1; /* bit 53 */
|
||||||
|
t_u8 rsvdBit52 : 1; /* bit 52 */
|
||||||
|
t_u8 rsvdBit51 : 1; /* bit 51 */
|
||||||
|
t_u8 rsvdBit50 : 1; /* bit 50 */
|
||||||
|
t_u8 rsvdBit49 : 1; /* bit 49 */
|
||||||
|
t_u8 rsvdBit48 : 1; /* bit 48 */
|
||||||
|
t_u8 rsvdBit47 : 1; /* bit 47 */
|
||||||
|
t_u8 rsvdBit46 : 1; /* bit 46 */
|
||||||
|
t_u8 rsvdBit45 : 1; /* bit 45 */
|
||||||
|
t_u8 rsvdBit44 : 1; /* bit 44 */
|
||||||
|
t_u8 rsvdBit43 : 1; /* bit 43 */
|
||||||
|
t_u8 rsvdBit42 : 1; /* bit 42 */
|
||||||
|
t_u8 rsvdBit41 : 1; /* bit 41 */
|
||||||
|
t_u8 rsvdBit40 : 1; /* bit 40 */
|
||||||
|
t_u8 TDLSChlSwitchProhib : 1; /* bit 39 */
|
||||||
|
t_u8 TDLSProhibited : 1; /* bit 38 */
|
||||||
|
t_u8 TDLSSupport : 1; /* bit 37 */
|
||||||
|
t_u8 MSGCF_Capa : 1; /* bit 36 */
|
||||||
|
t_u8 Reserved35 : 1; /* bit 35 */
|
||||||
|
t_u8 SSPN_Interface : 1; /* bit 34 */
|
||||||
|
t_u8 EBR : 1; /* bit 33 */
|
||||||
|
t_u8 Qos_Map : 1; /* bit 32 */
|
||||||
|
t_u8 Interworking : 1; /* bit 31 */
|
||||||
|
t_u8 TDLSChannelSwitching : 1; /* bit 30 */
|
||||||
|
t_u8 TDLSPeerPSMSupport : 1; /* bit 29 */
|
||||||
|
t_u8 TDLSPeerUAPSDSupport : 1; /* bit 28 */
|
||||||
|
t_u8 UTC : 1; /* bit 27 */
|
||||||
|
t_u8 DMS : 1; /* bit 26 */
|
||||||
|
t_u8 SSID_List : 1; /* bit 25 */
|
||||||
|
t_u8 ChannelUsage : 1; /* bit 24 */
|
||||||
|
t_u8 TimingMeasurement : 1; /* bit 23 */
|
||||||
|
t_u8 MultipleBSSID : 1; /* bit 22 */
|
||||||
|
t_u8 AC_StationCount : 1; /* bit 21 */
|
||||||
|
t_u8 QoSTrafficCap : 1; /* bit 20 */
|
||||||
|
t_u8 BSS_Transition : 1; /* bit 19 */
|
||||||
|
t_u8 TIM_Broadcast : 1; /* bit 18 */
|
||||||
|
t_u8 WNM_Sleep : 1; /* bit 17 */
|
||||||
|
t_u8 TFS : 1; /* bit 16 */
|
||||||
|
t_u8 GeospatialLocation : 1; /* bit 15 */
|
||||||
|
t_u8 CivicLocation : 1; /* bit 14 */
|
||||||
|
t_u8 CollocatedIntf : 1; /* bit 13 */
|
||||||
|
t_u8 ProxyARPService : 1; /* bit 12 */
|
||||||
|
t_u8 FMS : 1; /* bit 11 */
|
||||||
|
t_u8 LocationTracking : 1; /* bit 10 */
|
||||||
|
t_u8 MulticastDiagnostics : 1; /* bit 9 */
|
||||||
|
t_u8 Diagnostics : 1; /* bit 8 */
|
||||||
|
t_u8 Event : 1; /* bit 7 */
|
||||||
|
t_u8 SPSMP_Support : 1; /* bit 6 */
|
||||||
|
t_u8 Reserved5 : 1; /* bit 5 */
|
||||||
|
t_u8 PSMP_Capable : 1; /* bit 4 */
|
||||||
|
t_u8 RejectUnadmFrame : 1; /* bit 3 */
|
||||||
|
t_u8 ExtChanSwitching : 1; /* bit 2 */
|
||||||
|
t_u8 Reserved1 : 1; /* bit 1 */
|
||||||
|
t_u8 BSS_CoexistSupport : 1; /* bit 0 */
|
||||||
|
} MLAN_PACK_END ExtCap_t, *pExtCap_t;
|
||||||
|
#else
|
||||||
/** Extended Capabilities Data */
|
/** Extended Capabilities Data */
|
||||||
typedef struct MLAN_PACK_START _ExtCap_t {
|
typedef struct MLAN_PACK_START _ExtCap_t {
|
||||||
/** Extended Capabilities value */
|
/** Extended Capabilities value */
|
||||||
|
@ -2005,6 +2126,7 @@ typedef struct MLAN_PACK_START _ExtCap_t {
|
||||||
t_u8 rsvdBit86 : 1; /* bit 86 */
|
t_u8 rsvdBit86 : 1; /* bit 86 */
|
||||||
t_u8 rsvdBit87 : 1; /* bit 87 */
|
t_u8 rsvdBit87 : 1; /* bit 87 */
|
||||||
} MLAN_PACK_END ExtCap_t, *pExtCap_t;
|
} MLAN_PACK_END ExtCap_t, *pExtCap_t;
|
||||||
|
#endif
|
||||||
|
|
||||||
/** ExtCap : TDLS prohibited */
|
/** ExtCap : TDLS prohibited */
|
||||||
#define IS_EXTCAP_TDLS_PROHIBITED(ext_cap) (ext_cap.TDLSProhibited)
|
#define IS_EXTCAP_TDLS_PROHIBITED(ext_cap) (ext_cap.TDLSProhibited)
|
||||||
|
|
|
@ -308,6 +308,55 @@ extern t_u32 mlan_drvdbg;
|
||||||
(t_u64)(((t_u64)(x)&0x00ff000000000000ULL) >> 40) | \
|
(t_u64)(((t_u64)(x)&0x00ff000000000000ULL) >> 40) | \
|
||||||
(t_u64)(((t_u64)(x)&0xff00000000000000ULL) >> 56)))
|
(t_u64)(((t_u64)(x)&0xff00000000000000ULL) >> 56)))
|
||||||
|
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
/** Convert ulong n/w to host */
|
||||||
|
#define mlan_ntohl(x) x
|
||||||
|
/** Convert host ulong to n/w */
|
||||||
|
#define mlan_htonl(x) x
|
||||||
|
/** Convert n/w to host */
|
||||||
|
#define mlan_ntohs(x) x
|
||||||
|
/** Convert host to n/w */
|
||||||
|
#define mlan_htons(x) x
|
||||||
|
/** Convert from 16 bit little endian format to CPU format */
|
||||||
|
#define wlan_le16_to_cpu(x) swap_byte_16(x)
|
||||||
|
/** Convert from 32 bit little endian format to CPU format */
|
||||||
|
#define wlan_le32_to_cpu(x) swap_byte_32(x)
|
||||||
|
/** Convert from 64 bit little endian format to CPU format */
|
||||||
|
#define wlan_le64_to_cpu(x) swap_byte_64(x)
|
||||||
|
/** Convert to 16 bit little endian format from CPU format */
|
||||||
|
#define wlan_cpu_to_le16(x) swap_byte_16(x)
|
||||||
|
/** Convert to 32 bit little endian format from CPU format */
|
||||||
|
#define wlan_cpu_to_le32(x) swap_byte_32(x)
|
||||||
|
/** Convert to 64 bit little endian format from CPU format */
|
||||||
|
#define wlan_cpu_to_le64(x) swap_byte_64(x)
|
||||||
|
|
||||||
|
/** Convert TxPD to little endian format from CPU format */
|
||||||
|
#define endian_convert_TxPD(x) \
|
||||||
|
{ \
|
||||||
|
(x)->tx_pkt_length = wlan_cpu_to_le16((x)->tx_pkt_length); \
|
||||||
|
(x)->tx_pkt_offset = wlan_cpu_to_le16((x)->tx_pkt_offset); \
|
||||||
|
(x)->tx_pkt_type = wlan_cpu_to_le16((x)->tx_pkt_type); \
|
||||||
|
(x)->tx_control = wlan_cpu_to_le32((x)->tx_control); \
|
||||||
|
(x)->tx_control_1 = wlan_cpu_to_le32((x)->tx_control_1); \
|
||||||
|
}
|
||||||
|
/** Convert RxPD from little endian format to CPU format */
|
||||||
|
#define endian_convert_RxPD(x) \
|
||||||
|
{ \
|
||||||
|
(x)->rx_pkt_length = wlan_le16_to_cpu((x)->rx_pkt_length); \
|
||||||
|
(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)->seq_num = wlan_le16_to_cpu((x)->seq_num); \
|
||||||
|
(x)->rx_info = wlan_le32_to_cpu((x)->rx_info);
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Convert RxPD extra header from little endian format to CPU format */
|
||||||
|
#define endian_convert_RxPD_extra_header(x) \
|
||||||
|
do { \
|
||||||
|
(x)->channel_flags = wlan_le16_to_cpu((x)->channel_flags); \
|
||||||
|
(x)->vht_sig1 = wlan_le32_to_cpu((x)->vht_sig1); \
|
||||||
|
(x)->vht_sig2 = wlan_le32_to_cpu((x)->vht_sig2); \
|
||||||
|
} while (0)
|
||||||
|
#else
|
||||||
/** Convert ulong n/w to host */
|
/** Convert ulong n/w to host */
|
||||||
#define mlan_ntohl(x) swap_byte_32(x)
|
#define mlan_ntohl(x) swap_byte_32(x)
|
||||||
/** Convert host ulong to n/w */
|
/** Convert host ulong to n/w */
|
||||||
|
@ -341,6 +390,7 @@ extern t_u32 mlan_drvdbg;
|
||||||
#define endian_convert_RxPD_extra_header(x) \
|
#define endian_convert_RxPD_extra_header(x) \
|
||||||
do { \
|
do { \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
#endif /* BIG_ENDIAN_SUPPORT */
|
||||||
|
|
||||||
/** Global moal_assert_callback */
|
/** Global moal_assert_callback */
|
||||||
extern t_void (*assert_callback)(t_void *pmoal_handle, t_u32 cond);
|
extern t_void (*assert_callback)(t_void *pmoal_handle, t_u32 cond);
|
||||||
|
|
|
@ -24,7 +24,7 @@
|
||||||
#define _MLAN_DECL_H_
|
#define _MLAN_DECL_H_
|
||||||
|
|
||||||
/** MLAN release version */
|
/** MLAN release version */
|
||||||
#define MLAN_RELEASE_VERSION "362"
|
#define MLAN_RELEASE_VERSION "366"
|
||||||
|
|
||||||
/** Re-define generic data types for MLAN/MOAL */
|
/** Re-define generic data types for MLAN/MOAL */
|
||||||
/** Signed char (1-byte) */
|
/** Signed char (1-byte) */
|
||||||
|
@ -967,6 +967,16 @@ typedef enum _dfs_moe_t {
|
||||||
|
|
||||||
/** Band_Config_t */
|
/** Band_Config_t */
|
||||||
typedef MLAN_PACK_START struct _Band_Config_t {
|
typedef MLAN_PACK_START struct _Band_Config_t {
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
/** Channel Selection Mode - (00)=manual, (01)=ACS, (02)=user*/
|
||||||
|
t_u8 scanMode : 2;
|
||||||
|
/** Secondary Channel Offset - (00)=None, (01)=Above, (11)=Below */
|
||||||
|
t_u8 chan2Offset : 2;
|
||||||
|
/** Channel Width - (00)=20MHz, (10)=40MHz, (11)=80MHz */
|
||||||
|
t_u8 chanWidth : 2;
|
||||||
|
/** Band Info - (00)=2.4GHz, (01)=5GHz */
|
||||||
|
t_u8 chanBand : 2;
|
||||||
|
#else
|
||||||
/** Band Info - (00)=2.4GHz, (01)=5GHz */
|
/** Band Info - (00)=2.4GHz, (01)=5GHz */
|
||||||
t_u8 chanBand : 2;
|
t_u8 chanBand : 2;
|
||||||
/** Channel Width - (00)=20MHz, (10)=40MHz, (11)=80MHz */
|
/** Channel Width - (00)=20MHz, (10)=40MHz, (11)=80MHz */
|
||||||
|
@ -975,6 +985,7 @@ typedef MLAN_PACK_START struct _Band_Config_t {
|
||||||
t_u8 chan2Offset : 2;
|
t_u8 chan2Offset : 2;
|
||||||
/** Channel Selection Mode - (00)=manual, (01)=ACS, (02)=Adoption mode*/
|
/** Channel Selection Mode - (00)=manual, (01)=ACS, (02)=Adoption mode*/
|
||||||
t_u8 scanMode : 2;
|
t_u8 scanMode : 2;
|
||||||
|
#endif
|
||||||
} MLAN_PACK_END Band_Config_t;
|
} MLAN_PACK_END Band_Config_t;
|
||||||
|
|
||||||
/** channel_band_t */
|
/** channel_band_t */
|
||||||
|
@ -1176,6 +1187,16 @@ typedef MLAN_PACK_START struct _radiotap_info {
|
||||||
|
|
||||||
/** txpower structure */
|
/** txpower structure */
|
||||||
typedef MLAN_PACK_START struct {
|
typedef MLAN_PACK_START struct {
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
/** Host tx power ctrl:
|
||||||
|
0x0: use fw setting for TX power
|
||||||
|
0x1: value specified in bit[6] and bit[5:0] are valid */
|
||||||
|
t_u8 hostctl : 1;
|
||||||
|
/** Sign of the power specified in bit[5:0] */
|
||||||
|
t_u8 sign : 1;
|
||||||
|
/** Power to be used for transmission(in dBm) */
|
||||||
|
t_u8 abs_val : 6;
|
||||||
|
#else
|
||||||
/** Power to be used for transmission(in dBm) */
|
/** Power to be used for transmission(in dBm) */
|
||||||
t_u8 abs_val : 6;
|
t_u8 abs_val : 6;
|
||||||
/** Sign of the power specified in bit[5:0] */
|
/** Sign of the power specified in bit[5:0] */
|
||||||
|
@ -1184,6 +1205,7 @@ typedef MLAN_PACK_START struct {
|
||||||
0x0: use fw setting for TX power
|
0x0: use fw setting for TX power
|
||||||
0x1: value specified in bit[6] and bit[5:0] are valid */
|
0x1: value specified in bit[6] and bit[5:0] are valid */
|
||||||
t_u8 hostctl : 1;
|
t_u8 hostctl : 1;
|
||||||
|
#endif
|
||||||
} MLAN_PACK_END tx_power_t;
|
} MLAN_PACK_END tx_power_t;
|
||||||
/* pkt_txctrl */
|
/* pkt_txctrl */
|
||||||
typedef MLAN_PACK_START struct _pkt_txctrl {
|
typedef MLAN_PACK_START struct _pkt_txctrl {
|
||||||
|
|
|
@ -46,10 +46,17 @@ typedef enum _WLAN_802_11_NETWORK_TYPE {
|
||||||
Wlan802_11NetworkTypeMax
|
Wlan802_11NetworkTypeMax
|
||||||
} WLAN_802_11_NETWORK_TYPE;
|
} WLAN_802_11_NETWORK_TYPE;
|
||||||
|
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
/** Frame control: Type Mgmt frame */
|
||||||
|
#define IEEE80211_FC_MGMT_FRAME_TYPE_MASK 0x3000
|
||||||
|
/** Frame control: SubType Mgmt frame */
|
||||||
|
#define IEEE80211_GET_FC_MGMT_FRAME_SUBTYPE(fc) (((fc)&0xF000) >> 12)
|
||||||
|
#else
|
||||||
/** Frame control: Type Mgmt frame */
|
/** Frame control: Type Mgmt frame */
|
||||||
#define IEEE80211_FC_MGMT_FRAME_TYPE_MASK 0x000C
|
#define IEEE80211_FC_MGMT_FRAME_TYPE_MASK 0x000C
|
||||||
/** Frame control: SubType Mgmt frame */
|
/** Frame control: SubType Mgmt frame */
|
||||||
#define IEEE80211_GET_FC_MGMT_FRAME_SUBTYPE(fc) (((fc)&0x00F0) >> 4)
|
#define IEEE80211_GET_FC_MGMT_FRAME_SUBTYPE(fc) (((fc)&0x00F0) >> 4)
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef PRAGMA_PACK
|
#ifdef PRAGMA_PACK
|
||||||
#pragma pack(push, 1)
|
#pragma pack(push, 1)
|
||||||
|
@ -172,12 +179,21 @@ typedef MLAN_PACK_START struct _IEEEtypes_Generic_t {
|
||||||
|
|
||||||
/**ft capability policy*/
|
/**ft capability policy*/
|
||||||
typedef MLAN_PACK_START struct _IEEEtypes_FtCapPolicy_t {
|
typedef MLAN_PACK_START struct _IEEEtypes_FtCapPolicy_t {
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
/** Reserved */
|
||||||
|
t_u8 reserved : 6;
|
||||||
|
/** RIC support */
|
||||||
|
t_u8 ric : 1;
|
||||||
|
/** FT over the DS capable */
|
||||||
|
t_u8 ft_over_ds : 1;
|
||||||
|
#else
|
||||||
/** FT over the DS capable */
|
/** FT over the DS capable */
|
||||||
t_u8 ft_over_ds : 1;
|
t_u8 ft_over_ds : 1;
|
||||||
/** RIC support */
|
/** RIC support */
|
||||||
t_u8 ric : 1;
|
t_u8 ric : 1;
|
||||||
/** Reserved */
|
/** Reserved */
|
||||||
t_u8 reserved : 6;
|
t_u8 reserved : 6;
|
||||||
|
#endif
|
||||||
} MLAN_PACK_END IEEEtypes_FtCapPolicy_t;
|
} MLAN_PACK_END IEEEtypes_FtCapPolicy_t;
|
||||||
|
|
||||||
/** Mobility domain IE */
|
/** Mobility domain IE */
|
||||||
|
@ -310,6 +326,25 @@ typedef MLAN_PACK_START struct _TLV_Generic_t {
|
||||||
#define CAPINFO_MASK (~(MBIT(15) | MBIT(14) | MBIT(11) | MBIT(9)))
|
#define CAPINFO_MASK (~(MBIT(15) | MBIT(14) | MBIT(11) | MBIT(9)))
|
||||||
|
|
||||||
/** Capability Bit Map*/
|
/** Capability Bit Map*/
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
typedef MLAN_PACK_START struct _IEEEtypes_CapInfo_t {
|
||||||
|
t_u8 rsrvd1 : 2;
|
||||||
|
t_u8 dsss_ofdm : 1;
|
||||||
|
t_u8 radio_measurement : 1;
|
||||||
|
t_u8 rsvrd2 : 1;
|
||||||
|
t_u8 short_slot_time : 1;
|
||||||
|
t_u8 rsrvd3 : 1;
|
||||||
|
t_u8 spectrum_mgmt : 1;
|
||||||
|
t_u8 chan_agility : 1;
|
||||||
|
t_u8 pbcc : 1;
|
||||||
|
t_u8 short_preamble : 1;
|
||||||
|
t_u8 privacy : 1;
|
||||||
|
t_u8 cf_poll_rqst : 1;
|
||||||
|
t_u8 cf_pollable : 1;
|
||||||
|
t_u8 ibss : 1;
|
||||||
|
t_u8 ess : 1;
|
||||||
|
} MLAN_PACK_END IEEEtypes_CapInfo_t, *pIEEEtypes_CapInfo_t;
|
||||||
|
#else
|
||||||
typedef MLAN_PACK_START struct _IEEEtypes_CapInfo_t {
|
typedef MLAN_PACK_START struct _IEEEtypes_CapInfo_t {
|
||||||
/** Capability Bit Map : ESS */
|
/** Capability Bit Map : ESS */
|
||||||
t_u8 ess : 1;
|
t_u8 ess : 1;
|
||||||
|
@ -342,6 +377,7 @@ typedef MLAN_PACK_START struct _IEEEtypes_CapInfo_t {
|
||||||
/** Capability Bit Map : Reserved */
|
/** Capability Bit Map : Reserved */
|
||||||
t_u8 rsrvd1 : 2;
|
t_u8 rsrvd1 : 2;
|
||||||
} MLAN_PACK_END IEEEtypes_CapInfo_t, *pIEEEtypes_CapInfo_t;
|
} MLAN_PACK_END IEEEtypes_CapInfo_t, *pIEEEtypes_CapInfo_t;
|
||||||
|
#endif /* BIG_ENDIAN_SUPPORT */
|
||||||
|
|
||||||
/** IEEEtypes_Ssid_t */
|
/** IEEEtypes_Ssid_t */
|
||||||
typedef MLAN_PACK_START struct _IEEEtypes_Ssid_t {
|
typedef MLAN_PACK_START struct _IEEEtypes_Ssid_t {
|
||||||
|
@ -556,16 +592,35 @@ typedef MLAN_PACK_START struct _IEEEtypes_Wpa_t {
|
||||||
|
|
||||||
/** Data structure of WMM QoS information */
|
/** Data structure of WMM QoS information */
|
||||||
typedef MLAN_PACK_START struct _IEEEtypes_WmmQosInfo_t {
|
typedef MLAN_PACK_START struct _IEEEtypes_WmmQosInfo_t {
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
/** QoS UAPSD */
|
||||||
|
t_u8 qos_uapsd : 1;
|
||||||
|
/** Reserved */
|
||||||
|
t_u8 reserved : 3;
|
||||||
|
/** Parameter set count */
|
||||||
|
t_u8 para_set_count : 4;
|
||||||
|
#else
|
||||||
/** Parameter set count */
|
/** Parameter set count */
|
||||||
t_u8 para_set_count : 4;
|
t_u8 para_set_count : 4;
|
||||||
/** Reserved */
|
/** Reserved */
|
||||||
t_u8 reserved : 3;
|
t_u8 reserved : 3;
|
||||||
/** QoS UAPSD */
|
/** QoS UAPSD */
|
||||||
t_u8 qos_uapsd : 1;
|
t_u8 qos_uapsd : 1;
|
||||||
|
#endif /* BIG_ENDIAN_SUPPORT */
|
||||||
} MLAN_PACK_END IEEEtypes_WmmQosInfo_t, *pIEEEtypes_WmmQosInfo_t;
|
} MLAN_PACK_END IEEEtypes_WmmQosInfo_t, *pIEEEtypes_WmmQosInfo_t;
|
||||||
|
|
||||||
/** Data structure of WMM Aci/Aifsn */
|
/** Data structure of WMM Aci/Aifsn */
|
||||||
typedef MLAN_PACK_START struct _IEEEtypes_WmmAciAifsn_t {
|
typedef MLAN_PACK_START struct _IEEEtypes_WmmAciAifsn_t {
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
/** Reserved */
|
||||||
|
t_u8 reserved : 1;
|
||||||
|
/** Aci */
|
||||||
|
t_u8 aci : 2;
|
||||||
|
/** Acm */
|
||||||
|
t_u8 acm : 1;
|
||||||
|
/** Aifsn */
|
||||||
|
t_u8 aifsn : 4;
|
||||||
|
#else
|
||||||
/** Aifsn */
|
/** Aifsn */
|
||||||
t_u8 aifsn : 4;
|
t_u8 aifsn : 4;
|
||||||
/** Acm */
|
/** Acm */
|
||||||
|
@ -574,14 +629,22 @@ typedef MLAN_PACK_START struct _IEEEtypes_WmmAciAifsn_t {
|
||||||
t_u8 aci : 2;
|
t_u8 aci : 2;
|
||||||
/** Reserved */
|
/** Reserved */
|
||||||
t_u8 reserved : 1;
|
t_u8 reserved : 1;
|
||||||
|
#endif /* BIG_ENDIAN_SUPPORT */
|
||||||
} MLAN_PACK_END IEEEtypes_WmmAciAifsn_t, *pIEEEtypes_WmmAciAifsn_t;
|
} MLAN_PACK_END IEEEtypes_WmmAciAifsn_t, *pIEEEtypes_WmmAciAifsn_t;
|
||||||
|
|
||||||
/** Data structure of WMM ECW */
|
/** Data structure of WMM ECW */
|
||||||
typedef MLAN_PACK_START struct _IEEEtypes_WmmEcw_t {
|
typedef MLAN_PACK_START struct _IEEEtypes_WmmEcw_t {
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
/** Maximum Ecw */
|
||||||
|
t_u8 ecw_max : 4;
|
||||||
|
/** Minimum Ecw */
|
||||||
|
t_u8 ecw_min : 4;
|
||||||
|
#else
|
||||||
/** Minimum Ecw */
|
/** Minimum Ecw */
|
||||||
t_u8 ecw_min : 4;
|
t_u8 ecw_min : 4;
|
||||||
/** Maximum Ecw */
|
/** Maximum Ecw */
|
||||||
t_u8 ecw_max : 4;
|
t_u8 ecw_max : 4;
|
||||||
|
#endif /* BIG_ENDIAN_SUPPORT */
|
||||||
} MLAN_PACK_END IEEEtypes_WmmEcw_t, *pIEEEtypes_WmmEcw_t;
|
} MLAN_PACK_END IEEEtypes_WmmEcw_t, *pIEEEtypes_WmmEcw_t;
|
||||||
|
|
||||||
/** Data structure of WMM AC parameters */
|
/** Data structure of WMM AC parameters */
|
||||||
|
@ -669,6 +732,22 @@ typedef MLAN_PACK_START enum _IEEEtypes_WMM_TSPEC_TS_TRAFFIC_TYPE_e {
|
||||||
|
|
||||||
/** Data structure of WMM TSPEC information */
|
/** Data structure of WMM TSPEC information */
|
||||||
typedef MLAN_PACK_START struct {
|
typedef MLAN_PACK_START struct {
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
t_u8 Reserved17_23 : 7; /* ! Reserved */
|
||||||
|
t_u8 Schedule : 1;
|
||||||
|
IEEEtypes_WMM_TSPEC_TS_Info_AckPolicy_e AckPolicy : 2;
|
||||||
|
t_u8 UserPri : 3; /* ! 802.1d User Priority */
|
||||||
|
// IEEEtypes_WMM_TSPEC_TS_Info_PSB_e PowerSaveBehavior : 1; /*
|
||||||
|
// !Legacy/Trigg*/
|
||||||
|
t_u8 PowerSaveBehavior : 1;
|
||||||
|
t_u8 Aggregation : 1; /* ! Reserved */
|
||||||
|
t_u8 AccessPolicy2 : 1; /* ! */
|
||||||
|
t_u8 AccessPolicy1 : 1; /* ! */
|
||||||
|
IEEEtypes_WMM_TSPEC_TS_Info_Direction_e Direction : 2;
|
||||||
|
t_u8 TID : 4; /* ! Unique identifier */
|
||||||
|
// IEEEtypes_WMM_TSPEC_TS_TRAFFIC_TYPE_e TrafficType : 1;
|
||||||
|
t_u8 TrafficType : 1;
|
||||||
|
#else
|
||||||
// IEEEtypes_WMM_TSPEC_TS_TRAFFIC_TYPE_e TrafficType : 1;
|
// IEEEtypes_WMM_TSPEC_TS_TRAFFIC_TYPE_e TrafficType : 1;
|
||||||
t_u8 TrafficType : 1;
|
t_u8 TrafficType : 1;
|
||||||
t_u8 TID : 4; /* ! Unique identifier */
|
t_u8 TID : 4; /* ! Unique identifier */
|
||||||
|
@ -683,19 +762,31 @@ typedef MLAN_PACK_START struct {
|
||||||
IEEEtypes_WMM_TSPEC_TS_Info_AckPolicy_e AckPolicy : 2;
|
IEEEtypes_WMM_TSPEC_TS_Info_AckPolicy_e AckPolicy : 2;
|
||||||
t_u8 Schedule : 1;
|
t_u8 Schedule : 1;
|
||||||
t_u8 Reserved17_23 : 7; /* ! Reserved */
|
t_u8 Reserved17_23 : 7; /* ! Reserved */
|
||||||
|
#endif
|
||||||
} MLAN_PACK_END IEEEtypes_WMM_TSPEC_TS_Info_t;
|
} MLAN_PACK_END IEEEtypes_WMM_TSPEC_TS_Info_t;
|
||||||
|
|
||||||
/** Data structure of WMM TSPEC Nominal Size */
|
/** Data structure of WMM TSPEC Nominal Size */
|
||||||
typedef MLAN_PACK_START struct {
|
typedef MLAN_PACK_START struct {
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
t_u16 Fixed : 1; /* ! 1: Fixed size given in Size, 0: Var, size is
|
||||||
|
nominal */
|
||||||
|
t_u16 Size : 15; /* ! Nominal size in octets */
|
||||||
|
#else
|
||||||
t_u16 Size : 15; /* ! Nominal size in octets */
|
t_u16 Size : 15; /* ! Nominal size in octets */
|
||||||
t_u16 Fixed : 1; /* ! 1: Fixed size given in Size, 0: Var, size is
|
t_u16 Fixed : 1; /* ! 1: Fixed size given in Size, 0: Var, size is
|
||||||
nominal */
|
nominal */
|
||||||
|
#endif
|
||||||
} MLAN_PACK_END IEEEtypes_WMM_TSPEC_NomMSDUSize_t;
|
} MLAN_PACK_END IEEEtypes_WMM_TSPEC_NomMSDUSize_t;
|
||||||
|
|
||||||
/** Data structure of WMM TSPEC SBWA */
|
/** Data structure of WMM TSPEC SBWA */
|
||||||
typedef MLAN_PACK_START struct {
|
typedef MLAN_PACK_START struct {
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
t_u16 Whole : 3; /* ! Whole portion */
|
||||||
|
t_u16 Fractional : 13; /* ! Fractional portion */
|
||||||
|
#else
|
||||||
t_u16 Fractional : 13; /* ! Fractional portion */
|
t_u16 Fractional : 13; /* ! Fractional portion */
|
||||||
t_u16 Whole : 3; /* ! Whole portion */
|
t_u16 Whole : 3; /* ! Whole portion */
|
||||||
|
#endif
|
||||||
} MLAN_PACK_END IEEEtypes_WMM_TSPEC_SBWA;
|
} MLAN_PACK_END IEEEtypes_WMM_TSPEC_SBWA;
|
||||||
|
|
||||||
/** Data structure of WMM TSPEC Body */
|
/** Data structure of WMM TSPEC Body */
|
||||||
|
@ -1036,6 +1127,26 @@ typedef MLAN_PACK_START struct _VHT_MCS_set {
|
||||||
/** VHT Capabilities info field, reference 802.11ac D1.4 p89 */
|
/** VHT Capabilities info field, reference 802.11ac D1.4 p89 */
|
||||||
typedef MLAN_PACK_START struct _VHT_capa {
|
typedef MLAN_PACK_START struct _VHT_capa {
|
||||||
#if 0
|
#if 0
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
t_u8 mpdu_max_len:2;
|
||||||
|
t_u8 chan_width:2;
|
||||||
|
t_u8 rx_LDPC:1;
|
||||||
|
t_u8 sgi_80:1;
|
||||||
|
t_u8 sgi_160:1;
|
||||||
|
t_u8 tx_STBC:1;
|
||||||
|
t_u8 rx_STBC:3;
|
||||||
|
t_u8 SU_beamformer_capa:1;
|
||||||
|
t_u8 SU_beamformee_capa:1;
|
||||||
|
t_u8 beamformer_ante_num:3;
|
||||||
|
t_u8 sounding_dim_num:3;
|
||||||
|
t_u8 MU_beamformer_capa:1;
|
||||||
|
t_u8 MU_beamformee_capa:1;
|
||||||
|
t_u8 VHT_TXOP_ps:1;
|
||||||
|
t_u8 HTC_VHT_capa:1;
|
||||||
|
t_u8 max_ampdu_len:3;
|
||||||
|
t_u8 link_apapt_capa:2;
|
||||||
|
t_u8 reserved_1:4;
|
||||||
|
#else
|
||||||
t_u8 reserved_1:4;
|
t_u8 reserved_1:4;
|
||||||
t_u8 link_apapt_capa:2;
|
t_u8 link_apapt_capa:2;
|
||||||
t_u8 max_ampdu_len:3;
|
t_u8 max_ampdu_len:3;
|
||||||
|
@ -1054,6 +1165,7 @@ typedef MLAN_PACK_START struct _VHT_capa {
|
||||||
t_u8 rx_LDPC:1;
|
t_u8 rx_LDPC:1;
|
||||||
t_u8 chan_width:2;
|
t_u8 chan_width:2;
|
||||||
t_u8 mpdu_max_len:2;
|
t_u8 mpdu_max_len:2;
|
||||||
|
#endif /* BIG_ENDIAN_SUPPORT */
|
||||||
#endif
|
#endif
|
||||||
t_u32 vht_cap_info;
|
t_u32 vht_cap_info;
|
||||||
VHT_MCS_set_t mcs_sets;
|
VHT_MCS_set_t mcs_sets;
|
||||||
|
@ -1162,6 +1274,24 @@ typedef MLAN_PACK_START struct _IEEEtypes_Extension_t {
|
||||||
} MLAN_PACK_END IEEEtypes_Extension_t, *pIEEEtypes_Extension_t;
|
} MLAN_PACK_END IEEEtypes_Extension_t, *pIEEEtypes_Extension_t;
|
||||||
|
|
||||||
typedef MLAN_PACK_START struct _IEEEtypes_HeMcsMap_t {
|
typedef MLAN_PACK_START struct _IEEEtypes_HeMcsMap_t {
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
/** Max HE-MAC for 8 SS */
|
||||||
|
t_u8 max_mcs_8ss : 2;
|
||||||
|
/** Max HE-MAC for 7 SS */
|
||||||
|
t_u8 max_mcs_7ss : 2;
|
||||||
|
/** Max HE-MAC for 6 SS */
|
||||||
|
t_u8 max_mcs_6ss : 2;
|
||||||
|
/** Max HE-MAC for 5 SS */
|
||||||
|
t_u8 max_mcs_5ss : 2;
|
||||||
|
/** Max HE-MAC for 4 SS */
|
||||||
|
t_u8 max_mcs_4ss : 2;
|
||||||
|
/** Max HE-MAC for 3 SS */
|
||||||
|
t_u8 max_mcs_3ss : 2;
|
||||||
|
/** Max HE-MAC for 2 SS */
|
||||||
|
t_u8 max_mcs_2ss : 2;
|
||||||
|
/** Max HE-MAC for 1 SS */
|
||||||
|
t_u8 max_mcs_1ss : 2;
|
||||||
|
#else
|
||||||
/** Max HE-MAC for 1 SS */
|
/** Max HE-MAC for 1 SS */
|
||||||
t_u8 max_mcs_1ss : 2;
|
t_u8 max_mcs_1ss : 2;
|
||||||
/** Max HE-MAC for 2 SS */
|
/** Max HE-MAC for 2 SS */
|
||||||
|
@ -1178,6 +1308,7 @@ typedef MLAN_PACK_START struct _IEEEtypes_HeMcsMap_t {
|
||||||
t_u8 max_mcs_7ss : 2;
|
t_u8 max_mcs_7ss : 2;
|
||||||
/** Max HE-MAC for 8 SS */
|
/** Max HE-MAC for 8 SS */
|
||||||
t_u8 max_mcs_8ss : 2;
|
t_u8 max_mcs_8ss : 2;
|
||||||
|
#endif
|
||||||
} MLAN_PACK_END IEEEtypes_HeMcsMap_t, *pIEEEtypes_HeMcsMap_t;
|
} MLAN_PACK_END IEEEtypes_HeMcsMap_t, *pIEEEtypes_HeMcsMap_t;
|
||||||
|
|
||||||
typedef MLAN_PACK_START struct _IEEEtypes_HeMcsNss_t {
|
typedef MLAN_PACK_START struct _IEEEtypes_HeMcsNss_t {
|
||||||
|
@ -1204,6 +1335,24 @@ typedef MLAN_PACK_START struct _IEEEtypes_HECap_t {
|
||||||
} MLAN_PACK_END IEEEtypes_HECap_t, *pIEEEtypes_HECap_t;
|
} MLAN_PACK_END IEEEtypes_HECap_t, *pIEEEtypes_HECap_t;
|
||||||
|
|
||||||
typedef MLAN_PACK_START struct _IEEEtypes_HeOpParam_t {
|
typedef MLAN_PACK_START struct _IEEEtypes_HeOpParam_t {
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
/** Reserved, including 6G Operation Info Pressent (bit17) */
|
||||||
|
t_u8 reserved : 6; /* bit 18-23 */
|
||||||
|
/* 6g operation info present */
|
||||||
|
t_u8 he_6g_op_info_present : 1; /* bit 17 */
|
||||||
|
/** ER SU Disable */
|
||||||
|
t_u8 er_su_disable : 1; /* bit 16 */
|
||||||
|
/** Co-Hosted BSS */
|
||||||
|
t_u16 co_located_bss : 1; /* bit 15 */
|
||||||
|
/** VHT Operation Info Present */
|
||||||
|
t_u16 vht_op_info_present : 1; /* bit 14 */
|
||||||
|
/** TXOP Duration RTS Threshold */
|
||||||
|
t_u16 txop_dur_rts_threshold : 10; /* bit 4-13 */
|
||||||
|
/** TWT Required */
|
||||||
|
t_u16 twt_req : 1; /* bit 3 */
|
||||||
|
/** Default PE Duration */
|
||||||
|
t_u16 default_pe_dur : 3; /* bit 0-2 */
|
||||||
|
#else
|
||||||
/** Default PE Duration */
|
/** Default PE Duration */
|
||||||
t_u16 default_pe_dur : 3; /* bit 0-2 */
|
t_u16 default_pe_dur : 3; /* bit 0-2 */
|
||||||
/** TWT Required */
|
/** TWT Required */
|
||||||
|
@ -1220,15 +1369,25 @@ typedef MLAN_PACK_START struct _IEEEtypes_HeOpParam_t {
|
||||||
t_u8 he_6g_op_info_present : 1; /* bit 17 */
|
t_u8 he_6g_op_info_present : 1; /* bit 17 */
|
||||||
/** Reserved bit 18-23 */
|
/** Reserved bit 18-23 */
|
||||||
t_u8 reserved : 6; /* bit 18-23 */
|
t_u8 reserved : 6; /* bit 18-23 */
|
||||||
|
#endif
|
||||||
} MLAN_PACK_END IEEEtypes_HeOpParam_t;
|
} MLAN_PACK_END IEEEtypes_HeOpParam_t;
|
||||||
|
|
||||||
typedef MLAN_PACK_START struct _IEEEtypes_HeBssColorInfo_t {
|
typedef MLAN_PACK_START struct _IEEEtypes_HeBssColorInfo_t {
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
/** BSS Color Disabled */
|
||||||
|
t_u8 bss_color_disabled : 1; /* bit 7 */
|
||||||
|
/** Partial BSS Color */
|
||||||
|
t_u8 partial_bss_color : 1; /* bit 6 */
|
||||||
|
/** BSS Color */
|
||||||
|
t_u8 bss_color : 6; /* bit 0-5 */
|
||||||
|
#else
|
||||||
/** BSS Color */
|
/** BSS Color */
|
||||||
t_u8 bss_color : 6; /* bit 0-5 */
|
t_u8 bss_color : 6; /* bit 0-5 */
|
||||||
/** Partial BSS Color */
|
/** Partial BSS Color */
|
||||||
t_u8 partial_bss_color : 1; /* bit 6 */
|
t_u8 partial_bss_color : 1; /* bit 6 */
|
||||||
/** BSS Color Disabled */
|
/** BSS Color Disabled */
|
||||||
t_u8 bss_color_disabled : 1; /* bit 7 */
|
t_u8 bss_color_disabled : 1; /* bit 7 */
|
||||||
|
#endif
|
||||||
} MLAN_PACK_END IEEEtypes_HeBssColorInfo_t;
|
} MLAN_PACK_END IEEEtypes_HeBssColorInfo_t;
|
||||||
|
|
||||||
typedef MLAN_PACK_START struct _IEEEtypes_HeOp_t {
|
typedef MLAN_PACK_START struct _IEEEtypes_HeOp_t {
|
||||||
|
@ -1390,6 +1549,20 @@ typedef MLAN_PACK_START struct {
|
||||||
*** @brief Map octet of the basic measurement report (7.3.2.22.1)
|
*** @brief Map octet of the basic measurement report (7.3.2.22.1)
|
||||||
**/
|
**/
|
||||||
typedef MLAN_PACK_START struct {
|
typedef MLAN_PACK_START struct {
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
/**< Reserved */
|
||||||
|
t_u8 rsvd5_7 : 3;
|
||||||
|
/**< Channel is unmeasured */
|
||||||
|
t_u8 unmeasured : 1;
|
||||||
|
/**< Radar detected on channel */
|
||||||
|
t_u8 radar : 1;
|
||||||
|
/**< Unidentified signal found on channel */
|
||||||
|
t_u8 unidentified_sig : 1;
|
||||||
|
/**< OFDM preamble detected on channel */
|
||||||
|
t_u8 ofdm_preamble : 1;
|
||||||
|
/**< At least one valid MPDU received on channel */
|
||||||
|
t_u8 bss : 1;
|
||||||
|
#else
|
||||||
/**< At least one valid MPDU received on channel */
|
/**< At least one valid MPDU received on channel */
|
||||||
t_u8 bss : 1;
|
t_u8 bss : 1;
|
||||||
/**< OFDM preamble detected on channel */
|
/**< OFDM preamble detected on channel */
|
||||||
|
@ -1402,6 +1575,7 @@ typedef MLAN_PACK_START struct {
|
||||||
t_u8 unmeasured : 1;
|
t_u8 unmeasured : 1;
|
||||||
/**< Reserved */
|
/**< Reserved */
|
||||||
t_u8 rsvd5_7 : 3;
|
t_u8 rsvd5_7 : 3;
|
||||||
|
#endif /* BIG_ENDIAN_SUPPORT */
|
||||||
|
|
||||||
} MLAN_PACK_END MeasRptBasicMap_t;
|
} MLAN_PACK_END MeasRptBasicMap_t;
|
||||||
|
|
||||||
|
|
|
@ -770,14 +770,31 @@ typedef struct _mlan_ssid_bssid {
|
||||||
|
|
||||||
/** Data structure of WMM ECW */
|
/** Data structure of WMM ECW */
|
||||||
typedef struct _wmm_ecw_t {
|
typedef struct _wmm_ecw_t {
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
/** Maximum Ecw */
|
||||||
|
t_u8 ecw_max : 4;
|
||||||
|
/** Minimum Ecw */
|
||||||
|
t_u8 ecw_min : 4;
|
||||||
|
#else
|
||||||
/** Minimum Ecw */
|
/** Minimum Ecw */
|
||||||
t_u8 ecw_min : 4;
|
t_u8 ecw_min : 4;
|
||||||
/** Maximum Ecw */
|
/** Maximum Ecw */
|
||||||
t_u8 ecw_max : 4;
|
t_u8 ecw_max : 4;
|
||||||
|
#endif /* BIG_ENDIAN_SUPPORT */
|
||||||
} wmm_ecw_t, *pwmm_ecw_t;
|
} wmm_ecw_t, *pwmm_ecw_t;
|
||||||
|
|
||||||
/** Data structure of WMM Aci/Aifsn */
|
/** Data structure of WMM Aci/Aifsn */
|
||||||
typedef struct _wmm_aci_aifsn_t {
|
typedef struct _wmm_aci_aifsn_t {
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
/** Reserved */
|
||||||
|
t_u8 reserved : 1;
|
||||||
|
/** Aci */
|
||||||
|
t_u8 aci : 2;
|
||||||
|
/** Acm */
|
||||||
|
t_u8 acm : 1;
|
||||||
|
/** Aifsn */
|
||||||
|
t_u8 aifsn : 4;
|
||||||
|
#else
|
||||||
/** Aifsn */
|
/** Aifsn */
|
||||||
t_u8 aifsn : 4;
|
t_u8 aifsn : 4;
|
||||||
/** Acm */
|
/** Acm */
|
||||||
|
@ -786,6 +803,7 @@ typedef struct _wmm_aci_aifsn_t {
|
||||||
t_u8 aci : 2;
|
t_u8 aci : 2;
|
||||||
/** Reserved */
|
/** Reserved */
|
||||||
t_u8 reserved : 1;
|
t_u8 reserved : 1;
|
||||||
|
#endif /* BIG_ENDIAN_SUPPORT */
|
||||||
} wmm_aci_aifsn_t, *pwmm_aci_aifsn_t;
|
} wmm_aci_aifsn_t, *pwmm_aci_aifsn_t;
|
||||||
|
|
||||||
/** Data structure of WMM AC parameters */
|
/** Data structure of WMM AC parameters */
|
||||||
|
@ -992,12 +1010,21 @@ typedef struct _wep_param {
|
||||||
|
|
||||||
/** Data structure of WMM QoS information */
|
/** Data structure of WMM QoS information */
|
||||||
typedef struct _wmm_qos_info_t {
|
typedef struct _wmm_qos_info_t {
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
/** QoS UAPSD */
|
||||||
|
t_u8 qos_uapsd : 1;
|
||||||
|
/** Reserved */
|
||||||
|
t_u8 reserved : 3;
|
||||||
|
/** Parameter set count */
|
||||||
|
t_u8 para_set_count : 4;
|
||||||
|
#else
|
||||||
/** Parameter set count */
|
/** Parameter set count */
|
||||||
t_u8 para_set_count : 4;
|
t_u8 para_set_count : 4;
|
||||||
/** Reserved */
|
/** Reserved */
|
||||||
t_u8 reserved : 3;
|
t_u8 reserved : 3;
|
||||||
/** QoS UAPSD */
|
/** QoS UAPSD */
|
||||||
t_u8 qos_uapsd : 1;
|
t_u8 qos_uapsd : 1;
|
||||||
|
#endif /* BIG_ENDIAN_SUPPORT */
|
||||||
} wmm_qos_info_t, *pwmm_qos_info_t;
|
} wmm_qos_info_t, *pwmm_qos_info_t;
|
||||||
|
|
||||||
/** Data structure of WMM parameter IE */
|
/** Data structure of WMM parameter IE */
|
||||||
|
@ -1913,6 +1940,100 @@ typedef struct _mlan_ver_ext {
|
||||||
char version_str[MLAN_MAX_VER_STR_LEN];
|
char version_str[MLAN_MAX_VER_STR_LEN];
|
||||||
} mlan_ver_ext, *pmlan_ver_ext;
|
} mlan_ver_ext, *pmlan_ver_ext;
|
||||||
|
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
/** Extended Capabilities Data */
|
||||||
|
typedef struct MLAN_PACK_START _ExtCap_t {
|
||||||
|
/** Extended Capabilities value */
|
||||||
|
t_u8 rsvdBit87 : 1; /* bit 87 */
|
||||||
|
t_u8 rsvdBit86 : 1; /* bit 86 */
|
||||||
|
t_u8 rsvdBit85 : 1; /* bit 85 */
|
||||||
|
t_u8 beacon_prot : 1; /* bit 84 */
|
||||||
|
t_u8 rsvdBit83 : 1; /* bit 83 */
|
||||||
|
t_u8 rsvdBit82 : 1; /* bit 82 */
|
||||||
|
t_u8 rsvdBit81 : 1; /* bit 81 */
|
||||||
|
t_u8 rsvdBit80 : 1; /* bit 80 */
|
||||||
|
t_u8 rsvdBit79 : 1; /* bit 79 */
|
||||||
|
t_u8 TWTResp : 1; /* bit 78 */
|
||||||
|
t_u8 TWTReq : 1; /* bit 77 */
|
||||||
|
t_u8 rsvdBit76 : 1; /* bit 76 */
|
||||||
|
t_u8 rsvdBit75 : 1; /* bit 75 */
|
||||||
|
t_u8 rsvdBit74 : 1; /* bit 74 */
|
||||||
|
t_u8 rsvdBit73 : 1; /* bit 73 */
|
||||||
|
t_u8 FILS : 1; /* bit 72 */
|
||||||
|
t_u8 FTMI : 1; /* bit 71 */
|
||||||
|
t_u8 FTMR : 1; /* bit 70 */
|
||||||
|
t_u8 CAQ : 1; /* bit 69 */
|
||||||
|
t_u8 rsvdBit68 : 1; /* bit 68 */
|
||||||
|
t_u8 NCC : 1; /* bit 67 */
|
||||||
|
t_u8 rsvdBit66 : 1; /* bit 66 */
|
||||||
|
t_u8 chanSchedMgnt : 1; /* bit 65 */
|
||||||
|
t_u8 MaxAMSDU1 : 1; /* bit 64 */
|
||||||
|
t_u8 MaxAMSDU0 : 1; /* bit 63 */
|
||||||
|
t_u8 OperModeNtf : 1; /* bit 62 */
|
||||||
|
t_u8 TDLSWildBandwidth : 1; /* bit 61 */
|
||||||
|
t_u8 rsvdBit60 : 1; /* bit 60 */
|
||||||
|
t_u8 rsvdBit59 : 1; /* bit 59 */
|
||||||
|
t_u8 rsvdBit58 : 1; /* bit 58 */
|
||||||
|
t_u8 rsvdBit57 : 1; /* bit 57 */
|
||||||
|
t_u8 rsvdBit56 : 1; /* bit 56 */
|
||||||
|
t_u8 rsvdBit55 : 1; /* bit 55 */
|
||||||
|
t_u8 rsvdBit54 : 1; /* bit 54 */
|
||||||
|
t_u8 rsvdBit53 : 1; /* bit 53 */
|
||||||
|
t_u8 rsvdBit52 : 1; /* bit 52 */
|
||||||
|
t_u8 rsvdBit51 : 1; /* bit 51 */
|
||||||
|
t_u8 rsvdBit50 : 1; /* bit 50 */
|
||||||
|
t_u8 rsvdBit49 : 1; /* bit 49 */
|
||||||
|
t_u8 rsvdBit48 : 1; /* bit 48 */
|
||||||
|
t_u8 rsvdBit47 : 1; /* bit 47 */
|
||||||
|
t_u8 rsvdBit46 : 1; /* bit 46 */
|
||||||
|
t_u8 rsvdBit45 : 1; /* bit 45 */
|
||||||
|
t_u8 rsvdBit44 : 1; /* bit 44 */
|
||||||
|
t_u8 rsvdBit43 : 1; /* bit 43 */
|
||||||
|
t_u8 rsvdBit42 : 1; /* bit 42 */
|
||||||
|
t_u8 rsvdBit41 : 1; /* bit 41 */
|
||||||
|
t_u8 rsvdBit40 : 1; /* bit 40 */
|
||||||
|
t_u8 TDLSChlSwitchProhib : 1; /* bit 39 */
|
||||||
|
t_u8 TDLSProhibited : 1; /* bit 38 */
|
||||||
|
t_u8 TDLSSupport : 1; /* bit 37 */
|
||||||
|
t_u8 MSGCF_Capa : 1; /* bit 36 */
|
||||||
|
t_u8 Reserved35 : 1; /* bit 35 */
|
||||||
|
t_u8 SSPN_Interface : 1; /* bit 34 */
|
||||||
|
t_u8 EBR : 1; /* bit 33 */
|
||||||
|
t_u8 Qos_Map : 1; /* bit 32 */
|
||||||
|
t_u8 Interworking : 1; /* bit 31 */
|
||||||
|
t_u8 TDLSChannelSwitching : 1; /* bit 30 */
|
||||||
|
t_u8 TDLSPeerPSMSupport : 1; /* bit 29 */
|
||||||
|
t_u8 TDLSPeerUAPSDSupport : 1; /* bit 28 */
|
||||||
|
t_u8 UTC : 1; /* bit 27 */
|
||||||
|
t_u8 DMS : 1; /* bit 26 */
|
||||||
|
t_u8 SSID_List : 1; /* bit 25 */
|
||||||
|
t_u8 ChannelUsage : 1; /* bit 24 */
|
||||||
|
t_u8 TimingMeasurement : 1; /* bit 23 */
|
||||||
|
t_u8 MultipleBSSID : 1; /* bit 22 */
|
||||||
|
t_u8 AC_StationCount : 1; /* bit 21 */
|
||||||
|
t_u8 QoSTrafficCap : 1; /* bit 20 */
|
||||||
|
t_u8 BSS_Transition : 1; /* bit 19 */
|
||||||
|
t_u8 TIM_Broadcast : 1; /* bit 18 */
|
||||||
|
t_u8 WNM_Sleep : 1; /* bit 17 */
|
||||||
|
t_u8 TFS : 1; /* bit 16 */
|
||||||
|
t_u8 GeospatialLocation : 1; /* bit 15 */
|
||||||
|
t_u8 CivicLocation : 1; /* bit 14 */
|
||||||
|
t_u8 CollocatedIntf : 1; /* bit 13 */
|
||||||
|
t_u8 ProxyARPService : 1; /* bit 12 */
|
||||||
|
t_u8 FMS : 1; /* bit 11 */
|
||||||
|
t_u8 LocationTracking : 1; /* bit 10 */
|
||||||
|
t_u8 MulticastDiagnostics : 1; /* bit 9 */
|
||||||
|
t_u8 Diagnostics : 1; /* bit 8 */
|
||||||
|
t_u8 Event : 1; /* bit 7 */
|
||||||
|
t_u8 SPSMP_Support : 1; /* bit 6 */
|
||||||
|
t_u8 Reserved5 : 1; /* bit 5 */
|
||||||
|
t_u8 PSMP_Capable : 1; /* bit 4 */
|
||||||
|
t_u8 RejectUnadmFrame : 1; /* bit 3 */
|
||||||
|
t_u8 ExtChanSwitching : 1; /* bit 2 */
|
||||||
|
t_u8 Reserved1 : 1; /* bit 1 */
|
||||||
|
t_u8 BSS_CoexistSupport : 1; /* bit 0 */
|
||||||
|
} MLAN_PACK_END ExtCap_t, *pExtCap_t;
|
||||||
|
#else
|
||||||
/** Extended Capabilities Data */
|
/** Extended Capabilities Data */
|
||||||
typedef struct MLAN_PACK_START _ExtCap_t {
|
typedef struct MLAN_PACK_START _ExtCap_t {
|
||||||
/** Extended Capabilities value */
|
/** Extended Capabilities value */
|
||||||
|
@ -2005,6 +2126,7 @@ typedef struct MLAN_PACK_START _ExtCap_t {
|
||||||
t_u8 rsvdBit86 : 1; /* bit 86 */
|
t_u8 rsvdBit86 : 1; /* bit 86 */
|
||||||
t_u8 rsvdBit87 : 1; /* bit 87 */
|
t_u8 rsvdBit87 : 1; /* bit 87 */
|
||||||
} MLAN_PACK_END ExtCap_t, *pExtCap_t;
|
} MLAN_PACK_END ExtCap_t, *pExtCap_t;
|
||||||
|
#endif
|
||||||
|
|
||||||
/** ExtCap : TDLS prohibited */
|
/** ExtCap : TDLS prohibited */
|
||||||
#define IS_EXTCAP_TDLS_PROHIBITED(ext_cap) (ext_cap.TDLSProhibited)
|
#define IS_EXTCAP_TDLS_PROHIBITED(ext_cap) (ext_cap.TDLSProhibited)
|
||||||
|
|
|
@ -1211,7 +1211,7 @@ int woal_cfg80211_change_virtual_intf(struct wiphy *wiphy,
|
||||||
#endif /* WIFI_DIRECT_SUPPORT */
|
#endif /* WIFI_DIRECT_SUPPORT */
|
||||||
#if defined(STA_SUPPORT) && defined(UAP_SUPPORT)
|
#if defined(STA_SUPPORT) && defined(UAP_SUPPORT)
|
||||||
if (priv->bss_type == MLAN_BSS_TYPE_UAP) {
|
if (priv->bss_type == MLAN_BSS_TYPE_UAP) {
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 15, 2)
|
#if ((CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 19, 2)) || IMX_ANDROID_13)
|
||||||
woal_cfg80211_del_beacon(wiphy, dev, 0);
|
woal_cfg80211_del_beacon(wiphy, dev, 0);
|
||||||
#else
|
#else
|
||||||
woal_cfg80211_del_beacon(wiphy, dev);
|
woal_cfg80211_del_beacon(wiphy, dev);
|
||||||
|
@ -1445,7 +1445,7 @@ fail:
|
||||||
*/
|
*/
|
||||||
#endif
|
#endif
|
||||||
int woal_cfg80211_add_key(struct wiphy *wiphy, struct net_device *netdev,
|
int woal_cfg80211_add_key(struct wiphy *wiphy, struct net_device *netdev,
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 15, 2)
|
#if ((CFG80211_VERSION_CODE >= KERNEL_VERSION(6, 0, 0)) || IMX_ANDROID_13)
|
||||||
int link_id,
|
int link_id,
|
||||||
#endif
|
#endif
|
||||||
t_u8 key_index,
|
t_u8 key_index,
|
||||||
|
@ -1504,7 +1504,7 @@ int woal_cfg80211_add_key(struct wiphy *wiphy, struct net_device *netdev,
|
||||||
*/
|
*/
|
||||||
#endif
|
#endif
|
||||||
int woal_cfg80211_del_key(struct wiphy *wiphy, struct net_device *netdev,
|
int woal_cfg80211_del_key(struct wiphy *wiphy, struct net_device *netdev,
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 15, 2)
|
#if ((CFG80211_VERSION_CODE >= KERNEL_VERSION(6, 0, 0)) || IMX_ANDROID_13)
|
||||||
int link_id,
|
int link_id,
|
||||||
#endif
|
#endif
|
||||||
t_u8 key_index,
|
t_u8 key_index,
|
||||||
|
@ -1563,7 +1563,7 @@ int woal_cfg80211_del_key(struct wiphy *wiphy, struct net_device *netdev,
|
||||||
#endif
|
#endif
|
||||||
int woal_cfg80211_set_default_key(struct wiphy *wiphy,
|
int woal_cfg80211_set_default_key(struct wiphy *wiphy,
|
||||||
struct net_device *netdev,
|
struct net_device *netdev,
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 15, 2)
|
#if ((CFG80211_VERSION_CODE >= KERNEL_VERSION(6, 0, 0)) || IMX_ANDROID_13)
|
||||||
int link_id,
|
int link_id,
|
||||||
#endif
|
#endif
|
||||||
t_u8 key_index
|
t_u8 key_index
|
||||||
|
@ -1598,7 +1598,7 @@ int woal_cfg80211_set_default_key(struct wiphy *wiphy,
|
||||||
#if KERNEL_VERSION(2, 6, 30) <= CFG80211_VERSION_CODE
|
#if KERNEL_VERSION(2, 6, 30) <= CFG80211_VERSION_CODE
|
||||||
int woal_cfg80211_set_default_mgmt_key(struct wiphy *wiphy,
|
int woal_cfg80211_set_default_mgmt_key(struct wiphy *wiphy,
|
||||||
struct net_device *netdev,
|
struct net_device *netdev,
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 15, 2)
|
#if ((CFG80211_VERSION_CODE >= KERNEL_VERSION(6, 0, 0)) || IMX_ANDROID_13)
|
||||||
int link_id,
|
int link_id,
|
||||||
#endif
|
#endif
|
||||||
t_u8 key_index)
|
t_u8 key_index)
|
||||||
|
@ -1612,7 +1612,7 @@ int woal_cfg80211_set_default_mgmt_key(struct wiphy *wiphy,
|
||||||
#if KERNEL_VERSION(5, 10, 0) <= CFG80211_VERSION_CODE
|
#if KERNEL_VERSION(5, 10, 0) <= CFG80211_VERSION_CODE
|
||||||
int woal_cfg80211_set_default_beacon_key(struct wiphy *wiphy,
|
int woal_cfg80211_set_default_beacon_key(struct wiphy *wiphy,
|
||||||
struct net_device *netdev,
|
struct net_device *netdev,
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 15, 2)
|
#if ((CFG80211_VERSION_CODE >= KERNEL_VERSION(6, 0, 0)) || IMX_ANDROID_13)
|
||||||
int link_id,
|
int link_id,
|
||||||
#endif
|
#endif
|
||||||
t_u8 key_index)
|
t_u8 key_index)
|
||||||
|
@ -2199,7 +2199,7 @@ done:
|
||||||
* @return 0 -- success, otherwise fail
|
* @return 0 -- success, otherwise fail
|
||||||
*/
|
*/
|
||||||
int woal_cfg80211_set_bitrate_mask(struct wiphy *wiphy, struct net_device *dev,
|
int woal_cfg80211_set_bitrate_mask(struct wiphy *wiphy, struct net_device *dev,
|
||||||
#if KERNEL_VERSION(5, 15, 2) <= CFG80211_VERSION_CODE
|
#if ((CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 19, 2)) || IMX_ANDROID_13)
|
||||||
unsigned int link_id,
|
unsigned int link_id,
|
||||||
#endif
|
#endif
|
||||||
const u8 *peer,
|
const u8 *peer,
|
||||||
|
@ -4715,7 +4715,7 @@ done:
|
||||||
*/
|
*/
|
||||||
void woal_cfg80211_free_bands(struct wiphy *wiphy)
|
void woal_cfg80211_free_bands(struct wiphy *wiphy)
|
||||||
{
|
{
|
||||||
enum nl80211_band band;
|
t_u8 band;
|
||||||
|
|
||||||
for (band = NL80211_BAND_2GHZ; band < IEEE80211_NUM_BANDS; ++band) {
|
for (band = NL80211_BAND_2GHZ; band < IEEE80211_NUM_BANDS; ++band) {
|
||||||
if (!wiphy->bands[band])
|
if (!wiphy->bands[band])
|
||||||
|
@ -4889,10 +4889,10 @@ void woal_cfg80211_notify_channel(moal_private *priv,
|
||||||
#if KERNEL_VERSION(3, 14, 0) <= CFG80211_VERSION_CODE
|
#if KERNEL_VERSION(3, 14, 0) <= CFG80211_VERSION_CODE
|
||||||
mutex_lock(&priv->wdev->mtx);
|
mutex_lock(&priv->wdev->mtx);
|
||||||
#endif
|
#endif
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 15, 2)
|
#if ((CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 19, 2)) || IMX_ANDROID_13)
|
||||||
cfg80211_ch_switch_notify(priv->netdev, &chandef, 0);
|
cfg80211_ch_switch_notify(priv->netdev, &chandef, 0);
|
||||||
#else
|
#else
|
||||||
cfg80211_ch_switch_notify(priv->netdev, &chandef, 0);
|
cfg80211_ch_switch_notify(priv->netdev, &chandef);
|
||||||
#endif
|
#endif
|
||||||
#if KERNEL_VERSION(3, 14, 0) <= CFG80211_VERSION_CODE
|
#if KERNEL_VERSION(3, 14, 0) <= CFG80211_VERSION_CODE
|
||||||
mutex_unlock(&priv->wdev->mtx);
|
mutex_unlock(&priv->wdev->mtx);
|
||||||
|
@ -5238,7 +5238,8 @@ int woal_get_wiphy_chan_dfs_state(struct wiphy *wiphy,
|
||||||
if (sband->channels[i].flags & IEEE80211_CHAN_RADAR) {
|
if (sband->channels[i].flags & IEEE80211_CHAN_RADAR) {
|
||||||
#if CFG80211_VERSION_CODE > KERNEL_VERSION(3, 8, 13)
|
#if CFG80211_VERSION_CODE > KERNEL_VERSION(3, 8, 13)
|
||||||
ch_dfs_state->dfs_state =
|
ch_dfs_state->dfs_state =
|
||||||
(dfs_state_t)sband->channels[i].dfs_state;
|
(dfs_state_t)sband->channels[i]
|
||||||
|
.dfs_state;
|
||||||
ch_dfs_state->dfs_required = MTRUE;
|
ch_dfs_state->dfs_required = MTRUE;
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
|
@ -128,7 +128,7 @@ int woal_cfg80211_change_virtual_intf(struct wiphy *wiphy,
|
||||||
int woal_cfg80211_set_wiphy_params(struct wiphy *wiphy, u32 changed);
|
int woal_cfg80211_set_wiphy_params(struct wiphy *wiphy, u32 changed);
|
||||||
|
|
||||||
int woal_cfg80211_add_key(struct wiphy *wiphy, struct net_device *dev,
|
int woal_cfg80211_add_key(struct wiphy *wiphy, struct net_device *dev,
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 15, 2)
|
#if ((CFG80211_VERSION_CODE >= KERNEL_VERSION(6, 0, 0)) || IMX_ANDROID_13)
|
||||||
int link_id,
|
int link_id,
|
||||||
#endif
|
#endif
|
||||||
t_u8 key_index,
|
t_u8 key_index,
|
||||||
|
@ -138,7 +138,7 @@ int woal_cfg80211_add_key(struct wiphy *wiphy, struct net_device *dev,
|
||||||
const t_u8 *mac_addr, struct key_params *params);
|
const t_u8 *mac_addr, struct key_params *params);
|
||||||
|
|
||||||
int woal_cfg80211_del_key(struct wiphy *wiphy, struct net_device *dev,
|
int woal_cfg80211_del_key(struct wiphy *wiphy, struct net_device *dev,
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 15, 2)
|
#if ((CFG80211_VERSION_CODE >= KERNEL_VERSION(6, 0, 0)) || IMX_ANDROID_13)
|
||||||
int link_id,
|
int link_id,
|
||||||
#endif
|
#endif
|
||||||
t_u8 key_index,
|
t_u8 key_index,
|
||||||
|
@ -162,7 +162,7 @@ int woal_cfg80211_flush_pmksa(struct wiphy *wiphy, struct net_device *dev);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
int woal_cfg80211_set_bitrate_mask(struct wiphy *wiphy, struct net_device *dev,
|
int woal_cfg80211_set_bitrate_mask(struct wiphy *wiphy, struct net_device *dev,
|
||||||
#if KERNEL_VERSION(5, 15, 2) <= CFG80211_VERSION_CODE
|
#if ((CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 19, 2)) || IMX_ANDROID_13)
|
||||||
unsigned int link_id,
|
unsigned int link_id,
|
||||||
#endif
|
#endif
|
||||||
const u8 *peer,
|
const u8 *peer,
|
||||||
|
@ -213,7 +213,7 @@ int woal_cfg80211_set_channel(struct wiphy *wiphy,
|
||||||
|
|
||||||
#if KERNEL_VERSION(2, 6, 37) < CFG80211_VERSION_CODE
|
#if KERNEL_VERSION(2, 6, 37) < CFG80211_VERSION_CODE
|
||||||
int woal_cfg80211_set_default_key(struct wiphy *wiphy, struct net_device *dev,
|
int woal_cfg80211_set_default_key(struct wiphy *wiphy, struct net_device *dev,
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 15, 2)
|
#if ((CFG80211_VERSION_CODE >= KERNEL_VERSION(6, 0, 0)) || IMX_ANDROID_13)
|
||||||
int link_id,
|
int link_id,
|
||||||
#endif
|
#endif
|
||||||
t_u8 key_index, bool ucast, bool mcast);
|
t_u8 key_index, bool ucast, bool mcast);
|
||||||
|
@ -225,7 +225,7 @@ int woal_cfg80211_set_default_key(struct wiphy *wiphy, struct net_device *dev,
|
||||||
#if KERNEL_VERSION(2, 6, 30) <= CFG80211_VERSION_CODE
|
#if KERNEL_VERSION(2, 6, 30) <= CFG80211_VERSION_CODE
|
||||||
int woal_cfg80211_set_default_mgmt_key(struct wiphy *wiphy,
|
int woal_cfg80211_set_default_mgmt_key(struct wiphy *wiphy,
|
||||||
struct net_device *netdev,
|
struct net_device *netdev,
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 15, 2)
|
#if ((CFG80211_VERSION_CODE >= KERNEL_VERSION(6, 0, 0)) || IMX_ANDROID_13)
|
||||||
int link_id,
|
int link_id,
|
||||||
#endif
|
#endif
|
||||||
t_u8 key_index);
|
t_u8 key_index);
|
||||||
|
@ -234,7 +234,7 @@ int woal_cfg80211_set_default_mgmt_key(struct wiphy *wiphy,
|
||||||
#if KERNEL_VERSION(5, 10, 0) <= CFG80211_VERSION_CODE
|
#if KERNEL_VERSION(5, 10, 0) <= CFG80211_VERSION_CODE
|
||||||
int woal_cfg80211_set_default_beacon_key(struct wiphy *wiphy,
|
int woal_cfg80211_set_default_beacon_key(struct wiphy *wiphy,
|
||||||
struct net_device *netdev,
|
struct net_device *netdev,
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 15, 2)
|
#if ((CFG80211_VERSION_CODE >= KERNEL_VERSION(6, 0, 0)) || IMX_ANDROID_13)
|
||||||
int link_id,
|
int link_id,
|
||||||
#endif
|
#endif
|
||||||
t_u8 key_index);
|
t_u8 key_index);
|
||||||
|
@ -436,7 +436,7 @@ int woal_cfg80211_set_beacon(struct wiphy *wiphy, struct net_device *dev,
|
||||||
struct beacon_parameters *params);
|
struct beacon_parameters *params);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if KERNEL_VERSION(5, 15, 2) <= CFG80211_VERSION_CODE
|
#if ((CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 19, 2)) || IMX_ANDROID_13)
|
||||||
int woal_cfg80211_del_beacon(struct wiphy *wiphy, struct net_device *dev,
|
int woal_cfg80211_del_beacon(struct wiphy *wiphy, struct net_device *dev,
|
||||||
unsigned int link_id);
|
unsigned int link_id);
|
||||||
#else
|
#else
|
||||||
|
|
|
@ -52,6 +52,18 @@ static const struct nl80211_vendor_cmd_info vendor_events[] = {
|
||||||
.vendor_id = MRVL_VENDOR_ID,
|
.vendor_id = MRVL_VENDOR_ID,
|
||||||
.subcmd = event_fw_dump_done,
|
.subcmd = event_fw_dump_done,
|
||||||
}, /*event_id 1*/
|
}, /*event_id 1*/
|
||||||
|
{
|
||||||
|
.vendor_id = MRVL_VENDOR_ID,
|
||||||
|
.subcmd = event_fw_reset_success,
|
||||||
|
}, /*event_id 2*/
|
||||||
|
{
|
||||||
|
.vendor_id = MRVL_VENDOR_ID,
|
||||||
|
.subcmd = event_fw_reset_failure,
|
||||||
|
}, /*event_id 3*/
|
||||||
|
{
|
||||||
|
.vendor_id = MRVL_VENDOR_ID,
|
||||||
|
.subcmd = event_fw_reset_start,
|
||||||
|
}, /*event_id 4*/
|
||||||
{
|
{
|
||||||
.vendor_id = MRVL_VENDOR_ID,
|
.vendor_id = MRVL_VENDOR_ID,
|
||||||
.subcmd = event_rssi_monitor,
|
.subcmd = event_rssi_monitor,
|
||||||
|
@ -775,7 +787,8 @@ static int woal_cfg80211_subcmd_get_supp_feature_set(struct wiphy *wiphy,
|
||||||
| WLAN_FEATURE_LINK_LAYER_STATS |
|
| WLAN_FEATURE_LINK_LAYER_STATS |
|
||||||
WLAN_FEATURE_LOGGER | WLAN_FEATURE_RSSI_MONITOR |
|
WLAN_FEATURE_LOGGER | WLAN_FEATURE_RSSI_MONITOR |
|
||||||
WLAN_FEATURE_CONFIG_NDO | WLAN_FEATURE_SCAN_RAND |
|
WLAN_FEATURE_CONFIG_NDO | WLAN_FEATURE_SCAN_RAND |
|
||||||
WLAN_FEATURE_MKEEP_ALIVE | WLAN_FEATURE_PNO;
|
WLAN_FEATURE_MKEEP_ALIVE | WLAN_FEATURE_PNO |
|
||||||
|
WLAN_FEATURE_TDLS;
|
||||||
|
|
||||||
memset(&fw_info, 0, sizeof(mlan_fw_info));
|
memset(&fw_info, 0, sizeof(mlan_fw_info));
|
||||||
if (MLAN_STATUS_SUCCESS !=
|
if (MLAN_STATUS_SUCCESS !=
|
||||||
|
|
|
@ -626,6 +626,7 @@ enum vendor_event {
|
||||||
event_fw_dump_done = 1,
|
event_fw_dump_done = 1,
|
||||||
event_fw_reset_success = 2,
|
event_fw_reset_success = 2,
|
||||||
event_fw_reset_failure = 3,
|
event_fw_reset_failure = 3,
|
||||||
|
event_fw_reset_start = 4,
|
||||||
event_rssi_monitor = 0x1501,
|
event_rssi_monitor = 0x1501,
|
||||||
event_set_key_mgmt_offload = 0x10001,
|
event_set_key_mgmt_offload = 0x10001,
|
||||||
event_fw_roam_success = 0x10002,
|
event_fw_roam_success = 0x10002,
|
||||||
|
|
|
@ -16380,6 +16380,7 @@ static int woal_priv_extend_channel_switch(moal_private *priv, t_u8 *respbuf,
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
int user_data_len = 0;
|
int user_data_len = 0;
|
||||||
int data[5] = {0};
|
int data[5] = {0};
|
||||||
|
t_u8 channel;
|
||||||
mlan_ds_11h_chan_dfs_state ch_dfs;
|
mlan_ds_11h_chan_dfs_state ch_dfs;
|
||||||
ENTER();
|
ENTER();
|
||||||
|
|
||||||
|
@ -16409,8 +16410,13 @@ static int woal_priv_extend_channel_switch(moal_private *priv, t_u8 *respbuf,
|
||||||
LEAVE();
|
LEAVE();
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* For 2.4G channels skip the DFS checks */
|
||||||
|
channel = data[2];
|
||||||
|
if (channel > MAX_BG_CHANNEL) {
|
||||||
memset(&ch_dfs, 0, sizeof(ch_dfs));
|
memset(&ch_dfs, 0, sizeof(ch_dfs));
|
||||||
ch_dfs.channel = data[2];
|
ch_dfs.channel = data[2];
|
||||||
|
|
||||||
if (woal_11h_chan_dfs_state(priv, MLAN_ACT_GET, &ch_dfs)) {
|
if (woal_11h_chan_dfs_state(priv, MLAN_ACT_GET, &ch_dfs)) {
|
||||||
PRINTM(MERROR, "%s: woal_11h_chan_dfs_state failed \n",
|
PRINTM(MERROR, "%s: woal_11h_chan_dfs_state failed \n",
|
||||||
__func__);
|
__func__);
|
||||||
|
@ -16418,7 +16424,9 @@ static int woal_priv_extend_channel_switch(moal_private *priv, t_u8 *respbuf,
|
||||||
LEAVE();
|
LEAVE();
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
if (ch_dfs.dfs_required && (ch_dfs.dfs_state == DFS_UNAVAILABLE ||
|
|
||||||
|
if (ch_dfs.dfs_required &&
|
||||||
|
(ch_dfs.dfs_state == DFS_UNAVAILABLE ||
|
||||||
ch_dfs.dfs_state == DFS_USABLE)) {
|
ch_dfs.dfs_state == DFS_USABLE)) {
|
||||||
PRINTM(MERROR,
|
PRINTM(MERROR,
|
||||||
"DFS: Channel=%d is not Available, cannot switch to this channel\n",
|
"DFS: Channel=%d is not Available, cannot switch to this channel\n",
|
||||||
|
@ -16427,8 +16435,10 @@ static int woal_priv_extend_channel_switch(moal_private *priv, t_u8 *respbuf,
|
||||||
LEAVE();
|
LEAVE();
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ch_dfs.dfs_required)
|
if (ch_dfs.dfs_required)
|
||||||
woal_enable_dfs(priv, data[2], MOAL_IOCTL_WAIT);
|
woal_enable_dfs(priv, data[2], MOAL_IOCTL_WAIT);
|
||||||
|
}
|
||||||
if (data[1]) {
|
if (data[1]) {
|
||||||
if (woal_check_valid_channel_operclass(priv, data[2],
|
if (woal_check_valid_channel_operclass(priv, data[2],
|
||||||
data[1])) {
|
data[1])) {
|
||||||
|
|
|
@ -7541,15 +7541,41 @@ static int parse_radio_mode_string(const char *s, size_t len,
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* @brief PoweLevelToDUT11Bits
|
||||||
|
*
|
||||||
|
* @param Pwr A user txpwr values of type int
|
||||||
|
* @param PowerLevel A Pointer of uint32 type for converted txpwr vals
|
||||||
|
* @return nothing just exit
|
||||||
|
*/
|
||||||
|
|
||||||
|
static void PoweLevelToDUT11Bits(int Pwr, t_u32 *PowerLevel)
|
||||||
|
{
|
||||||
|
int Z = 0;
|
||||||
|
|
||||||
|
if ((Pwr > 64) || (Pwr < -64))
|
||||||
|
return;
|
||||||
|
|
||||||
|
Z = (int)(Pwr * 16);
|
||||||
|
if (Z < 0) {
|
||||||
|
Z = Z + (1 << 11);
|
||||||
|
}
|
||||||
|
(*PowerLevel) = (t_u32)Z;
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* @brief Parse mfg cmd tx pwr string
|
* @brief Parse mfg cmd tx pwr string
|
||||||
*
|
*
|
||||||
|
* @param handle A pointer to moal_handle structure
|
||||||
* @param s A pointer to user buffer
|
* @param s A pointer to user buffer
|
||||||
* @param len Length of user buffer
|
* @param len Length of user buffer
|
||||||
* @param d A pointer to mfg_cmd_generic_cfg struct
|
* @param d A pointer to mfg_cmd_generic_cfg struct
|
||||||
* @return 0 on success, -EINVAL otherwise
|
* @return 0 on success, -EINVAL otherwise
|
||||||
*/
|
*/
|
||||||
static int parse_tx_pwr_string(const char *s, size_t len,
|
|
||||||
|
static int parse_tx_pwr_string(moal_handle *handle, const char *s, size_t len,
|
||||||
struct mfg_cmd_generic_cfg *d)
|
struct mfg_cmd_generic_cfg *d)
|
||||||
{
|
{
|
||||||
int ret = MLAN_STATUS_SUCCESS;
|
int ret = MLAN_STATUS_SUCCESS;
|
||||||
|
@ -7557,12 +7583,19 @@ static int parse_tx_pwr_string(const char *s, size_t len,
|
||||||
char *tmp = NULL;
|
char *tmp = NULL;
|
||||||
char *pos = NULL;
|
char *pos = NULL;
|
||||||
gfp_t flag;
|
gfp_t flag;
|
||||||
|
t_u32 tx_pwr_converted = 0xffffffff;
|
||||||
|
int tx_pwr_local = 0;
|
||||||
|
t_u8 fc_card = MFALSE;
|
||||||
|
|
||||||
ENTER();
|
ENTER();
|
||||||
if (!s || !d) {
|
if (!s || !d) {
|
||||||
LEAVE();
|
LEAVE();
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
#ifdef SD9177
|
||||||
|
if (IS_SD9177(handle->card_type))
|
||||||
|
fc_card = MTRUE;
|
||||||
|
#endif
|
||||||
flag = (in_atomic() || irqs_disabled()) ? GFP_ATOMIC : GFP_KERNEL;
|
flag = (in_atomic() || irqs_disabled()) ? GFP_ATOMIC : GFP_KERNEL;
|
||||||
string = kzalloc(TX_PWR_STR_LEN, flag);
|
string = kzalloc(TX_PWR_STR_LEN, flag);
|
||||||
if (string == NULL) {
|
if (string == NULL) {
|
||||||
|
@ -7578,9 +7611,15 @@ static int parse_tx_pwr_string(const char *s, size_t len,
|
||||||
|
|
||||||
/* tx power value */
|
/* tx power value */
|
||||||
pos = strsep(&string, " \t");
|
pos = strsep(&string, " \t");
|
||||||
if (pos)
|
if (fc_card && pos) {
|
||||||
|
/* for sd9177 we need to convert user power vals including -ve
|
||||||
|
* vals as per labtool */
|
||||||
|
tx_pwr_local = woal_string_to_number(pos);
|
||||||
|
PoweLevelToDUT11Bits(tx_pwr_local, &tx_pwr_converted);
|
||||||
|
d->data1 = tx_pwr_converted;
|
||||||
|
} else if (pos) {
|
||||||
d->data1 = (t_u32)woal_string_to_number(pos);
|
d->data1 = (t_u32)woal_string_to_number(pos);
|
||||||
|
}
|
||||||
/* modulation */
|
/* modulation */
|
||||||
pos = strsep(&string, " \t");
|
pos = strsep(&string, " \t");
|
||||||
if (pos)
|
if (pos)
|
||||||
|
@ -7591,7 +7630,7 @@ static int parse_tx_pwr_string(const char *s, size_t len,
|
||||||
if (pos)
|
if (pos)
|
||||||
d->data3 = (t_u32)woal_string_to_number(pos);
|
d->data3 = (t_u32)woal_string_to_number(pos);
|
||||||
|
|
||||||
if ((d->data1 > 24) || (d->data2 > 2))
|
if (((!fc_card) && (d->data1 > 24)) || (d->data2 > 2))
|
||||||
ret = -EINVAL;
|
ret = -EINVAL;
|
||||||
|
|
||||||
kfree(tmp);
|
kfree(tmp);
|
||||||
|
@ -7637,13 +7676,13 @@ static int parse_tx_cont_string(const char *s, size_t len,
|
||||||
if (pos)
|
if (pos)
|
||||||
d->enable_tx = (t_u32)woal_string_to_number(pos);
|
d->enable_tx = (t_u32)woal_string_to_number(pos);
|
||||||
|
|
||||||
if (d->enable_tx == MFALSE)
|
|
||||||
goto done;
|
|
||||||
|
|
||||||
pos = strsep(&string, " \t");
|
pos = strsep(&string, " \t");
|
||||||
if (pos)
|
if (pos)
|
||||||
d->cw_mode = (t_u32)woal_string_to_number(pos);
|
d->cw_mode = (t_u32)woal_string_to_number(pos);
|
||||||
|
|
||||||
|
if (d->enable_tx == MFALSE)
|
||||||
|
goto done;
|
||||||
|
|
||||||
pos = strsep(&string, " \t");
|
pos = strsep(&string, " \t");
|
||||||
if (pos)
|
if (pos)
|
||||||
d->payload_pattern = (t_u32)woal_string_to_number(pos);
|
d->payload_pattern = (t_u32)woal_string_to_number(pos);
|
||||||
|
@ -7997,7 +8036,7 @@ mlan_status woal_process_rf_test_mode_cmd(moal_handle *handle, t_u32 cmd,
|
||||||
err = MTRUE;
|
err = MTRUE;
|
||||||
break;
|
break;
|
||||||
case MFG_CMD_RFPWR:
|
case MFG_CMD_RFPWR:
|
||||||
if (parse_tx_pwr_string(buffer, len,
|
if (parse_tx_pwr_string(handle, buffer, len,
|
||||||
&misc->param.mfg_generic_cfg))
|
&misc->param.mfg_generic_cfg))
|
||||||
err = MTRUE;
|
err = MTRUE;
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -939,9 +939,9 @@ static void woal_hang_work_queue(struct work_struct *work)
|
||||||
cfg80211_wext = reset_handle->params.cfg80211_wext;
|
cfg80211_wext = reset_handle->params.cfg80211_wext;
|
||||||
// stop pending scan
|
// stop pending scan
|
||||||
#ifdef STA_CFG80211
|
#ifdef STA_CFG80211
|
||||||
if (IS_STA_CFG80211(cfg80211_wext) && reset_handle->scan_request) {
|
if (IS_STA_CFG80211(cfg80211_wext) && reset_handle->scan_request &&
|
||||||
|
reset_handle->scan_priv) {
|
||||||
moal_private *scan_priv = reset_handle->scan_priv;
|
moal_private *scan_priv = reset_handle->scan_priv;
|
||||||
cancel_delayed_work_sync(&reset_handle->scan_timeout_work);
|
|
||||||
/** some supplicant can not handle SCAN abort event */
|
/** some supplicant can not handle SCAN abort event */
|
||||||
if (scan_priv->bss_type == MLAN_BSS_TYPE_STA)
|
if (scan_priv->bss_type == MLAN_BSS_TYPE_STA)
|
||||||
woal_cfg80211_scan_done(reset_handle->scan_request,
|
woal_cfg80211_scan_done(reset_handle->scan_request,
|
||||||
|
@ -951,6 +951,7 @@ static void woal_hang_work_queue(struct work_struct *work)
|
||||||
MFALSE);
|
MFALSE);
|
||||||
reset_handle->scan_request = NULL;
|
reset_handle->scan_request = NULL;
|
||||||
reset_handle->scan_priv = NULL;
|
reset_handle->scan_priv = NULL;
|
||||||
|
cancel_delayed_work_sync(&reset_handle->scan_timeout_work);
|
||||||
reset_handle->scan_pending_on_block = MFALSE;
|
reset_handle->scan_pending_on_block = MFALSE;
|
||||||
MOAL_REL_SEMAPHORE(&reset_handle->async_sem);
|
MOAL_REL_SEMAPHORE(&reset_handle->async_sem);
|
||||||
}
|
}
|
||||||
|
@ -968,10 +969,10 @@ static void woal_hang_work_queue(struct work_struct *work)
|
||||||
#ifdef STA_CFG80211
|
#ifdef STA_CFG80211
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 11, 0)
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 11, 0)
|
||||||
if (IS_STA_CFG80211(cfg80211_wext) && priv->wdev &&
|
if (IS_STA_CFG80211(cfg80211_wext) && priv->wdev &&
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 19, 2)
|
#if ((CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 19, 2)) || IMX_ANDROID_13)
|
||||||
priv->wdev->connected) {
|
priv->wdev->connected) {
|
||||||
#else
|
#else
|
||||||
priv->wdev->connected) {
|
priv->wdev->current_bss) {
|
||||||
#endif
|
#endif
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 8, 0)
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 8, 0)
|
||||||
if (priv->host_mlme)
|
if (priv->host_mlme)
|
||||||
|
@ -1015,14 +1016,25 @@ static void woal_hang_work_queue(struct work_struct *work)
|
||||||
if (priv) {
|
if (priv) {
|
||||||
woal_broadcast_event(priv, CUS_EVT_FW_RECOVER_START,
|
woal_broadcast_event(priv, CUS_EVT_FW_RECOVER_START,
|
||||||
strlen(CUS_EVT_FW_RECOVER_START));
|
strlen(CUS_EVT_FW_RECOVER_START));
|
||||||
|
#ifdef STA_CFG80211
|
||||||
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 14, 0)
|
||||||
|
if (IS_STA_OR_UAP_CFG80211(cfg80211_wext))
|
||||||
|
woal_cfg80211_vendor_event(
|
||||||
|
priv, event_fw_reset_start,
|
||||||
|
CUS_EVT_FW_RECOVER_START,
|
||||||
|
strlen(CUS_EVT_FW_RECOVER_START));
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
if (IS_SD(reset_handle->card_type)) {
|
if (IS_SD(reset_handle->card_type)) {
|
||||||
|
PRINTM(MMSG, "WIFI auto_fw_reload: fw_reload=1\n");
|
||||||
ret = woal_request_fw_reload(
|
ret = woal_request_fw_reload(
|
||||||
reset_handle, FW_RELOAD_SDIO_INBAND_RESET);
|
reset_handle, FW_RELOAD_SDIO_INBAND_RESET);
|
||||||
}
|
}
|
||||||
#ifdef PCIE
|
#ifdef PCIE
|
||||||
else if (IS_PCIE(reset_handle->card_type)) {
|
else if (IS_PCIE(reset_handle->card_type)) {
|
||||||
reset_handle->init_wait_q_woken = MFALSE;
|
reset_handle->init_wait_q_woken = MFALSE;
|
||||||
|
PRINTM(MMSG, "WIFI auto_fw_reload: fw_reload=4\n");
|
||||||
ret = woal_request_fw_reload(reset_handle,
|
ret = woal_request_fw_reload(reset_handle,
|
||||||
FW_RELOAD_PCIE_RESET);
|
FW_RELOAD_PCIE_RESET);
|
||||||
if (!ret) {
|
if (!ret) {
|
||||||
|
@ -3897,7 +3909,7 @@ static mlan_status woal_init_fw_dpc(moal_handle *handle)
|
||||||
fw.fw_reload = handle->params.fw_reload;
|
fw.fw_reload = handle->params.fw_reload;
|
||||||
else
|
else
|
||||||
fw.fw_reload = 0;
|
fw.fw_reload = 0;
|
||||||
wifi_status = WIFI_STATUS_OK;
|
wifi_status = WIFI_STATUS_FW_DNLD;
|
||||||
ret = mlan_dnld_fw(handle->pmlan_adapter, &fw);
|
ret = mlan_dnld_fw(handle->pmlan_adapter, &fw);
|
||||||
if (ret == MLAN_STATUS_FAILURE) {
|
if (ret == MLAN_STATUS_FAILURE) {
|
||||||
wifi_status = WIFI_STATUS_DNLD_FW_FAIL;
|
wifi_status = WIFI_STATUS_DNLD_FW_FAIL;
|
||||||
|
@ -3908,7 +3920,7 @@ static mlan_status woal_init_fw_dpc(moal_handle *handle)
|
||||||
handle->ops.reg_dbg(handle);
|
handle->ops.reg_dbg(handle);
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
wifi_status = WIFI_STATUS_OK;
|
wifi_status = WIFI_STATUS_FW_DNLD_COMPLETE;
|
||||||
|
|
||||||
#if defined(USB)
|
#if defined(USB)
|
||||||
if (handle->boot_state == USB_FW_DNLD) {
|
if (handle->boot_state == USB_FW_DNLD) {
|
||||||
|
@ -3962,11 +3974,13 @@ static mlan_status woal_init_fw_dpc(moal_handle *handle)
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
handle->init_wait_q_woken = MFALSE;
|
handle->init_wait_q_woken = MFALSE;
|
||||||
|
wifi_status = WIFI_STATUS_INIT_FW;
|
||||||
ret = mlan_init_fw(handle->pmlan_adapter);
|
ret = mlan_init_fw(handle->pmlan_adapter);
|
||||||
if (ret == MLAN_STATUS_FAILURE) {
|
if (ret == MLAN_STATUS_FAILURE) {
|
||||||
wifi_status = WIFI_STATUS_INIT_FW_FAIL;
|
wifi_status = WIFI_STATUS_INIT_FW_FAIL;
|
||||||
goto done;
|
goto done;
|
||||||
} else if (ret == MLAN_STATUS_SUCCESS) {
|
} else if (ret == MLAN_STATUS_SUCCESS) {
|
||||||
|
wifi_status = WIFI_STATUS_OK;
|
||||||
handle->hardware_status = HardwareStatusReady;
|
handle->hardware_status = HardwareStatusReady;
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
|
@ -3987,6 +4001,7 @@ static mlan_status woal_init_fw_dpc(moal_handle *handle)
|
||||||
ret = MLAN_STATUS_FAILURE;
|
ret = MLAN_STATUS_FAILURE;
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
|
wifi_status = WIFI_STATUS_OK;
|
||||||
ret = MLAN_STATUS_SUCCESS;
|
ret = MLAN_STATUS_SUCCESS;
|
||||||
done:
|
done:
|
||||||
if (handle->dpd_data) {
|
if (handle->dpd_data) {
|
||||||
|
@ -4665,7 +4680,7 @@ mlan_status woal_init_sta_dev(struct net_device *dev, moal_private *priv)
|
||||||
(MAX_MTU_SIZE + MLAN_MIN_DATA_HEADER_LEN +
|
(MAX_MTU_SIZE + MLAN_MIN_DATA_HEADER_LEN +
|
||||||
priv->extra_tx_head_len)) {
|
priv->extra_tx_head_len)) {
|
||||||
dev->max_mtu = MAX_MTU_SIZE;
|
dev->max_mtu = MAX_MTU_SIZE;
|
||||||
PRINTM(MMSG, "wlan: %s set max_mtu %d\n", dev->name,
|
PRINTM(MINFO, "wlan: %s set max_mtu %d\n", dev->name,
|
||||||
dev->max_mtu);
|
dev->max_mtu);
|
||||||
}
|
}
|
||||||
#ifdef MFG_CMD_SUPPORT
|
#ifdef MFG_CMD_SUPPORT
|
||||||
|
@ -4836,69 +4851,65 @@ moal_private *woal_add_interface(moal_handle *handle, t_u8 bss_index,
|
||||||
#endif
|
#endif
|
||||||
ENTER();
|
ENTER();
|
||||||
|
|
||||||
#if LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 29)
|
|
||||||
#define MAX_WMM_QUEUE 4
|
|
||||||
/* Allocate an Ethernet device */
|
|
||||||
dev = alloc_etherdev_mq(sizeof(moal_private), MAX_WMM_QUEUE);
|
|
||||||
#else
|
|
||||||
dev = alloc_etherdev(sizeof(moal_private));
|
|
||||||
#endif
|
|
||||||
if (!dev) {
|
|
||||||
PRINTM(MFATAL, "Init virtual ethernet device failed\n");
|
|
||||||
goto error;
|
|
||||||
}
|
|
||||||
/* Allocate device name */
|
|
||||||
#ifdef STA_SUPPORT
|
|
||||||
memset(name, 0, sizeof(name));
|
memset(name, 0, sizeof(name));
|
||||||
|
switch (bss_type) {
|
||||||
|
#ifdef STA_SUPPORT
|
||||||
|
case MLAN_BSS_TYPE_STA:
|
||||||
if (handle->params.sta_name)
|
if (handle->params.sta_name)
|
||||||
snprintf(name, sizeof(name), "%s%%d", handle->params.sta_name);
|
snprintf(name, sizeof(name), "%s%%d",
|
||||||
|
handle->params.sta_name);
|
||||||
else if (handle->second_mac)
|
else if (handle->second_mac)
|
||||||
snprintf(name, sizeof(name), "m%s", default_mlan_name);
|
snprintf(name, sizeof(name), "m%s", default_mlan_name);
|
||||||
else
|
else
|
||||||
snprintf(name, sizeof(name), "%s", default_mlan_name);
|
snprintf(name, sizeof(name), "%s", default_mlan_name);
|
||||||
|
break;
|
||||||
if ((bss_type == MLAN_BSS_TYPE_STA) &&
|
|
||||||
(dev_alloc_name(dev, name) < 0)) {
|
|
||||||
PRINTM(MERROR, "Could not allocate mlan device name\n");
|
|
||||||
goto error;
|
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
#ifdef UAP_SUPPORT
|
#ifdef UAP_SUPPORT
|
||||||
memset(name, 0, sizeof(name));
|
case MLAN_BSS_TYPE_UAP:
|
||||||
if (handle->params.uap_name)
|
if (handle->params.uap_name)
|
||||||
snprintf(name, sizeof(name), "%s%%d", handle->params.uap_name);
|
snprintf(name, sizeof(name), "%s%%d",
|
||||||
|
handle->params.uap_name);
|
||||||
else if (handle->second_mac)
|
else if (handle->second_mac)
|
||||||
snprintf(name, sizeof(name), "m%s", default_uap_name);
|
snprintf(name, sizeof(name), "m%s", default_uap_name);
|
||||||
else
|
else
|
||||||
snprintf(name, sizeof(name), "%s", default_uap_name);
|
snprintf(name, sizeof(name), "%s", default_uap_name);
|
||||||
if ((bss_type == MLAN_BSS_TYPE_UAP) &&
|
break;
|
||||||
(dev_alloc_name(dev, name) < 0)) {
|
|
||||||
PRINTM(MERROR, "Could not allocate uap device name\n");
|
|
||||||
goto error;
|
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
#ifdef WIFI_DIRECT_SUPPORT
|
#ifdef WIFI_DIRECT_SUPPORT
|
||||||
memset(name, 0, sizeof(name));
|
case MLAN_BSS_TYPE_WIFIDIRECT:
|
||||||
if (handle->params.wfd_name)
|
if (handle->params.wfd_name)
|
||||||
snprintf(name, sizeof(name), "%s%%d", handle->params.wfd_name);
|
snprintf(name, sizeof(name), "%s%%d",
|
||||||
|
handle->params.wfd_name);
|
||||||
else if (handle->second_mac)
|
else if (handle->second_mac)
|
||||||
snprintf(name, sizeof(name), "m%s", default_wfd_name);
|
snprintf(name, sizeof(name), "m%s", default_wfd_name);
|
||||||
else
|
else
|
||||||
snprintf(name, sizeof(name), "%s", default_wfd_name);
|
snprintf(name, sizeof(name), "%s", default_wfd_name);
|
||||||
if ((bss_type == MLAN_BSS_TYPE_WIFIDIRECT) &&
|
break;
|
||||||
(dev_alloc_name(dev, name) < 0)) {
|
|
||||||
PRINTM(MERROR, "Could not allocate wifidirect device name\n");
|
|
||||||
goto error;
|
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
memset(name, 0, sizeof(name));
|
case MLAN_BSS_TYPE_DFS:
|
||||||
if (handle->second_mac)
|
if (handle->second_mac)
|
||||||
snprintf(name, sizeof(name), "m%s", default_dfs_name);
|
snprintf(name, sizeof(name), "m%s", default_dfs_name);
|
||||||
else
|
else
|
||||||
snprintf(name, sizeof(name), "%s", default_dfs_name);
|
snprintf(name, sizeof(name), "%s", default_dfs_name);
|
||||||
if ((bss_type == MLAN_BSS_TYPE_DFS) &&
|
break;
|
||||||
(dev_alloc_name(dev, name) < 0)) {
|
default:
|
||||||
PRINTM(MERROR, "Could not allocate DFS device name\n");
|
PRINTM(MERROR, "woal_add_interface: invalid bss_type=%d\n",
|
||||||
|
bss_type);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
#define MAX_WMM_QUEUE 4
|
||||||
|
#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 17, 0)
|
||||||
|
/* Allocate an net device */
|
||||||
|
dev = alloc_netdev_mq(sizeof(moal_private), name, NET_NAME_UNKNOWN,
|
||||||
|
ether_setup, MAX_WMM_QUEUE);
|
||||||
|
#else
|
||||||
|
dev = alloc_netdev_mq(sizeof(moal_private), name, ether_setup,
|
||||||
|
MAX_WMM_QUEUE);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
if (!dev) {
|
||||||
|
PRINTM(MERROR, "alloc_netdev failed\n");
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
priv = (moal_private *)netdev_priv(dev);
|
priv = (moal_private *)netdev_priv(dev);
|
||||||
|
@ -5102,7 +5113,7 @@ moal_private *woal_add_interface(moal_handle *handle, t_u8 bss_index,
|
||||||
netif_carrier_off(dev);
|
netif_carrier_off(dev);
|
||||||
woal_stop_queue(dev);
|
woal_stop_queue(dev);
|
||||||
|
|
||||||
PRINTM(MINFO, "%s: NXP 802.11 Adapter\n", dev->name);
|
PRINTM(MMSG, "Register NXP 802.11 Adapter %s\n", dev->name);
|
||||||
|
|
||||||
if (bss_type == MLAN_BSS_TYPE_STA ||
|
if (bss_type == MLAN_BSS_TYPE_STA ||
|
||||||
priv->bss_type == MLAN_BSS_TYPE_UAP) {
|
priv->bss_type == MLAN_BSS_TYPE_UAP) {
|
||||||
|
@ -5795,10 +5806,10 @@ int woal_close(struct net_device *dev)
|
||||||
woal_cancel_scan(priv, MOAL_IOCTL_WAIT);
|
woal_cancel_scan(priv, MOAL_IOCTL_WAIT);
|
||||||
|
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 11, 0)
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 11, 0)
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 19, 2)
|
#if ((CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 19, 2)) || IMX_ANDROID_13)
|
||||||
if (IS_STA_CFG80211(cfg80211_wext) && priv->wdev->connected) {
|
if (IS_STA_CFG80211(cfg80211_wext) && priv->wdev->connected) {
|
||||||
#else
|
#else
|
||||||
if (IS_STA_CFG80211(cfg80211_wext) && priv->wdev->connected) {
|
if (IS_STA_CFG80211(cfg80211_wext) && priv->wdev->current_bss) {
|
||||||
#endif
|
#endif
|
||||||
priv->cfg_disconnect = MTRUE;
|
priv->cfg_disconnect = MTRUE;
|
||||||
cfg80211_disconnected(priv->netdev, 0, NULL, 0,
|
cfg80211_disconnected(priv->netdev, 0, NULL, 0,
|
||||||
|
@ -6743,7 +6754,7 @@ void woal_flush_tcp_sess_queue(moal_private *priv)
|
||||||
list_for_each_entry_safe (tcp_sess, tmp_node, &priv->tcp_sess_queue,
|
list_for_each_entry_safe (tcp_sess, tmp_node, &priv->tcp_sess_queue,
|
||||||
link) {
|
link) {
|
||||||
list_del(&tcp_sess->link);
|
list_del(&tcp_sess->link);
|
||||||
if (tcp_sess->is_timer_set)
|
if (atomic_read(&tcp_sess->is_timer_set))
|
||||||
woal_cancel_timer(&tcp_sess->ack_timer);
|
woal_cancel_timer(&tcp_sess->ack_timer);
|
||||||
skb = (struct sk_buff *)tcp_sess->ack_skb;
|
skb = (struct sk_buff *)tcp_sess->ack_skb;
|
||||||
if (skb)
|
if (skb)
|
||||||
|
@ -6809,7 +6820,7 @@ static void woal_ageout_tcp_sess_queue(moal_private *priv)
|
||||||
PRINTM(MDATA, "wlan: ageout TCP seesion %p\n",
|
PRINTM(MDATA, "wlan: ageout TCP seesion %p\n",
|
||||||
tcp_sess);
|
tcp_sess);
|
||||||
list_del(&tcp_sess->link);
|
list_del(&tcp_sess->link);
|
||||||
if (tcp_sess->is_timer_set)
|
if (atomic_read(&tcp_sess->is_timer_set))
|
||||||
woal_cancel_timer(&tcp_sess->ack_timer);
|
woal_cancel_timer(&tcp_sess->ack_timer);
|
||||||
skb = (struct sk_buff *)tcp_sess->ack_skb;
|
skb = (struct sk_buff *)tcp_sess->ack_skb;
|
||||||
if (skb)
|
if (skb)
|
||||||
|
@ -6839,7 +6850,7 @@ static void woal_tcp_ack_timer_func(void *context)
|
||||||
#endif
|
#endif
|
||||||
ENTER();
|
ENTER();
|
||||||
spin_lock_irqsave(&priv->tcp_sess_lock, flags);
|
spin_lock_irqsave(&priv->tcp_sess_lock, flags);
|
||||||
tcp_session->is_timer_set = MFALSE;
|
atomic_set(&tcp_session->is_timer_set, MFALSE);
|
||||||
skb = (struct sk_buff *)tcp_session->ack_skb;
|
skb = (struct sk_buff *)tcp_session->ack_skb;
|
||||||
pmbuf = (mlan_buffer *)tcp_session->pmbuf;
|
pmbuf = (mlan_buffer *)tcp_session->pmbuf;
|
||||||
tcp_session->ack_skb = NULL;
|
tcp_session->ack_skb = NULL;
|
||||||
|
@ -6906,9 +6917,8 @@ static void woal_send_tcp_ack(moal_private *priv, struct tcp_sess *tcp_session)
|
||||||
t_u32 index = 0;
|
t_u32 index = 0;
|
||||||
#endif
|
#endif
|
||||||
ENTER();
|
ENTER();
|
||||||
if (tcp_session->is_timer_set) {
|
if (atomic_cmpxchg(&tcp_session->is_timer_set, MTRUE, MFALSE)) {
|
||||||
woal_cancel_timer(&tcp_session->ack_timer);
|
woal_cancel_timer(&tcp_session->ack_timer);
|
||||||
tcp_session->is_timer_set = MFALSE;
|
|
||||||
}
|
}
|
||||||
tcp_session->ack_skb = NULL;
|
tcp_session->ack_skb = NULL;
|
||||||
tcp_session->pmbuf = NULL;
|
tcp_session->pmbuf = NULL;
|
||||||
|
@ -7032,7 +7042,7 @@ static int woal_process_tcp_ack(moal_private *priv, mlan_buffer *pmbuf)
|
||||||
woal_initialize_timer(&tcp_session->ack_timer,
|
woal_initialize_timer(&tcp_session->ack_timer,
|
||||||
woal_tcp_ack_timer_func,
|
woal_tcp_ack_timer_func,
|
||||||
tcp_session);
|
tcp_session);
|
||||||
tcp_session->is_timer_set = MTRUE;
|
atomic_set(&tcp_session->is_timer_set, MTRUE);
|
||||||
woal_mod_timer(&tcp_session->ack_timer, MOAL_TIMER_1MS);
|
woal_mod_timer(&tcp_session->ack_timer, MOAL_TIMER_1MS);
|
||||||
list_add_tail(&tcp_session->link,
|
list_add_tail(&tcp_session->link,
|
||||||
&priv->tcp_sess_queue);
|
&priv->tcp_sess_queue);
|
||||||
|
@ -7049,7 +7059,7 @@ static int woal_process_tcp_ack(moal_private *priv, mlan_buffer *pmbuf)
|
||||||
tcp_session->priv = (void *)priv;
|
tcp_session->priv = (void *)priv;
|
||||||
skb = (struct sk_buff *)pmbuf->pdesc;
|
skb = (struct sk_buff *)pmbuf->pdesc;
|
||||||
skb->cb[0] = 0;
|
skb->cb[0] = 0;
|
||||||
tcp_session->is_timer_set = MTRUE;
|
atomic_set(&tcp_session->is_timer_set, MTRUE);
|
||||||
woal_mod_timer(&tcp_session->ack_timer, MOAL_TIMER_1MS);
|
woal_mod_timer(&tcp_session->ack_timer, MOAL_TIMER_1MS);
|
||||||
spin_unlock_irqrestore(&priv->tcp_sess_lock, flags);
|
spin_unlock_irqrestore(&priv->tcp_sess_lock, flags);
|
||||||
ret = HOLD_TCP_ACK;
|
ret = HOLD_TCP_ACK;
|
||||||
|
@ -7093,7 +7103,7 @@ static int woal_process_tcp_ack(moal_private *priv, mlan_buffer *pmbuf)
|
||||||
if (tcp_session) {
|
if (tcp_session) {
|
||||||
PRINTM(MDATA,"wlan: delete TCP seesion %p\n",tcp_session);
|
PRINTM(MDATA,"wlan: delete TCP seesion %p\n",tcp_session);
|
||||||
list_del(&tcp_session->link);
|
list_del(&tcp_session->link);
|
||||||
if (tcp_session->is_timer_set)
|
if (atomic_read(&tcp_session->is_timer_set))
|
||||||
woal_cancel_timer(&tcp_session->ack_timer);
|
woal_cancel_timer(&tcp_session->ack_timer);
|
||||||
skb = (struct sk_buff *)tcp_session->ack_skb;
|
skb = (struct sk_buff *)tcp_session->ack_skb;
|
||||||
if (skb)
|
if (skb)
|
||||||
|
@ -8926,10 +8936,10 @@ t_void woal_send_disconnect_to_system(moal_private *priv,
|
||||||
if (IS_STA_CFG80211(cfg80211_wext)) {
|
if (IS_STA_CFG80211(cfg80211_wext)) {
|
||||||
spin_lock_irqsave(&priv->connect_lock, flags);
|
spin_lock_irqsave(&priv->connect_lock, flags);
|
||||||
if (!priv->cfg_disconnect && !priv->cfg_connect && priv->wdev &&
|
if (!priv->cfg_disconnect && !priv->cfg_connect && priv->wdev &&
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 19, 2)
|
#if ((CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 19, 2)) || IMX_ANDROID_13)
|
||||||
priv->wdev->connected) {
|
priv->wdev->connected) {
|
||||||
#else
|
#else
|
||||||
priv->wdev->connected) {
|
priv->wdev->current_bss) {
|
||||||
#endif
|
#endif
|
||||||
PRINTM(MMSG,
|
PRINTM(MMSG,
|
||||||
"wlan: Disconnected from " MACSTR
|
"wlan: Disconnected from " MACSTR
|
||||||
|
@ -10543,6 +10553,11 @@ moal_handle *woal_add_card(void *card, struct device *dev, moal_if_ops *if_ops,
|
||||||
PRINTM(MERROR, "Fail to load module parameter file\n");
|
PRINTM(MERROR, "Fail to load module parameter file\n");
|
||||||
goto err_kmalloc;
|
goto err_kmalloc;
|
||||||
}
|
}
|
||||||
|
if (!handle->params.drv_mode) {
|
||||||
|
PRINTM(MMSG, "wlan: stop init_adapter, drv_mode=%d\n",
|
||||||
|
handle->params.drv_mode);
|
||||||
|
goto err_kmalloc;
|
||||||
|
}
|
||||||
#ifdef IMX_SUPPORT
|
#ifdef IMX_SUPPORT
|
||||||
#ifdef SDIO
|
#ifdef SDIO
|
||||||
if (IS_SD(handle->card_type)) {
|
if (IS_SD(handle->card_type)) {
|
||||||
|
@ -10721,11 +10736,7 @@ moal_handle *woal_add_card(void *card, struct device *dev, moal_if_ops *if_ops,
|
||||||
if (moal_extflg_isset(handle, EXT_NAPI)) {
|
if (moal_extflg_isset(handle, EXT_NAPI)) {
|
||||||
init_dummy_netdev(&handle->napi_dev);
|
init_dummy_netdev(&handle->napi_dev);
|
||||||
netif_napi_add(&handle->napi_dev, &handle->napi_rx,
|
netif_napi_add(&handle->napi_dev, &handle->napi_rx,
|
||||||
#if LINUX_VERSION_CODE >= KERNEL_VERSION(6, 0, 0)
|
|
||||||
woal_netdev_poll_rx);
|
|
||||||
#else
|
|
||||||
woal_netdev_poll_rx, NAPI_BUDGET);
|
woal_netdev_poll_rx, NAPI_BUDGET);
|
||||||
#endif
|
|
||||||
napi_enable(&handle->napi_rx);
|
napi_enable(&handle->napi_rx);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -11183,8 +11194,6 @@ static int woal_reset_and_reload_fw(moal_handle *handle, t_u8 mode)
|
||||||
woal_sdio_reset_hw(handle);
|
woal_sdio_reset_hw(handle);
|
||||||
goto reload_fw;
|
goto reload_fw;
|
||||||
}
|
}
|
||||||
if (!IS_SD9098(handle->card_type) && !IS_SD9097(handle->card_type) &&
|
|
||||||
!IS_SDNW62X(handle->card_type) && !IS_SD9177(handle->card_type)) {
|
|
||||||
mlan_pm_wakeup_card(handle->pmlan_adapter, MTRUE);
|
mlan_pm_wakeup_card(handle->pmlan_adapter, MTRUE);
|
||||||
/** wait SOC fully wake up */
|
/** wait SOC fully wake up */
|
||||||
for (tries = 0; tries < FW_POLL_TRIES; ++tries) {
|
for (tries = 0; tries < FW_POLL_TRIES; ++tries) {
|
||||||
|
@ -11198,7 +11207,6 @@ static int woal_reset_and_reload_fw(moal_handle *handle, t_u8 mode)
|
||||||
}
|
}
|
||||||
udelay(1000);
|
udelay(1000);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
/* Write register to notify FW */
|
/* Write register to notify FW */
|
||||||
if (handle->ops.write_reg(handle, reset_reg, reset_val) !=
|
if (handle->ops.write_reg(handle, reset_reg, reset_val) !=
|
||||||
MLAN_STATUS_SUCCESS) {
|
MLAN_STATUS_SUCCESS) {
|
||||||
|
@ -11226,8 +11234,6 @@ static int woal_reset_and_reload_fw(moal_handle *handle, t_u8 mode)
|
||||||
ret = -EFAULT;
|
ret = -EFAULT;
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
if (!IS_SD9098(handle->card_type) && !IS_SD9097(handle->card_type) &&
|
|
||||||
!IS_SDNW62X(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:
|
reload_fw:
|
||||||
/* Download FW */
|
/* Download FW */
|
||||||
|
@ -11514,6 +11520,7 @@ int woal_request_fw_reload(moal_handle *phandle, t_u8 mode)
|
||||||
moal_handle *ref_handle = NULL;
|
moal_handle *ref_handle = NULL;
|
||||||
|
|
||||||
ENTER();
|
ENTER();
|
||||||
|
wifi_status = WIFI_STATUS_FW_RELOAD;
|
||||||
#ifdef PCIE
|
#ifdef PCIE
|
||||||
if (mode == FW_RELOAD_PCIE_RESET) {
|
if (mode == FW_RELOAD_PCIE_RESET) {
|
||||||
card = (pcie_service_card *)handle->card;
|
card = (pcie_service_card *)handle->card;
|
||||||
|
@ -11588,6 +11595,7 @@ int woal_request_fw_reload(moal_handle *phandle, t_u8 mode)
|
||||||
woal_post_reset(handle);
|
woal_post_reset(handle);
|
||||||
if (ref_handle)
|
if (ref_handle)
|
||||||
woal_post_reset(ref_handle);
|
woal_post_reset(ref_handle);
|
||||||
|
wifi_status = WIFI_STATUS_OK;
|
||||||
done:
|
done:
|
||||||
LEAVE();
|
LEAVE();
|
||||||
return ret;
|
return ret;
|
||||||
|
|
|
@ -156,6 +156,17 @@ Change log:
|
||||||
#define COMPAT_VERSION_CODE KERNEL_VERSION(0, 0, 0)
|
#define COMPAT_VERSION_CODE KERNEL_VERSION(0, 0, 0)
|
||||||
#define CFG80211_VERSION_CODE MAX(LINUX_VERSION_CODE, COMPAT_VERSION_CODE)
|
#define CFG80211_VERSION_CODE MAX(LINUX_VERSION_CODE, COMPAT_VERSION_CODE)
|
||||||
|
|
||||||
|
#define IMX_ANDROID_13 0
|
||||||
|
|
||||||
|
#ifdef IMX_SUPPORT
|
||||||
|
#ifdef IMX_ANDROID
|
||||||
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 15, 41)
|
||||||
|
#undef IMX_ANDROID_13
|
||||||
|
#define IMX_ANDROID_13 1
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Reason Code 3: STA is leaving (or has left) IBSS or ESS
|
* Reason Code 3: STA is leaving (or has left) IBSS or ESS
|
||||||
*/
|
*/
|
||||||
|
@ -327,12 +338,16 @@ typedef enum _MOAL_HARDWARE_STATUS {
|
||||||
} MOAL_HARDWARE_STATUS;
|
} MOAL_HARDWARE_STATUS;
|
||||||
|
|
||||||
#define WIFI_STATUS_OK 0
|
#define WIFI_STATUS_OK 0
|
||||||
#define WIFI_STATUS_DNLD_FW_FAIL 1
|
#define WIFI_STATUS_FW_DNLD 1
|
||||||
#define WIFI_STATUS_INIT_FW_FAIL 2
|
#define WIFI_STATUS_FW_DNLD_COMPLETE 2
|
||||||
#define WIFI_STATUS_TX_TIMEOUT 3
|
#define WIFI_STATUS_INIT_FW 3
|
||||||
#define WIFI_STATUS_WIFI_HANG 4
|
#define WIFI_STATUS_DNLD_FW_FAIL 4
|
||||||
#define WIFI_STATUS_SCAN_TIMEOUT 5
|
#define WIFI_STATUS_INIT_FW_FAIL 5
|
||||||
#define WIFI_STATUS_FW_DUMP 6
|
#define WIFI_STATUS_TX_TIMEOUT 6
|
||||||
|
#define WIFI_STATUS_WIFI_HANG 7
|
||||||
|
#define WIFI_STATUS_SCAN_TIMEOUT 8
|
||||||
|
#define WIFI_STATUS_FW_DUMP 9
|
||||||
|
#define WIFI_STATUS_FW_RELOAD 10
|
||||||
|
|
||||||
/** fw cap info 11p */
|
/** fw cap info 11p */
|
||||||
#define FW_CAPINFO_80211P MBIT(24)
|
#define FW_CAPINFO_80211P MBIT(24)
|
||||||
|
@ -1099,7 +1114,7 @@ struct tcp_sess {
|
||||||
/** timer for ack */
|
/** timer for ack */
|
||||||
moal_drv_timer ack_timer __ATTRIB_ALIGN__;
|
moal_drv_timer ack_timer __ATTRIB_ALIGN__;
|
||||||
/** timer is set */
|
/** timer is set */
|
||||||
BOOLEAN is_timer_set;
|
atomic_t is_timer_set;
|
||||||
/** last update time*/
|
/** last update time*/
|
||||||
wifi_timeval update_time;
|
wifi_timeval update_time;
|
||||||
};
|
};
|
||||||
|
@ -3064,6 +3079,20 @@ static inline void hexdump(t_u32 level, char *prompt, t_u8 *buf, int len)
|
||||||
} while (0)
|
} while (0)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||||||
|
/** Convert from 16 bit little endian format to CPU format */
|
||||||
|
#define woal_le16_to_cpu(x) le16_to_cpu(x)
|
||||||
|
/** Convert from 32 bit little endian format to CPU format */
|
||||||
|
#define woal_le32_to_cpu(x) le32_to_cpu(x)
|
||||||
|
/** Convert from 64 bit little endian format to CPU format */
|
||||||
|
#define woal_le64_to_cpu(x) le64_to_cpu(x)
|
||||||
|
/** Convert to 16 bit little endian format from CPU format */
|
||||||
|
#define woal_cpu_to_le16(x) cpu_to_le16(x)
|
||||||
|
/** Convert to 32 bit little endian format from CPU format */
|
||||||
|
#define woal_cpu_to_le32(x) cpu_to_le32(x)
|
||||||
|
/** Convert to 64 bit little endian format from CPU format */
|
||||||
|
#define woal_cpu_to_le64(x) cpu_to_le64(x)
|
||||||
|
#else
|
||||||
/** Do nothing */
|
/** Do nothing */
|
||||||
#define woal_le16_to_cpu(x) x
|
#define woal_le16_to_cpu(x) x
|
||||||
/** Do nothing */
|
/** Do nothing */
|
||||||
|
@ -3076,6 +3105,7 @@ static inline void hexdump(t_u32 level, char *prompt, t_u8 *buf, int len)
|
||||||
#define woal_cpu_to_le32(x) x
|
#define woal_cpu_to_le32(x) x
|
||||||
/** Do nothing */
|
/** Do nothing */
|
||||||
#define woal_cpu_to_le64(x) x
|
#define woal_cpu_to_le64(x) x
|
||||||
|
#endif
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief This function returns first available priv
|
* @brief This function returns first available priv
|
||||||
|
|
|
@ -132,6 +132,8 @@ static const struct pci_device_id wlan_ids[] = {
|
||||||
/* moal interface ops */
|
/* moal interface ops */
|
||||||
static moal_if_ops pcie_ops;
|
static moal_if_ops pcie_ops;
|
||||||
|
|
||||||
|
MODULE_DEVICE_TABLE(pci, wlan_ids);
|
||||||
|
|
||||||
/********************************************************
|
/********************************************************
|
||||||
Global Variables
|
Global Variables
|
||||||
********************************************************/
|
********************************************************/
|
||||||
|
|
|
@ -129,6 +129,8 @@ static const struct sdio_device_id wlan_ids[] = {
|
||||||
{},
|
{},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
MODULE_DEVICE_TABLE(sdio, wlan_ids);
|
||||||
|
|
||||||
int woal_sdio_probe(struct sdio_func *func, const struct sdio_device_id *id);
|
int woal_sdio_probe(struct sdio_func *func, const struct sdio_device_id *id);
|
||||||
void woal_sdio_remove(struct sdio_func *func);
|
void woal_sdio_remove(struct sdio_func *func);
|
||||||
#ifdef SDIO
|
#ifdef SDIO
|
||||||
|
@ -512,7 +514,7 @@ int woal_sdio_probe(struct sdio_func *func, const struct sdio_device_id *id)
|
||||||
|
|
||||||
if (NULL ==
|
if (NULL ==
|
||||||
woal_add_card(card, &card->func->dev, &sdiommc_ops, card_type)) {
|
woal_add_card(card, &card->func->dev, &sdiommc_ops, card_type)) {
|
||||||
PRINTM(MERROR, "woal_add_card failed\n");
|
PRINTM(MMSG, "woal_add_card failed\n");
|
||||||
ret = MLAN_STATUS_FAILURE;
|
ret = MLAN_STATUS_FAILURE;
|
||||||
goto err;
|
goto err;
|
||||||
}
|
}
|
||||||
|
|
|
@ -3454,10 +3454,10 @@ mlan_status moal_recv_event(t_void *pmoal, pmlan_event pmevent)
|
||||||
PRINTM(MMSG,
|
PRINTM(MMSG,
|
||||||
"Channel Under Nop: notify cfg80211 new channel=%d\n",
|
"Channel Under Nop: notify cfg80211 new channel=%d\n",
|
||||||
priv->channel);
|
priv->channel);
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 19, 2)
|
#if ((CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 19, 2)) || IMX_ANDROID_13)
|
||||||
cfg80211_ch_switch_notify(priv->netdev, &priv->chan, 0);
|
cfg80211_ch_switch_notify(priv->netdev, &priv->chan, 0);
|
||||||
#else
|
#else
|
||||||
cfg80211_ch_switch_notify(priv->netdev, &priv->chan, 0);
|
cfg80211_ch_switch_notify(priv->netdev, &priv->chan);
|
||||||
#endif
|
#endif
|
||||||
priv->chan_under_nop = MFALSE;
|
priv->chan_under_nop = MFALSE;
|
||||||
}
|
}
|
||||||
|
@ -3788,10 +3788,10 @@ mlan_status moal_recv_event(t_void *pmoal, pmlan_event pmevent)
|
||||||
PRINTM(MEVENT,
|
PRINTM(MEVENT,
|
||||||
"HostMlme %s: Receive deauth/disassociate\n",
|
"HostMlme %s: Receive deauth/disassociate\n",
|
||||||
priv->netdev->name);
|
priv->netdev->name);
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 19, 2)
|
#if ((CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 19, 2)) || IMX_ANDROID_13)
|
||||||
if (!priv->wdev->connected) {
|
if (!priv->wdev->connected) {
|
||||||
#else
|
#else
|
||||||
if (!priv->wdev->connected) {
|
if (!priv->wdev->current_bss) {
|
||||||
#endif
|
#endif
|
||||||
PRINTM(MEVENT,
|
PRINTM(MEVENT,
|
||||||
"HostMlme: Drop deauth/disassociate, current_bss = null\n");
|
"HostMlme: Drop deauth/disassociate, current_bss = null\n");
|
||||||
|
@ -4162,10 +4162,10 @@ mlan_status moal_recv_event(t_void *pmoal, pmlan_event pmevent)
|
||||||
roam_info =
|
roam_info =
|
||||||
kzalloc(sizeof(struct cfg80211_roam_info), GFP_ATOMIC);
|
kzalloc(sizeof(struct cfg80211_roam_info), GFP_ATOMIC);
|
||||||
if (roam_info) {
|
if (roam_info) {
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(6, 0, 0)
|
#if ((CFG80211_VERSION_CODE >= KERNEL_VERSION(6, 0, 0)) || IMX_ANDROID_13)
|
||||||
roam_info->links[0].bssid = priv->cfg_bssid;
|
roam_info->links[0].bssid = priv->cfg_bssid;
|
||||||
#else
|
#else
|
||||||
roam_info->links[0].bssid = priv->cfg_bssid;
|
roam_info->bssid = priv->cfg_bssid;
|
||||||
#endif
|
#endif
|
||||||
roam_info->req_ie = req_ie;
|
roam_info->req_ie = req_ie;
|
||||||
roam_info->req_ie_len = ie_len;
|
roam_info->req_ie_len = ie_len;
|
||||||
|
|
|
@ -103,7 +103,7 @@ static int woal_cfg80211_dump_survey(struct wiphy *wiphy,
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 8, 0)
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 8, 0)
|
||||||
static int woal_cfg80211_get_channel(struct wiphy *wiphy,
|
static int woal_cfg80211_get_channel(struct wiphy *wiphy,
|
||||||
struct wireless_dev *wdev,
|
struct wireless_dev *wdev,
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 15, 2)
|
#if ((CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 19, 2)) || IMX_ANDROID_13)
|
||||||
unsigned int link_id,
|
unsigned int link_id,
|
||||||
#endif
|
#endif
|
||||||
struct cfg80211_chan_def *chandef);
|
struct cfg80211_chan_def *chandef);
|
||||||
|
@ -4420,6 +4420,12 @@ static int woal_cfg80211_scan(struct wiphy *wiphy, struct net_device *dev,
|
||||||
ENTER();
|
ENTER();
|
||||||
|
|
||||||
PRINTM(MINFO, "Received scan request on %s\n", dev->name);
|
PRINTM(MINFO, "Received scan request on %s\n", dev->name);
|
||||||
|
if (priv->phandle->driver_status) {
|
||||||
|
PRINTM(MERROR,
|
||||||
|
"Block woal_cfg80211_scan in abnormal driver state\n");
|
||||||
|
LEAVE();
|
||||||
|
return -EFAULT;
|
||||||
|
}
|
||||||
if (priv->phandle->scan_pending_on_block == MTRUE) {
|
if (priv->phandle->scan_pending_on_block == MTRUE) {
|
||||||
PRINTM(MCMND, "scan already in processing...\n");
|
PRINTM(MCMND, "scan already in processing...\n");
|
||||||
LEAVE();
|
LEAVE();
|
||||||
|
@ -5380,7 +5386,7 @@ static int woal_cfg80211_disconnect(struct wiphy *wiphy, struct net_device *dev,
|
||||||
if (priv->media_connected == MFALSE) {
|
if (priv->media_connected == MFALSE) {
|
||||||
PRINTM(MMSG, " Already disconnected\n");
|
PRINTM(MMSG, " Already disconnected\n");
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 11, 0)
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 11, 0)
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 15, 2)
|
#if ((CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 19, 2)) || IMX_ANDROID_13)
|
||||||
if (priv->wdev->connected &&
|
if (priv->wdev->connected &&
|
||||||
#else
|
#else
|
||||||
if (priv->wdev->current_bss &&
|
if (priv->wdev->current_bss &&
|
||||||
|
@ -5711,7 +5717,7 @@ done:
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 8, 0)
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 8, 0)
|
||||||
static int woal_cfg80211_get_channel(struct wiphy *wiphy,
|
static int woal_cfg80211_get_channel(struct wiphy *wiphy,
|
||||||
struct wireless_dev *wdev,
|
struct wireless_dev *wdev,
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 15, 2)
|
#if ((CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 19, 2)) || IMX_ANDROID_13)
|
||||||
unsigned int link_id,
|
unsigned int link_id,
|
||||||
#endif
|
#endif
|
||||||
struct cfg80211_chan_def *chandef)
|
struct cfg80211_chan_def *chandef)
|
||||||
|
@ -8621,7 +8627,7 @@ int woal_cfg80211_update_ft_ies(struct wiphy *wiphy, struct net_device *dev,
|
||||||
passoc_rsp = (IEEEtypes_AssocRsp_t *)
|
passoc_rsp = (IEEEtypes_AssocRsp_t *)
|
||||||
assoc_rsp->assoc_resp_buf;
|
assoc_rsp->assoc_resp_buf;
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(4, 12, 0)
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(4, 12, 0)
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 15, 2)
|
#if ((CFG80211_VERSION_CODE >= KERNEL_VERSION(6, 0, 0)) || IMX_ANDROID_13)
|
||||||
roam_info.links[0].bssid = priv->cfg_bssid;
|
roam_info.links[0].bssid = priv->cfg_bssid;
|
||||||
#else
|
#else
|
||||||
roam_info.bssid = priv->cfg_bssid;
|
roam_info.bssid = priv->cfg_bssid;
|
||||||
|
@ -9093,7 +9099,7 @@ void woal_start_roaming(moal_private *priv)
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(4, 12, 0)
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(4, 12, 0)
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 15, 2)
|
#if ((CFG80211_VERSION_CODE >= KERNEL_VERSION(6, 0, 0)) || IMX_ANDROID_13)
|
||||||
roam_info.links[0].bssid = priv->cfg_bssid;
|
roam_info.links[0].bssid = priv->cfg_bssid;
|
||||||
#else
|
#else
|
||||||
roam_info.bssid = priv->cfg_bssid;
|
roam_info.bssid = priv->cfg_bssid;
|
||||||
|
|
|
@ -2348,7 +2348,7 @@ int woal_cfg80211_del_virtual_intf(struct wiphy *wiphy,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (vir_priv && vir_priv->bss_type == MLAN_BSS_TYPE_UAP) {
|
if (vir_priv && vir_priv->bss_type == MLAN_BSS_TYPE_UAP) {
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 15, 2)
|
#if ((CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 19, 2)) || IMX_ANDROID_13)
|
||||||
if (woal_cfg80211_del_beacon(wiphy, dev, 0))
|
if (woal_cfg80211_del_beacon(wiphy, dev, 0))
|
||||||
#else
|
#else
|
||||||
if (woal_cfg80211_del_beacon(wiphy, dev))
|
if (woal_cfg80211_del_beacon(wiphy, dev))
|
||||||
|
@ -2356,13 +2356,13 @@ int woal_cfg80211_del_virtual_intf(struct wiphy *wiphy,
|
||||||
PRINTM(MERROR, "%s: del_beacon failed\n",
|
PRINTM(MERROR, "%s: del_beacon failed\n",
|
||||||
__func__);
|
__func__);
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 0, 0)
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 0, 0)
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 15, 2)
|
#if ((CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 19, 2)) || IMX_ANDROID_13)
|
||||||
vir_priv->wdev->links[0].ap.beacon_interval = 0;
|
vir_priv->wdev->links[0].ap.beacon_interval = 0;
|
||||||
#else
|
#else
|
||||||
vir_priv->wdev->beacon_interval = 0;
|
vir_priv->wdev->beacon_interval = 0;
|
||||||
#endif
|
#endif
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 15, 0)
|
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(3, 15, 0)
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 15, 2)
|
#if ((CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 19, 2)) || IMX_ANDROID_13)
|
||||||
memset(&vir_priv->wdev->links[0].ap.chandef, 0,
|
memset(&vir_priv->wdev->links[0].ap.chandef, 0,
|
||||||
sizeof(vir_priv->wdev->links[0].ap.chandef));
|
sizeof(vir_priv->wdev->links[0].ap.chandef));
|
||||||
#else
|
#else
|
||||||
|
@ -2371,7 +2371,7 @@ int woal_cfg80211_del_virtual_intf(struct wiphy *wiphy,
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 15, 2)
|
#if ((CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 19, 2)) || IMX_ANDROID_13)
|
||||||
vir_priv->wdev->u.ap.ssid_len = 0;
|
vir_priv->wdev->u.ap.ssid_len = 0;
|
||||||
#else
|
#else
|
||||||
vir_priv->wdev->ssid_len = 0;
|
vir_priv->wdev->ssid_len = 0;
|
||||||
|
@ -2650,7 +2650,7 @@ done:
|
||||||
*
|
*
|
||||||
* @return 0 -- success, otherwise fail
|
* @return 0 -- success, otherwise fail
|
||||||
*/
|
*/
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 15, 2)
|
#if ((CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 19, 2)) || IMX_ANDROID_13)
|
||||||
int woal_cfg80211_del_beacon(struct wiphy *wiphy, struct net_device *dev,
|
int woal_cfg80211_del_beacon(struct wiphy *wiphy, struct net_device *dev,
|
||||||
unsigned int link_id)
|
unsigned int link_id)
|
||||||
#else
|
#else
|
||||||
|
@ -3436,7 +3436,7 @@ static void woal_switch_uap_channel(moal_private *priv, t_u8 wait_option)
|
||||||
priv->channel = uap_channel.channel;
|
priv->channel = uap_channel.channel;
|
||||||
moal_memcpy_ext(priv->phandle, &priv->chan, &priv->csa_chan,
|
moal_memcpy_ext(priv->phandle, &priv->chan, &priv->csa_chan,
|
||||||
sizeof(struct cfg80211_chan_def), sizeof(priv->chan));
|
sizeof(struct cfg80211_chan_def), sizeof(priv->chan));
|
||||||
#if CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 15, 2)
|
#if ((CFG80211_VERSION_CODE >= KERNEL_VERSION(5, 19, 2)) || IMX_ANDROID_13)
|
||||||
cfg80211_ch_switch_notify(priv->netdev, &priv->chan, 0);
|
cfg80211_ch_switch_notify(priv->netdev, &priv->chan, 0);
|
||||||
#else
|
#else
|
||||||
cfg80211_ch_switch_notify(priv->netdev, &priv->chan);
|
cfg80211_ch_switch_notify(priv->netdev, &priv->chan);
|
||||||
|
|
Loading…
Add table
Reference in a new issue