1 /* SPDX-License-Identifier: GPL-2.0 OR BSD-3-Clause */
2 /* Copyright(c) 2007 - 2012 Realtek Corporation. */
3 
4 /*-----------------------------------------------------------------------------
5 
6 	For type defines and data structure defines
7 
8 ------------------------------------------------------------------------------*/
9 
10 #ifndef __DRV_TYPES_H__
11 #define __DRV_TYPES_H__
12 
13 #define DRV_NAME "r8188eu"
14 
15 #include "osdep_service.h"
16 #include "wlan_bssdef.h"
17 #include "rtw_ht.h"
18 #include "rtw_cmd.h"
19 #include "rtw_xmit.h"
20 #include "rtw_recv.h"
21 #include "hal_intf.h"
22 #include "hal_com.h"
23 #include "rtw_security.h"
24 #include "rtw_pwrctrl.h"
25 #include "rtw_io.h"
26 #include "rtw_eeprom.h"
27 #include "sta_info.h"
28 #include "rtw_mlme.h"
29 #include "rtw_debug.h"
30 #include "rtw_rf.h"
31 #include "rtw_event.h"
32 #include "rtw_led.h"
33 #include "rtw_mlme_ext.h"
34 #include "rtw_p2p.h"
35 #include "rtw_ap.h"
36 #include "rtw_br_ext.h"
37 
38 #define DRIVERVERSION	"v4.1.4_6773.20130222"
39 
40 struct registry_priv {
41 	u8	chip_version;
42 	u8	rfintfs;
43 	u8	lbkmode;
44 	u8	hci;
45 	struct ndis_802_11_ssid	ssid;
46 	u8	network_mode;	/* infra, ad-hoc, auto */
47 	u8	channel;/* ad-hoc support requirement */
48 	u8	wireless_mode;/* A, B, G, auto */
49 	u8	scan_mode;/* active, passive */
50 	u8	radio_enable;
51 	u8	preamble;/* long, short, auto */
52 	u8	vrtl_carrier_sense;/* Enable, Disable, Auto */
53 	u8	vcs_type;/* RTS/CTS, CTS-to-self */
54 	u16	rts_thresh;
55 	u16	frag_thresh;
56 	u8	adhoc_tx_pwr;
57 	u8	soft_ap;
58 	u8	power_mgnt;
59 	u8	ips_mode;
60 	u8	smart_ps;
61 	u8	long_retry_lmt;
62 	u8	short_retry_lmt;
63 	u16	busy_thresh;
64 	u8	ack_policy;
65 	u8	software_encrypt;
66 	u8	software_decrypt;
67 	u8	acm_method;
68 	  /* UAPSD */
69 	u8	wmm_enable;
70 	u8	uapsd_enable;
71 	u8	uapsd_max_sp;
72 	u8	uapsd_acbk_en;
73 	u8	uapsd_acbe_en;
74 	u8	uapsd_acvi_en;
75 	u8	uapsd_acvo_en;
76 
77 	u8	led_enable;
78 
79 	struct wlan_bssid_ex    dev_network;
80 
81 	u8	ht_enable;
82 	u8	cbw40_enable;
83 	u8	ampdu_enable;/* for tx */
84 	u8	rx_stbc;
85 	u8	ampdu_amsdu;/* A-MPDU Supports A-MSDU is permitted */
86 	u8	lowrate_two_xmit;
87 
88 	u8	rf_config;
89 	u8	low_power;
90 
91 	u8	wifi_spec;/*  !turbo_mode */
92 
93 	u8	channel_plan;
94 	bool	bAcceptAddbaReq;
95 
96 	u8	antdiv_cfg;
97 	u8	antdiv_type;
98 
99 	u8	usbss_enable;/* 0:disable,1:enable */
100 	u8	hwpdn_mode;/* 0:disable,1:enable,2:decide by EFUSE config */
101 	u8	hwpwrp_detect;/* 0:disable,1:enable */
102 
103 	u8	hw_wps_pbc;/* 0:disable,1:enable */
104 
105 	u8	max_roaming_times; /*  the max number driver will try */
106 
107 	u8	fw_iol; /* enable iol without other concern */
108 
109 	u8	enable80211d;
110 
111 	u8	ifname[16];
112 	u8	if2name[16];
113 
114 	u8	notch_filter;
115 };
116 
117 /* For registry parameters */
118 #define RGTRY_OFT(field) ((u32)FIELD_OFFSET(struct registry_priv, field))
119 #define RGTRY_SZ(field)   sizeof(((struct registry_priv *)0)->field)
120 #define BSSID_OFT(field) ((u32)FIELD_OFFSET(struct wlan_bssid_ex, field))
121 #define BSSID_SZ(field)   sizeof(((struct wlan_bssid_ex *)0)->field)
122 
123 #define MAX_CONTINUAL_URB_ERR		4
124 
125 struct rt_firmware {
126 	u8			*szFwBuffer;
127 	u32			ulFwLength;
128 };
129 
130 struct dvobj_priv {
131 	struct adapter *if1;
132 	struct adapter *if2;
133 
134 	/* For 92D, DMDP have 2 interface. */
135 	u8	InterfaceNumber;
136 	u8	NumInterfaces;
137 
138 	/* In /Out Pipe information */
139 	int	RtInPipe[2];
140 	int	RtOutPipe[3];
141 	u8	Queue2Pipe[HW_QUEUE_ENTRY];/* for out pipe mapping */
142 
143 	u8	irq_alloc;
144 
145 	struct rt_firmware firmware;
146 
147 /*-------- below is for USB INTERFACE --------*/
148 
149 	u8	nr_endpoint;
150 	u8	ishighspeed;
151 	u8	RtNumInPipes;
152 	u8	RtNumOutPipes;
153 	int	ep_num[5]; /* endpoint number */
154 	int	RegUsbSS;
155 	struct semaphore usb_suspend_sema;
156 	struct mutex  usb_vendor_req_mutex;
157 
158 	struct usb_interface *pusbintf;
159 	struct usb_device *pusbdev;
160 
161 	atomic_t continual_urb_error;
162 	u8 signal_strength;
163 };
164 
dvobj_to_dev(struct dvobj_priv * dvobj)165 static inline struct device *dvobj_to_dev(struct dvobj_priv *dvobj)
166 {
167 	/* todo: get interface type from dvobj and the return
168 	 * the dev accordingly */
169 	return &dvobj->pusbintf->dev;
170 };
171 
172 enum _IFACE_TYPE {
173 	IFACE_PORT0, /* mapping to port0 for C/D series chips */
174 	IFACE_PORT1, /* mapping to port1 for C/D series chip */
175 	MAX_IFACE_PORT,
176 };
177 
178 enum _ADAPTER_TYPE {
179 	PRIMARY_ADAPTER,
180 	SECONDARY_ADAPTER,
181 	MAX_ADAPTER,
182 };
183 
184 enum driver_state {
185 	DRIVER_NORMAL = 0,
186 	DRIVER_DISAPPEAR = 1,
187 	DRIVER_REPLACE_DONGLE = 2,
188 };
189 
190 struct adapter {
191 	int	DriverState;/* for disable driver using module, use dongle toi
192 			     * replace module. */
193 	int	pid[3];/* process id from UI, 0:wps, 1:hostapd, 2:dhcpcd */
194 	int	bDongle;/* build-in module or external dongle */
195 
196 	struct dvobj_priv *dvobj;
197 	struct	mlme_priv mlmepriv;
198 	struct	mlme_ext_priv mlmeextpriv;
199 	struct	cmd_priv	cmdpriv;
200 	struct	evt_priv	evtpriv;
201 	struct	io_priv	iopriv;
202 	struct	xmit_priv	xmitpriv;
203 	struct	recv_priv	recvpriv;
204 	struct	sta_priv	stapriv;
205 	struct	security_priv	securitypriv;
206 	struct	registry_priv	registrypriv;
207 	struct	pwrctrl_priv	pwrctrlpriv;
208 	struct	eeprom_priv eeprompriv;
209 	struct	led_priv	ledpriv;
210 	struct	hostapd_priv	*phostapdpriv;
211 	struct wifidirect_info	wdinfo;
212 
213 	void *HalData;
214 	u32 hal_data_sz;
215 
216 	s32	bDriverStopped;
217 	s32	bSurpriseRemoved;
218 	s32	bCardDisableWOHSM;
219 
220 	u32	IsrContent;
221 	u32	ImrContent;
222 
223 	u8	EepromAddressSize;
224 	u8	hw_init_completed;
225 	u8	bDriverIsGoingToUnload;
226 	u8	init_adpt_in_progress;
227 	u8	bHaltInProgress;
228 	s8	signal_strength;
229 
230 	void *cmdThread;
231 	void *evtThread;
232 	void *xmitThread;
233 	void *recvThread;
234 	void (*intf_start)(struct adapter *adapter);
235 	void (*intf_stop)(struct adapter *adapter);
236 	struct  net_device *pnetdev;
237 
238 	/*  used by rtw_rereg_nd_name related function */
239 	struct rereg_nd_name_data {
240 		struct  net_device *old_pnetdev;
241 		char old_ifname[IFNAMSIZ];
242 		u8 old_ips_mode;
243 		u8 old_bRegUseLed;
244 	} rereg_nd_name_priv;
245 
246 	int bup;
247 	struct net_device_stats stats;
248 	struct iw_statistics iwstats;
249 	struct proc_dir_entry *dir_dev;/*  for proc directory */
250 
251 	int net_closed;
252 	u8 bFWReady;
253 	u8 bBTFWReady;
254 	u8 bReadPortCancel;
255 	u8 bWritePortCancel;
256 	u8 bRxRSSIDisplay;
257 	/* The driver will show up the desired channel number
258 	 * when this flag is 1. */
259 	u8 bNotifyChannelChange;
260 	/* The driver will show the current P2P status when the
261 	 * upper application reads it. */
262 	u8 bShowGetP2PState;
263 	struct adapter *pbuddy_adapter;
264 
265 	struct mutex *hw_init_mutex;
266 
267 	spinlock_t br_ext_lock;
268 	struct nat25_network_db_entry	*nethash[NAT25_HASH_SIZE];
269 	int				pppoe_connection_in_progress;
270 	unsigned char			pppoe_addr[ETH_ALEN];
271 	unsigned char			scdb_mac[ETH_ALEN];
272 	unsigned char			scdb_ip[4];
273 	struct nat25_network_db_entry	*scdb_entry;
274 	unsigned char			br_mac[ETH_ALEN];
275 	unsigned char			br_ip[4];
276 	struct br_ext_info		ethBrExtInfo;
277 
278 	u8	fix_rate;
279 
280 	unsigned char     in_cta_test;
281 };
282 
283 #define adapter_to_dvobj(adapter) (adapter->dvobj)
284 
285 int rtw_handle_dualmac(struct adapter *adapter, bool init);
286 
myid(struct eeprom_priv * peepriv)287 static inline u8 *myid(struct eeprom_priv *peepriv)
288 {
289 	return peepriv->mac_addr;
290 }
291 
292 #endif /* __DRV_TYPES_H__ */
293