1
0
mirror of git://projects.qi-hardware.com/openwrt-xburst.git synced 2025-01-25 08:21:06 +02:00

4422 lines
116 KiB
C
Raw Normal View History

/*
*
* Copyright (c) 2004-2007 Atheros Communications Inc.
* All rights reserved.
*
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation;
*
* Software distributed under the License is distributed on an "AS
* IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
* implied. See the License for the specific language governing
* rights and limitations under the License.
*
*
*
*/
#if 0
Wireless Module Interface (WMI) Documentaion
This section describes the format and the usage model for WMI control and
data messages between the host and the AR6000-based targets. The header
file include/wmi.h contains all command and event manifest constants as
well as structure typedefs for each set of command and reply parameters.
Data Frames
The data payload transmitted and received by the target follows RFC-1042
encapsulation and thus starts with an 802.2-style LLC-SNAP header. The
WLAN module completes 802.11 encapsulation of the payload, including the
MAC header, FCS, and WLAN security related fields. At the interface to the
message transport (HTC), a data frame is encapsulated in a WMI message.
WMI Message Structure
The WMI protocol leverages an 802.3-style Ethernet header in communicating
the source and destination information between the host and the AR6000
modules using a 14-byte 802.3 header ahead of the 802.2-style payload. In
addition, the WMI protocol adds a header to all data messages:
{
INT8 rssi
The RSSI of the received packet and its units are shown in db above the
noise floor, and the noise floor is shown in dbm.
UINT8 info
Contains information on message type and user priority. Message type
differentiates between a data packet and a synchronization message.
} WMI_DATA_HDR
User priority contains the 802.1d user priority info from host to target. Host
software translates the host Ethernet format to 802.3 format prior to Tx and
802.3 format to host format in the Rx direction. The host does not transmit the
FCS that follows the data. MsgType differentiates between a regular data
packet (msgType=0) and a synchronization message (msgType=1).
Data Endpoints
The AR6000 chipset provides several data endpoints to support quality of
service (QoS) and maintains separate queues and separate DMA engines for
each data endpoint. A data endpoint can be bi-directional.
Best effort (BE) class traffic uses the default data endpoint (2). The host can
establish up to two additional data endpoints for other traffic classes. Once
such a data endpoint is established, it sends and receives corresponding QoS
traffic in a manner similar to the default data endpoint.
If QoS is desired over the interconnect, host software must classify each data
packet and place it on the appropriate data endpoint. The information
required to classify data is generally available in-band as an 802.1p/q style
tag or as the ToS field in the IP header. The information may also be available
out-of-band depending on the host DDI.
Connection States
Table B-1 describes the AR6000 WLAN connection states:
Table B-1. AR6000 Connection States
Connection State
Description
DISCONNECTED
In this state, the AR6000 device is not connected to a wireless
network. The device is in this state after reset when it sends the
WIRELESS MODULE <EFBFBD>READY<EFBFBD> EVENT, after it processes a
DISCONNECT command, and when it loses its link with the
access point (AP) that it was connected to. The device signals a
transition to the DISCONNECTED state with a <EFBFBD>DISCONNECT<EFBFBD>
event.
CONNECTED
In this state, the AR6000 device is connected to wireless networks.
The device enters this state after successfully processing a
CONNECT, which establishes a connection with a wireless
network. The device signals a transition to the CONNECTED state
with a <EFBFBD>CONNECT<EFBFBD> event.
Message Types
WMI uses commands, replies, and events for the control and configuration of
the AR6000 device. The control protocol is asynchronous. Table B-2 describes
AR6000 message types:
Table B-2. AR6000 Message Types
Message Type
Description
Commands
Control messages that flow from the host to the device
Replies/Events
Control messages that flow from the device to the host.
The device issues a reply to some WMI commands, but not to others.
The payload in a reply is command-specific, and some commands do
not trigger a reply message at all. Events are control messages issued
by the device to signal the occurrence of an asynchronous event.
WMI Message Format
All WMI control commands, replies and events use the header format:
WMI_CMD_HDR Header Format
{
UINT16 id
This 16-bit constant identifies which WMI command the host is issuing,
which command the target is replying to, or which event has occurred.
WMI_CMD_HDR
}
A variable-size command-, reply-, or event-specific payload follows the
header. Over the interconnect, all fields in control messages (including
WMI_CMD_HDR and the command specific payload) use 32-bit little Endian
byte ordering and fields are packed. The AR6000 device always executes
commands in order, and the host may send multiple commands without
waiting for previous commands to complete. A majority of commands are
processed to completion once received. Other commands trigger a longer
duration activity whose completion is signaled to the host through an event.
Command Restrictions
Some commands may only be issued when the AR6000 device is in a certain
state. The host is required to wait for an event signaling a state transition
before such a command can be issued. For example, if a command requires
the device to be in the CONNECTED state, then the host is required to wait
for a <EFBFBD>CONNECT<EFBFBD> event before it issues that command.
The device ignores any commands inappropriate for its current state. If the
command triggers a reply, the device generates an error reply. Otherwise, the
device silently ignores the inappropriate command.
Command and Data Synchronization
WMI provides a mechanism for a host to advise the device of necessary
synchronization between commands and data. The device implements
synchronization; no implicit synchronization exists between endpoints.
The host controls synchronization using the <EFBFBD>SYNCHRONIZE<EFBFBD> command
over the control channel and synchronization messages over data channels.
The device stops each data channel upon receiving a synchronization message
on that channel, processing all data packets received prior to that message.
After the device receives synchronization messages for each data endpoint
and the <EFBFBD>SYNCHRONIZE<EFBFBD> command, it resumes all channels.
When the host must guarantee a command executes before processing new
data packets, it first issues the command, then issues the <EFBFBD>SYNCHRONIZE<EFBFBD>
command and sends synchronization messages on data channels. When the
host must guarantee the device has processed all old data packets before a
processing a new command, it issues a <EFBFBD>SYNCHRONIZE<EFBFBD> command and
synchronization messages on all data channels, then issues the desired
command.
WMI Commands
ADD_BAD_AP
Cause the AR6000 device to avoid a particular AP
ADD_CIPHER_KEY
Add or replace any of the four AR6000 encryption keys
ADD_WOW_PATTERN
Used to add a pattern to the WoW pattern list
CLR_RSSI_SNR
Clear the current calculated RSSI and SNR value
CONNECT_CMD
Request that the AR6000 device establish a wireless connection
with the specified SSID
CREATE_PSTREAM
Create prioritized data endpoint between the host and device
DELETE_BAD_AP
Clear an entry in the bad AP table
DELETE_CIPHER_KEY
Delete a previously added cipher key
DELETE_PSTREAM
Delete a prioritized data endpoint
DELETE_WOW_PATTERN
Remove a pre-specified pattern from the WoW pattern list
EXTENSION
WMI message interface command
GET_BIT_RATE
Retrieve rate most recently used by the AR6000
GET_CHANNEL_LIST
Retrieve list of channels used by the AR6000
GET_FIXRATES
Retrieves the rate-mask set via the SET_FIXRATES command.
GET_PMKID_LIST_CMD
Retrieve the firmware list of PMKIDs
GET_ROAM_DATA
Internal use for data collection; available in special build only
GET_ROAM_TBL
Retrieve the roaming table maintained on the target
GET_TARGET_STATS
Request that the target send the statistics it maintains
GET_TX_PWR
Retrieve the current AR6000 device Tx power levels
GET_WOW_LIST
Retrieve the current list of WoW patterns
LQ_THRESHOLD_PARAMS
Set the link quality thresholds
OPT_TX_FRAME
Send a special frame (special feature)
RECONNECT
Request a reconnection to a BSS
RSSI_THRESHOLD_PARAMS
Configure how the AR6000 device monitors and reports signal
strength (RSSI) of the connected BSS
SCAN_PARAMS
Determine dwell time and changes scanned channels
SET_ACCESS_PARAMS
Set access parameters for the wireless network
SET_ADHOC_BSSID
Set the BSSID for an ad hoc network
SET_AKMP_PARAMS
Set multiPMKID mode
SET_APPIE
Add application-specified IE to a management frame
SET_ASSOC_INFO
Specify the IEs the device should add to association or
reassociation requests
SET_AUTH_MODE
Set 802.11 authentication mode of reconnection
SET_BEACON_INT
Set the beacon interval for an ad hoc network
SET_BIT_RATE
Set the AR6000 to a specific fixed bit rate
SET_BMISS_TIME
Set the beacon miss time
SET_BSS_FILTER
Inform the AR6000 of network types about which it wants to
receive information using a <EFBFBD>BSSINFO<EFBFBD> event
SET_BT_PARAMS
Set the status of a Bluetooth stream (SCO or A2DP) or set
Bluetooth coexistence register parameters
SET_BT_STATUS
Set the status of a Bluetooth stream (SCO or A2DP)
SET_CHANNEL_PARAMETERS
Configure WLAN channel parameters
SET_DISC_TIMEOUT
Set the amount of time the AR6000 spends attempting to
reestablish a connection
SET_FIXRATES
Set the device to a specific fixed PHY rate (supported subset)
SET_HALPARAM
Internal AR6000 command to set certain hardware parameters
SET_HOST_SLEEP_MODE
Set the host mode to asleep or awake
SET_IBSS_PM_CAPS
Support a non-standard power management scheme for an
ad hoc network
SET_LISTEN_INT
Request a listen interval
SET_LPREAMBLE
Override the short preamble capability of the AR6000 device
SET_MAX_SP_LEN
Set the maximum service period
SET_OPT_MODE
Set the special mode on/off (special feature)
SET_PMKID
Set the pairwise master key ID (PMKID)
SET_PMKID_LIST_CMD
Configure the firmware list of PMKIDs
SET_POWER_MODE
Set guidelines on trade-off between power utilization
SET_POWER_PARAMS
Configure power parameters
SET_POWERSAVE_PARAMS
Set the two AR6000 power save timers
SET_PROBED_SSID
Provide list of SSIDs the device should seek
SET_REASSOC_MODE
Specify whether the disassociated frame should be sent upon
reassociation
SET_RETRY_LIMITS
Limit how many times the device tries to send a frame
SET_ROAM_CTRL
Control roaming behavior
SET_RTS
Determine when RTS should be sent
SET_SCAN_PARAMS
Set the AR6000 scan parameters
SET_TKIP_COUNTERMEASURES
Enable/disable reports of TKIP MIC errors
SET_TX_PWR
Specify the AR6000 device Tx power levels
SET_VOICE_PKT_SIZE
Set voice packet size
SET_WMM
Override the AR6000 WMM capability
SET_WMM_TXOP
Configure TxOP bursting when sending traffic to a WMM-
capable AP
SET_WOW_MODE
Enable/disable WoW mode
SET_WSC_STATUS
Enable/disable profile check in cserv when the WPS protocol
is in progress
SNR_THRESHOLD_PARAMS
Configure how the device monitors and reports SNR of BSS
START_SCAN
Start a long or short channel scan
SYNCHRONIZE
Force a synchronization point between command and data
paths
TARGET_REPORT_ERROR_BITMASK
Control <EFBFBD>ERROR_REPORT<EFBFBD> events from the AR6000
Name
ADD_BAD_AP
Synopsis
The host uses this command to cause the AR6000 to avoid a particular AP. The
AR6000 maintain a table with up to two APs to avoid. An ADD_BAD_AP command
adds or replaces the specified entry in this bad AP table.
If the AR6000 are currently connected to the AP specified in this command, they
disassociate.
Command
wmiconfig eth1 --badap <bssid> <badApIndex>
Command Parameters
UINT8 badApIndex Index [0...1] that identifies which entry in the
bad AP table to use
UINT8 bssid[6] MAC address of the AP to avoid
Command Values
badApIndex = 0, 1 Entry in the bad AP table to use
Reset Value
The bad AP table is cleared
Restrictions
None
See Also
<EFBFBD>DELETE_BAD_AP<EFBFBD> on page B-13
=====================================================================
Name
ADD_CIPHER_KEY
Synopsis
The host uses this command to add/replace any of four encryption keys on the
AR6000. The ADD_CIPHER_KEY command is issued after the CONNECT event
has been received by the host for all dot11Auth modes except for SHARED_AUTH.
When the dot11AuthMode is SHARED_AUTH, then the ADD_CIPHER_KEY
command should be issued before the <EFBFBD>CONNECT<EFBFBD> command.
Command
wmiconfig eth1 --cipherkey <keyIndex> <keyType> <keyUsage>
<keyLength> <keyopctrl> <keyRSC> <key>
Command Parameters
UINT8 keyIndex Index (0...3) of the key to add/replace;
uniquely identifies the key
UINT8 keyType CRYPTO_TYPE
UINT8 keyUsage Specifies usage parameters of the key when
keyType = WEP_CRYPT
UINT8 keyLength Length of the key in bytes
UINT8 keyOpCtrl bit[0] = Initialize TSC (default),
bit[1] = Initialize RSC
UINT8 keyRSC[8] Key replay sequence counter (RSC) initial
value the device should use
UINT8 key[32] Key material used for this connection
Command Values
{
NONE_CRYPT = 1
WEP_CRYPT = 2
TKIP_CRYPT = 3
AES_CRYPT = 4
KEY_OP_INIT_TSC 0x01
KEY_OP_INIT_RSC 0x02
KEY_OP_INIT_VAL 0x03
Default is to Initialize the TSC
KEY_OP_VALID_MASK 0x04
Two operations defined
} CRYPTO_TYPE
{
PAIRWISE_USAGE = 0 Set if the key is used for unicast traffic only
GROUP_USAGE = 1 Set if the key is used to receive multicast
traffic (also set for static WEP keys)
TX_USAGE = 2 Set for the GROUP key used to transmit frames
All others are reserved
} KEY_USAGE
Reset Value
The four available keys are disabled.
Restrictions
The cipher should correspond to the encryption mode specified in the <EFBFBD>CONNECT<EFBFBD>
command.
See Also
<EFBFBD>DELETE_CIPHER_KEY<EFBFBD>
=====================================================================
Name
ADD_WOW_PATTERN
Synopsis
The host uses this command to add a pattern to the WoW pattern list; used for
pattern-matching for host wakeups by the WoW module. If the host mode is asleep
and WoW is enabled, all packets are matched against the existing WoW patterns. If a
packet matches any of the patterns specified, the target will wake up the host. All
non-matching packets are discarded by the target without being sent up to the host.
Command
wmiconfig <EFBFBD>addwowpattern <list-id> <filter-size> <filter-offset>
<pattern> <mask>
Command Parameters
A_UINT8 filter_list_id ID of the list that is to include the new pattern
A_UINT8 filter_size Size of the new pattern
A_UINT8 filter_offset Offset at which the pattern matching for this
new pattern should begin at
A_UINT8 filter[1] Byte stream that contains both the pattern and
the mask of the new WoW wake-up pattern
Reply Parameters
None
Reset Value
None defined (default host mode is awake)
Restrictions
None
See Also
<EFBFBD>DELETE_WOW_PATTERN<EFBFBD>
=====================================================================
Name
CLR_RSSI_SNR
Synopsis
Clears the current calculated RSSI and SNR value. RSSI and SNR are reported by
running-average value. This command will clear the history and have a fresh start
for the running-average mechanism.
Command
wmiconfig eth1 --cleanRssiSnr
Command Parameters
None
Reply Parameters
None
Reset Value
None defined
Restrictions
None
=====================================================================
Name
CONNECT_CMD
Synopsis
New connect control information (connectCtrl) is added, with 32 possible modifiers.
CONNECT_SEND_REASSOC
Valid only for a host-controlled connection to a
particular AP. If this bit is set, a reassociation frame is
sent. If this bit is clear, an association request frame is
sent to the AP.
CONNECT_IGNORE_WPAx_GROUP_CIPHER
No group key is issued in the CONNECT command,
so use the group key advertised by the AP. In a target-
initiated roaming situation this allows a STA to roam
between APs that support different multicast ciphers.
CONNECT_PROFILE_MATCH_DONE
In a host-controlled connection case, it is possible that
during connect, firmware may not have the
information for a profile match (e.g, when the AP
supports hidden SSIDs and the device may not
transmit probe requests during connect). By setting
this bit in the connection control information, the
firmware waits for a beacon from the AP with the
BSSID supplied in the CONNECT command. No
additional profile checks are done.
CONNECT_IGNORE_AAC_BEACON
Ignore the Admission Capacity information in the
beacon of the AP
CONNECT_ASSOC_POLICY_USER
When set, the CONNECT_SEND_REASSOC setting
determines if an Assoc or Reassoc is sent to an AP
Command
wmiconfig --setconnectctrl <ctrl flags bitmask>
Command Parameters
typedef struct{
A_UINT8 networktype;
A_UINT8 dot11authmode;
A_UINT8 authmode;
A_UINT8 pairwiseCryptoType; /*CRYPTO_TYPE*/
A_UINT8 pairwiseCryptoLen;
A_UINT8 groupCryptoType; /*CRYPTO_TYPE*/
A_UINT8 groupCryptoLen;
A_UINT8 ssidLength;
A_UCHAR ssid[WMI_MAX_SSID_LEN];
A_UINT16 channel;
A_UINT8 bssid[AUTH_MAC_LEN];
A_UINT8 ctrl_flags; /*WMI_CONNECT_CTRL_FLAGS_BITS*/
} WMI_CONNECT_CMD;
ctrl flags bitmask
= 0x0001 CONNECT_ASSOC_POLICY_USER
Assoc frames are sent using the policy specified by
the flag
= 0x0002 CONNECT_SEND_REASSOC
Send Reassoc frame while connecting, otherwise send
assoc frames
= 0x0004 CONNECT_IGNORE_WPAx_GROUP_CIPHER
Ignore WPAx group cipher for WPA/WPA2
= 0x0008 CONNECT_PROFILE_MATCH_DONE
Ignore any profile check
= 0x0010 CONNECT_IGNORE_AAC_BEACON
Ignore the admission control information in the
beacon
... CONNECT_CMD, continued
Command Values
typedef enum {
INFRA_NETWORK = 0x01,
ADHOC_NETWORK = 0x02,
ADHOC_CREATOR = 0x04,
} NETWORK_TYPE;
typedef enum {
OPEN_AUTH = 0x01,
SHARED_AUTH = 0x02,
LEAP_AUTH = 0x04,
} DOT11_AUTH_MODE;
typedef enum {
NONE_AUTH = 0x01,
WPA_AUTH = 0x02,
WPA_PSK_AUTH = 0x03,
WPA2_AUTH = 0x04,
WPA2_PSK_AUTH = 0x05,
WPA_AUTH_CCKM = 0x06,
WPA2_AUTH_CCKM = 0x07,
} AUTH_MODE;
typedef enum {
NONE_CRYPT = 0x01,
WEP_CRYPT = 0x02,
TKIP_CRYPT = 0x03,
AES_CRYPT = 0x04,
} CRYPTO_TYPE;
typedef enum {
CONNECT_ASSOC_POLICY_USER = 0x0001,
CONNECT_SEND_REASSOC = 0x0002,
CONNECT_IGNORE_WPAx_GROUP_CIPHER = 0x0004,
CONNECT_PROFILE_MATCH_DONE = 0x0008,
CONNECT_IGNORE_AAC_BEACON = 0x0010,
} WMI_CONNECT_CTRL_FLAGS_BITS;
pairwiseCryptoLen and groupCryptoLen are valid when the respective
CryptoTypesis WEP_CRYPT, otherwise this value should be 0. This is the length in
bytes.
Reset Value
None defined
Restrictions
None
=====================================================================
Name
CREATE_PSTREAM
Synopsis
The host uses this command to create a new prioritized data endpoint between the
host and the AR6000 device that carries a prioritized stream of data. If the AP that the
device connects to requires TSPEC stream establishment, the device requests the
corresponding TSPEC with the AP. The maximum and minimum service interval
ranges from 0 <EFBFBD> 0x7FFFFFFF (ms), where 0 = disabled. The device does not send a
reply event for this command, as it is always assumed the command has succeeded.
An AP admission control response comes to the host via a WMI_CAC_INDICATION
event, once the response for the ADDTS frame comes.
Examples of cases where reassociation is generated (when WMM) and cases where
ADDTS is generated (when WMM and enabling ACM) are when:
Changing UAPSD flags in WMM mode, reassociation is generated
Changing the interval of sending auto QoS Null frame in WMM mode;
reassociation is not generated
Issuing a command with same previous parameters in WMM mode and enabling
ACM, an ADDTS request is generated
Changing the interval of a QoS null frame sending in WMM mode and enabling
ACM, an ADDTS request is generated
Issuing the command in disconnected state, reassociation or ADDTS is not
generated but the parameters are available after (re)association
Command
--createqos <user priority> <direction> <traffic class>
<trafficType> <voice PS capability> <min service interval> <max
service interval> <inactivity interval> <suspension interval>
<service start time> <tsid> <nominal MSDU> <max MSDU> <min data
rate> <mean data rate> <peak data rate> <max burst size> <delay
bound> <min phy rate> <sba> <medium time> where:
<user priority>
802.1D user priority range (0<EFBFBD>7)
<direction>
= 0 Tx (uplink) traffic
= 1 Rx (downlink) traffic
= 2 Bi-directional traffic
<traffic class>
= 1 BK
= 2 VI
= 3 VO
<trafficType>
= 0 Aperiodic
= 1 Periodic
<voice PS capability>
Specifies whether the voice power save mechanism
(APSD if AP supports it or legacy/simulated APSD
[using PS-Poll]) should be used
= 0 Disable voice power save for traffic class
= 1 Enable APSD voice power save for traffic class
= 2 Enable voice power save for all traffic classes
<min service interval>
(In ms)
<max service interval>
Inactivity interval (in ms) (0 = Infinite)
<suspension interval>
(In ms)
<service start time>
Service start time
<tsid>
TSID range (0<EFBFBD>15)
<nominal MSDU>
Nominal MAC SDU size
<max MSDU>
Maximum MAC SDU size
<min data rate>
Minimum data rate (in bps)
<mean data rate>
Mean data rate (in bps)
<peak data rate>
Peak data rate (in bps)
<max burst size>
Maximum burst size (in bps)
<delay bound>
Delay bound
<min phy rate>
Minimum PHY rate (in bps)
<sba>
Surplus bandwidth allowance
<medium time>
Medium time in TU of 32-ms periods per sec
... CREATE_PSTREAM (continued)
Command Parameters
UINT8 trafficClass TRAFFIC_CLASS value
UINT8 traffic
Direction
DIR_TYPE value
UINT8 rxQueueNum
AR6000 device mailbox index (2 or 3)
corresponding to the endpoint the host
wishes to use to receive packets for the
prioritized stream
UINT8 trafficType TRAFFIC_TYPE value
UINT8 voicePS
Capability
VOICEPS_CAP_TYPE value
UINT8 tsid Traffic stream ID
UINT8 userPriority 802.1D user priority
UINT16 nominalMSDU Nominal MSDU in octets
UINT16 maxMSDU Maximum MSDU in octets
UINT32 minServiceInt Minimum service interval: the min.
period of traffic specified (in ms)
UINT32 maxServiceInt Maximum service interval: the max.
period of traffic specified (in ms)
UINT32 inactivityInt Indicates how many ms an established
stream is inactive before the prioritized
data endpoint is taken down and the
corresponding T-SPEC deleted
UINT32 suspensionInt Suspension interval (in ms)
UINT32 service StartTime Service start time
UINT32 minDataRate Minimum data rate (in bps)
UINT32 meanDataRate Mean data rate (in bps)
UINT32 peakDataRate Peak data rate (in bps)
UINT32 maxBurstSize
UINT32 delayBound
UINT32 minPhyRate Minimum PHY rate for TSPEC (in bps)
UINT32 sba Surplus bandwidth allowance
UINT32 mediumTime Medium TSPEC time (in units of 32 ms)
Command Values
{
WMM_AC_BE = 0 Best Effort
WMM_AC_BK = 1 Background
WMM_AC_VI = 2 Video
WMM_AC_VO = 3 Voice
All other values reserved
} TRAFFIC_CLASS
{
UPLINK_TRAFFIC = 0 From the AR6000 device to the AP
DOWNLINK_TRAFFIC = 1 From the AP to the AR6000 device
BIDIR_TRAFFIC = 2 Bi-directional traffic
All other values reserved
} DIR_TYPE
{
DISABLE_FOR_THIS_AC = 0
ENABLE_FOR_THIS_AC = 1
ENABLE_FOR_ALL_AC = 2
All other values reserved
} VOICEPS_CAP_TYPE
... CREATE_PSTREAM (continued)
VI BE BK Supported, Y/N?
0 0 0 0 Y
0 0 0 1 Y
0 0 1 0 N
0 0 1 1 N
0 1 0 0 Y
0 1 0 1 Y
0 1 1 0 N
0 1 1 1 N
1 0 0 0 Y
1 0 0 1 Y
1 0 1 0 N
1 1 0 0 N
1 1 0 1 Y
1 1 0 0 N
1 1 1 0 N
1 1 1 1 Y
Reset Value
No pstream is present after reset; each of the BE, BK, VI,VO pstreams must be created
(either implicitly by data flow or explicitly by user)
Restrictions
This command can only be issued when the device is in the CONNECTED state. If
the device receives the command while in DISCONNECTED state, it replies with a
failure indication. At most four prioritized data endpoints can be created, one for
each AC.
See Also
<EFBFBD>DELETE_PSTREAM<EFBFBD>
=====================================================================
Name
DELETE_BAD_AP
Synopsis
The host uses this command to clear a particular entry in the bad AP table
Command
wmiconfig eth1 --rmAP [--num=<index>] // used to clear a badAP
entry. num is index from 0-3
Command Parameters
UINT8 badApIndex Index [0...n] that identifies the entry in the bad
AP table to delete
Command Values
badApIndex = 0, 1, 2, 3
Entry in the bad AP table
Reset Value
None defined
Restrictions
None
See Also
<EFBFBD>ADD_BAD_AP<EFBFBD>
=====================================================================
Name
DELETE_CIPHER_KEY
Synopsis
The host uses this command to delete a key that was previously added with the
<EFBFBD>ADD_CIPHER_KEY<EFBFBD> command.
Command
TBD
Command Parameters
UINT8 keyIndex Index (0...3) of the key to be deleted
Command Values
keyIndex = 0, 1,2, 3 Key to delete
Reset Value
None
Restrictions
The host should not delete a key that is currently in use by the AR6000.
See Also
<EFBFBD>ADD_CIPHER_KEY<EFBFBD>
=====================================================================
Name
DELETE_PSTREAM
Synopsis
The host uses this command to delete a prioritized data endpoint created by a
previous <EFBFBD>CREATE_PSTREAM<EFBFBD> command
Command
--deleteqos <trafficClass> <tsid>, where:
<traffic class>
= 0 BE
= 1 BK
= 2 VI
= 3 VO
<tsid>
The TSpec ID; use the -qosqueue option
to get the active TSpec IDs for each traffic class
Command Parameters
A_UINT8 trafficClass Indicate the traffic class of the stream
being deleted
Command Values
{
WMM_AC_BE = 0 Best effort
WMM_AC_BK = 1 Background
WMM_AC_VI = 2 Video
WMM_AC_VO = 3 Voice
} TRAFFIC CLASS
0-15 for TSID
Reply Values
N/A
Restrictions
This command should only be issued after a <EFBFBD>CREATE_PSTREAM<EFBFBD> command has
successfully created a prioritized stream
See Also
<EFBFBD>CREATE_PSTREAM<EFBFBD>
=====================================================================
Name
DELETE_WOW_PATTERN
Synopsis
The host uses this command to remove a pre-specified pattern from the
WoW pattern list.
Command
wmiconfig <EFBFBD>delwowpattern <list-id> <pattern-id>
Command Parameters
A_UINT8 filter_list_id ID of the list that contains the WoW filter
pattern to delete
A_UINT8 filter_id ID of the WoW filter pattern to delete
Reply Parameters
None
Reset Value
None defined
Restrictions
None
See Also
<EFBFBD>ADD_WOW_PATTERN<EFBFBD>
=====================================================================
Name
EXTENSION
Synopsis
The WMI message interface is used mostly for wireless control messages to a wireless
module applicable to wireless module management regardless of the target platform
implementation. However, some commands only peripherally related to wireless
management are desired during operation. These wireless extension commands may
be platform-specific or implementation-dependent.
Command
N/A
Command Parameters
Command-specific
Command Values
Command-specific
Reply Parameters
Command-specific
Reset Values
None defined
Restrictions
None defined
=====================================================================
Name
GET_BIT_RATE
Synopsis
Used by the host to obtain the rate most recently used by the AR6000 device
Command
wmiconfig eth1 --getfixrates
Command Parameters
None
Reply Parameters
INT8
rateIndex
See the <EFBFBD>SET_BIT_RATE<EFBFBD> command
Reset Values
None
Restrictions
This command should only be used during development/debug; it is not intended
for use in production. It is only valid when the device is in the CONNECTED state
See Also
<EFBFBD>SET_BIT_RATE<EFBFBD>
=====================================================================
Name
GET_CHANNEL_LIST
Synopsis
Used by the host uses to retrieve the list of channels that can be used by the device
while in the current wireless mode and in the current regulatory domain.
Command
TBD
Command Parameters
None
Reply Parameters
UINT8 reserved Reserved
UINT8 numberOfChannels Number of channels the reply contains
UINT16 channelList[numberOfChannels] Array of channel frequencies (in MHz)
Reset Values
None defined
Restrictions
The maximum number of channels that can be reported are 32
=====================================================================
Name
GET_FIXRATES
Synopsis
Clears the current calculated RSSI and SNR value. RSSI and SNR are reported by
running-average value. This command will clear the history and have a fresh start for
the running-average mechanism.
Synopsis
This returns rate-mask set via WMI_SET_FIXRATES to retrieve the current fixed rate
that the AR6001 or AR6001 is using. See <EFBFBD>SET_FIXRATES<EFBFBD>.
Command
wmiconfig eth1 --getfixrates
Command Parameters
A_UINT16 fixRateMask; Note: if this command is used prior to
using WMI_SET_FIXRATES, AR6000
returns 0xffff as fixRateMask, indicating
all the rates are enabled
Reply Parameters
None
Reset Value
None defined
Restrictions
None
See Also
<EFBFBD>SET_FIXRATES<EFBFBD>
=====================================================================
Name
GET_PMKID_LIST_CMD
Synopsis
Retrieves the list of PMKIDs on the firmware. The
WMI_GET_PMKID_LIST_EVENT is generated by the firmware.
Command
TBD
Command Parameters
Reset Values
None
Restrictions
None
See Also
SET_PMKID_LIST_CMD GET_PMKID_LIST_EVENT
=====================================================================
Name
GET_ROAM_TBL
Synopsis
Retrieve the roaming table maintained on the target. The response is reported
asynchronously through the ROAM_TBL_EVENT.
Command
wmiconfig --getroamtable <roamctrl> <info>
Command Parameters
A_UINT8 roamCtrlType;
A_UINT16 roamMode
A_UINT16 numEntries
WMI_BSS_ROAM_INFO bssRoamInfo[1]
Reply Value
Reported asynchronously through the ROAM_TBL_EVENT
Reset Value
None defined
Restrictions
None
See Also
SET_KEEPALIVE
=====================================================================
Name
GET_TARGET_STATS
Synopsis
The host uses this command to request that the target send the statistics that it
maintains. The statistics obtained from the target are accrued in the host every time
the GET_TARGET_STATS command is issued. The --clearStats option is added to
clear the target statistics maintained in the host.
Command
wmiconfig --getTargetStats --clearStats
Command Parameters
TARGET_STATS targetStats
WMI_TARGET_STATS
UINT8 clearStats
Reply Value
RSSI return value (0<EFBFBD>100)
Reset Values
All statistics are cleared (zeroed)
Restrictions
The --getTargetStats option must be used; the --clearStats option is also available also
=====================================================================
Name
GET_TX_PWR
Synopsis
The host uses this command to retrieve the current Tx power level
Command
wmiconfig -i eth1 --getpower
Command Parameters
None
Reply Parameters
UINT16 dbM The current Tx power level specified in dbM
Reset Values
The maximum permitted by the regulatory domain
Restrictions
None
See Also
<EFBFBD>SET_TX_PWR<EFBFBD>
=====================================================================
Name
GET_WOW_LIST
Synopsis
The host uses this command to retrieve the current list of WoW patterns.
Command
wmiconfig <EFBFBD>getwowlist <list-id>
Command Parameters
A_UINT8 filter_list_id ID of the list of WoW patterns to retrieve
Reply Value(s)
A_UINT16 num_filters Number of WoW patterns contained in the list
A_UINT8 wow_mode Current mode of WoW (enabled or disabled)
A_UINT8 host_mode Current host mode (asleep or awake)
WOW_FILTER wow_filters[1]
Contents of the WoW filter pattern list
(contains mask, pattern, offset and size
information for each of the patterns)
Reset Value
None defined
Restrictions
None
See Also
<EFBFBD>SET_WSC_STATUS<EFBFBD>
=====================================================================
Name
LQ_THRESHOLD_PARAMS
Synopsis
Sets Link Quality thresholds, the sampling will happen at every unicast data frame
Tx if a certain threshold is met, and the corresponding event will be sent to the host.
Command
--lqThreshold <enable> <upper_threshold_1> ...
<upper_threshold_4> <lower_threshold_1> ... <lower_threshold_4>
Command Parameters
<enable> = 0 Disable link quality sampling
= 1 Enable link quality sampling
<upper_threshold_x> Above thresholds (value in [0,100]), in
ascending order
<lower_threshold_x> Below thresholds (value in [0,100]), in
ascending order
Command Values
See command parameters
Reset Value
None defined
Restrictions
None
=====================================================================
Name
OPT_TX_FRAME
Synopsis
Special feature, sends a special frame.
Command
wmiconfig --sendframe <frmType> <dstaddr> <bssid> <optIEDatalen>
<optIEData>
Command Parameters
{
A_UINT16 optIEDataLen;
A_UINT8 frmType;
A_UINT8 dstAddr[ATH_MAC_LEN];
A_UINT8 bssid[ATH_MAC_LEN];
A_UINT8 optIEData[1];
} WMI_OPT_TX_FRAME_CMD;
Command Values
<frmtype> = 1 Probe request frame
= 2 Probe response frame
= 3 CPPP start
= 4 CPPP stop
Reset Value
None defined
Restrictions
Send a special frame only when special mode is on.
=====================================================================
Name
RECONNECT
Synopsis
This command requests a reconnection to a BSS to which the AR6000 device was
formerly connected
Command
TBD
Command Parameters
UINT16 channel Provides a hint as to which channel was
used for a previous connection
UINT8 bssid[6] If set, indicates which BSSID to connect to
Command Values
None
Reset Values
None
Restrictions
None
See Also
<EFBFBD>CONNECT_CMD<EFBFBD>
=====================================================================
Name
RSSI_THRESHOLD_PARAMS
Synopsis
Configures how the AR6000 device monitors and reports signal strength (RSSI) of the
connected BSS, which is used as a link quality metric. The four RSSI threshold sets (in
dbM) of the host specification divide the signal strength range into six segments.
When signal strength increases or decreases across one of the boundaries, an
RSSI_THRESHOLD event is signaled to the host. The host may then choose to take
action (such as influencing roaming).
Command
wmiconfig eth1 --rssiThreshold <weight> <pollTime>
<above_threshold_val_1> ... <above_threshold_tag_6>
<above_threshold_val_6>
<below_threshold_tag_1> <below_threshold_val_1> ...
<below_threshold_tag_6> <below_threshold_val_6>
Command Parameters
UINT8 weight Range in [1, 16] used to calculate average RSSI
UINT32 pollTime RSSI (signal strength) sampling frequency in
seconds (if pollTime = 0, single strength
sampling is disabled)
USER_RSS__THOLD tholds[12] Thresholds (6 x 2)
Command Values
None defined
Reset Values
pollTime is 0, and sampling is disabled
Restrictions
Can only be issued if the AR6000 device is connected
=====================================================================
Name
SCAN_PARAMS
Synopsis
The minact parameter determines the minimum active channel dwell time, within
which if the STA receives any beacon, it remains on that channel until the maxact
channel dwell time. If the STA does not receive a beacon within the minact dwell
time, it switches to scan the next channel.
Command
wmiconfig -scan -minact=<ms> --maxact=<ms>
Command Parameters
UINT16 maxact Channel dwell time (in ms), default = 0
UINT16 minact Channel dwell time (in ms), default = 105
Command Values
See channel parameters
Reset Values
None defined
Restrictions
The minact value should be greater than 0; maxact should be between 5<EFBFBD>65535 ms
and greater than minact
=====================================================================
Name
SET_ACCESS_PARAMS
Synopsis
Allows the host to set access parameters for the wireless network. A thorough
understanding of IEEE 802.11 is required to properly manipulate these parameters.
Command
wmiconfig eth1 --acparams --txop <limit> --cwmin <0-15>
--cwmax <0-15> --aifsn<0-15>
Command Parameters
UINT16 txop The maximum time (expressed in units of
32 ms) the device can spend transmitting
after acquiring the right to transmit
UINT8 eCWmin Minimum contention window
UINT8 eCWmax Maximum contention window
UINT8 aifsn The arbitration inter-frame space number
Command Values
None
Reset Values
Reasonable defaults that vary, between endpoints (prioritized streams)
Restrictions
None
=====================================================================
Name
SET_ADHOC_BSSID
Synopsis
Allows the host to set the BSSID for an ad hoc network. If a network with this BSSID
is not found, the target creates an ad hoc network with this BSSID after the connect
WMI command is triggered (e.g., by the SIOCSIWESSID IOCTL).
Command
wmiconfig eth1 --adhocbssid <bssid>
Command Parameters
A_UINT8 bssid[ATH_MAC_LEN] BSSID is specified in xx:xx:xx:xx:xx:xx format
Command Values
None
Reset Values
None
Restrictions
None
=====================================================================
Name
SET_AKMP_PARAMS
Synopsis
Enables or disables multi PMKID mode.
Command
wmiconfig eth1 --setakmp --multipmkid=<on/off>
Command Parameters
typedef struct {
A_UINT32 akmpInfo;
} WMI_SET_AKMP_PARAMS_CMD;
Command Values
akmpInfo;
bit[0] = 0
MultiPMKID mode is disabled and PMKIDs that
were set using the WMI_SET_PMKID_CMD are
used in the [Re]AssocRequest frame.
bit[0] = 1
MultiPMKID mode is enabled and PMKIDs issued
by the WMI_SET_PMKID_LIST_CMD are used in
the next [Re]AssocRequest sent to the AP.
Reset Values
MultiPMKID mode is disabled
Restrictions
None
=====================================================================
Name
SET_APPIE
Synopsis
Add an application-specified IE to a management frame. The maximum length is
76 bytes. Including the length and the element ID, this translates to 78 bytes.
Command
wmiconfig --setappie <frame> <IE>, where:
frame
One of beacon, probe, respon, assoc
IE
A hex string beginning with DD (if = 0, no
IE is sent in the management frame)
Command Parameters
mgmtFrmType;
A WMI_MGMT_FRAME_TYPE
ieLen;
Length of the IE to add to the GMT frame
Command Values
None
Reset Value
None defined
Restrictions
Supported only for the probe request and association request management frame
types. Also, only one IE can be added per management frame type.
=====================================================================
Name
SET_ASSOC_INFO
Synopsis
The host uses this command to specify any information elements (IEs) it wishes the
AR6000 device to add to all future association and reassociation requests. IEs must be
correct and are used as is by the device. IEs specified through this command are
cleared with a DISCONNECT.
Command
wmiconfig eth1 --setAssocIe <IE>
Command Parameters
UINT8 ieType Used directly in 802.11 frames
UINT8 bufferSize Size of assocInfo (in bytes) ranging from
0<EFBFBD>240. If = 0, previously set IEs are cleared.
UINT8 assocInfo[bufferSize] Used directly in 802.11 frames
Command Values
None
Reset Values
IEs are cleared
Restrictions
This command can only be issued in the DISCONNECTED state
=====================================================================
Name
SET_AUTHMODE
Synopsis
Sets the 802.11 authentication mode of reconnection
Command
wmiconfig eth1 --setauthmode <mode>
Command Parameters
UINT8 mode
Command Values
mode = 0x00 Proceed with authentication during reconnect
= 0x01 Do not proceed with authentication during reconnect
Reset Values
Authentication
Restrictions
None
=====================================================================
Name
SET_BEACON_INT
Synopsis
Sets the beacon interval for an ad hoc network. Beacon interval selection may have an
impact on power savings. To some degree, a longer interval reduces power
consumption but also decreases throughput. A thorough understanding of IEEE
802.11 ad hoc networks is required to use this command effectively.
Command
wmiconfig eth1 --ibssconintv
Command Parameters
UINT16 beaconInterval Specifies the beacon interval in TU units (1024 ms)
Command Values
None
Reset Values
The default beacon interval is 100 TUs (102.4 ms)
Restrictions
This command can only be issued before the AR6000 device starts an ad hoc network
See Also
<EFBFBD>SET_IBSS_PM_CAPS<EFBFBD>
=====================================================================
Name
SET_BIT_RATE
Synopsis
The host uses this command to set the AR6000 device to a specific fixed rate.
Command
wmiconfig eth1 --setfixrates <rate_0> ... <rate_n>
Command Parameters
INT8 rateIndex
A WMI_BIT_RATE value
{
RATE_AUTO = -1
RATE_1Mb = 0
RATE_2Mb = 1
RATE_5_5M = 2
RATE_11Mb = 3
RATE_6Mb = 4
RATE_9Mb = 5
RATE_12Mb = 6
RATE_18Mb = 7
RATE_24Mb = 8
RATE_36Mb = 9
RATE_48Mb = 10
RATE_54Mb = 11
} WMI_BIT_RATE
Command Values
See command parameters
Reset Values
The dynamic rate is determined by the AR6000 device
Restrictions
This command is intended for use only during development/debug; it is not
intended for use in production
See Also
<EFBFBD>GET_BIT_RATE<EFBFBD>
=====================================================================
Name
SET_BMISS_TIME
Synopsis
This command sets the beacon miss (BMISS) time, which the AR6000 hardware use
to recognize missed beacons. When an excessive number (15) of consecutive beacons
are missed, the AR6000 consider switching to a different BSS. The time can be
specified in number of beacons or in TUs.
Command(s)
wmiconfig eth1 --setbmissbeacons=<val>
wmiconfig eth1 --setbmisstime=<val>
Command Parameters
UINT16 bmissTime Specifies the beacon miss time
[1000...5000] in TUs (1024 ms)
UINT16 bmissbeacons Specifies the number of beacons [5...50]
Command Values
None
Reset Values
bmissTime is 1500 TUs (1536 ms)
Restrictions
None
=====================================================================
Name
SET_BSS_FILTER
Synopsis
The host uses this to inform the AR6000 device of the types of networks about which
it wants to receive information from the <EFBFBD>BSSINFO<EFBFBD> event. As the device performs
either foreground or background scans, it applies the filter and sends <EFBFBD>BSSINFO<EFBFBD>
events only for the networks that pass the filter. If any of the bssFilter or the ieMask
filter matches, a BSS Info is sent to the host. The ieMask currently is used as a match
for the IEs in the beacons, probe reponses and channel switch action management
frame. See also <EFBFBD>Scan and Roam<EFBFBD> on page C-1.
The BSS filter command has been enhanced to support IE based filtering. The IEs can
be specified as a bitmask through this command using this enum.
Command
wmiconfig eth1 <EFBFBD>filter = <filter> --ieMask 0x<mask>
Command Parameters
UINT8 BssFilter
Command Values
typedef struct {
A_UINT8 bssFilter; See WMI_BSS_FILTER
A_UINT32 ieMask;
} __ATTRIB_PACK WMI_BSS_FILTER_CMD;
The ieMask can take this combination of values:
enum {
BSS_ELEMID_CHANSWITCH = 0x01
BSS_ELEMID_ATHEROS = 0x02,
}
Reply Value
None
Reset Value
BssFilter = NONE_BSS_FILTER (0)
Restrictions
None
See Also
<EFBFBD>CONNECT_CMD<EFBFBD>
=====================================================================
Name
SET_BT_PARAMS
Synopsis
This command is used to set the status of a Bluetooth stream or set Bluetooth
coexistence register parameters. The stream may be an SCO or an A2DP stream and
its status can be started/stopped/suspended/resumed.
Command
wmiconfig <EFBFBD>setBTparams <paramType> <params>
Command Parameters
struct {
union {
BT_PARAMS_SCO scoParams;
BT_PARAMS_A2DP a2dpParams;
BT_PARAMS_MISC miscParams;
BT_COEX_REGS regs;
} info;
A_UINT8 paramType;
struct {
A_UINT8 noSCOPkts; Number of SCO packets between consecutive PS-POLLs
A_UINT8 pspollTimeout;
A_UINT8 stompbt;
} BT_PARAMS_SCO;
struct {
A2DP BT stream parameters
A_UINT32 period;
A_UINT32 dutycycle;
A_UINT8 stompbt;
} BT_PARAMS_A2DP;
struct {
union {
WLAN_PROTECT_POLICY_TYPE protectParams;
A_UINT16 wlanCtrlFlags;
}info;
A_UINT8 paramType;
} BT_PARAMS_MISC;
struct {
BT coexistence registers values
A_UINT32 mode; Coexistence mode
A_UINT32 scoWghts; WLAN and BT weights
A_UINT32 a2dpWghts;
A_UINT32 genWghts;
A_UINT32 mode2; Coexistence mode2
A_UINT8 setVal;
} BT_COEX_REGS;
Command Values
None defined
Reset Value
None
Restrictions
None
=====================================================================
Name
SET_BT_STATUS
Synopsis
Sets the status of a Bluetooth stream. The stream may be a SCO or an A2DP stream
and its status can be started/stopped/suspended/resumed.
Command
wmiconfig <EFBFBD>setBTstatus <streamType> <status>
Command Parameters
{
A_UINT8 streamType; Stream type
A_UINT8 status; Stream status
}WMI_SET_BT_STATUS_CMD;
Command Values
{
BT_STREAM_UNDEF = 0
BT_STREAM_SCO
SCO stream
BT_STREAM_A2DP
A2DP stream
BT_STREAM_MAX
} BT_STREAM_TYPE;
{
BT_STATUS_UNDEF = 0
BT_STATUS_START
BT_STATUS_STOP
BT_STATUS_RESUME
BT_STATUS_SUSPEND
BT_STATUS_MAX
} BT_STREAM_STATUS;
Reset Value
None defined
Restrictions
None
=====================================================================
Name
SET_CHANNEL_PARAMETERS
Synopsis
Configures various WLAN parameters related to channels, sets the wireless mode,
and can restrict the AR6000 device to a subset of available channels. The list of
available channels varies depending on the wireless mode and the regulatory
domain. The device never operates on a channel outside of its regulatory domain. The
device starts to scan the list of channels right after this command.
Command
wmiconfig eth1 --wmode <mode> <list>
Command Parameters
UINT8 phyMode See Values below.
UINT8 numberOfChannels
Number of channels in the channel array that
follows. If = 0, then the device uses all of the
channels permitted by the regulatory domain
and by the specified phyMode.
UINT16 channel[numberOfChannels]
Array listing the subset of channels (expressed
as frequencies in MHz) the host wants the
device to use. Any channel not permitted by
the specified phyMode or by the specified
regulatory domain is ignored by the device.
Command Values
phyMode = {
Wireless mode
11a = 0x01
11g = 0x02
11ag = 0x03
11b = 0x04
11g only = 0x05
}
Reset Values
phyMode
11ag
802.11a/g modules
11g
802.11g module
channels
Defaults to all channels permitted by the
current regulatory domain.
Restrictions
This command, if issued, should be issued soon after reset and prior to the first
connection. This command should only be issued in the DISCONNECTED state.
=====================================================================
Name
SET_DISC_TIMEOUT
Synopsis
The host uses this command to configure the amount of time that the AR6000 should
spend when it attempts to reestablish a connection after losing link with its current
BSS. If this time limit is exceeded, the AR6000 send a <EFBFBD>DISCONNECT<EFBFBD> event. After
sending the <EFBFBD>DISCONNECT<EFBFBD> event the AR6000 continues to attempt to reestablish a
connection, but they do so at the interval corresponding to a foreground scan as
established by the <EFBFBD>SET_SCAN_PARAMS<EFBFBD> command.
A timeout value of 0 indicates that the AR6000 will disable all autonomous roaming,
so that the AR6000 will not perform any scans after sending a <EFBFBD>DISCONNECT<EFBFBD>
event to the host. The state is maintained until a shutdown or host sets different
timeout value from 0.
Command
wmiconfig eth1 --disc=<timeout in seconds>
Command Parameters
UINT8 disconnectTimeout
Specifies the time limit (in seconds) after
which a failure to reestablish a connection
results in a <EFBFBD>DISCONNECT<EFBFBD> event
Command Values
None
Reset Values
disconnectTimeout is 10 seconds
Restrictions
This command can only be issued while in a DISCONNECTED state
=====================================================================
Name
SET_FIXRATES
Synopsis
By default, the AR6000 device uses all PHY rates based on mode of operation. If the
host application requires the device to use subset of supported rates, it can set those
rates with this command. In 802.11g mode, the AR6000 device takes the entire
802.11g basic rate set and the rates specified with this command and uses it as the
supported rate set.
This rate set is advertised in the probe request and the assoc/re-assoc request as
supported rates. Upon successful association, the device modifies the rate set pool
using the: intersection of AP-supported rates with the union of the 802.11g basic rate
set and rates set using this command. The device picks transmission rates from this
pool based on a rate control algorithm.
Command
TBD
Command Parameters
A_UINT16 fixRateMask;
The individual bit is an index for rate table,
and setting the that index to 1 would set that
corresponding rate. E.g., fixRateMask = 9
(1001) sets 1 Mbps and 11 Mbps.
Command Values
None
Reset Value
None defined
Restrictions
None
See Also
<EFBFBD>GET_FIXRATES<EFBFBD>
=====================================================================
Name
SET_WHAL_PARAM
Synopsis
An internal AR6000 command that is used to set certain hardware parameters. The
description of this command is in $WORKAREA/include/halapi.h.
Command
TBD
Command Parameters
ATH_HAL_SETCABTO_CMDID
Sets the timeout waiting for the multicast
traffic after a DTIM beacon (in TUs).
Command Values
None
Reset Value
Default = 10 TUs
Restrictions
This command should be executed before issuing a connect command.
=====================================================================
Name
SET_HOST_SLEEP_MODE
Synopsis
The host uses this command to set the host mode to asleep or awake. All packets are
delivered to the host when the host mode is awake. When host mode is asleep, only if
WoW is enabled and the incoming packet matches one of the specified WoW
patterns, will the packet be delivered to the host. The host will also be woken up by
the target for pattern-matching packets and important events.
Command
wmiconfig <EFBFBD>sethostmode=<asleep/awake>
Command Parameters
A_BOOL awake Set the host mode to awake
A_BOOL asleep Set the host mode to asleep
Command Values
1 = awake, 0 = asleep
Reset Value
None defined (default host mode is awake)
Restrictions
None
=====================================================================
Name
SET_IBSS_PM_CAPS
Synopsis
Used to support a non-standard power management scheme for an ad hoc wireless
network consisting of up to eight stations (STAs) that support this form of power
saving (e.g., Atheros-based STAs). A thorough understanding of IEEE 802.11 ad hoc
networks is required to use this command effectively.
Command
wmiconfig eth1 --ibsspmcaps --ps=<enable/disable>
--aw=<ATIM Windows in ms>
--ttl=<Time to live in number of beacon periods>
--to=<timeout in ms>
Command Parameters
UINT8 power_saving
= 0
The non-standard power saving scheme is
disabled and maximum throughput (with no
power saving) is obtained.
= 1
Ad hoc power saving scheme is enabled (but
throughput may be decreased)
UINT16 atim_windows
Specifies the length (in ms) of the ad hoc traffic
indication message (ATIM) windows used in an ad
hoc network. All Atheros-based STAs that join the
network use this duration ATIM window.
The duration is communicated between wireless
STAs through an IE in beacons and probe responses.
The host sets atim_windows to control trade-offs
between power use and throughput. The value
chosen should be based on the beacon interval (see
the <EFBFBD>SET_BEACON_INT<EFBFBD> command) on the
expected number of STAs in the IBSS, and on the
amount of traffic and traffic patterns between STAs.
UINT16 timeout_value
Specifies the timeout (in ms). The value is the same
for all ad hoc connections, but tracks separately for
each.
Applicable only for a beacon period and used to
derive actual timeout values on the Tx and Rx sides.
On the Tx side, the value defines a window during
which the STA accepts the frame(s) from the host for a
particular connection. Until closed, the window
restarts with every frame received from the host. On
the Rx side, indicates the time until which the STA
continues accepting frames from a particular
connection. The value resets with every frame
received. The value can be used to determine the
trade off between throughput and power.
Default = 10 ms
UINT8 ttl
Specifies the value in number of beacon periods. The
value is used to set a limit on the time until which a
frame is kept alive in the AR6001 before being
discarded. Default = 5
Command Values
None
Reset Values
By default, power_saving is enabled with atim_window = 20 ms
Restrictions
Can only be issued before the AR6000 starts an ad hoc network
See Also
<EFBFBD>SET_BEACON_INT<EFBFBD>
=====================================================================
Name
SET_LISTEN_INT
Synopsis
The host uses this command to request a listen interval, which determines how often
the AR6000 device should wake up and listen for traffic. The listen interval can be set
by the TUs or by the number of beacons. The device may not be able to comply with
the request (e.g., if the beacon interval is greater than the requested listen interval, the
device sets the listen interval to the beacon interval). The actual listen interval used
by the device is available in the <EFBFBD>CONNECT<EFBFBD> event.
Command
wmiconfig eth1 --listen=<#of TUs, can range from 15 to 3000>
--listenbeacons=<#of beacons, can range from 1 to 50>
Command Parameters
UINT16 listenInterval
Specifies the listen interval in Kms
(1024 ms), ranging from 100 to 1000
UINT16 listenbeacons
Specifies the listen interval in beacons,
ranging from 1 to 50
Command Values
None
Reset Values
The device sets the listen interval equal to the beacon interval of the AP it associates
to.
Restrictions
None
=====================================================================
Name
SET_LPREAMBLE
Synopsis
Overrides the short preamble capability of the AR6000 device
Command
TBD
Command Parameters
WMI_LPREAMBLE_DISABLED
The device is short-preamble capable
WMI_LPREAMBLE_ENABLED
The device supports only the long-
preamble mode
Command Values
None
Reset Value
None defined
Restrictions
None
=====================================================================
Name
SET_MAX_SP_LEN
Synopsis
Set the maximum service period; indicates the number of packets the AR6001 can
receive from the AP when triggered
Command
wmiconfig eth1 --setMaxSPLength <maxSPLen>
Command Parameters
UINT8 maxSPLen
An APSD_SP_LEN_TYPE value
Command Values
{
DELIVER_ALL_PKT = 0x0
DELIVER_2_PKT = 0x1
DELIVER_4_PKT = 0x2
DELIVER_6_PKT = 0x3
}APSD_SP_LEN_TYPE
Reset Values
maxSPLen is DELIVER_ALL_PKT
Restrictions
None
=====================================================================
Name
SET_OPT_MODE
Synopsis
Special feature, sets the special mode on/off
Command
wmiconfig eth1 --mode <mode>
Set the optional mode, where mode is special or off
Command Parameters
enum {
SPECIAL_OFF
SPECIAL_ON
} OPT_MODE_TYPE;
Command Values
Reset Value
Mode = Off
Restrictions
None
=====================================================================
Name
SET_PMKID
Synopsis
The host uses this command to enable or disable a pairwise master key ID (PMKID)
in the AR6000 PMKID cache. The AR6000 clears its PMKID cache on receipt of a
DISCONNECT command from the host. Individual entries in the cache might be
deleted as the AR6000 detect new APs and decides to remove old ones.
Command
wmiconfig eth1 --setbsspmkid --bssid=<aabbccddeeff>
--bsspmkid=<pmkid>
Command Parameters
UINT8 bssid[6]
The MAC address of the AP that the
PMKID corresponds to (6 bytes in hex
format)
UINT8 enable
Either PMKID_DISABLE (0) to disable
the PMKID or PMKID_ENABLE (1) to
enable it (16 bytes in hex format)
UINT8 pmkid[16]
Meaningful only if enable is
PMKID_ENABLE, when it is the PMKID
that the AR6000 should use on the next
reassociation with the specified AP
Command Values
enable
= 0 (disable), 1 (enable)
PKMID enabled/disabled
Reset Values
None defined
Restrictions
Only supported in infrastructure networks
=====================================================================
Name
SET_PMKID_LIST_CMD
Synopsis
Configures the list of PMKIDs on the firmware.
Command
wmiconfig --setpmkidlist --numpmkid=<n> --pmkid=<pmkid_1>
... --pmkid=<pmkid_n>
Where n is the number of pmkids (maximum = 8) and pmkid_i is the ith pmkid (16
bytes in hex format)
Command Parameters
{
A_UINT8 pmkid[WMI_PMKID_LEN];
} __ATTRIB_PACK WMI_PMKID;
{
A_UINT32 numPMKID;
WMI_PMKID pmkidList[WMI_MAX_PMKID_CACHE];
} __ATTRIB_PACK WMI_SET_PMKID_LIST_CMD;
Command Values
None
Reset Values
None
Restrictions
Supported only in infrastructure modes
=====================================================================
Name
SET_POWER_MODE
Synopsis
The host uses this command to provide the AR6000 device with guidelines on the
desired trade-off between power utilization and performance.
In normal power mode, the device enters a sleep state if they have nothing to do,
which conserves power but may cost performance as it can take up to 2 ms to
resume operation after leaving sleep state.
In maximum performance mode, the device never enters sleep state, thus no time
is spent waking up, resulting in higher power consumption and better
performance.
Command
TBD
Command Parameters
UINT8 powerMode
WMI_POWER_MODE value
{
REC_POWER = 1
(Recommended setting) Tries to conserve
power without sacrificing performance
MAX_PERF_POWER = 2
Setting that maximizes performance at
the expense of power
All other values are reserved
} WMI_POWER_MODE
Command Values
See command parameters
Reset Values
powerMode is REC_POWER
Restrictions
This command should only be issued in the DISCONNECTED state for the
infrastructure network.
For a PM-disabled ad hoc network, the power mode should remain in
MAX_PERF_POWER.
For a PM-enabled ad hoc network, the device can have REC_POWER or
MAX_PERF_POWER set, but either way it must follow the power save ad hoc
protocol. The host can change power modes in the CONNECTED state.
Host changes to the PS setting when the STA is off the home channel take no effect
and cause a TARGET_PM_FAIL event.
=====================================================================
Name
SET_POWER_PARAMS
Synopsis
The host uses this command to configure power parameters
Command
wmiconfig eth1 --pmparams --it=<ms> --np=<number of PS POLL>
--dp=<DTIM policy: ignore/normal/stick>
Command Parameters
UINT16 idle_period
Length of time (in ms) the AR6000 device
remains awake after frame Rx/Tx before going
to SLEEP state
UINT16 pspoll_number
The number of PowerSavePoll (PS-poll)
messages the device should send before
notifying the AP it is awake
UINT16 dtim_policy
A WMI_POWER_PARAMS_CMD value
{
IGNORE_DTIM =1
The device does not listen to any content after
beacon (CAB) traffic
NORMAL_DTIM = 2
DTIM period follows the listen interval (e.g., if
the listen interval is 4 and the DTIM period is 2,
the device wakes up every fourth beacon)
STICK_DTIM = 3
Device attempt to receive all CAB traffic (e.g., if
the DTIM period is 2 and the listen interval is 4,
the device wakes up every second beacon)
} WMI_POWER_PARAMS_CMD
Command Parameters
See command parameters
Reset Values
idle_period
200 ms
pspoll_number
= 1
dtim_policy
= NORMAL_DTIM
Restrictions
None
=====================================================================
Name
SET_POWERSAVE_PARAMS
Synopsis
Set the two AR6000 power save timers (PS-POLL timer and APSD trigger timer) and
the two ASPD TIM policies
Command
wmiconfig eth1--psparams --psPollTimer=<psPollTimeout in ms>
--triggerTimer=<triggerTimeout in ms> --apsdTimPolicy=<ignore/
adhere> --simulatedAPSDTimPolicy=<ignore/adhere>
Command Parameters
typedef struct {
A_UINT16 psPollTimeout;
Timeout (in ms) after sending PS-POLL; the
AR6000 device sleeps if it does not receive a
data packet from the AP
A_UINT16 triggerTimeout;
Timeout (in ms) after sending a trigger; the
device sleeps if it does not receive any data
or null frame from the AP
APSD_TIM_POLICY apsdTimPolicy;
TIM behavior with queue APSD enabled
APSD_TIM_POLICY simulatedAPSD
TimPolicy;
TIM behavior with simulated APSD
enabled
typedef enum {
IGNORE_TIM_ALL_QUEUES_APSD = 0,
PROCESS_TIM_ALL_QUEUES_APSD = 1,
IGNORE_TIM_SIMULATED_APSD = 2,
POWERSAVE_TIMERS_POLICY = 3,
} APSD_TIM_POLICY;
Command Values
None
Reset Values
psPollTimeout is 50 ms; triggerTimeout is 10 ms;
apsdTimPolicy = IGNORE_TIM_ALL_QUEUES_APSD;
simulatedAPSDTimPolicy = POWERSAVE_TIMERS_POLICY
Restrictions
When this command is used, all parameters must be set; this command does not
allow setting only one parameter.
=====================================================================
Name
SET_PROBED_SSID
Synopsis
The host uses this command to provide a list of up to MAX_PROBED_SSID_INDEX
(six) SSIDs that the AR6000 device should actively look for. It lists the active SSID
table. By default, the device actively looks for only the SSID specified in the
<EFBFBD>CONNECT_CMD<EFBFBD> command, and only when the regulatory domain allows active
probing. With this command, specified SSIDs are probed for, even if they are hidden.
Command
wmiconfig eth1 --ssid=<ssid> [--num=<index>]
Command Parameters
{
A_UINT8 numSsids
A number from 0 to
MAX_PROBED_SSID_INDEX indicating
the active SSID table entry index for this
command (if the specified entry index
already has an SSID, the SSID specified in
this command replaces it)
WMI_PROBED_SSID_INFO probedSSID[1]
} WMI_PROBED_SSID_CMD
{
A_UINT8 flag
WMI_SSID_FLAG indicates the current
entry in the active SSID table
A_UINT8 ssidLength
Length of the specified SSID in bytes.
If = 0, the entry corresponding to the
index is erased
A_UINT8 ssid[32]
SSID string actively probed for when
permitted by the regulatory domain
} WMI_PROBED_SSID_INFO
Command Values
WMI_SSID_FLAG
{
DISABLE_SSID_FLAG = 0
Disables entry
SPECIFIC_SSID_FLAG = 1
Probes specified SSID
ANY_SSID_FLAG = 2
Probes for any SSID
} WMI_SSID_FLAG
Reset Value
The entries are unused.
Restrictions
None
=====================================================================
Name
SET_REASSOC_MODE
Synopsis
Specify whether the disassociated frame should be sent or not upon reassociation.
Command
wmiconfig eth1 --setreassocmode <mode>
Command Parameters
UINT8 mode
Command Values
mode
= 0x00
Send disassoc to a previously connected AP
upon reassociation
= 0x01
Do not send disassoc to previously connected
AP upon reassociation
Reset Values
None defined
Restrictions
None
=====================================================================
Name
SET_RETRY_LIMITS
Synopsis
Allows the host to influence the number of times that the AR6000 device should
attempt to send a frame before they give up.
Command
wmiconfig --setretrylimits <frameType> <trafficClass> <maxRetries>
<enableNotify>
Command Parameters
{
UINT8 frameType
A WMI_FRAMETYPE specifying
which type of frame is of interest.
UINT8 trafficClass
Specifies a traffic class (see
<EFBFBD>CREATE_PSTREAM<EFBFBD>). This
parameter is only significant when
frameType = DATA_FRAMETYPE.
UINT8 maxRetries
Maximum number of times the
device attempts to retry a frame Tx,
ranging from WMI_MIN_RETRIES
(2) to WMI_MAX_RETRIES (15). If
the special value 0 is used,
maxRetries is set to 15.
A_UINT8 enableNotify
Notify when enabled
} WMI_RETRY_LIMIT_INFO
{
A_UINT8 numEntries
WMI_RETRY_LIMIT_INFO retryLimitInfo[1]
} WMI_SET_RETRY_LIMITS_CMD
Command Values
{
MGMT_FRAMETYPE = 0 Management frame
CONTROL_FRAMETYPE = 1 Control frame
DATA_FRAMETYPE = 2 Data frame
} WMI_FRAMETYPE
Reset Values
Retries are set to 15
Restrictions
None
=====================================================================
Name
SET_ROAM_CTRL
Synopsis
Affects how the AR6000 device selects a BSS. The host uses this command to set and
enable low RSSI scan parameters. The time period of low RSSI background scan is
mentioned in scan period. Low RSSI scan is triggered when the current RSSI
threshold (75% of current RSSI) is equal to or less than scan threshold.
Low RSSI roam is triggered when the current RSSI threshold falls below the roam
threshold and roams to a better AP by the end of the scan cycle. During Low RSSI
roam, if the STA finds a new AP with an RSSI greater than roam RSSI to floor, during
scan, it roams immediately to it instead of waiting for the end of the scan cycle. See
also <EFBFBD>Scan and Roam<EFBFBD> on page C-1.
Command
wmiconfig --roam <roamctrl> <info>, where info is <scan period>
<scan threshold> <roam threshold> <roam rssi floor>
Command Parameters
A_UINT8 roamCtrlType;
Command Values
WMI_FORCE_ROAM = 1
Roam to the specified BSSID
WMI_SET_ROAM_MODE = 2
Default, progd bias, no roam
WMI_SET_HOST_BIAS = 3
Set the host bias
WMI_SET_LOWRSSI_SCAN_PARAMS = 4
Info parameters
A_UINT8 bssid[ATH_MAC_LEN];
WMI_FORCE_ROAM
A_UINT8 roamMode;
WMI_SET_ROAM_MODE
A_UINT8 bssBiasInfo;
WMI_SET_HOST_BIAS
A_UINT16 lowrssi_scan_period;
WMI_SET_LOWRSSI_SCAN_PARAMS
A_INT16
lowrssi_scan_threshold;
WMI_SET_LOWRSSI_SCAN_PARAMS
A_INT16 lowrssi_roam_threshold;
WMI_SET_LOWRSSI_SCAN_PARAMS
A_UINT8 roam_rssi_floor;
WMI_SET_LOWRSSI_SCAN_PARAMS
Reset Value
None defined (default lowrssi scan is disabled. Enabled only when scan period is set.)
Restrictions
None
=====================================================================
Name
SET_RTS
Synopsis
Decides when RTS should be sent.
Command
wmiconfig eth1 --setRTS <pkt length threshold>
Command Parameters
A_UINT16
threshold;
Command parameter threshold in bytes. An RTS is
sent if the data length is more than this threshold.
The default is to NOT send RTS.
Command Values
None
Reset Value
Not to send RTS.
Restrictions
None
=====================================================================
Name
SET_SCAN_PARAMS
Synopsis
The host uses this command to set the AR6000 scan parameters, including the duty
cycle for both foreground and background scanning. Foreground scanning takes
place when the AR6000 device is not connected, and discovers all available wireless
networks to find the best BSS to join. Background scanning takes place when the
device is already connected to a network and scans for potential roaming candidates
and maintains them in order of best to worst. A second priority of background
scanning is to find new wireless networks.
The device initiates a scan when necessary. For example, a foreground scan is always
started on receipt of a <EFBFBD>CONNECT_CMD<EFBFBD> command or when the device cannot find
a BSS to connect to. Foreground scanning is disabled by default until receipt of a
CONNECT command. Background scanning is enabled by default and occurs every
60 seconds after the device is connected.
The device implements a binary backoff interval for foreground scanning when it
enters the DISCONNECTED state after losing connectivity with an AP or when a
CONNECT command is received. The first interval is ForegroundScanStartPeriod,
which doubles after each scan until the interval reaches ForegroundScanEndPeriod.
If the host terminates a connection with DISCONNECT, the foreground scan period
is ForegroundScanEndPeriod. All scan intervals are measured from the time a full
scan ends to the time the next full scan starts. The host starts a scan by issuing a
<EFBFBD>START_SCAN<EFBFBD> command. See also <EFBFBD>Scan and Roam<EFBFBD> on page C-1.
Command
wmiconfig eth1 --scan --fgstart=<sec> --fgend=<sec> --bg=<sec> --
act=<msec> --pas=<msec> --sr=<short scan ratio> --scanctrlflags
<connScan> <scanConnected> <activeScan> <reportBSSINFO>
Command Parameters
UINT16 fgStartPeriod
First interval used by the device when it
disconnects from an AP or receives a
CONNECT command, specified in seconds (0<EFBFBD>
65535). If = 0, the device uses the reset value.
If = 65535, the device disables foreground
scanning.
UINT16 fgEndPeriod
The maximum interval the device waits between
foreground scans specified in seconds (from
ForegroundScanStartPeriod to 65535). If = 0, the
device uses the reset value.
UINT16 bgScanPeriod
The period of background scan specified in
seconds (0<EFBFBD>65535). By default, it is set to the reset
value of 60 seconds. If 0 or 65535 is specified, the
device disables background scanning.
UINT16 maxactChDwellTime
The period of time the device stays on a
particular channel while active scanning. It is
specified in ms (10<EFBFBD>65535). If the special value of
0 is specified, the device uses the reset value.
UINT16 PasChDwellTime
The period of time the device remains on a
particular channel while passive scanning. It is
specified in ms (10<EFBFBD>65535). If the special value of
0 is specified, the device uses the reset value.
UINT8 shortScanRatio
Number of short scans to perform for each
long scan.
UINT8 scanCtrlFlasgs
UINT16 minactChDwellTime
Specified in ms
UINT32 maxDFSchActTime
The maximum time a DFS channel can stay
active before being marked passive, specified in
ms.
Command Values
None
Reset Values
ForegroundScanStart
Period
1 sec
ForegroundScanEndPeriod
60 sec
BackgroundScanPeriod
60 sec
ActiveChannelDwellTime
105 ms
=====================================================================
Name
SET_TKIP_COUNTERMEASURES
Synopsis
The host issues this command to tell the target whether to enable or disable TKIP
countermeasures.
Command
TBD
Command Parameters
UINT8 WMI_TKIP_CM_ENABLE
Enables the countermeasures
UINT8 TKIP_CM_DISABLE
Disables the countermeasures
Command Values
None
Reset Values
By default, TKIP MIC reporting is disabled
Restrictions
None
=====================================================================
Name
SET_TX_PWR
Synopsis
The host uses this command to specify the Tx power level of the AR6000. Cannot be
used to exceed the power limit permitted by the regulatory domain. The maximum
output power is limited in the chip to 31.5 dBm; the range is 0 <EFBFBD> 31.5 dbm.
Command
wmiconfig --power <dbM>
Command Parameters
UINT8 dbM
The desired Tx power specified in dbM.
If = 0, the device chooses the maximum
permitted by the regulatory domain.
Command Values
None
Reset Values
The maximum permitted by the regulatory domain
Restrictions
None
See Also
<EFBFBD>GET_TX_PWR<EFBFBD>
=====================================================================
Name
SET_VOICE_PKT_SIZE
Synopsis
If an AP does not support WMM, it has no way to differentiate voice from data.
Because the voice packet is typically small, packet in size less than voicePktSize are
assumed to be voice, otherwise it is treated as data.
Command
wmiconfig eth1 --setVoicePktSize <size-in-bytes>
Command Parameters
UINT16 voicePktSize
Packet size in octets
Command Values
None
Reset Values
voicePktSize default is 400 bytes
Restrictions
No effect if WMM is unavailable
=====================================================================
Name
SET_WMM
Synopsis
Overrides the AR6000 device WMM capability
Command
wmiconfig eth1 --setwmm <enable>
Command Parameters
WMI_WMM_ENABLED
Enables WMM
WMI_WMM_DISABLED
Disables WMM support
Command Values
0 = disabled
1 = enabled
Reset Value
WMM Disabled
Restrictions
None
=====================================================================
Name
SET_WMM_TXOP
Synopsis
Configures TxOP Bursting when sending traffic to a WMM capable AP
Command
wmiconfig eth1 --txopbursting <burstEnable>
<burstEnable>
= 0
Disallow TxOp bursting
= 1
Allow TxOp bursting
Command Parameters
txopEnable
= WMI_TXOP_DISABLED
Disabled
= WMI_TXOP_ENABLED
Enabled
Command Values
txopEnable
= 0 Disabled
= 1 Enabled
Reset Value
Bursting is off by default
Restrictions
None
=====================================================================
Name
SET_WOW_MODE
Synopsis
The host uses this command to enable or disable the WoW mode. When WoW mode
is enabled and the host is asleep, pattern matching takes place at the target level.
Only packets that match any of the pre-specified WoW filter patterns, will be passed
up to the host. The host will also be woken up by the target. Packets which do not
match any of the WoW patterns are discarded.
Command
wmiconfig <EFBFBD>setwowmode <enable/disable>
Command Parameters
A_BOOL enable_wow
Enable or disable WoW:
Command Values
= 0
Disable WoW
= 1
Enable WoW
Reset Value
None defined (default WoW mode is disabled).
Restrictions
None
See Also
<EFBFBD>GET_WOW_LIST<EFBFBD>
=====================================================================
Name
SET_WSC_STATUS
Synopsis
The supplicant uses this command to inform the target about the status of the WSC
registration protocol. During the WSC registration protocol, a flag is set so the target
bypasses some of the checks in the CSERV module. At the end of the registration, this
flag is reset.
Command
N/A
Command Parameters
A_BOOL status
= 1 WSC registration in progress
= 0 WSC protocol not running
Reply Parameters
None
Reset Value
None defined (default = 0)
Restrictions
None
=====================================================================
Name
SNR_THRESHOLD_PARAMS
Synopsis
Configures how the AR6000 device monitors and reports SNR of the connected BSS,
used as a link quality metric.
Command
--snrThreshold <weight> <upper_threshold_1> ...
<upper_threshold_4> <lower_threshold_1> ... <lower_threshold_4>
<pollTimer>
Command Parameters
<weight>
Share with rssiThreshold. Range in [1, 16], used
in the formula to calculate average RSSI
<upper_threshold_x>
Above thresholds expressed in db, in ascending
order
<lower_threshold_x>
Below thresholds expressed in db, in ascending
order
<pollTimer>
The signal strength sampling frequency in
seconds. If polltime = 0, signal strength
sampling is disabled
Command Values
None
Reset Value
None defined
Restrictions
None
=====================================================================
Name
START_SCAN
Synopsis
The host uses this command to start a long or short channel scan. All future scans are
relative to the time the AR6000 device processes this command. The device performs
a channel scan on receipt of this command, even if a scan was already in progress.
The host uses this command when it wishes to refresh its cached database of wireless
networks. The isLegacy field will be removed (0 for now) because it is achieved by
setting CONNECT_PROFILE_MATCH_DONE in the CONNECT command. See also
<EFBFBD>Scan and Roam<EFBFBD>
Command
wmiconfig eth1 --startscan <scan type> <forcefgscan> 0
<homeDwellTime> <forceScanInterval>
Command Parameters
UINT8 scanType
WMI_SCAN_TYPE
Command Values
{
WMI_LONG_SCAN =0x0
Requests a full scan
WMI_SHORT_SCAN =0x1
Requests a short scan
} WMI_SCAN_TYPE
A_BOOL forceFgScan
forceFgScan
= 0
Disable the foreground scan
forceFgScan
= 1
Forces a foreground scan
A_UINT32 homeDwellTime
Maximum duration in the home
channel (in ms)
A_UINT32 forceScanInterval
Time interval between scans (in ms)
A_UINT32 scanType
WMI_SCAN_TYPE
Reset Value
Disable forcing foreground scan
Restrictions
isLegacy field will no longer be supported (pass as 0 for now)
=====================================================================
Name
SYNCHRONIZE
Synopsis
The host uses this command to force a synchronization point between the command
and data paths
Command
TBD
Command Parameters
None
Command Values
None
Reset Values
None
Restrictions
None
=====================================================================
Name
TARGET_ERROR_REPORT_BITMASK
Synopsis
Allows the host to control <EFBFBD>ERROR_REPORT<EFBFBD> events from the AR6000 device.
If error reporting is disabled for an error type, a count of errors of that type is
maintained by the device.
If error reporting is enabled for an error type, an <EFBFBD>ERROR_REPORT<EFBFBD> event is
sent when an error occurs and the error report bit is cleared.
Error counts for each error type are available through the <EFBFBD>GET_TARGET_STATS<EFBFBD>
command.
Command
wmiconfig eth1 --setErrorReportingBitmask
Command Parameters
UINT32 bitmask
Represents the set of
WMI_TARGET_ERROR_VAL error types
enabled for reporting
Command Values
{
WMI_TARGET_PM_ERR_FAIL = 0x00000001
Power save fails (only two cases):
Retry out of null function/QoS null
function to associated AP for PS
indication'
Host changes the PS setting when
STA is off home channel
WMI_TARGET_KEY_NOT_FOUND = 0x00000002
No cipher key
WMI_TARGET_DECRYPTION_ERR = 0x00000004
Decryption error
WMI_TARGET_BMISS = 0x00000008
Beacon miss
WMI_PSDISABLE_NODE_JOIN = 0x00000010
A non-PS-enabled STA joined the
PS-enabled network
WMI_TARGET_COM_ERR = 0x00000020
Host/target communication error
WMI_TARGET_FATAL_ERR = 0x00000040
Fatal error
} WMI_TARGET_ERROR_VAL
Reset Values
Bitmask is 0, and all error reporting is disabled
Restrictions
None
=====================================================================
WMI Events
Event
Description
Page
BSSINFO
Contains information describing BSSs collected during a scan
CAC_EVENTID
Indicates signalling events in admission control
CMDERROR
The AR6000 device encounters an error while attempting to process
a command
CONNECT
The device has connected to a wireless network
DISCONNECT
The device lost connectivity with a wireless network
ERROR_REPORT
An error has occurred for which the host previously requested
notification with the command
<EFBFBD>TARGET_ERROR_REPORT_BITMASK<EFBFBD>
EXTENSION
WMI extension event
GET_PMKID_LIST_EVENT
Created in response to a <EFBFBD>GET_PMKID_LIST_CMD<EFBFBD> command
GET_WOW_LIST_EVENT
Response to the wmiconfig <EFBFBD>GET_WOW_LIST<EFBFBD> command to
retrieve the configured WoW patterns
NEIGHBOR_REPORT
Neighbor APs that match the current profile were detected
OPT_RX_FRAME_EVENT
(Special feature) informs the host of the reception of a special frame
PSTREAM_TIMEOUT
A prioritized stream has been idle for a specified interval
READY
The AR6000 device is ready to accept commands
REGDOMAIN
The regulatory domain has changed
REPORT_ROAM_DATA_EVENT
Reports the roam time calculations made by the device
(generated with a special build)
<EFBFBD>
REPORT_STATISTICS
Reply to a <EFBFBD>GET_TARGET_STATS<EFBFBD> command
ROAM_TBL_EVENT
Reports the roam table
RSSI_THRESHOLD
Signal strength from the connected AP has crossed the threshold
defined in the <EFBFBD>RSSI_THRESHOLD_PARAMS<EFBFBD> command
SCAN_COMPLETE_EVENT
A scan has completed (added status SCAN_ABORTED in release 2.0)
TEST_EVENT
Event generated by the TCMD
TKIP_MICERROR
TKIP MIC errors were detected
=====================================================================
Name
BSSINFO
Synopsis
Contains information describing one or more BSSs as collected during a scan.
Information includes the BSSID, SSID, RSSI, network type, channel, supported rates,
and IEs. BSSINFO events are sent only after the device receives a beacon or probe-
response frame that pass the filter specified in the <EFBFBD>SET_BSS_FILTER<EFBFBD> command.
BSSINFO events consist of a small header followed by a copy of the beacon or probe
response frame. The 802.11 header is not present. For formats of beacon and probe-
response frames please consult the IEEE 802.11 specification.
The beacons or probe responses containing the IE specified by the
WMI_BSS_FILTER_CMD are passed to the host through the
WMI_BSSINFO_EVENT. The event carries a 32-bit bitmask that indicates the IEs that
were detected in the management frame. The frame type field has been extended to
indicate action management frames. This would be helpful to route these frames
through the same event mechanism as used by the beacon processing function.
If the bssFilter in the SET_BSS_FILTER matches, then the ieMask is not relevant
because the BSSINFO event is sent to the host. If the bssFilter doesnot match in the
beacons/probe respones, then the ieMask match dictates whether the BSSINFO
event is sent to the host. In the case of action management frames, the ieMask is the
filter that is applied.
Event ID
0x1004
Event Parameters
typedef struct {
A_UINT16 channel;
Specifies the frequency (in MHz) where the
frame was received
A_UINT8 frameType;
A WMI_BI_FTYPE value
A_UINT8 snr;
A_INT16 rssi;
Indicates signal strength
A_UINT8 bssid[ATH_MAC_LEN];
A_UINT32 ieMask;
} _ATTRIB_PACK_WMI_BSS_INFO_HDR;
Beacon or Probe Response Frame
Event Values
{
BEACON_FTYPE = 0x1
Indicates a beacon frame
PROBERESP_FTYPE
Indicates a probe response frame
ACTION_MGMT_FTYPE
} WMI_BI_FTYPE
=====================================================================
Name
CAC_EVENTID
Synopsis
Indicates signalling events in admission control. Events are generated when
admission is accepted, rejected, or deleted by either the host or the AP. If the AP does
not respond to an admission request within a timeout of 500 ms, an event is
generated to the host.
Event ID
0x1011
Event Parameters
UINT8
ac
Access class pertaining to the
signalling
UINT8 cac_indication
Type of indication; indications are
listed in WMI_CAC_INDICATION
UINT8 statusCode
AP response status code for a
request
UINT8 tspecSuggestion[63]
Suggested TSPEC from AP
Event Values
{
CAC_INDICATION_ADMISSION = 0x00
CAC_INDICATION_ADMISSION_RESP = 0x01
CAC_INDICATION_DELETE = 0x02
CAC_INDICATION_NO_RESP = 0x03
} WMI_CAC_INDICATION
=====================================================================
Name
CMDERROR
Synopsis
Indicates that the AR6000 device encountered an error while attempting to process a
command. This error is fatal and indicates that the device requires a reset.
Event ID
0x1005
Event Parameters
UINT16 commandId
Corresponds to the command which generated
the error
UINT8 errorCode
A WMI_ERROR_CODE value
Event Values
{
INVALID_PARAM = 1
Invalid parameter
ILLEGAL_STATE = 2
Illegal state
INTERNAL_ERROR = 3
Internal Error
All other values reserved
} WMI_ERROR_CODE
=====================================================================
Name
CONNECT
Synopsis
Signals that the AR6000 connected to a wireless network. Connection occurs due to a
<EFBFBD>CONNECT<EFBFBD> command or roaming to a new AP. For infrastructure networks, shows
that the AR6000 successfully performed 802.11 authentication and AP association.
Event ID
0x1002
Event Parameters
UINT16 channel
Channel frequency (in MHz) of the network the
AR6000 are connected to
UINT8 bssid[6]
MAC address of the AP the AR6000 are
connected to or the BSSID of the ad hoc
network
UINT16 listenInterval
Listen interval (in Kms) that the AR6000 are
using
UINT 8 beaconIeLen
Length (in bytes) of the beacon IEs
UINT8 assocInfo
Pointer to an array containing beacon IEs,
followed first by association request IEs then by
association response IEs
UINT8 assocReqLen
Length (in bytes) of the assocReqIEs array
UINT8 assocRespLen
Length (in bytes) of the assocRespIEs array
Event Values
None defined
=====================================================================
Name
DISCONNECT
Synopsis
Signals that the AR6000 device lost connectivity with the wireless network.
DISCONENCT is generated when the device fails to complete a <EFBFBD>CONNECT<EFBFBD>
command or as a result of a transition from a connected state to disconnected state.
After sending the <EFBFBD>DISCONNECT<EFBFBD> event the device continually tries to re-establish
a connection. A LOST_LINK occurs when STA cannot receive beacons within the
specified time for the SET_BMISS_TIME command.
Event ID
0x1003
Event Parameters
UINT8 disconnect
Reason
A WMI_DISCONNECT_REASON value
UINT8 bssid[6]
Indicates which BSS the device was connected to
UINT8 assocRespLen
Length of the 802.11 association response frame
that triggered this event, or 0 if not applicable
UINT8 assocInfo[assocRespLen]
Copy of the 802.11 association response frame
Event Values
{
NO_NETWORK_AVAIL =0x01
Indicates that the device was unable to
establish or find the desired network
LOST_LINK =0x02
Indicates the devices is no longer receiving
beacons from the BSS it was previously
connected to
DISCONNECT_CMD =0x03
Indicates a <EFBFBD>DISCONNECT<EFBFBD> command was
processed
BSS_DISCONNECTED =0x04
Indicates the BSS explicitly disconnected the
device. Possible mechanisms include the AP
sending 802.11 management frames
(e.g., disassociate or deauthentication
messages).
AUTH_FAILED =0x05
Indicates that the device failed 802.11
authentication with the BSS
ASSOC_FAILED =0x06
Indicates that the device failed 802.11
association with the BSS
NO_RESOURCES_AVAIL =0x07
Indicates that a connection failed because the
AP had insufficient resources to complete the
connection
CSERV_DISCONNECT =0x08
Indicates that the device<EFBFBD>s connection services
module decided to disconnect from a BSS,
which can happen for a variety of reasons (e.g.,
the host marks the current connected AP as a
bad AP).
INVALID_PROFILE =0x0A
Indicates that an attempt was made to
reconnect to a BSS that no longer matches the
current profile
All other values are reserved
} WMI_DISCONNECT_REASON
=====================================================================
Name
ERROR_REPORT
Synopsis
Signals that a type of error has occurred for which the host previously requested
notification through the <EFBFBD>TARGET_ERROR_REPORT_BITMASK<EFBFBD> command.
Event ID
0x100D
Event Parameters
UINT32 errorVal
WMI_TARGET_ERROR_VAL value. See
<EFBFBD>TARGET_ERROR_REPORT_BITMASK<EFBFBD>.
Event Values
errorVal
= 0x00000001
Power save fails
= 0x00000002
No cipher key
= 0x00000004
Decryption error
= 0x00000008
Beacon miss
= 0x00000010
A non-power save disabled node has joined
the PS-enabled network
=====================================================================
Name
EXTENSION
Synopsis
The WMI is used mostly for wireless control messages to a wireless module that
apply to wireless module management regardless of the target platform
implementation. However, some events peripherally related to wireless management
are desired during operation. These wireless extension events may be platform-
specific or implementation-dependent. See <EFBFBD>WMI Extension Commands<EFBFBD>
Event ID
0x1010
=====================================================================
Name
GET_PMKID_LIST_EVENT
Synopsis
Generated by firmware in response to a <EFBFBD>GET_PMKID_LIST_CMD<EFBFBD> command.
Event Parameters
typedef struct {
A_UINT32 numPMKID;
Contains the number of PMKIDs in the reply
WMI_PMKID pmkidList[1];
} __ATTRIB_PACK WMI_PMKID_LIST_REPLY;
Event Values
None
=====================================================================
Name
GET_WOW_LIST_EVENT
Synopsis
Response to the wmiconfig <EFBFBD>getwowlist command to retrieve the configured Wake on
Wireless patterns
Event ID
0x10018
Event Parameters
{
A_UINT8 num_filters
Total number of patterns in the list
A_UINT8 this_filter_num
The filter number
A_UINT8 wow_mode
Shows whether WoW is enabled or disabled
A_UINT8 host_mode
Shows whether the host is asleep or awake
WOW_FILTER wow_filters[1]
List of WoW filters (pattern and mask data bytes)
} WMI_GET_WOW_LIST_REPLY;
{
Each wow_filter_list element shows:
A_UINT8 wow_valid_filter
Whether the filter is valid
A_UINT8 wow_filter_list_id
Filter List ID (23 = default)
A_UINT8 wow_filter_size
Size in bytes of the filter
A_UINT8 wow_filter_offset
Offset of the pattern to search in the data packet
A_UINT8 wow_filter_mask[MASK_SIZE]
The mask to be applied to the pattern
A_UINT8 wow_filter_pattern[WOW_PATTERN_SIZE]
The pattern that to match to wake up the host
} WOW_FILTER
Event Values
None
=====================================================================
Name
NEIGHBOR_REPORT
Synopsis
Indicates the existence of neighbor APs that match the current profile. The host uses
this event to populate the PMKID cache on the AR6000 and/or to perform
preauthentication. This event is only generated in infrastructure mode.
A total of numberOfAps pairs of bssid/bssFlags exist, one pair for each AP.
Event ID
0x1008
Event Parameters
UINT8 numberOfAps
The number of APs reported about in
this event
{
UINT8 bssid[6]
MAC address of a neighbor AP
UINT8 bssFlags
A WMI_BSS_FLAGS value
}[numberOfAps]
Event Values
{
WMI_DEFAULT_BSS_FLAGS = 0
Logical OR of 1 or more
WMI_BSS_FLAGS
WMI_PREAUTH_CAPABLE_BSS
= 1
Indicates that this AP is capable of
preauthentication
WMI_PMKID_VALID_BSS
= 2
Indicates that the AR6000 have a
valid pairwise master key for this AP
} WMI_BSS_FLAGS
=====================================================================
Name
OPT_RX_FRAME_EVENT
Synopsis
Special feature, informs host of the reception of a special frame.
Event ID
0x100E
Event Parameters
{
A_UINT16 channel;
A_UINT8 frameType;
A_INT8 snr;
A_UINT8 srcAddr[ATH_MAC_LEN];
A_UINT8 bssid[ATH_MAC_LEN];
}WMI_OPT_RX_INFO_HDR
Event Values
None
=====================================================================
Name
PSTREAM_TIMEOUT
Synopsis
Indicates that a priority stream that got created as a result of priority-marked data
flow (priority marked in IP TOS) being idle for the default inactivity interval period
(specified in the <EFBFBD>CREATE_PSTREAM<EFBFBD> command) used for priority streams created
implicitly by the driver. This event is not indicated for user-created priority streams.
User-created priority streams exist until the users delete them explicitly. They do not
timeout due to data inactivity.
Event ID
0x1007
Event Parameters
A_UINT8
trafficClass
Indicated the traffic class of priority
stream that timed out
Event Values
{
WMM_AC_BE = 0
Best effort
WMM_AC_BK = 1
Background
WMM_AC_VI = 2
Video
WMM_AC_VO = 3
Voice
} TRAFFIC CLASS
=====================================================================
Name
READY
Synopsis
Indicates that the AR6000 device is prepared to accept commands. It is sent once after
power on or reset. It also indicates the MAC address of the device.
Event ID
0x1001
Event Parameters
UINT8 macAddr[6]
Device MAC address
UINT8 phyCapability
A WMI_PHY_CAPABILITY value. Indicates the
capabilities of the device wireless module<EFBFBD>s radio
Event Values
{
WMI_11A_CAPABILITY = 1
WMI_11G_CAPABILITY = 2
WMI_11AG_CAPABILITY = 3
} WMI_PHY_CAPABILITY
=====================================================================
Name
REGDOMAIN
Synopsis
Indicates that the regulatory domain has changed. It initially occurs when the
AR6000 device reads the board data information. The regulatory domain can also
change when the device is a world-mode SKU. In this case, the regulatory domain is
based on the country advertised by APs per the IEEE 802.11d specification. A
potential side effect of a regulatory domain change is a change in the list of available
channels. Any channel restrictions that exist as a result of a previous
<EFBFBD>SET_CHANNEL_PARAMETERS<EFBFBD> command are lifted.
Event ID
0x1006
Event Parameters
UINT32 regDomain
The range of 0x0000 <EFBFBD> 0x00FF
corresponds to an ISO country code.
Other regCodes are reserved for world
mode settings and specific regulatory
domains.
Event Values
None
=====================================================================
Name
REPORT_STATISTICS
Synopsis
A reply to a <EFBFBD>GET_TARGET_STATS<EFBFBD> command.
Event ID
0x100B
Event Parameters
When the statistics are sent to the host, the AR6001 clear them so that a new set of
statistics are collected for the next report.
UINT32 tx_packets
UINT32 tx_bytes
UINT32 tx_unicast_pkts
UINT32 tx_unicast_bytes
UINT32 tx_multicast_pkts
UINT32 tx_multicast_bytes
UINT32 tx_broadcast_pkts
UINT32 tx_broadcast_bytes
UINT32 tx_rts_success_cnt
UINT32 tx_packet_per_ac[4]
Tx packets per AC: [0] = BE, [1] = BK,
[2] = VI, [3] = VO
UINT32 tx_errors
Number of packets which failed Tx, due
to all failures
... REPORT_STATISTICS, continued
UINT32 tx_failed_cnt
Number of data packets that failed Tx
UINT32 tx_retry_cnt
Number of Tx retries for all packets
UINT32 tx_rts_fail_cnt
Number of RTS Tx failed count
UINT32 rx_packets
UINT32 rx_bytes
UINT32 rx_unicast_pkts
UINT32 rx_unicast_bytes
UINT32 rx_multicast_pkts
UINT32 rx_multicast_bytes
UINT32 rx_broadcast_pkts
UINT32 rx_broadcast_bytes
UINT32 rx_fragment_pkt
Number of fragmented packets received
UINT32 rx_errors
Number of Rx errors due to all failures
UINT32 rx_crcerr
Number of Rx errors due to CRC errors
UINT32 rx_key_cache_miss
Number of Rx errors due to a key not
being plumbed
UINT32 rx_decrypt_err
Number of Rx errors due to decryption
failure
UINT32 rx_duplicate_frames
Number of duplicate frames received
UINT32 tkip_local_mic_failure
Number of TKIP MIC errors detected
UINT32 tkip_counter_measures_invoked
Number of times TKIP countermeasures
were invoked
UINT32 tkip_replays
Number of frames that replayed a TKIP
encrypted frame received earlier
UINT32 tkip_format_errors
Number of frames that did not conform
to the TKIP frame format
UINT32 ccmp_format_errors
Number of frames that did not conform
to the CCMP frame format
UINT32 ccmp_replays
Number of frames that replayed a CCMP
encrypted frame received earlier
UINT32 power_save_failure_cnt
Number of failures that occurred when
the AR6001 could not go to sleep
UINT32 cs_bmiss_cnt
Number of BMISS interrupts since
connection
UINT32 cs_lowRssi_cnt
Number of the times the RSSI went below
the low RSSI threshold
UINT16 cs_connect_cnt
Number of connection times
UINT16 cs_disconnect_cnt
Number of disconnection times
UINT8 cs_aveBeacon_rssi
The current averaged value of the RSSI
from the beacons of the connected BSS
UINT8 cs_lastRoam_msec
Time that the last roaming took, in ms.
This time is the difference between
roaming start and actual connection.
Event Values
None defined
=====================================================================
Name
ROAM_TBL_EVENT
Synopsis
Reports the roam table, which contains the current roam mode and this information
for every BSS:
Event ID
0x100F
Event Parameters
A_UINT8 bssid[ATH_MAC_LEN];
BSSID
A_UINT8 rssi
Averaged RSSI
A_UINT8 rssidt
Change in RSSI
A_UINT8 last_rssi
Last recorded RSSI
A_UINT8 roam_util
Utility value used in roaming decision
A_UINT8 util
Base utility with the BSS
A_UINT8 bias
Host configured for this BSS
Event Values
roamMode
Current roam mode
= 1
RSSI based roam
= 2
Host bias-based roam
= 3
Lock to the current BSS
= 4
Autonomous roaming disabled
=====================================================================
Name
RSSI_THRESHOLD
Synopsis
Alerts the host that the signal strength from the connected AP has crossed a
interesting threshold as defined in a previous <EFBFBD>RSSI_THRESHOLD_PARAMS<EFBFBD>
command.
Event ID
0x100C
Event Parameters
UINT8 range
A WMI_RSSI_THRESHOLD_VAL
value, which indicates the range of
the average signal strength
Event Values
{
WMI_RSSI_LOWTHRESHOLD_BELOW_LOWERVAL = 1
WMI_RSSI_LOWTHRESHOLD_LOWERVAL = 2
WMI_RSSI_LOWTHRESHOLD_UPPERVAL = 3
WMI_RSSI_HIGHTHRESHOLD_LOWERVAL = 4
WMI_RSSI_HIGHTHRESHOLD_HIGHERVAL = 5
} WMI_RSSI_THRESHOLD_VAL
=====================================================================
Name
SCAN_COMPLETE_EVENT
Synopsis
Indicates the scan status. if the Scan was not completed, this event is generated with
the status A_ECANCELED.
Event ID
0x100A
Event Parameters
A_UINT8 scanStatus
Event Values
{
#define SCAN_ABORTED 16
#define SCAN_COMPLETED 0
A_UINT8 scanStatus
A_OK or A_ECANCELED
} WMI_SCAN_COMPLETE_EVENT;
=====================================================================
Name
TEST_EVENT
Synopsis
The TCMD application uses a single WMI event (WMI_TEST_EVENTID) to
communicate events from target to host. The events are parsed by the TCMD
application and WMI layer is oblivious of it.
Event ID
0x1016
Event Parameters
WMI_TEST_EVENTID
Event Values
None
=====================================================================
Name
TKIP_MICERR
Synopsis
Indicates that TKIP MIC errors were detected.
Event ID
0x1009
Event Parameters
UINT8 keyid
Indicates the TKIP key ID
UINT8 ismcast
0 = Unicast
1 = Multicast
Event Values
See event parameters
=====================================================================
WMI Extension Commands
The WMI EXTENSION command is used to multiplex a collection of
commands that:
Are not generic wireless commands
May be implementation-specific
May be target platform-specific
May be optional for a host implementation
An extension command is sent to the AR6000 targets like any other WMI
command message and uses the WMI_EXTENSION. The first field of the
payload for this EXTENSION command is another commandId, sometimes
called the subcommandId, which indicates which extension command is
being used. A subcommandId-specific payload follows the subcommandId.
All extensions (subcommandIds) are listed in the header file include/wmix.h.
See also <EFBFBD>WMI Extension Events<EFBFBD> on page B-58.
WMI Extension Commands
GPIO_INPUT_GET
Read GPIO pins configured for input
GPIO_INTR_ACK
Acknowledge and re-arm GPIO interrupts reported earlier
GPIO_OUTPUT_SET
Manage output on GPIO pins configured for output
GPIO_REGISTER_GET
Read an arbitrary GPIO register
GPIO_REGISTER_SET
Dynamically change GPIO configuration
SET_LQTHRESHOLD
Set link quality thresholds; the sampling happens at every unicast
data frame Tx, if certain thresholds are met, and corresponding
events are sent to the host
=====================================================================
Name
GPIO_INPUT_GET
Synopsis
Allows the host to read GPIO pins that are configured for input. The values read are
returned through a <EFBFBD>GPIO_DATA<EFBFBD> extension event.
NOTE: Support for GPIO is optional.
Command
N/A
Command Parameters
None
Reply Parameters
None
Reset Value
None
Restrictions
None
=====================================================================
Name
GPIO_INTR_ACK
Synopsis
The host uses this command to acknowledge and to re-arm GPIO interrupts reported
through an earlier <EFBFBD>GPIO_INTR<EFBFBD> extension event. A single <EFBFBD>GPIO_INTR_ACK<EFBFBD>
command should be used to acknowledge all GPIO interrupts that the host knows to
be outstanding (if pending interrupts are not acknowledged through
<EFBFBD>GPIO_INTR_ACK<EFBFBD>, another <EFBFBD>GPIO_INTR<EFBFBD> extension event is raised).
NOTE: Support for GPIO is optional.
Command
N/A
Command Parameters
UINT32 ack_mask
A mask of interrupting GPIO pins (e.g., ack_mask
bit [3] acknowledges an interrupt from the pin GPIO3).
Command Values
None
Reset Value
None
Restrictions
The host should acknowledge only interrupts about which it was notified.
=====================================================================
Name
GPIO_OUTPUT_SET
Synopsis
Manages output on GPIO pins configured for output.
Conflicts between set_mask and clear_mask or enable_mask and disable_mask result
in undefined behavior.
NOTE: Support for GPIO is optional.
Command
N/A
Command Parameters
UINT32 set_mask
Specifies which pins should drive a 1 out
UINT32 clear_mask
Specifies which pins should drive a 0 out
UINT32 enable_mask
Specifies which pins should be enabled for output
UINT32 disable_mask
Specifies which pins should be disabled for output
Command Values
None
Reset Value
None
Restrictions
None
=====================================================================
Name
GPIO_REGISTER_GET
Synopsis
Allows the host to read an arbitrary GPIO register. It is intended for use during
bringup/debug. The target responds to this command with a <EFBFBD>GPIO_DATA<EFBFBD> event.
NOTE: Support for GPIO is optional.
Command
N/A
Command Parameters
UINT32
gpioreg_id
Specifies a GPIO register identifier, as defined
in include/AR6000/AR6000_gpio.h
Reply Parameters
None
Reset Value
N/A
Restrictions
None
=====================================================================
Name
GPIO_REGISTER_SET
Synopsis
Allows the host to dynamically change GPIO configuration (usually handled
statically through the GPIO configuration DataSet).
NOTE: Support for GPIO is optional.
Command
N/A
Command Parameters
UINT32 gpioreg_id
Specifies a GPIO register identifier, as defined in
include/AR6000/AR6000_gpio.h
UINT32 value
Specifies a value to write to the specified
GPIO register
Command Values
None
Reset Value
Initial hardware configuration is as defined in the AR6001 or AR6002 ROCmTM
Single-Chip MAC/BB/Radio for 2.4/5 GHz Embedded WLAN Applications data sheet. This
configuration is modified by the GPIO Configuration DataSet, if one exists.
Restrictions
None
=====================================================================
Name
SET_LQTHRESHOLD
Synopsis
Set link quality thresholds, the sampling happens at every unicast data frame Tx, if
certain threshold is met, corresponding event will be sent to host.
Command
wmiconfig eth1 --lqThreshold <enable> <upper_threshold_1>...
<upper_threshold_4> <lower_threshold_1>... <lower_threshold_4>
Command Parameters
A_UINT8 enable;
A_UINT8 thresholdAbove1_Val;
A_UINT8 thresholdAbove2_Val;
A_UINT8 thresholdAbove3_Val;
A_UINT8 thresholdAbove4_Val;
A_UINT8 thresholdBelow1_Val;
A_UINT8 thresholdBelow2_Val;
A_UINT8 thresholdBelow3_Val;
A_UINT8 thresholdBelow4_Val;
Command Values
enable
= 0
Disable link quality sampling
= 1
Enable link quality sampling
thresholdAbove_Val
[1...4]
Above thresholds (value in [0,100]), in ascending
order threshold
Below_Val [1...4] = below thresholds (value
in [0,100]), in ascending order
Reset Values
None
Restrictions
None
=====================================================================
WMI Extension Events
The WMI EXTENSION event is used for a collection of events that:
Are not generic wireless events
May be implementation-specific
May be target platform-specific
May be optional for a host implementation
An extension event is sent from the AR6000 device targets to the host just like
any other WMI event message, using the WMI_EXTENSION_EVENTID. The
first field of the payload for this <EFBFBD>EXTENSION<EFBFBD> event is another commandId
(sometimes called the subcommandId) that indicates which <EFBFBD>EXTENSION<EFBFBD>
event is being used. A subcommandId-specific payload follows the
subcommandId.
All extensions (subcommandIds) are listed in the header file include/wmix.h.
See also <EFBFBD>WMI Extension Commands<EFBFBD> on page B-55.
WMI Extension Events
GPIO_ACK
Acknowledges a host set command has been processed by the device
GPIO_DATA
Response to a host<EFBFBD>s request for data
GPIO_INTR
Signals that GPIO interrupts are pending
=====================================================================
Name
GPIO_ACK
Synopsis
Acknowledges that a host set command (either <EFBFBD>GPIO_OUTPUT_SET<EFBFBD> or
<EFBFBD>GPIO_REGISTER_SET<EFBFBD>) has been processed by the AR6000 device.
NOTE: Support for GPIO is optional.
Event ID
N/A
Event Parameters
None
Event Values
None
=====================================================================
Name
GPIO_DATA
Synopsis
The AR6000 device uses this event to respond to the host<EFBFBD>s earlier request for data
(through either a <EFBFBD>GPIO_REGISTER_GET<EFBFBD> or a <EFBFBD>GPIO_INPUT_GET<EFBFBD> command).
NOTE: Support for GPIO is optional.
Event ID
N/A
Event Parameters
UINT32 value
Holds the data of interest, which is either a register value
(in the case of <EFBFBD>GPIO_REGISTER_GET<EFBFBD>) or a mask of
pin inputs (in the case of <EFBFBD>GPIO_INPUT_GET<EFBFBD>).
UINT32 reg_id
Indicates which register was read (in the case of
<EFBFBD>GPIO_REGISTER_GET<EFBFBD>) or is GPIO_ID_NONE (in the
case of <EFBFBD>GPIO_INPUT_GET<EFBFBD>)
Event Values
None
=====================================================================
Name
GPIO_INTR
Synopsis
The AR6000 device raises this event to signal that GPIO interrupts are pending.
These GPIOs may be interrupts that occurred after the last <EFBFBD>GPIO_INTR_ACK<EFBFBD>
command was issued, or may be GPIO interrupts that the host failed to acknowledge
in the last <EFBFBD>GPIO_INTR_ACK<EFBFBD>. The AR6000 will not raise another GPIO_INTR
event until this event is acknowledged through a <EFBFBD>GPIO_INTR_ACK<EFBFBD> command.
NOTE: Support for GPIO is optional.
Event ID
N/A
Event Parameters
UINT32 intr_mask
Indicates which GPIO interrupts are currently pending
UINT32 input_values
A recent copy of the GPIO input values, taken at the
time the most recent GPIO interrupt was processed
Event Values
None
=====================================================================
#endif