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