hostcmd.h 13.8 KB
Newer Older
1 2 3 4
/*
 * This file contains the function prototypes, data structure
 * and defines for all the host/station commands
 */
5 6
#ifndef _LBS_HOSTCMD_H
#define _LBS_HOSTCMD_H
7 8 9 10 11 12 13 14 15 16

#include <linux/wireless.h>
#include "11d.h"
#include "types.h"

/* 802.11-related definitions */

/* TxPD descriptor */
struct txpd {
	/* Current Tx packet status */
17
	__le32 tx_status;
18
	/* Tx control */
19 20
	__le32 tx_control;
	__le32 tx_packet_location;
21
	/* Tx packet length */
22
	__le16 tx_packet_length;
23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39
	/* First 2 byte of destination MAC address */
	u8 tx_dest_addr_high[2];
	/* Last 4 byte of destination MAC address */
	u8 tx_dest_addr_low[4];
	/* Pkt Priority */
	u8 priority;
	/* Pkt Trasnit Power control */
	u8 powermgmt;
	/* Amount of time the packet has been queued in the driver (units = 2ms) */
	u8 pktdelay_2ms;
	/* reserved */
	u8 reserved1;
};

/* RxPD Descriptor */
struct rxpd {
	/* Current Rx packet status */
40
	__le16 status;
41 42 43 44 45 46 47 48

	/* SNR */
	u8 snr;

	/* Tx control */
	u8 rx_control;

	/* Pkt length */
49
	__le16 pkt_len;
50 51 52 53 54 55 56 57

	/* Noise Floor */
	u8 nf;

	/* Rx Packet Rate */
	u8 rx_rate;

	/* Pkt addr */
58
	__le32 pkt_ptr;
59 60

	/* Next Rx RxPD addr */
61
	__le32 next_rxpd_ptr;
62 63 64 65 66 67

	/* Pkt Priority */
	u8 priority;
	u8 reserved[3];
};

68 69 70 71 72 73 74
struct cmd_header {
	__le16 command;
	__le16 size;
	__le16 seqnum;
	__le16 result;
} __attribute__ ((packed));

75 76
struct cmd_ctrl_node {
	struct list_head list;
77
	int result;
78
	/* command response */
79
	int (*callback)(struct lbs_private *, unsigned long, struct cmd_header *);
80
	unsigned long callback_arg;
81
	/* command data */
82
	struct cmd_header *cmdbuf;
83 84 85 86 87
	/* wait queue */
	u16 cmdwaitqwoken;
	wait_queue_head_t cmdwait_q;
};

88 89 90
/* Generic structure to hold all key types. */
struct enc_key {
	u16 len;
91 92
	u16 flags;  /* KEY_INFO_* from defs.h */
	u16 type; /* KEY_TYPE_* from defs.h */
93
	u8 key[32];
94 95
};

96 97
/* lbs_offset_value */
struct lbs_offset_value {
98 99 100 101 102 103 104
	u32 offset;
	u32 value;
};

/* Define general data structure */
/* cmd_DS_GEN */
struct cmd_ds_gen {
105 106 107 108
	__le16 command;
	__le16 size;
	__le16 seqnum;
	__le16 result;
109
	void *cmdresp[0];
110 111 112
};

#define S_DS_GEN sizeof(struct cmd_ds_gen)
113 114


115
/*
116
 * Define data structure for CMD_GET_HW_SPEC
117 118 119
 * This structure defines the response for the GET_HW_SPEC command
 */
struct cmd_ds_get_hw_spec {
120 121
	struct cmd_header hdr;

122
	/* HW Interface version number */
123
	__le16 hwifversion;
124
	/* HW version number */
125
	__le16 version;
126
	/* Max number of TxPD FW can handle */
127
	__le16 nr_txpd;
128
	/* Max no of Multicast address */
129
	__le16 nr_mcast_adr;
130 131 132 133
	/* MAC address */
	u8 permanentaddr[6];

	/* region Code */
134
	__le16 regioncode;
135 136

	/* Number of antenna used */
137
	__le16 nr_antenna;
138

139 140
	/* FW release number, example 1,2,3,4 = 3.2.1p4 */
	u8 fwreleasenumber[4];
141 142

	/* Base Address of TxPD queue */
143
	__le32 wcb_base;
144
	/* Read Pointer of RxPd queue */
145
	__le32 rxpd_rdptr;
146 147

	/* Write Pointer of RxPd queue */
148
	__le32 rxpd_wrptr;
149 150

	/*FW/HW capability */
151
	__le32 fwcapinfo;
152 153 154
} __attribute__ ((packed));

struct cmd_ds_802_11_reset {
155
	__le16 action;
156 157 158
};

struct cmd_ds_802_11_subscribe_event {
159 160
	__le16 action;
	__le16 events;
161 162 163 164 165 166 167

	/* A TLV to the CMD_802_11_SUBSCRIBE_EVENT command can contain a
	 * number of TLVs. From the v5.1 manual, those TLVs would add up to
	 * 40 bytes. However, future firmware might add additional TLVs, so I
	 * bump this up a bit.
	 */
	u8 tlv[128];
168 169 170 171
};

/*
 * This scan handle Country Information IE(802.11d compliant)
172
 * Define data structure for CMD_802_11_SCAN
173 174 175
 */
struct cmd_ds_802_11_scan {
	u8 bsstype;
176
	u8 bssid[ETH_ALEN];
177 178 179 180 181 182 183 184 185
	u8 tlvbuffer[1];
#if 0
	mrvlietypes_ssidparamset_t ssidParamSet;
	mrvlietypes_chanlistparamset_t ChanListParamSet;
	mrvlietypes_ratesparamset_t OpRateSet;
#endif
};

struct cmd_ds_802_11_scan_rsp {
186
	__le16 bssdescriptsize;
187 188 189 190 191
	u8 nr_sets;
	u8 bssdesc_and_tlvbuffer[1];
};

struct cmd_ds_802_11_get_log {
192 193 194 195 196 197 198 199 200 201 202 203 204
	__le32 mcasttxframe;
	__le32 failed;
	__le32 retry;
	__le32 multiretry;
	__le32 framedup;
	__le32 rtssuccess;
	__le32 rtsfailure;
	__le32 ackfailure;
	__le32 rxfrag;
	__le32 mcastrxframe;
	__le32 fcserror;
	__le32 txframe;
	__le32 wepundecryptable;
205 206 207
};

struct cmd_ds_mac_control {
208 209
	__le16 action;
	__le16 reserved;
210 211 212
};

struct cmd_ds_mac_multicast_adr {
213 214
	__le16 action;
	__le16 nr_of_adrs;
215 216 217 218 219 220 221 222 223 224 225
	u8 maclist[ETH_ALEN * MRVDRV_MAX_MULTICAST_LIST_SIZE];
};

struct cmd_ds_802_11_authenticate {
	u8 macaddr[ETH_ALEN];
	u8 authtype;
	u8 reserved[10];
};

struct cmd_ds_802_11_deauthenticate {
	u8 macaddr[6];
226
	__le16 reasoncode;
227 228 229 230
};

struct cmd_ds_802_11_associate {
	u8 peerstaaddr[6];
231
	__le16 capability;
232 233
	__le16 listeninterval;
	__le16 bcnperiod;
234 235 236 237 238 239 240 241 242 243 244 245
	u8 dtimperiod;

#if 0
	mrvlietypes_ssidparamset_t ssidParamSet;
	mrvlietypes_phyparamset_t phyparamset;
	mrvlietypes_ssparamset_t ssparamset;
	mrvlietypes_ratesparamset_t ratesParamSet;
#endif
} __attribute__ ((packed));

struct cmd_ds_802_11_disassociate {
	u8 destmacaddr[6];
246
	__le16 reasoncode;
247 248 249 250 251 252 253
};

struct cmd_ds_802_11_associate_rsp {
	struct ieeetypes_assocrsp assocRsp;
};

struct cmd_ds_802_11_ad_hoc_result {
254 255
	u8 pad[3];
	u8 bssid[ETH_ALEN];
256 257 258
};

struct cmd_ds_802_11_set_wep {
259 260
	struct cmd_header hdr;

261
	/* ACT_ADD, ACT_REMOVE or ACT_ENABLE */
262
	__le16 action;
263 264

	/* key Index selected for Tx */
265
	__le16 keyindex;
266 267

	/* 40, 128bit or TXWEP */
268 269
	uint8_t keytype[4];
	uint8_t keymaterial[4][16];
270 271 272
};

struct cmd_ds_802_3_get_stat {
273 274 275 276 277 278
	__le32 xmitok;
	__le32 rcvok;
	__le32 xmiterror;
	__le32 rcverror;
	__le32 rcvnobuffer;
	__le32 rcvcrcerror;
279 280 281
};

struct cmd_ds_802_11_get_stat {
282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298
	__le32 txfragmentcnt;
	__le32 mcasttxframecnt;
	__le32 failedcnt;
	__le32 retrycnt;
	__le32 Multipleretrycnt;
	__le32 rtssuccesscnt;
	__le32 rtsfailurecnt;
	__le32 ackfailurecnt;
	__le32 frameduplicatecnt;
	__le32 rxfragmentcnt;
	__le32 mcastrxframecnt;
	__le32 fcserrorcnt;
	__le32 bcasttxframecnt;
	__le32 bcastrxframecnt;
	__le32 txbeacon;
	__le32 rxbeacon;
	__le32 wepundecryptable;
299 300 301
};

struct cmd_ds_802_11_snmp_mib {
302 303 304
	__le16 querytype;
	__le16 oid;
	__le16 bufsize;
305 306 307 308
	u8 value[128];
};

struct cmd_ds_mac_reg_map {
309
	__le16 buffersize;
310
	u8 regmap[128];
311
	__le16 reserved;
312 313 314
};

struct cmd_ds_bbp_reg_map {
315
	__le16 buffersize;
316
	u8 regmap[128];
317
	__le16 reserved;
318 319 320
};

struct cmd_ds_rf_reg_map {
321
	__le16 buffersize;
322
	u8 regmap[64];
323
	__le16 reserved;
324 325 326
};

struct cmd_ds_mac_reg_access {
327 328 329
	__le16 action;
	__le16 offset;
	__le32 value;
330 331 332
};

struct cmd_ds_bbp_reg_access {
333 334
	__le16 action;
	__le16 offset;
335 336 337 338 339
	u8 value;
	u8 reserved[3];
};

struct cmd_ds_rf_reg_access {
340 341
	__le16 action;
	__le16 offset;
342 343 344 345 346
	u8 value;
	u8 reserved[3];
};

struct cmd_ds_802_11_radio_control {
347 348
	struct cmd_header hdr;

349 350
	__le16 action;
	__le16 control;
351 352
};

353 354 355 356 357 358
struct cmd_ds_802_11_beacon_control {
	__le16 action;
	__le16 beacon_enable;
	__le16 beacon_period;
};

359
struct cmd_ds_802_11_sleep_params {
360 361
	struct cmd_header hdr;

362
	/* ACT_GET/ACT_SET */
363
	__le16 action;
364 365

	/* Sleep clock error in ppm */
366
	__le16 error;
367 368

	/* Wakeup offset in usec */
369
	__le16 offset;
370 371

	/* Clock stabilization time in usec */
372
	__le16 stabletime;
373 374

	/* control periodic calibration */
375
	uint8_t calcontrol;
376 377

	/* control the use of external sleep clock */
378
	uint8_t externalsleepclk;
379 380

	/* reserved field, should be set to zero */
381
	__le16 reserved;
382 383 384
};

struct cmd_ds_802_11_inactivity_timeout {
385 386
	struct cmd_header hdr;

387
	/* ACT_GET/ACT_SET */
388
	__le16 action;
389 390

	/* Inactivity timeout in msec */
391
	__le16 timeout;
392 393 394
};

struct cmd_ds_802_11_rf_channel {
395 396
	struct cmd_header hdr;

397
	__le16 action;
398 399 400 401
	__le16 channel;
	__le16 rftype;      /* unused */
	__le16 reserved;    /* unused */
	u8 channellist[32]; /* unused */
402 403 404 405
};

struct cmd_ds_802_11_rssi {
	/* weighting factor */
406
	__le16 N;
407

408 409 410
	__le16 reserved_0;
	__le16 reserved_1;
	__le16 reserved_2;
411 412 413
};

struct cmd_ds_802_11_rssi_rsp {
414 415 416 417
	__le16 SNR;
	__le16 noisefloor;
	__le16 avgSNR;
	__le16 avgnoisefloor;
418 419 420
};

struct cmd_ds_802_11_mac_address {
421
	__le16 action;
422 423 424 425
	u8 macadd[ETH_ALEN];
};

struct cmd_ds_802_11_rf_tx_power {
426 427
	__le16 action;
	__le16 currentlevel;
428 429 430
};

struct cmd_ds_802_11_rf_antenna {
431
	__le16 action;
432 433

	/* Number of antennas or 0xffff(diversity) */
434
	__le16 antennamode;
435 436 437

};

438
struct cmd_ds_802_11_monitor_mode {
H
Holger Schurig 已提交
439 440
	__le16 action;
	__le16 mode;
441 442
};

443
struct cmd_ds_set_boot2_ver {
444 445
	struct cmd_header hdr;

H
Holger Schurig 已提交
446 447
	__le16 action;
	__le16 version;
448 449
};

450 451 452 453 454 455 456 457 458 459 460 461 462 463
struct cmd_ds_802_11_fw_wake_method {
	struct cmd_header hdr;

	__le16 action;
	__le16 method;
};

struct cmd_ds_802_11_sleep_period {
	struct cmd_header hdr;

	__le16 action;
	__le16 period;
};

464
struct cmd_ds_802_11_ps_mode {
465 466 467 468 469
	__le16 action;
	__le16 nullpktinterval;
	__le16 multipledtim;
	__le16 reserved;
	__le16 locallisteninterval;
470 471 472
};

struct PS_CMD_ConfirmSleep {
473 474 475 476
	__le16 command;
	__le16 size;
	__le16 seqnum;
	__le16 result;
477

478 479 480 481 482
	__le16 action;
	__le16 reserved1;
	__le16 multipledtim;
	__le16 reserved;
	__le16 locallisteninterval;
483 484 485
};

struct cmd_ds_802_11_data_rate {
486 487
	struct cmd_header hdr;

488
	__le16 action;
489 490
	__le16 reserved;
	u8 rates[MAX_RATES];
491 492 493
};

struct cmd_ds_802_11_rate_adapt_rateset {
494 495 496
	__le16 action;
	__le16 enablehwauto;
	__le16 bitmap;
497 498 499
};

struct cmd_ds_802_11_ad_hoc_start {
500
	u8 ssid[IW_ESSID_MAX_SIZE];
501
	u8 bsstype;
502
	__le16 beaconperiod;
503 504 505
	u8 dtimperiod;
	union IEEEtypes_ssparamset ssparamset;
	union ieeetypes_phyparamset phyparamset;
506
	__le16 probedelay;
507
	__le16 capability;
508
	u8 rates[MAX_RATES];
509 510 511 512
	u8 tlv_memory_size_pad[100];
} __attribute__ ((packed));

struct adhoc_bssdesc {
513 514 515
	u8 bssid[6];
	u8 ssid[32];
	u8 type;
516
	__le16 beaconperiod;
517
	u8 dtimperiod;
518 519
	__le64 timestamp;
	__le64 localtime;
520 521
	union ieeetypes_phyparamset phyparamset;
	union IEEEtypes_ssparamset ssparamset;
522
	__le16 capability;
523
	u8 rates[MAX_RATES];
524 525 526 527 528 529 530 531

	/* DO NOT ADD ANY FIELDS TO THIS STRUCTURE. It is used below in the
	 * Adhoc join command and will cause a binary layout mismatch with
	 * the firmware
	 */
} __attribute__ ((packed));

struct cmd_ds_802_11_ad_hoc_join {
532
	struct adhoc_bssdesc bss;
533 534
	__le16 failtimeout;
	__le16 probedelay;
535 536 537 538

} __attribute__ ((packed));

struct cmd_ds_802_11_enable_rsn {
539 540
	struct cmd_header hdr;

541 542
	__le16 action;
	__le16 enable;
543
} __attribute__ ((packed));
544 545 546

struct MrvlIEtype_keyParamSet {
	/* type ID */
547
	__le16 type;
548 549

	/* length of Payload */
550
	__le16 length;
551 552

	/* type of key: WEP=0, TKIP=1, AES=2 */
553
	__le16 keytypeid;
554 555

	/* key control Info specific to a keytypeid */
556
	__le16 keyinfo;
557 558

	/* length of key */
559
	__le16 keylen;
560 561 562 563 564

	/* key material of size keylen */
	u8 key[32];
};

565 566 567 568 569 570 571
struct cmd_ds_host_sleep {
	struct cmd_header hdr;
	__le32 criteria;
	uint8_t gpio;
	uint8_t gap;
} __attribute__ ((packed));

572
struct cmd_ds_802_11_key_material {
573
	__le16 action;
574 575 576 577
	struct MrvlIEtype_keyParamSet keyParamSet[2];
} __attribute__ ((packed));

struct cmd_ds_802_11_eeprom_access {
578
	__le16 action;
579 580

	/* multiple 4 */
581 582
	__le16 offset;
	__le16 bytecount;
583 584 585 586
	u8 value;
} __attribute__ ((packed));

struct cmd_ds_802_11_tpc_cfg {
587
	__le16 action;
588 589 590 591 592 593 594 595
	u8 enable;
	s8 P0;
	s8 P1;
	s8 P2;
	u8 usesnr;
} __attribute__ ((packed));

struct cmd_ds_802_11_led_ctrl {
596 597
	__le16 action;
	__le16 numled;
598 599 600 601
	u8 data[256];
} __attribute__ ((packed));

struct cmd_ds_802_11_pwr_cfg {
602
	__le16 action;
603 604 605 606 607 608 609
	u8 enable;
	s8 PA_P0;
	s8 PA_P1;
	s8 PA_P2;
} __attribute__ ((packed));

struct cmd_ds_802_11_afc {
610
	__le16 afc_auto;
611 612
	union {
		struct {
613 614
			__le16 threshold;
			__le16 period;
615 616
		};
		struct {
617 618
			__le16 timing_offset; /* signed */
			__le16 carrier_offset; /* signed */
619 620 621 622 623
		};
	};
} __attribute__ ((packed));

struct cmd_tx_rate_query {
624
	__le16 txrate;
625 626 627 628 629 630 631
} __attribute__ ((packed));

struct cmd_ds_get_tsf {
	__le64 tsfvalue;
} __attribute__ ((packed));

struct cmd_ds_bt_access {
632 633
	__le16 action;
	__le32 id;
634 635 636 637 638
	u8 addr1[ETH_ALEN];
	u8 addr2[ETH_ALEN];
} __attribute__ ((packed));

struct cmd_ds_fwt_access {
639 640
	__le16 action;
	__le32 id;
641
	u8 valid;
642 643 644
	u8 da[ETH_ALEN];
	u8 dir;
	u8 ra[ETH_ALEN];
645 646 647
	__le32 ssn;
	__le32 dsn;
	__le32 metric;
648
	u8 rate;
649 650
	u8 hopcount;
	u8 ttl;
651
	__le32 expiration;
652
	u8 sleepmode;
653 654
	__le32 snr;
	__le32 references;
655
	u8 prec[ETH_ALEN];
656 657
} __attribute__ ((packed));

658 659 660 661 662 663 664 665 666 667 668 669

struct cmd_ds_mesh_config {
	struct cmd_header hdr;

        __le16 action;
        __le16 channel;
        __le16 type;
        __le16 length;
        u8 data[128];   /* last position reserved */
} __attribute__ ((packed));


670
struct cmd_ds_mesh_access {
671 672
	struct cmd_header hdr;

673 674
	__le16 action;
	__le32 data[32];	/* last position reserved */
675 676
} __attribute__ ((packed));

677 678 679
/* Number of stats counters returned by the firmware */
#define MESH_STATS_NUM 8

680 681
struct cmd_ds_command {
	/* command header */
682 683 684 685
	__le16 command;
	__le16 size;
	__le16 seqnum;
	__le16 result;
686 687 688 689 690 691 692 693 694 695 696 697 698 699 700 701 702 703 704

	/* command Body */
	union {
		struct cmd_ds_802_11_ps_mode psmode;
		struct cmd_ds_802_11_scan scan;
		struct cmd_ds_802_11_scan_rsp scanresp;
		struct cmd_ds_mac_control macctrl;
		struct cmd_ds_802_11_associate associate;
		struct cmd_ds_802_11_deauthenticate deauth;
		struct cmd_ds_802_11_ad_hoc_start ads;
		struct cmd_ds_802_11_reset reset;
		struct cmd_ds_802_11_ad_hoc_result result;
		struct cmd_ds_802_11_get_log glog;
		struct cmd_ds_802_11_authenticate auth;
		struct cmd_ds_802_11_get_stat gstat;
		struct cmd_ds_802_3_get_stat gstat_8023;
		struct cmd_ds_802_11_snmp_mib smib;
		struct cmd_ds_802_11_rf_tx_power txp;
		struct cmd_ds_802_11_rf_antenna rant;
705
		struct cmd_ds_802_11_monitor_mode monitor;
706 707 708 709 710 711 712 713 714 715 716 717 718 719 720 721 722 723 724 725 726 727 728 729 730 731
		struct cmd_ds_802_11_rate_adapt_rateset rateset;
		struct cmd_ds_mac_multicast_adr madr;
		struct cmd_ds_802_11_ad_hoc_join adj;
		struct cmd_ds_802_11_rssi rssi;
		struct cmd_ds_802_11_rssi_rsp rssirsp;
		struct cmd_ds_802_11_disassociate dassociate;
		struct cmd_ds_802_11_mac_address macadd;
		struct cmd_ds_802_11_key_material keymaterial;
		struct cmd_ds_mac_reg_access macreg;
		struct cmd_ds_bbp_reg_access bbpreg;
		struct cmd_ds_rf_reg_access rfreg;
		struct cmd_ds_802_11_eeprom_access rdeeprom;

		struct cmd_ds_802_11d_domain_info domaininfo;
		struct cmd_ds_802_11d_domain_info domaininforesp;

		struct cmd_ds_802_11_tpc_cfg tpccfg;
		struct cmd_ds_802_11_pwr_cfg pwrcfg;
		struct cmd_ds_802_11_afc afc;
		struct cmd_ds_802_11_led_ctrl ledgpio;

		struct cmd_tx_rate_query txrate;
		struct cmd_ds_bt_access bt;
		struct cmd_ds_fwt_access fwt;
		struct cmd_ds_get_tsf gettsf;
		struct cmd_ds_802_11_subscribe_event subscribe_event;
732
		struct cmd_ds_802_11_beacon_control bcn_ctrl;
733 734 735 736
	} params;
} __attribute__ ((packed));

#endif