mirror of
https://github.com/nxp-imx/mwifiex.git
synced 2025-01-16 08:45:32 +00:00
2968 lines
80 KiB
C
2968 lines
80 KiB
C
|
/** @file mlanutl.h
|
||
|
*
|
||
|
* @brief This file contains definitions for application
|
||
|
*
|
||
|
* Copyright (C) 2011-2019, Marvell International Ltd.
|
||
|
*
|
||
|
* This software file (the "File") is distributed by Marvell International
|
||
|
* Ltd. under the terms of the GNU General Public License Version 2, June 1991
|
||
|
* (the "License"). You may use, redistribute and/or modify this File in
|
||
|
* accordance with the terms and conditions of the License, a copy of which
|
||
|
* is available by writing to the Free Software Foundation, Inc.,
|
||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA or on the
|
||
|
* worldwide web at http://www.gnu.org/licenses/old-licenses/gpl-2.0.txt.
|
||
|
*
|
||
|
* THE FILE IS DISTRIBUTED AS-IS, WITHOUT WARRANTY OF ANY KIND, AND THE
|
||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE
|
||
|
* ARE EXPRESSLY DISCLAIMED. The License provides additional details about
|
||
|
* this warranty disclaimer.
|
||
|
*
|
||
|
*/
|
||
|
/************************************************************************
|
||
|
Change log:
|
||
|
11/26/2008: initial version
|
||
|
************************************************************************/
|
||
|
#ifndef _MLANUTL_H_
|
||
|
#define _MLANUTL_H_
|
||
|
|
||
|
/** Include header files */
|
||
|
#include <stdio.h>
|
||
|
#include <unistd.h>
|
||
|
#include <string.h>
|
||
|
#include <stdlib.h>
|
||
|
#include <ctype.h>
|
||
|
#include <sys/socket.h>
|
||
|
#include <sys/ioctl.h>
|
||
|
#include <errno.h>
|
||
|
#include <linux/if.h>
|
||
|
#include <linux/wireless.h>
|
||
|
#include <sys/types.h>
|
||
|
#include <sys/time.h>
|
||
|
#include <arpa/inet.h>
|
||
|
|
||
|
#include <netinet/ether.h>
|
||
|
#include <linux/if_packet.h>
|
||
|
|
||
|
/** Type definition: boolean */
|
||
|
typedef enum { FALSE, TRUE } boolean;
|
||
|
|
||
|
/** 16 bits byte swap */
|
||
|
#define swap_byte_16(x) \
|
||
|
((t_u16)((((t_u16)(x) & 0x00ffU) << 8) | \
|
||
|
(((t_u16)(x) & 0xff00U) >> 8)))
|
||
|
|
||
|
/** 32 bits byte swap */
|
||
|
#define swap_byte_32(x) \
|
||
|
((t_u32)((((t_u32)(x) & 0x000000ffUL) << 24) | \
|
||
|
(((t_u32)(x) & 0x0000ff00UL) << 8) | \
|
||
|
(((t_u32)(x) & 0x00ff0000UL) >> 8) | \
|
||
|
(((t_u32)(x) & 0xff000000UL) >> 24)))
|
||
|
|
||
|
/** Convert to correct endian format */
|
||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||
|
/** CPU to little-endian convert for 16-bit */
|
||
|
#define cpu_to_le16(x) swap_byte_16(x)
|
||
|
/** CPU to little-endian convert for 32-bit */
|
||
|
#define cpu_to_le32(x) swap_byte_32(x)
|
||
|
/** Little-endian to CPU convert for 16-bit */
|
||
|
#define le16_to_cpu(x) swap_byte_16(x)
|
||
|
/** Little-endian to CPU convert for 32-bit */
|
||
|
#define le32_to_cpu(x) swap_byte_32(x)
|
||
|
#else
|
||
|
/** Do nothing */
|
||
|
#define cpu_to_le16(x) (x)
|
||
|
/** Do nothing */
|
||
|
#define cpu_to_le32(x) (x)
|
||
|
/** Do nothing */
|
||
|
#define le16_to_cpu(x) (x)
|
||
|
/** Do nothing */
|
||
|
#define le32_to_cpu(x) (x)
|
||
|
#endif
|
||
|
|
||
|
/** TLV header */
|
||
|
#define TLVHEADER /** Tag */ \
|
||
|
t_u16 tag; \
|
||
|
/** Length */ \
|
||
|
t_u16 length
|
||
|
|
||
|
/** Length of TLV header */
|
||
|
#define TLVHEADER_LEN 4
|
||
|
|
||
|
/** Character, 1 byte */
|
||
|
typedef signed char t_s8;
|
||
|
/** Unsigned character, 1 byte */
|
||
|
typedef unsigned char t_u8;
|
||
|
|
||
|
/** Short integer */
|
||
|
typedef signed short t_s16;
|
||
|
/** Unsigned short integer */
|
||
|
typedef unsigned short t_u16;
|
||
|
|
||
|
/** Integer */
|
||
|
typedef signed int t_s32;
|
||
|
/** Unsigned integer */
|
||
|
typedef unsigned int t_u32;
|
||
|
|
||
|
/** Long long integer */
|
||
|
typedef signed long long t_s64;
|
||
|
/** Unsigned long long integer */
|
||
|
typedef unsigned long long t_u64;
|
||
|
|
||
|
/** Void pointer (4-bytes) */
|
||
|
typedef void t_void;
|
||
|
|
||
|
/** The attribute pack used for structure packing */
|
||
|
#ifndef __ATTRIB_PACK__
|
||
|
#define __ATTRIB_PACK__ __attribute__((packed))
|
||
|
#endif
|
||
|
|
||
|
/** Success */
|
||
|
#define MLAN_STATUS_SUCCESS (0)
|
||
|
/** Failure */
|
||
|
#define MLAN_STATUS_FAILURE (-1)
|
||
|
/** Not found */
|
||
|
#define MLAN_STATUS_NOTFOUND (1)
|
||
|
|
||
|
/** IOCTL number */
|
||
|
#define MLAN_ETH_PRIV (SIOCDEVPRIVATE + 14)
|
||
|
|
||
|
/** Command buffer max length */
|
||
|
#define BUFFER_LENGTH (2 * 1024)
|
||
|
|
||
|
/** Find number of elements */
|
||
|
#define NELEMENTS(x) (sizeof(x)/sizeof(x[0]))
|
||
|
|
||
|
/** BIT value */
|
||
|
#define MBIT(x) (((t_u32)1) << (x))
|
||
|
|
||
|
#ifndef MIN
|
||
|
/** Find minimum value */
|
||
|
#define MIN(a, b) ((a) < (b) ? (a) : (b))
|
||
|
#endif /* MIN */
|
||
|
|
||
|
/** Length of ethernet address */
|
||
|
#ifndef ETH_ALEN
|
||
|
#define ETH_ALEN 6
|
||
|
#endif
|
||
|
|
||
|
/** Action field value : get */
|
||
|
#define ACTION_GET 0
|
||
|
/** Action field value : set */
|
||
|
#define ACTION_SET 1
|
||
|
|
||
|
/** Channel usability flags */
|
||
|
#define MARVELL_CHANNEL_DISABLED MBIT(7)
|
||
|
#define MARVELL_CHANNEL_NOHT160 MBIT(4)
|
||
|
#define MARVELL_CHANNEL_NOHT80 MBIT(3)
|
||
|
#define MARVELL_CHANNEL_NOHT40 MBIT(2)
|
||
|
#define MARVELL_CHANNEL_DFS MBIT(1)
|
||
|
#define MARVELL_CHANNEL_PASSIVE MBIT(0)
|
||
|
|
||
|
char mod_conv_bg_1x1[10][35] = { "CCK (1,2,5.5,11 Mbps)",
|
||
|
"OFDM_PSK (6,9,12,18 Mbps)",
|
||
|
"OFDM_QAM16 (24,36 Mbps)",
|
||
|
"OFDM_QAM64 (48,54 Mbps)",
|
||
|
"HT_20_PSK (MCS 0,1,2)",
|
||
|
"HT_20_QAM16 (MCS 3,4)",
|
||
|
"HT_20_QAM64 (MCS 5,6,7)",
|
||
|
"HT_40_PSK (MCS 0,1,2)",
|
||
|
"HT_40_QAM16 (MCS 3,4)",
|
||
|
"HT_40_QAM64 (MCS 5,6,7)"
|
||
|
};
|
||
|
|
||
|
char mod_conv_a_1x1[6][35] = { "VHT_20_QAM256 (MCS 8)",
|
||
|
"VHT_40_QAM256 (MCS 8,9)",
|
||
|
"VHT_80_PSK (MCS 0,1,2)",
|
||
|
"VHT_80_QAM16 (MCS 3,4)",
|
||
|
"VHT_80_QAM64 (MCS 5,6,7)",
|
||
|
"VHT_80_QAM256 (MCS 8,9)"
|
||
|
};
|
||
|
|
||
|
char mod_conv_bg_2x2[6][35] = { "HT2_20_PSK (MCS 8,9,10)",
|
||
|
"HT2_20_QAM16 (MCS 11,12)",
|
||
|
"HT2_20_QAM64 (MCS 13,14,15)",
|
||
|
"HT2_40_PSK (MCS 8,9,10)",
|
||
|
"HT2_40_QAM16 (MCS 11,12)",
|
||
|
"HT2_40_QAM64 (MCS 13,14,15)"
|
||
|
};
|
||
|
|
||
|
char mod_conv_a_2x2[6][35] = { "VHT2_20_QAM256 (MCS 8)",
|
||
|
"VHT2_40_QAM256 (MCS 8,9)",
|
||
|
"VHT2_80_PSK (MCS 0,1,2)",
|
||
|
"VHT2_80_QAM16 (MCS 3,4)",
|
||
|
"VHT2_80_QAM64 (MCS 5,6,7)",
|
||
|
"VHT2_80_QAM256 (MCS 8,9)"
|
||
|
};
|
||
|
|
||
|
/** Socket */
|
||
|
extern t_s32 sockfd;
|
||
|
|
||
|
/** Device name */
|
||
|
extern char dev_name[IFNAMSIZ + 1];
|
||
|
|
||
|
#define HOSTCMD "hostcmd"
|
||
|
|
||
|
/** Marvell private command identifier */
|
||
|
#define CMD_MARVELL "MRVL_CMD"
|
||
|
|
||
|
struct command_node {
|
||
|
char *name;
|
||
|
int (*handler) (int, char **);
|
||
|
};
|
||
|
|
||
|
/** Private command structure */
|
||
|
#ifdef USERSPACE_32BIT_OVER_KERNEL_64BIT
|
||
|
struct eth_priv_cmd {
|
||
|
/** Command buffer pointer */
|
||
|
t_u64 buf;
|
||
|
/** buffer updated by driver */
|
||
|
int used_len;
|
||
|
/** buffer sent by application */
|
||
|
int total_len;
|
||
|
} __ATTRIB_PACK__;
|
||
|
#else
|
||
|
struct eth_priv_cmd {
|
||
|
/** Command buffer */
|
||
|
t_u8 *buf;
|
||
|
/** Used length */
|
||
|
int used_len;
|
||
|
/** Total length */
|
||
|
int total_len;
|
||
|
};
|
||
|
#endif
|
||
|
|
||
|
#if defined(STA_SUPPORT)
|
||
|
struct eth_priv_pmfcfg {
|
||
|
/* Management Frame Protection Capability */
|
||
|
t_u8 mfpc;
|
||
|
/* Management Frame Protection Required */
|
||
|
t_u8 mfpr;
|
||
|
};
|
||
|
#endif
|
||
|
|
||
|
struct eth_priv_htcapinfo {
|
||
|
t_u32 ht_cap_info_bg;
|
||
|
t_u32 ht_cap_info_a;
|
||
|
};
|
||
|
|
||
|
struct eth_priv_addba {
|
||
|
t_u32 time_out;
|
||
|
t_u32 tx_win_size;
|
||
|
t_u32 rx_win_size;
|
||
|
t_u32 tx_amsdu;
|
||
|
t_u32 rx_amsdu;
|
||
|
};
|
||
|
|
||
|
/** data_structure for cmd vhtcfg */
|
||
|
struct eth_priv_vhtcfg {
|
||
|
/** Band (1: 2.4G, 2: 5 G, 3: both 2.4G and 5G) */
|
||
|
t_u32 band;
|
||
|
/** TxRx (1: Tx, 2: Rx, 3: both Tx and Rx) */
|
||
|
t_u32 txrx;
|
||
|
/** BW CFG (0: 11N CFG, 1: vhtcap) */
|
||
|
t_u32 bwcfg;
|
||
|
/** VHT capabilities. */
|
||
|
t_u32 vht_cap_info;
|
||
|
/** VHT Tx mcs */
|
||
|
t_u32 vht_tx_mcs;
|
||
|
/** VHT Rx mcs */
|
||
|
t_u32 vht_rx_mcs;
|
||
|
/** VHT rx max rate */
|
||
|
t_u16 vht_rx_max_rate;
|
||
|
/** VHT max tx rate */
|
||
|
t_u16 vht_tx_max_rate;
|
||
|
};
|
||
|
|
||
|
/** data_structure for cmd opermodecfg */
|
||
|
struct eth_priv_opermodecfg {
|
||
|
/** channel width: 1-20MHz, 2-40MHz, 3-80MHz, 4-160MHz or 80+80MHz */
|
||
|
t_u8 bw;
|
||
|
/** Rx NSS */
|
||
|
t_u8 nss;
|
||
|
};
|
||
|
|
||
|
/** data structure for cmd getdatarate */
|
||
|
struct eth_priv_data_rate {
|
||
|
/** Tx data rate */
|
||
|
t_u32 tx_data_rate;
|
||
|
/** Rx data rate */
|
||
|
t_u32 rx_data_rate;
|
||
|
|
||
|
/** Tx channel bandwidth */
|
||
|
t_u32 tx_bw;
|
||
|
/** Tx guard interval */
|
||
|
t_u32 tx_gi;
|
||
|
/** Rx channel bandwidth */
|
||
|
t_u32 rx_bw;
|
||
|
/** Rx guard interval */
|
||
|
t_u32 rx_gi;
|
||
|
/** MCS index */
|
||
|
t_u32 tx_mcs_index;
|
||
|
t_u32 rx_mcs_index;
|
||
|
/** NSS */
|
||
|
t_u32 tx_nss;
|
||
|
t_u32 rx_nss;
|
||
|
/* LG rate: 0, HT rate: 1, VHT rate: 2 */
|
||
|
t_u32 tx_rate_format;
|
||
|
t_u32 rx_rate_format;
|
||
|
};
|
||
|
|
||
|
/** data structure for cmd bandcfg */
|
||
|
struct eth_priv_bandcfg {
|
||
|
/** Infra band */
|
||
|
t_u32 config_bands;
|
||
|
/** Ad-hoc start band */
|
||
|
t_u32 adhoc_start_band;
|
||
|
/** Ad-hoc start channel */
|
||
|
t_u32 adhoc_channel;
|
||
|
/** fw supported band */
|
||
|
t_u32 fw_bands;
|
||
|
};
|
||
|
|
||
|
/** data structure for cmd txratecfg */
|
||
|
struct eth_priv_tx_rate_cfg {
|
||
|
/* LG rate: 0, HT rate: 1, VHT rate: 2 */
|
||
|
t_u32 rate_format;
|
||
|
/** Rate/MCS index (0xFF: auto) */
|
||
|
t_u32 rate_index;
|
||
|
/** Rate rate */
|
||
|
t_u32 rate;
|
||
|
/** NSS */
|
||
|
t_u32 nss;
|
||
|
};
|
||
|
|
||
|
/** data structure for cmd getlog */
|
||
|
struct eth_priv_get_log {
|
||
|
/** Multicast transmitted frame count */
|
||
|
t_u32 mcast_tx_frame;
|
||
|
/** Failure count */
|
||
|
t_u32 failed;
|
||
|
/** Retry count */
|
||
|
t_u32 retry;
|
||
|
/** Multi entry count */
|
||
|
t_u32 multi_retry;
|
||
|
/** Duplicate frame count */
|
||
|
t_u32 frame_dup;
|
||
|
/** RTS success count */
|
||
|
t_u32 rts_success;
|
||
|
/** RTS failure count */
|
||
|
t_u32 rts_failure;
|
||
|
/** Ack failure count */
|
||
|
t_u32 ack_failure;
|
||
|
/** Rx fragmentation count */
|
||
|
t_u32 rx_frag;
|
||
|
/** Multicast Tx frame count */
|
||
|
t_u32 mcast_rx_frame;
|
||
|
/** FCS error count */
|
||
|
t_u32 fcs_error;
|
||
|
/** Tx frame count */
|
||
|
t_u32 tx_frame;
|
||
|
/** WEP ICV error count */
|
||
|
t_u32 wep_icv_error[4];
|
||
|
/** beacon recv count */
|
||
|
t_u32 bcn_rcv_cnt;
|
||
|
/** beacon miss count */
|
||
|
t_u32 bcn_miss_cnt;
|
||
|
/** Tx frag count */
|
||
|
t_u32 tx_frag_cnt;
|
||
|
/** Qos Tx frag count */
|
||
|
t_u32 qos_tx_frag_cnt[8];
|
||
|
/** Qos failed count */
|
||
|
t_u32 qos_failed_cnt[8];
|
||
|
/** Qos retry count */
|
||
|
t_u32 qos_retry_cnt[8];
|
||
|
/** Qos multi retry count */
|
||
|
t_u32 qos_multi_retry_cnt[8];
|
||
|
/** Qos frame dup count */
|
||
|
t_u32 qos_frm_dup_cnt[8];
|
||
|
/** Qos rts success count */
|
||
|
t_u32 qos_rts_suc_cnt[8];
|
||
|
/** Qos rts failure count */
|
||
|
t_u32 qos_rts_failure_cnt[8];
|
||
|
/** Qos ack failure count */
|
||
|
t_u32 qos_ack_failure_cnt[8];
|
||
|
/** Qos Rx frag count */
|
||
|
t_u32 qos_rx_frag_cnt[8];
|
||
|
/** Qos Tx frame count */
|
||
|
t_u32 qos_tx_frm_cnt[8];
|
||
|
/** Qos discarded frame count */
|
||
|
t_u32 qos_discarded_frm_cnt[8];
|
||
|
/** Qos mpdus Rx count */
|
||
|
t_u32 qos_mpdus_rx_cnt[8];
|
||
|
/** Qos retry rx count */
|
||
|
t_u32 qos_retries_rx_cnt[8];
|
||
|
/** CMACICV errors count */
|
||
|
t_u32 cmacicv_errors;
|
||
|
/** CMAC replays count */
|
||
|
t_u32 cmac_replays;
|
||
|
/** mgmt CCMP replays count */
|
||
|
t_u32 mgmt_ccmp_replays;
|
||
|
/** TKIP ICV errors count */
|
||
|
t_u32 tkipicv_errors;
|
||
|
/** TKIP replays count */
|
||
|
t_u32 tkip_replays;
|
||
|
/** CCMP decrypt errors count */
|
||
|
t_u32 ccmp_decrypt_errors;
|
||
|
/** CCMP replays count */
|
||
|
t_u32 ccmp_replays;
|
||
|
/** Tx amsdu count */
|
||
|
t_u32 tx_amsdu_cnt;
|
||
|
/** failed amsdu count */
|
||
|
t_u32 failed_amsdu_cnt;
|
||
|
/** retry amsdu count */
|
||
|
t_u32 retry_amsdu_cnt;
|
||
|
/** multi-retry amsdu count */
|
||
|
t_u32 multi_retry_amsdu_cnt;
|
||
|
/** Tx octets in amsdu count */
|
||
|
t_u64 tx_octets_in_amsdu_cnt;
|
||
|
/** amsdu ack failure count */
|
||
|
t_u32 amsdu_ack_failure_cnt;
|
||
|
/** Rx amsdu count */
|
||
|
t_u32 rx_amsdu_cnt;
|
||
|
/** Rx octets in amsdu count */
|
||
|
t_u64 rx_octets_in_amsdu_cnt;
|
||
|
/** Tx ampdu count */
|
||
|
t_u32 tx_ampdu_cnt;
|
||
|
/** tx mpdus in ampdu count */
|
||
|
t_u32 tx_mpdus_in_ampdu_cnt;
|
||
|
/** tx octets in ampdu count */
|
||
|
t_u64 tx_octets_in_ampdu_cnt;
|
||
|
/** ampdu Rx count */
|
||
|
t_u32 ampdu_rx_cnt;
|
||
|
/** mpdu in Rx ampdu count */
|
||
|
t_u32 mpdu_in_rx_ampdu_cnt;
|
||
|
/** Rx octets ampdu count */
|
||
|
t_u64 rx_octets_in_ampdu_cnt;
|
||
|
/** ampdu delimiter CRC error count */
|
||
|
t_u32 ampdu_delimiter_crc_error_cnt;
|
||
|
};
|
||
|
|
||
|
struct eth_priv_esuppmode_cfg {
|
||
|
/* RSN mode */
|
||
|
t_u16 rsn_mode;
|
||
|
/* Pairwise cipher */
|
||
|
t_u8 pairwise_cipher;
|
||
|
/* Group cipher */
|
||
|
t_u8 group_cipher;
|
||
|
};
|
||
|
|
||
|
/** MLAN MAC Address Length */
|
||
|
#define MLAN_MAC_ADDR_LENGTH 6
|
||
|
#ifdef UAP_SUPPORT
|
||
|
/** Max clients supported by AP */
|
||
|
#define MAX_AP_CLIENTS 10
|
||
|
|
||
|
/** associated station info */
|
||
|
struct ap_client_info {
|
||
|
/** STA MAC address */
|
||
|
t_u8 mac_address[MLAN_MAC_ADDR_LENGTH];
|
||
|
/** Power mfg status */
|
||
|
t_u8 power_mfg_status;
|
||
|
/** RSSI */
|
||
|
t_s8 rssi;
|
||
|
};
|
||
|
|
||
|
/** Type definition of eth_priv_getstalist */
|
||
|
struct eth_priv_getstalist {
|
||
|
/** station count */
|
||
|
t_u16 sta_count;
|
||
|
/** station list */
|
||
|
struct ap_client_info client_info[MAX_AP_CLIENTS];
|
||
|
};
|
||
|
#endif
|
||
|
|
||
|
#define COUNTRY_CODE_LEN 3
|
||
|
/** Type definition of eth_priv_countrycode for CMD_COUNTRYCODE */
|
||
|
struct eth_priv_countrycode {
|
||
|
/** Country Code */
|
||
|
t_u8 country_code[COUNTRY_CODE_LEN];
|
||
|
};
|
||
|
|
||
|
/** Type definition of mlan_ds_hs_cfg for MLAN_OID_PM_CFG_HS_CFG */
|
||
|
struct eth_priv_hs_cfg {
|
||
|
/** MTRUE to invoke the HostCmd, MFALSE otherwise */
|
||
|
t_u32 is_invoke_hostcmd;
|
||
|
/** Host sleep config condition */
|
||
|
/** Bit0: broadcast data
|
||
|
* Bit1: unicast data
|
||
|
* Bit2: mac event
|
||
|
* Bit3: multicast data
|
||
|
*/
|
||
|
t_u32 conditions;
|
||
|
/** GPIO pin or 0xff for interface */
|
||
|
t_u32 gpio;
|
||
|
/** Gap in milliseconds or or 0xff for special setting when GPIO is used to wakeup host */
|
||
|
t_u32 gap;
|
||
|
/** Host sleep wake interval */
|
||
|
t_u32 hs_wake_interval;
|
||
|
/** Parameter type*/
|
||
|
t_u8 param_type_ind;
|
||
|
/** Indication GPIO pin number */
|
||
|
t_u32 ind_gpio;
|
||
|
/** Level on ind_GPIO pin for normal wakeup source */
|
||
|
t_u32 level;
|
||
|
/** Parameter type*/
|
||
|
t_u8 param_type_ext;
|
||
|
/** Force ignore events*/
|
||
|
t_u32 event_force_ignore;
|
||
|
/** Events use ext gap to wake up host*/
|
||
|
t_u32 event_use_ext_gap;
|
||
|
/** Ext gap*/
|
||
|
t_u8 ext_gap;
|
||
|
/** GPIO wave level*/
|
||
|
t_u8 gpio_wave;
|
||
|
};
|
||
|
|
||
|
typedef struct _eth_priv_mgmt_frame_wakeup {
|
||
|
/** action - bitmap
|
||
|
** On matching rx'd pkt and filter during NON_HOSTSLEEP mode:
|
||
|
** Action[1]=0 Discard
|
||
|
** Action[1]=1 Allow
|
||
|
** Note that default action on non-match is "Allow".
|
||
|
**
|
||
|
** On matching rx'd pkt and filter during HOSTSLEEP mode:
|
||
|
** Action[1:0]=00 Discard and Not Wake host
|
||
|
** Action[1:0]=01 Discard and Wake host
|
||
|
** Action[1:0]=10 Invalid
|
||
|
** Note that default action on non-match is "Discard and Not Wake host".
|
||
|
**/
|
||
|
t_u32 action;
|
||
|
/** Frame type(p2p, tdls...)
|
||
|
** type=0: invalid
|
||
|
** type=1: p2p
|
||
|
** type=0xff: management frames(assoc res/rsp,probe req/rsp,...)
|
||
|
** type=others: reserved
|
||
|
**/
|
||
|
t_u32 type;
|
||
|
/** Frame mask according to each type
|
||
|
** When type=1 for p2p, frame-mask have following define:
|
||
|
** Bit Frame
|
||
|
** 0 GO Negotiation Request
|
||
|
** 1 GO Negotiation Response
|
||
|
** 2 GO Negotiation Confirmation
|
||
|
** 3 P2P Invitation Request
|
||
|
** 4 P2P Invitation Response
|
||
|
** 5 Device Discoverability Request
|
||
|
** 6 Device Discoverability Response
|
||
|
** 7 Provision Discovery Request
|
||
|
** 8 Provision Discovery Response
|
||
|
** 9 Notice of Absence
|
||
|
** 10 P2P Presence Request
|
||
|
** 11 P2P Presence Response
|
||
|
** 12 GO Discoverability Request
|
||
|
** 13-31 Reserved
|
||
|
**
|
||
|
** When type=others, frame-mask is reserved.
|
||
|
**/
|
||
|
t_u32 frame_mask;
|
||
|
} eth_priv_mgmt_frame_wakeup;
|
||
|
|
||
|
/** Type definition of eth_priv_scan_time_params */
|
||
|
struct eth_priv_scan_time_params {
|
||
|
/** Scan channel time for specific scan in milliseconds */
|
||
|
t_u32 specific_scan_time;
|
||
|
/** Scan channel time for active scan in milliseconds */
|
||
|
t_u32 active_scan_time;
|
||
|
/** Scan channel time for passive scan in milliseconds */
|
||
|
t_u32 passive_scan_time;
|
||
|
};
|
||
|
|
||
|
/** Type definition of eth_priv_scan_cfg */
|
||
|
struct eth_priv_scan_cfg {
|
||
|
/** Scan type */
|
||
|
t_u32 scan_type;
|
||
|
/** BSS mode for scanning */
|
||
|
t_u32 scan_mode;
|
||
|
/** Scan probe */
|
||
|
t_u32 scan_probe;
|
||
|
/** Scan time parameters */
|
||
|
struct eth_priv_scan_time_params scan_time;
|
||
|
/** First passive scan then active scan */
|
||
|
t_u8 passive_to_active_scan;
|
||
|
/** Extended Scan */
|
||
|
t_u32 ext_scan;
|
||
|
};
|
||
|
|
||
|
enum _mlan_rate_format {
|
||
|
MLAN_RATE_FORMAT_LG = 0,
|
||
|
MLAN_RATE_FORMAT_HT,
|
||
|
MLAN_RATE_FORMAT_VHT,
|
||
|
MLAN_RATE_FORMAT_AUTO = 0xFF,
|
||
|
};
|
||
|
|
||
|
/** HT channel bandwidth */
|
||
|
typedef enum _mlan_ht_bw {
|
||
|
MLAN_HT_BW20,
|
||
|
MLAN_HT_BW40,
|
||
|
/** VHT channel bandwidth */
|
||
|
MLAN_VHT_BW80,
|
||
|
MLAN_VHT_BW160,
|
||
|
} mlan_ht_bw;
|
||
|
/** Type definition of mlan_power group info */
|
||
|
struct eth_priv_power_group {
|
||
|
/** rate format (LG rate: 0; HT rate: 1; VHT rate: 2; no auto ctrl: 0xFF) */
|
||
|
t_u32 rate_format;
|
||
|
/** bandwidth (LG: 20 MHz; HT: 20/40 MHz; VHT: 80/160/80+80 MHz) */
|
||
|
t_u8 bandwidth;
|
||
|
/** NSS */
|
||
|
t_u32 nss;
|
||
|
/** LG: first rate index; HT/VHT: first MCS */
|
||
|
t_u8 first_rate_ind;
|
||
|
/** LG: last rate index; HT/VHT: last MCS */
|
||
|
t_u8 last_rate_ind;
|
||
|
/** minmum tx power (dBm) */
|
||
|
t_s8 power_min;
|
||
|
/** maximum tx power (dBm) */
|
||
|
t_s8 power_max;
|
||
|
/** tx power step (dB) */
|
||
|
t_s8 power_step;
|
||
|
};
|
||
|
|
||
|
/** max of power groups */
|
||
|
#define MAX_POWER_GROUP 64
|
||
|
/** Type definition of mlan_power_cfg_ext */
|
||
|
struct eth_priv_power_cfg_ext {
|
||
|
/** number of power_groups */
|
||
|
t_u32 num_pwr_grp;
|
||
|
/** array of power groups */
|
||
|
struct eth_priv_power_group power_group[MAX_POWER_GROUP];
|
||
|
};
|
||
|
|
||
|
/** Type definition of eth_priv_ds_ps_cfg */
|
||
|
struct eth_priv_ds_ps_cfg {
|
||
|
/** PS null interval in seconds */
|
||
|
t_u32 ps_null_interval;
|
||
|
/** Multiple DTIM interval */
|
||
|
t_u32 multiple_dtim_interval;
|
||
|
/** Listen interval */
|
||
|
t_u32 listen_interval;
|
||
|
/** Beacon miss timeout in milliseconds */
|
||
|
t_u32 bcn_miss_timeout;
|
||
|
/** Delay to PS in milliseconds */
|
||
|
t_s32 delay_to_ps;
|
||
|
/** PS mode */
|
||
|
t_u32 ps_mode;
|
||
|
};
|
||
|
|
||
|
#ifdef STA_SUPPORT
|
||
|
|
||
|
/** Maximum length of SSID */
|
||
|
#define MRVDRV_MAX_SSID_LENGTH 32
|
||
|
|
||
|
/** Maximum length of SSID list */
|
||
|
#define MRVDRV_MAX_SSID_LIST_LENGTH 10
|
||
|
|
||
|
/** Maximum number of channels that can be sent in a setuserscan ioctl */
|
||
|
#define WLAN_IOCTL_USER_SCAN_CHAN_MAX 50
|
||
|
|
||
|
/** Maximum channel scratch */
|
||
|
#define MAX_CHAN_SCRATCH 100
|
||
|
|
||
|
/** Maximum channel number for b/g band */
|
||
|
#define MAX_CHAN_BG_BAND 14
|
||
|
|
||
|
/** Maximum number of probes to send on each channel */
|
||
|
#define MAX_PROBES 4
|
||
|
|
||
|
/** Scan all the channels in specified band */
|
||
|
#define BAND_SPECIFIED 0x80
|
||
|
|
||
|
/** Maximum size of IEEE Information Elements */
|
||
|
#define IEEE_MAX_IE_SIZE 256
|
||
|
|
||
|
/** Maximum number of TID */
|
||
|
#define MAX_NUM_TID 8
|
||
|
|
||
|
/** Type enumeration of WMM AC_QUEUES */
|
||
|
typedef enum _mlan_wmm_ac_e {
|
||
|
WMM_AC_BK,
|
||
|
WMM_AC_BE,
|
||
|
WMM_AC_VI,
|
||
|
WMM_AC_VO
|
||
|
} __ATTRIB_PACK__ mlan_wmm_ac_e;
|
||
|
|
||
|
/** Enumeration for scan mode */
|
||
|
enum {
|
||
|
MLAN_SCAN_MODE_UNCHANGED = 0,
|
||
|
MLAN_SCAN_MODE_BSS,
|
||
|
MLAN_SCAN_MODE_IBSS,
|
||
|
MLAN_SCAN_MODE_ANY
|
||
|
};
|
||
|
|
||
|
/** Enumeration for scan type */
|
||
|
enum {
|
||
|
MLAN_SCAN_TYPE_UNCHANGED = 0,
|
||
|
MLAN_SCAN_TYPE_ACTIVE,
|
||
|
MLAN_SCAN_TYPE_PASSIVE
|
||
|
};
|
||
|
|
||
|
/** Enumeration for passive to active scan */
|
||
|
enum _mlan_pass_to_act_scan {
|
||
|
MLAN_PASS_TO_ACT_SCAN_UNCHANGED = 0,
|
||
|
MLAN_PASS_TO_ACT_SCAN_EN,
|
||
|
MLAN_PASS_TO_ACT_SCAN_DIS
|
||
|
};
|
||
|
|
||
|
/** IEEE Type definitions */
|
||
|
typedef enum _IEEEtypes_ElementId_e {
|
||
|
SSID = 0,
|
||
|
SUPPORTED_RATES = 1,
|
||
|
FH_PARAM_SET = 2,
|
||
|
DS_PARAM_SET = 3,
|
||
|
CF_PARAM_SET = 4,
|
||
|
|
||
|
IBSS_PARAM_SET = 6,
|
||
|
|
||
|
COUNTRY_INFO = 7,
|
||
|
|
||
|
TCLAS = 14,
|
||
|
|
||
|
POWER_CONSTRAINT = 32,
|
||
|
POWER_CAPABILITY = 33,
|
||
|
TPC_REQUEST = 34,
|
||
|
TPC_REPORT = 35,
|
||
|
SUPPORTED_CHANNELS = 36,
|
||
|
CHANNEL_SWITCH_ANN = 37,
|
||
|
QUIET = 40,
|
||
|
IBSS_DFS = 41,
|
||
|
HT_CAPABILITY = 45,
|
||
|
HT_OPERATION = 61,
|
||
|
BSSCO_2040 = 72,
|
||
|
OVERLAPBSSSCANPARAM = 74,
|
||
|
EXT_CAPABILITY = 127,
|
||
|
|
||
|
VHT_CAPABILITY = 191,
|
||
|
VHT_OPERATION = 192,
|
||
|
EXT_BSS_LOAD = 193,
|
||
|
BW_CHANNEL_SWITCH = 194,
|
||
|
VHT_TX_POWER_ENV = 195,
|
||
|
EXT_POWER_CONSTR = 196,
|
||
|
AID_INFO = 197,
|
||
|
QUIET_CHAN = 198,
|
||
|
OPER_MODE_NTF = 199,
|
||
|
|
||
|
ERP_INFO = 42,
|
||
|
EXTENDED_SUPPORTED_RATES = 50,
|
||
|
|
||
|
VENDOR_SPECIFIC_221 = 221,
|
||
|
WMM_IE = VENDOR_SPECIFIC_221,
|
||
|
|
||
|
WPS_IE = VENDOR_SPECIFIC_221,
|
||
|
|
||
|
WPA_IE = VENDOR_SPECIFIC_221,
|
||
|
RSN_IE = 48,
|
||
|
} __ATTRIB_PACK__ IEEEtypes_ElementId_e;
|
||
|
|
||
|
/** Capability Bit Map*/
|
||
|
#ifdef BIG_ENDIAN_SUPPORT
|
||
|
typedef struct _IEEEtypes_CapInfo_t {
|
||
|
t_u8 rsrvd1:2;
|
||
|
t_u8 dsss_ofdm:1;
|
||
|
t_u8 rsvrd2:2;
|
||
|
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;
|
||
|
} __ATTRIB_PACK__ IEEEtypes_CapInfo_t, *pIEEEtypes_CapInfo_t;
|
||
|
#else
|
||
|
typedef struct _IEEEtypes_CapInfo_t {
|
||
|
/** Capability Bit Map : ESS */
|
||
|
t_u8 ess:1;
|
||
|
/** Capability Bit Map : IBSS */
|
||
|
t_u8 ibss:1;
|
||
|
/** Capability Bit Map : CF pollable */
|
||
|
t_u8 cf_pollable:1;
|
||
|
/** Capability Bit Map : CF poll request */
|
||
|
t_u8 cf_poll_rqst:1;
|
||
|
/** Capability Bit Map : privacy */
|
||
|
t_u8 privacy:1;
|
||
|
/** Capability Bit Map : Short preamble */
|
||
|
t_u8 short_preamble:1;
|
||
|
/** Capability Bit Map : PBCC */
|
||
|
t_u8 pbcc:1;
|
||
|
/** Capability Bit Map : Channel agility */
|
||
|
t_u8 chan_agility:1;
|
||
|
/** Capability Bit Map : Spectrum management */
|
||
|
t_u8 spectrum_mgmt:1;
|
||
|
/** Capability Bit Map : Reserved */
|
||
|
t_u8 rsrvd3:1;
|
||
|
/** Capability Bit Map : Short slot time */
|
||
|
t_u8 short_slot_time:1;
|
||
|
/** Capability Bit Map : APSD */
|
||
|
t_u8 apsd:1;
|
||
|
/** Capability Bit Map : Reserved */
|
||
|
t_u8 rsvrd2:1;
|
||
|
/** Capability Bit Map : DSS OFDM */
|
||
|
t_u8 dsss_ofdm:1;
|
||
|
/** Capability Bit Map : Reserved */
|
||
|
t_u8 rsrvd1:2;
|
||
|
} __ATTRIB_PACK__ IEEEtypes_CapInfo_t, *pIEEEtypes_CapInfo_t;
|
||
|
#endif /* BIG_ENDIAN_SUPPORT */
|
||
|
|
||
|
/** IEEE IE header */
|
||
|
typedef struct _IEEEtypes_Header_t {
|
||
|
/** Element ID */
|
||
|
t_u8 element_id;
|
||
|
/** Length */
|
||
|
t_u8 len;
|
||
|
} __ATTRIB_PACK__ IEEEtypes_Header_t, *pIEEEtypes_Header_t;
|
||
|
|
||
|
/** IEEE IE header */
|
||
|
#define IEEE_HEADER_LEN sizeof(IEEEtypes_Header_t)
|
||
|
|
||
|
/** Vendor specific IE header */
|
||
|
typedef struct _IEEEtypes_VendorHeader_t {
|
||
|
/** Element ID */
|
||
|
t_u8 element_id;
|
||
|
/** Length */
|
||
|
t_u8 len;
|
||
|
/** OUI */
|
||
|
t_u8 oui[3];
|
||
|
/** OUI type */
|
||
|
t_u8 oui_type;
|
||
|
/** OUI subtype */
|
||
|
t_u8 oui_subtype;
|
||
|
/** Version */
|
||
|
t_u8 version;
|
||
|
} __ATTRIB_PACK__ IEEEtypes_VendorHeader_t, *pIEEEtypes_VendorHeader_t;
|
||
|
|
||
|
/** Vendor specific IE */
|
||
|
typedef struct _IEEEtypes_VendorSpecific_t {
|
||
|
/** Vendor specific IE header */
|
||
|
IEEEtypes_VendorHeader_t vend_hdr;
|
||
|
/** IE Max - size of previous fields */
|
||
|
t_u8 data[IEEE_MAX_IE_SIZE - sizeof(IEEEtypes_VendorHeader_t)];
|
||
|
} __ATTRIB_PACK__ IEEEtypes_VendorSpecific_t, *pIEEEtypes_VendorSpecific_t;
|
||
|
|
||
|
/** IEEE IE */
|
||
|
typedef struct _IEEEtypes_Generic_t {
|
||
|
/** Generic IE header */
|
||
|
IEEEtypes_Header_t ieee_hdr;
|
||
|
/** IE Max - size of previous fields */
|
||
|
t_u8 data[IEEE_MAX_IE_SIZE - sizeof(IEEEtypes_Header_t)];
|
||
|
} __ATTRIB_PACK__ IEEEtypes_Generic_t, *pIEEEtypes_Generic_t;
|
||
|
|
||
|
typedef struct _wlan_get_scan_table_fixed {
|
||
|
/** BSSID of this network */
|
||
|
t_u8 bssid[MLAN_MAC_ADDR_LENGTH];
|
||
|
/** Channel this beacon/probe response was detected */
|
||
|
t_u8 channel;
|
||
|
/** RSSI for the received packet */
|
||
|
t_u8 rssi;
|
||
|
/** TSF value from the firmware at packet reception */
|
||
|
t_u64 network_tsf;
|
||
|
} wlan_get_scan_table_fixed;
|
||
|
|
||
|
/**
|
||
|
* Structure passed in the wlan_ioctl_get_scan_table_info for each
|
||
|
* BSS returned in the WLAN_GET_SCAN_RESP IOCTL
|
||
|
*/
|
||
|
typedef struct _wlan_ioctl_get_scan_table_entry {
|
||
|
/**
|
||
|
* Fixed field length included in the response.
|
||
|
*
|
||
|
* Length value is included so future fixed fields can be added to the
|
||
|
* response without breaking backwards compatibility. Use the length
|
||
|
* to find the offset for the bssInfoLength field, not a sizeof() calc.
|
||
|
*/
|
||
|
t_u32 fixed_field_length;
|
||
|
|
||
|
/**
|
||
|
* Length of the BSS Information (probe resp or beacon) that
|
||
|
* follows after the fixed_field_length
|
||
|
*/
|
||
|
t_u32 bss_info_length;
|
||
|
|
||
|
/**
|
||
|
* Always present, fixed length data fields for the BSS
|
||
|
*/
|
||
|
wlan_get_scan_table_fixed fixed_fields;
|
||
|
|
||
|
/*
|
||
|
* Probe response or beacon scanned for the BSS.
|
||
|
*
|
||
|
* Field layout:
|
||
|
* - TSF 8 octets
|
||
|
* - Beacon Interval 2 octets
|
||
|
* - Capability Info 2 octets
|
||
|
*
|
||
|
* - IEEE Infomation Elements; variable number & length per 802.11 spec
|
||
|
*/
|
||
|
/* t_u8 bss_info_buffer[1]; */
|
||
|
} wlan_ioctl_get_scan_table_entry;
|
||
|
|
||
|
/**
|
||
|
* Structure to store BSS info (probe resp or beacon) & IEEE IE info for each
|
||
|
* BSS returned in WLAN_GET_SCAN_RESP IOCTL
|
||
|
*/
|
||
|
typedef struct _wlan_ioctl_get_bss_info {
|
||
|
/**
|
||
|
* Length of the BSS Information (probe resp or beacon) that
|
||
|
* follows after the fixed_field
|
||
|
*/
|
||
|
t_u32 bss_info_length;
|
||
|
|
||
|
/**
|
||
|
* Probe response or beacon scanned for the BSS.
|
||
|
*
|
||
|
* Field layout:
|
||
|
*/
|
||
|
/** TSF 8 octets */
|
||
|
t_u8 tsf[8];
|
||
|
/** Beacon Interval 2 octets */
|
||
|
t_u16 beacon_interval;
|
||
|
/** Capability Info 2 octets */
|
||
|
IEEEtypes_CapInfo_t cap_info;
|
||
|
|
||
|
/**
|
||
|
* IEEE Infomation Elements; variable number & length per 802.11 spec
|
||
|
*/
|
||
|
/** SSID */
|
||
|
char ssid[MRVDRV_MAX_SSID_LENGTH + 1];
|
||
|
/** SSID Length */
|
||
|
t_u32 ssid_len;
|
||
|
/** WMM Capability */
|
||
|
char wmm_cap;
|
||
|
/** WPS Capability */
|
||
|
char wps_cap;
|
||
|
/** Privacy Capability - WEP/WPA/RSN */
|
||
|
char priv_cap;
|
||
|
/** HT (11N) Capability */
|
||
|
char ht_cap;
|
||
|
/** VHT (11AC) Capability */
|
||
|
char vht_cap[2];
|
||
|
/* 802.11k Capability */
|
||
|
char dot11k_cap;
|
||
|
/** 802.11r Capability */
|
||
|
char dot11r_cap;
|
||
|
} wlan_ioctl_get_bss_info;
|
||
|
|
||
|
/**
|
||
|
* Structure to save of scan table info for each BSS returned
|
||
|
* in WLAN_GET_SCAN_RESP IOCTL
|
||
|
*/
|
||
|
struct wlan_ioctl_get_scan_list {
|
||
|
/** fixed info */
|
||
|
wlan_ioctl_get_scan_table_entry fixed_buf;
|
||
|
/** variable info - BSS info (probe resp or beacon) & IEEE IE info */
|
||
|
wlan_ioctl_get_bss_info bss_info_buf;
|
||
|
/** pointer to next node in list */
|
||
|
struct wlan_ioctl_get_scan_list *next;
|
||
|
/** pointer to previous node in list */
|
||
|
struct wlan_ioctl_get_scan_list *prev;
|
||
|
};
|
||
|
|
||
|
/**
|
||
|
* Sructure to retrieve the scan table
|
||
|
*/
|
||
|
typedef struct {
|
||
|
/**
|
||
|
* - Zero based scan entry to start retrieval in command request
|
||
|
* - Number of scans entries returned in command response
|
||
|
*/
|
||
|
t_u32 scan_number;
|
||
|
/**
|
||
|
* Buffer marker for multiple wlan_ioctl_get_scan_table_entry structures.
|
||
|
* Each struct is padded to the nearest 32 bit boundary.
|
||
|
*/
|
||
|
t_u8 scan_table_entry_buf[1];
|
||
|
|
||
|
} wlan_ioctl_get_scan_table_info;
|
||
|
|
||
|
typedef struct {
|
||
|
t_u8 chan_number;
|
||
|
/**< Channel Number to scan */
|
||
|
t_u8 radio_type;
|
||
|
/**< Radio type: 'B/G' Band = 0, 'A' Band = 1 */
|
||
|
t_u8 scan_type;/**< Scan type: Active = 1, Passive = 2 */
|
||
|
t_u8 reserved;/**< Reserved */
|
||
|
t_u32 scan_time;
|
||
|
/**< Scan duration in milliseconds; if 0 default used */
|
||
|
} __ATTRIB_PACK__ wlan_ioctl_user_scan_chan;
|
||
|
|
||
|
typedef struct {
|
||
|
char ssid[MRVDRV_MAX_SSID_LENGTH + 1];
|
||
|
/**< SSID */
|
||
|
t_u8 max_len; /**< Maximum length of SSID */
|
||
|
} __ATTRIB_PACK__ wlan_ioctl_user_scan_ssid;
|
||
|
|
||
|
typedef struct {
|
||
|
|
||
|
/** Flag set to keep the previous scan table intact */
|
||
|
t_u8 keep_previous_scan; /* Do not erase the existing scan results */
|
||
|
|
||
|
/** BSS mode to be sent in the firmware command */
|
||
|
t_u8 bss_mode;
|
||
|
|
||
|
/** Configure the number of probe requests for active chan scans */
|
||
|
t_u8 num_probes;
|
||
|
|
||
|
/** Reserved */
|
||
|
t_u8 reserved;
|
||
|
|
||
|
/** BSSID filter sent in the firmware command to limit the results */
|
||
|
t_u8 specific_bssid[ETH_ALEN];
|
||
|
|
||
|
/** SSID filter list used in the to limit the scan results */
|
||
|
wlan_ioctl_user_scan_ssid ssid_list[MRVDRV_MAX_SSID_LIST_LENGTH];
|
||
|
|
||
|
/** Variable number (fixed maximum) of channels to scan up */
|
||
|
wlan_ioctl_user_scan_chan chan_list[WLAN_IOCTL_USER_SCAN_CHAN_MAX];
|
||
|
|
||
|
/** Gap between two scans */
|
||
|
t_u16 scan_chan_gap;
|
||
|
/** scan type: 0 legacy, 1: enhance scan*/
|
||
|
t_u8 ext_scan_type;
|
||
|
|
||
|
} __ATTRIB_PACK__ wlan_ioctl_user_scan_cfg;
|
||
|
|
||
|
/** Max Ie length */
|
||
|
#define MAX_IE_SIZE 256
|
||
|
|
||
|
/** custom IE */
|
||
|
typedef struct _custom_ie {
|
||
|
/** IE Index */
|
||
|
t_u16 ie_index;
|
||
|
/** Mgmt Subtype Mask */
|
||
|
t_u16 mgmt_subtype_mask;
|
||
|
/** IE Length */
|
||
|
t_u16 ie_length;
|
||
|
/** IE buffer */
|
||
|
t_u8 ie_buffer[0];
|
||
|
} __ATTRIB_PACK__ custom_ie;
|
||
|
|
||
|
/** Convert character to integer */
|
||
|
#define CHAR2INT(x) (((x) >= 'A') ? ((x) - 'A' + 10) : ((x) - '0'))
|
||
|
|
||
|
/**
|
||
|
* Hex or Decimal to Integer
|
||
|
* @param num string to convert into decimal or hex
|
||
|
*/
|
||
|
#define A2HEXDECIMAL(num) \
|
||
|
(strncasecmp("0x", (num), 2) ? (unsigned int) strtoll((num), NULL, 0) : a2hex((num)))
|
||
|
|
||
|
/** Convert TLV header from little endian format to CPU format */
|
||
|
#define endian_convert_tlv_header_in(x) \
|
||
|
{ \
|
||
|
(x)->tag = le16_to_cpu((x)->tag); \
|
||
|
(x)->length = le16_to_cpu((x)->length); \
|
||
|
}
|
||
|
|
||
|
/** Convert TLV header to little endian format from CPU format */
|
||
|
#define endian_convert_tlv_header_out(x) \
|
||
|
{ \
|
||
|
(x)->tag = cpu_to_le16((x)->tag); \
|
||
|
(x)->length = cpu_to_le16((x)->length); \
|
||
|
}
|
||
|
/** Max IE index to FW */
|
||
|
#define MAX_MGMT_IE_INDEX_TO_FW 4
|
||
|
/** Max IE index per BSS */
|
||
|
#define MAX_MGMT_IE_INDEX 16
|
||
|
|
||
|
/** Private command ID to pass custom IE list */
|
||
|
#define CUSTOM_IE_CFG (SIOCDEVPRIVATE + 13)
|
||
|
/* TLV Definitions */
|
||
|
|
||
|
/** Maximum IE buffer length */
|
||
|
#define MAX_IE_BUFFER_LEN 256
|
||
|
|
||
|
/** TLV: Management IE list */
|
||
|
#define MRVL_MGMT_IE_LIST_TLV_ID (PROPRIETARY_TLV_BASE_ID + 0x69) /* 0x0169 */
|
||
|
|
||
|
/** TLV: Max Management IE */
|
||
|
#define MRVL_MAX_MGMT_IE_TLV_ID (PROPRIETARY_TLV_BASE_ID + 0xaa) /* 0x01aa */
|
||
|
|
||
|
/** custom IE info */
|
||
|
typedef struct _custom_ie_info {
|
||
|
/** size of buffer */
|
||
|
t_u16 buf_size;
|
||
|
/** no of buffers of buf_size */
|
||
|
t_u16 buf_count;
|
||
|
} __ATTRIB_PACK__ custom_ie_info;
|
||
|
|
||
|
/** TLV buffer : Max Mgmt IE */
|
||
|
typedef struct _tlvbuf_max_mgmt_ie {
|
||
|
/** Type */
|
||
|
t_u16 type;
|
||
|
/** Length */
|
||
|
t_u16 len;
|
||
|
/** No of tuples */
|
||
|
t_u16 count;
|
||
|
/** custom IE info tuples */
|
||
|
custom_ie_info info[0];
|
||
|
} __ATTRIB_PACK__ tlvbuf_max_mgmt_ie;
|
||
|
|
||
|
/** TLV buffer : custom IE */
|
||
|
typedef struct _eth_priv_ds_misc_custom_ie {
|
||
|
/** Type */
|
||
|
t_u16 type;
|
||
|
/** Length */
|
||
|
t_u16 len;
|
||
|
/** IE data */
|
||
|
custom_ie ie_data[0];
|
||
|
} __ATTRIB_PACK__ eth_priv_ds_misc_custom_ie;
|
||
|
|
||
|
/*-----------------------------------------------------------------*/
|
||
|
/** Register Memory Access Group */
|
||
|
/*-----------------------------------------------------------------*/
|
||
|
/** Enumeration for register type */
|
||
|
enum _mlan_reg_type {
|
||
|
MLAN_REG_MAC = 1,
|
||
|
MLAN_REG_BBP,
|
||
|
MLAN_REG_RF,
|
||
|
MLAN_REG_CAU = 5,
|
||
|
};
|
||
|
|
||
|
/** Type definition of mlan_ds_reg_rw for MLAN_OID_REG_RW */
|
||
|
struct eth_priv_ds_reg_rw {
|
||
|
/** Register type */
|
||
|
t_u32 type;
|
||
|
/** Offset */
|
||
|
t_u32 offset;
|
||
|
/** Value */
|
||
|
t_u32 value;
|
||
|
};
|
||
|
|
||
|
/** Maximum EEPROM data */
|
||
|
#define MAX_EEPROM_DATA 256
|
||
|
|
||
|
/** Type definition of mlan_ds_read_eeprom for MLAN_OID_EEPROM_RD */
|
||
|
struct eth_priv_ds_read_eeprom {
|
||
|
/** Multiples of 4 */
|
||
|
t_u16 offset;
|
||
|
/** Number of bytes */
|
||
|
t_u16 byte_count;
|
||
|
/** Value */
|
||
|
t_u8 value[MAX_EEPROM_DATA];
|
||
|
};
|
||
|
|
||
|
/** Type definition of mlan_ds_mem_rw for MLAN_OID_MEM_RW */
|
||
|
struct eth_priv_ds_mem_rw {
|
||
|
/** Address */
|
||
|
t_u32 addr;
|
||
|
/** Value */
|
||
|
t_u32 value;
|
||
|
};
|
||
|
|
||
|
/** Type definition of mlan_ds_reg_mem for MLAN_IOCTL_REG_MEM */
|
||
|
struct eth_priv_ds_reg_mem {
|
||
|
/** Sub-command */
|
||
|
t_u32 sub_command;
|
||
|
/** Register memory access parameter */
|
||
|
union {
|
||
|
/** Register access for MLAN_OID_REG_RW */
|
||
|
struct eth_priv_ds_reg_rw reg_rw;
|
||
|
/** EEPROM access for MLAN_OID_EEPROM_RD */
|
||
|
struct eth_priv_ds_read_eeprom rd_eeprom;
|
||
|
/** Memory access for MLAN_OID_MEM_RW */
|
||
|
struct eth_priv_ds_mem_rw mem_rw;
|
||
|
} param;
|
||
|
};
|
||
|
|
||
|
/** Data structure of WMM QoS information */
|
||
|
typedef 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 */
|
||
|
t_u8 para_set_count:4;
|
||
|
/** Reserved */
|
||
|
t_u8 reserved:3;
|
||
|
/** QoS UAPSD */
|
||
|
t_u8 qos_uapsd:1;
|
||
|
#endif /* BIG_ENDIAN_SUPPORT */
|
||
|
} __ATTRIB_PACK__ IEEEtypes_WmmQosInfo_t;
|
||
|
|
||
|
/** band BG */
|
||
|
#define BAND_BG_TDLS 0
|
||
|
/** band A */
|
||
|
#define BAND_A_TDLS 1
|
||
|
/** NO PERIODIC SWITCH */
|
||
|
#define NO_PERIODIC_SWITCH 0
|
||
|
/** Enable periodic channel switch */
|
||
|
#define ENABLE_PERIODIC_SWITCH 1
|
||
|
/** Min channel value for BG band */
|
||
|
#define MIN_BG_CHANNEL 1
|
||
|
/** Max channel value for BG band */
|
||
|
#define MAX_BG_CHANNEL 14
|
||
|
/** Max channel value for A band */
|
||
|
#define MIN_A_CHANNEL 36
|
||
|
/** Max channel value for A band */
|
||
|
#define MAX_A_CHANNEL 252
|
||
|
|
||
|
/** Host Command ioctl number */
|
||
|
#define TDLS_IOCTL (SIOCDEVPRIVATE + 5)
|
||
|
/** TDLS action definitions */
|
||
|
/** Action ID for TDLS config */
|
||
|
#define ACTION_TDLS_CONFIG 0x0000
|
||
|
/** Action ID for TDLS setinfo request */
|
||
|
#define ACTION_TDLS_SETINFO 0x0001
|
||
|
/** Action ID for TDLS Discovery request */
|
||
|
#define ACTION_TDLS_DISCOVERY 0x0002
|
||
|
/** Action ID for TDLS setup request */
|
||
|
#define ACTION_TDLS_SETUP 0x0003
|
||
|
/** Action ID for TDLS Teardown request */
|
||
|
#define ACTION_TDLS_TEARDOWN 0x0004
|
||
|
/** Action ID for TDLS power mode */
|
||
|
#define ACTION_TDLS_POWER_MODE 0x0005
|
||
|
/**Action ID for init TDLS Channel Switch*/
|
||
|
#define ACTION_TDLS_INIT_CHAN_SWITCH 0x06
|
||
|
/** Action ID for stop TDLS Channel Switch */
|
||
|
#define ACTION_TDLS_STOP_CHAN_SWITCH 0x07
|
||
|
/** Action ID for configure CS related parameters */
|
||
|
#define ACTION_TDLS_CS_PARAMS 0x08
|
||
|
/** Action ID for TDLS Disable Channel switch */
|
||
|
#define ACTION_TDLS_CS_DISABLE 0x09
|
||
|
/** Action ID for TDLS Link status */
|
||
|
#define ACTION_TDLS_LINK_STATUS 0x000A
|
||
|
/** Action ID for Host TDLS config uapsd and CS */
|
||
|
#define ACTION_HOST_TDLS_CONFIG 0x000D
|
||
|
/** Action ID for TDLS CS immediate return */
|
||
|
#define ACTION_TDLS_DEBUG_CS_RET_IM 0xFFF7
|
||
|
/** Action ID for TDLS Stop RX */
|
||
|
#define ACTION_TDLS_DEBUG_STOP_RX 0xFFF8
|
||
|
/** Action ID for TDLS Allow weak security */
|
||
|
#define ACTION_TDLS_DEBUG_ALLOW_WEAK_SECURITY 0xFFF9
|
||
|
/** Action ID for TDLS Ignore key lifetime expiry */
|
||
|
#define ACTION_TDLS_DEBUG_IGNORE_KEY_EXPIRY 0xFFFA
|
||
|
/** Action ID for TDLS Higher/Lower mac Test */
|
||
|
#define ACTION_TDLS_DEBUG_HIGHER_LOWER_MAC 0xFFFB
|
||
|
/** Action ID for TDLS Prohibited Test */
|
||
|
#define ACTION_TDLS_DEBUG_SETUP_PROHIBITED 0xFFFC
|
||
|
/** Action ID for TDLS Existing link Test */
|
||
|
#define ACTION_TDLS_DEBUG_SETUP_SAME_LINK 0xFFFD
|
||
|
/** Action ID for TDLS Fail Setup Confirm */
|
||
|
#define ACTION_TDLS_DEBUG_FAIL_SETUP_CONFIRM 0xFFFE
|
||
|
/** Action ID for TDLS WRONG BSS Test */
|
||
|
#define ACTION_TDLS_DEBUG_WRONG_BSS 0xFFFF
|
||
|
|
||
|
/** TLV type : Rates */
|
||
|
#define TLV_TYPE_RATES 0x0001
|
||
|
/** TLV type : Domain */
|
||
|
#define TLV_TYPE_DOMAIN 0x0007
|
||
|
/** TLV type : Supported channels */
|
||
|
#define TLV_TYPE_SUPPORTED_CHANNELS 0x0024
|
||
|
/** TLV type : HT Capabilities */
|
||
|
#define TLV_TYPE_HT_CAP 0x002d
|
||
|
/** TLV type : Qos Info */
|
||
|
#define TLV_TYPE_QOSINFO 0x002e
|
||
|
/** TLV type : RSN IE */
|
||
|
#define TLV_TYPE_RSN_IE 0x0030
|
||
|
/** TLV type : extended supported rates */
|
||
|
#define TLV_EXTENDED_SUPPORTED_RATES 0x0032
|
||
|
/** TLV type : timeout interval */
|
||
|
#define TLV_TIMEOUT_INTERVAL 0x0038
|
||
|
/** TLV type : Regulatory classes */
|
||
|
#define TLV_TYPE_REGULATORY_CLASSES 0x003b
|
||
|
/** TLV type : HT Information */
|
||
|
#define TLV_TYPE_HT_INFO 0x003d
|
||
|
/** TLV type : 20/40 BSS Coexistence */
|
||
|
#define TLV_TYPE_2040BSS_COEXISTENCE 0x0048
|
||
|
/** TLv Type : Link identifier */
|
||
|
#define TLV_LINK_IDENTIFIER 0x0065
|
||
|
|
||
|
/** Country code length */
|
||
|
#define COUNTRY_CODE_LEN 3
|
||
|
/** Length of Group Cipher Suite */
|
||
|
#define GROUP_CIPHER_SUITE_LEN 4
|
||
|
/** Length of Pairwise Cipher Suite */
|
||
|
#define PAIRWISE_CIPHER_SUITE_LEN 4
|
||
|
/** Length of AKM Suite */
|
||
|
#define AKM_SUITE_LEN 4
|
||
|
/** PMKID length */
|
||
|
#define PMKID_LEN 16
|
||
|
/** Maximum number of pairwise_cipher_suite */
|
||
|
#define MAX_PAIRWISE_CIPHER_SUITE_COUNT 2
|
||
|
/** Maximum number of AKM suite */
|
||
|
#define MAX_AKM_SUITE_COUNT 2
|
||
|
/** Maximum number of PMKID list count */
|
||
|
#define MAX_PMKID_COUNT 2
|
||
|
/** Length of MCS set */
|
||
|
#define MCS_SET_LEN 16
|
||
|
/** Version in RSN IE */
|
||
|
#define VERSION_RSN_IE 0x0001
|
||
|
|
||
|
/** tdls setinfo */
|
||
|
typedef struct _tdls_setinfo {
|
||
|
/** Action */
|
||
|
t_u16 action;
|
||
|
/** (TLV + capInfo) length */
|
||
|
t_u16 tlv_len;
|
||
|
/** Capability Info */
|
||
|
t_u16 cap_info;
|
||
|
/** tdls info */
|
||
|
t_u8 tlv_buffer[0];
|
||
|
} __ATTRIB_PACK__ tdls_setinfo;
|
||
|
|
||
|
/** tdls discovery */
|
||
|
typedef struct _tdls_discovery {
|
||
|
/** Action */
|
||
|
t_u16 action;
|
||
|
/** Peer MAC address */
|
||
|
t_u8 peer_mac[ETH_ALEN];
|
||
|
} __ATTRIB_PACK__ tdls_discovery;
|
||
|
|
||
|
/** tdls link status */
|
||
|
typedef struct _tdls_links_status {
|
||
|
/** Action */
|
||
|
t_u16 action;
|
||
|
} __ATTRIB_PACK__ tdls_link_status;
|
||
|
|
||
|
/** tdls discovery response */
|
||
|
typedef struct _tdls_discovery_resp {
|
||
|
/** Action */
|
||
|
t_u16 action;
|
||
|
/** payload length */
|
||
|
t_u16 payload_len;
|
||
|
/** peer mac Address */
|
||
|
t_u8 peer_mac[ETH_ALEN];
|
||
|
/** RSSI */
|
||
|
t_s8 rssi;
|
||
|
/** Cap Info */
|
||
|
t_u16 cap_info;
|
||
|
/** TLV buffer */
|
||
|
t_u8 tlv_buffer[0];
|
||
|
} __ATTRIB_PACK__ tdls_discovery_resp;
|
||
|
|
||
|
/** tdls each link rate information */
|
||
|
typedef struct _tdls_link_rate_info {
|
||
|
/** Tx Data Rate */
|
||
|
t_u8 tx_data_rate;
|
||
|
/** Tx Rate HT info*/
|
||
|
t_u8 tx_rate_htinfo;
|
||
|
} __ATTRIB_PACK__ tdls_link_rate_info;
|
||
|
|
||
|
/** tdls each link status */
|
||
|
typedef struct _tdls_each_link_status {
|
||
|
/** peer mac Address */
|
||
|
t_u8 peer_mac[ETH_ALEN];
|
||
|
/** Link Flags */
|
||
|
t_u8 link_flags;
|
||
|
/** Traffic Status */
|
||
|
t_u8 traffic_status;
|
||
|
/** Tx Failure Count */
|
||
|
t_u8 tx_fail_count;
|
||
|
/** Channel Number */
|
||
|
t_u32 active_channel;
|
||
|
/** Last Data RSSI in dBm */
|
||
|
t_s16 data_rssi_last;
|
||
|
/** Last Data NF in dBm */
|
||
|
t_s16 data_nf_last;
|
||
|
/** AVG DATA RSSI in dBm */
|
||
|
t_s16 data_rssi_avg;
|
||
|
/** AVG DATA NF in dBm */
|
||
|
t_s16 data_nf_avg;
|
||
|
union {
|
||
|
/** tdls rate info */
|
||
|
tdls_link_rate_info rate_info;
|
||
|
/** final rate value*/
|
||
|
t_u16 final_data_rate;
|
||
|
} u;
|
||
|
/** Security Method */
|
||
|
t_u8 security_method;
|
||
|
/** Key Lifetime */
|
||
|
t_u32 key_lifetime;
|
||
|
/** Key Length */
|
||
|
t_u8 key_length;
|
||
|
/** actual key */
|
||
|
t_u8 key[0];
|
||
|
} __ATTRIB_PACK__ tdls_each_link_status;
|
||
|
|
||
|
/** tdls link status response */
|
||
|
typedef struct _tdls_link_status_resp {
|
||
|
/** Action */
|
||
|
t_u16 action;
|
||
|
/** payload length */
|
||
|
t_u16 payload_len;
|
||
|
/** number of links */
|
||
|
t_u8 active_links;
|
||
|
/** structure for link status */
|
||
|
tdls_each_link_status link_stats[1];
|
||
|
} __ATTRIB_PACK__ tdls_link_status_resp;
|
||
|
|
||
|
/** tdls setup */
|
||
|
typedef struct _tdls_setup {
|
||
|
/** Action */
|
||
|
t_u16 action;
|
||
|
/** Peer MAC address */
|
||
|
t_u8 peer_mac[ETH_ALEN];
|
||
|
/** Time to wait for response from peer*/
|
||
|
t_u32 wait_time;
|
||
|
/** Key Life Time */
|
||
|
t_u32 key_life_time;
|
||
|
} __ATTRIB_PACK__ tdls_setup;
|
||
|
|
||
|
/** tdls tear down */
|
||
|
typedef struct _tdls_tear_down {
|
||
|
/** Action */
|
||
|
t_u16 action;
|
||
|
/** Peer MAC address */
|
||
|
t_u8 peer_mac[ETH_ALEN];
|
||
|
/** Reason code */
|
||
|
t_u16 reason_code;
|
||
|
} __ATTRIB_PACK__ tdls_teardown;
|
||
|
|
||
|
/** tdls power mode */
|
||
|
typedef struct _tdls_power_mode {
|
||
|
/** Action */
|
||
|
t_u16 action;
|
||
|
/** Peer MAC address */
|
||
|
t_u8 peer_mac[ETH_ALEN];
|
||
|
/** Power mode */
|
||
|
t_u16 power_mode;
|
||
|
} __ATTRIB_PACK__ tdls_powermode;
|
||
|
|
||
|
/** tdls channel switch info */
|
||
|
typedef struct _tdls_channel_switch {
|
||
|
/** Action */
|
||
|
t_u16 action;
|
||
|
/** peer mac Address */
|
||
|
t_u8 peer_mac[ETH_ALEN];
|
||
|
/** Channel Switch primary channel no */
|
||
|
t_u8 primary_channel;
|
||
|
/** Channel Switch secondary channel offset */
|
||
|
t_u8 secondary_channel_offset;
|
||
|
/** Channel Switch Band */
|
||
|
t_u8 band;
|
||
|
/** Channel Switch time*/
|
||
|
t_u16 switch_time;
|
||
|
/** Channel Switch timeout*/
|
||
|
t_u16 switch_timeout;
|
||
|
/** Channel Regulatory class*/
|
||
|
t_u8 regulatory_class;
|
||
|
/** Channel Switch periodicity*/
|
||
|
t_u8 periodicity;
|
||
|
} __ATTRIB_PACK__ tdls_channel_switch;
|
||
|
|
||
|
/** tdls stop channel switch */
|
||
|
typedef struct _tdls_stop_chan_switch {
|
||
|
/** Action */
|
||
|
t_u16 action;
|
||
|
/** Peer MAC address */
|
||
|
t_u8 peer_mac[ETH_ALEN];
|
||
|
} __ATTRIB_PACK__ tdls_stop_chan_switch;
|
||
|
|
||
|
/** tdls disable channel switch */
|
||
|
typedef struct _tdls_disable_cs {
|
||
|
/** Action */
|
||
|
t_u16 action;
|
||
|
/** Data*/
|
||
|
t_u16 data;
|
||
|
} __ATTRIB_PACK__ tdls_disable_cs, tdls_config;
|
||
|
|
||
|
/** tdls channel switch parameters */
|
||
|
typedef struct _tdls_cs_params {
|
||
|
/** Action */
|
||
|
t_u16 action;
|
||
|
/** unit time, multiples of 10ms */
|
||
|
t_u8 unit_time;
|
||
|
/** threshold for other link */
|
||
|
t_u8 threshold_otherlink;
|
||
|
/** threshold for direct link */
|
||
|
t_u8 threshold_directlink;
|
||
|
} __ATTRIB_PACK__ tdls_cs_params;
|
||
|
|
||
|
/** Host tdls config */
|
||
|
typedef struct _host_tdls_cfg {
|
||
|
/** Action */
|
||
|
t_u16 action;
|
||
|
/** support uapsd */
|
||
|
t_u8 uapsd_support;
|
||
|
/** channel_switch */
|
||
|
t_u8 cs_support;
|
||
|
/** TLV length */
|
||
|
t_u16 tlv_len;
|
||
|
/** tdls info */
|
||
|
t_u8 tlv_buffer[0];
|
||
|
} __ATTRIB_PACK__ host_tdls_cfg;
|
||
|
|
||
|
/** tdls debug */
|
||
|
typedef struct _tdls_debug {
|
||
|
/** Action */
|
||
|
t_u16 action;
|
||
|
/** Data */
|
||
|
t_u8 data[0];
|
||
|
} __ATTRIB_PACK__ tdls_debug;
|
||
|
|
||
|
/** TLV header */
|
||
|
#define TLVHEADER /** Tag */ \
|
||
|
t_u16 tag; \
|
||
|
/** Length */ \
|
||
|
t_u16 length
|
||
|
|
||
|
/** Length of TLV header */
|
||
|
#define TLVHEADER_LEN 4
|
||
|
|
||
|
/** Data structure for subband set */
|
||
|
typedef struct _IEEEtypes_SubbandSet_t {
|
||
|
/** First channel */
|
||
|
t_u8 first_chan;
|
||
|
/** Number of channels */
|
||
|
t_u8 no_of_chan;
|
||
|
/** Maximum Tx power */
|
||
|
t_u8 max_tx_pwr;
|
||
|
} __ATTRIB_PACK__ IEEEtypes_SubbandSet_t, *pIEEEtypes_SubbandSet_t;
|
||
|
|
||
|
/** tlvbuf_DomainParamSet_t */
|
||
|
typedef struct _tlvbuf_DomainParamSet {
|
||
|
/** Header */
|
||
|
TLVHEADER;
|
||
|
/** Country code */
|
||
|
t_u8 country_code[COUNTRY_CODE_LEN];
|
||
|
/** Set of subbands */
|
||
|
IEEEtypes_SubbandSet_t sub_band[0];
|
||
|
} __ATTRIB_PACK__ tlvbuf_DomainParamSet_t;
|
||
|
|
||
|
/** Qos Info TLV */
|
||
|
typedef struct _tlvbuf_QosInfo_t {
|
||
|
/** Header */
|
||
|
TLVHEADER;
|
||
|
/** QosInfo */
|
||
|
union {
|
||
|
/** QosInfo bitfield */
|
||
|
IEEEtypes_WmmQosInfo_t qos_info;
|
||
|
/** QosInfo byte */
|
||
|
t_u8 qos_info_byte;
|
||
|
} u;
|
||
|
} __ATTRIB_PACK__ tlvbuf_QosInfo_t;
|
||
|
|
||
|
/** HT Capabilities Data */
|
||
|
typedef struct _HTCap_t {
|
||
|
/** HT Capabilities Info field */
|
||
|
t_u16 ht_cap_info;
|
||
|
/** A-MPDU Parameters field */
|
||
|
t_u8 ampdu_param;
|
||
|
/** Supported MCS Set field */
|
||
|
t_u8 supported_mcs_set[16];
|
||
|
/** HT Extended Capabilities field */
|
||
|
t_u16 ht_ext_cap;
|
||
|
/** Transmit Beamforming Capabilities field */
|
||
|
t_u32 tx_bf_cap;
|
||
|
/** Antenna Selection Capability field */
|
||
|
t_u8 asel;
|
||
|
} __ATTRIB_PACK__ HTCap_t, *pHTCap_t;
|
||
|
|
||
|
/** HT Information Data */
|
||
|
typedef struct _HTInfo_t {
|
||
|
/** Primary channel */
|
||
|
t_u8 pri_chan;
|
||
|
/** Field 2 */
|
||
|
t_u8 field2;
|
||
|
/** Field 3 */
|
||
|
t_u16 field3;
|
||
|
/** Field 4 */
|
||
|
t_u16 field4;
|
||
|
/** Bitmap indicating MCSs supported by all HT STAs in the BSS */
|
||
|
t_u8 basic_mcs_set[16];
|
||
|
} __ATTRIB_PACK__ HTInfo_t, *pHTInfo_t;
|
||
|
|
||
|
/** 20/40 BSS Coexistence Data */
|
||
|
typedef struct _BSSCo2040_t {
|
||
|
/** 20/40 BSS Coexistence value */
|
||
|
t_u8 bss_co_2040_value;
|
||
|
} __ATTRIB_PACK__ BSSCo2040_t, *pBSSCo2040_t;
|
||
|
|
||
|
/** HT Capabilities element */
|
||
|
typedef struct _tlvbuf_HTCap_t {
|
||
|
/** Header */
|
||
|
TLVHEADER;
|
||
|
/** HTCap struct */
|
||
|
HTCap_t ht_cap;
|
||
|
} __ATTRIB_PACK__ tlvbuf_HTCap_t;
|
||
|
|
||
|
/** HT Information element */
|
||
|
typedef struct _tlvbuf_HTInfo_t {
|
||
|
/** Header */
|
||
|
TLVHEADER;
|
||
|
|
||
|
/** HTInfo struct */
|
||
|
HTInfo_t ht_info;
|
||
|
} __ATTRIB_PACK__ tlvbuf_HTInfo_t;
|
||
|
|
||
|
/** 20/40 BSS Coexistence element */
|
||
|
typedef struct _tlvbuf_2040BSSCo_t {
|
||
|
/** Header */
|
||
|
TLVHEADER;
|
||
|
|
||
|
/** BSSCo2040_t struct */
|
||
|
BSSCo2040_t bss_co_2040;
|
||
|
} __ATTRIB_PACK__ tlvbuf_2040BSSCo_t;
|
||
|
|
||
|
/** Extended Capabilities element */
|
||
|
typedef struct _tlvbuf_ExtCap_t {
|
||
|
/** Header */
|
||
|
TLVHEADER;
|
||
|
/** ExtCap_t struct */
|
||
|
t_u8 ext_cap[0];
|
||
|
} __ATTRIB_PACK__ tlvbuf_ExtCap_t;
|
||
|
|
||
|
/** tlvbuf_RatesParamSet_t */
|
||
|
typedef struct _tlvbuf_RatesParamSet_t {
|
||
|
/** Header */
|
||
|
TLVHEADER;
|
||
|
/** Rates */
|
||
|
t_u8 rates[0];
|
||
|
} __ATTRIB_PACK__ tlvbuf_RatesParamSet_t;
|
||
|
|
||
|
/* IEEE Supported Channel sub-band description (7.3.2.19) */
|
||
|
/* Sub-band description used in the supported channels element. */
|
||
|
typedef struct _IEEEtypes_SupportChan_Subband_t {
|
||
|
t_u8 start_chan;/**< Starting channel in the subband */
|
||
|
t_u8 num_chans; /**< Number of channels in the subband */
|
||
|
|
||
|
} __ATTRIB_PACK__ IEEEtypes_SupportChan_Subband_t;
|
||
|
|
||
|
/* IEEE Supported Channel element (7.3.2.19) */
|
||
|
/**
|
||
|
* Sent in association requests. Details the sub-bands and number
|
||
|
* of channels supported in each subband
|
||
|
*/
|
||
|
typedef struct _tlvbuf_SupportedChannels_t {
|
||
|
/** Header */
|
||
|
TLVHEADER;
|
||
|
/**< IEEE Element ID = 36 */
|
||
|
/** Configured sub-bands information in the element */
|
||
|
IEEEtypes_SupportChan_Subband_t subband[0];
|
||
|
} __ATTRIB_PACK__ tlvbuf_SupportedChannels_t;
|
||
|
|
||
|
#define VHT_MCS_MAP_LEN 2
|
||
|
/** VHT MCS rate set field, refer to 802.11ac */
|
||
|
typedef struct _VHT_MCS_set {
|
||
|
t_u16 rx_mcs_map;
|
||
|
t_u16 rx_max_rate; /* bit 29-31 reserved */
|
||
|
t_u16 tx_mcs_map;
|
||
|
t_u16 tx_max_rate; /* bit 61-63 reserved */
|
||
|
} __ATTRIB_PACK__ VHT_MCS_set_t, *pVHT_MCS_set_t;
|
||
|
|
||
|
typedef struct _VHT_capa {
|
||
|
t_u32 vht_cap_info;
|
||
|
VHT_MCS_set_t mcs_sets;
|
||
|
} __ATTRIB_PACK__ VHT_capa_t, *pVHT_capa_t;
|
||
|
|
||
|
/** VHT Capabilities IE */
|
||
|
typedef struct _IEEEtypes_VHTCap_t {
|
||
|
/** Header */
|
||
|
TLVHEADER;
|
||
|
/** VHTInfo struct */
|
||
|
VHT_capa_t vht_cap;
|
||
|
} __ATTRIB_PACK__ tlvbuf_VHTCap_t, *ptlvbuf_VHTCap_t;
|
||
|
|
||
|
/** VHT Operations IE */
|
||
|
typedef struct _IEEEtypes_VHTOprat_t {
|
||
|
/** Header */
|
||
|
TLVHEADER;
|
||
|
/** VHTOpra struct */
|
||
|
t_u8 chan_width;
|
||
|
t_u8 chan_cf1;
|
||
|
t_u8 chan_cf2;
|
||
|
/** Basic MCS set map, each 2 bits stands for a Nss */
|
||
|
t_u8 basic_mcs_map[VHT_MCS_MAP_LEN];
|
||
|
} __ATTRIB_PACK__ tlvbuf_VHTOpra_t, *ptlvbuf_VHTOpra_t;
|
||
|
|
||
|
/* IEEE Supported Regulatory Classes description (7.3.2.54) */
|
||
|
typedef struct _IEEEtypes_RegulatoryClass_t {
|
||
|
/** current regulatory class */
|
||
|
t_u8 cur_regulatory_class;
|
||
|
/** supported regulatory class list */
|
||
|
t_u8 regulatory_classes_list[0];
|
||
|
|
||
|
} __ATTRIB_PACK__ IEEEtypes_RegulatoryClass_t;
|
||
|
|
||
|
/* IEEE Supported Regulatory Classes TLV (7.3.2.54) */
|
||
|
typedef struct _tlvbuf_RegulatoryClass_t {
|
||
|
/** Header */
|
||
|
TLVHEADER;
|
||
|
/**< IEEE Element ID = 59 */
|
||
|
/** supported regulatory class */
|
||
|
IEEEtypes_RegulatoryClass_t regulatory_class;
|
||
|
} __ATTRIB_PACK__ tlvbuf_RegulatoryClass_t;
|
||
|
|
||
|
/** tlvbuf_RsnParamSet_t */
|
||
|
typedef struct _tlvbuf_RsnParamSet_t {
|
||
|
/** Header */
|
||
|
TLVHEADER;
|
||
|
/** Version */
|
||
|
t_u16 version;
|
||
|
/** Group Cipher Suite */
|
||
|
t_u8 group_cipher_suite[4];
|
||
|
/** Pairwise Cipher Suite count */
|
||
|
t_u16 pairwise_cipher_count;
|
||
|
/** Pairwise Cipher Suite */
|
||
|
t_u8 pairwise_cipher_suite[0];
|
||
|
/** AKM Suite Sount */
|
||
|
t_u16 akm_suite_count;
|
||
|
/** AKM Suite */
|
||
|
t_u8 akm_suite[0];
|
||
|
/** RSN Capability */
|
||
|
t_u16 rsn_capability;
|
||
|
/** PMKID Count */
|
||
|
t_u16 pmkid_count;
|
||
|
/** PMKID list */
|
||
|
t_u8 pmkid_list[0];
|
||
|
} __ATTRIB_PACK__ tlvbuf_RsnParamSet_t;
|
||
|
|
||
|
/** Size of a TSPEC. Used to allocate necessary buffer space in commands */
|
||
|
#define WMM_TSPEC_SIZE 63
|
||
|
|
||
|
/** Maximum number of AC QOS queues available in the driver/firmware */
|
||
|
#define MAX_AC_QUEUES 4
|
||
|
|
||
|
/** Maximum number of User Priorities */
|
||
|
#define MAX_USER_PRIORITIES 8
|
||
|
|
||
|
/** Extra IE bytes allocated in messages for appended IEs after a TSPEC */
|
||
|
#define WMM_ADDTS_EXTRA_IE_BYTES 256
|
||
|
|
||
|
/**
|
||
|
* @brief Enumeration for the command result from an ADDTS or DELTS command
|
||
|
*/
|
||
|
typedef enum {
|
||
|
TSPEC_RESULT_SUCCESS = 0,
|
||
|
TSPEC_RESULT_EXEC_FAILURE = 1,
|
||
|
TSPEC_RESULT_TIMEOUT = 2,
|
||
|
TSPEC_RESULT_DATA_INVALID = 3,
|
||
|
} __ATTRIB_PACK__ mlan_wmm_tspec_result_e;
|
||
|
|
||
|
/**
|
||
|
* @brief Enumeration for the action field in the Queue configure command
|
||
|
*/
|
||
|
typedef enum {
|
||
|
WMM_QUEUE_CONFIG_ACTION_GET = 0,
|
||
|
WMM_QUEUE_CONFIG_ACTION_SET = 1,
|
||
|
WMM_QUEUE_CONFIG_ACTION_DEFAULT = 2,
|
||
|
|
||
|
WMM_QUEUE_CONFIG_ACTION_MAX
|
||
|
} __ATTRIB_PACK__ mlan_wmm_queue_config_action_e;
|
||
|
|
||
|
/**
|
||
|
* @brief Enumeration for the action field in the queue stats command
|
||
|
*/
|
||
|
typedef enum {
|
||
|
WMM_STATS_ACTION_START = 0,
|
||
|
WMM_STATS_ACTION_STOP = 1,
|
||
|
WMM_STATS_ACTION_GET_CLR = 2,
|
||
|
WMM_STATS_ACTION_SET_CFG = 3, /* Not currently used */
|
||
|
WMM_STATS_ACTION_GET_CFG = 4, /* Not currently used */
|
||
|
|
||
|
WMM_STATS_ACTION_MAX
|
||
|
} __ATTRIB_PACK__ mlan_wmm_stats_action_e;
|
||
|
|
||
|
/** Data structure of WMM Aci/Aifsn */
|
||
|
typedef 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 */
|
||
|
t_u8 aifsn:4;
|
||
|
/** Acm */
|
||
|
t_u8 acm:1;
|
||
|
/** Aci */
|
||
|
t_u8 aci:2;
|
||
|
/** Reserved */
|
||
|
t_u8 reserved:1;
|
||
|
#endif
|
||
|
} __ATTRIB_PACK__ IEEEtypes_WmmAciAifsn_t, *pIEEEtypes_WmmAciAifsn_t;
|
||
|
|
||
|
/** Data structure of WMM ECW */
|
||
|
typedef 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 */
|
||
|
t_u8 ecw_min:4;
|
||
|
/** Maximum Ecw */
|
||
|
t_u8 ecw_max:4;
|
||
|
#endif
|
||
|
} __ATTRIB_PACK__ IEEEtypes_WmmEcw_t, *pIEEEtypes_WmmEcw_t;
|
||
|
|
||
|
/** Data structure of WMM AC parameters */
|
||
|
typedef struct _IEEEtypes_WmmAcParameters_t {
|
||
|
IEEEtypes_WmmAciAifsn_t aci_aifsn; /**< AciAifSn */
|
||
|
IEEEtypes_WmmEcw_t ecw; /**< Ecw */
|
||
|
t_u16 tx_op_limit; /**< Tx op limit */
|
||
|
} __ATTRIB_PACK__ IEEEtypes_WmmAcParameters_t, *pIEEEtypes_WmmAcParameters_t;
|
||
|
|
||
|
/** Data structure of WMM Info IE */
|
||
|
typedef struct _IEEEtypes_WmmInfo_t {
|
||
|
|
||
|
/**
|
||
|
* WMM Info IE - Vendor Specific Header:
|
||
|
* element_id [221/0xdd]
|
||
|
* Len [7]
|
||
|
* Oui [00:50:f2]
|
||
|
* OuiType [2]
|
||
|
* OuiSubType [0]
|
||
|
* Version [1]
|
||
|
*/
|
||
|
IEEEtypes_VendorHeader_t vend_hdr;
|
||
|
|
||
|
/** QoS information */
|
||
|
IEEEtypes_WmmQosInfo_t qos_info;
|
||
|
|
||
|
} __ATTRIB_PACK__ IEEEtypes_WmmInfo_t, *pIEEEtypes_WmmInfo_t;
|
||
|
|
||
|
/** Data structure of WMM parameter IE */
|
||
|
typedef struct _IEEEtypes_WmmParameter_t {
|
||
|
/**
|
||
|
* WMM Parameter IE - Vendor Specific Header:
|
||
|
* element_id [221/0xdd]
|
||
|
* Len [24]
|
||
|
* Oui [00:50:f2]
|
||
|
* OuiType [2]
|
||
|
* OuiSubType [1]
|
||
|
* Version [1]
|
||
|
*/
|
||
|
IEEEtypes_VendorHeader_t vend_hdr;
|
||
|
|
||
|
/** QoS information */
|
||
|
IEEEtypes_WmmQosInfo_t qos_info;
|
||
|
/** Reserved */
|
||
|
t_u8 reserved;
|
||
|
|
||
|
/** AC Parameters Record WMM_AC_BE, WMM_AC_BK, WMM_AC_VI, WMM_AC_VO */
|
||
|
IEEEtypes_WmmAcParameters_t ac_params[MAX_AC_QUEUES];
|
||
|
|
||
|
} __ATTRIB_PACK__ IEEEtypes_WmmParameter_t, *pIEEEtypes_WmmParameter_t;
|
||
|
|
||
|
/**
|
||
|
* @brief IOCTL structure to send an ADDTS request and retrieve the response.
|
||
|
*
|
||
|
* IOCTL structure from the application layer relayed to firmware to
|
||
|
* instigate an ADDTS management frame with an appropriate TSPEC IE as well
|
||
|
* as any additional IEs appended in the ADDTS Action frame.
|
||
|
*
|
||
|
* @sa wlan_wmm_addts_req_ioctl
|
||
|
*/
|
||
|
typedef struct {
|
||
|
mlan_wmm_tspec_result_e commandResult;
|
||
|
/**< Firmware execution result */
|
||
|
|
||
|
t_u32 timeout_ms; /**< Timeout value in milliseconds */
|
||
|
t_u8 ieeeStatusCode; /**< IEEE status code */
|
||
|
|
||
|
t_u32 ieDataLen;
|
||
|
t_u8 ieData[WMM_TSPEC_SIZE
|
||
|
/**< TSPEC to send in the ADDTS */
|
||
|
+ WMM_ADDTS_EXTRA_IE_BYTES];
|
||
|
/**< ADDTS extra IE buf */
|
||
|
} wlan_ioctl_wmm_addts_req_t;
|
||
|
|
||
|
/**
|
||
|
* @brief IOCTL structure to send a DELTS request.
|
||
|
*
|
||
|
* IOCTL structure from the application layer relayed to firmware to
|
||
|
* instigate an DELTS management frame with an appropriate TSPEC IE.
|
||
|
*
|
||
|
* @sa wlan_wmm_delts_req_ioctl
|
||
|
*/
|
||
|
typedef struct {
|
||
|
mlan_wmm_tspec_result_e commandResult;
|
||
|
/**< Firmware execution result */
|
||
|
t_u8 ieeeReasonCode; /**< IEEE reason code sent, unused for WMM */
|
||
|
|
||
|
t_u32 ieDataLen;
|
||
|
t_u8 ieData[WMM_TSPEC_SIZE];
|
||
|
/**< TSPEC to send in the DELTS */
|
||
|
} wlan_ioctl_wmm_delts_req_t;
|
||
|
|
||
|
/**
|
||
|
* @brief IOCTL structure to configure a specific AC Queue's parameters
|
||
|
*
|
||
|
* IOCTL structure from the application layer relayed to firmware to
|
||
|
* get, set, or default the WMM AC queue parameters.
|
||
|
*
|
||
|
* - msduLifetimeExpiry is ignored if set to 0 on a set command
|
||
|
*
|
||
|
* @sa wlan_wmm_queue_config_ioctl
|
||
|
*/
|
||
|
typedef struct {
|
||
|
mlan_wmm_queue_config_action_e action;
|
||
|
/**< Set, Get, or Default */
|
||
|
mlan_wmm_ac_e accessCategory; /**< WMM_AC_BK(0) to WMM_AC_VO(3) */
|
||
|
t_u16 msduLifetimeExpiry; /**< lifetime expiry in TUs */
|
||
|
t_u8 supportedRates[10]; /**< Not supported yet */
|
||
|
} wlan_ioctl_wmm_queue_config_t;
|
||
|
|
||
|
/** Number of bins in the histogram for the HostCmd_DS_WMM_QUEUE_STATS */
|
||
|
#define WMM_STATS_PKTS_HIST_BINS 7
|
||
|
|
||
|
/**
|
||
|
* @brief IOCTL structure to start, stop, and get statistics for a WMM AC
|
||
|
*
|
||
|
* IOCTL structure from the application layer relayed to firmware to
|
||
|
* start or stop statistical collection for a given AC. Also used to
|
||
|
* retrieve and clear the collected stats on a given AC.
|
||
|
*
|
||
|
* @sa wlan_wmm_queue_stats_ioctl
|
||
|
*/
|
||
|
typedef struct {
|
||
|
mlan_wmm_stats_action_e action;
|
||
|
/**< Start, Stop, or Get */
|
||
|
t_u8 userPriority;
|
||
|
/**< User Priority (0 to 7) */
|
||
|
t_u16 pktCount; /**< Number of successful packets transmitted */
|
||
|
t_u16 pktLoss; /**< Packets lost; not included in pktCount */
|
||
|
t_u32 avgQueueDelay;
|
||
|
/**< Average Queue delay in microseconds */
|
||
|
t_u32 avgTxDelay;/**< Average Transmission delay in microseconds */
|
||
|
t_u16 usedTime; /**< Calculated used time - units of 32 microsec */
|
||
|
t_u16 policedTime;
|
||
|
/**< Calculated policed time - units of 32 microsec */
|
||
|
|
||
|
/** @brief Queue Delay Histogram; number of packets per queue delay range
|
||
|
*
|
||
|
* [0] - 0ms <= delay < 5ms
|
||
|
* [1] - 5ms <= delay < 10ms
|
||
|
* [2] - 10ms <= delay < 20ms
|
||
|
* [3] - 20ms <= delay < 30ms
|
||
|
* [4] - 30ms <= delay < 40ms
|
||
|
* [5] - 40ms <= delay < 50ms
|
||
|
* [6] - 50ms <= delay < msduLifetime (TUs)
|
||
|
*/
|
||
|
t_u16 delayHistogram[WMM_STATS_PKTS_HIST_BINS];
|
||
|
} wlan_ioctl_wmm_queue_stats_t;
|
||
|
|
||
|
/**
|
||
|
* @brief IOCTL and command sub structure for a Traffic stream status.
|
||
|
*/
|
||
|
typedef struct {
|
||
|
t_u8 tid; /**< TSID: Range: 0->7 */
|
||
|
t_u8 valid; /**< TSID specified is valid */
|
||
|
t_u8 accessCategory;/**< AC TSID is active on */
|
||
|
t_u8 userPriority; /**< UP specified for the TSID */
|
||
|
|
||
|
t_u8 psb; /**< Power save mode for TSID: 0 (legacy), 1 (UAPSD) */
|
||
|
t_u8 flowDir; /**< Upstream (0), Downlink(1), Bidirectional(3) */
|
||
|
t_u16 mediumTime; /**< Medium time granted for the TSID */
|
||
|
} __ATTRIB_PACK__ HostCmd_DS_WMM_TS_STATUS,
|
||
|
wlan_ioctl_wmm_ts_status_t, wlan_cmd_wmm_ts_status_t;
|
||
|
|
||
|
/**
|
||
|
* @brief IOCTL sub structure for a specific WMM AC Status
|
||
|
*/
|
||
|
typedef struct {
|
||
|
/** WMM Acm */
|
||
|
t_u8 wmmAcm;
|
||
|
/** Flow required flag */
|
||
|
t_u8 flowRequired;
|
||
|
/** Flow created flag */
|
||
|
t_u8 flowCreated;
|
||
|
/** Disabled flag */
|
||
|
t_u8 disabled;
|
||
|
/** delivery enabled */
|
||
|
t_u8 deliveryEnabled;
|
||
|
/** trigger enabled */
|
||
|
t_u8 triggerEnabled;
|
||
|
} wlan_ioctl_wmm_queue_status_ac_t;
|
||
|
|
||
|
/**
|
||
|
* @brief IOCTL structure to retrieve the WMM AC Queue status
|
||
|
*
|
||
|
* IOCTL structure from the application layer to retrieve:
|
||
|
* - ACM bit setting for the AC
|
||
|
* - Firmware status (flow required, flow created, flow disabled)
|
||
|
*
|
||
|
* @sa wlan_wmm_queue_status_ioctl
|
||
|
*/
|
||
|
typedef struct {
|
||
|
/** WMM AC queue status */
|
||
|
wlan_ioctl_wmm_queue_status_ac_t acStatus[MAX_AC_QUEUES];
|
||
|
} wlan_ioctl_wmm_queue_status_t;
|
||
|
#endif /* STA_SUPPORT */
|
||
|
|
||
|
/** Command RET code, MSB is set to 1 */
|
||
|
#define HostCmd_RET_BIT 0x8000
|
||
|
/** General purpose action : Get */
|
||
|
#define HostCmd_ACT_GEN_GET 0x0000
|
||
|
/** General purpose action : Set */
|
||
|
#define HostCmd_ACT_GEN_SET 0x0001
|
||
|
/** General purpose action : Clear */
|
||
|
#define HostCmd_ACT_GEN_CLEAR 0x0004
|
||
|
/** General purpose action : Remove */
|
||
|
#define HostCmd_ACT_GEN_REMOVE 0x0004
|
||
|
|
||
|
/** TLV type ID definition */
|
||
|
#define PROPRIETARY_TLV_BASE_ID 0x0100
|
||
|
|
||
|
/** MrvlIEtypesHeader_t */
|
||
|
typedef struct MrvlIEtypesHeader {
|
||
|
/** Header type */
|
||
|
t_u16 type;
|
||
|
/** Header length */
|
||
|
t_u16 len;
|
||
|
} __ATTRIB_PACK__ MrvlIEtypesHeader_t;
|
||
|
|
||
|
/** MrvlIEtypes_Data_t */
|
||
|
typedef struct MrvlIEtypes_Data_t {
|
||
|
/** Header */
|
||
|
MrvlIEtypesHeader_t header;
|
||
|
/** Data */
|
||
|
t_u8 data[1];
|
||
|
} __ATTRIB_PACK__ MrvlIEtypes_Data_t;
|
||
|
|
||
|
/** HostCmd_DS_802_11_SUBSCRIBE_EVENT */
|
||
|
typedef struct MAPP_HostCmd_DS_802_11_SUBSCRIBE_EVENT {
|
||
|
/** Action */
|
||
|
t_u16 action;
|
||
|
/** Events */
|
||
|
t_u16 events;
|
||
|
} __ATTRIB_PACK__ HostCmd_DS_802_11_SUBSCRIBE_EVENT;
|
||
|
|
||
|
/** MrvlIEtypes_RssiParamSet_t */
|
||
|
typedef struct MrvlIEtypes_RssiThreshold {
|
||
|
/** Header */
|
||
|
MrvlIEtypesHeader_t header;
|
||
|
/** RSSI value */
|
||
|
t_u8 RSSI_value;
|
||
|
/** RSSI frequency */
|
||
|
t_u8 RSSI_freq;
|
||
|
} __ATTRIB_PACK__ MrvlIEtypes_RssiThreshold_t;
|
||
|
|
||
|
/** MrvlIEtypes_SnrThreshold_t */
|
||
|
typedef struct MrvlIEtypes_SnrThreshold {
|
||
|
/** Header */
|
||
|
MrvlIEtypesHeader_t header;
|
||
|
/** SNR value */
|
||
|
t_u8 SNR_value;
|
||
|
/** SNR frequency */
|
||
|
t_u8 SNR_freq;
|
||
|
} __ATTRIB_PACK__ MrvlIEtypes_SnrThreshold_t;
|
||
|
|
||
|
/** MrvlIEtypes_FailureCount_t */
|
||
|
typedef struct MrvlIEtypes_FailureCount {
|
||
|
/** Header */
|
||
|
MrvlIEtypesHeader_t header;
|
||
|
/** Failure value */
|
||
|
t_u8 fail_value;
|
||
|
/** Failure frequency */
|
||
|
t_u8 fail_freq;
|
||
|
} __ATTRIB_PACK__ MrvlIEtypes_FailureCount_t;
|
||
|
|
||
|
/** MrvlIEtypes_BeaconsMissed_t */
|
||
|
typedef struct MrvlIEtypes_BeaconsMissed {
|
||
|
/** Header */
|
||
|
MrvlIEtypesHeader_t header;
|
||
|
/** Number of beacons missed */
|
||
|
t_u8 beacon_missed;
|
||
|
/** Reserved */
|
||
|
t_u8 reserved;
|
||
|
} __ATTRIB_PACK__ MrvlIEtypes_BeaconsMissed_t;
|
||
|
|
||
|
/** MrvlIEtypes_LinkQuality_t */
|
||
|
typedef struct MrvlIEtypes_LinkQuality {
|
||
|
/** Header */
|
||
|
MrvlIEtypesHeader_t header;
|
||
|
/** Link SNR threshold */
|
||
|
t_u16 link_SNR_thrs;
|
||
|
/** Link SNR frequency */
|
||
|
t_u16 link_SNR_freq;
|
||
|
/** Minimum rate value */
|
||
|
t_u16 min_rate_val;
|
||
|
/** Minimum rate frequency */
|
||
|
t_u16 min_rate_freq;
|
||
|
/** Tx latency value */
|
||
|
t_u32 tx_latency_val;
|
||
|
/** Tx latency threshold */
|
||
|
t_u32 tx_latency_thrs;
|
||
|
} __ATTRIB_PACK__ MrvlIEtypes_LinkQuality_t;
|
||
|
|
||
|
/** Host Command ID : 802.11 subscribe event */
|
||
|
#define HostCmd_CMD_802_11_SUBSCRIBE_EVENT 0x0075
|
||
|
|
||
|
/** TLV type : Beacon RSSI low */
|
||
|
#define TLV_TYPE_RSSI_LOW (PROPRIETARY_TLV_BASE_ID + 0x04) /* 0x0104 */
|
||
|
/** TLV type : Beacon SNR low */
|
||
|
#define TLV_TYPE_SNR_LOW (PROPRIETARY_TLV_BASE_ID + 0x05) /* 0x0105 */
|
||
|
/** TLV type : Fail count */
|
||
|
#define TLV_TYPE_FAILCOUNT (PROPRIETARY_TLV_BASE_ID + 0x06) /* 0x0106 */
|
||
|
/** TLV type : BCN miss */
|
||
|
#define TLV_TYPE_BCNMISS (PROPRIETARY_TLV_BASE_ID + 0x07) /* 0x0107 */
|
||
|
/** TLV type : Beacon RSSI high */
|
||
|
#define TLV_TYPE_RSSI_HIGH (PROPRIETARY_TLV_BASE_ID + 0x16) /* 0x0116 */
|
||
|
/** TLV type : Beacon SNR high */
|
||
|
#define TLV_TYPE_SNR_HIGH (PROPRIETARY_TLV_BASE_ID + 0x17) /* 0x0117 */
|
||
|
|
||
|
/** TLV type :Link Quality */
|
||
|
#define TLV_TYPE_LINK_QUALITY (PROPRIETARY_TLV_BASE_ID + 0x24) /* 0x0124 */
|
||
|
|
||
|
/** TLV type : Data RSSI low */
|
||
|
#define TLV_TYPE_RSSI_LOW_DATA (PROPRIETARY_TLV_BASE_ID + 0x26) /* 0x0126 */
|
||
|
/** TLV type : Data SNR low */
|
||
|
#define TLV_TYPE_SNR_LOW_DATA (PROPRIETARY_TLV_BASE_ID + 0x27) /* 0x0127 */
|
||
|
/** TLV type : Data RSSI high */
|
||
|
#define TLV_TYPE_RSSI_HIGH_DATA (PROPRIETARY_TLV_BASE_ID + 0x28) /* 0x0128 */
|
||
|
/** TLV type : Data SNR high */
|
||
|
#define TLV_TYPE_SNR_HIGH_DATA (PROPRIETARY_TLV_BASE_ID + 0x29) /* 0x0129 */
|
||
|
|
||
|
/** MrvlIEtypes_PreBeaconLost_t */
|
||
|
typedef struct MrvlIEtypes_PreBeaconLost {
|
||
|
/** Header */
|
||
|
MrvlIEtypesHeader_t header;
|
||
|
/** Pre-Beacon Lost */
|
||
|
t_u8 pre_beacon_lost;
|
||
|
/** Reserved */
|
||
|
t_u8 reserved;
|
||
|
} __ATTRIB_PACK__ MrvlIEtypes_PreBeaconLost_t;
|
||
|
|
||
|
/** TLV type: Pre-Beacon Lost */
|
||
|
#define TLV_TYPE_PRE_BEACON_LOST (PROPRIETARY_TLV_BASE_ID + 0x49) /* 0x0149 */
|
||
|
|
||
|
/** TLV type : Extended capabilities */
|
||
|
#define TLV_TYPE_EXTCAP 0x007f
|
||
|
|
||
|
/** AutoTx_MacFrame_t */
|
||
|
typedef struct AutoTx_MacFrame {
|
||
|
t_u16 interval; /**< in seconds */
|
||
|
t_u8 priority; /**< User Priority: 0~7, ignored if non-WMM */
|
||
|
t_u8 reserved; /**< set to 0 */
|
||
|
t_u16 frame_len; /**< Length of MAC frame payload */
|
||
|
t_u8 dest_mac_addr[MLAN_MAC_ADDR_LENGTH]; /**< Destination MAC address */
|
||
|
t_u8 src_mac_addr[MLAN_MAC_ADDR_LENGTH]; /**< Source MAC address */
|
||
|
t_u8 payload[]; /**< Payload */
|
||
|
} __ATTRIB_PACK__ AutoTx_MacFrame_t;
|
||
|
|
||
|
/** MrvlIEtypes_AutoTx_t */
|
||
|
typedef struct MrvlIEtypes_AutoTx {
|
||
|
MrvlIEtypesHeader_t header; /**< Header */
|
||
|
AutoTx_MacFrame_t auto_tx_mac_frame; /**< Auto Tx MAC frame */
|
||
|
} __ATTRIB_PACK__ MrvlIEtypes_AutoTx_t;
|
||
|
|
||
|
/** HostCmd_DS_802_11_AUTO_TX */
|
||
|
typedef struct MAPP_HostCmd_DS_802_11_AUTO_TX {
|
||
|
/** Action */
|
||
|
t_u16 action; /* 0 = ACT_GET; 1 = ACT_SET; */
|
||
|
MrvlIEtypes_AutoTx_t auto_tx; /**< Auto Tx */
|
||
|
} __ATTRIB_PACK__ HostCmd_DS_802_11_AUTO_TX;
|
||
|
|
||
|
/** Host Command ID : 802.11 auto Tx */
|
||
|
#define HostCmd_CMD_802_11_AUTO_TX 0x0082
|
||
|
|
||
|
/** TLV type : Auto Tx */
|
||
|
#define TLV_TYPE_AUTO_TX (PROPRIETARY_TLV_BASE_ID + 0x18) /* 0x0118 */
|
||
|
|
||
|
/** HostCmd_DS_802_11_CFG_DATA */
|
||
|
typedef struct MAPP_HostCmd_DS_802_11_CFG_DATA {
|
||
|
/** Action */
|
||
|
t_u16 action;
|
||
|
/** Type */
|
||
|
t_u16 type;
|
||
|
/** Data length */
|
||
|
t_u16 data_len;
|
||
|
/** Data */
|
||
|
t_u8 data[1];
|
||
|
} __ATTRIB_PACK__ HostCmd_DS_802_11_CFG_DATA;
|
||
|
|
||
|
/** Host Command ID : Configuration data */
|
||
|
#define HostCmd_CMD_CFG_DATA 0x008f
|
||
|
|
||
|
/** mlan_ioctl_11h_tpc_resp */
|
||
|
typedef struct {
|
||
|
int status_code;
|
||
|
/**< Firmware command result status code */
|
||
|
int tx_power;/**< Reported TX Power from the TPC Report */
|
||
|
int link_margin;
|
||
|
/**< Reported Link margin from the TPC Report */
|
||
|
int rssi; /**< RSSI of the received TPC Report frame */
|
||
|
} __ATTRIB_PACK__ mlan_ioctl_11h_tpc_resp;
|
||
|
|
||
|
/** Host Command ID : 802.11 TPC adapt req */
|
||
|
#define HostCmd_CMD_802_11_TPC_ADAPT_REQ 0x0060
|
||
|
|
||
|
/** HostCmd_DS_802_11_CRYPTO */
|
||
|
typedef struct MAPP_HostCmd_DS_802_11_CRYPTO {
|
||
|
t_u16 encdec; /**< Decrypt=0, Encrypt=1 */
|
||
|
t_u16 algorithm; /**< RC4=1 AES=2 , AES_KEY_WRAP=3 */
|
||
|
t_u16 key_IV_length;/**< Length of Key IV (bytes) */
|
||
|
t_u8 keyIV[32]; /**< Key IV */
|
||
|
t_u16 key_length; /**< Length of Key (bytes) */
|
||
|
t_u8 key[32]; /**< Key */
|
||
|
MrvlIEtypes_Data_t data;
|
||
|
/**< Plain text if encdec=Encrypt, Ciphertext data if encdec=Decrypt*/
|
||
|
} __ATTRIB_PACK__ HostCmd_DS_802_11_CRYPTO;
|
||
|
|
||
|
/** HostCmd_DS_802_11_CRYPTO_AES_CCM */
|
||
|
typedef struct MAPP_HostCmd_DS_802_11_CRYPTO_AES_CCM {
|
||
|
t_u16 encdec; /**< Decrypt=0, Encrypt=1 */
|
||
|
t_u16 algorithm; /**< AES_CCM=4 */
|
||
|
t_u16 key_length; /**< Length of Key (bytes) */
|
||
|
t_u8 key[32]; /**< Key */
|
||
|
t_u16 nonce_length;/**< Length of Nonce (bytes) */
|
||
|
t_u8 nonce[14]; /**< Nonce */
|
||
|
t_u16 AAD_length; /**< Length of AAD (bytes) */
|
||
|
t_u8 AAD[32]; /**< AAD */
|
||
|
MrvlIEtypes_Data_t data;
|
||
|
/**< Plain text if encdec=Encrypt, Ciphertext data if encdec=Decrypt*/
|
||
|
} __ATTRIB_PACK__ HostCmd_DS_802_11_CRYPTO_AES_CCM;
|
||
|
|
||
|
/** HostCmd_DS_802_11_CRYPTO_WAPI */
|
||
|
typedef struct MAPP_HostCmd_DS_802_11_CRYPTO_WAPI {
|
||
|
t_u16 encdec; /**< Decrypt=0, Encrypt=1 */
|
||
|
t_u16 algorithm; /**< WAPI =5 */
|
||
|
t_u16 key_length; /**< Length of Key (bytes) */
|
||
|
t_u8 key[32]; /**< Key */
|
||
|
t_u16 nonce_length;/**< Length of Nonce (bytes) */
|
||
|
t_u8 nonce[16]; /**< Nonce */
|
||
|
t_u16 AAD_length; /**< Length of AAD (bytes) */
|
||
|
t_u8 AAD[48]; /**< AAD */
|
||
|
t_u16 data_length; /**< Length of data (bytes) */
|
||
|
} __ATTRIB_PACK__ HostCmd_DS_802_11_CRYPTO_WAPI;
|
||
|
|
||
|
/** WAPI cipher test */
|
||
|
#define CIPHER_TEST_WAPI (5)
|
||
|
/** AES CCM cipher test */
|
||
|
#define CIPHER_TEST_AES_CCM (4)
|
||
|
/** GCMP cipher test */
|
||
|
#define CIPHER_TEST_GCMP (6)
|
||
|
/** Host Command ID : 802.11 crypto */
|
||
|
#define HostCmd_CMD_802_11_CRYPTO 0x0078
|
||
|
/** Get the current TSF */
|
||
|
#define HostCmd_CMD_GET_TSF 0x0080
|
||
|
|
||
|
/** Read/Write Mac register */
|
||
|
#define HostCmd_CMD_MAC_REG_ACCESS 0x0019
|
||
|
/** Read/Write BBP register */
|
||
|
#define HostCmd_CMD_BBP_REG_ACCESS 0x001a
|
||
|
/** Read/Write RF register */
|
||
|
#define HostCmd_CMD_RF_REG_ACCESS 0x001b
|
||
|
|
||
|
/** Host Command ID : CAU register access */
|
||
|
#define HostCmd_CMD_CAU_REG_ACCESS 0x00ed
|
||
|
|
||
|
/** Host Command ID : Memory access */
|
||
|
#define HostCmd_CMD_MEM_ACCESS 0x0086
|
||
|
|
||
|
/** channel band */
|
||
|
enum {
|
||
|
BAND_2GHZ = 0,
|
||
|
BAND_5GHZ = 1,
|
||
|
BAND_4GHZ = 2,
|
||
|
};
|
||
|
|
||
|
/** channel offset */
|
||
|
enum {
|
||
|
SEC_CHAN_NONE = 0,
|
||
|
SEC_CHAN_ABOVE = 1,
|
||
|
SEC_CHAN_5MHZ = 2,
|
||
|
SEC_CHAN_BELOW = 3
|
||
|
};
|
||
|
|
||
|
/** channel bandwidth */
|
||
|
enum {
|
||
|
CHAN_BW_20MHZ = 0,
|
||
|
CHAN_BW_10MHZ,
|
||
|
CHAN_BW_40MHZ,
|
||
|
CHAN_BW_80MHZ,
|
||
|
};
|
||
|
|
||
|
/** scan mode */
|
||
|
enum {
|
||
|
SCAN_MODE_MANUAL = 0,
|
||
|
SCAN_MODE_ACS,
|
||
|
SCAN_MODE_USER,
|
||
|
};
|
||
|
|
||
|
/** Band_Config_t */
|
||
|
typedef 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 */
|
||
|
t_u8 chanBand:2;
|
||
|
/** Channel Width - (00)=20MHz, (10)=40MHz, (11)=80MHz */
|
||
|
t_u8 chanWidth:2;
|
||
|
/** Secondary Channel Offset - (00)=None, (01)=Above, (11)=Below */
|
||
|
t_u8 chan2Offset:2;
|
||
|
/** Channel Selection Mode - (00)=manual, (01)=ACS, (02)=Adoption mode*/
|
||
|
t_u8 scanMode:2;
|
||
|
#endif
|
||
|
} __ATTRIB_PACK__ Band_Config_t;
|
||
|
|
||
|
/** Failure */
|
||
|
#define MLAN_EVENT_FAILURE -1
|
||
|
|
||
|
/** Netlink protocol number */
|
||
|
#define NETLINK_MARVELL (MAX_LINKS - 1)
|
||
|
/** Netlink maximum payload size */
|
||
|
#define NL_MAX_PAYLOAD 1024
|
||
|
/** Netlink multicast group number */
|
||
|
#define NL_MULTICAST_GROUP 1
|
||
|
/** Default wait time in seconds for events */
|
||
|
#define UAP_RECV_WAIT_DEFAULT 10
|
||
|
/** Maximum number of devices */
|
||
|
#define MAX_NO_OF_DEVICES 4
|
||
|
|
||
|
/* Event buffer */
|
||
|
typedef struct _evt_buf {
|
||
|
/** Flag to check if event data is present in the buffer or not */
|
||
|
int flag;
|
||
|
/** Event length */
|
||
|
int length;
|
||
|
/** Event data */
|
||
|
t_u8 buffer[NL_MAX_PAYLOAD];
|
||
|
} __ATTRIB_PACK__ evt_buf;
|
||
|
|
||
|
/** Event header */
|
||
|
typedef struct _event_header {
|
||
|
/** Event ID */
|
||
|
t_u32 event_id;
|
||
|
/** Event data */
|
||
|
t_u8 event_data[0];
|
||
|
} __ATTRIB_PACK__ event_header;
|
||
|
|
||
|
/** Event ID length */
|
||
|
#define EVENT_ID_LEN 4
|
||
|
|
||
|
/** Event definition: Radar Detected by card */
|
||
|
#define EVENT_CHANNEL_REPORT_RDY 0x00000054
|
||
|
|
||
|
/** Host Command ID : Channel report request */
|
||
|
#define HostCmd_CMD_CHAN_REPORT_REQUEST 0x00dd
|
||
|
/** TLV type : Chan Load */
|
||
|
#define TLV_TYPE_CHANRPT_CHAN_LOAD (PROPRIETARY_TLV_BASE_ID + 0x59) /* 0x0159 */
|
||
|
/** TLV type : Noise Historgram */
|
||
|
#define TLV_TYPE_CHANRPT_NOISE_HIST (PROPRIETARY_TLV_BASE_ID + 0x5a) /* 0x015a */
|
||
|
|
||
|
typedef struct {
|
||
|
t_u16 startFreq;
|
||
|
t_u8 chanWidth;
|
||
|
t_u8 chanNum;
|
||
|
|
||
|
} __ATTRIB_PACK__ MrvlChannelDesc_t;
|
||
|
|
||
|
typedef struct {
|
||
|
MrvlChannelDesc_t chanDesc;
|
||
|
/**< Channel band, number */
|
||
|
t_u32 millisecDwellTime; /**< Channel dwell time in milliseconds */
|
||
|
} __ATTRIB_PACK__ HostCmd_DS_CHAN_RPT_REQ;
|
||
|
|
||
|
typedef struct {
|
||
|
|
||
|
t_u32 commandResult;
|
||
|
/**< Rpt request command result (0 == SUCCESS) */
|
||
|
t_u64 startTsf; /**< TSF Measurement started */
|
||
|
t_u32 duration; /**< Duration of measurement in microsecs */
|
||
|
|
||
|
t_u8 tlvBuffer[1];
|
||
|
/**< TLV Buffer */
|
||
|
} __ATTRIB_PACK__ HostCmd_DS_CHAN_RPT_RSP;
|
||
|
|
||
|
typedef struct {
|
||
|
MrvlIEtypesHeader_t Header; /**< Header */
|
||
|
|
||
|
t_u8 ccaBusyFraction; /**< Parts per 255 channel was busy */
|
||
|
} __ATTRIB_PACK__ MrvlIEtypes_ChanRptChanLoad_t;
|
||
|
|
||
|
typedef struct {
|
||
|
MrvlIEtypesHeader_t header; /**< Header */
|
||
|
|
||
|
t_s16 anpi; /**< ANPI calculated from the histogram */
|
||
|
/** RPI histogram bins. The number of bins utilized is variable and must
|
||
|
be calculated by the header length */
|
||
|
t_u8 rpiDensities[11];
|
||
|
} __ATTRIB_PACK__ MrvlIEtypes_ChanRptNoiseHist_t;
|
||
|
|
||
|
/** Maximum length of lines in configuration file */
|
||
|
#define MAX_CONFIG_LINE 1024
|
||
|
/** MAC BROADCAST */
|
||
|
#define MAC_BROADCAST 0x1FF
|
||
|
/** MAC MULTICAST */
|
||
|
#define MAC_MULTICAST 0x1FE
|
||
|
|
||
|
/** HostCmd_DS_REG */
|
||
|
typedef struct MAPP_HostCmd_DS_REG {
|
||
|
/** Read or write */
|
||
|
t_u16 action;
|
||
|
/** Register offset */
|
||
|
t_u16 offset;
|
||
|
/** Value */
|
||
|
t_u32 value;
|
||
|
} __ATTRIB_PACK__ HostCmd_DS_REG;
|
||
|
|
||
|
/** HostCmd_DS_MEM */
|
||
|
typedef struct MAPP_HostCmd_DS_MEM {
|
||
|
/** Read or write */
|
||
|
t_u16 action;
|
||
|
/** Reserved */
|
||
|
t_u16 reserved;
|
||
|
/** Address */
|
||
|
t_u32 addr;
|
||
|
/** Value */
|
||
|
t_u32 value;
|
||
|
} __ATTRIB_PACK__ HostCmd_DS_MEM;
|
||
|
|
||
|
typedef struct _HostCmd_DS_MEF_CFG {
|
||
|
/** Criteria */
|
||
|
t_u32 Criteria;
|
||
|
/** Number of entries */
|
||
|
t_u16 NumEntries;
|
||
|
} __ATTRIB_PACK__ HostCmd_DS_MEF_CFG;
|
||
|
|
||
|
typedef struct _MEF_CFG_DATA {
|
||
|
/** Size */
|
||
|
t_u16 size;
|
||
|
/** Data */
|
||
|
HostCmd_DS_MEF_CFG data;
|
||
|
} __ATTRIB_PACK__ MEF_CFG_DATA;
|
||
|
|
||
|
/** HostCmd_DS_GEN */
|
||
|
typedef struct MAPP_HostCmd_DS_GEN {
|
||
|
/** Command */
|
||
|
t_u16 command;
|
||
|
/** Size */
|
||
|
t_u16 size;
|
||
|
/** Sequence number */
|
||
|
t_u16 seq_num;
|
||
|
/** Result */
|
||
|
t_u16 result;
|
||
|
} __ATTRIB_PACK__ HostCmd_DS_GEN;
|
||
|
|
||
|
/** Size of HostCmd_DS_GEN */
|
||
|
#define S_DS_GEN sizeof(HostCmd_DS_GEN)
|
||
|
|
||
|
/** pkt_header */
|
||
|
typedef struct _pkt_header {
|
||
|
/** pkt_len */
|
||
|
t_u32 pkt_len;
|
||
|
/** pkt_type */
|
||
|
t_u32 TxPktType;
|
||
|
/** tx control */
|
||
|
t_u32 TxControl;
|
||
|
} pkt_header;
|
||
|
|
||
|
/** eth_priv_802_11_header packet from FW with length */
|
||
|
typedef struct _eth_priv_mgmt_frame_tx {
|
||
|
/** Packet Length */
|
||
|
t_u16 frm_len;
|
||
|
/** Frame Control */
|
||
|
t_u16 frm_ctl;
|
||
|
/** Duration ID */
|
||
|
t_u16 duration_id;
|
||
|
/** Address1 */
|
||
|
t_u8 addr1[ETH_ALEN];
|
||
|
/** Address2 */
|
||
|
t_u8 addr2[ETH_ALEN];
|
||
|
/** Address3 */
|
||
|
t_u8 addr3[ETH_ALEN];
|
||
|
/** Sequence Control */
|
||
|
t_u16 seq_ctl;
|
||
|
/** Address4 */
|
||
|
t_u8 addr4[ETH_ALEN];
|
||
|
/** Frame payload */
|
||
|
t_u8 payload[0];
|
||
|
} __ATTRIB_PACK__ eth_priv_mgmt_frame_tx;
|
||
|
|
||
|
/** frame tx ioctl number */
|
||
|
#define FRAME_TX_IOCTL (SIOCDEVPRIVATE + 12)
|
||
|
|
||
|
typedef struct {
|
||
|
t_u32 timeSinceLastQuery_ms; /**< Duration of stats collection */
|
||
|
|
||
|
t_u16 bcnCnt; /**< Number of beacons received */
|
||
|
t_u16 bcnMiss; /**< Estimate of beacons missed */
|
||
|
t_s16 bcnRssiAvg; /**< Avg beacon RSSI */
|
||
|
t_s16 bcnSnrAvg; /**< Avg beacon SNR */
|
||
|
|
||
|
t_u32 rxPkts; /**< Number of packets received */
|
||
|
t_s16 rxRssiAvg; /**< Avg received packet RSSI */
|
||
|
t_s16 rxSnrAvg; /**< Avg received packet SNR */
|
||
|
|
||
|
t_u32 txPkts; /**< Number of packets transmitted */
|
||
|
t_u32 txAttempts; /**< Number of attempts made */
|
||
|
t_u32 txFailures; /**< Number of pkts that failed */
|
||
|
t_u8 txInitRate; /**< Current rate adaptation TX rateid */
|
||
|
t_u8 reserved[3]; /**< Reserved */
|
||
|
|
||
|
t_u16 txQueuePktCnt[MAX_AC_QUEUES];
|
||
|
/**< Number of packets per AC */
|
||
|
t_u32 txQueueDelay[MAX_AC_QUEUES];
|
||
|
/**< Averge queue delay per AC*/
|
||
|
} __ATTRIB_PACK__ HostCmd_DS_LINK_STATS_SUMMARY;
|
||
|
|
||
|
#define HostCmd_CMD_LINK_STATS_SUMMARY 0x00d3
|
||
|
|
||
|
/** Type enumeration of WMM AC_QUEUES */
|
||
|
typedef enum _wmm_ac {
|
||
|
AC_BE,
|
||
|
AC_BK,
|
||
|
AC_VI,
|
||
|
AC_VO,
|
||
|
} wmm_ac;
|
||
|
|
||
|
/** Data structure of Host command WMM_PARAM_CFG */
|
||
|
typedef struct _HostCmd_DS_WMM_PARAM_CONFIG {
|
||
|
/** action */
|
||
|
t_u16 action;
|
||
|
/** AC Parameters Record WMM_AC_BE, WMM_AC_BK, WMM_AC_VI, WMM_AC_VO */
|
||
|
IEEEtypes_WmmAcParameters_t ac_params[MAX_AC_QUEUES];
|
||
|
} __ATTRIB_PACK__ HostCmd_DS_WMM_PARAM_CONFIG;
|
||
|
|
||
|
/** Host Command ID : Configure ADHOC_OVER_IP parameters */
|
||
|
#define HostCmd_CMD_WMM_PARAM_CONFIG 0x023a
|
||
|
|
||
|
/** TLV ID for multi chan info */
|
||
|
#define MULTI_CHAN_INFO_TLV_ID (PROPRIETARY_TLV_BASE_ID + 0xb7)
|
||
|
/** TLV ID for multi chan group info */
|
||
|
#define MULTI_CHAN_GROUP_INFO_TLV_ID (PROPRIETARY_TLV_BASE_ID + 0xb8)
|
||
|
/** BSS number mask */
|
||
|
#define BSS_NUM_MASK 0xf
|
||
|
|
||
|
typedef struct _eth_priv_multi_chan_cfg {
|
||
|
/** Channel Time in us*/
|
||
|
t_u32 channel_time;
|
||
|
/** Buffer Weight */
|
||
|
t_u8 buffer_weight;
|
||
|
/** tlv len */
|
||
|
t_u16 tlv_len;
|
||
|
/** TLV Buffer */
|
||
|
t_u8 tlv_buf[0];
|
||
|
} __ATTRIB_PACK__ eth_priv_multi_chan_cfg;
|
||
|
|
||
|
typedef struct _eth_priv_drcs_cfg {
|
||
|
/** Channel Index*/
|
||
|
t_u16 chan_idx;
|
||
|
/** Channel time (in TU) for chan_idx*/
|
||
|
t_u8 chantime;
|
||
|
/** Channel swith time (in TU) for chan_idx*/
|
||
|
t_u8 switchtime;
|
||
|
/** Undoze time (in TU) for chan_idx*/
|
||
|
t_u8 undozetime;
|
||
|
/** Rx traffic control scheme when channel switch*/
|
||
|
/** only valid for GC/STA interface*/
|
||
|
t_u8 mode;
|
||
|
} __ATTRIB_PACK__ eth_priv_drcs_cfg;
|
||
|
|
||
|
typedef struct _ChannelBandInfo {
|
||
|
Band_Config_t bandcfg;
|
||
|
t_u8 chan_num;
|
||
|
} __ATTRIB_PACK__ ChannelBandInfo;
|
||
|
|
||
|
typedef struct _MrvlIETypes_multi_chan_group_info_t {
|
||
|
/** Header */
|
||
|
MrvlIEtypesHeader_t header;
|
||
|
t_u8 chan_group_id;
|
||
|
t_u8 chan_buff_weight;
|
||
|
ChannelBandInfo chan_band_info;
|
||
|
t_u32 channel_time;
|
||
|
t_u32 reserved;
|
||
|
union {
|
||
|
t_u8 sdio_func_num;
|
||
|
t_u8 usb_epnum;
|
||
|
} __ATTRIB_PACK__ hid_num;
|
||
|
t_u8 num_intf;
|
||
|
t_u8 bss_type_numlist[0];
|
||
|
} __ATTRIB_PACK__ MrvlIEtypes_multi_chan_group_info_t;
|
||
|
|
||
|
typedef struct _MrvlIETypes_multi_chan_info_t {
|
||
|
/** Header */
|
||
|
MrvlIEtypesHeader_t header;
|
||
|
/** multi channel operation status */
|
||
|
t_u16 status;
|
||
|
/** Tlv buffer */
|
||
|
t_u8 tlv_buffer[0];
|
||
|
} __ATTRIB_PACK__ MrvlIEtypes_multi_chan_info_t;
|
||
|
|
||
|
#ifdef WIFI_DIRECT_SUPPORT
|
||
|
/** flag for NOA */
|
||
|
#define WIFI_DIRECT_NOA 1
|
||
|
/** flag for OPP_PS */
|
||
|
#define WIFI_DIRECT_OPP_PS 2
|
||
|
/** Type definition of mlan_ds_wifi_direct_config for MLAN_OID_MISC_WIFI_DIRECT_CONFIG */
|
||
|
typedef struct _mlan_ds_wifi_direct_config {
|
||
|
/** flags for NOA/OPP_PS */
|
||
|
t_u8 flags;
|
||
|
/** NoA enable/disable */
|
||
|
t_u8 noa_enable;
|
||
|
/** index */
|
||
|
t_u16 index;
|
||
|
/** NoA count */
|
||
|
t_u8 noa_count;
|
||
|
/** NoA duration */
|
||
|
t_u32 noa_duration;
|
||
|
/** NoA interval */
|
||
|
t_u32 noa_interval;
|
||
|
/** opp ps enable/disable */
|
||
|
t_u8 opp_ps_enable;
|
||
|
/** CT window value */
|
||
|
t_u8 ct_window;
|
||
|
} mlan_ds_wifi_direct_config;
|
||
|
#endif
|
||
|
|
||
|
/** DFS repeater mode configuration */
|
||
|
typedef struct _dfs_repeater {
|
||
|
/** Enable DFS repeater mode */
|
||
|
t_u16 action;
|
||
|
/** 1 on and 0 off */
|
||
|
t_u16 mode;
|
||
|
} dfs_repeater;
|
||
|
|
||
|
#ifdef RX_PACKET_COALESCE
|
||
|
/** RX packet coalesce tlv */
|
||
|
typedef struct _tlvbuf_rx_pkt_coal_t {
|
||
|
/** threshold for rx packets */
|
||
|
t_u32 rx_pkt_count;
|
||
|
/** timeout for rx coalescing timer */
|
||
|
t_u16 delay;
|
||
|
} tlvbuf_rx_pkt_coal_t;
|
||
|
#endif
|
||
|
|
||
|
/** Maximum SSID length */
|
||
|
#define MAX_SSID_LENGTH 32
|
||
|
/** Maximum SSID length */
|
||
|
#define MIN_SSID_LENGTH 1
|
||
|
/** Maximum WPA passphrase length */
|
||
|
#define MAX_WPA_PASSPHRASE_LENGTH 64
|
||
|
/** Minimum WPA passphrase length */
|
||
|
#define MIN_WPA_PASSPHRASE_LENGTH 8
|
||
|
|
||
|
#define TLV_TYPE_PER_PKT_CFG 0x0001
|
||
|
#define MAX_NUM_ETHER_TYPE 8
|
||
|
#define MAX_TXRX_CTRL 3
|
||
|
#define TX_PKT_CTRL MBIT(0)
|
||
|
#define RX_PKT_INFO MBIT(1)
|
||
|
/** PER_PKT_CFG_TLV for per-packet configuration */
|
||
|
typedef struct _MrvlIEtypes_per_pkt_cfg_t {
|
||
|
/** Header */
|
||
|
MrvlIEtypesHeader_t header;
|
||
|
/** Tx/Rx per-packet control */
|
||
|
t_u8 tx_rx_control;
|
||
|
/** Number of ethernet types in ether_type array */
|
||
|
t_u8 proto_type_num;
|
||
|
/** Array of ether_type for per-packet control */
|
||
|
t_u16 ether_type[0];
|
||
|
} MrvlIEtypes_per_pkt_cfg_t;
|
||
|
|
||
|
#define FLAG_TX_HISTOGRAM 0x01
|
||
|
#define FLAG_RX_HISTOGRAM 0x02
|
||
|
#define DISABLE_TX_RX_HISTOGRAM 0x00
|
||
|
#define ENABLE_TX_RX_HISTOGRAM 0x01
|
||
|
#define GET_TX_RX_HISTOGRAM 0x02
|
||
|
/** TX histogram statistic parameters*/
|
||
|
typedef struct _tx_pkt_rate_info {
|
||
|
/** tx packet counter of MCS0~MCS15 */
|
||
|
t_u32 htmcs_txcnt[16];
|
||
|
/** tx packet's short GI counter of MCS0~MCS15 */
|
||
|
t_u32 htsgi_txcnt[16];
|
||
|
/** tx STBC packet counter of MCS0~MCS15 */
|
||
|
t_u32 htstbcrate_txcnt[16];
|
||
|
/** tx packet counter of MCS0~MCS9 */
|
||
|
t_u32 vhtmcs_txcnt[10];
|
||
|
/** tx packet's short GI counter of MCS0~MCS9 */
|
||
|
t_u32 vhtsgi_txcnt[10];
|
||
|
/** tx STBC packet counter of MCS0~MCS9 */
|
||
|
t_u32 vhtstbcrate_txcnt[10];
|
||
|
/** tx packet counter of every NSS, NSS=1,2 */
|
||
|
t_u32 nss_txcnt[2];
|
||
|
/** tx packet counter of every bandwith */
|
||
|
t_u32 bandwidth_txcnt[3];
|
||
|
/** different preamble tx packet counter */
|
||
|
t_u32 preamble_txcnt[4];
|
||
|
/** tx packet counter of using LDPC coding */
|
||
|
t_u32 ldpc_txcnt;
|
||
|
/** transmitted RTS counter */
|
||
|
t_u32 rts_txcnt;
|
||
|
/** RSSI of ack */
|
||
|
t_s32 ack_RSSI;
|
||
|
} tx_pkt_rate_info;
|
||
|
/** RX histogram statistic parameters*/
|
||
|
typedef struct _rx_pkt_rate_info {
|
||
|
/** Rx packet counter of MCS0~MCS15 */
|
||
|
t_u32 htmcs_rxcnt[16];
|
||
|
/** Rx packet's short GI counter of MCS0~MCS15 */
|
||
|
t_u32 htsgi_rxcnt[16];
|
||
|
/** Rx STBC packet counter of MCS0~MCS15 */
|
||
|
t_u32 htstbcrate_rxcnt[16];
|
||
|
/** Rx packet counter of MCS0~MCS9 */
|
||
|
t_u32 vhtmcs_rxcnt[10];
|
||
|
/** Rx packet's short GI counter of MCS0~MCS9 */
|
||
|
t_u32 vhtsgi_rxcnt[10];
|
||
|
/** Rx STBC packet counter of MCS0~MCS9 */
|
||
|
t_u32 vhtstbcrate_rxcnt[10];
|
||
|
/** Rx packet counter of every NSS, NSS=1,2 */
|
||
|
t_u32 nss_rxcnt[2];
|
||
|
/** Received packet counter which using STBC */
|
||
|
t_u32 nsts_rxcnt;
|
||
|
/** Rx packet counter of every bandwith */
|
||
|
t_u32 bandwidth_rxcnt[3];
|
||
|
/** Different preamble Rx packet counter */
|
||
|
t_u32 preamble_rxcnt[6];
|
||
|
/** VHT SIGA2 LDPC bit*/
|
||
|
t_u32 ldpc_txbfcnt[2];
|
||
|
/** Average RSSI */
|
||
|
t_s32 rssi_value[2];
|
||
|
/** RSSI value of path A */
|
||
|
t_s32 rssi_chain0[4];
|
||
|
/** RSSI value of path B */
|
||
|
t_s32 rssi_chain1[4];
|
||
|
} rx_pkt_rate_info;
|
||
|
/** TX and RX histogram statistic parameters*/
|
||
|
typedef struct _tx_rx_histogram {
|
||
|
/** Enable or disable get tx/rx histogram statistic */
|
||
|
t_u8 enable;
|
||
|
/** Choose to get TX, RX or both histogram statistic */
|
||
|
t_u8 action;
|
||
|
} __ATTRIB_PACK__ tx_rx_histogram;
|
||
|
|
||
|
#define ETH_P_WSMP 0x88dc
|
||
|
#define BUF_SIZ 1024
|
||
|
typedef struct {
|
||
|
t_u8 version;
|
||
|
t_u8 sec_type;
|
||
|
t_u8 chan;
|
||
|
t_u8 rate;
|
||
|
t_u8 tx_pow;
|
||
|
t_u8 app_class;
|
||
|
t_u8 acm_len;
|
||
|
t_u16 len;
|
||
|
} __ATTRIB_PACK__ wsmp_header;
|
||
|
|
||
|
typedef struct {
|
||
|
t_u16 rx_datarate; //Data rate
|
||
|
t_u8 rx_channel; //Channel number
|
||
|
t_u8 rx_antenna; //received antenna
|
||
|
t_s8 rx_RSSI; //RSSI info
|
||
|
t_u8 reserved[3]; //Reserved fields
|
||
|
} __ATTRIB_PACK__ dot11_rxcontrol;
|
||
|
|
||
|
typedef struct {
|
||
|
t_u16 tx_datarate; //Data rate in unit of 0.5Mbps
|
||
|
t_u8 tx_channel; //Channel number to transmit the frame
|
||
|
t_u8 tx_Bw; //Bandwidth to transmit the frame
|
||
|
t_u8 tx_power; //Power to be used for transmission
|
||
|
t_u8 pkt_priority; //Priority of the packet to be transmitted
|
||
|
t_u8 retry_limit; //tx retry limit
|
||
|
t_u8 reserved[1]; //Reserved fields
|
||
|
} __ATTRIB_PACK__ dot11_txcontrol;
|
||
|
|
||
|
/* CW_MODE_CTRL structure*/
|
||
|
typedef struct {
|
||
|
t_u8 mode;
|
||
|
t_u8 channel;
|
||
|
t_u8 chanInfo;
|
||
|
t_u16 txPower;
|
||
|
t_u16 pktLength;
|
||
|
t_u32 rateInfo;
|
||
|
} __ATTRIB_PACK__ cw_mode_ctrl;
|
||
|
|
||
|
#define TX_AMPDU_RTS_CTS 0
|
||
|
#define TX_AMPDU_CTS_2_SELF 1
|
||
|
#define TX_AMPDU_DISABLE_PROTECTION 2
|
||
|
/** tx_ampdu_prot_mode parameters */
|
||
|
typedef struct _tx_ampdu_prot_mode_para {
|
||
|
/** set prot mode */
|
||
|
int mode;
|
||
|
} tx_ampdu_prot_mode_para;
|
||
|
|
||
|
/** channel statictics */
|
||
|
typedef struct _ChStat_t {
|
||
|
/** channle number */
|
||
|
t_u8 chan_num;
|
||
|
/** total network */
|
||
|
t_u16 total_networks;
|
||
|
/** busy duration */
|
||
|
t_u16 cca_busy_duration;
|
||
|
} ChStat_t, *pChStat_t;
|
||
|
|
||
|
#define MAX_CH_STATS MAX_BG_CHANNEL
|
||
|
/** Type definition of mlan_acs_scan */
|
||
|
typedef struct _acs_result {
|
||
|
/** Best Channel Number */
|
||
|
t_u8 best_ch;
|
||
|
/** Channel Statistics Number */
|
||
|
t_u8 ch_stats_num;
|
||
|
/** Channel Statistics */
|
||
|
ChStat_t ch_stats[0];
|
||
|
} acs_result, *pacs_result;
|
||
|
|
||
|
/** BF Global Configuration */
|
||
|
#define BF_GLOBAL_CONFIGURATION 0x00
|
||
|
/** Performs NDP sounding for PEER specified */
|
||
|
#define TRIGGER_SOUNDING_FOR_PEER 0x01
|
||
|
/** TX BF interval for channel sounding */
|
||
|
#define SET_GET_BF_PERIODICITY 0x02
|
||
|
/** Tell FW not to perform any sounding for peer */
|
||
|
#define TX_BF_FOR_PEER_ENBL 0x03
|
||
|
/** TX BF SNR threshold for peer */
|
||
|
#define SET_SNR_THR_PEER 0x04
|
||
|
/** TX Sounding*/
|
||
|
#define TX_SOUNDING_CFG 0x05
|
||
|
|
||
|
/** bf global cfg args */
|
||
|
typedef struct _bf_global_cfg {
|
||
|
/** Global enable/disable bf */
|
||
|
t_u8 bf_enbl;
|
||
|
/** Global enable/disable sounding */
|
||
|
t_u8 sounding_enbl;
|
||
|
/** FB Type */
|
||
|
t_u8 fb_type;
|
||
|
/** SNR Threshold */
|
||
|
t_u8 snr_threshold;
|
||
|
/** Sounding interval in milliseconds */
|
||
|
t_u16 sounding_interval;
|
||
|
/** BF mode */
|
||
|
t_u8 bf_mode;
|
||
|
/** Reserved */
|
||
|
t_u8 reserved;
|
||
|
} bf_global_cfg;
|
||
|
|
||
|
/** trigger sounding args */
|
||
|
typedef struct _trigger_sound {
|
||
|
/** Peer MAC address */
|
||
|
t_u8 peer_mac[MLAN_MAC_ADDR_LENGTH];
|
||
|
/** Status */
|
||
|
t_u8 status;
|
||
|
} trigger_sound;
|
||
|
|
||
|
/** bf periodicity args */
|
||
|
typedef struct _bf_periodicity_cfg {
|
||
|
/** Peer MAC address */
|
||
|
t_u8 peer_mac[MLAN_MAC_ADDR_LENGTH];
|
||
|
/** Current Tx BF Interval in milliseconds */
|
||
|
t_u16 interval;
|
||
|
/** Status */
|
||
|
t_u8 status;
|
||
|
} bf_periodicity_cfg;
|
||
|
|
||
|
/** tx bf peer args */
|
||
|
typedef struct _tx_bf_peer_cfg {
|
||
|
/** Peer MAC address */
|
||
|
t_u8 peer_mac[MLAN_MAC_ADDR_LENGTH];
|
||
|
/** Reserved */
|
||
|
t_u16 reserved;
|
||
|
/** Enable/Disable Beamforming */
|
||
|
t_u8 bf_enbl;
|
||
|
/** Enable/Disable sounding */
|
||
|
t_u8 sounding_enbl;
|
||
|
/** FB Type */
|
||
|
t_u8 fb_type;
|
||
|
} tx_bf_peer_cfg;
|
||
|
|
||
|
/** SNR threshold args */
|
||
|
typedef struct _snr_thr_cfg {
|
||
|
/** Peer MAC address */
|
||
|
t_u8 peer_mac[MLAN_MAC_ADDR_LENGTH];
|
||
|
/** SNR for peer */
|
||
|
t_u8 snr;
|
||
|
} snr_thr_cfg;
|
||
|
|
||
|
/** tx sounding cfg */
|
||
|
typedef struct _tx_sounding_cfg {
|
||
|
/** enable/disable tx sounding */
|
||
|
t_u8 tx_sounding_enbl;
|
||
|
/** Sounding Type */
|
||
|
t_u8 sounding_type;
|
||
|
/** Sounding interval in milliseconds */
|
||
|
t_u16 sounding_interval;
|
||
|
} tx_sounding_cfg;
|
||
|
|
||
|
/**
|
||
|
* Type definitions for TCLAS element
|
||
|
*/
|
||
|
#define TCLAS_CLASSIFIER_TYPE_4 4
|
||
|
|
||
|
/**
|
||
|
* IEEE TCLAS Classifier Type 4
|
||
|
*
|
||
|
* Type definition for Classifier Type 4 in TCLAS element
|
||
|
*
|
||
|
*/
|
||
|
typedef struct _IEEEtypes_TCLAS_IPv4_t {
|
||
|
/** Version */
|
||
|
t_u8 version;
|
||
|
/** Source IP address */
|
||
|
t_u8 source_ip_addr[4];
|
||
|
/** Dest IP address */
|
||
|
t_u8 dest_ip_addr[4];
|
||
|
/** Source port */
|
||
|
t_u8 source_port[2];
|
||
|
/** Dest port */
|
||
|
t_u8 dest_port[2];
|
||
|
/** DSCP value */
|
||
|
t_u8 dscp;
|
||
|
/** Protocol value */
|
||
|
t_u8 protocol;
|
||
|
/** Reserved */
|
||
|
t_u8 reserved;
|
||
|
} __ATTRIB_PACK__ IEEEtypes_TCLAS_IPv4_t;
|
||
|
|
||
|
/**
|
||
|
* IEEE TCLAS base
|
||
|
*
|
||
|
* Type definition for common parameters for every
|
||
|
* classifier type
|
||
|
*
|
||
|
*/
|
||
|
typedef struct _IEEEtypes_TCLAS_Base_t {
|
||
|
/** Element id */
|
||
|
IEEEtypes_ElementId_e element_id;
|
||
|
/** Element len */
|
||
|
t_u8 element_len;
|
||
|
/** User priority */
|
||
|
t_u8 user_priority;
|
||
|
/** Classifier type */
|
||
|
t_u8 classifier_type;
|
||
|
/** Classifier mask */
|
||
|
t_u8 classifier_mask;
|
||
|
} __ATTRIB_PACK__ IEEEtypes_TCLAS_Base_t;
|
||
|
|
||
|
/**
|
||
|
* IEEE TCLAS element
|
||
|
*
|
||
|
* Type definition for TCLAS element with different
|
||
|
* classifier types
|
||
|
*
|
||
|
*/
|
||
|
typedef struct _IEEEtypes_TCLAS_t {
|
||
|
/** Base structure for TCLAS */
|
||
|
IEEEtypes_TCLAS_Base_t tclas_base;
|
||
|
|
||
|
union {
|
||
|
/** Classifier type 4 */
|
||
|
IEEEtypes_TCLAS_IPv4_t ipv4;
|
||
|
} __ATTRIB_PACK__ classifier;
|
||
|
} __ATTRIB_PACK__ IEEEtypes_TCLAS_t;
|
||
|
|
||
|
/**
|
||
|
* TCLAS element TLV
|
||
|
*
|
||
|
* Structure that defines TLV for TCLAS element with different
|
||
|
* classifier types
|
||
|
*
|
||
|
*/
|
||
|
typedef struct tclasElemen_tlv {
|
||
|
/** Header */
|
||
|
MrvlIEtypesHeader_t header;
|
||
|
/** Tclas Ie */
|
||
|
IEEEtypes_TCLAS_t tclas_ie;
|
||
|
} __ATTRIB_PACK__ tclas_element_tlv_t;
|
||
|
|
||
|
#endif /* _MLANUTL_H_ */
|