| /* |
| * Intel Wireless Multicomm 3200 WiFi driver |
| * |
| * Copyright (C) 2009 Intel Corporation. All rights reserved. |
| * |
| * Redistribution and use in source and binary forms, with or without |
| * modification, are permitted provided that the following conditions |
| * are met: |
| * |
| * * Redistributions of source code must retain the above copyright |
| * notice, this list of conditions and the following disclaimer. |
| * * Redistributions in binary form must reproduce the above copyright |
| * notice, this list of conditions and the following disclaimer in |
| * the documentation and/or other materials provided with the |
| * distribution. |
| * * Neither the name of Intel Corporation nor the names of its |
| * contributors may be used to endorse or promote products derived |
| * from this software without specific prior written permission. |
| * |
| * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
| * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
| * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
| * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |
| * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
| * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
| * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
| * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
| * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
| * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
| * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| * |
| * |
| * Intel Corporation <ilw@linux.intel.com> |
| * Samuel Ortiz <samuel.ortiz@intel.com> |
| * Zhu Yi <yi.zhu@intel.com> |
| * |
| */ |
| |
| #ifndef __IWM_COMMANDS_H__ |
| #define __IWM_COMMANDS_H__ |
| |
| #include <linux/ieee80211.h> |
| |
| #define IWM_BARKER_REBOOT_NOTIFICATION 0xF |
| #define IWM_ACK_BARKER_NOTIFICATION 0x10 |
| |
| /* UMAC commands */ |
| #define UMAC_RST_CTRL_FLG_LARC_CLK_EN 0x0001 |
| #define UMAC_RST_CTRL_FLG_LARC_RESET 0x0002 |
| #define UMAC_RST_CTRL_FLG_FUNC_RESET 0x0004 |
| #define UMAC_RST_CTRL_FLG_DEV_RESET 0x0008 |
| #define UMAC_RST_CTRL_FLG_WIFI_CORE_EN 0x0010 |
| #define UMAC_RST_CTRL_FLG_WIFI_LINK_EN 0x0040 |
| #define UMAC_RST_CTRL_FLG_WIFI_MLME_EN 0x0080 |
| #define UMAC_RST_CTRL_FLG_NVM_RELOAD 0x0100 |
| |
| struct iwm_umac_cmd_reset { |
| __le32 flags; |
| } __attribute__ ((packed)); |
| |
| #define UMAC_PARAM_TBL_ORD_FIX 0x0 |
| #define UMAC_PARAM_TBL_ORD_VAR 0x1 |
| #define UMAC_PARAM_TBL_CFG_FIX 0x2 |
| #define UMAC_PARAM_TBL_CFG_VAR 0x3 |
| #define UMAC_PARAM_TBL_BSS_TRK 0x4 |
| #define UMAC_PARAM_TBL_FA_CFG_FIX 0x5 |
| #define UMAC_PARAM_TBL_STA 0x6 |
| #define UMAC_PARAM_TBL_CHN 0x7 |
| #define UMAC_PARAM_TBL_STATISTICS 0x8 |
| |
| /* fast access table */ |
| enum { |
| CFG_FRAG_THRESHOLD = 0, |
| CFG_FRAME_RETRY_LIMIT, |
| CFG_OS_QUEUE_UTIL_TH, |
| CFG_RX_FILTER, |
| /* <-- LAST --> */ |
| FAST_ACCESS_CFG_TBL_FIX_LAST |
| }; |
| |
| /* fixed size table */ |
| enum { |
| CFG_POWER_INDEX = 0, |
| CFG_PM_LEGACY_RX_TIMEOUT, |
| CFG_PM_LEGACY_TX_TIMEOUT, |
| CFG_PM_CTRL_FLAGS, |
| CFG_PM_KEEP_ALIVE_IN_BEACONS, |
| CFG_BT_ON_THRESHOLD, |
| CFG_RTS_THRESHOLD, |
| CFG_CTS_TO_SELF, |
| CFG_COEX_MODE, |
| CFG_WIRELESS_MODE, |
| CFG_ASSOCIATION_TIMEOUT, |
| CFG_ROAM_TIMEOUT, |
| CFG_CAPABILITY_SUPPORTED_RATES, |
| CFG_SCAN_ALLOWED_UNASSOC_FLAGS, |
| CFG_SCAN_ALLOWED_MAIN_ASSOC_FLAGS, |
| CFG_SCAN_ALLOWED_PAN_ASSOC_FLAGS, |
| CFG_SCAN_INTERNAL_PERIODIC_ENABLED, |
| CFG_SCAN_IMM_INTERNAL_PERIODIC_SCAN_ON_INIT, |
| CFG_SCAN_DEFAULT_PERIODIC_FREQ_SEC, |
| CFG_SCAN_NUM_PASSIVE_CHAN_PER_PARTIAL_SCAN, |
| CFG_TLC_SUPPORTED_TX_HT_RATES, |
| CFG_TLC_SUPPORTED_TX_RATES, |
| CFG_TLC_VALID_ANTENNA, |
| CFG_TLC_SPATIAL_STREAM_SUPPORTED, |
| CFG_TLC_RETRY_PER_RATE, |
| CFG_TLC_RETRY_PER_HT_RATE, |
| CFG_TLC_FIXED_MCS, |
| CFG_TLC_CONTROL_FLAGS, |
| CFG_TLC_SR_MIN_FAIL, |
| CFG_TLC_SR_MIN_PASS, |
| CFG_TLC_HT_STAY_IN_COL_PASS_THRESH, |
| CFG_TLC_HT_STAY_IN_COL_FAIL_THRESH, |
| CFG_TLC_LEGACY_STAY_IN_COL_PASS_THRESH, |
| CFG_TLC_LEGACY_STAY_IN_COL_FAIL_THRESH, |
| CFG_TLC_HT_FLUSH_STATS_PACKETS, |
| CFG_TLC_LEGACY_FLUSH_STATS_PACKETS, |
| CFG_TLC_LEGACY_FLUSH_STATS_MS, |
| CFG_TLC_HT_FLUSH_STATS_MS, |
| CFG_TLC_STAY_IN_COL_TIME_OUT, |
| CFG_TLC_AGG_SHORT_LIM, |
| CFG_TLC_AGG_LONG_LIM, |
| CFG_TLC_HT_SR_NO_DECREASE, |
| CFG_TLC_LEGACY_SR_NO_DECREASE, |
| CFG_TLC_SR_FORCE_DECREASE, |
| CFG_TLC_SR_ALLOW_INCREASE, |
| CFG_TLC_AGG_SET_LONG, |
| CFG_TLC_AUTO_AGGREGATION, |
| CFG_TLC_AGG_THRESHOLD, |
| CFG_TLC_TID_LOAD_THRESHOLD, |
| CFG_TLC_BLOCK_ACK_TIMEOUT, |
| CFG_TLC_NO_BA_COUNTED_AS_ONE, |
| CFG_TLC_NUM_BA_STREAMS_ALLOWED, |
| CFG_TLC_NUM_BA_STREAMS_PRESENT, |
| CFG_TLC_RENEW_ADDBA_DELAY, |
| CFG_TLC_NUM_OF_MULTISEC_TO_COUN_LOAD, |
| CFG_TLC_IS_STABLE_IN_HT, |
| CFG_RLC_CHAIN_CTRL, |
| CFG_TRK_TABLE_OP_MODE, |
| CFG_TRK_TABLE_RSSI_THRESHOLD, |
| CFG_TX_PWR_TARGET, /* Used By xVT */ |
| CFG_TX_PWR_LIMIT_USR, |
| CFG_TX_PWR_LIMIT_BSS, /* 11d limit */ |
| CFG_TX_PWR_LIMIT_BSS_CONSTRAINT, /* 11h constraint */ |
| CFG_TX_PWR_MODE, |
| CFG_MLME_DBG_NOTIF_BLOCK, |
| CFG_BT_OFF_BECONS_INTERVALS, |
| CFG_BT_FRAG_DURATION, |
| |
| /* <-- LAST --> */ |
| CFG_TBL_FIX_LAST |
| }; |
| |
| /* variable size table */ |
| enum { |
| CFG_NET_ADDR = 0, |
| CFG_PROFILE, |
| /* <-- LAST --> */ |
| CFG_TBL_VAR_LAST |
| }; |
| |
| struct iwm_umac_cmd_set_param_fix { |
| __le16 tbl; |
| __le16 key; |
| __le32 value; |
| } __attribute__ ((packed)); |
| |
| struct iwm_umac_cmd_set_param_var { |
| __le16 tbl; |
| __le16 key; |
| __le16 len; |
| __le16 reserved; |
| } __attribute__ ((packed)); |
| |
| struct iwm_umac_cmd_get_param { |
| __le16 tbl; |
| __le16 key; |
| } __attribute__ ((packed)); |
| |
| struct iwm_umac_cmd_get_param_resp { |
| __le16 tbl; |
| __le16 key; |
| __le16 len; |
| __le16 reserved; |
| } __attribute__ ((packed)); |
| |
| struct iwm_umac_cmd_eeprom_proxy_hdr { |
| __le32 type; |
| __le32 offset; |
| __le32 len; |
| } __attribute__ ((packed)); |
| |
| struct iwm_umac_cmd_eeprom_proxy { |
| struct iwm_umac_cmd_eeprom_proxy_hdr hdr; |
| u8 buf[0]; |
| } __attribute__ ((packed)); |
| |
| #define IWM_UMAC_CMD_EEPROM_TYPE_READ 0x1 |
| #define IWM_UMAC_CMD_EEPROM_TYPE_WRITE 0x2 |
| |
| #define UMAC_CHANNEL_FLAG_VALID BIT(0) |
| #define UMAC_CHANNEL_FLAG_IBSS BIT(1) |
| #define UMAC_CHANNEL_FLAG_ACTIVE BIT(3) |
| #define UMAC_CHANNEL_FLAG_RADAR BIT(4) |
| #define UMAC_CHANNEL_FLAG_DFS BIT(7) |
| |
| struct iwm_umac_channel_info { |
| u8 band; |
| u8 type; |
| u8 reserved; |
| u8 flags; |
| __le32 channels_mask; |
| } __attribute__ ((packed)); |
| |
| struct iwm_umac_cmd_get_channel_list { |
| __le16 count; |
| __le16 reserved; |
| struct iwm_umac_channel_info ch[0]; |
| } __attribute__ ((packed)); |
| |
| |
| /* UMAC WiFi interface commands */ |
| |
| /* Coexistence mode */ |
| #define COEX_MODE_SA 0x1 |
| #define COEX_MODE_XOR 0x2 |
| #define COEX_MODE_CM 0x3 |
| #define COEX_MODE_MAX 0x4 |
| |
| /* Wireless mode */ |
| #define WIRELESS_MODE_11A 0x1 |
| #define WIRELESS_MODE_11G 0x2 |
| #define WIRELESS_MODE_11N 0x4 |
| |
| #define UMAC_PROFILE_EX_IE_REQUIRED 0x1 |
| #define UMAC_PROFILE_QOS_ALLOWED 0x2 |
| |
| /* Scanning */ |
| #define UMAC_WIFI_IF_PROBE_OPTION_MAX 10 |
| |
| #define UMAC_WIFI_IF_SCAN_TYPE_USER 0x0 |
| #define UMAC_WIFI_IF_SCAN_TYPE_UMAC_RESERVED 0x1 |
| #define UMAC_WIFI_IF_SCAN_TYPE_HOST_PERIODIC 0x2 |
| #define UMAC_WIFI_IF_SCAN_TYPE_MAX 0x3 |
| |
| struct iwm_umac_ssid { |
| u8 ssid_len; |
| u8 ssid[IEEE80211_MAX_SSID_LEN]; |
| u8 reserved[3]; |
| } __attribute__ ((packed)); |
| |
| struct iwm_umac_cmd_scan_request { |
| struct iwm_umac_wifi_if hdr; |
| __le32 type; /* UMAC_WIFI_IF_SCAN_TYPE_* */ |
| u8 ssid_num; |
| u8 seq_num; |
| u8 timeout; /* In seconds */ |
| u8 reserved; |
| struct iwm_umac_ssid ssids[UMAC_WIFI_IF_PROBE_OPTION_MAX]; |
| } __attribute__ ((packed)); |
| |
| #define UMAC_CIPHER_TYPE_NONE 0xFF |
| #define UMAC_CIPHER_TYPE_USE_GROUPCAST 0x00 |
| #define UMAC_CIPHER_TYPE_WEP_40 0x01 |
| #define UMAC_CIPHER_TYPE_WEP_104 0x02 |
| #define UMAC_CIPHER_TYPE_TKIP 0x04 |
| #define UMAC_CIPHER_TYPE_CCMP 0x08 |
| |
| /* Supported authentication types - bitmap */ |
| #define UMAC_AUTH_TYPE_OPEN 0x00 |
| #define UMAC_AUTH_TYPE_LEGACY_PSK 0x01 |
| #define UMAC_AUTH_TYPE_8021X 0x02 |
| #define UMAC_AUTH_TYPE_RSNA_PSK 0x04 |
| |
| /* iwm_umac_security.flag is WPA supported -- bits[0:0] */ |
| #define UMAC_SEC_FLG_WPA_ON_POS 0 |
| #define UMAC_SEC_FLG_WPA_ON_SEED 1 |
| #define UMAC_SEC_FLG_WPA_ON_MSK (UMAC_SEC_FLG_WPA_ON_SEED << \ |
| UMAC_SEC_FLG_WPA_ON_POS) |
| |
| /* iwm_umac_security.flag is WPA2 supported -- bits [1:1] */ |
| #define UMAC_SEC_FLG_RSNA_ON_POS 1 |
| #define UMAC_SEC_FLG_RSNA_ON_SEED 1 |
| #define UMAC_SEC_FLG_RSNA_ON_MSK (UMAC_SEC_FLG_RSNA_ON_SEED << \ |
| UMAC_SEC_FLG_RSNA_ON_POS) |
| |
| /* iwm_umac_security.flag is WSC mode on -- bits [2:2] */ |
| #define UMAC_SEC_FLG_WSC_ON_POS 2 |
| #define UMAC_SEC_FLG_WSC_ON_SEED 1 |
| |
| /* Legacy profile can use only WEP40 and WEP104 for encryption and |
| * OPEN or PSK for authentication */ |
| #define UMAC_SEC_FLG_LEGACY_PROFILE 0 |
| |
| struct iwm_umac_security { |
| u8 auth_type; |
| u8 ucast_cipher; |
| u8 mcast_cipher; |
| u8 flags; |
| } __attribute__ ((packed)); |
| |
| struct iwm_umac_ibss { |
| u8 beacon_interval; /* in millisecond */ |
| u8 atim; /* in millisecond */ |
| s8 join_only; |
| u8 band; |
| u8 channel; |
| u8 reserved[3]; |
| } __attribute__ ((packed)); |
| |
| #define UMAC_MODE_BSS 0 |
| #define UMAC_MODE_IBSS 1 |
| |
| #define UMAC_BSSID_MAX 4 |
| |
| struct iwm_umac_profile { |
| struct iwm_umac_wifi_if hdr; |
| __le32 mode; |
| struct iwm_umac_ssid ssid; |
| u8 bssid[UMAC_BSSID_MAX][ETH_ALEN]; |
| struct iwm_umac_security sec; |
| struct iwm_umac_ibss ibss; |
| __le32 channel_2ghz; |
| __le32 channel_5ghz; |
| __le16 flags; |
| u8 wireless_mode; |
| u8 bss_num; |
| } __attribute__ ((packed)); |
| |
| struct iwm_umac_invalidate_profile { |
| struct iwm_umac_wifi_if hdr; |
| u8 reason; |
| u8 reserved[3]; |
| } __attribute__ ((packed)); |
| |
| /* Encryption key commands */ |
| struct iwm_umac_key_wep40 { |
| struct iwm_umac_wifi_if hdr; |
| struct iwm_umac_key_hdr key_hdr; |
| u8 key[WLAN_KEY_LEN_WEP40]; |
| u8 static_key; |
| u8 reserved[2]; |
| } __attribute__ ((packed)); |
| |
| struct iwm_umac_key_wep104 { |
| struct iwm_umac_wifi_if hdr; |
| struct iwm_umac_key_hdr key_hdr; |
| u8 key[WLAN_KEY_LEN_WEP104]; |
| u8 static_key; |
| u8 reserved[2]; |
| } __attribute__ ((packed)); |
| |
| #define IWM_TKIP_KEY_SIZE 16 |
| #define IWM_TKIP_MIC_SIZE 8 |
| struct iwm_umac_key_tkip { |
| struct iwm_umac_wifi_if hdr; |
| struct iwm_umac_key_hdr key_hdr; |
| u8 iv_count[6]; |
| u8 reserved[2]; |
| u8 tkip_key[IWM_TKIP_KEY_SIZE]; |
| u8 mic_rx_key[IWM_TKIP_MIC_SIZE]; |
| u8 mic_tx_key[IWM_TKIP_MIC_SIZE]; |
| } __attribute__ ((packed)); |
| |
| struct iwm_umac_key_ccmp { |
| struct iwm_umac_wifi_if hdr; |
| struct iwm_umac_key_hdr key_hdr; |
| u8 iv_count[6]; |
| u8 reserved[2]; |
| u8 key[WLAN_KEY_LEN_CCMP]; |
| } __attribute__ ((packed)); |
| |
| struct iwm_umac_key_remove { |
| struct iwm_umac_wifi_if hdr; |
| struct iwm_umac_key_hdr key_hdr; |
| } __attribute__ ((packed)); |
| |
| struct iwm_umac_tx_key_id { |
| struct iwm_umac_wifi_if hdr; |
| u8 key_idx; |
| u8 reserved[3]; |
| } __attribute__ ((packed)); |
| |
| struct iwm_umac_cmd_stats_req { |
| __le32 flags; |
| } __attribute__ ((packed)); |
| |
| /* LMAC commands */ |
| int iwm_read_mac(struct iwm_priv *iwm, u8 *mac); |
| int iwm_send_prio_table(struct iwm_priv *iwm); |
| int iwm_send_init_calib_cfg(struct iwm_priv *iwm, u8 calib_requested); |
| int iwm_send_periodic_calib_cfg(struct iwm_priv *iwm, u8 calib_requested); |
| int iwm_send_calib_results(struct iwm_priv *iwm); |
| int iwm_store_rxiq_calib_result(struct iwm_priv *iwm); |
| |
| /* UMAC commands */ |
| int iwm_send_wifi_if_cmd(struct iwm_priv *iwm, void *payload, u16 payload_size, |
| bool resp); |
| int iwm_send_umac_reset(struct iwm_priv *iwm, __le32 reset_flags, bool resp); |
| int iwm_umac_set_config_fix(struct iwm_priv *iwm, u16 tbl, u16 key, u32 value); |
| int iwm_umac_set_config_var(struct iwm_priv *iwm, u16 key, |
| void *payload, u16 payload_size); |
| int iwm_send_umac_config(struct iwm_priv *iwm, __le32 reset_flags); |
| int iwm_send_mlme_profile(struct iwm_priv *iwm); |
| int iwm_invalidate_mlme_profile(struct iwm_priv *iwm); |
| int iwm_send_packet(struct iwm_priv *iwm, struct sk_buff *skb, int pool_id); |
| int iwm_set_tx_key(struct iwm_priv *iwm, u8 key_idx); |
| int iwm_set_key(struct iwm_priv *iwm, bool remove, struct iwm_key *key); |
| int iwm_send_umac_stats_req(struct iwm_priv *iwm, u32 flags); |
| int iwm_send_umac_channel_list(struct iwm_priv *iwm); |
| int iwm_scan_ssids(struct iwm_priv *iwm, struct cfg80211_ssid *ssids, |
| int ssid_num); |
| int iwm_scan_one_ssid(struct iwm_priv *iwm, u8 *ssid, int ssid_len); |
| |
| /* UDMA commands */ |
| int iwm_target_reset(struct iwm_priv *iwm); |
| #endif |