diff options
Diffstat (limited to 'drivers/net')
-rw-r--r-- | drivers/net/wireless/libertas/README | 516 | ||||
-rw-r--r-- | drivers/net/wireless/libertas/ioctl.c | 1349 | ||||
-rw-r--r-- | drivers/net/wireless/libertas/join.c | 135 | ||||
-rw-r--r-- | drivers/net/wireless/libertas/join.h | 4 | ||||
-rw-r--r-- | drivers/net/wireless/libertas/wext.c | 274 | ||||
-rw-r--r-- | drivers/net/wireless/libertas/wext.h | 85 |
6 files changed, 0 insertions, 2363 deletions
diff --git a/drivers/net/wireless/libertas/README b/drivers/net/wireless/libertas/README index 688da4c784b1..378577200b56 100644 --- a/drivers/net/wireless/libertas/README +++ b/drivers/net/wireless/libertas/README | |||
@@ -40,64 +40,11 @@ NAME | |||
40 | SYNOPSIS | 40 | SYNOPSIS |
41 | iwpriv <ethX> <command> [sub-command] ... | 41 | iwpriv <ethX> <command> [sub-command] ... |
42 | 42 | ||
43 | iwpriv ethX version | ||
44 | iwpriv ethX scantype [sub-command] | ||
45 | iwpriv ethX getSNR <n> | ||
46 | iwpriv ethX getNF <n> | ||
47 | iwpriv ethX getRSSI <n> | ||
48 | iwpriv ethX setrxant <n> | ||
49 | iwpriv ethX getrxant | ||
50 | iwpriv ethX settxant <n> | ||
51 | iwpriv ethX gettxant | ||
52 | iwpriv ethX authalgs <n> | ||
53 | iwpriv ethX pre-TBTT <n> | ||
54 | iwpriv ethX 8021xauthalgs <n> | ||
55 | iwpriv ethX encryptionmode <n> | ||
56 | iwpriv ethX setregioncode <n> | 43 | iwpriv ethX setregioncode <n> |
57 | iwpriv ethX getregioncode | 44 | iwpriv ethX getregioncode |
58 | iwpriv ethX setbcnavg <n> | ||
59 | iwpriv ethX getbcnavg | ||
60 | iwpriv ethX setdataavg <n> | ||
61 | iwpriv ethX setlisteninter <n> | ||
62 | iwpriv ethX getlisteninter | ||
63 | iwpriv ethX setmultipledtim <n> | ||
64 | iwpriv ethX getmultipledtim | ||
65 | iwpriv ethX atimwindow <n> | ||
66 | iwpriv ethX deauth | ||
67 | iwpriv ethX adhocstop | ||
68 | iwpriv ethX radioon | ||
69 | iwpriv ethX radiooff | ||
70 | iwpriv ethX reasso-on | ||
71 | iwpriv ethX reasso-off | ||
72 | iwpriv ethX scanmode [sub-command] | ||
73 | iwpriv ethX setwpaie <n> | ||
74 | iwpriv ethX wlanidle-off | ||
75 | iwpriv ethX wlanidle-on | ||
76 | iwpriv ethX getcis | ||
77 | iwpriv ethX getlog | ||
78 | iwpriv ethX getadhocstatus | ||
79 | iwpriv ethX adhocgrate <n> | ||
80 | |||
81 | Version 4 Command: | ||
82 | iwpriv ethX inactvityto <n> | ||
83 | iwpriv ethX sleeppd <n> | ||
84 | iwpriv ethX enable11d <n> | ||
85 | iwpriv ethX tpccfg <n> | ||
86 | iwpriv ethX powercfg <n> | ||
87 | iwpriv ethX setafc <n> | ||
88 | iwpriv ethX getafc | ||
89 | 45 | ||
90 | Version 5 Command: | 46 | Version 5 Command: |
91 | iwpriv ethX ledgpio <n> | 47 | iwpriv ethX ledgpio <n> |
92 | iwpriv ethX scanprobes <n> | ||
93 | iwpriv ethX lolisteninter <n> | ||
94 | iwpriv ethX rateadapt <n> <m> | ||
95 | iwpriv ethX txcontrol <n> | ||
96 | iwpriv ethX psnullinterval <n> | ||
97 | iwpriv ethX prescan <n> | ||
98 | iwpriv ethX getrxinfo | ||
99 | iwpriv ethX gettxrate | ||
100 | iwpriv ethX beaconinterval | ||
101 | 48 | ||
102 | BT Commands: | 49 | BT Commands: |
103 | The blinding table (BT) contains a list of mac addresses that should be | 50 | The blinding table (BT) contains a list of mac addresses that should be |
@@ -150,114 +97,6 @@ DESCRIPTION | |||
150 | The ethX parameter specifies the network device that is to be used to | 97 | The ethX parameter specifies the network device that is to be used to |
151 | perform this command on. it could be eth0, eth1 etc. | 98 | perform this command on. it could be eth0, eth1 etc. |
152 | 99 | ||
153 | version | ||
154 | This is used to get the current version of the driver and the firmware. | ||
155 | |||
156 | scantype | ||
157 | This command is used to set the scan type to be used by the driver in | ||
158 | the scan command. This setting will not be used while performing a scan | ||
159 | for a specific SSID, as it is always done with scan type being active. | ||
160 | |||
161 | where the sub-commands are: - | ||
162 | active -- to set the scan type to active | ||
163 | passive -- to set the scan type to passive | ||
164 | get -- to get the scan type set in the driver | ||
165 | |||
166 | getSNR | ||
167 | This command gets the average and non average value of Signal to Noise | ||
168 | Ratio of Beacon and Data. | ||
169 | |||
170 | where value is:- | ||
171 | 0 -- Beacon non-average. | ||
172 | 1 -- Beacon average. | ||
173 | 2 -- Data non-average. | ||
174 | 3 -- Data average. | ||
175 | |||
176 | If no value is given, all four values are returned in the order mentioned | ||
177 | above. | ||
178 | |||
179 | Note: This command is available only when STA is connected. | ||
180 | |||
181 | getRSSI | ||
182 | This command gets the average and non average value os Receive Signal | ||
183 | Strength of Beacon and Data. | ||
184 | |||
185 | where value is:- | ||
186 | 0 -- Beacon non-average. | ||
187 | 1 -- Beacon average. | ||
188 | 2 -- Data non-average. | ||
189 | 3 -- Data average. | ||
190 | |||
191 | Note: This command is available only when STA is connected. | ||
192 | |||
193 | getNF | ||
194 | This command gets the average and non average value of Noise Floor of | ||
195 | Beacon and Data. | ||
196 | |||
197 | where value is:- | ||
198 | 0 -- Beacon non-average. | ||
199 | 1 -- Beacon average. | ||
200 | 2 -- Data non-average. | ||
201 | 3 -- Data average. | ||
202 | |||
203 | Note: This command is available only when STA is connected. | ||
204 | |||
205 | setrxant | ||
206 | This command is used to set the mode for Rx antenna. | ||
207 | |||
208 | The options that can be sent are:- | ||
209 | 1 -- Antenna 1. | ||
210 | 2 -- Antenna 2. | ||
211 | 0xFFFF -- Diversity. | ||
212 | |||
213 | Usage: | ||
214 | iwpriv ethX setrxant 0x01: select Antenna 1. | ||
215 | |||
216 | getrxant | ||
217 | This command is used to get the mode for Rx antenna. | ||
218 | |||
219 | |||
220 | settxant | ||
221 | This command is used to set the mode for Tx antenna. | ||
222 | The options that can be sent are:- | ||
223 | 1 -- Antenna 1. | ||
224 | 2 -- Antenna 2. | ||
225 | 0xFFFF -- Diversity. | ||
226 | Usage: | ||
227 | iwpriv ethX settxant 0x01: select Antenna 1. | ||
228 | |||
229 | gettxant | ||
230 | This command is used to get the mode for Tx antenna. | ||
231 | |||
232 | authalgs | ||
233 | This command is used by the WPA supplicant to set the authentication | ||
234 | algorithms in the station. | ||
235 | |||
236 | 8021xauthalgs | ||
237 | This command is used by the WPA supplicant to set the 8021.x authentication algorithm type | ||
238 | station. | ||
239 | |||
240 | where values can be:- | ||
241 | 1 -- None | ||
242 | 2 -- LEAP | ||
243 | 4 -- TLS | ||
244 | 8 -- TTLs | ||
245 | 16 -- MD5 | ||
246 | |||
247 | |||
248 | encryptionmode | ||
249 | This command is used by the WPA supplicant to set the encryption algorithm. | ||
250 | |||
251 | where values can be:- | ||
252 | 0 -- NONE | ||
253 | 1 -- WEP40 | ||
254 | 2 -- TKIP | ||
255 | 3 -- CCMP | ||
256 | 4 -- WEP104 | ||
257 | |||
258 | pre-TBTT | ||
259 | This command is used to set pre-TBTT time period where value is in microseconds. | ||
260 | |||
261 | setregioncode | 100 | setregioncode |
262 | This command is used to set the region code in the station. | 101 | This command is used to set the region code in the station. |
263 | where value is 'region code' for various regions like | 102 | where value is 'region code' for various regions like |
@@ -270,114 +109,6 @@ getregioncode | |||
270 | This command is used to get the region code information set in the | 109 | This command is used to get the region code information set in the |
271 | station. | 110 | station. |
272 | 111 | ||
273 | setbcnavg | ||
274 | Set the weighting factor for calculating RSSI. | ||
275 | |||
276 | getbcnavg | ||
277 | Get weighting factor for calculating RSSI. | ||
278 | |||
279 | setdataavg | ||
280 | Set the weighting factor for calculating SNR. | ||
281 | |||
282 | setlisteninter | ||
283 | This command is used to set the listen interval in the | ||
284 | station. | ||
285 | |||
286 | where the value ranges between 1 - 255 | ||
287 | |||
288 | getlisteninter | ||
289 | This command is used to get the listen interval value set in the | ||
290 | station. | ||
291 | |||
292 | setmultipledtim | ||
293 | This command is used to set the multiple dtim value in the | ||
294 | station. | ||
295 | where the value is 1,2,3,4,5,0xfffe | ||
296 | 0xfffe means the firmware will use listen interval in association | ||
297 | command for waking up | ||
298 | |||
299 | getmultipledtim | ||
300 | This command is used to get the multiple dtim value set in the station. | ||
301 | |||
302 | atimwindow | ||
303 | This command is used to set the atim value in the | ||
304 | station. | ||
305 | |||
306 | where the value ranges between 0 - 50 | ||
307 | |||
308 | deauth | ||
309 | This command is used to send the de-authentication to the AP with which | ||
310 | the station is associated. This command is valid only when | ||
311 | station is in Infrastructure mode. | ||
312 | |||
313 | Note: This command is available only when STA is connected. | ||
314 | |||
315 | adhocstop | ||
316 | This command is used to stop beacon transmission from the station and | ||
317 | go into idle state in ad-hoc mode. | ||
318 | |||
319 | Note: This command is available only when STA is connected. | ||
320 | |||
321 | radioon | ||
322 | This command is used to turn on the RF antenna. | ||
323 | |||
324 | radiooff | ||
325 | This command is sued to turn off the RF antenna. | ||
326 | |||
327 | scanmode | ||
328 | This command is used to set the station to scan for either IBSS | ||
329 | networks or BSS networks or both BSS and IBSS networks. This | ||
330 | command can be used with sub commands, | ||
331 | |||
332 | where the value for | ||
333 | bss -- Scan All the BSS networks. | ||
334 | ibss -- Scan All the IBSS networks. | ||
335 | any -- Scan both BSS and IBSS networks. | ||
336 | |||
337 | |||
338 | |||
339 | setwpaie | ||
340 | This command is used by WPA supplicant to send the WPA-IE to the driver. | ||
341 | |||
342 | wlanidle-off | ||
343 | This command is used to get into idle state. | ||
344 | |||
345 | Note: This command is available only when STA is connected. | ||
346 | |||
347 | wlanidle-on | ||
348 | This command is used to get off the idle state. | ||
349 | |||
350 | Note: This command is available only when STA is connected. | ||
351 | |||
352 | |||
353 | getlog | ||
354 | This command is used to get the 802.11 statistics available in the | ||
355 | station. | ||
356 | |||
357 | Note: This command is available only when STA is connected. | ||
358 | |||
359 | getadhocstatus | ||
360 | This command is used to get the ad-hoc Network Status. | ||
361 | |||
362 | The various status codes are: | ||
363 | AdhocStarted | ||
364 | AdhocJoined | ||
365 | AdhocIdle | ||
366 | InfraMode | ||
367 | AutoUnknownMode | ||
368 | |||
369 | Note: This command is available only when STA is connected. | ||
370 | |||
371 | adhocgrate | ||
372 | This command is used to enable(1) g_rate, Disable(0) g_rate | ||
373 | and request(2) the status which g_rate is disabled/enabled, | ||
374 | for Ad-hoc creator. | ||
375 | |||
376 | where value is:- | ||
377 | 0 -- Disabled | ||
378 | 1 -- Enabled | ||
379 | 2 -- Get | ||
380 | |||
381 | ledgpio | 112 | ledgpio |
382 | This command is used to set/get LEDs. | 113 | This command is used to set/get LEDs. |
383 | 114 | ||
@@ -400,253 +131,6 @@ ledgpio | |||
400 | Note: LED0 is invalid | 131 | Note: LED0 is invalid |
401 | Note: Maximum Number of LEDs are 16. | 132 | Note: Maximum Number of LEDs are 16. |
402 | 133 | ||
403 | inactivityto | ||
404 | This command is used by the host to set/get the inactivity timeout value, | ||
405 | which specifies when WLAN device is put to sleep. | ||
406 | |||
407 | Usage: | ||
408 | iwpriv ethX inactivityto [<timeout>] | ||
409 | |||
410 | where the parameter are: | ||
411 | timeout: timeout value in milliseconds. | ||
412 | |||
413 | Example: | ||
414 | iwpriv eth1 inactivityto | ||
415 | "get the timeout value" | ||
416 | |||
417 | iwpriv eth1 inactivityto X | ||
418 | "set timeout value to X ms" | ||
419 | |||
420 | |||
421 | sleeppd | ||
422 | This command is used to configure the sleep period of the WLAN device. | ||
423 | |||
424 | Usage: | ||
425 | iwpriv ethX sleeppd [<sleep period>] | ||
426 | |||
427 | where the parameter are: | ||
428 | Period: sleep period in milliseconds. Range 10~60. | ||
429 | |||
430 | Example: | ||
431 | iwpriv eth1 sleeppd 10 | ||
432 | "set period as 10 ms" | ||
433 | iwpriv eth1 sleeppd | ||
434 | "get the sleep period configuration" | ||
435 | |||
436 | enable11d | ||
437 | This command is used to control 11d | ||
438 | where value is:- | ||
439 | 1 -- Enabled | ||
440 | 0 -- Disabled | ||
441 | 2 -- Get | ||
442 | |||
443 | |||
444 | |||
445 | |||
446 | tpccfg | ||
447 | Enables or disables automatic transmit power control. | ||
448 | |||
449 | The first parameter turns this feature on (1) or off (0). When turning | ||
450 | on, the user must also supply four more parameters in the following | ||
451 | order: | ||
452 | -UseSNR (Use SNR (in addition to PER) for TPC algorithm), | ||
453 | -P0 (P0 power level for TPC), | ||
454 | -P1 (P1 power level for TPC), | ||
455 | -P2 (P2 power level for TPC). | ||
456 | |||
457 | Usage: | ||
458 | iwpriv ethX tpccfg: Get current configuration | ||
459 | iwpriv ethX tpccfg 0: disable auto TPC | ||
460 | iwpriv ethX tpccfg 0x01 0x00 0x05 0x0a 0x0d: enable auto TPC; do not use SNR; | ||
461 | P0=0x05; P1=0x0a; P2=0x0d; | ||
462 | iwpriv ethX tpccfg 0x01 0x01 0x05 0x0a 0x0d: enable auto TPC; use SNR; | ||
463 | P0=0x05; P1=0x0a; P2=0x0d. | ||
464 | |||
465 | powercfg | ||
466 | Enables or disables power adaptation. | ||
467 | |||
468 | The first parameter turns this feature on (1) or off (0). When turning | ||
469 | on, the user must also supply three more parameters in the following | ||
470 | order: | ||
471 | -P0 (P0 power level for Power Adaptation), | ||
472 | -P1 (P1 power level for Power Adaptation), | ||
473 | -P2 (P2 power level for Power Adaptation). | ||
474 | |||
475 | Usage: | ||
476 | iwpriv ethX powercfg: Get current configuration | ||
477 | iwpriv ethX powercfg 0: disable power adaptation | ||
478 | iwpriv ethX powercfg 1 0x0d 0x0f 0x12: enable power adaptation; | ||
479 | P0=0x0d; P1=0x0f; P2=0x12. | ||
480 | |||
481 | getafc | ||
482 | This command returns automatic frequency control parameters. It returns | ||
483 | three integers: | ||
484 | -P0: automatic is on (1), or off (0), | ||
485 | -P1: current timing offset in PPM (part per million), and | ||
486 | -P2: current frequency offset in PPM. | ||
487 | |||
488 | setafc | ||
489 | Set automatic frequency control options. | ||
490 | |||
491 | The first parameter turns automatic on (1) or off (0). | ||
492 | The user must supply two more parameters in either case, in the following | ||
493 | order: | ||
494 | |||
495 | When auto is on: | ||
496 | |||
497 | -P0 (automatic adjustment frequency threshold in PPM), | ||
498 | -P1 (automatic adjustment period in beacon period), | ||
499 | |||
500 | When auto is off: | ||
501 | |||
502 | -P0 (manual adjustment timing offset in PPM), and | ||
503 | -P1 (manual adjustment frequency offset in PPM). | ||
504 | |||
505 | Usage: | ||
506 | iwpriv ethX setafc 0 10 10: manual adjustment, both timing and frequcncy | ||
507 | offset are 10 PPM. | ||
508 | |||
509 | iwpriv ethX setafc 1 10 10 enable afc, automatic adjustment, | ||
510 | frequency threshold 10 PPM, for every 10 beacon periods. | ||
511 | |||
512 | |||
513 | |||
514 | scanprobes | ||
515 | This command sets number of probe requests per channel. | ||
516 | |||
517 | Usage: | ||
518 | iwpriv ethX scanprobes 3 (set scan probes to 3) | ||
519 | iwpriv ethX scanprobes (get scan probes) | ||
520 | |||
521 | lolisteninter | ||
522 | This command sets the value of listen interval. | ||
523 | |||
524 | Usage: | ||
525 | iwpriv ethX lolisteninter 234 (set the lolisteninter to 234) | ||
526 | iwpriv ethX lolisteninter (get the lolisteninter value) | ||
527 | |||
528 | rateadapt | ||
529 | This command sets the data rates bitmap. | ||
530 | Where <n> | ||
531 | 0: Disable auto rate adapt | ||
532 | 1: Enable auto rate adapt | ||
533 | |||
534 | <m> | ||
535 | data rate bitmap | ||
536 | Bit Data rate | ||
537 | 0 1 Mbps | ||
538 | 1 2 Mbps | ||
539 | 2 5.5 Mbps | ||
540 | 3 11 Mbps | ||
541 | 4 Reserved | ||
542 | 5 6 Mbps | ||
543 | 6 9 Mbps | ||
544 | 7 12 Mbps | ||
545 | 8 18 Mbps | ||
546 | 9 24 Mbps | ||
547 | 10 36 Mbps | ||
548 | 11 48 Mbps | ||
549 | 12 54 Mbps | ||
550 | 12-15 Reserved | ||
551 | |||
552 | Usage: | ||
553 | iwpriv ethX rateadapt | ||
554 | read the currect data rate setting | ||
555 | iwpriv ethX rateadapt 1 0x07 | ||
556 | enable auto data rate adapt and | ||
557 | data rates are 1Mbps, 2Mbsp and 5.5Mbps | ||
558 | |||
559 | |||
560 | txcontrol | ||
561 | This command is used to set the Tx rate, ack policy, and retry limit on a per packet basis. | ||
562 | |||
563 | Where value <n> is: | ||
564 | if bit[4] == 1: | ||
565 | bit[3:0] -- 0 1 2 3 4 5 6 7 8 9 10 11 12 13-16 | ||
566 | Data Rate(Mbps) -- 1 2 5.5 11 Rsv 6 9 12 18 24 36 48 54 Rsv | ||
567 | |||
568 | bit[12:8] | ||
569 | if bit[12] == 1, bit[11:8] specifies the Tx retry limit. | ||
570 | |||
571 | bit[14:13] specifies per packet ack policy: | ||
572 | bit[14:13] | ||
573 | 1 0 use immediate ack policy for this packet | ||
574 | 1 1 use no ack policy for this packet | ||
575 | 0 x use the per-packet ack policy setting | ||
576 | |||
577 | Usage: | ||
578 | iwpriv ethX txcontrol 0x7513 | ||
579 | Use no-ack policy, 5 retires for Tx, 11Mbps rate | ||
580 | |||
581 | |||
582 | |||
583 | psnullinterval | ||
584 | This command is used to set/request NULL package interval for Power Save | ||
585 | under infrastructure mode. | ||
586 | |||
587 | where value is:- | ||
588 | -1 -- Disabled | ||
589 | n>0 -- Set interval as n (seconds) | ||
590 | |||
591 | prescan | ||
592 | This command is used to enable (1)/disable(0) auto prescan before assoicate to the ap | ||
593 | |||
594 | where value is:- | ||
595 | 0 -- Disabled | ||
596 | 1 -- Enabled | ||
597 | 2 -- Get | ||
598 | |||
599 | getrxinfo | ||
600 | This command gets non average value of Signal to Noise Ratio of Data and rate index. | ||
601 | |||
602 | The following table shows RateIndex and Rate | ||
603 | |||
604 | RateIndex Data rate | ||
605 | 0 1 Mbps | ||
606 | 1 2 Mbps | ||
607 | 2 5.5 Mbps | ||
608 | 3 11 Mbps | ||
609 | 4 Reserved | ||
610 | 5 6 Mbps | ||
611 | 6 9 Mbps | ||
612 | 7 12 Mbps | ||
613 | 8 18 Mbps | ||
614 | 9 24 Mbps | ||
615 | 10 36 Mbps | ||
616 | 11 48 Mbps | ||
617 | 12 54 Mbps | ||
618 | 13-15 Reserved | ||
619 | |||
620 | gettxrate | ||
621 | This command gets current Tx rate index of the first packet associated with Rate Adaptation. | ||
622 | |||
623 | The following table shows RateIndex and Rate | ||
624 | |||
625 | RateIndex Data rate | ||
626 | 0 1 Mbps | ||
627 | 1 2 Mbps | ||
628 | 2 5.5 Mbps | ||
629 | 3 11 Mbps | ||
630 | 4 Reserved | ||
631 | 5 6 Mbps | ||
632 | 6 9 Mbps | ||
633 | 7 12 Mbps | ||
634 | 8 18 Mbps | ||
635 | 9 24 Mbps | ||
636 | 10 36 Mbps | ||
637 | 11 48 Mbps | ||
638 | 12 54 Mbps | ||
639 | 13-15 Reserved | ||
640 | |||
641 | bcninterval | ||
642 | This command is used to sets beacon interval in adhoc mode when an argument is given, and gets current adhoc | ||
643 | beacon interval when no argument is given. The valid beacon interval is between 20 - 1000, | ||
644 | default beacon interval is 100. | ||
645 | |||
646 | Usage: | ||
647 | iwpriv ethX bcninterval 100 (set adhoc beacon interval to 100) | ||
648 | iwpriv ethX bcninterval (get adhoc beacon interval) | ||
649 | |||
650 | fwt_add | 134 | fwt_add |
651 | This command is used to insert an entry into the FWT table. The list of | 135 | This command is used to insert an entry into the FWT table. The list of |
652 | parameters must follow the following structure: | 136 | parameters must follow the following structure: |
diff --git a/drivers/net/wireless/libertas/ioctl.c b/drivers/net/wireless/libertas/ioctl.c index 636a0897150e..42dfd45890c2 100644 --- a/drivers/net/wireless/libertas/ioctl.c +++ b/drivers/net/wireless/libertas/ioctl.c | |||
@@ -27,95 +27,6 @@ | |||
27 | 27 | ||
28 | #define WAIT_FOR_SCAN_RRESULT_MAX_TIME (10 * HZ) | 28 | #define WAIT_FOR_SCAN_RRESULT_MAX_TIME (10 * HZ) |
29 | 29 | ||
30 | static int setrxantenna(wlan_private * priv, int mode) | ||
31 | { | ||
32 | int ret = 0; | ||
33 | wlan_adapter *adapter = priv->adapter; | ||
34 | |||
35 | if (mode != RF_ANTENNA_1 && mode != RF_ANTENNA_2 | ||
36 | && mode != RF_ANTENNA_AUTO) { | ||
37 | return -EINVAL; | ||
38 | } | ||
39 | |||
40 | adapter->rxantennamode = mode; | ||
41 | |||
42 | lbs_pr_debug(1, "SET RX Antenna mode to 0x%04x\n", adapter->rxantennamode); | ||
43 | |||
44 | ret = libertas_prepare_and_send_command(priv, cmd_802_11_rf_antenna, | ||
45 | cmd_act_set_rx, | ||
46 | cmd_option_waitforrsp, 0, | ||
47 | &adapter->rxantennamode); | ||
48 | return ret; | ||
49 | } | ||
50 | |||
51 | static int settxantenna(wlan_private * priv, int mode) | ||
52 | { | ||
53 | int ret = 0; | ||
54 | wlan_adapter *adapter = priv->adapter; | ||
55 | |||
56 | if ((mode != RF_ANTENNA_1) && (mode != RF_ANTENNA_2) | ||
57 | && (mode != RF_ANTENNA_AUTO)) { | ||
58 | return -EINVAL; | ||
59 | } | ||
60 | |||
61 | adapter->txantennamode = mode; | ||
62 | |||
63 | lbs_pr_debug(1, "SET TX Antenna mode to 0x%04x\n", adapter->txantennamode); | ||
64 | |||
65 | ret = libertas_prepare_and_send_command(priv, cmd_802_11_rf_antenna, | ||
66 | cmd_act_set_tx, | ||
67 | cmd_option_waitforrsp, 0, | ||
68 | &adapter->txantennamode); | ||
69 | |||
70 | return ret; | ||
71 | } | ||
72 | |||
73 | static int getrxantenna(wlan_private * priv, char *buf) | ||
74 | { | ||
75 | int ret = 0; | ||
76 | wlan_adapter *adapter = priv->adapter; | ||
77 | |||
78 | // clear it, so we will know if the value | ||
79 | // returned below is correct or not. | ||
80 | adapter->rxantennamode = 0; | ||
81 | |||
82 | ret = libertas_prepare_and_send_command(priv, cmd_802_11_rf_antenna, | ||
83 | cmd_act_get_rx, | ||
84 | cmd_option_waitforrsp, 0, NULL); | ||
85 | |||
86 | if (ret) { | ||
87 | LEAVE(); | ||
88 | return ret; | ||
89 | } | ||
90 | |||
91 | lbs_pr_debug(1, "Get Rx Antenna mode:0x%04x\n", adapter->rxantennamode); | ||
92 | |||
93 | return sprintf(buf, "0x%04x", adapter->rxantennamode) + 1; | ||
94 | } | ||
95 | |||
96 | static int gettxantenna(wlan_private * priv, char *buf) | ||
97 | { | ||
98 | int ret = 0; | ||
99 | wlan_adapter *adapter = priv->adapter; | ||
100 | |||
101 | // clear it, so we will know if the value | ||
102 | // returned below is correct or not. | ||
103 | adapter->txantennamode = 0; | ||
104 | |||
105 | ret = libertas_prepare_and_send_command(priv, cmd_802_11_rf_antenna, | ||
106 | cmd_act_get_tx, | ||
107 | cmd_option_waitforrsp, 0, NULL); | ||
108 | |||
109 | if (ret) { | ||
110 | LEAVE(); | ||
111 | return ret; | ||
112 | } | ||
113 | |||
114 | lbs_pr_debug(1, "Get Tx Antenna mode:0x%04x\n", adapter->txantennamode); | ||
115 | |||
116 | return sprintf(buf, "0x%04x", adapter->txantennamode) + 1; | ||
117 | } | ||
118 | |||
119 | static int wlan_set_region(wlan_private * priv, u16 region_code) | 30 | static int wlan_set_region(wlan_private * priv, u16 region_code) |
120 | { | 31 | { |
121 | int i; | 32 | int i; |
@@ -144,852 +55,6 @@ static int wlan_set_region(wlan_private * priv, u16 region_code) | |||
144 | return 0; | 55 | return 0; |
145 | } | 56 | } |
146 | 57 | ||
147 | /** | ||
148 | * @brief Get/Set Firmware wakeup method | ||
149 | * | ||
150 | * @param priv A pointer to wlan_private structure | ||
151 | * @param wrq A pointer to user data | ||
152 | * @return 0--success, otherwise fail | ||
153 | */ | ||
154 | static int wlan_txcontrol(wlan_private * priv, struct iwreq *wrq) | ||
155 | { | ||
156 | wlan_adapter *adapter = priv->adapter; | ||
157 | int data; | ||
158 | ENTER(); | ||
159 | |||
160 | if ((int)wrq->u.data.length == 0) { | ||
161 | if (copy_to_user | ||
162 | (wrq->u.data.pointer, &adapter->pkttxctrl, sizeof(u32))) { | ||
163 | lbs_pr_alert("copy_to_user failed!\n"); | ||
164 | return -EFAULT; | ||
165 | } | ||
166 | } else { | ||
167 | if ((int)wrq->u.data.length > 1) { | ||
168 | lbs_pr_alert("ioctl too many args!\n"); | ||
169 | return -EFAULT; | ||
170 | } | ||
171 | if (copy_from_user(&data, wrq->u.data.pointer, sizeof(int))) { | ||
172 | lbs_pr_alert("Copy from user failed\n"); | ||
173 | return -EFAULT; | ||
174 | } | ||
175 | |||
176 | adapter->pkttxctrl = (u32) data; | ||
177 | } | ||
178 | |||
179 | wrq->u.data.length = 1; | ||
180 | |||
181 | LEAVE(); | ||
182 | return 0; | ||
183 | } | ||
184 | |||
185 | /** | ||
186 | * @brief Get/Set NULL Package generation interval | ||
187 | * | ||
188 | * @param priv A pointer to wlan_private structure | ||
189 | * @param wrq A pointer to user data | ||
190 | * @return 0--success, otherwise fail | ||
191 | */ | ||
192 | static int wlan_null_pkt_interval(wlan_private * priv, struct iwreq *wrq) | ||
193 | { | ||
194 | wlan_adapter *adapter = priv->adapter; | ||
195 | int data; | ||
196 | ENTER(); | ||
197 | |||
198 | if ((int)wrq->u.data.length == 0) { | ||
199 | data = adapter->nullpktinterval; | ||
200 | |||
201 | if (copy_to_user(wrq->u.data.pointer, &data, sizeof(int))) { | ||
202 | lbs_pr_alert( "copy_to_user failed!\n"); | ||
203 | return -EFAULT; | ||
204 | } | ||
205 | } else { | ||
206 | if ((int)wrq->u.data.length > 1) { | ||
207 | lbs_pr_alert( "ioctl too many args!\n"); | ||
208 | return -EFAULT; | ||
209 | } | ||
210 | if (copy_from_user(&data, wrq->u.data.pointer, sizeof(int))) { | ||
211 | lbs_pr_debug(1, "Copy from user failed\n"); | ||
212 | return -EFAULT; | ||
213 | } | ||
214 | |||
215 | adapter->nullpktinterval = data; | ||
216 | } | ||
217 | |||
218 | wrq->u.data.length = 1; | ||
219 | |||
220 | LEAVE(); | ||
221 | return 0; | ||
222 | } | ||
223 | |||
224 | static int wlan_get_rxinfo(wlan_private * priv, struct iwreq *wrq) | ||
225 | { | ||
226 | wlan_adapter *adapter = priv->adapter; | ||
227 | int data[2]; | ||
228 | ENTER(); | ||
229 | data[0] = adapter->SNR[TYPE_RXPD][TYPE_NOAVG]; | ||
230 | data[1] = adapter->rxpd_rate; | ||
231 | if (copy_to_user(wrq->u.data.pointer, data, sizeof(int) * 2)) { | ||
232 | lbs_pr_debug(1, "Copy to user failed\n"); | ||
233 | return -EFAULT; | ||
234 | } | ||
235 | wrq->u.data.length = 2; | ||
236 | LEAVE(); | ||
237 | return 0; | ||
238 | } | ||
239 | |||
240 | static int wlan_get_snr(wlan_private * priv, struct iwreq *wrq) | ||
241 | { | ||
242 | int ret = 0; | ||
243 | wlan_adapter *adapter = priv->adapter; | ||
244 | int data[4]; | ||
245 | |||
246 | ENTER(); | ||
247 | memset(data, 0, sizeof(data)); | ||
248 | if (wrq->u.data.length) { | ||
249 | if (copy_from_user(data, wrq->u.data.pointer, | ||
250 | min_t(size_t, wrq->u.data.length, 4) * sizeof(int))) | ||
251 | return -EFAULT; | ||
252 | } | ||
253 | if ((wrq->u.data.length == 0) || (data[0] == 0) || (data[0] == 1)) { | ||
254 | if (adapter->connect_status == libertas_connected) { | ||
255 | ret = libertas_prepare_and_send_command(priv, | ||
256 | cmd_802_11_rssi, | ||
257 | 0, | ||
258 | cmd_option_waitforrsp, | ||
259 | 0, NULL); | ||
260 | |||
261 | if (ret) { | ||
262 | LEAVE(); | ||
263 | return ret; | ||
264 | } | ||
265 | } | ||
266 | } | ||
267 | |||
268 | if (wrq->u.data.length == 0) { | ||
269 | data[0] = adapter->SNR[TYPE_BEACON][TYPE_NOAVG]; | ||
270 | data[1] = adapter->SNR[TYPE_BEACON][TYPE_AVG]; | ||
271 | data[2] = adapter->SNR[TYPE_RXPD][TYPE_NOAVG]; | ||
272 | data[3] = adapter->SNR[TYPE_RXPD][TYPE_AVG] / AVG_SCALE; | ||
273 | if (copy_to_user(wrq->u.data.pointer, data, sizeof(int) * 4)) | ||
274 | return -EFAULT; | ||
275 | wrq->u.data.length = 4; | ||
276 | } else if (data[0] == 0) { | ||
277 | data[0] = adapter->SNR[TYPE_BEACON][TYPE_NOAVG]; | ||
278 | if (copy_to_user(wrq->u.data.pointer, data, sizeof(int))) | ||
279 | return -EFAULT; | ||
280 | wrq->u.data.length = 1; | ||
281 | } else if (data[0] == 1) { | ||
282 | data[0] = adapter->SNR[TYPE_BEACON][TYPE_AVG]; | ||
283 | if (copy_to_user(wrq->u.data.pointer, data, sizeof(int))) | ||
284 | return -EFAULT; | ||
285 | wrq->u.data.length = 1; | ||
286 | } else if (data[0] == 2) { | ||
287 | data[0] = adapter->SNR[TYPE_RXPD][TYPE_NOAVG]; | ||
288 | if (copy_to_user(wrq->u.data.pointer, data, sizeof(int))) | ||
289 | return -EFAULT; | ||
290 | wrq->u.data.length = 1; | ||
291 | } else if (data[0] == 3) { | ||
292 | data[0] = adapter->SNR[TYPE_RXPD][TYPE_AVG] / AVG_SCALE; | ||
293 | if (copy_to_user(wrq->u.data.pointer, data, sizeof(int))) | ||
294 | return -EFAULT; | ||
295 | wrq->u.data.length = 1; | ||
296 | } else | ||
297 | return -ENOTSUPP; | ||
298 | |||
299 | LEAVE(); | ||
300 | return 0; | ||
301 | } | ||
302 | |||
303 | static int wlan_beacon_interval(wlan_private * priv, struct iwreq *wrq) | ||
304 | { | ||
305 | int data; | ||
306 | wlan_adapter *adapter = priv->adapter; | ||
307 | |||
308 | if (wrq->u.data.length > 0) { | ||
309 | if (copy_from_user(&data, wrq->u.data.pointer, sizeof(int))) | ||
310 | return -EFAULT; | ||
311 | |||
312 | lbs_pr_debug(1, "WLAN SET BEACON INTERVAL: %d\n", data); | ||
313 | if ((data > MRVDRV_MAX_BEACON_INTERVAL) | ||
314 | || (data < MRVDRV_MIN_BEACON_INTERVAL)) | ||
315 | return -ENOTSUPP; | ||
316 | adapter->beaconperiod = data; | ||
317 | } | ||
318 | data = adapter->beaconperiod; | ||
319 | if (copy_to_user(wrq->u.data.pointer, &data, sizeof(int))) | ||
320 | return -EFAULT; | ||
321 | |||
322 | wrq->u.data.length = 1; | ||
323 | |||
324 | return 0; | ||
325 | } | ||
326 | |||
327 | static int wlan_get_rssi(wlan_private * priv, struct iwreq *wrq) | ||
328 | { | ||
329 | int ret = 0; | ||
330 | wlan_adapter *adapter = priv->adapter; | ||
331 | int temp; | ||
332 | int data = 0; | ||
333 | int *val; | ||
334 | |||
335 | ENTER(); | ||
336 | data = SUBCMD_DATA(wrq); | ||
337 | if ((data == 0) || (data == 1)) { | ||
338 | ret = libertas_prepare_and_send_command(priv, | ||
339 | cmd_802_11_rssi, | ||
340 | 0, cmd_option_waitforrsp, | ||
341 | 0, NULL); | ||
342 | if (ret) { | ||
343 | LEAVE(); | ||
344 | return ret; | ||
345 | } | ||
346 | } | ||
347 | |||
348 | switch (data) { | ||
349 | case 0: | ||
350 | |||
351 | temp = CAL_RSSI(adapter->SNR[TYPE_BEACON][TYPE_NOAVG], | ||
352 | adapter->NF[TYPE_BEACON][TYPE_NOAVG]); | ||
353 | break; | ||
354 | case 1: | ||
355 | temp = CAL_RSSI(adapter->SNR[TYPE_BEACON][TYPE_AVG], | ||
356 | adapter->NF[TYPE_BEACON][TYPE_AVG]); | ||
357 | break; | ||
358 | case 2: | ||
359 | temp = CAL_RSSI(adapter->SNR[TYPE_RXPD][TYPE_NOAVG], | ||
360 | adapter->NF[TYPE_RXPD][TYPE_NOAVG]); | ||
361 | break; | ||
362 | case 3: | ||
363 | temp = CAL_RSSI(adapter->SNR[TYPE_RXPD][TYPE_AVG] / AVG_SCALE, | ||
364 | adapter->NF[TYPE_RXPD][TYPE_AVG] / AVG_SCALE); | ||
365 | break; | ||
366 | default: | ||
367 | return -ENOTSUPP; | ||
368 | } | ||
369 | val = (int *)wrq->u.name; | ||
370 | *val = temp; | ||
371 | |||
372 | LEAVE(); | ||
373 | return 0; | ||
374 | } | ||
375 | |||
376 | static int wlan_get_nf(wlan_private * priv, struct iwreq *wrq) | ||
377 | { | ||
378 | int ret = 0; | ||
379 | wlan_adapter *adapter = priv->adapter; | ||
380 | int temp; | ||
381 | int data = 0; | ||
382 | int *val; | ||
383 | |||
384 | data = SUBCMD_DATA(wrq); | ||
385 | if ((data == 0) || (data == 1)) { | ||
386 | ret = libertas_prepare_and_send_command(priv, | ||
387 | cmd_802_11_rssi, | ||
388 | 0, cmd_option_waitforrsp, | ||
389 | 0, NULL); | ||
390 | |||
391 | if (ret) { | ||
392 | LEAVE(); | ||
393 | return ret; | ||
394 | } | ||
395 | } | ||
396 | |||
397 | switch (data) { | ||
398 | case 0: | ||
399 | temp = adapter->NF[TYPE_BEACON][TYPE_NOAVG]; | ||
400 | break; | ||
401 | case 1: | ||
402 | temp = adapter->NF[TYPE_BEACON][TYPE_AVG]; | ||
403 | break; | ||
404 | case 2: | ||
405 | temp = adapter->NF[TYPE_RXPD][TYPE_NOAVG]; | ||
406 | break; | ||
407 | case 3: | ||
408 | temp = adapter->NF[TYPE_RXPD][TYPE_AVG] / AVG_SCALE; | ||
409 | break; | ||
410 | default: | ||
411 | return -ENOTSUPP; | ||
412 | } | ||
413 | |||
414 | temp = CAL_NF(temp); | ||
415 | |||
416 | lbs_pr_debug(1, "%s: temp = %d\n", __FUNCTION__, temp); | ||
417 | val = (int *)wrq->u.name; | ||
418 | *val = temp; | ||
419 | return 0; | ||
420 | } | ||
421 | |||
422 | static int wlan_get_txrate_ioctl(wlan_private * priv, struct ifreq *req) | ||
423 | { | ||
424 | wlan_adapter *adapter = priv->adapter; | ||
425 | int *pdata; | ||
426 | struct iwreq *wrq = (struct iwreq *)req; | ||
427 | int ret = 0; | ||
428 | adapter->txrate = 0; | ||
429 | lbs_pr_debug(1, "wlan_get_txrate_ioctl\n"); | ||
430 | ret = libertas_prepare_and_send_command(priv, cmd_802_11_tx_rate_query, | ||
431 | cmd_act_get, cmd_option_waitforrsp, | ||
432 | 0, NULL); | ||
433 | if (ret) | ||
434 | return ret; | ||
435 | |||
436 | pdata = (int *)wrq->u.name; | ||
437 | *pdata = (int)adapter->txrate; | ||
438 | return 0; | ||
439 | } | ||
440 | |||
441 | static int wlan_get_adhoc_status_ioctl(wlan_private * priv, struct iwreq *wrq) | ||
442 | { | ||
443 | char status[64]; | ||
444 | wlan_adapter *adapter = priv->adapter; | ||
445 | |||
446 | memset(status, 0, sizeof(status)); | ||
447 | |||
448 | switch (adapter->mode) { | ||
449 | case IW_MODE_ADHOC: | ||
450 | if (adapter->connect_status == libertas_connected) { | ||
451 | if (adapter->adhoccreate) | ||
452 | memcpy(&status, "AdhocStarted", sizeof(status)); | ||
453 | else | ||
454 | memcpy(&status, "AdhocJoined", sizeof(status)); | ||
455 | } else { | ||
456 | memcpy(&status, "AdhocIdle", sizeof(status)); | ||
457 | } | ||
458 | break; | ||
459 | case IW_MODE_INFRA: | ||
460 | memcpy(&status, "Inframode", sizeof(status)); | ||
461 | break; | ||
462 | default: | ||
463 | memcpy(&status, "AutoUnknownmode", sizeof(status)); | ||
464 | break; | ||
465 | } | ||
466 | |||
467 | lbs_pr_debug(1, "status = %s\n", status); | ||
468 | wrq->u.data.length = strlen(status) + 1; | ||
469 | |||
470 | if (wrq->u.data.pointer) { | ||
471 | if (copy_to_user(wrq->u.data.pointer, | ||
472 | &status, wrq->u.data.length)) | ||
473 | return -EFAULT; | ||
474 | } | ||
475 | |||
476 | LEAVE(); | ||
477 | return 0; | ||
478 | } | ||
479 | |||
480 | /** | ||
481 | * @brief Set Auto prescan | ||
482 | * @param priv A pointer to wlan_private structure | ||
483 | * @param wrq A pointer to iwreq structure | ||
484 | * @return 0 --success, otherwise fail | ||
485 | */ | ||
486 | static int wlan_subcmd_setprescan_ioctl(wlan_private * priv, struct iwreq *wrq) | ||
487 | { | ||
488 | int data; | ||
489 | wlan_adapter *adapter = priv->adapter; | ||
490 | int *val; | ||
491 | |||
492 | data = SUBCMD_DATA(wrq); | ||
493 | lbs_pr_debug(1, "WLAN_SUBCMD_SET_PRESCAN %d\n", data); | ||
494 | adapter->prescan = data; | ||
495 | |||
496 | val = (int *)wrq->u.name; | ||
497 | *val = data; | ||
498 | return 0; | ||
499 | } | ||
500 | |||
501 | static int wlan_set_multiple_dtim_ioctl(wlan_private * priv, struct ifreq *req) | ||
502 | { | ||
503 | struct iwreq *wrq = (struct iwreq *)req; | ||
504 | u32 mdtim; | ||
505 | int idata; | ||
506 | int ret = -EINVAL; | ||
507 | |||
508 | ENTER(); | ||
509 | |||
510 | idata = SUBCMD_DATA(wrq); | ||
511 | mdtim = (u32) idata; | ||
512 | if (((mdtim >= MRVDRV_MIN_MULTIPLE_DTIM) | ||
513 | && (mdtim <= MRVDRV_MAX_MULTIPLE_DTIM)) | ||
514 | || (mdtim == MRVDRV_IGNORE_MULTIPLE_DTIM)) { | ||
515 | priv->adapter->multipledtim = mdtim; | ||
516 | ret = 0; | ||
517 | } | ||
518 | if (ret) | ||
519 | lbs_pr_debug(1, "Invalid parameter, multipledtim not changed.\n"); | ||
520 | |||
521 | LEAVE(); | ||
522 | return ret; | ||
523 | } | ||
524 | |||
525 | static void adjust_mtu(wlan_private * priv) | ||
526 | { | ||
527 | int mtu_increment = 0; | ||
528 | |||
529 | if (priv->adapter->linkmode == WLAN_LINKMODE_802_11) | ||
530 | mtu_increment += sizeof(struct ieee80211_hdr_4addr); | ||
531 | |||
532 | if (priv->adapter->radiomode == WLAN_RADIOMODE_RADIOTAP) | ||
533 | mtu_increment += max(sizeof(struct tx_radiotap_hdr), | ||
534 | sizeof(struct rx_radiotap_hdr)); | ||
535 | priv->wlan_dev.netdev->mtu = ETH_FRAME_LEN | ||
536 | - sizeof(struct ethhdr) | ||
537 | + mtu_increment; | ||
538 | } | ||
539 | |||
540 | /** | ||
541 | * @brief Set Link-Layer Layer mode | ||
542 | * @param priv A pointer to wlan_private structure | ||
543 | * @param req A pointer to ifreq structure | ||
544 | * @return 0 --success, otherwise fail | ||
545 | */ | ||
546 | static int wlan_set_linkmode_ioctl(wlan_private * priv, struct ifreq *req) | ||
547 | { | ||
548 | int mode; | ||
549 | |||
550 | mode = (int)((struct ifreq *)((u8 *) req + 4))->ifr_data; | ||
551 | |||
552 | switch (mode) { | ||
553 | case WLAN_LINKMODE_802_3: | ||
554 | priv->adapter->linkmode = mode; | ||
555 | break; | ||
556 | case WLAN_LINKMODE_802_11: | ||
557 | priv->adapter->linkmode = mode; | ||
558 | break; | ||
559 | default: | ||
560 | lbs_pr_info("usb8388-5: invalid link-layer mode (%#x)\n", | ||
561 | mode); | ||
562 | return -EINVAL; | ||
563 | break; | ||
564 | } | ||
565 | lbs_pr_debug(1, "usb8388-5: link-layer mode is %#x\n", mode); | ||
566 | |||
567 | adjust_mtu(priv); | ||
568 | |||
569 | return 0; | ||
570 | } | ||
571 | |||
572 | /** | ||
573 | * @brief Set Radio header mode | ||
574 | * @param priv A pointer to wlan_private structure | ||
575 | * @param req A pointer to ifreq structure | ||
576 | * @return 0 --success, otherwise fail | ||
577 | */ | ||
578 | static int wlan_set_radiomode_ioctl(wlan_private * priv, struct ifreq *req) | ||
579 | { | ||
580 | int mode; | ||
581 | |||
582 | mode = (int)((struct ifreq *)((u8 *) req + 4))->ifr_data; | ||
583 | |||
584 | switch (mode) { | ||
585 | case WLAN_RADIOMODE_NONE: | ||
586 | priv->adapter->radiomode = mode; | ||
587 | break; | ||
588 | case WLAN_RADIOMODE_RADIOTAP: | ||
589 | priv->adapter->radiomode = mode; | ||
590 | break; | ||
591 | default: | ||
592 | lbs_pr_debug(1, "usb8388-5: invalid radio header mode (%#x)\n", | ||
593 | mode); | ||
594 | return -EINVAL; | ||
595 | } | ||
596 | lbs_pr_debug(1, "usb8388-5: radio-header mode is %#x\n", mode); | ||
597 | |||
598 | adjust_mtu(priv); | ||
599 | return 0; | ||
600 | } | ||
601 | |||
602 | /** | ||
603 | * @brief Set Debug header mode | ||
604 | * @param priv A pointer to wlan_private structure | ||
605 | * @param req A pointer to ifreq structure | ||
606 | * @return 0 --success, otherwise fail | ||
607 | */ | ||
608 | static int wlan_set_debugmode_ioctl(wlan_private * priv, struct ifreq *req) | ||
609 | { | ||
610 | priv->adapter->debugmode = (int)((struct ifreq *) | ||
611 | ((u8 *) req + 4))->ifr_data; | ||
612 | return 0; | ||
613 | } | ||
614 | |||
615 | static int wlan_subcmd_getrxantenna_ioctl(wlan_private * priv, | ||
616 | struct ifreq *req) | ||
617 | { | ||
618 | int len; | ||
619 | char buf[8]; | ||
620 | struct iwreq *wrq = (struct iwreq *)req; | ||
621 | |||
622 | lbs_pr_debug(1, "WLAN_SUBCMD_GETRXANTENNA\n"); | ||
623 | len = getrxantenna(priv, buf); | ||
624 | |||
625 | wrq->u.data.length = len; | ||
626 | if (wrq->u.data.pointer) { | ||
627 | if (copy_to_user(wrq->u.data.pointer, &buf, len)) { | ||
628 | lbs_pr_debug(1, "CopyToUser failed\n"); | ||
629 | return -EFAULT; | ||
630 | } | ||
631 | } | ||
632 | |||
633 | return 0; | ||
634 | } | ||
635 | |||
636 | static int wlan_subcmd_gettxantenna_ioctl(wlan_private * priv, | ||
637 | struct ifreq *req) | ||
638 | { | ||
639 | int len; | ||
640 | char buf[8]; | ||
641 | struct iwreq *wrq = (struct iwreq *)req; | ||
642 | |||
643 | lbs_pr_debug(1, "WLAN_SUBCMD_GETTXANTENNA\n"); | ||
644 | len = gettxantenna(priv, buf); | ||
645 | |||
646 | wrq->u.data.length = len; | ||
647 | if (wrq->u.data.pointer) { | ||
648 | if (copy_to_user(wrq->u.data.pointer, &buf, len)) { | ||
649 | lbs_pr_debug(1, "CopyToUser failed\n"); | ||
650 | return -EFAULT; | ||
651 | } | ||
652 | } | ||
653 | return 0; | ||
654 | } | ||
655 | |||
656 | /** | ||
657 | * @brief Get the MAC TSF value from the firmware | ||
658 | * | ||
659 | * @param priv A pointer to wlan_private structure | ||
660 | * @param wrq A pointer to iwreq structure containing buffer | ||
661 | * space to store a TSF value retrieved from the firmware | ||
662 | * | ||
663 | * @return 0 if successful; IOCTL error code otherwise | ||
664 | */ | ||
665 | static int wlan_get_tsf_ioctl(wlan_private * priv, struct iwreq *wrq) | ||
666 | { | ||
667 | u64 tsfval; | ||
668 | int ret; | ||
669 | |||
670 | ret = libertas_prepare_and_send_command(priv, | ||
671 | cmd_get_tsf, | ||
672 | 0, cmd_option_waitforrsp, 0, &tsfval); | ||
673 | |||
674 | lbs_pr_debug(1, "IOCTL: Get TSF = 0x%016llx\n", tsfval); | ||
675 | |||
676 | if (ret != 0) { | ||
677 | lbs_pr_debug(1, "IOCTL: Get TSF; command exec failed\n"); | ||
678 | ret = -EFAULT; | ||
679 | } else { | ||
680 | if (copy_to_user(wrq->u.data.pointer, | ||
681 | &tsfval, | ||
682 | min_t(size_t, wrq->u.data.length, | ||
683 | sizeof(tsfval))) != 0) { | ||
684 | |||
685 | lbs_pr_debug(1, "IOCTL: Get TSF; Copy to user failed\n"); | ||
686 | ret = -EFAULT; | ||
687 | } else { | ||
688 | ret = 0; | ||
689 | } | ||
690 | } | ||
691 | return ret; | ||
692 | } | ||
693 | |||
694 | /** | ||
695 | * @brief Get/Set adapt rate | ||
696 | * @param priv A pointer to wlan_private structure | ||
697 | * @param wrq A pointer to iwreq structure | ||
698 | * @return 0 --success, otherwise fail | ||
699 | */ | ||
700 | static int wlan_adapt_rateset(wlan_private * priv, struct iwreq *wrq) | ||
701 | { | ||
702 | int ret; | ||
703 | wlan_adapter *adapter = priv->adapter; | ||
704 | int data[2]; | ||
705 | |||
706 | memset(data, 0, sizeof(data)); | ||
707 | if (!wrq->u.data.length) { | ||
708 | lbs_pr_debug(1, "Get ADAPT RATE SET\n"); | ||
709 | ret = libertas_prepare_and_send_command(priv, | ||
710 | cmd_802_11_rate_adapt_rateset, | ||
711 | cmd_act_get, | ||
712 | cmd_option_waitforrsp, 0, NULL); | ||
713 | data[0] = adapter->enablehwauto; | ||
714 | data[1] = adapter->ratebitmap; | ||
715 | if (copy_to_user(wrq->u.data.pointer, data, sizeof(int) * 2)) { | ||
716 | lbs_pr_debug(1, "Copy to user failed\n"); | ||
717 | return -EFAULT; | ||
718 | } | ||
719 | #define GET_TWO_INT 2 | ||
720 | wrq->u.data.length = GET_TWO_INT; | ||
721 | } else { | ||
722 | lbs_pr_debug(1, "Set ADAPT RATE SET\n"); | ||
723 | if (wrq->u.data.length > 2) | ||
724 | return -EINVAL; | ||
725 | if (copy_from_user | ||
726 | (data, wrq->u.data.pointer, | ||
727 | sizeof(int) * wrq->u.data.length)) { | ||
728 | lbs_pr_debug(1, "Copy from user failed\n"); | ||
729 | return -EFAULT; | ||
730 | } | ||
731 | |||
732 | adapter->enablehwauto = data[0]; | ||
733 | adapter->ratebitmap = data[1]; | ||
734 | ret = libertas_prepare_and_send_command(priv, | ||
735 | cmd_802_11_rate_adapt_rateset, | ||
736 | cmd_act_set, | ||
737 | cmd_option_waitforrsp, 0, NULL); | ||
738 | } | ||
739 | return ret; | ||
740 | } | ||
741 | |||
742 | /** | ||
743 | * @brief Get/Set inactivity timeout | ||
744 | * @param priv A pointer to wlan_private structure | ||
745 | * @param wrq A pointer to iwreq structure | ||
746 | * @return 0 --success, otherwise fail | ||
747 | */ | ||
748 | static int wlan_inactivity_timeout(wlan_private * priv, struct iwreq *wrq) | ||
749 | { | ||
750 | int ret; | ||
751 | int data = 0; | ||
752 | u16 timeout = 0; | ||
753 | |||
754 | ENTER(); | ||
755 | if (wrq->u.data.length > 1) | ||
756 | return -ENOTSUPP; | ||
757 | |||
758 | if (wrq->u.data.length == 0) { | ||
759 | /* Get */ | ||
760 | ret = libertas_prepare_and_send_command(priv, | ||
761 | cmd_802_11_inactivity_timeout, | ||
762 | cmd_act_get, | ||
763 | cmd_option_waitforrsp, 0, | ||
764 | &timeout); | ||
765 | data = timeout; | ||
766 | if (copy_to_user(wrq->u.data.pointer, &data, sizeof(int))) { | ||
767 | lbs_pr_debug(1, "Copy to user failed\n"); | ||
768 | return -EFAULT; | ||
769 | } | ||
770 | } else { | ||
771 | /* Set */ | ||
772 | if (copy_from_user(&data, wrq->u.data.pointer, sizeof(int))) { | ||
773 | lbs_pr_debug(1, "Copy from user failed\n"); | ||
774 | return -EFAULT; | ||
775 | } | ||
776 | |||
777 | timeout = data; | ||
778 | ret = libertas_prepare_and_send_command(priv, | ||
779 | cmd_802_11_inactivity_timeout, | ||
780 | cmd_act_set, | ||
781 | cmd_option_waitforrsp, 0, | ||
782 | &timeout); | ||
783 | } | ||
784 | |||
785 | wrq->u.data.length = 1; | ||
786 | |||
787 | LEAVE(); | ||
788 | return ret; | ||
789 | } | ||
790 | |||
791 | static int wlan_do_getlog_ioctl(wlan_private * priv, struct iwreq *wrq) | ||
792 | { | ||
793 | int ret; | ||
794 | char buf[GETLOG_BUFSIZE - 1]; | ||
795 | wlan_adapter *adapter = priv->adapter; | ||
796 | |||
797 | lbs_pr_debug(1, " GET STATS\n"); | ||
798 | |||
799 | ret = libertas_prepare_and_send_command(priv, cmd_802_11_get_log, | ||
800 | 0, cmd_option_waitforrsp, 0, NULL); | ||
801 | |||
802 | if (ret) { | ||
803 | return ret; | ||
804 | } | ||
805 | |||
806 | if (wrq->u.data.pointer) { | ||
807 | sprintf(buf, "\n mcasttxframe %u failed %u retry %u " | ||
808 | "multiretry %u framedup %u " | ||
809 | "rtssuccess %u rtsfailure %u ackfailure %u\n" | ||
810 | "rxfrag %u mcastrxframe %u fcserror %u " | ||
811 | "txframe %u wepundecryptable %u ", | ||
812 | adapter->logmsg.mcasttxframe, | ||
813 | adapter->logmsg.failed, | ||
814 | adapter->logmsg.retry, | ||
815 | adapter->logmsg.multiretry, | ||
816 | adapter->logmsg.framedup, | ||
817 | adapter->logmsg.rtssuccess, | ||
818 | adapter->logmsg.rtsfailure, | ||
819 | adapter->logmsg.ackfailure, | ||
820 | adapter->logmsg.rxfrag, | ||
821 | adapter->logmsg.mcastrxframe, | ||
822 | adapter->logmsg.fcserror, | ||
823 | adapter->logmsg.txframe, | ||
824 | adapter->logmsg.wepundecryptable); | ||
825 | wrq->u.data.length = strlen(buf) + 1; | ||
826 | if (copy_to_user(wrq->u.data.pointer, buf, wrq->u.data.length)) { | ||
827 | lbs_pr_debug(1, "Copy to user failed\n"); | ||
828 | return -EFAULT; | ||
829 | } | ||
830 | } | ||
831 | |||
832 | return 0; | ||
833 | } | ||
834 | |||
835 | static int wlan_scan_type_ioctl(wlan_private * priv, struct iwreq *wrq) | ||
836 | { | ||
837 | u8 buf[12]; | ||
838 | u8 *option[] = { "active", "passive", "get", }; | ||
839 | int i, max_options = (sizeof(option) / sizeof(option[0])); | ||
840 | int ret = 0; | ||
841 | wlan_adapter *adapter = priv->adapter; | ||
842 | |||
843 | if (priv->adapter->enable11d) { | ||
844 | lbs_pr_debug(1, "11D: Cannot set scantype when 11D enabled\n"); | ||
845 | return -EFAULT; | ||
846 | } | ||
847 | |||
848 | memset(buf, 0, sizeof(buf)); | ||
849 | |||
850 | if (copy_from_user(buf, wrq->u.data.pointer, min_t(size_t, sizeof(buf), | ||
851 | wrq->u.data.length))) | ||
852 | return -EFAULT; | ||
853 | |||
854 | lbs_pr_debug(1, "Scan type Option = %s\n", buf); | ||
855 | |||
856 | buf[sizeof(buf) - 1] = '\0'; | ||
857 | |||
858 | for (i = 0; i < max_options; i++) { | ||
859 | if (!strcmp(buf, option[i])) | ||
860 | break; | ||
861 | } | ||
862 | |||
863 | switch (i) { | ||
864 | case 0: | ||
865 | adapter->scantype = cmd_scan_type_active; | ||
866 | break; | ||
867 | case 1: | ||
868 | adapter->scantype = cmd_scan_type_passive; | ||
869 | break; | ||
870 | case 2: | ||
871 | wrq->u.data.length = strlen(option[adapter->scantype]) + 1; | ||
872 | |||
873 | if (copy_to_user(wrq->u.data.pointer, | ||
874 | option[adapter->scantype], | ||
875 | wrq->u.data.length)) { | ||
876 | lbs_pr_debug(1, "Copy to user failed\n"); | ||
877 | ret = -EFAULT; | ||
878 | } | ||
879 | |||
880 | break; | ||
881 | default: | ||
882 | lbs_pr_debug(1, "Invalid Scan type Ioctl Option\n"); | ||
883 | ret = -EINVAL; | ||
884 | break; | ||
885 | } | ||
886 | |||
887 | return ret; | ||
888 | } | ||
889 | |||
890 | static int wlan_scan_mode_ioctl(wlan_private * priv, struct iwreq *wrq) | ||
891 | { | ||
892 | wlan_adapter *adapter = priv->adapter; | ||
893 | u8 buf[12]; | ||
894 | u8 *option[] = { "bss", "ibss", "any", "get" }; | ||
895 | int i, max_options = (sizeof(option) / sizeof(option[0])); | ||
896 | int ret = 0; | ||
897 | |||
898 | ENTER(); | ||
899 | |||
900 | memset(buf, 0, sizeof(buf)); | ||
901 | |||
902 | if (copy_from_user(buf, wrq->u.data.pointer, min_t(size_t, sizeof(buf), | ||
903 | wrq->u.data.length))) { | ||
904 | lbs_pr_debug(1, "Copy from user failed\n"); | ||
905 | return -EFAULT; | ||
906 | } | ||
907 | |||
908 | lbs_pr_debug(1, "Scan mode Option = %s\n", buf); | ||
909 | |||
910 | buf[sizeof(buf) - 1] = '\0'; | ||
911 | |||
912 | for (i = 0; i < max_options; i++) { | ||
913 | if (!strcmp(buf, option[i])) | ||
914 | break; | ||
915 | } | ||
916 | |||
917 | switch (i) { | ||
918 | |||
919 | case 0: | ||
920 | adapter->scanmode = cmd_bss_type_bss; | ||
921 | break; | ||
922 | case 1: | ||
923 | adapter->scanmode = cmd_bss_type_ibss; | ||
924 | break; | ||
925 | case 2: | ||
926 | adapter->scanmode = cmd_bss_type_any; | ||
927 | break; | ||
928 | case 3: | ||
929 | |||
930 | wrq->u.data.length = strlen(option[adapter->scanmode - 1]) + 1; | ||
931 | |||
932 | lbs_pr_debug(1, "Get Scan mode Option = %s\n", | ||
933 | option[adapter->scanmode - 1]); | ||
934 | |||
935 | lbs_pr_debug(1, "Scan mode length %d\n", wrq->u.data.length); | ||
936 | |||
937 | if (copy_to_user(wrq->u.data.pointer, | ||
938 | option[adapter->scanmode - 1], | ||
939 | wrq->u.data.length)) { | ||
940 | lbs_pr_debug(1, "Copy to user failed\n"); | ||
941 | ret = -EFAULT; | ||
942 | } | ||
943 | lbs_pr_debug(1, "GET Scan type Option after copy = %s\n", | ||
944 | (char *)wrq->u.data.pointer); | ||
945 | |||
946 | break; | ||
947 | |||
948 | default: | ||
949 | lbs_pr_debug(1, "Invalid Scan mode Ioctl Option\n"); | ||
950 | ret = -EINVAL; | ||
951 | break; | ||
952 | } | ||
953 | |||
954 | LEAVE(); | ||
955 | return ret; | ||
956 | } | ||
957 | |||
958 | /** | ||
959 | * @brief Get/Set Adhoc G Rate | ||
960 | * | ||
961 | * @param priv A pointer to wlan_private structure | ||
962 | * @param wrq A pointer to user data | ||
963 | * @return 0--success, otherwise fail | ||
964 | */ | ||
965 | static int wlan_do_set_grate_ioctl(wlan_private * priv, struct iwreq *wrq) | ||
966 | { | ||
967 | wlan_adapter *adapter = priv->adapter; | ||
968 | int data, data1; | ||
969 | int *val; | ||
970 | |||
971 | ENTER(); | ||
972 | |||
973 | data1 = SUBCMD_DATA(wrq); | ||
974 | switch (data1) { | ||
975 | case 0: | ||
976 | adapter->adhoc_grate_enabled = 0; | ||
977 | break; | ||
978 | case 1: | ||
979 | adapter->adhoc_grate_enabled = 1; | ||
980 | break; | ||
981 | case 2: | ||
982 | break; | ||
983 | default: | ||
984 | return -EINVAL; | ||
985 | } | ||
986 | data = adapter->adhoc_grate_enabled; | ||
987 | val = (int *)wrq->u.name; | ||
988 | *val = data; | ||
989 | LEAVE(); | ||
990 | return 0; | ||
991 | } | ||
992 | |||
993 | static inline int hex2int(char c) | 58 | static inline int hex2int(char c) |
994 | { | 59 | { |
995 | if (c >= '0' && c <= '9') | 60 | if (c >= '0' && c <= '9') |
@@ -1752,36 +817,8 @@ int libertas_do_ioctl(struct net_device *dev, struct ifreq *req, int cmd) | |||
1752 | 817 | ||
1753 | lbs_pr_debug(1, "libertas_do_ioctl: ioctl cmd = 0x%x\n", cmd); | 818 | lbs_pr_debug(1, "libertas_do_ioctl: ioctl cmd = 0x%x\n", cmd); |
1754 | switch (cmd) { | 819 | switch (cmd) { |
1755 | case WLANSCAN_TYPE: | ||
1756 | lbs_pr_debug(1, "Scan type Ioctl\n"); | ||
1757 | ret = wlan_scan_type_ioctl(priv, wrq); | ||
1758 | break; | ||
1759 | |||
1760 | case WLAN_SETNONE_GETNONE: /* set WPA mode on/off ioctl #20 */ | 820 | case WLAN_SETNONE_GETNONE: /* set WPA mode on/off ioctl #20 */ |
1761 | switch (wrq->u.data.flags) { | 821 | switch (wrq->u.data.flags) { |
1762 | case WLANDEAUTH: | ||
1763 | lbs_pr_debug(1, "Deauth\n"); | ||
1764 | libertas_send_deauth(priv); | ||
1765 | break; | ||
1766 | |||
1767 | case WLANADHOCSTOP: | ||
1768 | lbs_pr_debug(1, "Adhoc stop\n"); | ||
1769 | ret = libertas_do_adhocstop_ioctl(priv); | ||
1770 | break; | ||
1771 | |||
1772 | case WLANRADIOON: | ||
1773 | wlan_radio_ioctl(priv, 1); | ||
1774 | break; | ||
1775 | |||
1776 | case WLANRADIOOFF: | ||
1777 | wlan_radio_ioctl(priv, 0); | ||
1778 | break; | ||
1779 | case WLANWLANIDLEON: | ||
1780 | libertas_idle_on(priv); | ||
1781 | break; | ||
1782 | case WLANWLANIDLEOFF: | ||
1783 | libertas_idle_off(priv); | ||
1784 | break; | ||
1785 | case WLAN_SUBCMD_BT_RESET: /* bt_reset */ | 822 | case WLAN_SUBCMD_BT_RESET: /* bt_reset */ |
1786 | wlan_bt_reset_ioctl(priv); | 823 | wlan_bt_reset_ioctl(priv); |
1787 | break; | 824 | break; |
@@ -1791,81 +828,6 @@ int libertas_do_ioctl(struct net_device *dev, struct ifreq *req, int cmd) | |||
1791 | } /* End of switch */ | 828 | } /* End of switch */ |
1792 | break; | 829 | break; |
1793 | 830 | ||
1794 | case WLAN_SETINT_GETINT: | ||
1795 | /* The first 4 bytes of req->ifr_data is sub-ioctl number | ||
1796 | * after 4 bytes sits the payload. | ||
1797 | */ | ||
1798 | subcmd = (int)req->ifr_data; //from iwpriv subcmd | ||
1799 | switch (subcmd) { | ||
1800 | case WLANNF: | ||
1801 | ret = wlan_get_nf(priv, wrq); | ||
1802 | break; | ||
1803 | case WLANRSSI: | ||
1804 | ret = wlan_get_rssi(priv, wrq); | ||
1805 | break; | ||
1806 | case WLANENABLE11D: | ||
1807 | ret = libertas_cmd_enable_11d(priv, wrq); | ||
1808 | break; | ||
1809 | case WLANADHOCGRATE: | ||
1810 | ret = wlan_do_set_grate_ioctl(priv, wrq); | ||
1811 | break; | ||
1812 | case WLAN_SUBCMD_SET_PRESCAN: | ||
1813 | ret = wlan_subcmd_setprescan_ioctl(priv, wrq); | ||
1814 | break; | ||
1815 | } | ||
1816 | break; | ||
1817 | |||
1818 | case WLAN_SETONEINT_GETONEINT: | ||
1819 | switch (wrq->u.data.flags) { | ||
1820 | case WLAN_BEACON_INTERVAL: | ||
1821 | ret = wlan_beacon_interval(priv, wrq); | ||
1822 | break; | ||
1823 | |||
1824 | case WLAN_LISTENINTRVL: | ||
1825 | if (!wrq->u.data.length) { | ||
1826 | int data; | ||
1827 | lbs_pr_debug(1, "Get locallisteninterval value\n"); | ||
1828 | #define GET_ONE_INT 1 | ||
1829 | data = adapter->locallisteninterval; | ||
1830 | if (copy_to_user(wrq->u.data.pointer, | ||
1831 | &data, sizeof(int))) { | ||
1832 | lbs_pr_debug(1, "Copy to user failed\n"); | ||
1833 | return -EFAULT; | ||
1834 | } | ||
1835 | |||
1836 | wrq->u.data.length = GET_ONE_INT; | ||
1837 | } else { | ||
1838 | int data; | ||
1839 | if (copy_from_user | ||
1840 | (&data, wrq->u.data.pointer, sizeof(int))) { | ||
1841 | lbs_pr_debug(1, "Copy from user failed\n"); | ||
1842 | return -EFAULT; | ||
1843 | } | ||
1844 | |||
1845 | lbs_pr_debug(1, "Set locallisteninterval = %d\n", | ||
1846 | data); | ||
1847 | #define MAX_U16_VAL 65535 | ||
1848 | if (data > MAX_U16_VAL) { | ||
1849 | lbs_pr_debug(1, "Exceeds U16 value\n"); | ||
1850 | return -EINVAL; | ||
1851 | } | ||
1852 | adapter->locallisteninterval = data; | ||
1853 | } | ||
1854 | break; | ||
1855 | case WLAN_TXCONTROL: | ||
1856 | ret = wlan_txcontrol(priv, wrq); //adds for txcontrol ioctl | ||
1857 | break; | ||
1858 | |||
1859 | case WLAN_NULLPKTINTERVAL: | ||
1860 | ret = wlan_null_pkt_interval(priv, wrq); | ||
1861 | break; | ||
1862 | |||
1863 | default: | ||
1864 | ret = -EOPNOTSUPP; | ||
1865 | break; | ||
1866 | } | ||
1867 | break; | ||
1868 | |||
1869 | case WLAN_SETONEINT_GETNONE: | 831 | case WLAN_SETONEINT_GETNONE: |
1870 | /* The first 4 bytes of req->ifr_data is sub-ioctl number | 832 | /* The first 4 bytes of req->ifr_data is sub-ioctl number |
1871 | * after 4 bytes sits the payload. | 833 | * after 4 bytes sits the payload. |
@@ -1876,62 +838,10 @@ int libertas_do_ioctl(struct net_device *dev, struct ifreq *req, int cmd) | |||
1876 | subcmd = (int)req->ifr_data; //from iwpriv subcmd | 838 | subcmd = (int)req->ifr_data; //from iwpriv subcmd |
1877 | 839 | ||
1878 | switch (subcmd) { | 840 | switch (subcmd) { |
1879 | case WLAN_SUBCMD_SETRXANTENNA: /* SETRXANTENNA */ | ||
1880 | idata = SUBCMD_DATA(wrq); | ||
1881 | ret = setrxantenna(priv, idata); | ||
1882 | break; | ||
1883 | case WLAN_SUBCMD_SETTXANTENNA: /* SETTXANTENNA */ | ||
1884 | idata = SUBCMD_DATA(wrq); | ||
1885 | ret = settxantenna(priv, idata); | ||
1886 | break; | ||
1887 | case WLAN_SET_ATIM_WINDOW: | ||
1888 | adapter->atimwindow = SUBCMD_DATA(wrq); | ||
1889 | adapter->atimwindow = min_t(__u16, adapter->atimwindow, 50); | ||
1890 | break; | ||
1891 | case WLANSETBCNAVG: | ||
1892 | adapter->bcn_avg_factor = SUBCMD_DATA(wrq); | ||
1893 | if (adapter->bcn_avg_factor == 0) | ||
1894 | adapter->bcn_avg_factor = | ||
1895 | DEFAULT_BCN_AVG_FACTOR; | ||
1896 | if (adapter->bcn_avg_factor > DEFAULT_BCN_AVG_FACTOR) | ||
1897 | adapter->bcn_avg_factor = | ||
1898 | DEFAULT_BCN_AVG_FACTOR; | ||
1899 | break; | ||
1900 | case WLANSETDATAAVG: | ||
1901 | adapter->data_avg_factor = SUBCMD_DATA(wrq); | ||
1902 | if (adapter->data_avg_factor == 0) | ||
1903 | adapter->data_avg_factor = | ||
1904 | DEFAULT_DATA_AVG_FACTOR; | ||
1905 | if (adapter->data_avg_factor > DEFAULT_DATA_AVG_FACTOR) | ||
1906 | adapter->data_avg_factor = | ||
1907 | DEFAULT_DATA_AVG_FACTOR; | ||
1908 | break; | ||
1909 | case WLANSETREGION: | 841 | case WLANSETREGION: |
1910 | idata = SUBCMD_DATA(wrq); | 842 | idata = SUBCMD_DATA(wrq); |
1911 | ret = wlan_set_region(priv, (u16) idata); | 843 | ret = wlan_set_region(priv, (u16) idata); |
1912 | break; | 844 | break; |
1913 | |||
1914 | case WLAN_SET_LISTEN_INTERVAL: | ||
1915 | idata = SUBCMD_DATA(wrq); | ||
1916 | adapter->listeninterval = (u16) idata; | ||
1917 | break; | ||
1918 | |||
1919 | case WLAN_SET_MULTIPLE_DTIM: | ||
1920 | ret = wlan_set_multiple_dtim_ioctl(priv, req); | ||
1921 | break; | ||
1922 | |||
1923 | case WLAN_SET_LINKMODE: | ||
1924 | ret = wlan_set_linkmode_ioctl(priv, req); | ||
1925 | break; | ||
1926 | |||
1927 | case WLAN_SET_RADIOMODE: | ||
1928 | ret = wlan_set_radiomode_ioctl(priv, req); | ||
1929 | break; | ||
1930 | |||
1931 | case WLAN_SET_DEBUGMODE: | ||
1932 | ret = wlan_set_debugmode_ioctl(priv, req); | ||
1933 | break; | ||
1934 | |||
1935 | case WLAN_SUBCMD_MESH_SET_TTL: | 845 | case WLAN_SUBCMD_MESH_SET_TTL: |
1936 | idata = SUBCMD_DATA(wrq); | 846 | idata = SUBCMD_DATA(wrq); |
1937 | ret = wlan_mesh_set_ttl_ioctl(priv, idata); | 847 | ret = wlan_mesh_set_ttl_ioctl(priv, idata); |
@@ -1944,38 +854,8 @@ int libertas_do_ioctl(struct net_device *dev, struct ifreq *req, int cmd) | |||
1944 | 854 | ||
1945 | break; | 855 | break; |
1946 | 856 | ||
1947 | case WLAN_SETNONE_GETTWELVE_CHAR: /* Get Antenna settings */ | ||
1948 | /* | ||
1949 | * We've not used IW_PRIV_TYPE_FIXED so sub-ioctl number is | ||
1950 | * in flags of iwreq structure, otherwise it will be in | ||
1951 | * mode member of iwreq structure. | ||
1952 | */ | ||
1953 | switch ((int)wrq->u.data.flags) { | ||
1954 | case WLAN_SUBCMD_GETRXANTENNA: /* Get Rx Antenna */ | ||
1955 | ret = wlan_subcmd_getrxantenna_ioctl(priv, req); | ||
1956 | break; | ||
1957 | |||
1958 | case WLAN_SUBCMD_GETTXANTENNA: /* Get Tx Antenna */ | ||
1959 | ret = wlan_subcmd_gettxantenna_ioctl(priv, req); | ||
1960 | break; | ||
1961 | |||
1962 | case WLAN_GET_TSF: | ||
1963 | ret = wlan_get_tsf_ioctl(priv, wrq); | ||
1964 | break; | ||
1965 | } | ||
1966 | break; | ||
1967 | |||
1968 | case WLAN_SET128CHAR_GET128CHAR: | 857 | case WLAN_SET128CHAR_GET128CHAR: |
1969 | switch ((int)wrq->u.data.flags) { | 858 | switch ((int)wrq->u.data.flags) { |
1970 | |||
1971 | case WLANSCAN_MODE: | ||
1972 | lbs_pr_debug(1, "Scan mode Ioctl\n"); | ||
1973 | ret = wlan_scan_mode_ioctl(priv, wrq); | ||
1974 | break; | ||
1975 | |||
1976 | case WLAN_GET_ADHOC_STATUS: | ||
1977 | ret = wlan_get_adhoc_status_ioctl(priv, wrq); | ||
1978 | break; | ||
1979 | case WLAN_SUBCMD_BT_ADD: | 859 | case WLAN_SUBCMD_BT_ADD: |
1980 | ret = wlan_bt_add_ioctl(priv, req); | 860 | ret = wlan_bt_add_ioctl(priv, req); |
1981 | break; | 861 | break; |
@@ -2008,40 +888,10 @@ int libertas_do_ioctl(struct net_device *dev, struct ifreq *req, int cmd) | |||
2008 | 888 | ||
2009 | case WLAN_SETNONE_GETONEINT: | 889 | case WLAN_SETNONE_GETONEINT: |
2010 | switch ((int)req->ifr_data) { | 890 | switch ((int)req->ifr_data) { |
2011 | case WLANGETBCNAVG: | ||
2012 | pdata = (int *)wrq->u.name; | ||
2013 | *pdata = (int)adapter->bcn_avg_factor; | ||
2014 | break; | ||
2015 | |||
2016 | case WLANGETREGION: | 891 | case WLANGETREGION: |
2017 | pdata = (int *)wrq->u.name; | 892 | pdata = (int *)wrq->u.name; |
2018 | *pdata = (int)adapter->regioncode; | 893 | *pdata = (int)adapter->regioncode; |
2019 | break; | 894 | break; |
2020 | |||
2021 | case WLAN_GET_LISTEN_INTERVAL: | ||
2022 | pdata = (int *)wrq->u.name; | ||
2023 | *pdata = (int)adapter->listeninterval; | ||
2024 | break; | ||
2025 | |||
2026 | case WLAN_GET_LINKMODE: | ||
2027 | req->ifr_data = (char *)((u32) adapter->linkmode); | ||
2028 | break; | ||
2029 | |||
2030 | case WLAN_GET_RADIOMODE: | ||
2031 | req->ifr_data = (char *)((u32) adapter->radiomode); | ||
2032 | break; | ||
2033 | |||
2034 | case WLAN_GET_DEBUGMODE: | ||
2035 | req->ifr_data = (char *)((u32) adapter->debugmode); | ||
2036 | break; | ||
2037 | |||
2038 | case WLAN_GET_MULTIPLE_DTIM: | ||
2039 | pdata = (int *)wrq->u.name; | ||
2040 | *pdata = (int)adapter->multipledtim; | ||
2041 | break; | ||
2042 | case WLAN_GET_TX_RATE: | ||
2043 | ret = wlan_get_txrate_ioctl(priv, req); | ||
2044 | break; | ||
2045 | case WLAN_SUBCMD_FWT_CLEANUP: /* fwt_cleanup */ | 895 | case WLAN_SUBCMD_FWT_CLEANUP: /* fwt_cleanup */ |
2046 | ret = wlan_fwt_cleanup_ioctl(priv, req); | 896 | ret = wlan_fwt_cleanup_ioctl(priv, req); |
2047 | break; | 897 | break; |
@@ -2061,196 +911,8 @@ int libertas_do_ioctl(struct net_device *dev, struct ifreq *req, int cmd) | |||
2061 | 911 | ||
2062 | break; | 912 | break; |
2063 | 913 | ||
2064 | case WLANGETLOG: | ||
2065 | ret = wlan_do_getlog_ioctl(priv, wrq); | ||
2066 | break; | ||
2067 | |||
2068 | case WLAN_SET_GET_SIXTEEN_INT: | 914 | case WLAN_SET_GET_SIXTEEN_INT: |
2069 | switch ((int)wrq->u.data.flags) { | 915 | switch ((int)wrq->u.data.flags) { |
2070 | case WLAN_TPCCFG: | ||
2071 | { | ||
2072 | int data[5]; | ||
2073 | struct cmd_ds_802_11_tpc_cfg cfg; | ||
2074 | memset(&cfg, 0, sizeof(cfg)); | ||
2075 | if ((wrq->u.data.length > 1) | ||
2076 | && (wrq->u.data.length != 5)) | ||
2077 | return -1; | ||
2078 | |||
2079 | if (wrq->u.data.length == 0) { | ||
2080 | cfg.action = | ||
2081 | cpu_to_le16 | ||
2082 | (cmd_act_get); | ||
2083 | } else { | ||
2084 | if (copy_from_user | ||
2085 | (data, wrq->u.data.pointer, | ||
2086 | sizeof(int) * 5)) { | ||
2087 | lbs_pr_debug(1, | ||
2088 | "Copy from user failed\n"); | ||
2089 | return -EFAULT; | ||
2090 | } | ||
2091 | |||
2092 | cfg.action = | ||
2093 | cpu_to_le16 | ||
2094 | (cmd_act_set); | ||
2095 | cfg.enable = data[0]; | ||
2096 | cfg.usesnr = data[1]; | ||
2097 | cfg.P0 = data[2]; | ||
2098 | cfg.P1 = data[3]; | ||
2099 | cfg.P2 = data[4]; | ||
2100 | } | ||
2101 | |||
2102 | ret = | ||
2103 | libertas_prepare_and_send_command(priv, | ||
2104 | cmd_802_11_tpc_cfg, | ||
2105 | 0, | ||
2106 | cmd_option_waitforrsp, | ||
2107 | 0, (void *)&cfg); | ||
2108 | |||
2109 | data[0] = cfg.enable; | ||
2110 | data[1] = cfg.usesnr; | ||
2111 | data[2] = cfg.P0; | ||
2112 | data[3] = cfg.P1; | ||
2113 | data[4] = cfg.P2; | ||
2114 | if (copy_to_user | ||
2115 | (wrq->u.data.pointer, data, | ||
2116 | sizeof(int) * 5)) { | ||
2117 | lbs_pr_debug(1, "Copy to user failed\n"); | ||
2118 | return -EFAULT; | ||
2119 | } | ||
2120 | |||
2121 | wrq->u.data.length = 5; | ||
2122 | } | ||
2123 | break; | ||
2124 | |||
2125 | case WLAN_POWERCFG: | ||
2126 | { | ||
2127 | int data[4]; | ||
2128 | struct cmd_ds_802_11_pwr_cfg cfg; | ||
2129 | memset(&cfg, 0, sizeof(cfg)); | ||
2130 | if ((wrq->u.data.length > 1) | ||
2131 | && (wrq->u.data.length != 4)) | ||
2132 | return -1; | ||
2133 | if (wrq->u.data.length == 0) { | ||
2134 | cfg.action = | ||
2135 | cpu_to_le16 | ||
2136 | (cmd_act_get); | ||
2137 | } else { | ||
2138 | if (copy_from_user | ||
2139 | (data, wrq->u.data.pointer, | ||
2140 | sizeof(int) * 4)) { | ||
2141 | lbs_pr_debug(1, | ||
2142 | "Copy from user failed\n"); | ||
2143 | return -EFAULT; | ||
2144 | } | ||
2145 | |||
2146 | cfg.action = | ||
2147 | cpu_to_le16 | ||
2148 | (cmd_act_set); | ||
2149 | cfg.enable = data[0]; | ||
2150 | cfg.PA_P0 = data[1]; | ||
2151 | cfg.PA_P1 = data[2]; | ||
2152 | cfg.PA_P2 = data[3]; | ||
2153 | } | ||
2154 | ret = | ||
2155 | libertas_prepare_and_send_command(priv, | ||
2156 | cmd_802_11_pwr_cfg, | ||
2157 | 0, | ||
2158 | cmd_option_waitforrsp, | ||
2159 | 0, (void *)&cfg); | ||
2160 | data[0] = cfg.enable; | ||
2161 | data[1] = cfg.PA_P0; | ||
2162 | data[2] = cfg.PA_P1; | ||
2163 | data[3] = cfg.PA_P2; | ||
2164 | if (copy_to_user | ||
2165 | (wrq->u.data.pointer, data, | ||
2166 | sizeof(int) * 4)) { | ||
2167 | lbs_pr_debug(1, "Copy to user failed\n"); | ||
2168 | return -EFAULT; | ||
2169 | } | ||
2170 | |||
2171 | wrq->u.data.length = 4; | ||
2172 | } | ||
2173 | break; | ||
2174 | case WLAN_AUTO_FREQ_SET: | ||
2175 | { | ||
2176 | int data[3]; | ||
2177 | struct cmd_ds_802_11_afc afc; | ||
2178 | memset(&afc, 0, sizeof(afc)); | ||
2179 | if (wrq->u.data.length != 3) | ||
2180 | return -1; | ||
2181 | if (copy_from_user | ||
2182 | (data, wrq->u.data.pointer, | ||
2183 | sizeof(int) * 3)) { | ||
2184 | lbs_pr_debug(1, "Copy from user failed\n"); | ||
2185 | return -EFAULT; | ||
2186 | } | ||
2187 | afc.afc_auto = data[0]; | ||
2188 | |||
2189 | if (afc.afc_auto != 0) { | ||
2190 | afc.threshold = data[1]; | ||
2191 | afc.period = data[2]; | ||
2192 | } else { | ||
2193 | afc.timing_offset = data[1]; | ||
2194 | afc.carrier_offset = data[2]; | ||
2195 | } | ||
2196 | ret = | ||
2197 | libertas_prepare_and_send_command(priv, | ||
2198 | cmd_802_11_set_afc, | ||
2199 | 0, | ||
2200 | cmd_option_waitforrsp, | ||
2201 | 0, (void *)&afc); | ||
2202 | } | ||
2203 | break; | ||
2204 | case WLAN_AUTO_FREQ_GET: | ||
2205 | { | ||
2206 | int data[3]; | ||
2207 | struct cmd_ds_802_11_afc afc; | ||
2208 | memset(&afc, 0, sizeof(afc)); | ||
2209 | ret = | ||
2210 | libertas_prepare_and_send_command(priv, | ||
2211 | cmd_802_11_get_afc, | ||
2212 | 0, | ||
2213 | cmd_option_waitforrsp, | ||
2214 | 0, (void *)&afc); | ||
2215 | data[0] = afc.afc_auto; | ||
2216 | data[1] = afc.timing_offset; | ||
2217 | data[2] = afc.carrier_offset; | ||
2218 | if (copy_to_user | ||
2219 | (wrq->u.data.pointer, data, | ||
2220 | sizeof(int) * 3)) { | ||
2221 | lbs_pr_debug(1, "Copy to user failed\n"); | ||
2222 | return -EFAULT; | ||
2223 | } | ||
2224 | |||
2225 | wrq->u.data.length = 3; | ||
2226 | } | ||
2227 | break; | ||
2228 | case WLAN_SCANPROBES: | ||
2229 | { | ||
2230 | int data; | ||
2231 | if (wrq->u.data.length > 0) { | ||
2232 | if (copy_from_user | ||
2233 | (&data, wrq->u.data.pointer, | ||
2234 | sizeof(int))) { | ||
2235 | lbs_pr_debug(1, | ||
2236 | "Copy from user failed\n"); | ||
2237 | return -EFAULT; | ||
2238 | } | ||
2239 | |||
2240 | adapter->scanprobes = data; | ||
2241 | } else { | ||
2242 | data = adapter->scanprobes; | ||
2243 | if (copy_to_user | ||
2244 | (wrq->u.data.pointer, &data, | ||
2245 | sizeof(int))) { | ||
2246 | lbs_pr_debug(1, | ||
2247 | "Copy to user failed\n"); | ||
2248 | return -EFAULT; | ||
2249 | } | ||
2250 | } | ||
2251 | wrq->u.data.length = 1; | ||
2252 | } | ||
2253 | break; | ||
2254 | case WLAN_LED_GPIO_CTRL: | 916 | case WLAN_LED_GPIO_CTRL: |
2255 | { | 917 | { |
2256 | int i; | 918 | int i; |
@@ -2314,17 +976,6 @@ int libertas_do_ioctl(struct net_device *dev, struct ifreq *req, int cmd) | |||
2314 | wrq->u.data.length = gpio->header.len; | 976 | wrq->u.data.length = gpio->header.len; |
2315 | } | 977 | } |
2316 | break; | 978 | break; |
2317 | case WLAN_ADAPT_RATESET: | ||
2318 | ret = wlan_adapt_rateset(priv, wrq); | ||
2319 | break; | ||
2320 | case WLAN_INACTIVITY_TIMEOUT: | ||
2321 | ret = wlan_inactivity_timeout(priv, wrq); | ||
2322 | break; | ||
2323 | case WLANSNR: | ||
2324 | ret = wlan_get_snr(priv, wrq); | ||
2325 | break; | ||
2326 | case WLAN_GET_RXINFO: | ||
2327 | ret = wlan_get_rxinfo(priv, wrq); | ||
2328 | } | 979 | } |
2329 | break; | 980 | break; |
2330 | 981 | ||
diff --git a/drivers/net/wireless/libertas/join.c b/drivers/net/wireless/libertas/join.c index 2292c14a1531..ec40d32183ed 100644 --- a/drivers/net/wireless/libertas/join.c +++ b/drivers/net/wireless/libertas/join.c | |||
@@ -96,20 +96,6 @@ int libertas_send_deauth(wlan_private * priv) | |||
96 | return ret; | 96 | return ret; |
97 | } | 97 | } |
98 | 98 | ||
99 | int libertas_do_adhocstop_ioctl(wlan_private * priv) | ||
100 | { | ||
101 | wlan_adapter *adapter = priv->adapter; | ||
102 | int ret = 0; | ||
103 | |||
104 | if (adapter->mode == IW_MODE_ADHOC && | ||
105 | adapter->connect_status == libertas_connected) | ||
106 | ret = libertas_stop_adhoc_network(priv); | ||
107 | else | ||
108 | ret = -ENOTSUPP; | ||
109 | |||
110 | return ret; | ||
111 | } | ||
112 | |||
113 | /** | 99 | /** |
114 | * @brief Associate to a specific BSS discovered in a scan | 100 | * @brief Associate to a specific BSS discovered in a scan |
115 | * | 101 | * |
@@ -262,127 +248,6 @@ int libertas_send_deauthentication(wlan_private * priv) | |||
262 | } | 248 | } |
263 | 249 | ||
264 | /** | 250 | /** |
265 | * @brief Set Idle Off | ||
266 | * | ||
267 | * @param priv A pointer to wlan_private structure | ||
268 | * @return 0 --success, otherwise fail | ||
269 | */ | ||
270 | int libertas_idle_off(wlan_private * priv) | ||
271 | { | ||
272 | wlan_adapter *adapter = priv->adapter; | ||
273 | int ret = 0; | ||
274 | const u8 zeromac[] = { 0, 0, 0, 0, 0, 0 }; | ||
275 | int i; | ||
276 | |||
277 | ENTER(); | ||
278 | |||
279 | if (adapter->connect_status == libertas_disconnected) { | ||
280 | if (adapter->mode == IW_MODE_INFRA) { | ||
281 | if (memcmp(adapter->previousbssid, zeromac, | ||
282 | sizeof(zeromac)) != 0) { | ||
283 | |||
284 | lbs_pr_debug(1, "Previous SSID = %s\n", | ||
285 | adapter->previousssid.ssid); | ||
286 | lbs_pr_debug(1, "Previous BSSID = " | ||
287 | "%02x:%02x:%02x:%02x:%02x:%02x:\n", | ||
288 | adapter->previousbssid[0], | ||
289 | adapter->previousbssid[1], | ||
290 | adapter->previousbssid[2], | ||
291 | adapter->previousbssid[3], | ||
292 | adapter->previousbssid[4], | ||
293 | adapter->previousbssid[5]); | ||
294 | |||
295 | i = libertas_find_SSID_in_list(adapter, | ||
296 | &adapter->previousssid, | ||
297 | adapter->previousbssid, | ||
298 | adapter->mode); | ||
299 | |||
300 | if (i < 0) { | ||
301 | libertas_send_specific_BSSID_scan(priv, | ||
302 | adapter-> | ||
303 | previousbssid, | ||
304 | 1); | ||
305 | i = libertas_find_SSID_in_list(adapter, | ||
306 | &adapter-> | ||
307 | previousssid, | ||
308 | adapter-> | ||
309 | previousbssid, | ||
310 | adapter->mode); | ||
311 | } | ||
312 | |||
313 | if (i < 0) { | ||
314 | /* If the BSSID could not be found, try just the SSID */ | ||
315 | i = libertas_find_SSID_in_list(adapter, | ||
316 | &adapter-> | ||
317 | previousssid, NULL, | ||
318 | adapter->mode); | ||
319 | } | ||
320 | |||
321 | if (i < 0) { | ||
322 | libertas_send_specific_SSID_scan(priv, | ||
323 | &adapter-> | ||
324 | previousssid, | ||
325 | 1); | ||
326 | i = libertas_find_SSID_in_list(adapter, | ||
327 | &adapter-> | ||
328 | previousssid, NULL, | ||
329 | adapter->mode); | ||
330 | } | ||
331 | |||
332 | if (i >= 0) { | ||
333 | ret = | ||
334 | wlan_associate(priv, | ||
335 | &adapter-> | ||
336 | scantable[i]); | ||
337 | } | ||
338 | } | ||
339 | } else if (adapter->mode == IW_MODE_ADHOC) { | ||
340 | ret = libertas_prepare_and_send_command(priv, | ||
341 | cmd_802_11_ad_hoc_start, | ||
342 | 0, | ||
343 | cmd_option_waitforrsp, | ||
344 | 0, &adapter->previousssid); | ||
345 | } | ||
346 | } | ||
347 | /* else it is connected */ | ||
348 | |||
349 | lbs_pr_debug(1, "\nwlanidle is off"); | ||
350 | LEAVE(); | ||
351 | return ret; | ||
352 | } | ||
353 | |||
354 | /** | ||
355 | * @brief Set Idle On | ||
356 | * | ||
357 | * @param priv A pointer to wlan_private structure | ||
358 | * @return 0 --success, otherwise fail | ||
359 | */ | ||
360 | int libertas_idle_on(wlan_private * priv) | ||
361 | { | ||
362 | wlan_adapter *adapter = priv->adapter; | ||
363 | int ret = 0; | ||
364 | |||
365 | if (adapter->connect_status == libertas_connected) { | ||
366 | if (adapter->mode == IW_MODE_INFRA) { | ||
367 | lbs_pr_debug(1, "Previous SSID = %s\n", | ||
368 | adapter->previousssid.ssid); | ||
369 | memmove(&adapter->previousssid, | ||
370 | &adapter->curbssparams.ssid, | ||
371 | sizeof(struct WLAN_802_11_SSID)); | ||
372 | libertas_send_deauth(priv); | ||
373 | |||
374 | } else if (adapter->mode == IW_MODE_ADHOC) { | ||
375 | ret = libertas_stop_adhoc_network(priv); | ||
376 | } | ||
377 | |||
378 | } | ||
379 | |||
380 | lbs_pr_debug(1, "\nwlanidle is on"); | ||
381 | |||
382 | return ret; | ||
383 | } | ||
384 | |||
385 | /** | ||
386 | * @brief This function prepares command of authenticate. | 251 | * @brief This function prepares command of authenticate. |
387 | * | 252 | * |
388 | * @param priv A pointer to wlan_private structure | 253 | * @param priv A pointer to wlan_private structure |
diff --git a/drivers/net/wireless/libertas/join.h b/drivers/net/wireless/libertas/join.h index 0e6d9288506d..115f5a8ba346 100644 --- a/drivers/net/wireless/libertas/join.h +++ b/drivers/net/wireless/libertas/join.h | |||
@@ -37,10 +37,6 @@ extern int libertas_ret_80211_disassociate(wlan_private * priv, | |||
37 | extern int libertas_ret_80211_associate(wlan_private * priv, | 37 | extern int libertas_ret_80211_associate(wlan_private * priv, |
38 | struct cmd_ds_command *resp); | 38 | struct cmd_ds_command *resp); |
39 | 39 | ||
40 | extern int libertas_idle_on(wlan_private * priv); | ||
41 | extern int libertas_idle_off(wlan_private * priv); | ||
42 | |||
43 | extern int libertas_do_adhocstop_ioctl(wlan_private * priv); | ||
44 | extern int libertas_reassociation_thread(void *data); | 40 | extern int libertas_reassociation_thread(void *data); |
45 | 41 | ||
46 | struct WLAN_802_11_SSID; | 42 | struct WLAN_802_11_SSID; |
diff --git a/drivers/net/wireless/libertas/wext.c b/drivers/net/wireless/libertas/wext.c index c62ffcd214c2..69f52b6e59c8 100644 --- a/drivers/net/wireless/libertas/wext.c +++ b/drivers/net/wireless/libertas/wext.c | |||
@@ -986,137 +986,18 @@ static const struct iw_priv_args wlan_private_args[] = { | |||
986 | /* | 986 | /* |
987 | * { cmd, set_args, get_args, name } | 987 | * { cmd, set_args, get_args, name } |
988 | */ | 988 | */ |
989 | { | ||
990 | WLANSCAN_TYPE, | ||
991 | IW_PRIV_TYPE_CHAR | 8, | ||
992 | IW_PRIV_TYPE_CHAR | 8, | ||
993 | "scantype"}, | ||
994 | |||
995 | { | ||
996 | WLAN_SETINT_GETINT, | ||
997 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, | ||
998 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, | ||
999 | ""}, | ||
1000 | { | ||
1001 | WLANNF, | ||
1002 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, | ||
1003 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, | ||
1004 | "getNF"}, | ||
1005 | { | ||
1006 | WLANRSSI, | ||
1007 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, | ||
1008 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, | ||
1009 | "getRSSI"}, | ||
1010 | { | ||
1011 | WLANENABLE11D, | ||
1012 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, | ||
1013 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, | ||
1014 | "enable11d"}, | ||
1015 | { | ||
1016 | WLANADHOCGRATE, | ||
1017 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, | ||
1018 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, | ||
1019 | "adhocgrate"}, | ||
1020 | |||
1021 | { | ||
1022 | WLAN_SUBCMD_SET_PRESCAN, | ||
1023 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, | ||
1024 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, | ||
1025 | "prescan"}, | ||
1026 | { | ||
1027 | WLAN_SETONEINT_GETONEINT, | ||
1028 | IW_PRIV_TYPE_INT | 1, | ||
1029 | IW_PRIV_TYPE_INT | 1, | ||
1030 | ""}, | ||
1031 | { | ||
1032 | WLAN_BEACON_INTERVAL, | ||
1033 | IW_PRIV_TYPE_INT | 1, | ||
1034 | IW_PRIV_TYPE_INT | 1, | ||
1035 | "bcninterval"}, | ||
1036 | { | ||
1037 | WLAN_LISTENINTRVL, | ||
1038 | IW_PRIV_TYPE_INT | 1, | ||
1039 | IW_PRIV_TYPE_INT | 1, | ||
1040 | "lolisteninter"}, | ||
1041 | { | ||
1042 | WLAN_TXCONTROL, | ||
1043 | IW_PRIV_TYPE_INT | 1, | ||
1044 | IW_PRIV_TYPE_INT | 1, | ||
1045 | "txcontrol"}, | ||
1046 | { | ||
1047 | WLAN_NULLPKTINTERVAL, | ||
1048 | IW_PRIV_TYPE_INT | 1, | ||
1049 | IW_PRIV_TYPE_INT | 1, | ||
1050 | "psnullinterval"}, | ||
1051 | /* Using iwpriv sub-command feature */ | 989 | /* Using iwpriv sub-command feature */ |
1052 | { | 990 | { |
1053 | WLAN_SETONEINT_GETNONE, /* IOCTL: 24 */ | 991 | WLAN_SETONEINT_GETNONE, /* IOCTL: 24 */ |
1054 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, | 992 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, |
1055 | IW_PRIV_TYPE_NONE, | 993 | IW_PRIV_TYPE_NONE, |
1056 | ""}, | 994 | ""}, |
1057 | |||
1058 | { | ||
1059 | WLAN_SUBCMD_SETRXANTENNA, | ||
1060 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, | ||
1061 | IW_PRIV_TYPE_NONE, | ||
1062 | "setrxant"}, | ||
1063 | { | ||
1064 | WLAN_SUBCMD_SETTXANTENNA, | ||
1065 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, | ||
1066 | IW_PRIV_TYPE_NONE, | ||
1067 | "settxant"}, | ||
1068 | { | ||
1069 | WLANSETENCRYPTIONMODE, | ||
1070 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, | ||
1071 | IW_PRIV_TYPE_NONE, | ||
1072 | "encryptionmode", | ||
1073 | }, | ||
1074 | { | 995 | { |
1075 | WLANSETREGION, | 996 | WLANSETREGION, |
1076 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, | 997 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, |
1077 | IW_PRIV_TYPE_NONE, | 998 | IW_PRIV_TYPE_NONE, |
1078 | "setregioncode"}, | 999 | "setregioncode"}, |
1079 | { | 1000 | { |
1080 | WLAN_SET_LISTEN_INTERVAL, | ||
1081 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, | ||
1082 | IW_PRIV_TYPE_NONE, | ||
1083 | "setlisteninter"}, | ||
1084 | { | ||
1085 | WLAN_SET_MULTIPLE_DTIM, | ||
1086 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, | ||
1087 | IW_PRIV_TYPE_NONE, | ||
1088 | "setmultipledtim"}, | ||
1089 | { | ||
1090 | WLAN_SET_ATIM_WINDOW, | ||
1091 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, | ||
1092 | IW_PRIV_TYPE_NONE, | ||
1093 | "atimwindow"}, | ||
1094 | { | ||
1095 | WLANSETBCNAVG, | ||
1096 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, | ||
1097 | IW_PRIV_TYPE_NONE, | ||
1098 | "setbcnavg"}, | ||
1099 | { | ||
1100 | WLANSETDATAAVG, | ||
1101 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, | ||
1102 | IW_PRIV_TYPE_NONE, | ||
1103 | "setdataavg"}, | ||
1104 | { | ||
1105 | WLAN_SET_LINKMODE, | ||
1106 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, | ||
1107 | IW_PRIV_TYPE_NONE, | ||
1108 | "linkmode"}, | ||
1109 | { | ||
1110 | WLAN_SET_RADIOMODE, | ||
1111 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, | ||
1112 | IW_PRIV_TYPE_NONE, | ||
1113 | "radiomode"}, | ||
1114 | { | ||
1115 | WLAN_SET_DEBUGMODE, | ||
1116 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, | ||
1117 | IW_PRIV_TYPE_NONE, | ||
1118 | "debugmode"}, | ||
1119 | { | ||
1120 | WLAN_SUBCMD_MESH_SET_TTL, | 1001 | WLAN_SUBCMD_MESH_SET_TTL, |
1121 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, | 1002 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, |
1122 | IW_PRIV_TYPE_NONE, | 1003 | IW_PRIV_TYPE_NONE, |
@@ -1132,41 +1013,6 @@ static const struct iw_priv_args wlan_private_args[] = { | |||
1132 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, | 1013 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, |
1133 | "getregioncode"}, | 1014 | "getregioncode"}, |
1134 | { | 1015 | { |
1135 | WLAN_GET_LISTEN_INTERVAL, | ||
1136 | IW_PRIV_TYPE_NONE, | ||
1137 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, | ||
1138 | "getlisteninter"}, | ||
1139 | { | ||
1140 | WLAN_GET_MULTIPLE_DTIM, | ||
1141 | IW_PRIV_TYPE_NONE, | ||
1142 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, | ||
1143 | "getmultipledtim"}, | ||
1144 | { | ||
1145 | WLAN_GET_TX_RATE, | ||
1146 | IW_PRIV_TYPE_NONE, | ||
1147 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, | ||
1148 | "gettxrate"}, | ||
1149 | { | ||
1150 | WLANGETBCNAVG, | ||
1151 | IW_PRIV_TYPE_NONE, | ||
1152 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, | ||
1153 | "getbcnavg"}, | ||
1154 | { | ||
1155 | WLAN_GET_LINKMODE, | ||
1156 | IW_PRIV_TYPE_NONE, | ||
1157 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, | ||
1158 | "get_linkmode"}, | ||
1159 | { | ||
1160 | WLAN_GET_RADIOMODE, | ||
1161 | IW_PRIV_TYPE_NONE, | ||
1162 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, | ||
1163 | "get_radiomode"}, | ||
1164 | { | ||
1165 | WLAN_GET_DEBUGMODE, | ||
1166 | IW_PRIV_TYPE_NONE, | ||
1167 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, | ||
1168 | "get_debugmode"}, | ||
1169 | { | ||
1170 | WLAN_SUBCMD_FWT_CLEANUP, | 1016 | WLAN_SUBCMD_FWT_CLEANUP, |
1171 | IW_PRIV_TYPE_NONE, | 1017 | IW_PRIV_TYPE_NONE, |
1172 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, | 1018 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, |
@@ -1182,61 +1028,11 @@ static const struct iw_priv_args wlan_private_args[] = { | |||
1182 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, | 1028 | IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, |
1183 | "mesh_get_ttl"}, | 1029 | "mesh_get_ttl"}, |
1184 | { | 1030 | { |
1185 | WLAN_SETNONE_GETTWELVE_CHAR, | ||
1186 | IW_PRIV_TYPE_NONE, | ||
1187 | IW_PRIV_TYPE_CHAR | 12, | ||
1188 | ""}, | ||
1189 | { | ||
1190 | WLAN_SUBCMD_GETRXANTENNA, | ||
1191 | IW_PRIV_TYPE_NONE, | ||
1192 | IW_PRIV_TYPE_CHAR | 12, | ||
1193 | "getrxant"}, | ||
1194 | { | ||
1195 | WLAN_SUBCMD_GETTXANTENNA, | ||
1196 | IW_PRIV_TYPE_NONE, | ||
1197 | IW_PRIV_TYPE_CHAR | 12, | ||
1198 | "gettxant"}, | ||
1199 | { | ||
1200 | WLAN_GET_TSF, | ||
1201 | IW_PRIV_TYPE_NONE, | ||
1202 | IW_PRIV_TYPE_CHAR | 12, | ||
1203 | "gettsf"}, | ||
1204 | { | ||
1205 | WLAN_SETNONE_GETNONE, | 1031 | WLAN_SETNONE_GETNONE, |
1206 | IW_PRIV_TYPE_NONE, | 1032 | IW_PRIV_TYPE_NONE, |
1207 | IW_PRIV_TYPE_NONE, | 1033 | IW_PRIV_TYPE_NONE, |
1208 | ""}, | 1034 | ""}, |
1209 | { | 1035 | { |
1210 | WLANDEAUTH, | ||
1211 | IW_PRIV_TYPE_NONE, | ||
1212 | IW_PRIV_TYPE_NONE, | ||
1213 | "deauth"}, | ||
1214 | { | ||
1215 | WLANADHOCSTOP, | ||
1216 | IW_PRIV_TYPE_NONE, | ||
1217 | IW_PRIV_TYPE_NONE, | ||
1218 | "adhocstop"}, | ||
1219 | { | ||
1220 | WLANRADIOON, | ||
1221 | IW_PRIV_TYPE_NONE, | ||
1222 | IW_PRIV_TYPE_NONE, | ||
1223 | "radioon"}, | ||
1224 | { | ||
1225 | WLANRADIOOFF, | ||
1226 | IW_PRIV_TYPE_NONE, | ||
1227 | IW_PRIV_TYPE_NONE, | ||
1228 | "radiooff"}, | ||
1229 | { | ||
1230 | WLANWLANIDLEON, | ||
1231 | IW_PRIV_TYPE_NONE, | ||
1232 | IW_PRIV_TYPE_NONE, | ||
1233 | "wlanidle-on"}, | ||
1234 | { | ||
1235 | WLANWLANIDLEOFF, | ||
1236 | IW_PRIV_TYPE_NONE, | ||
1237 | IW_PRIV_TYPE_NONE, | ||
1238 | "wlanidle-off"}, | ||
1239 | { | ||
1240 | WLAN_SUBCMD_FWT_RESET, | 1036 | WLAN_SUBCMD_FWT_RESET, |
1241 | IW_PRIV_TYPE_NONE, | 1037 | IW_PRIV_TYPE_NONE, |
1242 | IW_PRIV_TYPE_NONE, | 1038 | IW_PRIV_TYPE_NONE, |
@@ -1299,85 +1095,15 @@ static const struct iw_priv_args wlan_private_args[] = { | |||
1299 | IW_PRIV_TYPE_CHAR | 128, | 1095 | IW_PRIV_TYPE_CHAR | 128, |
1300 | "fwt_list_route"}, | 1096 | "fwt_list_route"}, |
1301 | { | 1097 | { |
1302 | WLANSCAN_MODE, | ||
1303 | IW_PRIV_TYPE_CHAR | 128, | ||
1304 | IW_PRIV_TYPE_CHAR | 128, | ||
1305 | "scanmode"}, | ||
1306 | { | ||
1307 | WLAN_GET_ADHOC_STATUS, | ||
1308 | IW_PRIV_TYPE_CHAR | 128, | ||
1309 | IW_PRIV_TYPE_CHAR | 128, | ||
1310 | "getadhocstatus"}, | ||
1311 | { | ||
1312 | WLAN_SETNONE_GETWORDCHAR, | ||
1313 | IW_PRIV_TYPE_NONE, | ||
1314 | IW_PRIV_TYPE_CHAR | 128, | ||
1315 | ""}, | ||
1316 | { | ||
1317 | WLANGETLOG, | ||
1318 | IW_PRIV_TYPE_NONE, | ||
1319 | IW_PRIV_TYPE_CHAR | GETLOG_BUFSIZE, | ||
1320 | "getlog"}, | ||
1321 | { | ||
1322 | WLAN_SET_GET_SIXTEEN_INT, | 1098 | WLAN_SET_GET_SIXTEEN_INT, |
1323 | IW_PRIV_TYPE_INT | 16, | 1099 | IW_PRIV_TYPE_INT | 16, |
1324 | IW_PRIV_TYPE_INT | 16, | 1100 | IW_PRIV_TYPE_INT | 16, |
1325 | ""}, | 1101 | ""}, |
1326 | { | 1102 | { |
1327 | WLAN_TPCCFG, | ||
1328 | IW_PRIV_TYPE_INT | 16, | ||
1329 | IW_PRIV_TYPE_INT | 16, | ||
1330 | "tpccfg"}, | ||
1331 | { | ||
1332 | WLAN_POWERCFG, | ||
1333 | IW_PRIV_TYPE_INT | 16, | ||
1334 | IW_PRIV_TYPE_INT | 16, | ||
1335 | "powercfg"}, | ||
1336 | { | ||
1337 | WLAN_AUTO_FREQ_SET, | ||
1338 | IW_PRIV_TYPE_INT | 16, | ||
1339 | IW_PRIV_TYPE_INT | 16, | ||
1340 | "setafc"}, | ||
1341 | { | ||
1342 | WLAN_AUTO_FREQ_GET, | ||
1343 | IW_PRIV_TYPE_INT | 16, | ||
1344 | IW_PRIV_TYPE_INT | 16, | ||
1345 | "getafc"}, | ||
1346 | { | ||
1347 | WLAN_SCANPROBES, | ||
1348 | IW_PRIV_TYPE_INT | 16, | ||
1349 | IW_PRIV_TYPE_INT | 16, | ||
1350 | "scanprobes"}, | ||
1351 | { | ||
1352 | WLAN_LED_GPIO_CTRL, | 1103 | WLAN_LED_GPIO_CTRL, |
1353 | IW_PRIV_TYPE_INT | 16, | 1104 | IW_PRIV_TYPE_INT | 16, |
1354 | IW_PRIV_TYPE_INT | 16, | 1105 | IW_PRIV_TYPE_INT | 16, |
1355 | "ledgpio"}, | 1106 | "ledgpio"}, |
1356 | { | ||
1357 | WLAN_ADAPT_RATESET, | ||
1358 | IW_PRIV_TYPE_INT | 16, | ||
1359 | IW_PRIV_TYPE_INT | 16, | ||
1360 | "rateadapt"}, | ||
1361 | { | ||
1362 | WLAN_INACTIVITY_TIMEOUT, | ||
1363 | IW_PRIV_TYPE_INT | 16, | ||
1364 | IW_PRIV_TYPE_INT | 16, | ||
1365 | "inactivityto"}, | ||
1366 | { | ||
1367 | WLANSNR, | ||
1368 | IW_PRIV_TYPE_INT | 16, | ||
1369 | IW_PRIV_TYPE_INT | 16, | ||
1370 | "getSNR"}, | ||
1371 | { | ||
1372 | WLAN_GET_RATE, | ||
1373 | IW_PRIV_TYPE_INT | 16, | ||
1374 | IW_PRIV_TYPE_INT | 16, | ||
1375 | "getrate"}, | ||
1376 | { | ||
1377 | WLAN_GET_RXINFO, | ||
1378 | IW_PRIV_TYPE_INT | 16, | ||
1379 | IW_PRIV_TYPE_INT | 16, | ||
1380 | "getrxinfo"}, | ||
1381 | }; | 1107 | }; |
1382 | 1108 | ||
1383 | static struct iw_statistics *wlan_get_wireless_stats(struct net_device *dev) | 1109 | static struct iw_statistics *wlan_get_wireless_stats(struct net_device *dev) |
diff --git a/drivers/net/wireless/libertas/wext.h b/drivers/net/wireless/libertas/wext.h index 39f367c38d90..15cfaaf0797f 100644 --- a/drivers/net/wireless/libertas/wext.h +++ b/drivers/net/wireless/libertas/wext.h | |||
@@ -10,88 +10,22 @@ | |||
10 | /** PRIVATE CMD ID */ | 10 | /** PRIVATE CMD ID */ |
11 | #define WLANIOCTL SIOCIWFIRSTPRIV | 11 | #define WLANIOCTL SIOCIWFIRSTPRIV |
12 | 12 | ||
13 | #define WLANSETWPAIE (WLANIOCTL + 0) | ||
14 | |||
15 | #define WLAN_SETINT_GETINT (WLANIOCTL + 7) | ||
16 | #define WLANNF 1 | ||
17 | #define WLANRSSI 2 | ||
18 | #define WLANENABLE11D 5 | ||
19 | #define WLANADHOCGRATE 6 | ||
20 | #define WLAN_SUBCMD_SET_PRESCAN 11 | ||
21 | |||
22 | #define WLAN_SETNONE_GETNONE (WLANIOCTL + 8) | 13 | #define WLAN_SETNONE_GETNONE (WLANIOCTL + 8) |
23 | #define WLANDEAUTH 1 | ||
24 | #define WLANRADIOON 2 | ||
25 | #define WLANRADIOOFF 3 | ||
26 | #define WLANREMOVEADHOCAES 4 | ||
27 | #define WLANADHOCSTOP 5 | ||
28 | #define WLANCIPHERTEST 6 | ||
29 | #define WLANCRYPTOTEST 7 | ||
30 | |||
31 | #define WLANWLANIDLEON 10 | ||
32 | #define WLANWLANIDLEOFF 11 | ||
33 | #define WLAN_SUBCMD_BT_RESET 13 | 14 | #define WLAN_SUBCMD_BT_RESET 13 |
34 | #define WLAN_SUBCMD_FWT_RESET 14 | 15 | #define WLAN_SUBCMD_FWT_RESET 14 |
35 | 16 | ||
36 | #define WLANGETLOG (WLANIOCTL + 9) | ||
37 | #define GETLOG_BUFSIZE 300 | ||
38 | |||
39 | #define WLANSCAN_TYPE (WLANIOCTL + 11) | ||
40 | |||
41 | #define WLAN_SETNONE_GETONEINT (WLANIOCTL + 15) | 17 | #define WLAN_SETNONE_GETONEINT (WLANIOCTL + 15) |
42 | #define WLANGETREGION 1 | 18 | #define WLANGETREGION 1 |
43 | #define WLAN_GET_LISTEN_INTERVAL 2 | ||
44 | #define WLAN_GET_MULTIPLE_DTIM 3 | ||
45 | #define WLAN_GET_TX_RATE 4 | ||
46 | #define WLANGETBCNAVG 5 | ||
47 | 19 | ||
48 | #define WLAN_GET_LINKMODE 6 | ||
49 | #define WLAN_GET_RADIOMODE 7 | ||
50 | #define WLAN_GET_DEBUGMODE 8 | ||
51 | #define WLAN_SUBCMD_FWT_CLEANUP 15 | 20 | #define WLAN_SUBCMD_FWT_CLEANUP 15 |
52 | #define WLAN_SUBCMD_FWT_TIME 16 | 21 | #define WLAN_SUBCMD_FWT_TIME 16 |
53 | #define WLAN_SUBCMD_MESH_GET_TTL 17 | 22 | #define WLAN_SUBCMD_MESH_GET_TTL 17 |
54 | 23 | ||
55 | #define WLANREGCFRDWR (WLANIOCTL + 18) | ||
56 | |||
57 | #define WLAN_SETNONE_GETTWELVE_CHAR (WLANIOCTL + 19) | ||
58 | #define WLAN_SUBCMD_GETRXANTENNA 1 | ||
59 | #define WLAN_SUBCMD_GETTXANTENNA 2 | ||
60 | #define WLAN_GET_TSF 3 | ||
61 | |||
62 | #define WLAN_SETNONE_GETWORDCHAR (WLANIOCTL + 21) | ||
63 | #define WLANGETADHOCAES 1 | ||
64 | |||
65 | #define WLAN_SETONEINT_GETONEINT (WLANIOCTL + 23) | ||
66 | #define WLAN_BEACON_INTERVAL 1 | ||
67 | #define WLAN_LISTENINTRVL 4 | ||
68 | |||
69 | #define WLAN_TXCONTROL 6 | ||
70 | #define WLAN_NULLPKTINTERVAL 7 | ||
71 | |||
72 | #define WLAN_SETONEINT_GETNONE (WLANIOCTL + 24) | 24 | #define WLAN_SETONEINT_GETNONE (WLANIOCTL + 24) |
73 | #define WLAN_SUBCMD_SETRXANTENNA 1 | ||
74 | #define WLAN_SUBCMD_SETTXANTENNA 2 | ||
75 | #define WLANSETAUTHALG 5 | ||
76 | #define WLANSET8021XAUTHALG 6 | ||
77 | #define WLANSETENCRYPTIONMODE 7 | ||
78 | #define WLANSETREGION 8 | 25 | #define WLANSETREGION 8 |
79 | #define WLAN_SET_LISTEN_INTERVAL 9 | ||
80 | |||
81 | #define WLAN_SET_MULTIPLE_DTIM 10 | ||
82 | #define WLAN_SET_ATIM_WINDOW 11 | ||
83 | #define WLANSETBCNAVG 13 | ||
84 | #define WLANSETDATAAVG 14 | ||
85 | #define WLAN_SET_LINKMODE 15 | ||
86 | #define WLAN_SET_RADIOMODE 16 | ||
87 | #define WLAN_SET_DEBUGMODE 17 | ||
88 | #define WLAN_SUBCMD_MESH_SET_TTL 18 | 26 | #define WLAN_SUBCMD_MESH_SET_TTL 18 |
89 | 27 | ||
90 | #define WLAN_SET128CHAR_GET128CHAR (WLANIOCTL + 25) | 28 | #define WLAN_SET128CHAR_GET128CHAR (WLANIOCTL + 25) |
91 | #define WLANSCAN_MODE 6 | ||
92 | |||
93 | #define WLAN_GET_ADHOC_STATUS 9 | ||
94 | |||
95 | #define WLAN_SUBCMD_BT_ADD 18 | 29 | #define WLAN_SUBCMD_BT_ADD 18 |
96 | #define WLAN_SUBCMD_BT_DEL 19 | 30 | #define WLAN_SUBCMD_BT_DEL 19 |
97 | #define WLAN_SUBCMD_BT_LIST 20 | 31 | #define WLAN_SUBCMD_BT_LIST 20 |
@@ -103,27 +37,8 @@ | |||
103 | #define WLAN_SUBCMD_FWT_LIST_ROUTE 26 | 37 | #define WLAN_SUBCMD_FWT_LIST_ROUTE 26 |
104 | 38 | ||
105 | #define WLAN_SET_GET_SIXTEEN_INT (WLANIOCTL + 29) | 39 | #define WLAN_SET_GET_SIXTEEN_INT (WLANIOCTL + 29) |
106 | #define WLAN_TPCCFG 1 | ||
107 | #define WLAN_POWERCFG 2 | ||
108 | |||
109 | #define WLAN_AUTO_FREQ_SET 3 | ||
110 | #define WLAN_AUTO_FREQ_GET 4 | ||
111 | #define WLAN_LED_GPIO_CTRL 5 | 40 | #define WLAN_LED_GPIO_CTRL 5 |
112 | #define WLAN_SCANPROBES 6 | ||
113 | #define WLAN_ADAPT_RATESET 8 | ||
114 | #define WLAN_INACTIVITY_TIMEOUT 9 | ||
115 | #define WLANSNR 10 | ||
116 | #define WLAN_GET_RATE 11 | ||
117 | #define WLAN_GET_RXINFO 12 | ||
118 | |||
119 | #define WLANCMD52RDWR (WLANIOCTL + 30) | ||
120 | #define WLANCMD53RDWR (WLANIOCTL + 31) | ||
121 | #define CMD53BUFLEN 32 | ||
122 | 41 | ||
123 | #define REG_MAC 0x19 | ||
124 | #define REG_BBP 0x1a | ||
125 | #define REG_RF 0x1b | ||
126 | #define REG_EEPROM 0x59 | ||
127 | #define WLAN_LINKMODE_802_3 0 | 42 | #define WLAN_LINKMODE_802_3 0 |
128 | #define WLAN_LINKMODE_802_11 2 | 43 | #define WLAN_LINKMODE_802_11 2 |
129 | #define WLAN_RADIOMODE_NONE 0 | 44 | #define WLAN_RADIOMODE_NONE 0 |