* [PATCH] libertas: cleanup host.h and hostcmd.h
@ 2009-10-16 15:32 Holger Schurig
2009-10-16 16:28 ` Dan Williams
0 siblings, 1 reply; 2+ messages in thread
From: Holger Schurig @ 2009-10-16 15:32 UTC (permalink / raw)
To: linux-wireless, John Linville, Dan Williams
Also remove some unused definitions and make tab usage consistent.
Signed-off-by: Holger Schurig <hs4233@mail.mn-solutions.de>
---
No functional changes!
--- linux-wl.orig/drivers/net/wireless/libertas/host.h
+++ linux-wl/drivers/net/wireless/libertas/host.h
@@ -1,202 +1,189 @@
/**
- * This file contains definitions of WLAN commands.
+ * This file function prototypes, data structure
+ * and definitions for all the host/station commands
*/
#ifndef _LBS_HOST_H_
#define _LBS_HOST_H_
-/** PUBLIC DEFINITIONS */
-#define DEFAULT_AD_HOC_CHANNEL 6
-#define DEFAULT_AD_HOC_CHANNEL_A 36
+#include "11d.h"
-#define CMD_OPTION_WAITFORRSP 0x0002
+#define DEFAULT_AD_HOC_CHANNEL 6
+
+#define CMD_OPTION_WAITFORRSP 0x0002
/** Host command IDs */
/* Return command are almost always the same as the host command, but with
* bit 15 set high. There are a few exceptions, though...
*/
-#define CMD_RET(cmd) (0x8000 | cmd)
+#define CMD_RET(cmd) (0x8000 | cmd)
/* Return command convention exceptions: */
-#define CMD_RET_802_11_ASSOCIATE 0x8012
+#define CMD_RET_802_11_ASSOCIATE 0x8012
/* Command codes */
-#define CMD_GET_HW_SPEC 0x0003
-#define CMD_EEPROM_UPDATE 0x0004
-#define CMD_802_11_RESET 0x0005
-#define CMD_802_11_SCAN 0x0006
-#define CMD_802_11_GET_LOG 0x000b
-#define CMD_MAC_MULTICAST_ADR 0x0010
-#define CMD_802_11_AUTHENTICATE 0x0011
-#define CMD_802_11_EEPROM_ACCESS 0x0059
-#define CMD_802_11_ASSOCIATE 0x0050
-#define CMD_802_11_SET_WEP 0x0013
-#define CMD_802_11_GET_STAT 0x0014
-#define CMD_802_3_GET_STAT 0x0015
-#define CMD_802_11_SNMP_MIB 0x0016
-#define CMD_MAC_REG_MAP 0x0017
-#define CMD_BBP_REG_MAP 0x0018
-#define CMD_MAC_REG_ACCESS 0x0019
-#define CMD_BBP_REG_ACCESS 0x001a
-#define CMD_RF_REG_ACCESS 0x001b
-#define CMD_802_11_RADIO_CONTROL 0x001c
-#define CMD_802_11_RF_CHANNEL 0x001d
-#define CMD_802_11_RF_TX_POWER 0x001e
-#define CMD_802_11_RSSI 0x001f
-#define CMD_802_11_RF_ANTENNA 0x0020
-#define CMD_802_11_PS_MODE 0x0021
-#define CMD_802_11_DATA_RATE 0x0022
-#define CMD_RF_REG_MAP 0x0023
-#define CMD_802_11_DEAUTHENTICATE 0x0024
-#define CMD_802_11_REASSOCIATE 0x0025
-#define CMD_MAC_CONTROL 0x0028
-#define CMD_802_11_AD_HOC_START 0x002b
-#define CMD_802_11_AD_HOC_JOIN 0x002c
-#define CMD_802_11_QUERY_TKIP_REPLY_CNTRS 0x002e
-#define CMD_802_11_ENABLE_RSN 0x002f
-#define CMD_802_11_SET_AFC 0x003c
-#define CMD_802_11_GET_AFC 0x003d
-#define CMD_802_11_DEEP_SLEEP 0x003e
-#define CMD_802_11_AD_HOC_STOP 0x0040
-#define CMD_802_11_HOST_SLEEP_CFG 0x0043
-#define CMD_802_11_WAKEUP_CONFIRM 0x0044
-#define CMD_802_11_HOST_SLEEP_ACTIVATE 0x0045
-#define CMD_802_11_BEACON_STOP 0x0049
-#define CMD_802_11_MAC_ADDRESS 0x004d
-#define CMD_802_11_LED_GPIO_CTRL 0x004e
-#define CMD_802_11_EEPROM_ACCESS 0x0059
-#define CMD_802_11_BAND_CONFIG 0x0058
-#define CMD_GSPI_BUS_CONFIG 0x005a
-#define CMD_802_11D_DOMAIN_INFO 0x005b
-#define CMD_802_11_KEY_MATERIAL 0x005e
-#define CMD_802_11_SLEEP_PARAMS 0x0066
-#define CMD_802_11_INACTIVITY_TIMEOUT 0x0067
-#define CMD_802_11_SLEEP_PERIOD 0x0068
-#define CMD_802_11_TPC_CFG 0x0072
-#define CMD_802_11_PA_CFG 0x0073
-#define CMD_802_11_FW_WAKE_METHOD 0x0074
-#define CMD_802_11_SUBSCRIBE_EVENT 0x0075
-#define CMD_802_11_RATE_ADAPT_RATESET 0x0076
-#define CMD_802_11_TX_RATE_QUERY 0x007f
-#define CMD_GET_TSF 0x0080
-#define CMD_BT_ACCESS 0x0087
-#define CMD_FWT_ACCESS 0x0095
-#define CMD_802_11_MONITOR_MODE 0x0098
-#define CMD_MESH_ACCESS 0x009b
-#define CMD_MESH_CONFIG_OLD 0x00a3
-#define CMD_MESH_CONFIG 0x00ac
-#define CMD_SET_BOOT2_VER 0x00a5
-#define CMD_FUNC_INIT 0x00a9
-#define CMD_FUNC_SHUTDOWN 0x00aa
-#define CMD_802_11_BEACON_CTRL 0x00b0
+#define CMD_GET_HW_SPEC 0x0003
+#define CMD_EEPROM_UPDATE 0x0004
+#define CMD_802_11_RESET 0x0005
+#define CMD_802_11_SCAN 0x0006
+#define CMD_802_11_GET_LOG 0x000b
+#define CMD_MAC_MULTICAST_ADR 0x0010
+#define CMD_802_11_AUTHENTICATE 0x0011
+#define CMD_802_11_EEPROM_ACCESS 0x0059
+#define CMD_802_11_ASSOCIATE 0x0050
+#define CMD_802_11_SET_WEP 0x0013
+#define CMD_802_11_GET_STAT 0x0014
+#define CMD_802_3_GET_STAT 0x0015
+#define CMD_802_11_SNMP_MIB 0x0016
+#define CMD_MAC_REG_MAP 0x0017
+#define CMD_BBP_REG_MAP 0x0018
+#define CMD_MAC_REG_ACCESS 0x0019
+#define CMD_BBP_REG_ACCESS 0x001a
+#define CMD_RF_REG_ACCESS 0x001b
+#define CMD_802_11_RADIO_CONTROL 0x001c
+#define CMD_802_11_RF_CHANNEL 0x001d
+#define CMD_802_11_RF_TX_POWER 0x001e
+#define CMD_802_11_RSSI 0x001f
+#define CMD_802_11_RF_ANTENNA 0x0020
+#define CMD_802_11_PS_MODE 0x0021
+#define CMD_802_11_DATA_RATE 0x0022
+#define CMD_RF_REG_MAP 0x0023
+#define CMD_802_11_DEAUTHENTICATE 0x0024
+#define CMD_802_11_REASSOCIATE 0x0025
+#define CMD_MAC_CONTROL 0x0028
+#define CMD_802_11_AD_HOC_START 0x002b
+#define CMD_802_11_AD_HOC_JOIN 0x002c
+#define CMD_802_11_QUERY_TKIP_REPLY_CNTRS 0x002e
+#define CMD_802_11_ENABLE_RSN 0x002f
+#define CMD_802_11_SET_AFC 0x003c
+#define CMD_802_11_GET_AFC 0x003d
+#define CMD_802_11_DEEP_SLEEP 0x003e
+#define CMD_802_11_AD_HOC_STOP 0x0040
+#define CMD_802_11_HOST_SLEEP_CFG 0x0043
+#define CMD_802_11_WAKEUP_CONFIRM 0x0044
+#define CMD_802_11_HOST_SLEEP_ACTIVATE 0x0045
+#define CMD_802_11_BEACON_STOP 0x0049
+#define CMD_802_11_MAC_ADDRESS 0x004d
+#define CMD_802_11_LED_GPIO_CTRL 0x004e
+#define CMD_802_11_EEPROM_ACCESS 0x0059
+#define CMD_802_11_BAND_CONFIG 0x0058
+#define CMD_GSPI_BUS_CONFIG 0x005a
+#define CMD_802_11D_DOMAIN_INFO 0x005b
+#define CMD_802_11_KEY_MATERIAL 0x005e
+#define CMD_802_11_SLEEP_PARAMS 0x0066
+#define CMD_802_11_INACTIVITY_TIMEOUT 0x0067
+#define CMD_802_11_SLEEP_PERIOD 0x0068
+#define CMD_802_11_TPC_CFG 0x0072
+#define CMD_802_11_PA_CFG 0x0073
+#define CMD_802_11_FW_WAKE_METHOD 0x0074
+#define CMD_802_11_SUBSCRIBE_EVENT 0x0075
+#define CMD_802_11_RATE_ADAPT_RATESET 0x0076
+#define CMD_802_11_TX_RATE_QUERY 0x007f
+#define CMD_GET_TSF 0x0080
+#define CMD_BT_ACCESS 0x0087
+#define CMD_FWT_ACCESS 0x0095
+#define CMD_802_11_MONITOR_MODE 0x0098
+#define CMD_MESH_ACCESS 0x009b
+#define CMD_MESH_CONFIG_OLD 0x00a3
+#define CMD_MESH_CONFIG 0x00ac
+#define CMD_SET_BOOT2_VER 0x00a5
+#define CMD_FUNC_INIT 0x00a9
+#define CMD_FUNC_SHUTDOWN 0x00aa
+#define CMD_802_11_BEACON_CTRL 0x00b0
/* For the IEEE Power Save */
-#define CMD_SUBCMD_ENTER_PS 0x0030
-#define CMD_SUBCMD_EXIT_PS 0x0031
-#define CMD_SUBCMD_SLEEP_CONFIRMED 0x0034
-#define CMD_SUBCMD_FULL_POWERDOWN 0x0035
-#define CMD_SUBCMD_FULL_POWERUP 0x0036
-
-#define CMD_ENABLE_RSN 0x0001
-#define CMD_DISABLE_RSN 0x0000
-
-#define CMD_ACT_GET 0x0000
-#define CMD_ACT_SET 0x0001
-#define CMD_ACT_GET_AES 0x0002
-#define CMD_ACT_SET_AES 0x0003
-#define CMD_ACT_REMOVE_AES 0x0004
+#define CMD_SUBCMD_ENTER_PS 0x0030
+#define CMD_SUBCMD_EXIT_PS 0x0031
+#define CMD_SUBCMD_SLEEP_CONFIRMED 0x0034
+#define CMD_SUBCMD_FULL_POWERDOWN 0x0035
+#define CMD_SUBCMD_FULL_POWERUP 0x0036
-/* Define action or option for CMD_802_11_SET_WEP */
-#define CMD_ACT_ADD 0x0002
-#define CMD_ACT_REMOVE 0x0004
-#define CMD_ACT_USE_DEFAULT 0x0008
+#define CMD_ENABLE_RSN 0x0001
+#define CMD_DISABLE_RSN 0x0000
-#define CMD_TYPE_WEP_40_BIT 0x01
-#define CMD_TYPE_WEP_104_BIT 0x02
+#define CMD_ACT_GET 0x0000
+#define CMD_ACT_SET 0x0001
-#define CMD_NUM_OF_WEP_KEYS 4
+/* Define action or option for CMD_802_11_SET_WEP */
+#define CMD_ACT_ADD 0x0002
+#define CMD_ACT_REMOVE 0x0004
-#define CMD_WEP_KEY_INDEX_MASK 0x3fff
+#define CMD_TYPE_WEP_40_BIT 0x01
+#define CMD_TYPE_WEP_104_BIT 0x02
-/* Define action or option for CMD_802_11_RESET */
-#define CMD_ACT_HALT 0x0003
+#define CMD_NUM_OF_WEP_KEYS 4
+
+#define CMD_WEP_KEY_INDEX_MASK 0x3fff
/* Define action or option for CMD_802_11_SCAN */
-#define CMD_BSS_TYPE_BSS 0x0001
-#define CMD_BSS_TYPE_IBSS 0x0002
-#define CMD_BSS_TYPE_ANY 0x0003
+#define CMD_BSS_TYPE_BSS 0x0001
+#define CMD_BSS_TYPE_IBSS 0x0002
+#define CMD_BSS_TYPE_ANY 0x0003
/* Define action or option for CMD_802_11_SCAN */
-#define CMD_SCAN_TYPE_ACTIVE 0x0000
-#define CMD_SCAN_TYPE_PASSIVE 0x0001
+#define CMD_SCAN_TYPE_ACTIVE 0x0000
+#define CMD_SCAN_TYPE_PASSIVE 0x0001
-#define CMD_SCAN_RADIO_TYPE_BG 0
+#define CMD_SCAN_RADIO_TYPE_BG 0
-#define CMD_SCAN_PROBE_DELAY_TIME 0
+#define CMD_SCAN_PROBE_DELAY_TIME 0
/* Define action or option for CMD_MAC_CONTROL */
-#define CMD_ACT_MAC_RX_ON 0x0001
-#define CMD_ACT_MAC_TX_ON 0x0002
-#define CMD_ACT_MAC_LOOPBACK_ON 0x0004
-#define CMD_ACT_MAC_WEP_ENABLE 0x0008
-#define CMD_ACT_MAC_INT_ENABLE 0x0010
-#define CMD_ACT_MAC_MULTICAST_ENABLE 0x0020
-#define CMD_ACT_MAC_BROADCAST_ENABLE 0x0040
-#define CMD_ACT_MAC_PROMISCUOUS_ENABLE 0x0080
-#define CMD_ACT_MAC_ALL_MULTICAST_ENABLE 0x0100
-#define CMD_ACT_MAC_STRICT_PROTECTION_ENABLE 0x0400
+#define CMD_ACT_MAC_RX_ON 0x0001
+#define CMD_ACT_MAC_TX_ON 0x0002
+#define CMD_ACT_MAC_LOOPBACK_ON 0x0004
+#define CMD_ACT_MAC_WEP_ENABLE 0x0008
+#define CMD_ACT_MAC_INT_ENABLE 0x0010
+#define CMD_ACT_MAC_MULTICAST_ENABLE 0x0020
+#define CMD_ACT_MAC_BROADCAST_ENABLE 0x0040
+#define CMD_ACT_MAC_PROMISCUOUS_ENABLE 0x0080
+#define CMD_ACT_MAC_ALL_MULTICAST_ENABLE 0x0100
+#define CMD_ACT_MAC_STRICT_PROTECTION_ENABLE 0x0400
/* Event flags for CMD_802_11_SUBSCRIBE_EVENT */
-#define CMD_SUBSCRIBE_RSSI_LOW 0x0001
-#define CMD_SUBSCRIBE_SNR_LOW 0x0002
-#define CMD_SUBSCRIBE_FAILCOUNT 0x0004
-#define CMD_SUBSCRIBE_BCNMISS 0x0008
-#define CMD_SUBSCRIBE_RSSI_HIGH 0x0010
-#define CMD_SUBSCRIBE_SNR_HIGH 0x0020
-
-#define RADIO_PREAMBLE_LONG 0x00
-#define RADIO_PREAMBLE_SHORT 0x02
-#define RADIO_PREAMBLE_AUTO 0x04
+#define CMD_SUBSCRIBE_RSSI_LOW 0x0001
+#define CMD_SUBSCRIBE_SNR_LOW 0x0002
+#define CMD_SUBSCRIBE_FAILCOUNT 0x0004
+#define CMD_SUBSCRIBE_BCNMISS 0x0008
+#define CMD_SUBSCRIBE_RSSI_HIGH 0x0010
+#define CMD_SUBSCRIBE_SNR_HIGH 0x0020
+
+#define RADIO_PREAMBLE_LONG 0x00
+#define RADIO_PREAMBLE_SHORT 0x02
+#define RADIO_PREAMBLE_AUTO 0x04
/* Define action or option for CMD_802_11_RF_CHANNEL */
-#define CMD_OPT_802_11_RF_CHANNEL_GET 0x00
-#define CMD_OPT_802_11_RF_CHANNEL_SET 0x01
+#define CMD_OPT_802_11_RF_CHANNEL_GET 0x00
+#define CMD_OPT_802_11_RF_CHANNEL_SET 0x01
/* Define action or option for CMD_802_11_DATA_RATE */
-#define CMD_ACT_SET_TX_AUTO 0x0000
-#define CMD_ACT_SET_TX_FIX_RATE 0x0001
-#define CMD_ACT_GET_TX_RATE 0x0002
-
-#define CMD_ACT_SET_RX 0x0001
-#define CMD_ACT_SET_TX 0x0002
-#define CMD_ACT_SET_BOTH 0x0003
-#define CMD_ACT_GET_RX 0x0004
-#define CMD_ACT_GET_TX 0x0008
-#define CMD_ACT_GET_BOTH 0x000c
+#define CMD_ACT_SET_TX_AUTO 0x0000
+#define CMD_ACT_SET_TX_FIX_RATE 0x0001
+#define CMD_ACT_GET_TX_RATE 0x0002
/* Define action or option for CMD_802_11_PS_MODE */
-#define CMD_TYPE_CAM 0x0000
-#define CMD_TYPE_MAX_PSP 0x0001
-#define CMD_TYPE_FAST_PSP 0x0002
+#define CMD_TYPE_CAM 0x0000
+#define CMD_TYPE_MAX_PSP 0x0001
+#define CMD_TYPE_FAST_PSP 0x0002
/* Options for CMD_802_11_FW_WAKE_METHOD */
-#define CMD_WAKE_METHOD_UNCHANGED 0x0000
-#define CMD_WAKE_METHOD_COMMAND_INT 0x0001
-#define CMD_WAKE_METHOD_GPIO 0x0002
+#define CMD_WAKE_METHOD_UNCHANGED 0x0000
+#define CMD_WAKE_METHOD_COMMAND_INT 0x0001
+#define CMD_WAKE_METHOD_GPIO 0x0002
/* Object IDs for CMD_802_11_SNMP_MIB */
-#define SNMP_MIB_OID_BSS_TYPE 0x0000
-#define SNMP_MIB_OID_OP_RATE_SET 0x0001
-#define SNMP_MIB_OID_BEACON_PERIOD 0x0002 /* Reserved on v9+ */
-#define SNMP_MIB_OID_DTIM_PERIOD 0x0003 /* Reserved on v9+ */
-#define SNMP_MIB_OID_ASSOC_TIMEOUT 0x0004 /* Reserved on v9+ */
-#define SNMP_MIB_OID_RTS_THRESHOLD 0x0005
-#define SNMP_MIB_OID_SHORT_RETRY_LIMIT 0x0006
-#define SNMP_MIB_OID_LONG_RETRY_LIMIT 0x0007
-#define SNMP_MIB_OID_FRAG_THRESHOLD 0x0008
-#define SNMP_MIB_OID_11D_ENABLE 0x0009
-#define SNMP_MIB_OID_11H_ENABLE 0x000A
+#define SNMP_MIB_OID_BSS_TYPE 0x0000
+#define SNMP_MIB_OID_OP_RATE_SET 0x0001
+#define SNMP_MIB_OID_BEACON_PERIOD 0x0002 /* Reserved on v9+ */
+#define SNMP_MIB_OID_DTIM_PERIOD 0x0003 /* Reserved on v9+ */
+#define SNMP_MIB_OID_ASSOC_TIMEOUT 0x0004 /* Reserved on v9+ */
+#define SNMP_MIB_OID_RTS_THRESHOLD 0x0005
+#define SNMP_MIB_OID_SHORT_RETRY_LIMIT 0x0006
+#define SNMP_MIB_OID_LONG_RETRY_LIMIT 0x0007
+#define SNMP_MIB_OID_FRAG_THRESHOLD 0x0008
+#define SNMP_MIB_OID_11D_ENABLE 0x0009
+#define SNMP_MIB_OID_11H_ENABLE 0x000A
/* Define action or option for CMD_BT_ACCESS */
enum cmd_bt_access_opts {
@@ -303,4 +290,714 @@
#define MACREG_INT_CODE_MESH_AUTO_STARTED 35
#define MACREG_INT_CODE_FIRMWARE_READY 48
+
+/* 802.11-related definitions */
+
+/* TxPD descriptor */
+struct txpd {
+ /* union to cope up with later FW revisions */
+ union {
+ /* Current Tx packet status */
+ __le32 tx_status;
+ struct {
+ /* BSS type: client, AP, etc. */
+ u8 bss_type;
+ /* BSS number */
+ u8 bss_num;
+ /* Reserved */
+ __le16 reserved;
+ } bss;
+ } u;
+ /* Tx control */
+ __le32 tx_control;
+ __le32 tx_packet_location;
+ /* Tx packet length */
+ __le16 tx_packet_length;
+ /* 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 (units = 2ms) */
+ u8 pktdelay_2ms;
+ /* reserved */
+ u8 reserved1;
+} __attribute__ ((packed));
+
+/* RxPD Descriptor */
+struct rxpd {
+ /* union to cope up with later FW revisions */
+ union {
+ /* Current Rx packet status */
+ __le16 status;
+ struct {
+ /* BSS type: client, AP, etc. */
+ u8 bss_type;
+ /* BSS number */
+ u8 bss_num;
+ } __attribute__ ((packed)) bss;
+ } __attribute__ ((packed)) u;
+
+ /* SNR */
+ u8 snr;
+
+ /* Tx control */
+ u8 rx_control;
+
+ /* Pkt length */
+ __le16 pkt_len;
+
+ /* Noise Floor */
+ u8 nf;
+
+ /* Rx Packet Rate */
+ u8 rx_rate;
+
+ /* Pkt addr */
+ __le32 pkt_ptr;
+
+ /* Next Rx RxPD addr */
+ __le32 next_rxpd_ptr;
+
+ /* Pkt Priority */
+ u8 priority;
+ u8 reserved[3];
+} __attribute__ ((packed));
+
+struct cmd_header {
+ __le16 command;
+ __le16 size;
+ __le16 seqnum;
+ __le16 result;
+} __attribute__ ((packed));
+
+struct cmd_ctrl_node {
+ struct list_head list;
+ int result;
+ /* command response */
+ int (*callback)(struct lbs_private *,
+ unsigned long,
+ struct cmd_header *);
+ unsigned long callback_arg;
+ /* command data */
+ struct cmd_header *cmdbuf;
+ /* wait queue */
+ u16 cmdwaitqwoken;
+ wait_queue_head_t cmdwait_q;
+};
+
+/* Generic structure to hold all key types. */
+struct enc_key {
+ u16 len;
+ u16 flags; /* KEY_INFO_* from defs.h */
+ u16 type; /* KEY_TYPE_* from defs.h */
+ u8 key[32];
+};
+
+/* lbs_offset_value */
+struct lbs_offset_value {
+ u32 offset;
+ u32 value;
+} __attribute__ ((packed));
+
+/* Define general data structure */
+/* cmd_DS_GEN */
+struct cmd_ds_gen {
+ __le16 command;
+ __le16 size;
+ __le16 seqnum;
+ __le16 result;
+ void *cmdresp[0];
+} __attribute__ ((packed));
+
+#define S_DS_GEN sizeof(struct cmd_ds_gen)
+
+
+/*
+ * Define data structure for CMD_GET_HW_SPEC
+ * This structure defines the response for the GET_HW_SPEC command
+ */
+struct cmd_ds_get_hw_spec {
+ struct cmd_header hdr;
+
+ /* HW Interface version number */
+ __le16 hwifversion;
+ /* HW version number */
+ __le16 version;
+ /* Max number of TxPD FW can handle */
+ __le16 nr_txpd;
+ /* Max no of Multicast address */
+ __le16 nr_mcast_adr;
+ /* MAC address */
+ u8 permanentaddr[6];
+
+ /* region Code */
+ __le16 regioncode;
+
+ /* Number of antenna used */
+ __le16 nr_antenna;
+
+ /* FW release number, example 0x01030304 = 2.3.4p1 */
+ __le32 fwrelease;
+
+ /* Base Address of TxPD queue */
+ __le32 wcb_base;
+ /* Read Pointer of RxPd queue */
+ __le32 rxpd_rdptr;
+
+ /* Write Pointer of RxPd queue */
+ __le32 rxpd_wrptr;
+
+ /*FW/HW capability */
+ __le32 fwcapinfo;
+} __attribute__ ((packed));
+
+struct cmd_ds_802_11_subscribe_event {
+ struct cmd_header hdr;
+
+ __le16 action;
+ __le16 events;
+
+ /* 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.
+ */
+ uint8_t tlv[128];
+} __attribute__ ((packed));
+
+/*
+ * This scan handle Country Information IE(802.11d compliant)
+ * Define data structure for CMD_802_11_SCAN
+ */
+struct cmd_ds_802_11_scan {
+ struct cmd_header hdr;
+
+ uint8_t bsstype;
+ uint8_t bssid[ETH_ALEN];
+ uint8_t tlvbuffer[0];
+} __attribute__ ((packed));
+
+struct cmd_ds_802_11_scan_rsp {
+ struct cmd_header hdr;
+
+ __le16 bssdescriptsize;
+ uint8_t nr_sets;
+ uint8_t bssdesc_and_tlvbuffer[0];
+} __attribute__ ((packed));
+
+struct cmd_ds_802_11_get_log {
+ struct cmd_header hdr;
+
+ __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;
+} __attribute__ ((packed));
+
+struct cmd_ds_mac_control {
+ struct cmd_header hdr;
+ __le16 action;
+ u16 reserved;
+} __attribute__ ((packed));
+
+struct cmd_ds_mac_multicast_adr {
+ struct cmd_header hdr;
+ __le16 action;
+ __le16 nr_of_adrs;
+ u8 maclist[ETH_ALEN * MRVDRV_MAX_MULTICAST_LIST_SIZE];
+} __attribute__ ((packed));
+
+struct cmd_ds_802_11_authenticate {
+ struct cmd_header hdr;
+
+ u8 bssid[ETH_ALEN];
+ u8 authtype;
+ u8 reserved[10];
+} __attribute__ ((packed));
+
+struct cmd_ds_802_11_deauthenticate {
+ struct cmd_header hdr;
+
+ u8 macaddr[ETH_ALEN];
+ __le16 reasoncode;
+} __attribute__ ((packed));
+
+struct cmd_ds_802_11_associate {
+ struct cmd_header hdr;
+
+ u8 bssid[6];
+ __le16 capability;
+ __le16 listeninterval;
+ __le16 bcnperiod;
+ u8 dtimperiod;
+ u8 iebuf[512]; /* Enough for required and most optional IEs */
+} __attribute__ ((packed));
+
+struct cmd_ds_802_11_associate_response {
+ struct cmd_header hdr;
+
+ __le16 capability;
+ __le16 statuscode;
+ __le16 aid;
+ u8 iebuf[512];
+} __attribute__ ((packed));
+
+struct cmd_ds_802_11_set_wep {
+ struct cmd_header hdr;
+
+ /* ACT_ADD, ACT_REMOVE or ACT_ENABLE */
+ __le16 action;
+
+ /* key Index selected for Tx */
+ __le16 keyindex;
+
+ /* 40, 128bit or TXWEP */
+ uint8_t keytype[4];
+ uint8_t keymaterial[4][16];
+} __attribute__ ((packed));
+
+struct cmd_ds_802_11_snmp_mib {
+ struct cmd_header hdr;
+
+ __le16 action;
+ __le16 oid;
+ __le16 bufsize;
+ u8 value[128];
+} __attribute__ ((packed));
+
+struct cmd_ds_mac_reg_access {
+ __le16 action;
+ __le16 offset;
+ __le32 value;
+} __attribute__ ((packed));
+
+struct cmd_ds_bbp_reg_access {
+ __le16 action;
+ __le16 offset;
+ u8 value;
+ u8 reserved[3];
+} __attribute__ ((packed));
+
+struct cmd_ds_rf_reg_access {
+ __le16 action;
+ __le16 offset;
+ u8 value;
+ u8 reserved[3];
+} __attribute__ ((packed));
+
+struct cmd_ds_802_11_radio_control {
+ struct cmd_header hdr;
+
+ __le16 action;
+ __le16 control;
+} __attribute__ ((packed));
+
+struct cmd_ds_802_11_beacon_control {
+ __le16 action;
+ __le16 beacon_enable;
+ __le16 beacon_period;
+} __attribute__ ((packed));
+
+struct cmd_ds_802_11_sleep_params {
+ struct cmd_header hdr;
+
+ /* ACT_GET/ACT_SET */
+ __le16 action;
+
+ /* Sleep clock error in ppm */
+ __le16 error;
+
+ /* Wakeup offset in usec */
+ __le16 offset;
+
+ /* Clock stabilization time in usec */
+ __le16 stabletime;
+
+ /* control periodic calibration */
+ uint8_t calcontrol;
+
+ /* control the use of external sleep clock */
+ uint8_t externalsleepclk;
+
+ /* reserved field, should be set to zero */
+ __le16 reserved;
+} __attribute__ ((packed));
+
+struct cmd_ds_802_11_inactivity_timeout {
+ struct cmd_header hdr;
+
+ /* ACT_GET/ACT_SET */
+ __le16 action;
+
+ /* Inactivity timeout in msec */
+ __le16 timeout;
+} __attribute__ ((packed));
+
+struct cmd_ds_802_11_rf_channel {
+ struct cmd_header hdr;
+
+ __le16 action;
+ __le16 channel;
+ __le16 rftype; /* unused */
+ __le16 reserved; /* unused */
+ u8 channellist[32]; /* unused */
+} __attribute__ ((packed));
+
+struct cmd_ds_802_11_rssi {
+ /* weighting factor */
+ __le16 N;
+
+ __le16 reserved_0;
+ __le16 reserved_1;
+ __le16 reserved_2;
+} __attribute__ ((packed));
+
+struct cmd_ds_802_11_rssi_rsp {
+ __le16 SNR;
+ __le16 noisefloor;
+ __le16 avgSNR;
+ __le16 avgnoisefloor;
+} __attribute__ ((packed));
+
+struct cmd_ds_802_11_mac_address {
+ struct cmd_header hdr;
+
+ __le16 action;
+ u8 macadd[ETH_ALEN];
+} __attribute__ ((packed));
+
+struct cmd_ds_802_11_rf_tx_power {
+ struct cmd_header hdr;
+
+ __le16 action;
+ __le16 curlevel;
+ s8 maxlevel;
+ s8 minlevel;
+} __attribute__ ((packed));
+
+struct cmd_ds_802_11_monitor_mode {
+ __le16 action;
+ __le16 mode;
+} __attribute__ ((packed));
+
+struct cmd_ds_set_boot2_ver {
+ struct cmd_header hdr;
+
+ __le16 action;
+ __le16 version;
+} __attribute__ ((packed));
+
+struct cmd_ds_802_11_fw_wake_method {
+ struct cmd_header hdr;
+
+ __le16 action;
+ __le16 method;
+} __attribute__ ((packed));
+
+struct cmd_ds_802_11_ps_mode {
+ __le16 action;
+ __le16 nullpktinterval;
+ __le16 multipledtim;
+ __le16 reserved;
+ __le16 locallisteninterval;
+} __attribute__ ((packed));
+
+struct cmd_confirm_sleep {
+ struct cmd_header hdr;
+
+ __le16 action;
+ __le16 nullpktinterval;
+ __le16 multipledtim;
+ __le16 reserved;
+ __le16 locallisteninterval;
+} __attribute__ ((packed));
+
+struct cmd_ds_802_11_data_rate {
+ struct cmd_header hdr;
+
+ __le16 action;
+ __le16 reserved;
+ u8 rates[MAX_RATES];
+} __attribute__ ((packed));
+
+struct cmd_ds_802_11_rate_adapt_rateset {
+ struct cmd_header hdr;
+ __le16 action;
+ __le16 enablehwauto;
+ __le16 bitmap;
+} __attribute__ ((packed));
+
+struct cmd_ds_802_11_ad_hoc_start {
+ struct cmd_header hdr;
+
+ u8 ssid[IW_ESSID_MAX_SIZE];
+ u8 bsstype;
+ __le16 beaconperiod;
+ u8 dtimperiod; /* Reserved on v9 and later */
+ struct ieee_ie_ibss_param_set ibss;
+ u8 reserved1[4];
+ struct ieee_ie_ds_param_set ds;
+ u8 reserved2[4];
+ __le16 probedelay; /* Reserved on v9 and later */
+ __le16 capability;
+ u8 rates[MAX_RATES];
+ u8 tlv_memory_size_pad[100];
+} __attribute__ ((packed));
+
+struct cmd_ds_802_11_ad_hoc_result {
+ struct cmd_header hdr;
+
+ u8 pad[3];
+ u8 bssid[ETH_ALEN];
+} __attribute__ ((packed));
+
+struct adhoc_bssdesc {
+ u8 bssid[ETH_ALEN];
+ u8 ssid[IW_ESSID_MAX_SIZE];
+ u8 type;
+ __le16 beaconperiod;
+ u8 dtimperiod;
+ __le64 timestamp;
+ __le64 localtime;
+ struct ieee_ie_ds_param_set ds;
+ u8 reserved1[4];
+ struct ieee_ie_ibss_param_set ibss;
+ u8 reserved2[4];
+ __le16 capability;
+ u8 rates[MAX_RATES];
+
+ /* 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 {
+ struct cmd_header hdr;
+
+ struct adhoc_bssdesc bss;
+ __le16 failtimeout; /* Reserved on v9 and later */
+ __le16 probedelay; /* Reserved on v9 and later */
+} __attribute__ ((packed));
+
+struct cmd_ds_802_11_ad_hoc_stop {
+ struct cmd_header hdr;
+} __attribute__ ((packed));
+
+struct cmd_ds_802_11_enable_rsn {
+ struct cmd_header hdr;
+
+ __le16 action;
+ __le16 enable;
+} __attribute__ ((packed));
+
+struct MrvlIEtype_keyParamSet {
+ /* type ID */
+ __le16 type;
+
+ /* length of Payload */
+ __le16 length;
+
+ /* type of key: WEP=0, TKIP=1, AES=2 */
+ __le16 keytypeid;
+
+ /* key control Info specific to a keytypeid */
+ __le16 keyinfo;
+
+ /* length of key */
+ __le16 keylen;
+
+ /* key material of size keylen */
+ u8 key[32];
+} __attribute__ ((packed));
+
+#define MAX_WOL_RULES 16
+
+struct host_wol_rule {
+ uint8_t rule_no;
+ uint8_t rule_ops;
+ __le16 sig_offset;
+ __le16 sig_length;
+ __le16 reserve;
+ __be32 sig_mask;
+ __be32 signature;
+} __attribute__ ((packed));
+
+struct wol_config {
+ uint8_t action;
+ uint8_t pattern;
+ uint8_t no_rules_in_cmd;
+ uint8_t result;
+ struct host_wol_rule rule[MAX_WOL_RULES];
+} __attribute__ ((packed));
+
+struct cmd_ds_host_sleep {
+ struct cmd_header hdr;
+ __le32 criteria;
+ uint8_t gpio;
+ uint16_t gap;
+ struct wol_config wol_conf;
+} __attribute__ ((packed));
+
+
+
+struct cmd_ds_802_11_key_material {
+ struct cmd_header hdr;
+
+ __le16 action;
+ struct MrvlIEtype_keyParamSet keyParamSet[2];
+} __attribute__ ((packed));
+
+struct cmd_ds_802_11_eeprom_access {
+ struct cmd_header hdr;
+ __le16 action;
+ __le16 offset;
+ __le16 len;
+ /* firmware says it returns a maximum of 20 bytes */
+#define LBS_EEPROM_READ_LEN 20
+ u8 value[LBS_EEPROM_READ_LEN];
+} __attribute__ ((packed));
+
+struct cmd_ds_802_11_tpc_cfg {
+ struct cmd_header hdr;
+
+ __le16 action;
+ uint8_t enable;
+ int8_t P0;
+ int8_t P1;
+ int8_t P2;
+ uint8_t usesnr;
+} __attribute__ ((packed));
+
+
+struct cmd_ds_802_11_pa_cfg {
+ struct cmd_header hdr;
+
+ __le16 action;
+ uint8_t enable;
+ int8_t P0;
+ int8_t P1;
+ int8_t P2;
+} __attribute__ ((packed));
+
+
+struct cmd_ds_802_11_led_ctrl {
+ __le16 action;
+ __le16 numled;
+ u8 data[256];
+} __attribute__ ((packed));
+
+struct cmd_ds_802_11_afc {
+ __le16 afc_auto;
+ union {
+ struct {
+ __le16 threshold;
+ __le16 period;
+ };
+ struct {
+ __le16 timing_offset; /* signed */
+ __le16 carrier_offset; /* signed */
+ };
+ };
+} __attribute__ ((packed));
+
+struct cmd_tx_rate_query {
+ __le16 txrate;
+} __attribute__ ((packed));
+
+struct cmd_ds_get_tsf {
+ __le64 tsfvalue;
+} __attribute__ ((packed));
+
+struct cmd_ds_bt_access {
+ __le16 action;
+ __le32 id;
+ u8 addr1[ETH_ALEN];
+ u8 addr2[ETH_ALEN];
+} __attribute__ ((packed));
+
+struct cmd_ds_fwt_access {
+ __le16 action;
+ __le32 id;
+ u8 valid;
+ u8 da[ETH_ALEN];
+ u8 dir;
+ u8 ra[ETH_ALEN];
+ __le32 ssn;
+ __le32 dsn;
+ __le32 metric;
+ u8 rate;
+ u8 hopcount;
+ u8 ttl;
+ __le32 expiration;
+ u8 sleepmode;
+ __le32 snr;
+ __le32 references;
+ u8 prec[ETH_ALEN];
+} __attribute__ ((packed));
+
+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));
+
+struct cmd_ds_mesh_access {
+ struct cmd_header hdr;
+
+ __le16 action;
+ __le32 data[32]; /* last position reserved */
+} __attribute__ ((packed));
+
+/* Number of stats counters returned by the firmware */
+#define MESH_STATS_NUM 8
+
+struct cmd_ds_command {
+ /* command header */
+ __le16 command;
+ __le16 size;
+ __le16 seqnum;
+ __le16 result;
+
+ /* command Body */
+ union {
+ struct cmd_ds_802_11_ps_mode psmode;
+ struct cmd_ds_802_11_monitor_mode monitor;
+ struct cmd_ds_802_11_rssi rssi;
+ struct cmd_ds_802_11_rssi_rsp rssirsp;
+ 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_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_afc afc;
+ struct cmd_ds_802_11_led_ctrl ledgpio;
+
+ struct cmd_ds_bt_access bt;
+ struct cmd_ds_fwt_access fwt;
+ struct cmd_ds_get_tsf gettsf;
+ struct cmd_ds_802_11_beacon_control bcn_ctrl;
+ } params;
+} __attribute__ ((packed));
+
#endif
--- linux-wl.orig/drivers/net/wireless/libertas/hostcmd.h
+++ /dev/null
@@ -1,800 +0,0 @@
-/*
- * This file contains the function prototypes, data structure
- * and defines for all the host/station commands
- */
-#ifndef _LBS_HOSTCMD_H
-#define _LBS_HOSTCMD_H
-
-#include <linux/wireless.h>
-#include "11d.h"
-#include "types.h"
-
-/* 802.11-related definitions */
-
-/* TxPD descriptor */
-struct txpd {
- /* union to cope up with later FW revisions */
- union {
- /* Current Tx packet status */
- __le32 tx_status;
- struct {
- /* BSS type: client, AP, etc. */
- u8 bss_type;
- /* BSS number */
- u8 bss_num;
- /* Reserved */
- __le16 reserved;
- } bss;
- } u;
- /* Tx control */
- __le32 tx_control;
- __le32 tx_packet_location;
- /* Tx packet length */
- __le16 tx_packet_length;
- /* 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;
-} __attribute__ ((packed));
-
-/* RxPD Descriptor */
-struct rxpd {
- /* union to cope up with later FW revisions */
- union {
- /* Current Rx packet status */
- __le16 status;
- struct {
- /* BSS type: client, AP, etc. */
- u8 bss_type;
- /* BSS number */
- u8 bss_num;
- } __attribute__ ((packed)) bss;
- } __attribute__ ((packed)) u;
-
- /* SNR */
- u8 snr;
-
- /* Tx control */
- u8 rx_control;
-
- /* Pkt length */
- __le16 pkt_len;
-
- /* Noise Floor */
- u8 nf;
-
- /* Rx Packet Rate */
- u8 rx_rate;
-
- /* Pkt addr */
- __le32 pkt_ptr;
-
- /* Next Rx RxPD addr */
- __le32 next_rxpd_ptr;
-
- /* Pkt Priority */
- u8 priority;
- u8 reserved[3];
-} __attribute__ ((packed));
-
-struct cmd_header {
- __le16 command;
- __le16 size;
- __le16 seqnum;
- __le16 result;
-} __attribute__ ((packed));
-
-struct cmd_ctrl_node {
- struct list_head list;
- int result;
- /* command response */
- int (*callback)(struct lbs_private *, unsigned long, struct cmd_header *);
- unsigned long callback_arg;
- /* command data */
- struct cmd_header *cmdbuf;
- /* wait queue */
- u16 cmdwaitqwoken;
- wait_queue_head_t cmdwait_q;
-};
-
-/* Generic structure to hold all key types. */
-struct enc_key {
- u16 len;
- u16 flags; /* KEY_INFO_* from defs.h */
- u16 type; /* KEY_TYPE_* from defs.h */
- u8 key[32];
-};
-
-/* lbs_offset_value */
-struct lbs_offset_value {
- u32 offset;
- u32 value;
-} __attribute__ ((packed));
-
-/* Define general data structure */
-/* cmd_DS_GEN */
-struct cmd_ds_gen {
- __le16 command;
- __le16 size;
- __le16 seqnum;
- __le16 result;
- void *cmdresp[0];
-} __attribute__ ((packed));
-
-#define S_DS_GEN sizeof(struct cmd_ds_gen)
-
-
-/*
- * Define data structure for CMD_GET_HW_SPEC
- * This structure defines the response for the GET_HW_SPEC command
- */
-struct cmd_ds_get_hw_spec {
- struct cmd_header hdr;
-
- /* HW Interface version number */
- __le16 hwifversion;
- /* HW version number */
- __le16 version;
- /* Max number of TxPD FW can handle */
- __le16 nr_txpd;
- /* Max no of Multicast address */
- __le16 nr_mcast_adr;
- /* MAC address */
- u8 permanentaddr[6];
-
- /* region Code */
- __le16 regioncode;
-
- /* Number of antenna used */
- __le16 nr_antenna;
-
- /* FW release number, example 0x01030304 = 2.3.4p1 */
- __le32 fwrelease;
-
- /* Base Address of TxPD queue */
- __le32 wcb_base;
- /* Read Pointer of RxPd queue */
- __le32 rxpd_rdptr;
-
- /* Write Pointer of RxPd queue */
- __le32 rxpd_wrptr;
-
- /*FW/HW capability */
- __le32 fwcapinfo;
-} __attribute__ ((packed));
-
-struct cmd_ds_802_11_subscribe_event {
- struct cmd_header hdr;
-
- __le16 action;
- __le16 events;
-
- /* 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.
- */
- uint8_t tlv[128];
-} __attribute__ ((packed));
-
-/*
- * This scan handle Country Information IE(802.11d compliant)
- * Define data structure for CMD_802_11_SCAN
- */
-struct cmd_ds_802_11_scan {
- struct cmd_header hdr;
-
- uint8_t bsstype;
- uint8_t bssid[ETH_ALEN];
- uint8_t tlvbuffer[0];
-#if 0
- mrvlietypes_ssidparamset_t ssidParamSet;
- mrvlietypes_chanlistparamset_t ChanListParamSet;
- mrvlietypes_ratesparamset_t OpRateSet;
-#endif
-} __attribute__ ((packed));
-
-struct cmd_ds_802_11_scan_rsp {
- struct cmd_header hdr;
-
- __le16 bssdescriptsize;
- uint8_t nr_sets;
- uint8_t bssdesc_and_tlvbuffer[0];
-} __attribute__ ((packed));
-
-struct cmd_ds_802_11_get_log {
- struct cmd_header hdr;
-
- __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;
-} __attribute__ ((packed));
-
-struct cmd_ds_mac_control {
- struct cmd_header hdr;
- __le16 action;
- u16 reserved;
-} __attribute__ ((packed));
-
-struct cmd_ds_mac_multicast_adr {
- struct cmd_header hdr;
- __le16 action;
- __le16 nr_of_adrs;
- u8 maclist[ETH_ALEN * MRVDRV_MAX_MULTICAST_LIST_SIZE];
-} __attribute__ ((packed));
-
-struct cmd_ds_gspi_bus_config {
- struct cmd_header hdr;
- __le16 action;
- __le16 bus_delay_mode;
- __le16 host_time_delay_to_read_port;
- __le16 host_time_delay_to_read_register;
-} __attribute__ ((packed));
-
-struct cmd_ds_802_11_authenticate {
- struct cmd_header hdr;
-
- u8 bssid[ETH_ALEN];
- u8 authtype;
- u8 reserved[10];
-} __attribute__ ((packed));
-
-struct cmd_ds_802_11_deauthenticate {
- struct cmd_header hdr;
-
- u8 macaddr[ETH_ALEN];
- __le16 reasoncode;
-} __attribute__ ((packed));
-
-struct cmd_ds_802_11_associate {
- struct cmd_header hdr;
-
- u8 bssid[6];
- __le16 capability;
- __le16 listeninterval;
- __le16 bcnperiod;
- u8 dtimperiod;
- u8 iebuf[512]; /* Enough for required and most optional IEs */
-} __attribute__ ((packed));
-
-struct cmd_ds_802_11_associate_response {
- struct cmd_header hdr;
-
- __le16 capability;
- __le16 statuscode;
- __le16 aid;
- u8 iebuf[512];
-} __attribute__ ((packed));
-
-struct cmd_ds_802_11_set_wep {
- struct cmd_header hdr;
-
- /* ACT_ADD, ACT_REMOVE or ACT_ENABLE */
- __le16 action;
-
- /* key Index selected for Tx */
- __le16 keyindex;
-
- /* 40, 128bit or TXWEP */
- uint8_t keytype[4];
- uint8_t keymaterial[4][16];
-} __attribute__ ((packed));
-
-struct cmd_ds_802_3_get_stat {
- __le32 xmitok;
- __le32 rcvok;
- __le32 xmiterror;
- __le32 rcverror;
- __le32 rcvnobuffer;
- __le32 rcvcrcerror;
-} __attribute__ ((packed));
-
-struct cmd_ds_802_11_get_stat {
- __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;
-} __attribute__ ((packed));
-
-struct cmd_ds_802_11_snmp_mib {
- struct cmd_header hdr;
-
- __le16 action;
- __le16 oid;
- __le16 bufsize;
- u8 value[128];
-} __attribute__ ((packed));
-
-struct cmd_ds_mac_reg_map {
- __le16 buffersize;
- u8 regmap[128];
- __le16 reserved;
-} __attribute__ ((packed));
-
-struct cmd_ds_bbp_reg_map {
- __le16 buffersize;
- u8 regmap[128];
- __le16 reserved;
-} __attribute__ ((packed));
-
-struct cmd_ds_rf_reg_map {
- __le16 buffersize;
- u8 regmap[64];
- __le16 reserved;
-} __attribute__ ((packed));
-
-struct cmd_ds_mac_reg_access {
- __le16 action;
- __le16 offset;
- __le32 value;
-} __attribute__ ((packed));
-
-struct cmd_ds_bbp_reg_access {
- __le16 action;
- __le16 offset;
- u8 value;
- u8 reserved[3];
-} __attribute__ ((packed));
-
-struct cmd_ds_rf_reg_access {
- __le16 action;
- __le16 offset;
- u8 value;
- u8 reserved[3];
-} __attribute__ ((packed));
-
-struct cmd_ds_802_11_radio_control {
- struct cmd_header hdr;
-
- __le16 action;
- __le16 control;
-} __attribute__ ((packed));
-
-struct cmd_ds_802_11_beacon_control {
- __le16 action;
- __le16 beacon_enable;
- __le16 beacon_period;
-} __attribute__ ((packed));
-
-struct cmd_ds_802_11_sleep_params {
- struct cmd_header hdr;
-
- /* ACT_GET/ACT_SET */
- __le16 action;
-
- /* Sleep clock error in ppm */
- __le16 error;
-
- /* Wakeup offset in usec */
- __le16 offset;
-
- /* Clock stabilization time in usec */
- __le16 stabletime;
-
- /* control periodic calibration */
- uint8_t calcontrol;
-
- /* control the use of external sleep clock */
- uint8_t externalsleepclk;
-
- /* reserved field, should be set to zero */
- __le16 reserved;
-} __attribute__ ((packed));
-
-struct cmd_ds_802_11_inactivity_timeout {
- struct cmd_header hdr;
-
- /* ACT_GET/ACT_SET */
- __le16 action;
-
- /* Inactivity timeout in msec */
- __le16 timeout;
-} __attribute__ ((packed));
-
-struct cmd_ds_802_11_rf_channel {
- struct cmd_header hdr;
-
- __le16 action;
- __le16 channel;
- __le16 rftype; /* unused */
- __le16 reserved; /* unused */
- u8 channellist[32]; /* unused */
-} __attribute__ ((packed));
-
-struct cmd_ds_802_11_rssi {
- /* weighting factor */
- __le16 N;
-
- __le16 reserved_0;
- __le16 reserved_1;
- __le16 reserved_2;
-} __attribute__ ((packed));
-
-struct cmd_ds_802_11_rssi_rsp {
- __le16 SNR;
- __le16 noisefloor;
- __le16 avgSNR;
- __le16 avgnoisefloor;
-} __attribute__ ((packed));
-
-struct cmd_ds_802_11_mac_address {
- struct cmd_header hdr;
-
- __le16 action;
- u8 macadd[ETH_ALEN];
-} __attribute__ ((packed));
-
-struct cmd_ds_802_11_rf_tx_power {
- struct cmd_header hdr;
-
- __le16 action;
- __le16 curlevel;
- s8 maxlevel;
- s8 minlevel;
-} __attribute__ ((packed));
-
-struct cmd_ds_802_11_rf_antenna {
- __le16 action;
-
- /* Number of antennas or 0xffff(diversity) */
- __le16 antennamode;
-
-} __attribute__ ((packed));
-
-struct cmd_ds_802_11_monitor_mode {
- __le16 action;
- __le16 mode;
-} __attribute__ ((packed));
-
-struct cmd_ds_set_boot2_ver {
- struct cmd_header hdr;
-
- __le16 action;
- __le16 version;
-} __attribute__ ((packed));
-
-struct cmd_ds_802_11_fw_wake_method {
- struct cmd_header hdr;
-
- __le16 action;
- __le16 method;
-} __attribute__ ((packed));
-
-struct cmd_ds_802_11_sleep_period {
- struct cmd_header hdr;
-
- __le16 action;
- __le16 period;
-} __attribute__ ((packed));
-
-struct cmd_ds_802_11_ps_mode {
- __le16 action;
- __le16 nullpktinterval;
- __le16 multipledtim;
- __le16 reserved;
- __le16 locallisteninterval;
-} __attribute__ ((packed));
-
-struct cmd_confirm_sleep {
- struct cmd_header hdr;
-
- __le16 action;
- __le16 nullpktinterval;
- __le16 multipledtim;
- __le16 reserved;
- __le16 locallisteninterval;
-} __attribute__ ((packed));
-
-struct cmd_ds_802_11_data_rate {
- struct cmd_header hdr;
-
- __le16 action;
- __le16 reserved;
- u8 rates[MAX_RATES];
-} __attribute__ ((packed));
-
-struct cmd_ds_802_11_rate_adapt_rateset {
- struct cmd_header hdr;
- __le16 action;
- __le16 enablehwauto;
- __le16 bitmap;
-} __attribute__ ((packed));
-
-struct cmd_ds_802_11_ad_hoc_start {
- struct cmd_header hdr;
-
- u8 ssid[IW_ESSID_MAX_SIZE];
- u8 bsstype;
- __le16 beaconperiod;
- u8 dtimperiod; /* Reserved on v9 and later */
- struct ieee_ie_ibss_param_set ibss;
- u8 reserved1[4];
- struct ieee_ie_ds_param_set ds;
- u8 reserved2[4];
- __le16 probedelay; /* Reserved on v9 and later */
- __le16 capability;
- u8 rates[MAX_RATES];
- u8 tlv_memory_size_pad[100];
-} __attribute__ ((packed));
-
-struct cmd_ds_802_11_ad_hoc_result {
- struct cmd_header hdr;
-
- u8 pad[3];
- u8 bssid[ETH_ALEN];
-} __attribute__ ((packed));
-
-struct adhoc_bssdesc {
- u8 bssid[ETH_ALEN];
- u8 ssid[IW_ESSID_MAX_SIZE];
- u8 type;
- __le16 beaconperiod;
- u8 dtimperiod;
- __le64 timestamp;
- __le64 localtime;
- struct ieee_ie_ds_param_set ds;
- u8 reserved1[4];
- struct ieee_ie_ibss_param_set ibss;
- u8 reserved2[4];
- __le16 capability;
- u8 rates[MAX_RATES];
-
- /* 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 {
- struct cmd_header hdr;
-
- struct adhoc_bssdesc bss;
- __le16 failtimeout; /* Reserved on v9 and later */
- __le16 probedelay; /* Reserved on v9 and later */
-} __attribute__ ((packed));
-
-struct cmd_ds_802_11_ad_hoc_stop {
- struct cmd_header hdr;
-} __attribute__ ((packed));
-
-struct cmd_ds_802_11_enable_rsn {
- struct cmd_header hdr;
-
- __le16 action;
- __le16 enable;
-} __attribute__ ((packed));
-
-struct MrvlIEtype_keyParamSet {
- /* type ID */
- __le16 type;
-
- /* length of Payload */
- __le16 length;
-
- /* type of key: WEP=0, TKIP=1, AES=2 */
- __le16 keytypeid;
-
- /* key control Info specific to a keytypeid */
- __le16 keyinfo;
-
- /* length of key */
- __le16 keylen;
-
- /* key material of size keylen */
- u8 key[32];
-} __attribute__ ((packed));
-
-#define MAX_WOL_RULES 16
-
-struct host_wol_rule {
- uint8_t rule_no;
- uint8_t rule_ops;
- __le16 sig_offset;
- __le16 sig_length;
- __le16 reserve;
- __be32 sig_mask;
- __be32 signature;
-} __attribute__ ((packed));
-
-struct wol_config {
- uint8_t action;
- uint8_t pattern;
- uint8_t no_rules_in_cmd;
- uint8_t result;
- struct host_wol_rule rule[MAX_WOL_RULES];
-} __attribute__ ((packed));
-
-struct cmd_ds_host_sleep {
- struct cmd_header hdr;
- __le32 criteria;
- uint8_t gpio;
- uint16_t gap;
- struct wol_config wol_conf;
-} __attribute__ ((packed));
-
-
-
-struct cmd_ds_802_11_key_material {
- struct cmd_header hdr;
-
- __le16 action;
- struct MrvlIEtype_keyParamSet keyParamSet[2];
-} __attribute__ ((packed));
-
-struct cmd_ds_802_11_eeprom_access {
- struct cmd_header hdr;
- __le16 action;
- __le16 offset;
- __le16 len;
- /* firmware says it returns a maximum of 20 bytes */
-#define LBS_EEPROM_READ_LEN 20
- u8 value[LBS_EEPROM_READ_LEN];
-} __attribute__ ((packed));
-
-struct cmd_ds_802_11_tpc_cfg {
- struct cmd_header hdr;
-
- __le16 action;
- uint8_t enable;
- int8_t P0;
- int8_t P1;
- int8_t P2;
- uint8_t usesnr;
-} __attribute__ ((packed));
-
-
-struct cmd_ds_802_11_pa_cfg {
- struct cmd_header hdr;
-
- __le16 action;
- uint8_t enable;
- int8_t P0;
- int8_t P1;
- int8_t P2;
-} __attribute__ ((packed));
-
-
-struct cmd_ds_802_11_led_ctrl {
- __le16 action;
- __le16 numled;
- u8 data[256];
-} __attribute__ ((packed));
-
-struct cmd_ds_802_11_afc {
- __le16 afc_auto;
- union {
- struct {
- __le16 threshold;
- __le16 period;
- };
- struct {
- __le16 timing_offset; /* signed */
- __le16 carrier_offset; /* signed */
- };
- };
-} __attribute__ ((packed));
-
-struct cmd_tx_rate_query {
- __le16 txrate;
-} __attribute__ ((packed));
-
-struct cmd_ds_get_tsf {
- __le64 tsfvalue;
-} __attribute__ ((packed));
-
-struct cmd_ds_bt_access {
- __le16 action;
- __le32 id;
- u8 addr1[ETH_ALEN];
- u8 addr2[ETH_ALEN];
-} __attribute__ ((packed));
-
-struct cmd_ds_fwt_access {
- __le16 action;
- __le32 id;
- u8 valid;
- u8 da[ETH_ALEN];
- u8 dir;
- u8 ra[ETH_ALEN];
- __le32 ssn;
- __le32 dsn;
- __le32 metric;
- u8 rate;
- u8 hopcount;
- u8 ttl;
- __le32 expiration;
- u8 sleepmode;
- __le32 snr;
- __le32 references;
- u8 prec[ETH_ALEN];
-} __attribute__ ((packed));
-
-
-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));
-
-
-struct cmd_ds_mesh_access {
- struct cmd_header hdr;
-
- __le16 action;
- __le32 data[32]; /* last position reserved */
-} __attribute__ ((packed));
-
-/* Number of stats counters returned by the firmware */
-#define MESH_STATS_NUM 8
-
-struct cmd_ds_command {
- /* command header */
- __le16 command;
- __le16 size;
- __le16 seqnum;
- __le16 result;
-
- /* command Body */
- union {
- struct cmd_ds_802_11_ps_mode psmode;
- struct cmd_ds_802_11_get_stat gstat;
- struct cmd_ds_802_3_get_stat gstat_8023;
- struct cmd_ds_802_11_rf_antenna rant;
- struct cmd_ds_802_11_monitor_mode monitor;
- struct cmd_ds_802_11_rssi rssi;
- struct cmd_ds_802_11_rssi_rsp rssirsp;
- 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_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_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_beacon_control bcn_ctrl;
- } params;
-} __attribute__ ((packed));
-
-#endif
--- linux-wl.orig/drivers/net/wireless/libertas/cmd.h
+++ linux-wl/drivers/net/wireless/libertas/cmd.h
@@ -3,7 +3,7 @@
#ifndef _LBS_CMD_H_
#define _LBS_CMD_H_
-#include "hostcmd.h"
+#include "host.h"
#include "dev.h"
/* lbs_cmd() infers the size of the buffer to copy data back into, from
--- linux-wl.orig/drivers/net/wireless/libertas/cmd.c
+++ linux-wl/drivers/net/wireless/libertas/cmd.c
@@ -8,7 +8,6 @@
#include <linux/kfifo.h>
#include <linux/sched.h>
#include "host.h"
-#include "hostcmd.h"
#include "decl.h"
#include "defs.h"
#include "dev.h"
--- linux-wl.orig/drivers/net/wireless/libertas/dev.h
+++ linux-wl/drivers/net/wireless/libertas/dev.h
@@ -12,7 +12,7 @@
#include <linux/debugfs.h>
#include "defs.h"
-#include "hostcmd.h"
+#include "host.h"
extern const struct ethtool_ops lbs_ethtool_ops;
--- linux-wl.orig/drivers/net/wireless/libertas/rx.c
+++ linux-wl/drivers/net/wireless/libertas/rx.c
@@ -4,7 +4,7 @@
#include <linux/etherdevice.h>
#include <linux/types.h>
-#include "hostcmd.h"
+#include "host.h"
#include "radiotap.h"
#include "decl.h"
#include "dev.h"
--- linux-wl.orig/drivers/net/wireless/libertas/tx.c
+++ linux-wl/drivers/net/wireless/libertas/tx.c
@@ -5,7 +5,7 @@
#include <linux/etherdevice.h>
#include <linux/sched.h>
-#include "hostcmd.h"
+#include "host.h"
#include "radiotap.h"
#include "decl.h"
#include "defs.h"
--
http://www.holgerschurig.de
^ permalink raw reply [flat|nested] 2+ messages in thread
* Re: [PATCH] libertas: cleanup host.h and hostcmd.h
2009-10-16 15:32 [PATCH] libertas: cleanup host.h and hostcmd.h Holger Schurig
@ 2009-10-16 16:28 ` Dan Williams
0 siblings, 0 replies; 2+ messages in thread
From: Dan Williams @ 2009-10-16 16:28 UTC (permalink / raw)
To: Holger Schurig; +Cc: linux-wireless, John Linville
On Fri, 2009-10-16 at 17:32 +0200, Holger Schurig wrote:
> Also remove some unused definitions and make tab usage consistent.
>
> Signed-off-by: Holger Schurig <hs4233@mail.mn-solutions.de>
Acked-by: Dan Williams <dcbw@redhat.com>
>
> ---
> No functional changes!
>
> --- linux-wl.orig/drivers/net/wireless/libertas/host.h
> +++ linux-wl/drivers/net/wireless/libertas/host.h
> @@ -1,202 +1,189 @@
> /**
> - * This file contains definitions of WLAN commands.
> + * This file function prototypes, data structure
> + * and definitions for all the host/station commands
> */
>
> #ifndef _LBS_HOST_H_
> #define _LBS_HOST_H_
>
> -/** PUBLIC DEFINITIONS */
> -#define DEFAULT_AD_HOC_CHANNEL 6
> -#define DEFAULT_AD_HOC_CHANNEL_A 36
> +#include "11d.h"
>
> -#define CMD_OPTION_WAITFORRSP 0x0002
> +#define DEFAULT_AD_HOC_CHANNEL 6
> +
> +#define CMD_OPTION_WAITFORRSP 0x0002
>
> /** Host command IDs */
>
> /* Return command are almost always the same as the host command, but with
> * bit 15 set high. There are a few exceptions, though...
> */
> -#define CMD_RET(cmd) (0x8000 | cmd)
> +#define CMD_RET(cmd) (0x8000 | cmd)
>
> /* Return command convention exceptions: */
> -#define CMD_RET_802_11_ASSOCIATE 0x8012
> +#define CMD_RET_802_11_ASSOCIATE 0x8012
>
> /* Command codes */
> -#define CMD_GET_HW_SPEC 0x0003
> -#define CMD_EEPROM_UPDATE 0x0004
> -#define CMD_802_11_RESET 0x0005
> -#define CMD_802_11_SCAN 0x0006
> -#define CMD_802_11_GET_LOG 0x000b
> -#define CMD_MAC_MULTICAST_ADR 0x0010
> -#define CMD_802_11_AUTHENTICATE 0x0011
> -#define CMD_802_11_EEPROM_ACCESS 0x0059
> -#define CMD_802_11_ASSOCIATE 0x0050
> -#define CMD_802_11_SET_WEP 0x0013
> -#define CMD_802_11_GET_STAT 0x0014
> -#define CMD_802_3_GET_STAT 0x0015
> -#define CMD_802_11_SNMP_MIB 0x0016
> -#define CMD_MAC_REG_MAP 0x0017
> -#define CMD_BBP_REG_MAP 0x0018
> -#define CMD_MAC_REG_ACCESS 0x0019
> -#define CMD_BBP_REG_ACCESS 0x001a
> -#define CMD_RF_REG_ACCESS 0x001b
> -#define CMD_802_11_RADIO_CONTROL 0x001c
> -#define CMD_802_11_RF_CHANNEL 0x001d
> -#define CMD_802_11_RF_TX_POWER 0x001e
> -#define CMD_802_11_RSSI 0x001f
> -#define CMD_802_11_RF_ANTENNA 0x0020
> -#define CMD_802_11_PS_MODE 0x0021
> -#define CMD_802_11_DATA_RATE 0x0022
> -#define CMD_RF_REG_MAP 0x0023
> -#define CMD_802_11_DEAUTHENTICATE 0x0024
> -#define CMD_802_11_REASSOCIATE 0x0025
> -#define CMD_MAC_CONTROL 0x0028
> -#define CMD_802_11_AD_HOC_START 0x002b
> -#define CMD_802_11_AD_HOC_JOIN 0x002c
> -#define CMD_802_11_QUERY_TKIP_REPLY_CNTRS 0x002e
> -#define CMD_802_11_ENABLE_RSN 0x002f
> -#define CMD_802_11_SET_AFC 0x003c
> -#define CMD_802_11_GET_AFC 0x003d
> -#define CMD_802_11_DEEP_SLEEP 0x003e
> -#define CMD_802_11_AD_HOC_STOP 0x0040
> -#define CMD_802_11_HOST_SLEEP_CFG 0x0043
> -#define CMD_802_11_WAKEUP_CONFIRM 0x0044
> -#define CMD_802_11_HOST_SLEEP_ACTIVATE 0x0045
> -#define CMD_802_11_BEACON_STOP 0x0049
> -#define CMD_802_11_MAC_ADDRESS 0x004d
> -#define CMD_802_11_LED_GPIO_CTRL 0x004e
> -#define CMD_802_11_EEPROM_ACCESS 0x0059
> -#define CMD_802_11_BAND_CONFIG 0x0058
> -#define CMD_GSPI_BUS_CONFIG 0x005a
> -#define CMD_802_11D_DOMAIN_INFO 0x005b
> -#define CMD_802_11_KEY_MATERIAL 0x005e
> -#define CMD_802_11_SLEEP_PARAMS 0x0066
> -#define CMD_802_11_INACTIVITY_TIMEOUT 0x0067
> -#define CMD_802_11_SLEEP_PERIOD 0x0068
> -#define CMD_802_11_TPC_CFG 0x0072
> -#define CMD_802_11_PA_CFG 0x0073
> -#define CMD_802_11_FW_WAKE_METHOD 0x0074
> -#define CMD_802_11_SUBSCRIBE_EVENT 0x0075
> -#define CMD_802_11_RATE_ADAPT_RATESET 0x0076
> -#define CMD_802_11_TX_RATE_QUERY 0x007f
> -#define CMD_GET_TSF 0x0080
> -#define CMD_BT_ACCESS 0x0087
> -#define CMD_FWT_ACCESS 0x0095
> -#define CMD_802_11_MONITOR_MODE 0x0098
> -#define CMD_MESH_ACCESS 0x009b
> -#define CMD_MESH_CONFIG_OLD 0x00a3
> -#define CMD_MESH_CONFIG 0x00ac
> -#define CMD_SET_BOOT2_VER 0x00a5
> -#define CMD_FUNC_INIT 0x00a9
> -#define CMD_FUNC_SHUTDOWN 0x00aa
> -#define CMD_802_11_BEACON_CTRL 0x00b0
> +#define CMD_GET_HW_SPEC 0x0003
> +#define CMD_EEPROM_UPDATE 0x0004
> +#define CMD_802_11_RESET 0x0005
> +#define CMD_802_11_SCAN 0x0006
> +#define CMD_802_11_GET_LOG 0x000b
> +#define CMD_MAC_MULTICAST_ADR 0x0010
> +#define CMD_802_11_AUTHENTICATE 0x0011
> +#define CMD_802_11_EEPROM_ACCESS 0x0059
> +#define CMD_802_11_ASSOCIATE 0x0050
> +#define CMD_802_11_SET_WEP 0x0013
> +#define CMD_802_11_GET_STAT 0x0014
> +#define CMD_802_3_GET_STAT 0x0015
> +#define CMD_802_11_SNMP_MIB 0x0016
> +#define CMD_MAC_REG_MAP 0x0017
> +#define CMD_BBP_REG_MAP 0x0018
> +#define CMD_MAC_REG_ACCESS 0x0019
> +#define CMD_BBP_REG_ACCESS 0x001a
> +#define CMD_RF_REG_ACCESS 0x001b
> +#define CMD_802_11_RADIO_CONTROL 0x001c
> +#define CMD_802_11_RF_CHANNEL 0x001d
> +#define CMD_802_11_RF_TX_POWER 0x001e
> +#define CMD_802_11_RSSI 0x001f
> +#define CMD_802_11_RF_ANTENNA 0x0020
> +#define CMD_802_11_PS_MODE 0x0021
> +#define CMD_802_11_DATA_RATE 0x0022
> +#define CMD_RF_REG_MAP 0x0023
> +#define CMD_802_11_DEAUTHENTICATE 0x0024
> +#define CMD_802_11_REASSOCIATE 0x0025
> +#define CMD_MAC_CONTROL 0x0028
> +#define CMD_802_11_AD_HOC_START 0x002b
> +#define CMD_802_11_AD_HOC_JOIN 0x002c
> +#define CMD_802_11_QUERY_TKIP_REPLY_CNTRS 0x002e
> +#define CMD_802_11_ENABLE_RSN 0x002f
> +#define CMD_802_11_SET_AFC 0x003c
> +#define CMD_802_11_GET_AFC 0x003d
> +#define CMD_802_11_DEEP_SLEEP 0x003e
> +#define CMD_802_11_AD_HOC_STOP 0x0040
> +#define CMD_802_11_HOST_SLEEP_CFG 0x0043
> +#define CMD_802_11_WAKEUP_CONFIRM 0x0044
> +#define CMD_802_11_HOST_SLEEP_ACTIVATE 0x0045
> +#define CMD_802_11_BEACON_STOP 0x0049
> +#define CMD_802_11_MAC_ADDRESS 0x004d
> +#define CMD_802_11_LED_GPIO_CTRL 0x004e
> +#define CMD_802_11_EEPROM_ACCESS 0x0059
> +#define CMD_802_11_BAND_CONFIG 0x0058
> +#define CMD_GSPI_BUS_CONFIG 0x005a
> +#define CMD_802_11D_DOMAIN_INFO 0x005b
> +#define CMD_802_11_KEY_MATERIAL 0x005e
> +#define CMD_802_11_SLEEP_PARAMS 0x0066
> +#define CMD_802_11_INACTIVITY_TIMEOUT 0x0067
> +#define CMD_802_11_SLEEP_PERIOD 0x0068
> +#define CMD_802_11_TPC_CFG 0x0072
> +#define CMD_802_11_PA_CFG 0x0073
> +#define CMD_802_11_FW_WAKE_METHOD 0x0074
> +#define CMD_802_11_SUBSCRIBE_EVENT 0x0075
> +#define CMD_802_11_RATE_ADAPT_RATESET 0x0076
> +#define CMD_802_11_TX_RATE_QUERY 0x007f
> +#define CMD_GET_TSF 0x0080
> +#define CMD_BT_ACCESS 0x0087
> +#define CMD_FWT_ACCESS 0x0095
> +#define CMD_802_11_MONITOR_MODE 0x0098
> +#define CMD_MESH_ACCESS 0x009b
> +#define CMD_MESH_CONFIG_OLD 0x00a3
> +#define CMD_MESH_CONFIG 0x00ac
> +#define CMD_SET_BOOT2_VER 0x00a5
> +#define CMD_FUNC_INIT 0x00a9
> +#define CMD_FUNC_SHUTDOWN 0x00aa
> +#define CMD_802_11_BEACON_CTRL 0x00b0
>
> /* For the IEEE Power Save */
> -#define CMD_SUBCMD_ENTER_PS 0x0030
> -#define CMD_SUBCMD_EXIT_PS 0x0031
> -#define CMD_SUBCMD_SLEEP_CONFIRMED 0x0034
> -#define CMD_SUBCMD_FULL_POWERDOWN 0x0035
> -#define CMD_SUBCMD_FULL_POWERUP 0x0036
> -
> -#define CMD_ENABLE_RSN 0x0001
> -#define CMD_DISABLE_RSN 0x0000
> -
> -#define CMD_ACT_GET 0x0000
> -#define CMD_ACT_SET 0x0001
> -#define CMD_ACT_GET_AES 0x0002
> -#define CMD_ACT_SET_AES 0x0003
> -#define CMD_ACT_REMOVE_AES 0x0004
> +#define CMD_SUBCMD_ENTER_PS 0x0030
> +#define CMD_SUBCMD_EXIT_PS 0x0031
> +#define CMD_SUBCMD_SLEEP_CONFIRMED 0x0034
> +#define CMD_SUBCMD_FULL_POWERDOWN 0x0035
> +#define CMD_SUBCMD_FULL_POWERUP 0x0036
>
> -/* Define action or option for CMD_802_11_SET_WEP */
> -#define CMD_ACT_ADD 0x0002
> -#define CMD_ACT_REMOVE 0x0004
> -#define CMD_ACT_USE_DEFAULT 0x0008
> +#define CMD_ENABLE_RSN 0x0001
> +#define CMD_DISABLE_RSN 0x0000
>
> -#define CMD_TYPE_WEP_40_BIT 0x01
> -#define CMD_TYPE_WEP_104_BIT 0x02
> +#define CMD_ACT_GET 0x0000
> +#define CMD_ACT_SET 0x0001
>
> -#define CMD_NUM_OF_WEP_KEYS 4
> +/* Define action or option for CMD_802_11_SET_WEP */
> +#define CMD_ACT_ADD 0x0002
> +#define CMD_ACT_REMOVE 0x0004
>
> -#define CMD_WEP_KEY_INDEX_MASK 0x3fff
> +#define CMD_TYPE_WEP_40_BIT 0x01
> +#define CMD_TYPE_WEP_104_BIT 0x02
>
> -/* Define action or option for CMD_802_11_RESET */
> -#define CMD_ACT_HALT 0x0003
> +#define CMD_NUM_OF_WEP_KEYS 4
> +
> +#define CMD_WEP_KEY_INDEX_MASK 0x3fff
>
> /* Define action or option for CMD_802_11_SCAN */
> -#define CMD_BSS_TYPE_BSS 0x0001
> -#define CMD_BSS_TYPE_IBSS 0x0002
> -#define CMD_BSS_TYPE_ANY 0x0003
> +#define CMD_BSS_TYPE_BSS 0x0001
> +#define CMD_BSS_TYPE_IBSS 0x0002
> +#define CMD_BSS_TYPE_ANY 0x0003
>
> /* Define action or option for CMD_802_11_SCAN */
> -#define CMD_SCAN_TYPE_ACTIVE 0x0000
> -#define CMD_SCAN_TYPE_PASSIVE 0x0001
> +#define CMD_SCAN_TYPE_ACTIVE 0x0000
> +#define CMD_SCAN_TYPE_PASSIVE 0x0001
>
> -#define CMD_SCAN_RADIO_TYPE_BG 0
> +#define CMD_SCAN_RADIO_TYPE_BG 0
>
> -#define CMD_SCAN_PROBE_DELAY_TIME 0
> +#define CMD_SCAN_PROBE_DELAY_TIME 0
>
> /* Define action or option for CMD_MAC_CONTROL */
> -#define CMD_ACT_MAC_RX_ON 0x0001
> -#define CMD_ACT_MAC_TX_ON 0x0002
> -#define CMD_ACT_MAC_LOOPBACK_ON 0x0004
> -#define CMD_ACT_MAC_WEP_ENABLE 0x0008
> -#define CMD_ACT_MAC_INT_ENABLE 0x0010
> -#define CMD_ACT_MAC_MULTICAST_ENABLE 0x0020
> -#define CMD_ACT_MAC_BROADCAST_ENABLE 0x0040
> -#define CMD_ACT_MAC_PROMISCUOUS_ENABLE 0x0080
> -#define CMD_ACT_MAC_ALL_MULTICAST_ENABLE 0x0100
> -#define CMD_ACT_MAC_STRICT_PROTECTION_ENABLE 0x0400
> +#define CMD_ACT_MAC_RX_ON 0x0001
> +#define CMD_ACT_MAC_TX_ON 0x0002
> +#define CMD_ACT_MAC_LOOPBACK_ON 0x0004
> +#define CMD_ACT_MAC_WEP_ENABLE 0x0008
> +#define CMD_ACT_MAC_INT_ENABLE 0x0010
> +#define CMD_ACT_MAC_MULTICAST_ENABLE 0x0020
> +#define CMD_ACT_MAC_BROADCAST_ENABLE 0x0040
> +#define CMD_ACT_MAC_PROMISCUOUS_ENABLE 0x0080
> +#define CMD_ACT_MAC_ALL_MULTICAST_ENABLE 0x0100
> +#define CMD_ACT_MAC_STRICT_PROTECTION_ENABLE 0x0400
>
> /* Event flags for CMD_802_11_SUBSCRIBE_EVENT */
> -#define CMD_SUBSCRIBE_RSSI_LOW 0x0001
> -#define CMD_SUBSCRIBE_SNR_LOW 0x0002
> -#define CMD_SUBSCRIBE_FAILCOUNT 0x0004
> -#define CMD_SUBSCRIBE_BCNMISS 0x0008
> -#define CMD_SUBSCRIBE_RSSI_HIGH 0x0010
> -#define CMD_SUBSCRIBE_SNR_HIGH 0x0020
> -
> -#define RADIO_PREAMBLE_LONG 0x00
> -#define RADIO_PREAMBLE_SHORT 0x02
> -#define RADIO_PREAMBLE_AUTO 0x04
> +#define CMD_SUBSCRIBE_RSSI_LOW 0x0001
> +#define CMD_SUBSCRIBE_SNR_LOW 0x0002
> +#define CMD_SUBSCRIBE_FAILCOUNT 0x0004
> +#define CMD_SUBSCRIBE_BCNMISS 0x0008
> +#define CMD_SUBSCRIBE_RSSI_HIGH 0x0010
> +#define CMD_SUBSCRIBE_SNR_HIGH 0x0020
> +
> +#define RADIO_PREAMBLE_LONG 0x00
> +#define RADIO_PREAMBLE_SHORT 0x02
> +#define RADIO_PREAMBLE_AUTO 0x04
>
> /* Define action or option for CMD_802_11_RF_CHANNEL */
> -#define CMD_OPT_802_11_RF_CHANNEL_GET 0x00
> -#define CMD_OPT_802_11_RF_CHANNEL_SET 0x01
> +#define CMD_OPT_802_11_RF_CHANNEL_GET 0x00
> +#define CMD_OPT_802_11_RF_CHANNEL_SET 0x01
>
> /* Define action or option for CMD_802_11_DATA_RATE */
> -#define CMD_ACT_SET_TX_AUTO 0x0000
> -#define CMD_ACT_SET_TX_FIX_RATE 0x0001
> -#define CMD_ACT_GET_TX_RATE 0x0002
> -
> -#define CMD_ACT_SET_RX 0x0001
> -#define CMD_ACT_SET_TX 0x0002
> -#define CMD_ACT_SET_BOTH 0x0003
> -#define CMD_ACT_GET_RX 0x0004
> -#define CMD_ACT_GET_TX 0x0008
> -#define CMD_ACT_GET_BOTH 0x000c
> +#define CMD_ACT_SET_TX_AUTO 0x0000
> +#define CMD_ACT_SET_TX_FIX_RATE 0x0001
> +#define CMD_ACT_GET_TX_RATE 0x0002
>
> /* Define action or option for CMD_802_11_PS_MODE */
> -#define CMD_TYPE_CAM 0x0000
> -#define CMD_TYPE_MAX_PSP 0x0001
> -#define CMD_TYPE_FAST_PSP 0x0002
> +#define CMD_TYPE_CAM 0x0000
> +#define CMD_TYPE_MAX_PSP 0x0001
> +#define CMD_TYPE_FAST_PSP 0x0002
>
> /* Options for CMD_802_11_FW_WAKE_METHOD */
> -#define CMD_WAKE_METHOD_UNCHANGED 0x0000
> -#define CMD_WAKE_METHOD_COMMAND_INT 0x0001
> -#define CMD_WAKE_METHOD_GPIO 0x0002
> +#define CMD_WAKE_METHOD_UNCHANGED 0x0000
> +#define CMD_WAKE_METHOD_COMMAND_INT 0x0001
> +#define CMD_WAKE_METHOD_GPIO 0x0002
>
> /* Object IDs for CMD_802_11_SNMP_MIB */
> -#define SNMP_MIB_OID_BSS_TYPE 0x0000
> -#define SNMP_MIB_OID_OP_RATE_SET 0x0001
> -#define SNMP_MIB_OID_BEACON_PERIOD 0x0002 /* Reserved on v9+ */
> -#define SNMP_MIB_OID_DTIM_PERIOD 0x0003 /* Reserved on v9+ */
> -#define SNMP_MIB_OID_ASSOC_TIMEOUT 0x0004 /* Reserved on v9+ */
> -#define SNMP_MIB_OID_RTS_THRESHOLD 0x0005
> -#define SNMP_MIB_OID_SHORT_RETRY_LIMIT 0x0006
> -#define SNMP_MIB_OID_LONG_RETRY_LIMIT 0x0007
> -#define SNMP_MIB_OID_FRAG_THRESHOLD 0x0008
> -#define SNMP_MIB_OID_11D_ENABLE 0x0009
> -#define SNMP_MIB_OID_11H_ENABLE 0x000A
> +#define SNMP_MIB_OID_BSS_TYPE 0x0000
> +#define SNMP_MIB_OID_OP_RATE_SET 0x0001
> +#define SNMP_MIB_OID_BEACON_PERIOD 0x0002 /* Reserved on v9+ */
> +#define SNMP_MIB_OID_DTIM_PERIOD 0x0003 /* Reserved on v9+ */
> +#define SNMP_MIB_OID_ASSOC_TIMEOUT 0x0004 /* Reserved on v9+ */
> +#define SNMP_MIB_OID_RTS_THRESHOLD 0x0005
> +#define SNMP_MIB_OID_SHORT_RETRY_LIMIT 0x0006
> +#define SNMP_MIB_OID_LONG_RETRY_LIMIT 0x0007
> +#define SNMP_MIB_OID_FRAG_THRESHOLD 0x0008
> +#define SNMP_MIB_OID_11D_ENABLE 0x0009
> +#define SNMP_MIB_OID_11H_ENABLE 0x000A
>
> /* Define action or option for CMD_BT_ACCESS */
> enum cmd_bt_access_opts {
> @@ -303,4 +290,714 @@
> #define MACREG_INT_CODE_MESH_AUTO_STARTED 35
> #define MACREG_INT_CODE_FIRMWARE_READY 48
>
> +
> +/* 802.11-related definitions */
> +
> +/* TxPD descriptor */
> +struct txpd {
> + /* union to cope up with later FW revisions */
> + union {
> + /* Current Tx packet status */
> + __le32 tx_status;
> + struct {
> + /* BSS type: client, AP, etc. */
> + u8 bss_type;
> + /* BSS number */
> + u8 bss_num;
> + /* Reserved */
> + __le16 reserved;
> + } bss;
> + } u;
> + /* Tx control */
> + __le32 tx_control;
> + __le32 tx_packet_location;
> + /* Tx packet length */
> + __le16 tx_packet_length;
> + /* 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 (units = 2ms) */
> + u8 pktdelay_2ms;
> + /* reserved */
> + u8 reserved1;
> +} __attribute__ ((packed));
> +
> +/* RxPD Descriptor */
> +struct rxpd {
> + /* union to cope up with later FW revisions */
> + union {
> + /* Current Rx packet status */
> + __le16 status;
> + struct {
> + /* BSS type: client, AP, etc. */
> + u8 bss_type;
> + /* BSS number */
> + u8 bss_num;
> + } __attribute__ ((packed)) bss;
> + } __attribute__ ((packed)) u;
> +
> + /* SNR */
> + u8 snr;
> +
> + /* Tx control */
> + u8 rx_control;
> +
> + /* Pkt length */
> + __le16 pkt_len;
> +
> + /* Noise Floor */
> + u8 nf;
> +
> + /* Rx Packet Rate */
> + u8 rx_rate;
> +
> + /* Pkt addr */
> + __le32 pkt_ptr;
> +
> + /* Next Rx RxPD addr */
> + __le32 next_rxpd_ptr;
> +
> + /* Pkt Priority */
> + u8 priority;
> + u8 reserved[3];
> +} __attribute__ ((packed));
> +
> +struct cmd_header {
> + __le16 command;
> + __le16 size;
> + __le16 seqnum;
> + __le16 result;
> +} __attribute__ ((packed));
> +
> +struct cmd_ctrl_node {
> + struct list_head list;
> + int result;
> + /* command response */
> + int (*callback)(struct lbs_private *,
> + unsigned long,
> + struct cmd_header *);
> + unsigned long callback_arg;
> + /* command data */
> + struct cmd_header *cmdbuf;
> + /* wait queue */
> + u16 cmdwaitqwoken;
> + wait_queue_head_t cmdwait_q;
> +};
> +
> +/* Generic structure to hold all key types. */
> +struct enc_key {
> + u16 len;
> + u16 flags; /* KEY_INFO_* from defs.h */
> + u16 type; /* KEY_TYPE_* from defs.h */
> + u8 key[32];
> +};
> +
> +/* lbs_offset_value */
> +struct lbs_offset_value {
> + u32 offset;
> + u32 value;
> +} __attribute__ ((packed));
> +
> +/* Define general data structure */
> +/* cmd_DS_GEN */
> +struct cmd_ds_gen {
> + __le16 command;
> + __le16 size;
> + __le16 seqnum;
> + __le16 result;
> + void *cmdresp[0];
> +} __attribute__ ((packed));
> +
> +#define S_DS_GEN sizeof(struct cmd_ds_gen)
> +
> +
> +/*
> + * Define data structure for CMD_GET_HW_SPEC
> + * This structure defines the response for the GET_HW_SPEC command
> + */
> +struct cmd_ds_get_hw_spec {
> + struct cmd_header hdr;
> +
> + /* HW Interface version number */
> + __le16 hwifversion;
> + /* HW version number */
> + __le16 version;
> + /* Max number of TxPD FW can handle */
> + __le16 nr_txpd;
> + /* Max no of Multicast address */
> + __le16 nr_mcast_adr;
> + /* MAC address */
> + u8 permanentaddr[6];
> +
> + /* region Code */
> + __le16 regioncode;
> +
> + /* Number of antenna used */
> + __le16 nr_antenna;
> +
> + /* FW release number, example 0x01030304 = 2.3.4p1 */
> + __le32 fwrelease;
> +
> + /* Base Address of TxPD queue */
> + __le32 wcb_base;
> + /* Read Pointer of RxPd queue */
> + __le32 rxpd_rdptr;
> +
> + /* Write Pointer of RxPd queue */
> + __le32 rxpd_wrptr;
> +
> + /*FW/HW capability */
> + __le32 fwcapinfo;
> +} __attribute__ ((packed));
> +
> +struct cmd_ds_802_11_subscribe_event {
> + struct cmd_header hdr;
> +
> + __le16 action;
> + __le16 events;
> +
> + /* 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.
> + */
> + uint8_t tlv[128];
> +} __attribute__ ((packed));
> +
> +/*
> + * This scan handle Country Information IE(802.11d compliant)
> + * Define data structure for CMD_802_11_SCAN
> + */
> +struct cmd_ds_802_11_scan {
> + struct cmd_header hdr;
> +
> + uint8_t bsstype;
> + uint8_t bssid[ETH_ALEN];
> + uint8_t tlvbuffer[0];
> +} __attribute__ ((packed));
> +
> +struct cmd_ds_802_11_scan_rsp {
> + struct cmd_header hdr;
> +
> + __le16 bssdescriptsize;
> + uint8_t nr_sets;
> + uint8_t bssdesc_and_tlvbuffer[0];
> +} __attribute__ ((packed));
> +
> +struct cmd_ds_802_11_get_log {
> + struct cmd_header hdr;
> +
> + __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;
> +} __attribute__ ((packed));
> +
> +struct cmd_ds_mac_control {
> + struct cmd_header hdr;
> + __le16 action;
> + u16 reserved;
> +} __attribute__ ((packed));
> +
> +struct cmd_ds_mac_multicast_adr {
> + struct cmd_header hdr;
> + __le16 action;
> + __le16 nr_of_adrs;
> + u8 maclist[ETH_ALEN * MRVDRV_MAX_MULTICAST_LIST_SIZE];
> +} __attribute__ ((packed));
> +
> +struct cmd_ds_802_11_authenticate {
> + struct cmd_header hdr;
> +
> + u8 bssid[ETH_ALEN];
> + u8 authtype;
> + u8 reserved[10];
> +} __attribute__ ((packed));
> +
> +struct cmd_ds_802_11_deauthenticate {
> + struct cmd_header hdr;
> +
> + u8 macaddr[ETH_ALEN];
> + __le16 reasoncode;
> +} __attribute__ ((packed));
> +
> +struct cmd_ds_802_11_associate {
> + struct cmd_header hdr;
> +
> + u8 bssid[6];
> + __le16 capability;
> + __le16 listeninterval;
> + __le16 bcnperiod;
> + u8 dtimperiod;
> + u8 iebuf[512]; /* Enough for required and most optional IEs */
> +} __attribute__ ((packed));
> +
> +struct cmd_ds_802_11_associate_response {
> + struct cmd_header hdr;
> +
> + __le16 capability;
> + __le16 statuscode;
> + __le16 aid;
> + u8 iebuf[512];
> +} __attribute__ ((packed));
> +
> +struct cmd_ds_802_11_set_wep {
> + struct cmd_header hdr;
> +
> + /* ACT_ADD, ACT_REMOVE or ACT_ENABLE */
> + __le16 action;
> +
> + /* key Index selected for Tx */
> + __le16 keyindex;
> +
> + /* 40, 128bit or TXWEP */
> + uint8_t keytype[4];
> + uint8_t keymaterial[4][16];
> +} __attribute__ ((packed));
> +
> +struct cmd_ds_802_11_snmp_mib {
> + struct cmd_header hdr;
> +
> + __le16 action;
> + __le16 oid;
> + __le16 bufsize;
> + u8 value[128];
> +} __attribute__ ((packed));
> +
> +struct cmd_ds_mac_reg_access {
> + __le16 action;
> + __le16 offset;
> + __le32 value;
> +} __attribute__ ((packed));
> +
> +struct cmd_ds_bbp_reg_access {
> + __le16 action;
> + __le16 offset;
> + u8 value;
> + u8 reserved[3];
> +} __attribute__ ((packed));
> +
> +struct cmd_ds_rf_reg_access {
> + __le16 action;
> + __le16 offset;
> + u8 value;
> + u8 reserved[3];
> +} __attribute__ ((packed));
> +
> +struct cmd_ds_802_11_radio_control {
> + struct cmd_header hdr;
> +
> + __le16 action;
> + __le16 control;
> +} __attribute__ ((packed));
> +
> +struct cmd_ds_802_11_beacon_control {
> + __le16 action;
> + __le16 beacon_enable;
> + __le16 beacon_period;
> +} __attribute__ ((packed));
> +
> +struct cmd_ds_802_11_sleep_params {
> + struct cmd_header hdr;
> +
> + /* ACT_GET/ACT_SET */
> + __le16 action;
> +
> + /* Sleep clock error in ppm */
> + __le16 error;
> +
> + /* Wakeup offset in usec */
> + __le16 offset;
> +
> + /* Clock stabilization time in usec */
> + __le16 stabletime;
> +
> + /* control periodic calibration */
> + uint8_t calcontrol;
> +
> + /* control the use of external sleep clock */
> + uint8_t externalsleepclk;
> +
> + /* reserved field, should be set to zero */
> + __le16 reserved;
> +} __attribute__ ((packed));
> +
> +struct cmd_ds_802_11_inactivity_timeout {
> + struct cmd_header hdr;
> +
> + /* ACT_GET/ACT_SET */
> + __le16 action;
> +
> + /* Inactivity timeout in msec */
> + __le16 timeout;
> +} __attribute__ ((packed));
> +
> +struct cmd_ds_802_11_rf_channel {
> + struct cmd_header hdr;
> +
> + __le16 action;
> + __le16 channel;
> + __le16 rftype; /* unused */
> + __le16 reserved; /* unused */
> + u8 channellist[32]; /* unused */
> +} __attribute__ ((packed));
> +
> +struct cmd_ds_802_11_rssi {
> + /* weighting factor */
> + __le16 N;
> +
> + __le16 reserved_0;
> + __le16 reserved_1;
> + __le16 reserved_2;
> +} __attribute__ ((packed));
> +
> +struct cmd_ds_802_11_rssi_rsp {
> + __le16 SNR;
> + __le16 noisefloor;
> + __le16 avgSNR;
> + __le16 avgnoisefloor;
> +} __attribute__ ((packed));
> +
> +struct cmd_ds_802_11_mac_address {
> + struct cmd_header hdr;
> +
> + __le16 action;
> + u8 macadd[ETH_ALEN];
> +} __attribute__ ((packed));
> +
> +struct cmd_ds_802_11_rf_tx_power {
> + struct cmd_header hdr;
> +
> + __le16 action;
> + __le16 curlevel;
> + s8 maxlevel;
> + s8 minlevel;
> +} __attribute__ ((packed));
> +
> +struct cmd_ds_802_11_monitor_mode {
> + __le16 action;
> + __le16 mode;
> +} __attribute__ ((packed));
> +
> +struct cmd_ds_set_boot2_ver {
> + struct cmd_header hdr;
> +
> + __le16 action;
> + __le16 version;
> +} __attribute__ ((packed));
> +
> +struct cmd_ds_802_11_fw_wake_method {
> + struct cmd_header hdr;
> +
> + __le16 action;
> + __le16 method;
> +} __attribute__ ((packed));
> +
> +struct cmd_ds_802_11_ps_mode {
> + __le16 action;
> + __le16 nullpktinterval;
> + __le16 multipledtim;
> + __le16 reserved;
> + __le16 locallisteninterval;
> +} __attribute__ ((packed));
> +
> +struct cmd_confirm_sleep {
> + struct cmd_header hdr;
> +
> + __le16 action;
> + __le16 nullpktinterval;
> + __le16 multipledtim;
> + __le16 reserved;
> + __le16 locallisteninterval;
> +} __attribute__ ((packed));
> +
> +struct cmd_ds_802_11_data_rate {
> + struct cmd_header hdr;
> +
> + __le16 action;
> + __le16 reserved;
> + u8 rates[MAX_RATES];
> +} __attribute__ ((packed));
> +
> +struct cmd_ds_802_11_rate_adapt_rateset {
> + struct cmd_header hdr;
> + __le16 action;
> + __le16 enablehwauto;
> + __le16 bitmap;
> +} __attribute__ ((packed));
> +
> +struct cmd_ds_802_11_ad_hoc_start {
> + struct cmd_header hdr;
> +
> + u8 ssid[IW_ESSID_MAX_SIZE];
> + u8 bsstype;
> + __le16 beaconperiod;
> + u8 dtimperiod; /* Reserved on v9 and later */
> + struct ieee_ie_ibss_param_set ibss;
> + u8 reserved1[4];
> + struct ieee_ie_ds_param_set ds;
> + u8 reserved2[4];
> + __le16 probedelay; /* Reserved on v9 and later */
> + __le16 capability;
> + u8 rates[MAX_RATES];
> + u8 tlv_memory_size_pad[100];
> +} __attribute__ ((packed));
> +
> +struct cmd_ds_802_11_ad_hoc_result {
> + struct cmd_header hdr;
> +
> + u8 pad[3];
> + u8 bssid[ETH_ALEN];
> +} __attribute__ ((packed));
> +
> +struct adhoc_bssdesc {
> + u8 bssid[ETH_ALEN];
> + u8 ssid[IW_ESSID_MAX_SIZE];
> + u8 type;
> + __le16 beaconperiod;
> + u8 dtimperiod;
> + __le64 timestamp;
> + __le64 localtime;
> + struct ieee_ie_ds_param_set ds;
> + u8 reserved1[4];
> + struct ieee_ie_ibss_param_set ibss;
> + u8 reserved2[4];
> + __le16 capability;
> + u8 rates[MAX_RATES];
> +
> + /* 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 {
> + struct cmd_header hdr;
> +
> + struct adhoc_bssdesc bss;
> + __le16 failtimeout; /* Reserved on v9 and later */
> + __le16 probedelay; /* Reserved on v9 and later */
> +} __attribute__ ((packed));
> +
> +struct cmd_ds_802_11_ad_hoc_stop {
> + struct cmd_header hdr;
> +} __attribute__ ((packed));
> +
> +struct cmd_ds_802_11_enable_rsn {
> + struct cmd_header hdr;
> +
> + __le16 action;
> + __le16 enable;
> +} __attribute__ ((packed));
> +
> +struct MrvlIEtype_keyParamSet {
> + /* type ID */
> + __le16 type;
> +
> + /* length of Payload */
> + __le16 length;
> +
> + /* type of key: WEP=0, TKIP=1, AES=2 */
> + __le16 keytypeid;
> +
> + /* key control Info specific to a keytypeid */
> + __le16 keyinfo;
> +
> + /* length of key */
> + __le16 keylen;
> +
> + /* key material of size keylen */
> + u8 key[32];
> +} __attribute__ ((packed));
> +
> +#define MAX_WOL_RULES 16
> +
> +struct host_wol_rule {
> + uint8_t rule_no;
> + uint8_t rule_ops;
> + __le16 sig_offset;
> + __le16 sig_length;
> + __le16 reserve;
> + __be32 sig_mask;
> + __be32 signature;
> +} __attribute__ ((packed));
> +
> +struct wol_config {
> + uint8_t action;
> + uint8_t pattern;
> + uint8_t no_rules_in_cmd;
> + uint8_t result;
> + struct host_wol_rule rule[MAX_WOL_RULES];
> +} __attribute__ ((packed));
> +
> +struct cmd_ds_host_sleep {
> + struct cmd_header hdr;
> + __le32 criteria;
> + uint8_t gpio;
> + uint16_t gap;
> + struct wol_config wol_conf;
> +} __attribute__ ((packed));
> +
> +
> +
> +struct cmd_ds_802_11_key_material {
> + struct cmd_header hdr;
> +
> + __le16 action;
> + struct MrvlIEtype_keyParamSet keyParamSet[2];
> +} __attribute__ ((packed));
> +
> +struct cmd_ds_802_11_eeprom_access {
> + struct cmd_header hdr;
> + __le16 action;
> + __le16 offset;
> + __le16 len;
> + /* firmware says it returns a maximum of 20 bytes */
> +#define LBS_EEPROM_READ_LEN 20
> + u8 value[LBS_EEPROM_READ_LEN];
> +} __attribute__ ((packed));
> +
> +struct cmd_ds_802_11_tpc_cfg {
> + struct cmd_header hdr;
> +
> + __le16 action;
> + uint8_t enable;
> + int8_t P0;
> + int8_t P1;
> + int8_t P2;
> + uint8_t usesnr;
> +} __attribute__ ((packed));
> +
> +
> +struct cmd_ds_802_11_pa_cfg {
> + struct cmd_header hdr;
> +
> + __le16 action;
> + uint8_t enable;
> + int8_t P0;
> + int8_t P1;
> + int8_t P2;
> +} __attribute__ ((packed));
> +
> +
> +struct cmd_ds_802_11_led_ctrl {
> + __le16 action;
> + __le16 numled;
> + u8 data[256];
> +} __attribute__ ((packed));
> +
> +struct cmd_ds_802_11_afc {
> + __le16 afc_auto;
> + union {
> + struct {
> + __le16 threshold;
> + __le16 period;
> + };
> + struct {
> + __le16 timing_offset; /* signed */
> + __le16 carrier_offset; /* signed */
> + };
> + };
> +} __attribute__ ((packed));
> +
> +struct cmd_tx_rate_query {
> + __le16 txrate;
> +} __attribute__ ((packed));
> +
> +struct cmd_ds_get_tsf {
> + __le64 tsfvalue;
> +} __attribute__ ((packed));
> +
> +struct cmd_ds_bt_access {
> + __le16 action;
> + __le32 id;
> + u8 addr1[ETH_ALEN];
> + u8 addr2[ETH_ALEN];
> +} __attribute__ ((packed));
> +
> +struct cmd_ds_fwt_access {
> + __le16 action;
> + __le32 id;
> + u8 valid;
> + u8 da[ETH_ALEN];
> + u8 dir;
> + u8 ra[ETH_ALEN];
> + __le32 ssn;
> + __le32 dsn;
> + __le32 metric;
> + u8 rate;
> + u8 hopcount;
> + u8 ttl;
> + __le32 expiration;
> + u8 sleepmode;
> + __le32 snr;
> + __le32 references;
> + u8 prec[ETH_ALEN];
> +} __attribute__ ((packed));
> +
> +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));
> +
> +struct cmd_ds_mesh_access {
> + struct cmd_header hdr;
> +
> + __le16 action;
> + __le32 data[32]; /* last position reserved */
> +} __attribute__ ((packed));
> +
> +/* Number of stats counters returned by the firmware */
> +#define MESH_STATS_NUM 8
> +
> +struct cmd_ds_command {
> + /* command header */
> + __le16 command;
> + __le16 size;
> + __le16 seqnum;
> + __le16 result;
> +
> + /* command Body */
> + union {
> + struct cmd_ds_802_11_ps_mode psmode;
> + struct cmd_ds_802_11_monitor_mode monitor;
> + struct cmd_ds_802_11_rssi rssi;
> + struct cmd_ds_802_11_rssi_rsp rssirsp;
> + 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_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_afc afc;
> + struct cmd_ds_802_11_led_ctrl ledgpio;
> +
> + struct cmd_ds_bt_access bt;
> + struct cmd_ds_fwt_access fwt;
> + struct cmd_ds_get_tsf gettsf;
> + struct cmd_ds_802_11_beacon_control bcn_ctrl;
> + } params;
> +} __attribute__ ((packed));
> +
> #endif
> --- linux-wl.orig/drivers/net/wireless/libertas/hostcmd.h
> +++ /dev/null
> @@ -1,800 +0,0 @@
> -/*
> - * This file contains the function prototypes, data structure
> - * and defines for all the host/station commands
> - */
> -#ifndef _LBS_HOSTCMD_H
> -#define _LBS_HOSTCMD_H
> -
> -#include <linux/wireless.h>
> -#include "11d.h"
> -#include "types.h"
> -
> -/* 802.11-related definitions */
> -
> -/* TxPD descriptor */
> -struct txpd {
> - /* union to cope up with later FW revisions */
> - union {
> - /* Current Tx packet status */
> - __le32 tx_status;
> - struct {
> - /* BSS type: client, AP, etc. */
> - u8 bss_type;
> - /* BSS number */
> - u8 bss_num;
> - /* Reserved */
> - __le16 reserved;
> - } bss;
> - } u;
> - /* Tx control */
> - __le32 tx_control;
> - __le32 tx_packet_location;
> - /* Tx packet length */
> - __le16 tx_packet_length;
> - /* 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;
> -} __attribute__ ((packed));
> -
> -/* RxPD Descriptor */
> -struct rxpd {
> - /* union to cope up with later FW revisions */
> - union {
> - /* Current Rx packet status */
> - __le16 status;
> - struct {
> - /* BSS type: client, AP, etc. */
> - u8 bss_type;
> - /* BSS number */
> - u8 bss_num;
> - } __attribute__ ((packed)) bss;
> - } __attribute__ ((packed)) u;
> -
> - /* SNR */
> - u8 snr;
> -
> - /* Tx control */
> - u8 rx_control;
> -
> - /* Pkt length */
> - __le16 pkt_len;
> -
> - /* Noise Floor */
> - u8 nf;
> -
> - /* Rx Packet Rate */
> - u8 rx_rate;
> -
> - /* Pkt addr */
> - __le32 pkt_ptr;
> -
> - /* Next Rx RxPD addr */
> - __le32 next_rxpd_ptr;
> -
> - /* Pkt Priority */
> - u8 priority;
> - u8 reserved[3];
> -} __attribute__ ((packed));
> -
> -struct cmd_header {
> - __le16 command;
> - __le16 size;
> - __le16 seqnum;
> - __le16 result;
> -} __attribute__ ((packed));
> -
> -struct cmd_ctrl_node {
> - struct list_head list;
> - int result;
> - /* command response */
> - int (*callback)(struct lbs_private *, unsigned long, struct cmd_header *);
> - unsigned long callback_arg;
> - /* command data */
> - struct cmd_header *cmdbuf;
> - /* wait queue */
> - u16 cmdwaitqwoken;
> - wait_queue_head_t cmdwait_q;
> -};
> -
> -/* Generic structure to hold all key types. */
> -struct enc_key {
> - u16 len;
> - u16 flags; /* KEY_INFO_* from defs.h */
> - u16 type; /* KEY_TYPE_* from defs.h */
> - u8 key[32];
> -};
> -
> -/* lbs_offset_value */
> -struct lbs_offset_value {
> - u32 offset;
> - u32 value;
> -} __attribute__ ((packed));
> -
> -/* Define general data structure */
> -/* cmd_DS_GEN */
> -struct cmd_ds_gen {
> - __le16 command;
> - __le16 size;
> - __le16 seqnum;
> - __le16 result;
> - void *cmdresp[0];
> -} __attribute__ ((packed));
> -
> -#define S_DS_GEN sizeof(struct cmd_ds_gen)
> -
> -
> -/*
> - * Define data structure for CMD_GET_HW_SPEC
> - * This structure defines the response for the GET_HW_SPEC command
> - */
> -struct cmd_ds_get_hw_spec {
> - struct cmd_header hdr;
> -
> - /* HW Interface version number */
> - __le16 hwifversion;
> - /* HW version number */
> - __le16 version;
> - /* Max number of TxPD FW can handle */
> - __le16 nr_txpd;
> - /* Max no of Multicast address */
> - __le16 nr_mcast_adr;
> - /* MAC address */
> - u8 permanentaddr[6];
> -
> - /* region Code */
> - __le16 regioncode;
> -
> - /* Number of antenna used */
> - __le16 nr_antenna;
> -
> - /* FW release number, example 0x01030304 = 2.3.4p1 */
> - __le32 fwrelease;
> -
> - /* Base Address of TxPD queue */
> - __le32 wcb_base;
> - /* Read Pointer of RxPd queue */
> - __le32 rxpd_rdptr;
> -
> - /* Write Pointer of RxPd queue */
> - __le32 rxpd_wrptr;
> -
> - /*FW/HW capability */
> - __le32 fwcapinfo;
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_802_11_subscribe_event {
> - struct cmd_header hdr;
> -
> - __le16 action;
> - __le16 events;
> -
> - /* 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.
> - */
> - uint8_t tlv[128];
> -} __attribute__ ((packed));
> -
> -/*
> - * This scan handle Country Information IE(802.11d compliant)
> - * Define data structure for CMD_802_11_SCAN
> - */
> -struct cmd_ds_802_11_scan {
> - struct cmd_header hdr;
> -
> - uint8_t bsstype;
> - uint8_t bssid[ETH_ALEN];
> - uint8_t tlvbuffer[0];
> -#if 0
> - mrvlietypes_ssidparamset_t ssidParamSet;
> - mrvlietypes_chanlistparamset_t ChanListParamSet;
> - mrvlietypes_ratesparamset_t OpRateSet;
> -#endif
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_802_11_scan_rsp {
> - struct cmd_header hdr;
> -
> - __le16 bssdescriptsize;
> - uint8_t nr_sets;
> - uint8_t bssdesc_and_tlvbuffer[0];
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_802_11_get_log {
> - struct cmd_header hdr;
> -
> - __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;
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_mac_control {
> - struct cmd_header hdr;
> - __le16 action;
> - u16 reserved;
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_mac_multicast_adr {
> - struct cmd_header hdr;
> - __le16 action;
> - __le16 nr_of_adrs;
> - u8 maclist[ETH_ALEN * MRVDRV_MAX_MULTICAST_LIST_SIZE];
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_gspi_bus_config {
> - struct cmd_header hdr;
> - __le16 action;
> - __le16 bus_delay_mode;
> - __le16 host_time_delay_to_read_port;
> - __le16 host_time_delay_to_read_register;
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_802_11_authenticate {
> - struct cmd_header hdr;
> -
> - u8 bssid[ETH_ALEN];
> - u8 authtype;
> - u8 reserved[10];
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_802_11_deauthenticate {
> - struct cmd_header hdr;
> -
> - u8 macaddr[ETH_ALEN];
> - __le16 reasoncode;
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_802_11_associate {
> - struct cmd_header hdr;
> -
> - u8 bssid[6];
> - __le16 capability;
> - __le16 listeninterval;
> - __le16 bcnperiod;
> - u8 dtimperiod;
> - u8 iebuf[512]; /* Enough for required and most optional IEs */
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_802_11_associate_response {
> - struct cmd_header hdr;
> -
> - __le16 capability;
> - __le16 statuscode;
> - __le16 aid;
> - u8 iebuf[512];
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_802_11_set_wep {
> - struct cmd_header hdr;
> -
> - /* ACT_ADD, ACT_REMOVE or ACT_ENABLE */
> - __le16 action;
> -
> - /* key Index selected for Tx */
> - __le16 keyindex;
> -
> - /* 40, 128bit or TXWEP */
> - uint8_t keytype[4];
> - uint8_t keymaterial[4][16];
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_802_3_get_stat {
> - __le32 xmitok;
> - __le32 rcvok;
> - __le32 xmiterror;
> - __le32 rcverror;
> - __le32 rcvnobuffer;
> - __le32 rcvcrcerror;
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_802_11_get_stat {
> - __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;
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_802_11_snmp_mib {
> - struct cmd_header hdr;
> -
> - __le16 action;
> - __le16 oid;
> - __le16 bufsize;
> - u8 value[128];
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_mac_reg_map {
> - __le16 buffersize;
> - u8 regmap[128];
> - __le16 reserved;
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_bbp_reg_map {
> - __le16 buffersize;
> - u8 regmap[128];
> - __le16 reserved;
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_rf_reg_map {
> - __le16 buffersize;
> - u8 regmap[64];
> - __le16 reserved;
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_mac_reg_access {
> - __le16 action;
> - __le16 offset;
> - __le32 value;
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_bbp_reg_access {
> - __le16 action;
> - __le16 offset;
> - u8 value;
> - u8 reserved[3];
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_rf_reg_access {
> - __le16 action;
> - __le16 offset;
> - u8 value;
> - u8 reserved[3];
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_802_11_radio_control {
> - struct cmd_header hdr;
> -
> - __le16 action;
> - __le16 control;
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_802_11_beacon_control {
> - __le16 action;
> - __le16 beacon_enable;
> - __le16 beacon_period;
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_802_11_sleep_params {
> - struct cmd_header hdr;
> -
> - /* ACT_GET/ACT_SET */
> - __le16 action;
> -
> - /* Sleep clock error in ppm */
> - __le16 error;
> -
> - /* Wakeup offset in usec */
> - __le16 offset;
> -
> - /* Clock stabilization time in usec */
> - __le16 stabletime;
> -
> - /* control periodic calibration */
> - uint8_t calcontrol;
> -
> - /* control the use of external sleep clock */
> - uint8_t externalsleepclk;
> -
> - /* reserved field, should be set to zero */
> - __le16 reserved;
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_802_11_inactivity_timeout {
> - struct cmd_header hdr;
> -
> - /* ACT_GET/ACT_SET */
> - __le16 action;
> -
> - /* Inactivity timeout in msec */
> - __le16 timeout;
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_802_11_rf_channel {
> - struct cmd_header hdr;
> -
> - __le16 action;
> - __le16 channel;
> - __le16 rftype; /* unused */
> - __le16 reserved; /* unused */
> - u8 channellist[32]; /* unused */
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_802_11_rssi {
> - /* weighting factor */
> - __le16 N;
> -
> - __le16 reserved_0;
> - __le16 reserved_1;
> - __le16 reserved_2;
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_802_11_rssi_rsp {
> - __le16 SNR;
> - __le16 noisefloor;
> - __le16 avgSNR;
> - __le16 avgnoisefloor;
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_802_11_mac_address {
> - struct cmd_header hdr;
> -
> - __le16 action;
> - u8 macadd[ETH_ALEN];
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_802_11_rf_tx_power {
> - struct cmd_header hdr;
> -
> - __le16 action;
> - __le16 curlevel;
> - s8 maxlevel;
> - s8 minlevel;
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_802_11_rf_antenna {
> - __le16 action;
> -
> - /* Number of antennas or 0xffff(diversity) */
> - __le16 antennamode;
> -
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_802_11_monitor_mode {
> - __le16 action;
> - __le16 mode;
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_set_boot2_ver {
> - struct cmd_header hdr;
> -
> - __le16 action;
> - __le16 version;
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_802_11_fw_wake_method {
> - struct cmd_header hdr;
> -
> - __le16 action;
> - __le16 method;
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_802_11_sleep_period {
> - struct cmd_header hdr;
> -
> - __le16 action;
> - __le16 period;
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_802_11_ps_mode {
> - __le16 action;
> - __le16 nullpktinterval;
> - __le16 multipledtim;
> - __le16 reserved;
> - __le16 locallisteninterval;
> -} __attribute__ ((packed));
> -
> -struct cmd_confirm_sleep {
> - struct cmd_header hdr;
> -
> - __le16 action;
> - __le16 nullpktinterval;
> - __le16 multipledtim;
> - __le16 reserved;
> - __le16 locallisteninterval;
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_802_11_data_rate {
> - struct cmd_header hdr;
> -
> - __le16 action;
> - __le16 reserved;
> - u8 rates[MAX_RATES];
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_802_11_rate_adapt_rateset {
> - struct cmd_header hdr;
> - __le16 action;
> - __le16 enablehwauto;
> - __le16 bitmap;
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_802_11_ad_hoc_start {
> - struct cmd_header hdr;
> -
> - u8 ssid[IW_ESSID_MAX_SIZE];
> - u8 bsstype;
> - __le16 beaconperiod;
> - u8 dtimperiod; /* Reserved on v9 and later */
> - struct ieee_ie_ibss_param_set ibss;
> - u8 reserved1[4];
> - struct ieee_ie_ds_param_set ds;
> - u8 reserved2[4];
> - __le16 probedelay; /* Reserved on v9 and later */
> - __le16 capability;
> - u8 rates[MAX_RATES];
> - u8 tlv_memory_size_pad[100];
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_802_11_ad_hoc_result {
> - struct cmd_header hdr;
> -
> - u8 pad[3];
> - u8 bssid[ETH_ALEN];
> -} __attribute__ ((packed));
> -
> -struct adhoc_bssdesc {
> - u8 bssid[ETH_ALEN];
> - u8 ssid[IW_ESSID_MAX_SIZE];
> - u8 type;
> - __le16 beaconperiod;
> - u8 dtimperiod;
> - __le64 timestamp;
> - __le64 localtime;
> - struct ieee_ie_ds_param_set ds;
> - u8 reserved1[4];
> - struct ieee_ie_ibss_param_set ibss;
> - u8 reserved2[4];
> - __le16 capability;
> - u8 rates[MAX_RATES];
> -
> - /* 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 {
> - struct cmd_header hdr;
> -
> - struct adhoc_bssdesc bss;
> - __le16 failtimeout; /* Reserved on v9 and later */
> - __le16 probedelay; /* Reserved on v9 and later */
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_802_11_ad_hoc_stop {
> - struct cmd_header hdr;
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_802_11_enable_rsn {
> - struct cmd_header hdr;
> -
> - __le16 action;
> - __le16 enable;
> -} __attribute__ ((packed));
> -
> -struct MrvlIEtype_keyParamSet {
> - /* type ID */
> - __le16 type;
> -
> - /* length of Payload */
> - __le16 length;
> -
> - /* type of key: WEP=0, TKIP=1, AES=2 */
> - __le16 keytypeid;
> -
> - /* key control Info specific to a keytypeid */
> - __le16 keyinfo;
> -
> - /* length of key */
> - __le16 keylen;
> -
> - /* key material of size keylen */
> - u8 key[32];
> -} __attribute__ ((packed));
> -
> -#define MAX_WOL_RULES 16
> -
> -struct host_wol_rule {
> - uint8_t rule_no;
> - uint8_t rule_ops;
> - __le16 sig_offset;
> - __le16 sig_length;
> - __le16 reserve;
> - __be32 sig_mask;
> - __be32 signature;
> -} __attribute__ ((packed));
> -
> -struct wol_config {
> - uint8_t action;
> - uint8_t pattern;
> - uint8_t no_rules_in_cmd;
> - uint8_t result;
> - struct host_wol_rule rule[MAX_WOL_RULES];
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_host_sleep {
> - struct cmd_header hdr;
> - __le32 criteria;
> - uint8_t gpio;
> - uint16_t gap;
> - struct wol_config wol_conf;
> -} __attribute__ ((packed));
> -
> -
> -
> -struct cmd_ds_802_11_key_material {
> - struct cmd_header hdr;
> -
> - __le16 action;
> - struct MrvlIEtype_keyParamSet keyParamSet[2];
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_802_11_eeprom_access {
> - struct cmd_header hdr;
> - __le16 action;
> - __le16 offset;
> - __le16 len;
> - /* firmware says it returns a maximum of 20 bytes */
> -#define LBS_EEPROM_READ_LEN 20
> - u8 value[LBS_EEPROM_READ_LEN];
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_802_11_tpc_cfg {
> - struct cmd_header hdr;
> -
> - __le16 action;
> - uint8_t enable;
> - int8_t P0;
> - int8_t P1;
> - int8_t P2;
> - uint8_t usesnr;
> -} __attribute__ ((packed));
> -
> -
> -struct cmd_ds_802_11_pa_cfg {
> - struct cmd_header hdr;
> -
> - __le16 action;
> - uint8_t enable;
> - int8_t P0;
> - int8_t P1;
> - int8_t P2;
> -} __attribute__ ((packed));
> -
> -
> -struct cmd_ds_802_11_led_ctrl {
> - __le16 action;
> - __le16 numled;
> - u8 data[256];
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_802_11_afc {
> - __le16 afc_auto;
> - union {
> - struct {
> - __le16 threshold;
> - __le16 period;
> - };
> - struct {
> - __le16 timing_offset; /* signed */
> - __le16 carrier_offset; /* signed */
> - };
> - };
> -} __attribute__ ((packed));
> -
> -struct cmd_tx_rate_query {
> - __le16 txrate;
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_get_tsf {
> - __le64 tsfvalue;
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_bt_access {
> - __le16 action;
> - __le32 id;
> - u8 addr1[ETH_ALEN];
> - u8 addr2[ETH_ALEN];
> -} __attribute__ ((packed));
> -
> -struct cmd_ds_fwt_access {
> - __le16 action;
> - __le32 id;
> - u8 valid;
> - u8 da[ETH_ALEN];
> - u8 dir;
> - u8 ra[ETH_ALEN];
> - __le32 ssn;
> - __le32 dsn;
> - __le32 metric;
> - u8 rate;
> - u8 hopcount;
> - u8 ttl;
> - __le32 expiration;
> - u8 sleepmode;
> - __le32 snr;
> - __le32 references;
> - u8 prec[ETH_ALEN];
> -} __attribute__ ((packed));
> -
> -
> -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));
> -
> -
> -struct cmd_ds_mesh_access {
> - struct cmd_header hdr;
> -
> - __le16 action;
> - __le32 data[32]; /* last position reserved */
> -} __attribute__ ((packed));
> -
> -/* Number of stats counters returned by the firmware */
> -#define MESH_STATS_NUM 8
> -
> -struct cmd_ds_command {
> - /* command header */
> - __le16 command;
> - __le16 size;
> - __le16 seqnum;
> - __le16 result;
> -
> - /* command Body */
> - union {
> - struct cmd_ds_802_11_ps_mode psmode;
> - struct cmd_ds_802_11_get_stat gstat;
> - struct cmd_ds_802_3_get_stat gstat_8023;
> - struct cmd_ds_802_11_rf_antenna rant;
> - struct cmd_ds_802_11_monitor_mode monitor;
> - struct cmd_ds_802_11_rssi rssi;
> - struct cmd_ds_802_11_rssi_rsp rssirsp;
> - 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_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_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_beacon_control bcn_ctrl;
> - } params;
> -} __attribute__ ((packed));
> -
> -#endif
> --- linux-wl.orig/drivers/net/wireless/libertas/cmd.h
> +++ linux-wl/drivers/net/wireless/libertas/cmd.h
> @@ -3,7 +3,7 @@
> #ifndef _LBS_CMD_H_
> #define _LBS_CMD_H_
>
> -#include "hostcmd.h"
> +#include "host.h"
> #include "dev.h"
>
> /* lbs_cmd() infers the size of the buffer to copy data back into, from
> --- linux-wl.orig/drivers/net/wireless/libertas/cmd.c
> +++ linux-wl/drivers/net/wireless/libertas/cmd.c
> @@ -8,7 +8,6 @@
> #include <linux/kfifo.h>
> #include <linux/sched.h>
> #include "host.h"
> -#include "hostcmd.h"
> #include "decl.h"
> #include "defs.h"
> #include "dev.h"
> --- linux-wl.orig/drivers/net/wireless/libertas/dev.h
> +++ linux-wl/drivers/net/wireless/libertas/dev.h
> @@ -12,7 +12,7 @@
> #include <linux/debugfs.h>
>
> #include "defs.h"
> -#include "hostcmd.h"
> +#include "host.h"
>
> extern const struct ethtool_ops lbs_ethtool_ops;
>
> --- linux-wl.orig/drivers/net/wireless/libertas/rx.c
> +++ linux-wl/drivers/net/wireless/libertas/rx.c
> @@ -4,7 +4,7 @@
> #include <linux/etherdevice.h>
> #include <linux/types.h>
>
> -#include "hostcmd.h"
> +#include "host.h"
> #include "radiotap.h"
> #include "decl.h"
> #include "dev.h"
> --- linux-wl.orig/drivers/net/wireless/libertas/tx.c
> +++ linux-wl/drivers/net/wireless/libertas/tx.c
> @@ -5,7 +5,7 @@
> #include <linux/etherdevice.h>
> #include <linux/sched.h>
>
> -#include "hostcmd.h"
> +#include "host.h"
> #include "radiotap.h"
> #include "decl.h"
> #include "defs.h"
>
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2009-10-16 16:28 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2009-10-16 15:32 [PATCH] libertas: cleanup host.h and hostcmd.h Holger Schurig
2009-10-16 16:28 ` Dan Williams
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).