1 /******************************************************************************
2 *
3 * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
4 *
5 * This program is free software; you can redistribute it and/or modify it
6 * under the terms of version 2 of the GNU General Public License as
7 * published by the Free Software Foundation.
8 *
9 * This program is distributed in the hope that it will be useful, but WITHOUT
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
12 * more details.
13 *
14 * You should have received a copy of the GNU General Public License along with
15 * this program; if not, write to the Free Software Foundation, Inc.,
16 * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
17 *
18 *
19 ******************************************************************************/
20 #ifndef _RTW_IOCTL_H_
21 #define _RTW_IOCTL_H_
22
23 #ifndef PLATFORM_WINDOWS
24 /* 00 - Success
25 * 11 - Error */
26 #define STATUS_SUCCESS (0x00000000L)
27 #define STATUS_PENDING (0x00000103L)
28
29 #define STATUS_UNSUCCESSFUL (0xC0000001L)
30 #define STATUS_INSUFFICIENT_RESOURCES (0xC000009AL)
31 #define STATUS_NOT_SUPPORTED (0xC00000BBL)
32
33 #define NDIS_STATUS_SUCCESS ((NDIS_STATUS)STATUS_SUCCESS)
34 #define NDIS_STATUS_PENDING ((NDIS_STATUS)STATUS_PENDING)
35 #define NDIS_STATUS_NOT_RECOGNIZED ((NDIS_STATUS)0x00010001L)
36 #define NDIS_STATUS_NOT_COPIED ((NDIS_STATUS)0x00010002L)
37 #define NDIS_STATUS_NOT_ACCEPTED ((NDIS_STATUS)0x00010003L)
38 #define NDIS_STATUS_CALL_ACTIVE ((NDIS_STATUS)0x00010007L)
39
40 #define NDIS_STATUS_FAILURE ((NDIS_STATUS)STATUS_UNSUCCESSFUL)
41 #define NDIS_STATUS_RESOURCES ((NDIS_STATUS)STATUS_INSUFFICIENT_RESOURCES)
42 #define NDIS_STATUS_CLOSING ((NDIS_STATUS)0xC0010002L)
43 #define NDIS_STATUS_BAD_VERSION ((NDIS_STATUS)0xC0010004L)
44 #define NDIS_STATUS_BAD_CHARACTERISTICS ((NDIS_STATUS)0xC0010005L)
45 #define NDIS_STATUS_ADAPTER_NOT_FOUND ((NDIS_STATUS)0xC0010006L)
46 #define NDIS_STATUS_OPEN_FAILED ((NDIS_STATUS)0xC0010007L)
47 #define NDIS_STATUS_DEVICE_FAILED ((NDIS_STATUS)0xC0010008L)
48 #define NDIS_STATUS_MULTICAST_FULL ((NDIS_STATUS)0xC0010009L)
49 #define NDIS_STATUS_MULTICAST_EXISTS ((NDIS_STATUS)0xC001000AL)
50 #define NDIS_STATUS_MULTICAST_NOT_FOUND ((NDIS_STATUS)0xC001000BL)
51 #define NDIS_STATUS_REQUEST_ABORTED ((NDIS_STATUS)0xC001000CL)
52 #define NDIS_STATUS_RESET_IN_PROGRESS ((NDIS_STATUS)0xC001000DL)
53 #define NDIS_STATUS_CLOSING_INDICATING ((NDIS_STATUS)0xC001000EL)
54 #define NDIS_STATUS_NOT_SUPPORTED ((NDIS_STATUS)STATUS_NOT_SUPPORTED)
55 #define NDIS_STATUS_INVALID_PACKET ((NDIS_STATUS)0xC001000FL)
56 #define NDIS_STATUS_OPEN_LIST_FULL ((NDIS_STATUS)0xC0010010L)
57 #define NDIS_STATUS_ADAPTER_NOT_READY ((NDIS_STATUS)0xC0010011L)
58 #define NDIS_STATUS_ADAPTER_NOT_OPEN ((NDIS_STATUS)0xC0010012L)
59 #define NDIS_STATUS_NOT_INDICATING ((NDIS_STATUS)0xC0010013L)
60 #define NDIS_STATUS_INVALID_LENGTH ((NDIS_STATUS)0xC0010014L)
61 #define NDIS_STATUS_INVALID_DATA ((NDIS_STATUS)0xC0010015L)
62 #define NDIS_STATUS_BUFFER_TOO_SHORT ((NDIS_STATUS)0xC0010016L)
63 #define NDIS_STATUS_INVALID_OID ((NDIS_STATUS)0xC0010017L)
64 #define NDIS_STATUS_ADAPTER_REMOVED ((NDIS_STATUS)0xC0010018L)
65 #define NDIS_STATUS_UNSUPPORTED_MEDIA ((NDIS_STATUS)0xC0010019L)
66 #define NDIS_STATUS_GROUP_ADDRESS_IN_USE ((NDIS_STATUS)0xC001001AL)
67 #define NDIS_STATUS_FILE_NOT_FOUND ((NDIS_STATUS)0xC001001BL)
68 #define NDIS_STATUS_ERROR_READING_FILE ((NDIS_STATUS)0xC001001CL)
69 #define NDIS_STATUS_ALREADY_MAPPED ((NDIS_STATUS)0xC001001DL)
70 #define NDIS_STATUS_RESOURCE_CONFLICT ((NDIS_STATUS)0xC001001EL)
71 #define NDIS_STATUS_NO_CABLE ((NDIS_STATUS)0xC001001FL)
72
73 #define NDIS_STATUS_INVALID_SAP ((NDIS_STATUS)0xC0010020L)
74 #define NDIS_STATUS_SAP_IN_USE ((NDIS_STATUS)0xC0010021L)
75 #define NDIS_STATUS_INVALID_ADDRESS ((NDIS_STATUS)0xC0010022L)
76 #define NDIS_STATUS_VC_NOT_ACTIVATED ((NDIS_STATUS)0xC0010023L)
77 #define NDIS_STATUS_DEST_OUT_OF_ORDER ((NDIS_STATUS)0xC0010024L) /* cause 27 */
78 #define NDIS_STATUS_VC_NOT_AVAILABLE ((NDIS_STATUS)0xC0010025L) /* cause 35, 45 */
79 #define NDIS_STATUS_CELLRATE_NOT_AVAILABLE ((NDIS_STATUS)0xC0010026L) /* cause 37 */
80 #define NDIS_STATUS_INCOMPATABLE_QOS ((NDIS_STATUS)0xC0010027L) /* cause 49 */
81 #define NDIS_STATUS_AAL_PARAMS_UNSUPPORTED ((NDIS_STATUS)0xC0010028L) /* cause 93 */
82 #define NDIS_STATUS_NO_ROUTE_TO_DESTINATION ((NDIS_STATUS)0xC0010029L) /* cause 3 */
83 #endif /* #ifndef PLATFORM_WINDOWS */
84
85
86 #ifndef OID_802_11_CAPABILITY
87 #define OID_802_11_CAPABILITY 0x0d010122
88 #endif
89
90 #ifndef OID_802_11_PMKID
91 #define OID_802_11_PMKID 0x0d010123
92 #endif
93
94
95 /* For DDK-defined OIDs */
96 #define OID_NDIS_SEG1 0x00010100
97 #define OID_NDIS_SEG2 0x00010200
98 #define OID_NDIS_SEG3 0x00020100
99 #define OID_NDIS_SEG4 0x01010100
100 #define OID_NDIS_SEG5 0x01020100
101 #define OID_NDIS_SEG6 0x01020200
102 #define OID_NDIS_SEG7 0xFD010100
103 #define OID_NDIS_SEG8 0x0D010100
104 #define OID_NDIS_SEG9 0x0D010200
105 #define OID_NDIS_SEG10 0x0D020200
106
107 #define SZ_OID_NDIS_SEG1 23
108 #define SZ_OID_NDIS_SEG2 3
109 #define SZ_OID_NDIS_SEG3 6
110 #define SZ_OID_NDIS_SEG4 6
111 #define SZ_OID_NDIS_SEG5 4
112 #define SZ_OID_NDIS_SEG6 8
113 #define SZ_OID_NDIS_SEG7 7
114 #define SZ_OID_NDIS_SEG8 36
115 #define SZ_OID_NDIS_SEG9 24
116 #define SZ_OID_NDIS_SEG10 19
117
118 /* For Realtek-defined OIDs */
119 #define OID_MP_SEG1 0xFF871100
120 #define OID_MP_SEG2 0xFF818000
121
122 #define OID_MP_SEG3 0xFF818700
123 #define OID_MP_SEG4 0xFF011100
124
125 #define DEBUG_OID(dbg, str) \
126 if ((!dbg)) \
127 { \
128 RT_TRACE(_module_rtl871x_ioctl_c_, _drv_info_,("%s(%d): %s", __FUNCTION__, __LINE__, str)); \
129 }
130
131
132 enum oid_type {
133 QUERY_OID,
134 SET_OID
135 };
136
137 struct oid_funs_node {
138 unsigned int oid_start; /* the starting number for OID */
139 unsigned int oid_end; /* the ending number for OID */
140 struct oid_obj_priv *node_array;
141 unsigned int array_sz; /* the size of node_array */
142 int query_counter; /* count the number of query hits for this segment */
143 int set_counter; /* count the number of set hits for this segment */
144 };
145
146 struct oid_par_priv {
147 void *adapter_context;
148 NDIS_OID oid;
149 void *information_buf;
150 u32 information_buf_len;
151 u32 *bytes_rw;
152 u32 *bytes_needed;
153 enum oid_type type_of_oid;
154 u32 dbg;
155 };
156
157 struct oid_obj_priv {
158 unsigned char dbg; /* 0: without OID debug message 1: with OID debug message */
159 NDIS_STATUS(*oidfuns)(struct oid_par_priv *poid_par_priv);
160 };
161
162 #if (defined(CONFIG_MP_INCLUDED) && defined(_RTW_MP_IOCTL_C_)) || \
163 (defined(PLATFORM_WINDOWS) && defined(_RTW_IOCTL_RTL_C_))
oid_null_function(struct oid_par_priv * poid_par_priv)164 static NDIS_STATUS oid_null_function(struct oid_par_priv *poid_par_priv)
165 {
166 _func_enter_;
167 _func_exit_;
168 return NDIS_STATUS_SUCCESS;
169 }
170 #endif
171
172 #ifdef PLATFORM_WINDOWS
173
174 int TranslateNdisPsToRtPs(IN NDIS_802_11_POWER_MODE ndisPsMode);
175
176 /* OID Handler for Segment 1 */
177 NDIS_STATUS oid_gen_supported_list_hdl(struct oid_par_priv *poid_par_priv);
178 NDIS_STATUS oid_gen_hardware_status_hdl(struct oid_par_priv *poid_par_priv);
179 NDIS_STATUS oid_gen_media_supported_hdl(struct oid_par_priv *poid_par_priv);
180 NDIS_STATUS oid_gen_media_in_use_hdl(struct oid_par_priv *poid_par_priv);
181 NDIS_STATUS oid_gen_maximum_lookahead_hdl(struct oid_par_priv *poid_par_priv);
182 NDIS_STATUS oid_gen_maximum_frame_size_hdl(struct oid_par_priv *poid_par_priv);
183 NDIS_STATUS oid_gen_link_speed_hdl(struct oid_par_priv *poid_par_priv);
184 NDIS_STATUS oid_gen_transmit_buffer_space_hdl(struct oid_par_priv *poid_par_priv);
185 NDIS_STATUS oid_gen_receive_buffer_space_hdl(struct oid_par_priv *poid_par_priv);
186 NDIS_STATUS oid_gen_transmit_block_size_hdl(struct oid_par_priv *poid_par_priv);
187 NDIS_STATUS oid_gen_receive_block_size_hdl(struct oid_par_priv *poid_par_priv);
188 NDIS_STATUS oid_gen_vendor_id_hdl(struct oid_par_priv *poid_par_priv);
189 NDIS_STATUS oid_gen_vendor_description_hdl(struct oid_par_priv *poid_par_priv);
190 NDIS_STATUS oid_gen_current_packet_filter_hdl(struct oid_par_priv *poid_par_priv);
191 NDIS_STATUS oid_gen_current_lookahead_hdl(struct oid_par_priv *poid_par_priv);
192 NDIS_STATUS oid_gen_driver_version_hdl(struct oid_par_priv *poid_par_priv);
193 NDIS_STATUS oid_gen_maximum_total_size_hdl(struct oid_par_priv *poid_par_priv);
194 NDIS_STATUS oid_gen_protocol_options_hdl(struct oid_par_priv *poid_par_priv);
195 NDIS_STATUS oid_gen_mac_options_hdl(struct oid_par_priv *poid_par_priv);
196 NDIS_STATUS oid_gen_media_connect_status_hdl(struct oid_par_priv *poid_par_priv);
197 NDIS_STATUS oid_gen_maximum_send_packets_hdl(struct oid_par_priv *poid_par_priv);
198 NDIS_STATUS oid_gen_vendor_driver_version_hdl(struct oid_par_priv *poid_par_priv);
199
200
201 /* OID Handler for Segment 2 */
202 NDIS_STATUS oid_gen_physical_medium_hdl(struct oid_par_priv *poid_par_priv);
203
204 /* OID Handler for Segment 3 */
205 NDIS_STATUS oid_gen_xmit_ok_hdl(struct oid_par_priv *poid_par_priv);
206 NDIS_STATUS oid_gen_rcv_ok_hdl(struct oid_par_priv *poid_par_priv);
207 NDIS_STATUS oid_gen_xmit_error_hdl(struct oid_par_priv *poid_par_priv);
208 NDIS_STATUS oid_gen_rcv_error_hdl(struct oid_par_priv *poid_par_priv);
209 NDIS_STATUS oid_gen_rcv_no_buffer_hdl(struct oid_par_priv *poid_par_priv);
210
211
212 /* OID Handler for Segment 4 */
213 NDIS_STATUS oid_802_3_permanent_address_hdl(struct oid_par_priv *poid_par_priv);
214 NDIS_STATUS oid_802_3_current_address_hdl(struct oid_par_priv *poid_par_priv);
215 NDIS_STATUS oid_802_3_multicast_list_hdl(struct oid_par_priv *poid_par_priv);
216 NDIS_STATUS oid_802_3_maximum_list_size_hdl(struct oid_par_priv *poid_par_priv);
217 NDIS_STATUS oid_802_3_mac_options_hdl(struct oid_par_priv *poid_par_priv);
218
219
220
221 /* OID Handler for Segment 5 */
222 NDIS_STATUS oid_802_3_rcv_error_alignment_hdl(struct oid_par_priv *poid_par_priv);
223 NDIS_STATUS oid_802_3_xmit_one_collision_hdl(struct oid_par_priv *poid_par_priv);
224 NDIS_STATUS oid_802_3_xmit_more_collisions_hdl(struct oid_par_priv *poid_par_priv);
225
226
227 /* OID Handler for Segment 6 */
228 NDIS_STATUS oid_802_3_xmit_deferred_hdl(struct oid_par_priv *poid_par_priv);
229 NDIS_STATUS oid_802_3_xmit_max_collisions_hdl(struct oid_par_priv *poid_par_priv);
230 NDIS_STATUS oid_802_3_rcv_overrun_hdl(struct oid_par_priv *poid_par_priv);
231 NDIS_STATUS oid_802_3_xmit_underrun_hdl(struct oid_par_priv *poid_par_priv);
232 NDIS_STATUS oid_802_3_xmit_heartbeat_failure_hdl(struct oid_par_priv *poid_par_priv);
233 NDIS_STATUS oid_802_3_xmit_times_crs_lost_hdl(struct oid_par_priv *poid_par_priv);
234 NDIS_STATUS oid_802_3_xmit_late_collisions_hdl(struct oid_par_priv *poid_par_priv);
235
236
237
238 /* OID Handler for Segment 7 */
239 NDIS_STATUS oid_pnp_capabilities_hdl(struct oid_par_priv *poid_par_priv);
240 NDIS_STATUS oid_pnp_set_power_hdl(struct oid_par_priv *poid_par_priv);
241 NDIS_STATUS oid_pnp_query_power_hdl(struct oid_par_priv *poid_par_priv);
242 NDIS_STATUS oid_pnp_add_wake_up_pattern_hdl(struct oid_par_priv *poid_par_priv);
243 NDIS_STATUS oid_pnp_remove_wake_up_pattern_hdl(struct oid_par_priv *poid_par_priv);
244 NDIS_STATUS oid_pnp_wake_up_pattern_list_hdl(struct oid_par_priv *poid_par_priv);
245 NDIS_STATUS oid_pnp_enable_wake_up_hdl(struct oid_par_priv *poid_par_priv);
246
247
248
249 /* OID Handler for Segment 8 */
250 NDIS_STATUS oid_802_11_bssid_hdl(struct oid_par_priv *poid_par_priv);
251 NDIS_STATUS oid_802_11_ssid_hdl(struct oid_par_priv *poid_par_priv);
252 NDIS_STATUS oid_802_11_infrastructure_mode_hdl(struct oid_par_priv *poid_par_priv);
253 NDIS_STATUS oid_802_11_add_wep_hdl(struct oid_par_priv *poid_par_priv);
254 NDIS_STATUS oid_802_11_remove_wep_hdl(struct oid_par_priv *poid_par_priv);
255 NDIS_STATUS oid_802_11_disassociate_hdl(struct oid_par_priv *poid_par_priv);
256 NDIS_STATUS oid_802_11_authentication_mode_hdl(struct oid_par_priv *poid_par_priv);
257 NDIS_STATUS oid_802_11_privacy_filter_hdl(struct oid_par_priv *poid_par_priv);
258 NDIS_STATUS oid_802_11_bssid_list_scan_hdl(struct oid_par_priv *poid_par_priv);
259 NDIS_STATUS oid_802_11_encryption_status_hdl(struct oid_par_priv *poid_par_priv);
260 NDIS_STATUS oid_802_11_reload_defaults_hdl(struct oid_par_priv *poid_par_priv);
261 NDIS_STATUS oid_802_11_add_key_hdl(struct oid_par_priv *poid_par_priv);
262 NDIS_STATUS oid_802_11_remove_key_hdl(struct oid_par_priv *poid_par_priv);
263 NDIS_STATUS oid_802_11_association_information_hdl(struct oid_par_priv *poid_par_priv);
264 NDIS_STATUS oid_802_11_test_hdl(struct oid_par_priv *poid_par_priv);
265 NDIS_STATUS oid_802_11_media_stream_mode_hdl(struct oid_par_priv *poid_par_priv);
266 NDIS_STATUS oid_802_11_capability_hdl(struct oid_par_priv *poid_par_priv);
267 NDIS_STATUS oid_802_11_pmkid_hdl(struct oid_par_priv *poid_par_priv);
268
269
270
271
272
273 /* OID Handler for Segment 9 */
274 NDIS_STATUS oid_802_11_network_types_supported_hdl(struct oid_par_priv *poid_par_priv);
275 NDIS_STATUS oid_802_11_network_type_in_use_hdl(struct oid_par_priv *poid_par_priv);
276 NDIS_STATUS oid_802_11_tx_power_level_hdl(struct oid_par_priv *poid_par_priv);
277 NDIS_STATUS oid_802_11_rssi_hdl(struct oid_par_priv *poid_par_priv);
278 NDIS_STATUS oid_802_11_rssi_trigger_hdl(struct oid_par_priv *poid_par_priv);
279 NDIS_STATUS oid_802_11_fragmentation_threshold_hdl(struct oid_par_priv *poid_par_priv);
280 NDIS_STATUS oid_802_11_rts_threshold_hdl(struct oid_par_priv *poid_par_priv);
281 NDIS_STATUS oid_802_11_number_of_antennas_hdl(struct oid_par_priv *poid_par_priv);
282 NDIS_STATUS oid_802_11_rx_antenna_selected_hdl(struct oid_par_priv *poid_par_priv);
283 NDIS_STATUS oid_802_11_tx_antenna_selected_hdl(struct oid_par_priv *poid_par_priv);
284 NDIS_STATUS oid_802_11_supported_rates_hdl(struct oid_par_priv *poid_par_priv);
285 NDIS_STATUS oid_802_11_desired_rates_hdl(struct oid_par_priv *poid_par_priv);
286 NDIS_STATUS oid_802_11_configuration_hdl(struct oid_par_priv *poid_par_priv);
287 NDIS_STATUS oid_802_11_power_mode_hdl(struct oid_par_priv *poid_par_priv);
288 NDIS_STATUS oid_802_11_bssid_list_hdl(struct oid_par_priv *poid_par_priv);
289
290
291 /* OID Handler for Segment 10 */
292 NDIS_STATUS oid_802_11_statistics_hdl(struct oid_par_priv *poid_par_priv);
293
294
295 /* OID Handler for Segment ED */
296 NDIS_STATUS oid_rt_mh_vender_id_hdl(struct oid_par_priv *poid_par_priv);
297
298 void Set_802_3_MULTICAST_LIST(ADAPTER *pAdapter, UCHAR *MCListbuf, ULONG MCListlen, BOOLEAN bAcceptAllMulticast);
299
300 #endif/* end of PLATFORM_WINDOWS */
301
302 #if defined(PLATFORM_LINUX) && defined(CONFIG_WIRELESS_EXT)
303 extern struct iw_handler_def rtw_handlers_def;
304 #endif
305
306 extern void rtw_request_wps_pbc_event(_adapter *padapter);
307
308 extern NDIS_STATUS drv_query_info(
309 IN _nic_hdl MiniportAdapterContext,
310 IN NDIS_OID Oid,
311 IN void *InformationBuffer,
312 IN u32 InformationBufferLength,
313 OUT u32 *BytesWritten,
314 OUT u32 *BytesNeeded
315 );
316
317 extern NDIS_STATUS drv_set_info(
318 IN _nic_hdl MiniportAdapterContext,
319 IN NDIS_OID Oid,
320 IN void *InformationBuffer,
321 IN u32 InformationBufferLength,
322 OUT u32 *BytesRead,
323 OUT u32 *BytesNeeded
324 );
325
326 #ifdef CONFIG_APPEND_VENDOR_IE_ENABLE
327 extern int rtw_vendor_ie_get_raw_data(struct net_device *, u32, char *, u32);
328 extern int rtw_vendor_ie_get_data(struct net_device*, int , char*);
329 extern int rtw_vendor_ie_get(struct net_device *, struct iw_request_info *, union iwreq_data *, char *);
330 extern int rtw_vendor_ie_set(struct net_device*, struct iw_request_info*, union iwreq_data*, char*);
331 #endif
332
333 #endif /* #ifndef __INC_CEINFO_ */
334