blob: 2ad32bc2cf24d8e58cffc84c693103b40c419481 [file] [log] [blame]
Marcelo Tosatti876c9d32007-02-10 12:25:27 -02001/*
2 * This file contains the function prototypes, data structure
3 * and defines for all the host/station commands
4 */
Holger Schurig10078322007-11-15 18:05:47 -05005#ifndef _LBS_HOSTCMD_H
6#define _LBS_HOSTCMD_H
Marcelo Tosatti876c9d32007-02-10 12:25:27 -02007
8#include <linux/wireless.h>
9#include "11d.h"
10#include "types.h"
11
12/* 802.11-related definitions */
13
14/* TxPD descriptor */
15struct txpd {
16 /* Current Tx packet status */
David Woodhouse981f1872007-05-25 23:36:54 -040017 __le32 tx_status;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -020018 /* Tx control */
David Woodhouse981f1872007-05-25 23:36:54 -040019 __le32 tx_control;
20 __le32 tx_packet_location;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -020021 /* Tx packet length */
David Woodhouse981f1872007-05-25 23:36:54 -040022 __le16 tx_packet_length;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -020023 /* 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 */
38struct rxpd {
39 /* Current Rx packet status */
David Woodhouse981f1872007-05-25 23:36:54 -040040 __le16 status;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -020041
42 /* SNR */
43 u8 snr;
44
45 /* Tx control */
46 u8 rx_control;
47
48 /* Pkt length */
David Woodhouse981f1872007-05-25 23:36:54 -040049 __le16 pkt_len;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -020050
51 /* Noise Floor */
52 u8 nf;
53
54 /* Rx Packet Rate */
55 u8 rx_rate;
56
57 /* Pkt addr */
David Woodhouse981f1872007-05-25 23:36:54 -040058 __le32 pkt_ptr;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -020059
60 /* Next Rx RxPD addr */
David Woodhouse981f1872007-05-25 23:36:54 -040061 __le32 next_rxpd_ptr;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -020062
63 /* Pkt Priority */
64 u8 priority;
65 u8 reserved[3];
66};
67
Dan Williams7ad994d2007-12-11 12:33:30 -050068struct cmd_header {
69 __le16 command;
70 __le16 size;
71 __le16 seqnum;
72 __le16 result;
73} __attribute__ ((packed));
74
Marcelo Tosatti876c9d32007-02-10 12:25:27 -020075struct cmd_ctrl_node {
Marcelo Tosatti876c9d32007-02-10 12:25:27 -020076 struct list_head list;
David Woodhouseae125bf2007-12-15 04:22:52 -050077 int result;
Holger Schurig675787e2007-12-05 17:58:11 +010078 /* command response */
Dan Williams7ad994d2007-12-11 12:33:30 -050079 int (*callback)(struct lbs_private *, unsigned long, struct cmd_header *);
David Woodhouse1309b552007-12-10 13:36:10 -050080 unsigned long callback_arg;
Holger Schurig675787e2007-12-05 17:58:11 +010081 /* command data */
Dan Williamsddac4522007-12-11 13:49:39 -050082 struct cmd_header *cmdbuf;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -020083 /* wait queue */
84 u16 cmdwaitqwoken;
85 wait_queue_head_t cmdwait_q;
86};
87
Dan Williams1443b652007-08-02 10:45:55 -040088/* Generic structure to hold all key types. */
89struct enc_key {
90 u16 len;
Holger Schurig10078322007-11-15 18:05:47 -050091 u16 flags; /* KEY_INFO_* from defs.h */
92 u16 type; /* KEY_TYPE_* from defs.h */
Dan Williams1443b652007-08-02 10:45:55 -040093 u8 key[32];
Marcelo Tosatti876c9d32007-02-10 12:25:27 -020094};
95
Holger Schurig10078322007-11-15 18:05:47 -050096/* lbs_offset_value */
97struct lbs_offset_value {
Marcelo Tosatti876c9d32007-02-10 12:25:27 -020098 u32 offset;
99 u32 value;
100};
101
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200102/* Define general data structure */
103/* cmd_DS_GEN */
104struct cmd_ds_gen {
David Woodhouse981f1872007-05-25 23:36:54 -0400105 __le16 command;
106 __le16 size;
107 __le16 seqnum;
108 __le16 result;
Holger Schurig675787e2007-12-05 17:58:11 +0100109 void *cmdresp[0];
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200110};
111
112#define S_DS_GEN sizeof(struct cmd_ds_gen)
Holger Schurig675787e2007-12-05 17:58:11 +0100113
114
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200115/*
Dan Williams0aef64d2007-08-02 11:31:18 -0400116 * Define data structure for CMD_GET_HW_SPEC
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200117 * This structure defines the response for the GET_HW_SPEC command
118 */
119struct cmd_ds_get_hw_spec {
Dan Williams6e66f032007-12-11 12:42:16 -0500120 struct cmd_header hdr;
121
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200122 /* HW Interface version number */
David Woodhouse981f1872007-05-25 23:36:54 -0400123 __le16 hwifversion;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200124 /* HW version number */
David Woodhouse981f1872007-05-25 23:36:54 -0400125 __le16 version;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200126 /* Max number of TxPD FW can handle */
David Woodhouse981f1872007-05-25 23:36:54 -0400127 __le16 nr_txpd;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200128 /* Max no of Multicast address */
David Woodhouse981f1872007-05-25 23:36:54 -0400129 __le16 nr_mcast_adr;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200130 /* MAC address */
131 u8 permanentaddr[6];
132
133 /* region Code */
David Woodhouse981f1872007-05-25 23:36:54 -0400134 __le16 regioncode;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200135
136 /* Number of antenna used */
David Woodhouse981f1872007-05-25 23:36:54 -0400137 __le16 nr_antenna;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200138
David Woodhousee5b3d472007-05-25 23:40:21 -0400139 /* FW release number, example 1,2,3,4 = 3.2.1p4 */
140 u8 fwreleasenumber[4];
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200141
142 /* Base Address of TxPD queue */
David Woodhouse981f1872007-05-25 23:36:54 -0400143 __le32 wcb_base;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200144 /* Read Pointer of RxPd queue */
David Woodhouse981f1872007-05-25 23:36:54 -0400145 __le32 rxpd_rdptr;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200146
147 /* Write Pointer of RxPd queue */
David Woodhouse981f1872007-05-25 23:36:54 -0400148 __le32 rxpd_wrptr;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200149
150 /*FW/HW capability */
David Woodhouse981f1872007-05-25 23:36:54 -0400151 __le32 fwcapinfo;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200152} __attribute__ ((packed));
153
154struct cmd_ds_802_11_reset {
David Woodhouse981f1872007-05-25 23:36:54 -0400155 __le16 action;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200156};
157
158struct cmd_ds_802_11_subscribe_event {
David Woodhouse981f1872007-05-25 23:36:54 -0400159 __le16 action;
160 __le16 events;
Holger Schurig3a188642007-11-26 10:07:14 +0100161
162 /* A TLV to the CMD_802_11_SUBSCRIBE_EVENT command can contain a
163 * number of TLVs. From the v5.1 manual, those TLVs would add up to
164 * 40 bytes. However, future firmware might add additional TLVs, so I
165 * bump this up a bit.
166 */
167 u8 tlv[128];
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200168};
169
170/*
171 * This scan handle Country Information IE(802.11d compliant)
Dan Williams0aef64d2007-08-02 11:31:18 -0400172 * Define data structure for CMD_802_11_SCAN
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200173 */
174struct cmd_ds_802_11_scan {
175 u8 bsstype;
Dan Williams492b6da2007-08-02 11:16:07 -0400176 u8 bssid[ETH_ALEN];
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200177 u8 tlvbuffer[1];
178#if 0
179 mrvlietypes_ssidparamset_t ssidParamSet;
180 mrvlietypes_chanlistparamset_t ChanListParamSet;
181 mrvlietypes_ratesparamset_t OpRateSet;
182#endif
183};
184
185struct cmd_ds_802_11_scan_rsp {
David Woodhouse981f1872007-05-25 23:36:54 -0400186 __le16 bssdescriptsize;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200187 u8 nr_sets;
188 u8 bssdesc_and_tlvbuffer[1];
189};
190
191struct cmd_ds_802_11_get_log {
David Woodhouse981f1872007-05-25 23:36:54 -0400192 __le32 mcasttxframe;
193 __le32 failed;
194 __le32 retry;
195 __le32 multiretry;
196 __le32 framedup;
197 __le32 rtssuccess;
198 __le32 rtsfailure;
199 __le32 ackfailure;
200 __le32 rxfrag;
201 __le32 mcastrxframe;
202 __le32 fcserror;
203 __le32 txframe;
204 __le32 wepundecryptable;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200205};
206
207struct cmd_ds_mac_control {
David Woodhouse981f1872007-05-25 23:36:54 -0400208 __le16 action;
209 __le16 reserved;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200210};
211
212struct cmd_ds_mac_multicast_adr {
David Woodhouse981f1872007-05-25 23:36:54 -0400213 __le16 action;
214 __le16 nr_of_adrs;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200215 u8 maclist[ETH_ALEN * MRVDRV_MAX_MULTICAST_LIST_SIZE];
216};
217
218struct cmd_ds_802_11_authenticate {
219 u8 macaddr[ETH_ALEN];
220 u8 authtype;
221 u8 reserved[10];
222};
223
224struct cmd_ds_802_11_deauthenticate {
225 u8 macaddr[6];
David Woodhouse981f1872007-05-25 23:36:54 -0400226 __le16 reasoncode;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200227};
228
229struct cmd_ds_802_11_associate {
230 u8 peerstaaddr[6];
Dan Williams0c9ca692007-08-02 10:43:44 -0400231 __le16 capability;
David Woodhouse981f1872007-05-25 23:36:54 -0400232 __le16 listeninterval;
233 __le16 bcnperiod;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200234 u8 dtimperiod;
235
236#if 0
237 mrvlietypes_ssidparamset_t ssidParamSet;
238 mrvlietypes_phyparamset_t phyparamset;
239 mrvlietypes_ssparamset_t ssparamset;
240 mrvlietypes_ratesparamset_t ratesParamSet;
241#endif
242} __attribute__ ((packed));
243
244struct cmd_ds_802_11_disassociate {
245 u8 destmacaddr[6];
David Woodhouse981f1872007-05-25 23:36:54 -0400246 __le16 reasoncode;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200247};
248
249struct cmd_ds_802_11_associate_rsp {
250 struct ieeetypes_assocrsp assocRsp;
251};
252
253struct cmd_ds_802_11_ad_hoc_result {
Dan Williamsea8da922007-08-02 11:18:23 -0400254 u8 pad[3];
255 u8 bssid[ETH_ALEN];
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200256};
257
258struct cmd_ds_802_11_set_wep {
259 /* ACT_ADD, ACT_REMOVE or ACT_ENABLE */
David Woodhouse981f1872007-05-25 23:36:54 -0400260 __le16 action;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200261
262 /* key Index selected for Tx */
David Woodhouse981f1872007-05-25 23:36:54 -0400263 __le16 keyindex;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200264
265 /* 40, 128bit or TXWEP */
266 u8 keytype[4];
267 u8 keymaterial[4][16];
268};
269
270struct cmd_ds_802_3_get_stat {
David Woodhouse981f1872007-05-25 23:36:54 -0400271 __le32 xmitok;
272 __le32 rcvok;
273 __le32 xmiterror;
274 __le32 rcverror;
275 __le32 rcvnobuffer;
276 __le32 rcvcrcerror;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200277};
278
279struct cmd_ds_802_11_get_stat {
David Woodhouse981f1872007-05-25 23:36:54 -0400280 __le32 txfragmentcnt;
281 __le32 mcasttxframecnt;
282 __le32 failedcnt;
283 __le32 retrycnt;
284 __le32 Multipleretrycnt;
285 __le32 rtssuccesscnt;
286 __le32 rtsfailurecnt;
287 __le32 ackfailurecnt;
288 __le32 frameduplicatecnt;
289 __le32 rxfragmentcnt;
290 __le32 mcastrxframecnt;
291 __le32 fcserrorcnt;
292 __le32 bcasttxframecnt;
293 __le32 bcastrxframecnt;
294 __le32 txbeacon;
295 __le32 rxbeacon;
296 __le32 wepundecryptable;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200297};
298
299struct cmd_ds_802_11_snmp_mib {
David Woodhouse981f1872007-05-25 23:36:54 -0400300 __le16 querytype;
301 __le16 oid;
302 __le16 bufsize;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200303 u8 value[128];
304};
305
306struct cmd_ds_mac_reg_map {
David Woodhouse981f1872007-05-25 23:36:54 -0400307 __le16 buffersize;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200308 u8 regmap[128];
David Woodhouse981f1872007-05-25 23:36:54 -0400309 __le16 reserved;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200310};
311
312struct cmd_ds_bbp_reg_map {
David Woodhouse981f1872007-05-25 23:36:54 -0400313 __le16 buffersize;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200314 u8 regmap[128];
David Woodhouse981f1872007-05-25 23:36:54 -0400315 __le16 reserved;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200316};
317
318struct cmd_ds_rf_reg_map {
David Woodhouse981f1872007-05-25 23:36:54 -0400319 __le16 buffersize;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200320 u8 regmap[64];
David Woodhouse981f1872007-05-25 23:36:54 -0400321 __le16 reserved;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200322};
323
324struct cmd_ds_mac_reg_access {
David Woodhouse981f1872007-05-25 23:36:54 -0400325 __le16 action;
326 __le16 offset;
327 __le32 value;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200328};
329
330struct cmd_ds_bbp_reg_access {
David Woodhouse981f1872007-05-25 23:36:54 -0400331 __le16 action;
332 __le16 offset;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200333 u8 value;
334 u8 reserved[3];
335};
336
337struct cmd_ds_rf_reg_access {
David Woodhouse981f1872007-05-25 23:36:54 -0400338 __le16 action;
339 __le16 offset;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200340 u8 value;
341 u8 reserved[3];
342};
343
344struct cmd_ds_802_11_radio_control {
David Woodhousea7c45892007-12-17 22:43:48 -0500345 struct cmd_header hdr;
346
David Woodhouse981f1872007-05-25 23:36:54 -0400347 __le16 action;
348 __le16 control;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200349};
350
Brajesh Dave96287ac2007-11-20 17:44:28 -0500351struct cmd_ds_802_11_beacon_control {
352 __le16 action;
353 __le16 beacon_enable;
354 __le16 beacon_period;
355};
356
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200357struct cmd_ds_802_11_sleep_params {
358 /* ACT_GET/ACT_SET */
David Woodhouse981f1872007-05-25 23:36:54 -0400359 __le16 action;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200360
361 /* Sleep clock error in ppm */
David Woodhouse981f1872007-05-25 23:36:54 -0400362 __le16 error;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200363
364 /* Wakeup offset in usec */
David Woodhouse981f1872007-05-25 23:36:54 -0400365 __le16 offset;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200366
367 /* Clock stabilization time in usec */
David Woodhouse981f1872007-05-25 23:36:54 -0400368 __le16 stabletime;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200369
370 /* control periodic calibration */
371 u8 calcontrol;
372
373 /* control the use of external sleep clock */
374 u8 externalsleepclk;
375
376 /* reserved field, should be set to zero */
David Woodhouse981f1872007-05-25 23:36:54 -0400377 __le16 reserved;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200378};
379
380struct cmd_ds_802_11_inactivity_timeout {
David Woodhouse6e5cc4f2007-12-17 23:04:37 -0500381 struct cmd_header hdr;
382
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200383 /* ACT_GET/ACT_SET */
David Woodhouse981f1872007-05-25 23:36:54 -0400384 __le16 action;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200385
386 /* Inactivity timeout in msec */
David Woodhouse981f1872007-05-25 23:36:54 -0400387 __le16 timeout;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200388};
389
390struct cmd_ds_802_11_rf_channel {
Dan Williams2dd4b262007-12-11 16:54:15 -0500391 struct cmd_header hdr;
392
David Woodhouse981f1872007-05-25 23:36:54 -0400393 __le16 action;
Dan Williams2dd4b262007-12-11 16:54:15 -0500394 __le16 channel;
395 __le16 rftype; /* unused */
396 __le16 reserved; /* unused */
397 u8 channellist[32]; /* unused */
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200398};
399
400struct cmd_ds_802_11_rssi {
401 /* weighting factor */
David Woodhouse981f1872007-05-25 23:36:54 -0400402 __le16 N;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200403
David Woodhouse981f1872007-05-25 23:36:54 -0400404 __le16 reserved_0;
405 __le16 reserved_1;
406 __le16 reserved_2;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200407};
408
409struct cmd_ds_802_11_rssi_rsp {
David Woodhouse981f1872007-05-25 23:36:54 -0400410 __le16 SNR;
411 __le16 noisefloor;
412 __le16 avgSNR;
413 __le16 avgnoisefloor;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200414};
415
416struct cmd_ds_802_11_mac_address {
David Woodhouse981f1872007-05-25 23:36:54 -0400417 __le16 action;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200418 u8 macadd[ETH_ALEN];
419};
420
421struct cmd_ds_802_11_rf_tx_power {
David Woodhouse981f1872007-05-25 23:36:54 -0400422 __le16 action;
423 __le16 currentlevel;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200424};
425
426struct cmd_ds_802_11_rf_antenna {
David Woodhouse981f1872007-05-25 23:36:54 -0400427 __le16 action;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200428
429 /* Number of antennas or 0xffff(diversity) */
David Woodhouse981f1872007-05-25 23:36:54 -0400430 __le16 antennamode;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200431
432};
433
Luis Carlos Cobo965f8bb2007-08-02 13:16:55 -0400434struct cmd_ds_802_11_monitor_mode {
Holger Schurigc2df2ef2007-12-07 15:30:44 +0000435 __le16 action;
436 __le16 mode;
Luis Carlos Cobo965f8bb2007-08-02 13:16:55 -0400437};
438
Luis Carlos Cobo63f00232007-08-02 13:19:24 -0400439struct cmd_ds_set_boot2_ver {
Dan Williams7ad994d2007-12-11 12:33:30 -0500440 struct cmd_header hdr;
441
Holger Schurigc2df2ef2007-12-07 15:30:44 +0000442 __le16 action;
443 __le16 version;
Luis Carlos Cobo63f00232007-08-02 13:19:24 -0400444};
445
David Woodhousec6ad3732007-12-16 21:43:40 -0500446struct cmd_ds_802_11_fw_wake_method {
447 struct cmd_header hdr;
448
449 __le16 action;
450 __le16 method;
451};
452
453struct cmd_ds_802_11_sleep_period {
454 struct cmd_header hdr;
455
456 __le16 action;
457 __le16 period;
458};
459
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200460struct cmd_ds_802_11_ps_mode {
David Woodhouse981f1872007-05-25 23:36:54 -0400461 __le16 action;
462 __le16 nullpktinterval;
463 __le16 multipledtim;
464 __le16 reserved;
465 __le16 locallisteninterval;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200466};
467
468struct PS_CMD_ConfirmSleep {
David Woodhouse981f1872007-05-25 23:36:54 -0400469 __le16 command;
470 __le16 size;
471 __le16 seqnum;
472 __le16 result;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200473
David Woodhouse981f1872007-05-25 23:36:54 -0400474 __le16 action;
475 __le16 reserved1;
476 __le16 multipledtim;
477 __le16 reserved;
478 __le16 locallisteninterval;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200479};
480
481struct cmd_ds_802_11_data_rate {
Dan Williams8e3c91b2007-12-11 15:50:59 -0500482 struct cmd_header hdr;
483
David Woodhouse981f1872007-05-25 23:36:54 -0400484 __le16 action;
Dan Williams8c512762007-08-02 11:40:45 -0400485 __le16 reserved;
486 u8 rates[MAX_RATES];
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200487};
488
489struct cmd_ds_802_11_rate_adapt_rateset {
David Woodhouse981f1872007-05-25 23:36:54 -0400490 __le16 action;
491 __le16 enablehwauto;
492 __le16 bitmap;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200493};
494
495struct cmd_ds_802_11_ad_hoc_start {
Dan Williamsb44898e2007-08-02 11:18:40 -0400496 u8 ssid[IW_ESSID_MAX_SIZE];
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200497 u8 bsstype;
David Woodhouse981f1872007-05-25 23:36:54 -0400498 __le16 beaconperiod;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200499 u8 dtimperiod;
500 union IEEEtypes_ssparamset ssparamset;
501 union ieeetypes_phyparamset phyparamset;
David Woodhouse981f1872007-05-25 23:36:54 -0400502 __le16 probedelay;
Dan Williams0c9ca692007-08-02 10:43:44 -0400503 __le16 capability;
Dan Williams8c512762007-08-02 11:40:45 -0400504 u8 rates[MAX_RATES];
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200505 u8 tlv_memory_size_pad[100];
506} __attribute__ ((packed));
507
508struct adhoc_bssdesc {
Dan Williams0c9ca692007-08-02 10:43:44 -0400509 u8 bssid[6];
510 u8 ssid[32];
511 u8 type;
David Woodhouse981f1872007-05-25 23:36:54 -0400512 __le16 beaconperiod;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200513 u8 dtimperiod;
David Woodhouse981f1872007-05-25 23:36:54 -0400514 __le64 timestamp;
515 __le64 localtime;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200516 union ieeetypes_phyparamset phyparamset;
517 union IEEEtypes_ssparamset ssparamset;
Dan Williams0c9ca692007-08-02 10:43:44 -0400518 __le16 capability;
Dan Williams8c512762007-08-02 11:40:45 -0400519 u8 rates[MAX_RATES];
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200520
521 /* DO NOT ADD ANY FIELDS TO THIS STRUCTURE. It is used below in the
522 * Adhoc join command and will cause a binary layout mismatch with
523 * the firmware
524 */
525} __attribute__ ((packed));
526
527struct cmd_ds_802_11_ad_hoc_join {
Dan Williams0c9ca692007-08-02 10:43:44 -0400528 struct adhoc_bssdesc bss;
David Woodhouse981f1872007-05-25 23:36:54 -0400529 __le16 failtimeout;
530 __le16 probedelay;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200531
532} __attribute__ ((packed));
533
534struct cmd_ds_802_11_enable_rsn {
David Woodhouse981f1872007-05-25 23:36:54 -0400535 __le16 action;
536 __le16 enable;
Dan Williams18c96c342007-06-18 12:01:12 -0400537} __attribute__ ((packed));
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200538
539struct MrvlIEtype_keyParamSet {
540 /* type ID */
David Woodhouse981f1872007-05-25 23:36:54 -0400541 __le16 type;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200542
543 /* length of Payload */
David Woodhouse981f1872007-05-25 23:36:54 -0400544 __le16 length;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200545
546 /* type of key: WEP=0, TKIP=1, AES=2 */
David Woodhouse981f1872007-05-25 23:36:54 -0400547 __le16 keytypeid;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200548
549 /* key control Info specific to a keytypeid */
David Woodhouse981f1872007-05-25 23:36:54 -0400550 __le16 keyinfo;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200551
552 /* length of key */
David Woodhouse981f1872007-05-25 23:36:54 -0400553 __le16 keylen;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200554
555 /* key material of size keylen */
556 u8 key[32];
557};
558
David Woodhouse6ce4fd22007-12-12 15:19:29 -0500559struct cmd_ds_host_sleep {
560 struct cmd_header hdr;
561 __le32 criteria;
562 uint8_t gpio;
563 uint8_t gap;
564} __attribute__ ((packed));
565
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200566struct cmd_ds_802_11_key_material {
David Woodhouse981f1872007-05-25 23:36:54 -0400567 __le16 action;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200568 struct MrvlIEtype_keyParamSet keyParamSet[2];
569} __attribute__ ((packed));
570
571struct cmd_ds_802_11_eeprom_access {
David Woodhouse981f1872007-05-25 23:36:54 -0400572 __le16 action;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200573
574 /* multiple 4 */
David Woodhouse981f1872007-05-25 23:36:54 -0400575 __le16 offset;
576 __le16 bytecount;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200577 u8 value;
578} __attribute__ ((packed));
579
580struct cmd_ds_802_11_tpc_cfg {
David Woodhouse981f1872007-05-25 23:36:54 -0400581 __le16 action;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200582 u8 enable;
583 s8 P0;
584 s8 P1;
585 s8 P2;
586 u8 usesnr;
587} __attribute__ ((packed));
588
589struct cmd_ds_802_11_led_ctrl {
David Woodhouse981f1872007-05-25 23:36:54 -0400590 __le16 action;
591 __le16 numled;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200592 u8 data[256];
593} __attribute__ ((packed));
594
595struct cmd_ds_802_11_pwr_cfg {
David Woodhouse981f1872007-05-25 23:36:54 -0400596 __le16 action;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200597 u8 enable;
598 s8 PA_P0;
599 s8 PA_P1;
600 s8 PA_P2;
601} __attribute__ ((packed));
602
603struct cmd_ds_802_11_afc {
David Woodhouse981f1872007-05-25 23:36:54 -0400604 __le16 afc_auto;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200605 union {
606 struct {
David Woodhouse981f1872007-05-25 23:36:54 -0400607 __le16 threshold;
608 __le16 period;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200609 };
610 struct {
David Woodhouse981f1872007-05-25 23:36:54 -0400611 __le16 timing_offset; /* signed */
612 __le16 carrier_offset; /* signed */
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200613 };
614 };
615} __attribute__ ((packed));
616
617struct cmd_tx_rate_query {
David Woodhouse981f1872007-05-25 23:36:54 -0400618 __le16 txrate;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200619} __attribute__ ((packed));
620
621struct cmd_ds_get_tsf {
622 __le64 tsfvalue;
623} __attribute__ ((packed));
624
625struct cmd_ds_bt_access {
David Woodhouse981f1872007-05-25 23:36:54 -0400626 __le16 action;
627 __le32 id;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200628 u8 addr1[ETH_ALEN];
629 u8 addr2[ETH_ALEN];
630} __attribute__ ((packed));
631
632struct cmd_ds_fwt_access {
David Woodhouse981f1872007-05-25 23:36:54 -0400633 __le16 action;
634 __le32 id;
Luis Carlos Cobo90e8eaf2007-05-25 13:53:26 -0400635 u8 valid;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200636 u8 da[ETH_ALEN];
637 u8 dir;
638 u8 ra[ETH_ALEN];
David Woodhouse981f1872007-05-25 23:36:54 -0400639 __le32 ssn;
640 __le32 dsn;
641 __le32 metric;
Luis Carlos Cobo90e8eaf2007-05-25 13:53:26 -0400642 u8 rate;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200643 u8 hopcount;
644 u8 ttl;
David Woodhouse981f1872007-05-25 23:36:54 -0400645 __le32 expiration;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200646 u8 sleepmode;
David Woodhouse981f1872007-05-25 23:36:54 -0400647 __le32 snr;
648 __le32 references;
Luis Carlos Cobo90e8eaf2007-05-25 13:53:26 -0400649 u8 prec[ETH_ALEN];
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200650} __attribute__ ((packed));
651
David Woodhouse23a397a2007-12-11 18:56:42 -0500652
653struct cmd_ds_mesh_config {
654 struct cmd_header hdr;
655
656 __le16 action;
657 __le16 channel;
658 __le16 type;
659 __le16 length;
660 u8 data[128]; /* last position reserved */
661} __attribute__ ((packed));
662
663
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200664struct cmd_ds_mesh_access {
David Woodhouse301eacb2007-12-11 15:23:59 -0500665 struct cmd_header hdr;
666
David Woodhouse981f1872007-05-25 23:36:54 -0400667 __le16 action;
668 __le32 data[32]; /* last position reserved */
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200669} __attribute__ ((packed));
670
Javier Cardona0601e7e2007-05-25 12:12:06 -0400671/* Number of stats counters returned by the firmware */
672#define MESH_STATS_NUM 8
673
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200674struct cmd_ds_command {
675 /* command header */
David Woodhouse981f1872007-05-25 23:36:54 -0400676 __le16 command;
677 __le16 size;
678 __le16 seqnum;
679 __le16 result;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200680
681 /* command Body */
682 union {
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200683 struct cmd_ds_802_11_ps_mode psmode;
684 struct cmd_ds_802_11_scan scan;
685 struct cmd_ds_802_11_scan_rsp scanresp;
686 struct cmd_ds_mac_control macctrl;
687 struct cmd_ds_802_11_associate associate;
688 struct cmd_ds_802_11_deauthenticate deauth;
689 struct cmd_ds_802_11_set_wep wep;
690 struct cmd_ds_802_11_ad_hoc_start ads;
691 struct cmd_ds_802_11_reset reset;
692 struct cmd_ds_802_11_ad_hoc_result result;
693 struct cmd_ds_802_11_get_log glog;
694 struct cmd_ds_802_11_authenticate auth;
695 struct cmd_ds_802_11_get_stat gstat;
696 struct cmd_ds_802_3_get_stat gstat_8023;
697 struct cmd_ds_802_11_snmp_mib smib;
698 struct cmd_ds_802_11_rf_tx_power txp;
699 struct cmd_ds_802_11_rf_antenna rant;
Luis Carlos Cobo965f8bb2007-08-02 13:16:55 -0400700 struct cmd_ds_802_11_monitor_mode monitor;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200701 struct cmd_ds_802_11_rate_adapt_rateset rateset;
702 struct cmd_ds_mac_multicast_adr madr;
703 struct cmd_ds_802_11_ad_hoc_join adj;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200704 struct cmd_ds_802_11_rssi rssi;
705 struct cmd_ds_802_11_rssi_rsp rssirsp;
706 struct cmd_ds_802_11_disassociate dassociate;
707 struct cmd_ds_802_11_mac_address macadd;
708 struct cmd_ds_802_11_enable_rsn enbrsn;
709 struct cmd_ds_802_11_key_material keymaterial;
710 struct cmd_ds_mac_reg_access macreg;
711 struct cmd_ds_bbp_reg_access bbpreg;
712 struct cmd_ds_rf_reg_access rfreg;
713 struct cmd_ds_802_11_eeprom_access rdeeprom;
714
715 struct cmd_ds_802_11d_domain_info domaininfo;
716 struct cmd_ds_802_11d_domain_info domaininforesp;
717
718 struct cmd_ds_802_11_sleep_params sleep_params;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200719 struct cmd_ds_802_11_tpc_cfg tpccfg;
720 struct cmd_ds_802_11_pwr_cfg pwrcfg;
721 struct cmd_ds_802_11_afc afc;
722 struct cmd_ds_802_11_led_ctrl ledgpio;
723
724 struct cmd_tx_rate_query txrate;
725 struct cmd_ds_bt_access bt;
726 struct cmd_ds_fwt_access fwt;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200727 struct cmd_ds_get_tsf gettsf;
728 struct cmd_ds_802_11_subscribe_event subscribe_event;
Brajesh Dave96287ac2007-11-20 17:44:28 -0500729 struct cmd_ds_802_11_beacon_control bcn_ctrl;
Marcelo Tosatti876c9d32007-02-10 12:25:27 -0200730 } params;
731} __attribute__ ((packed));
732
733#endif