]> err.no Git - linux-2.6/blob - drivers/net/wireless/libertas/hostcmd.h
libertas: implement new scanning logic
[linux-2.6] / drivers / net / wireless / libertas / hostcmd.h
1 /*
2  * This file contains the function prototypes, data structure
3  * and defines for all the host/station commands
4  */
5 #ifndef _LBS_HOSTCMD_H
6 #define _LBS_HOSTCMD_H
7
8 #include <linux/wireless.h>
9 #include "11d.h"
10 #include "types.h"
11
12 /* 802.11-related definitions */
13
14 /* TxPD descriptor */
15 struct txpd {
16         /* Current Tx packet status */
17         __le32 tx_status;
18         /* Tx control */
19         __le32 tx_control;
20         __le32 tx_packet_location;
21         /* Tx packet length */
22         __le16 tx_packet_length;
23         /* First 2 byte of destination MAC address */
24         u8 tx_dest_addr_high[2];
25         /* Last 4 byte of destination MAC address */
26         u8 tx_dest_addr_low[4];
27         /* Pkt Priority */
28         u8 priority;
29         /* Pkt Trasnit Power control */
30         u8 powermgmt;
31         /* Amount of time the packet has been queued in the driver (units = 2ms) */
32         u8 pktdelay_2ms;
33         /* reserved */
34         u8 reserved1;
35 };
36
37 /* RxPD Descriptor */
38 struct rxpd {
39         /* Current Rx packet status */
40         __le16 status;
41
42         /* SNR */
43         u8 snr;
44
45         /* Tx control */
46         u8 rx_control;
47
48         /* Pkt length */
49         __le16 pkt_len;
50
51         /* Noise Floor */
52         u8 nf;
53
54         /* Rx Packet Rate */
55         u8 rx_rate;
56
57         /* Pkt addr */
58         __le32 pkt_ptr;
59
60         /* Next Rx RxPD addr */
61         __le32 next_rxpd_ptr;
62
63         /* Pkt Priority */
64         u8 priority;
65         u8 reserved[3];
66 };
67
68 struct cmd_ctrl_node {
69         struct list_head list;
70         /* wait for finish or not */
71         u16 wait_option;
72         /* command response */
73         void *pdata_buf;
74         int *pdata_size;
75         /* command data */
76         u8 *bufvirtualaddr;
77         /* wait queue */
78         u16 cmdwaitqwoken;
79         wait_queue_head_t cmdwait_q;
80 };
81
82 /* Generic structure to hold all key types. */
83 struct enc_key {
84         u16 len;
85         u16 flags;  /* KEY_INFO_* from defs.h */
86         u16 type; /* KEY_TYPE_* from defs.h */
87         u8 key[32];
88 };
89
90 /* lbs_offset_value */
91 struct lbs_offset_value {
92         u32 offset;
93         u32 value;
94 };
95
96 /* Define general data structure */
97 /* cmd_DS_GEN */
98 struct cmd_ds_gen {
99         __le16 command;
100         __le16 size;
101         __le16 seqnum;
102         __le16 result;
103         void *cmdresp[0];
104 };
105
106 #define S_DS_GEN sizeof(struct cmd_ds_gen)
107
108
109 /*
110  * Define data structure for CMD_GET_HW_SPEC
111  * This structure defines the response for the GET_HW_SPEC command
112  */
113 struct cmd_ds_get_hw_spec {
114         /* HW Interface version number */
115         __le16 hwifversion;
116         /* HW version number */
117         __le16 version;
118         /* Max number of TxPD FW can handle */
119         __le16 nr_txpd;
120         /* Max no of Multicast address */
121         __le16 nr_mcast_adr;
122         /* MAC address */
123         u8 permanentaddr[6];
124
125         /* region Code */
126         __le16 regioncode;
127
128         /* Number of antenna used */
129         __le16 nr_antenna;
130
131         /* FW release number, example 1,2,3,4 = 3.2.1p4 */
132         u8 fwreleasenumber[4];
133
134         /* Base Address of TxPD queue */
135         __le32 wcb_base;
136         /* Read Pointer of RxPd queue */
137         __le32 rxpd_rdptr;
138
139         /* Write Pointer of RxPd queue */
140         __le32 rxpd_wrptr;
141
142         /*FW/HW capability */
143         __le32 fwcapinfo;
144 } __attribute__ ((packed));
145
146 struct cmd_ds_802_11_reset {
147         __le16 action;
148 };
149
150 struct cmd_ds_802_11_subscribe_event {
151         __le16 action;
152         __le16 events;
153
154         /* A TLV to the CMD_802_11_SUBSCRIBE_EVENT command can contain a
155          * number of TLVs. From the v5.1 manual, those TLVs would add up to
156          * 40 bytes. However, future firmware might add additional TLVs, so I
157          * bump this up a bit.
158          */
159         u8 tlv[128];
160 };
161
162 /*
163  * This scan handle Country Information IE(802.11d compliant)
164  * Define data structure for CMD_802_11_SCAN
165  */
166 struct cmd_ds_802_11_scan {
167         u8 bsstype;
168         u8 bssid[ETH_ALEN];
169         u8 tlvbuffer[1];
170 #if 0
171         mrvlietypes_ssidparamset_t ssidParamSet;
172         mrvlietypes_chanlistparamset_t ChanListParamSet;
173         mrvlietypes_ratesparamset_t OpRateSet;
174 #endif
175 };
176
177 struct cmd_ds_802_11_scan_rsp {
178         __le16 bssdescriptsize;
179         u8 nr_sets;
180         u8 bssdesc_and_tlvbuffer[1];
181 };
182
183 struct cmd_ds_802_11_get_log {
184         __le32 mcasttxframe;
185         __le32 failed;
186         __le32 retry;
187         __le32 multiretry;
188         __le32 framedup;
189         __le32 rtssuccess;
190         __le32 rtsfailure;
191         __le32 ackfailure;
192         __le32 rxfrag;
193         __le32 mcastrxframe;
194         __le32 fcserror;
195         __le32 txframe;
196         __le32 wepundecryptable;
197 };
198
199 struct cmd_ds_mac_control {
200         __le16 action;
201         __le16 reserved;
202 };
203
204 struct cmd_ds_mac_multicast_adr {
205         __le16 action;
206         __le16 nr_of_adrs;
207         u8 maclist[ETH_ALEN * MRVDRV_MAX_MULTICAST_LIST_SIZE];
208 };
209
210 struct cmd_ds_802_11_authenticate {
211         u8 macaddr[ETH_ALEN];
212         u8 authtype;
213         u8 reserved[10];
214 };
215
216 struct cmd_ds_802_11_deauthenticate {
217         u8 macaddr[6];
218         __le16 reasoncode;
219 };
220
221 struct cmd_ds_802_11_associate {
222         u8 peerstaaddr[6];
223         __le16 capability;
224         __le16 listeninterval;
225         __le16 bcnperiod;
226         u8 dtimperiod;
227
228 #if 0
229         mrvlietypes_ssidparamset_t ssidParamSet;
230         mrvlietypes_phyparamset_t phyparamset;
231         mrvlietypes_ssparamset_t ssparamset;
232         mrvlietypes_ratesparamset_t ratesParamSet;
233 #endif
234 } __attribute__ ((packed));
235
236 struct cmd_ds_802_11_disassociate {
237         u8 destmacaddr[6];
238         __le16 reasoncode;
239 };
240
241 struct cmd_ds_802_11_associate_rsp {
242         struct ieeetypes_assocrsp assocRsp;
243 };
244
245 struct cmd_ds_802_11_ad_hoc_result {
246         u8 pad[3];
247         u8 bssid[ETH_ALEN];
248 };
249
250 struct cmd_ds_802_11_set_wep {
251         /* ACT_ADD, ACT_REMOVE or ACT_ENABLE */
252         __le16 action;
253
254         /* key Index selected for Tx */
255         __le16 keyindex;
256
257         /* 40, 128bit or TXWEP */
258         u8 keytype[4];
259         u8 keymaterial[4][16];
260 };
261
262 struct cmd_ds_802_3_get_stat {
263         __le32 xmitok;
264         __le32 rcvok;
265         __le32 xmiterror;
266         __le32 rcverror;
267         __le32 rcvnobuffer;
268         __le32 rcvcrcerror;
269 };
270
271 struct cmd_ds_802_11_get_stat {
272         __le32 txfragmentcnt;
273         __le32 mcasttxframecnt;
274         __le32 failedcnt;
275         __le32 retrycnt;
276         __le32 Multipleretrycnt;
277         __le32 rtssuccesscnt;
278         __le32 rtsfailurecnt;
279         __le32 ackfailurecnt;
280         __le32 frameduplicatecnt;
281         __le32 rxfragmentcnt;
282         __le32 mcastrxframecnt;
283         __le32 fcserrorcnt;
284         __le32 bcasttxframecnt;
285         __le32 bcastrxframecnt;
286         __le32 txbeacon;
287         __le32 rxbeacon;
288         __le32 wepundecryptable;
289 };
290
291 struct cmd_ds_802_11_snmp_mib {
292         __le16 querytype;
293         __le16 oid;
294         __le16 bufsize;
295         u8 value[128];
296 };
297
298 struct cmd_ds_mac_reg_map {
299         __le16 buffersize;
300         u8 regmap[128];
301         __le16 reserved;
302 };
303
304 struct cmd_ds_bbp_reg_map {
305         __le16 buffersize;
306         u8 regmap[128];
307         __le16 reserved;
308 };
309
310 struct cmd_ds_rf_reg_map {
311         __le16 buffersize;
312         u8 regmap[64];
313         __le16 reserved;
314 };
315
316 struct cmd_ds_mac_reg_access {
317         __le16 action;
318         __le16 offset;
319         __le32 value;
320 };
321
322 struct cmd_ds_bbp_reg_access {
323         __le16 action;
324         __le16 offset;
325         u8 value;
326         u8 reserved[3];
327 };
328
329 struct cmd_ds_rf_reg_access {
330         __le16 action;
331         __le16 offset;
332         u8 value;
333         u8 reserved[3];
334 };
335
336 struct cmd_ds_802_11_radio_control {
337         __le16 action;
338         __le16 control;
339 };
340
341 struct cmd_ds_802_11_beacon_control {
342         __le16 action;
343         __le16 beacon_enable;
344         __le16 beacon_period;
345 };
346
347 struct cmd_ds_802_11_sleep_params {
348         /* ACT_GET/ACT_SET */
349         __le16 action;
350
351         /* Sleep clock error in ppm */
352         __le16 error;
353
354         /* Wakeup offset in usec */
355         __le16 offset;
356
357         /* Clock stabilization time in usec */
358         __le16 stabletime;
359
360         /* control periodic calibration */
361         u8 calcontrol;
362
363         /* control the use of external sleep clock */
364         u8 externalsleepclk;
365
366         /* reserved field, should be set to zero */
367         __le16 reserved;
368 };
369
370 struct cmd_ds_802_11_inactivity_timeout {
371         /* ACT_GET/ACT_SET */
372         __le16 action;
373
374         /* Inactivity timeout in msec */
375         __le16 timeout;
376 };
377
378 struct cmd_ds_802_11_rf_channel {
379         __le16 action;
380         __le16 currentchannel;
381         __le16 rftype;
382         __le16 reserved;
383         u8 channellist[32];
384 };
385
386 struct cmd_ds_802_11_rssi {
387         /* weighting factor */
388         __le16 N;
389
390         __le16 reserved_0;
391         __le16 reserved_1;
392         __le16 reserved_2;
393 };
394
395 struct cmd_ds_802_11_rssi_rsp {
396         __le16 SNR;
397         __le16 noisefloor;
398         __le16 avgSNR;
399         __le16 avgnoisefloor;
400 };
401
402 struct cmd_ds_802_11_mac_address {
403         __le16 action;
404         u8 macadd[ETH_ALEN];
405 };
406
407 struct cmd_ds_802_11_rf_tx_power {
408         __le16 action;
409         __le16 currentlevel;
410 };
411
412 struct cmd_ds_802_11_rf_antenna {
413         __le16 action;
414
415         /* Number of antennas or 0xffff(diversity) */
416         __le16 antennamode;
417
418 };
419
420 struct cmd_ds_802_11_monitor_mode {
421         u16 action;
422         u16 mode;
423 };
424
425 struct cmd_ds_set_boot2_ver {
426         u16 action;
427         u16 version;
428 };
429
430 struct cmd_ds_802_11_ps_mode {
431         __le16 action;
432         __le16 nullpktinterval;
433         __le16 multipledtim;
434         __le16 reserved;
435         __le16 locallisteninterval;
436 };
437
438 struct PS_CMD_ConfirmSleep {
439         __le16 command;
440         __le16 size;
441         __le16 seqnum;
442         __le16 result;
443
444         __le16 action;
445         __le16 reserved1;
446         __le16 multipledtim;
447         __le16 reserved;
448         __le16 locallisteninterval;
449 };
450
451 struct cmd_ds_802_11_data_rate {
452         __le16 action;
453         __le16 reserved;
454         u8 rates[MAX_RATES];
455 };
456
457 struct cmd_ds_802_11_rate_adapt_rateset {
458         __le16 action;
459         __le16 enablehwauto;
460         __le16 bitmap;
461 };
462
463 struct cmd_ds_802_11_ad_hoc_start {
464         u8 ssid[IW_ESSID_MAX_SIZE];
465         u8 bsstype;
466         __le16 beaconperiod;
467         u8 dtimperiod;
468         union IEEEtypes_ssparamset ssparamset;
469         union ieeetypes_phyparamset phyparamset;
470         __le16 probedelay;
471         __le16 capability;
472         u8 rates[MAX_RATES];
473         u8 tlv_memory_size_pad[100];
474 } __attribute__ ((packed));
475
476 struct adhoc_bssdesc {
477         u8 bssid[6];
478         u8 ssid[32];
479         u8 type;
480         __le16 beaconperiod;
481         u8 dtimperiod;
482         __le64 timestamp;
483         __le64 localtime;
484         union ieeetypes_phyparamset phyparamset;
485         union IEEEtypes_ssparamset ssparamset;
486         __le16 capability;
487         u8 rates[MAX_RATES];
488
489         /* DO NOT ADD ANY FIELDS TO THIS STRUCTURE. It is used below in the
490          * Adhoc join command and will cause a binary layout mismatch with
491          * the firmware
492          */
493 } __attribute__ ((packed));
494
495 struct cmd_ds_802_11_ad_hoc_join {
496         struct adhoc_bssdesc bss;
497         __le16 failtimeout;
498         __le16 probedelay;
499
500 } __attribute__ ((packed));
501
502 struct cmd_ds_802_11_enable_rsn {
503         __le16 action;
504         __le16 enable;
505 } __attribute__ ((packed));
506
507 struct MrvlIEtype_keyParamSet {
508         /* type ID */
509         __le16 type;
510
511         /* length of Payload */
512         __le16 length;
513
514         /* type of key: WEP=0, TKIP=1, AES=2 */
515         __le16 keytypeid;
516
517         /* key control Info specific to a keytypeid */
518         __le16 keyinfo;
519
520         /* length of key */
521         __le16 keylen;
522
523         /* key material of size keylen */
524         u8 key[32];
525 };
526
527 struct cmd_ds_802_11_key_material {
528         __le16 action;
529         struct MrvlIEtype_keyParamSet keyParamSet[2];
530 } __attribute__ ((packed));
531
532 struct cmd_ds_802_11_eeprom_access {
533         __le16 action;
534
535         /* multiple 4 */
536         __le16 offset;
537         __le16 bytecount;
538         u8 value;
539 } __attribute__ ((packed));
540
541 struct cmd_ds_802_11_tpc_cfg {
542         __le16 action;
543         u8 enable;
544         s8 P0;
545         s8 P1;
546         s8 P2;
547         u8 usesnr;
548 } __attribute__ ((packed));
549
550 struct cmd_ds_802_11_led_ctrl {
551         __le16 action;
552         __le16 numled;
553         u8 data[256];
554 } __attribute__ ((packed));
555
556 struct cmd_ds_802_11_pwr_cfg {
557         __le16 action;
558         u8 enable;
559         s8 PA_P0;
560         s8 PA_P1;
561         s8 PA_P2;
562 } __attribute__ ((packed));
563
564 struct cmd_ds_802_11_afc {
565         __le16 afc_auto;
566         union {
567                 struct {
568                         __le16 threshold;
569                         __le16 period;
570                 };
571                 struct {
572                         __le16 timing_offset; /* signed */
573                         __le16 carrier_offset; /* signed */
574                 };
575         };
576 } __attribute__ ((packed));
577
578 struct cmd_tx_rate_query {
579         __le16 txrate;
580 } __attribute__ ((packed));
581
582 struct cmd_ds_get_tsf {
583         __le64 tsfvalue;
584 } __attribute__ ((packed));
585
586 struct cmd_ds_bt_access {
587         __le16 action;
588         __le32 id;
589         u8 addr1[ETH_ALEN];
590         u8 addr2[ETH_ALEN];
591 } __attribute__ ((packed));
592
593 struct cmd_ds_fwt_access {
594         __le16 action;
595         __le32 id;
596         u8 valid;
597         u8 da[ETH_ALEN];
598         u8 dir;
599         u8 ra[ETH_ALEN];
600         __le32 ssn;
601         __le32 dsn;
602         __le32 metric;
603         u8 rate;
604         u8 hopcount;
605         u8 ttl;
606         __le32 expiration;
607         u8 sleepmode;
608         __le32 snr;
609         __le32 references;
610         u8 prec[ETH_ALEN];
611 } __attribute__ ((packed));
612
613 struct cmd_ds_mesh_access {
614         __le16 action;
615         __le32 data[32];        /* last position reserved */
616 } __attribute__ ((packed));
617
618 /* Number of stats counters returned by the firmware */
619 #define MESH_STATS_NUM 8
620
621 struct cmd_ds_command {
622         /* command header */
623         __le16 command;
624         __le16 size;
625         __le16 seqnum;
626         __le16 result;
627
628         /* command Body */
629         union {
630                 struct cmd_ds_get_hw_spec hwspec;
631                 struct cmd_ds_802_11_ps_mode psmode;
632                 struct cmd_ds_802_11_scan scan;
633                 struct cmd_ds_802_11_scan_rsp scanresp;
634                 struct cmd_ds_mac_control macctrl;
635                 struct cmd_ds_802_11_associate associate;
636                 struct cmd_ds_802_11_deauthenticate deauth;
637                 struct cmd_ds_802_11_set_wep wep;
638                 struct cmd_ds_802_11_ad_hoc_start ads;
639                 struct cmd_ds_802_11_reset reset;
640                 struct cmd_ds_802_11_ad_hoc_result result;
641                 struct cmd_ds_802_11_get_log glog;
642                 struct cmd_ds_802_11_authenticate auth;
643                 struct cmd_ds_802_11_get_stat gstat;
644                 struct cmd_ds_802_3_get_stat gstat_8023;
645                 struct cmd_ds_802_11_snmp_mib smib;
646                 struct cmd_ds_802_11_rf_tx_power txp;
647                 struct cmd_ds_802_11_rf_antenna rant;
648                 struct cmd_ds_802_11_monitor_mode monitor;
649                 struct cmd_ds_802_11_data_rate drate;
650                 struct cmd_ds_802_11_rate_adapt_rateset rateset;
651                 struct cmd_ds_mac_multicast_adr madr;
652                 struct cmd_ds_802_11_ad_hoc_join adj;
653                 struct cmd_ds_802_11_radio_control radio;
654                 struct cmd_ds_802_11_rf_channel rfchannel;
655                 struct cmd_ds_802_11_rssi rssi;
656                 struct cmd_ds_802_11_rssi_rsp rssirsp;
657                 struct cmd_ds_802_11_disassociate dassociate;
658                 struct cmd_ds_802_11_mac_address macadd;
659                 struct cmd_ds_802_11_enable_rsn enbrsn;
660                 struct cmd_ds_802_11_key_material keymaterial;
661                 struct cmd_ds_mac_reg_access macreg;
662                 struct cmd_ds_bbp_reg_access bbpreg;
663                 struct cmd_ds_rf_reg_access rfreg;
664                 struct cmd_ds_802_11_eeprom_access rdeeprom;
665
666                 struct cmd_ds_802_11d_domain_info domaininfo;
667                 struct cmd_ds_802_11d_domain_info domaininforesp;
668
669                 struct cmd_ds_802_11_sleep_params sleep_params;
670                 struct cmd_ds_802_11_inactivity_timeout inactivity_timeout;
671                 struct cmd_ds_802_11_tpc_cfg tpccfg;
672                 struct cmd_ds_802_11_pwr_cfg pwrcfg;
673                 struct cmd_ds_802_11_afc afc;
674                 struct cmd_ds_802_11_led_ctrl ledgpio;
675
676                 struct cmd_tx_rate_query txrate;
677                 struct cmd_ds_bt_access bt;
678                 struct cmd_ds_fwt_access fwt;
679                 struct cmd_ds_mesh_access mesh;
680                 struct cmd_ds_set_boot2_ver boot2_ver;
681                 struct cmd_ds_get_tsf gettsf;
682                 struct cmd_ds_802_11_subscribe_event subscribe_event;
683                 struct cmd_ds_802_11_beacon_control bcn_ctrl;
684         } params;
685 } __attribute__ ((packed));
686
687 #endif