1/* SPDX-License-Identifier: GPL-2.0 */
2/*
3 * This header file contains global constant/enum definitions,
4 * global variable declaration.
5 */
6#ifndef _LBS_DEFS_H_
7#define _LBS_DEFS_H_
8
9#include <linux/spinlock.h>
10
11#ifdef CONFIG_LIBERTAS_DEBUG
12#define DEBUG
13#define PROC_DEBUG
14#endif
15
16#ifndef DRV_NAME
17#define DRV_NAME "libertas"
18#endif
19
20
21#define LBS_DEB_ENTER	0x00000001
22#define LBS_DEB_LEAVE	0x00000002
23#define LBS_DEB_MAIN	0x00000004
24#define LBS_DEB_NET	0x00000008
25#define LBS_DEB_MESH	0x00000010
26#define LBS_DEB_WEXT	0x00000020
27#define LBS_DEB_IOCTL	0x00000040
28#define LBS_DEB_SCAN	0x00000080
29#define LBS_DEB_ASSOC	0x00000100
30#define LBS_DEB_JOIN	0x00000200
31#define LBS_DEB_11D	0x00000400
32#define LBS_DEB_DEBUGFS	0x00000800
33#define LBS_DEB_ETHTOOL	0x00001000
34#define LBS_DEB_HOST	0x00002000
35#define LBS_DEB_CMD	0x00004000
36#define LBS_DEB_RX	0x00008000
37#define LBS_DEB_TX	0x00010000
38#define LBS_DEB_USB	0x00020000
39#define LBS_DEB_CS	0x00040000
40#define LBS_DEB_FW	0x00080000
41#define LBS_DEB_THREAD	0x00100000
42#define LBS_DEB_HEX	0x00200000
43#define LBS_DEB_SDIO	0x00400000
44#define LBS_DEB_SYSFS	0x00800000
45#define LBS_DEB_SPI	0x01000000
46#define LBS_DEB_CFG80211 0x02000000
47
48extern unsigned int lbs_debug;
49
50#ifdef DEBUG
51#define LBS_DEB_LL(grp, grpnam, fmt, args...) \
52do { if ((lbs_debug & (grp)) == (grp)) \
53  printk(KERN_DEBUG DRV_NAME grpnam ": " fmt, ## args); } while (0)
54#else
55#define LBS_DEB_LL(grp, grpnam, fmt, args...) do {} while (0)
56#endif
57
58#define lbs_deb_main(fmt, args...)      LBS_DEB_LL(LBS_DEB_MAIN, " main", fmt, ##args)
59#define lbs_deb_net(fmt, args...)       LBS_DEB_LL(LBS_DEB_NET, " net", fmt, ##args)
60#define lbs_deb_mesh(fmt, args...)      LBS_DEB_LL(LBS_DEB_MESH, " mesh", fmt, ##args)
61#define lbs_deb_wext(fmt, args...)      LBS_DEB_LL(LBS_DEB_WEXT, " wext", fmt, ##args)
62#define lbs_deb_ioctl(fmt, args...)     LBS_DEB_LL(LBS_DEB_IOCTL, " ioctl", fmt, ##args)
63#define lbs_deb_scan(fmt, args...)      LBS_DEB_LL(LBS_DEB_SCAN, " scan", fmt, ##args)
64#define lbs_deb_assoc(fmt, args...)     LBS_DEB_LL(LBS_DEB_ASSOC, " assoc", fmt, ##args)
65#define lbs_deb_join(fmt, args...)      LBS_DEB_LL(LBS_DEB_JOIN, " join", fmt, ##args)
66#define lbs_deb_11d(fmt, args...)       LBS_DEB_LL(LBS_DEB_11D, " 11d", fmt, ##args)
67#define lbs_deb_debugfs(fmt, args...)   LBS_DEB_LL(LBS_DEB_DEBUGFS, " debugfs", fmt, ##args)
68#define lbs_deb_ethtool(fmt, args...)   LBS_DEB_LL(LBS_DEB_ETHTOOL, " ethtool", fmt, ##args)
69#define lbs_deb_host(fmt, args...)      LBS_DEB_LL(LBS_DEB_HOST, " host", fmt, ##args)
70#define lbs_deb_cmd(fmt, args...)       LBS_DEB_LL(LBS_DEB_CMD, " cmd", fmt, ##args)
71#define lbs_deb_rx(fmt, args...)        LBS_DEB_LL(LBS_DEB_RX, " rx", fmt, ##args)
72#define lbs_deb_tx(fmt, args...)        LBS_DEB_LL(LBS_DEB_TX, " tx", fmt, ##args)
73#define lbs_deb_fw(fmt, args...)        LBS_DEB_LL(LBS_DEB_FW, " fw", fmt, ##args)
74#define lbs_deb_usb(fmt, args...)       LBS_DEB_LL(LBS_DEB_USB, " usb", fmt, ##args)
75#define lbs_deb_usbd(dev, fmt, args...) LBS_DEB_LL(LBS_DEB_USB, " usbd", "%s:" fmt, dev_name(dev), ##args)
76#define lbs_deb_cs(fmt, args...)        LBS_DEB_LL(LBS_DEB_CS, " cs", fmt, ##args)
77#define lbs_deb_thread(fmt, args...)    LBS_DEB_LL(LBS_DEB_THREAD, " thread", fmt, ##args)
78#define lbs_deb_sdio(fmt, args...)      LBS_DEB_LL(LBS_DEB_SDIO, " sdio", fmt, ##args)
79#define lbs_deb_sysfs(fmt, args...)     LBS_DEB_LL(LBS_DEB_SYSFS, " sysfs", fmt, ##args)
80#define lbs_deb_spi(fmt, args...)       LBS_DEB_LL(LBS_DEB_SPI, " spi", fmt, ##args)
81#define lbs_deb_cfg80211(fmt, args...)  LBS_DEB_LL(LBS_DEB_CFG80211, " cfg80211", fmt, ##args)
82
83#ifdef DEBUG
84static inline void lbs_deb_hex(unsigned int grp, const char *prompt,
85			       const u8 *buf, int len)
86{
87	int i = 0;
88
89	if (len &&
90	    (lbs_debug & LBS_DEB_HEX) &&
91	    (lbs_debug & grp))
92	{
93		for (i = 1; i <= len; i++) {
94			if ((i & 0xf) == 1) {
95				if (i != 1)
96					printk("\n");
97				printk(DRV_NAME " %s: ", prompt);
98			}
99			printk("%02x ", (u8) * buf);
100			buf++;
101		}
102		printk("\n");
103	}
104}
105#else
106#define lbs_deb_hex(grp,prompt,buf,len)	do {} while (0)
107#endif
108
109
110
111/* Buffer Constants */
112
113/*	The size of SQ memory PPA, DPA are 8 DWORDs, that keep the physical
114 *	addresses of TxPD buffers. Station has only 8 TxPD available, Whereas
115 *	driver has more local TxPDs. Each TxPD on the host memory is associated
116 *	with a Tx control node. The driver maintains 8 RxPD descriptors for
117 *	station firmware to store Rx packet information.
118 *
119 *	Current version of MAC has a 32x6 multicast address buffer.
120 *
121 *	802.11b can have up to  14 channels, the driver keeps the
122 *	BSSID(MAC address) of each APs or Ad hoc stations it has sensed.
123 */
124
125#define MRVDRV_MAX_MULTICAST_LIST_SIZE	32
126#define LBS_NUM_CMD_BUFFERS             10
127#define LBS_CMD_BUFFER_SIZE             (2 * 1024)
128#define MRVDRV_MAX_CHANNEL_SIZE		14
129#define MRVDRV_ASSOCIATION_TIME_OUT	255
130#define MRVDRV_SNAP_HEADER_LEN          8
131
132#define	LBS_UPLD_SIZE			2312
133#define DEV_NAME_LEN			32
134
135/* Wake criteria for HOST_SLEEP_CFG command */
136#define EHS_WAKE_ON_BROADCAST_DATA	0x0001
137#define EHS_WAKE_ON_UNICAST_DATA	0x0002
138#define EHS_WAKE_ON_MAC_EVENT		0x0004
139#define EHS_WAKE_ON_MULTICAST_DATA	0x0008
140#define EHS_REMOVE_WAKEUP		0xFFFFFFFF
141/* Wake rules for Host_Sleep_CFG command */
142#define WOL_RULE_NET_TYPE_INFRA_OR_IBSS	0x00
143#define WOL_RULE_NET_TYPE_MESH		0x10
144#define WOL_RULE_ADDR_TYPE_BCAST	0x01
145#define WOL_RULE_ADDR_TYPE_MCAST	0x08
146#define WOL_RULE_ADDR_TYPE_UCAST	0x02
147#define WOL_RULE_OP_AND			0x01
148#define WOL_RULE_OP_OR			0x02
149#define WOL_RULE_OP_INVALID		0xFF
150#define WOL_RESULT_VALID_CMD		0
151#define WOL_RESULT_NOSPC_ERR		1
152#define WOL_RESULT_EEXIST_ERR		2
153
154/* Misc constants */
155/* This section defines 802.11 specific contants */
156
157#define MRVDRV_MAX_BSS_DESCRIPTS		16
158#define MRVDRV_MAX_REGION_CODE			6
159
160#define MRVDRV_DEFAULT_LISTEN_INTERVAL		10
161
162#define	MRVDRV_CHANNELS_PER_SCAN		4
163#define	MRVDRV_MAX_CHANNELS_PER_SCAN		14
164
165#define MRVDRV_MIN_BEACON_INTERVAL		20
166#define MRVDRV_MAX_BEACON_INTERVAL		1000
167#define MRVDRV_BEACON_INTERVAL			100
168
169#define MARVELL_MESH_IE_LENGTH		9
170
171/*
172 * Values used to populate the struct mrvl_mesh_ie.  The only time you need this
173 * is when enabling the mesh using CMD_MESH_CONFIG.
174 */
175#define MARVELL_MESH_IE_TYPE		4
176#define MARVELL_MESH_IE_SUBTYPE		0
177#define MARVELL_MESH_IE_VERSION		0
178#define MARVELL_MESH_PROTO_ID_HWMP	0
179#define MARVELL_MESH_METRIC_ID		0
180#define MARVELL_MESH_CAPABILITY		0
181
182/* INT status Bit Definition */
183#define MRVDRV_TX_DNLD_RDY		0x0001
184#define MRVDRV_RX_UPLD_RDY		0x0002
185#define MRVDRV_CMD_DNLD_RDY		0x0004
186#define MRVDRV_CMD_UPLD_RDY		0x0008
187#define MRVDRV_CARDEVENT		0x0010
188
189/* Automatic TX control default levels */
190#define POW_ADAPT_DEFAULT_P0 13
191#define POW_ADAPT_DEFAULT_P1 15
192#define POW_ADAPT_DEFAULT_P2 18
193#define TPC_DEFAULT_P0 5
194#define TPC_DEFAULT_P1 10
195#define TPC_DEFAULT_P2 13
196
197/* TxPD status */
198
199/*
200 *	Station firmware use TxPD status field to report final Tx transmit
201 *	result, Bit masks are used to present combined situations.
202 */
203
204#define MRVDRV_TxPD_POWER_MGMT_NULL_PACKET 0x01
205#define MRVDRV_TxPD_POWER_MGMT_LAST_PACKET 0x08
206
207/* Tx mesh flag */
208/*
209 * Currently we are using normal WDS flag as mesh flag.
210 * TODO: change to proper mesh flag when MAC understands it.
211 */
212#define TxPD_CONTROL_WDS_FRAME (1<<17)
213#define TxPD_MESH_FRAME TxPD_CONTROL_WDS_FRAME
214
215/* Mesh interface ID */
216#define MESH_IFACE_ID					0x0001
217/* Mesh id should be in bits 14-13-12 */
218#define MESH_IFACE_BIT_OFFSET				0x000c
219/* Mesh enable bit in FW capability */
220#define MESH_CAPINFO_ENABLE_MASK			(1<<16)
221
222/* FW definition from Marvell v4 */
223#define MRVL_FW_V4					(0x04)
224/* FW definition from Marvell v5 */
225#define MRVL_FW_V5					(0x05)
226/* FW definition from Marvell v10 */
227#define MRVL_FW_V10					(0x0a)
228/* FW major revision definition */
229#define MRVL_FW_MAJOR_REV(x)				((x)>>24)
230
231/* RxPD status */
232
233#define MRVDRV_RXPD_STATUS_OK                0x0001
234
235/* RxPD status - Received packet types */
236/* Rx mesh flag */
237/*
238 * Currently we are using normal WDS flag as mesh flag.
239 * TODO: change to proper mesh flag when MAC understands it.
240 */
241#define RxPD_CONTROL_WDS_FRAME (0x40)
242#define RxPD_MESH_FRAME RxPD_CONTROL_WDS_FRAME
243
244/* RSSI-related defines */
245/*
246 *	RSSI constants are used to implement 802.11 RSSI threshold
247 *	indication. if the Rx packet signal got too weak for 5 consecutive
248 *	times, miniport driver (driver) will report this event to wrapper
249 */
250
251#define MRVDRV_NF_DEFAULT_SCAN_VALUE		(-96)
252
253/* RTS/FRAG related defines */
254#define MRVDRV_RTS_MIN_VALUE		0
255#define MRVDRV_RTS_MAX_VALUE		2347
256#define MRVDRV_FRAG_MIN_VALUE		256
257#define MRVDRV_FRAG_MAX_VALUE		2346
258
259/* This is for firmware specific length */
260#define EXTRA_LEN	36
261
262#define MRVDRV_ETH_TX_PACKET_BUFFER_SIZE \
263	(ETH_FRAME_LEN + sizeof(struct txpd) + EXTRA_LEN)
264
265#define MRVDRV_ETH_RX_PACKET_BUFFER_SIZE \
266	(ETH_FRAME_LEN + sizeof(struct rxpd) \
267	 + MRVDRV_SNAP_HEADER_LEN + EXTRA_LEN)
268
269#define	CMD_F_HOSTCMD		(1 << 0)
270#define FW_CAPINFO_WPA  	(1 << 0)
271#define FW_CAPINFO_PS  		(1 << 1)
272#define FW_CAPINFO_FIRMWARE_UPGRADE	(1 << 13)
273#define FW_CAPINFO_BOOT2_UPGRADE	(1<<14)
274#define FW_CAPINFO_PERSISTENT_CONFIG	(1<<15)
275
276#define KEY_LEN_WPA_AES			16
277#define KEY_LEN_WPA_TKIP		32
278#define KEY_LEN_WEP_104			13
279#define KEY_LEN_WEP_40			5
280
281#define RF_ANTENNA_1		0x1
282#define RF_ANTENNA_2		0x2
283#define RF_ANTENNA_AUTO		0xFFFF
284
285#define	BAND_B			(0x01)
286#define	BAND_G			(0x02)
287#define ALL_802_11_BANDS	(BAND_B | BAND_G)
288
289#define MAX_RATES			14
290
291#define	MAX_LEDS			8
292
293/* Global Variable Declaration */
294extern const char lbs_driver_version[];
295extern u16 lbs_region_code_to_index[MRVDRV_MAX_REGION_CODE];
296
297
298/* ENUM definition */
299/* SNRNF_TYPE */
300enum SNRNF_TYPE {
301	TYPE_BEACON = 0,
302	TYPE_RXPD,
303	MAX_TYPE_B
304};
305
306/* SNRNF_DATA */
307enum SNRNF_DATA {
308	TYPE_NOAVG = 0,
309	TYPE_AVG,
310	MAX_TYPE_AVG
311};
312
313/* LBS_802_11_POWER_MODE */
314enum LBS_802_11_POWER_MODE {
315	LBS802_11POWERMODECAM,
316	LBS802_11POWERMODEMAX_PSP,
317	LBS802_11POWERMODEFAST_PSP,
318	/* not a real mode, defined as an upper bound */
319	LBS802_11POWEMODEMAX
320};
321
322/* PS_STATE */
323enum PS_STATE {
324	PS_STATE_FULL_POWER,
325	PS_STATE_AWAKE,
326	PS_STATE_PRE_SLEEP,
327	PS_STATE_SLEEP
328};
329
330/* DNLD_STATE */
331enum DNLD_STATE {
332	DNLD_RES_RECEIVED,
333	DNLD_DATA_SENT,
334	DNLD_CMD_SENT,
335	DNLD_BOOTCMD_SENT,
336};
337
338/* LBS_MEDIA_STATE */
339enum LBS_MEDIA_STATE {
340	LBS_CONNECTED,
341	LBS_DISCONNECTED
342};
343
344/* LBS_802_11_PRIVACY_FILTER */
345enum LBS_802_11_PRIVACY_FILTER {
346	LBS802_11PRIVFILTERACCEPTALL,
347	LBS802_11PRIVFILTER8021XWEP
348};
349
350/* mv_ms_type */
351enum mv_ms_type {
352	MVMS_DAT = 0,
353	MVMS_CMD = 1,
354	MVMS_TXDONE = 2,
355	MVMS_EVENT
356};
357
358/* KEY_TYPE_ID */
359enum KEY_TYPE_ID {
360	KEY_TYPE_ID_WEP = 0,
361	KEY_TYPE_ID_TKIP,
362	KEY_TYPE_ID_AES
363};
364
365/* KEY_INFO_WPA (applies to both TKIP and AES/CCMP) */
366enum KEY_INFO_WPA {
367	KEY_INFO_WPA_MCAST = 0x01,
368	KEY_INFO_WPA_UNICAST = 0x02,
369	KEY_INFO_WPA_ENABLED = 0x04
370};
371
372/* Default values for fwt commands. */
373#define FWT_DEFAULT_METRIC 0
374#define FWT_DEFAULT_DIR 1
375/* Default Rate, 11Mbps */
376#define FWT_DEFAULT_RATE 3
377#define FWT_DEFAULT_SSN 0xffffffff
378#define FWT_DEFAULT_DSN 0
379#define FWT_DEFAULT_HOPCOUNT 0
380#define FWT_DEFAULT_TTL 0
381#define FWT_DEFAULT_EXPIRATION 0
382#define FWT_DEFAULT_SLEEPMODE 0
383#define FWT_DEFAULT_SNR 0
384
385#endif
386