blob: 94cc09d48444600129620a247c3e227d10865e59 [file] [log] [blame]
Bing Zhao5e6e3a92011-03-21 18:00:50 -07001/*
2 * Marvell Wireless LAN device driver: generic data structures and APIs
3 *
4 * Copyright (C) 2011, Marvell International Ltd.
5 *
6 * This software file (the "File") is distributed by Marvell International
7 * Ltd. under the terms of the GNU General Public License Version 2, June 1991
8 * (the "License"). You may use, redistribute and/or modify this File in
9 * accordance with the terms and conditions of the License, a copy of which
10 * is available by writing to the Free Software Foundation, Inc.,
11 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA or on the
12 * worldwide web at http://www.gnu.org/licenses/old-licenses/gpl-2.0.txt.
13 *
14 * THE FILE IS DISTRIBUTED AS-IS, WITHOUT WARRANTY OF ANY KIND, AND THE
15 * IMPLIED WARRANTIES OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE
16 * ARE EXPRESSLY DISCLAIMED. The License provides additional details about
17 * this warranty disclaimer.
18 */
19
20#ifndef _MWIFIEX_DECL_H_
21#define _MWIFIEX_DECL_H_
22
23#undef pr_fmt
24#define pr_fmt(fmt) KBUILD_MODNAME ": " fmt
25
26#include <linux/wait.h>
27#include <linux/timer.h>
28#include <linux/ieee80211.h>
Avinash Patil54428c52013-01-02 16:56:01 -080029#include <net/mac80211.h>
Bing Zhao5e6e3a92011-03-21 18:00:50 -070030
31
Stone Piao197f4a22012-09-25 20:23:40 -070032#define MWIFIEX_MAX_BSS_NUM (3)
Bing Zhao5e6e3a92011-03-21 18:00:50 -070033
Yogesh Ashok Poware1561032011-07-07 17:37:09 -070034#define MWIFIEX_MIN_DATA_HEADER_LEN 36 /* sizeof(mwifiex_txpd)
35 * + 4 byte alignment
36 */
Stone Piaoe39faa72012-09-25 20:23:32 -070037#define MWIFIEX_MGMT_FRAME_HEADER_SIZE 8 /* sizeof(pkt_type)
38 * + sizeof(tx_control)
39 */
Bing Zhao5e6e3a92011-03-21 18:00:50 -070040
41#define MWIFIEX_MAX_TX_BASTREAM_SUPPORTED 2
42#define MWIFIEX_MAX_RX_BASTREAM_SUPPORTED 16
43
Avinash Patil04abc0a2013-03-27 19:10:31 -070044#define MWIFIEX_STA_AMPDU_DEF_TXWINSIZE 16
45#define MWIFIEX_STA_AMPDU_DEF_RXWINSIZE 32
46#define MWIFIEX_UAP_AMPDU_DEF_TXWINSIZE 32
47#define MWIFIEX_UAP_AMPDU_DEF_RXWINSIZE 16
Avinash Patil2b6254d2013-03-27 19:10:32 -070048#define MWIFIEX_11AC_STA_AMPDU_DEF_TXWINSIZE 32
49#define MWIFIEX_11AC_STA_AMPDU_DEF_RXWINSIZE 48
50#define MWIFIEX_11AC_UAP_AMPDU_DEF_TXWINSIZE 48
51#define MWIFIEX_11AC_UAP_AMPDU_DEF_RXWINSIZE 32
Avinash Patil04abc0a2013-03-27 19:10:31 -070052
Bing Zhao5e6e3a92011-03-21 18:00:50 -070053#define MWIFIEX_DEFAULT_BLOCK_ACK_TIMEOUT 0xffff
54
Bing Zhao5e6e3a92011-03-21 18:00:50 -070055#define MWIFIEX_RATE_BITMAP_MCS0 32
Bing Zhao5e6e3a92011-03-21 18:00:50 -070056
57#define MWIFIEX_RX_DATA_BUF_SIZE (4 * 1024)
Amitkumar Karwar4daffe32012-04-18 20:08:28 -070058#define MWIFIEX_RX_CMD_BUF_SIZE (2 * 1024)
Bing Zhao5e6e3a92011-03-21 18:00:50 -070059
Avinash Patil12190c52012-05-08 18:30:24 -070060#define MAX_BEACON_PERIOD (4000)
61#define MIN_BEACON_PERIOD (50)
62#define MAX_DTIM_PERIOD (100)
63#define MIN_DTIM_PERIOD (1)
64
Bing Zhao5e6e3a92011-03-21 18:00:50 -070065#define MWIFIEX_RTS_MIN_VALUE (0)
66#define MWIFIEX_RTS_MAX_VALUE (2347)
67#define MWIFIEX_FRAG_MIN_VALUE (256)
68#define MWIFIEX_FRAG_MAX_VALUE (2346)
Avinash Patil54428c52013-01-02 16:56:01 -080069#define MWIFIEX_WMM_VERSION 0x01
70#define MWIFIEX_WMM_SUBTYPE 0x01
Bing Zhao5e6e3a92011-03-21 18:00:50 -070071
Avinash Patil9b930ea2012-05-08 18:30:23 -070072#define MWIFIEX_RETRY_LIMIT 14
Bing Zhao5e6e3a92011-03-21 18:00:50 -070073#define MWIFIEX_SDIO_BLOCK_SIZE 256
74
75#define MWIFIEX_BUF_FLAG_REQUEUED_PKT BIT(0)
Avinash Patil838e4f42012-08-03 18:06:08 -070076#define MWIFIEX_BUF_FLAG_BRIDGED_PKT BIT(1)
77
78#define MWIFIEX_BRIDGED_PKTS_THRESHOLD 1024
Bing Zhao5e6e3a92011-03-21 18:00:50 -070079
Bing Zhao5e6e3a92011-03-21 18:00:50 -070080enum mwifiex_bss_type {
81 MWIFIEX_BSS_TYPE_STA = 0,
82 MWIFIEX_BSS_TYPE_UAP = 1,
Stone Piao197f4a22012-09-25 20:23:40 -070083 MWIFIEX_BSS_TYPE_P2P = 2,
Bing Zhao5e6e3a92011-03-21 18:00:50 -070084 MWIFIEX_BSS_TYPE_ANY = 0xff,
85};
86
87enum mwifiex_bss_role {
88 MWIFIEX_BSS_ROLE_STA = 0,
89 MWIFIEX_BSS_ROLE_UAP = 1,
90 MWIFIEX_BSS_ROLE_ANY = 0xff,
91};
92
93#define BSS_ROLE_BIT_MASK BIT(0)
94
95#define GET_BSS_ROLE(priv) ((priv)->bss_role & BSS_ROLE_BIT_MASK)
96
97enum mwifiex_data_frame_type {
98 MWIFIEX_DATA_FRAME_TYPE_ETH_II = 0,
99 MWIFIEX_DATA_FRAME_TYPE_802_11,
100};
101
102struct mwifiex_fw_image {
103 u8 *helper_buf;
104 u32 helper_len;
105 u8 *fw_buf;
106 u32 fw_len;
107};
108
Avinash Patil12190c52012-05-08 18:30:24 -0700109struct mwifiex_802_11_ssid {
110 u32 ssid_len;
111 u8 ssid[IEEE80211_MAX_SSID_LEN];
112};
113
Bing Zhao5e6e3a92011-03-21 18:00:50 -0700114struct mwifiex_wait_queue {
Amitkumar Karwar600f5d92011-04-13 17:27:06 -0700115 wait_queue_head_t wait;
Bing Zhao5e6e3a92011-03-21 18:00:50 -0700116 int status;
Bing Zhao5e6e3a92011-03-21 18:00:50 -0700117};
118
119struct mwifiex_rxinfo {
Yogesh Ashok Powar9da9a3b2012-01-11 20:06:11 -0800120 u8 bss_num;
121 u8 bss_type;
Bing Zhao5e6e3a92011-03-21 18:00:50 -0700122 struct sk_buff *parent;
123 u8 use_count;
124};
125
126struct mwifiex_txinfo {
127 u32 status_code;
128 u8 flags;
Yogesh Ashok Powar9da9a3b2012-01-11 20:06:11 -0800129 u8 bss_num;
130 u8 bss_type;
Bing Zhao5e6e3a92011-03-21 18:00:50 -0700131};
132
Bing Zhao5e6e3a92011-03-21 18:00:50 -0700133enum mwifiex_wmm_ac_e {
134 WMM_AC_BK,
135 WMM_AC_BE,
136 WMM_AC_VI,
137 WMM_AC_VO
138} __packed;
Avinash Patil54428c52013-01-02 16:56:01 -0800139
140struct ieee_types_wmm_ac_parameters {
141 u8 aci_aifsn_bitmap;
142 u8 ecw_bitmap;
143 __le16 tx_op_limit;
144} __packed;
145
146struct mwifiex_types_wmm_info {
147 u8 oui[4];
148 u8 subtype;
149 u8 version;
150 u8 qos_info;
151 u8 reserved;
152 struct ieee_types_wmm_ac_parameters ac_params[IEEE80211_NUM_ACS];
153} __packed;
Bing Zhao5e6e3a92011-03-21 18:00:50 -0700154#endif /* !_MWIFIEX_DECL_H_ */