ath9k bluetooth coexistence#
This page documents how bluetooth coexistence is supported by ath9k.
Supported Coexistence Schemes#
Enabling bluetooth coexistence#
Bluetooth coexistence has to be manually enabled when loading ath9k by setting the btcoex_enable module parameter.
modprobe ath9k btcoex_enable=1
Cards supporting BTCOEX#
2-wire (two-chip cards with separate WLAN and BT)#
* WB197 ( AR9287 + AR3011 )
3-wire (two-chip cards with separate WLAN and BT)#
* WB195 ( AR9285 + AR3011 )
* WB225 ( AR9485 + AR3012 )
MCI (SoC-type cards with integrated WLAN and BT)#
* WB222 ( based on AR9462 )
* WB335 ( based on AR9565 )
3-wire scheme details#
Some Atheros cards in both the AR9002 and AR9003 family use this scheme in which WLAN and Bluetooth time-shares their usage of the 2.4 GHz band. Three pins are used in this scheme.
PIN |
Driven by |
Details |
---|---|---|
BT_ACTIVE |
BT |
Signals that Bluetooth device is expecting TX or RX activity. Provides WLAN with information about when the antenna is being used by Bluetooth. |
BT_PRIORITY |
BT |
At the start of BT_ACTIVE, it is asserted to indicate the priority of the Bluetooth activity. Then, this pin indicates the TX/RX status of the Bluetooth activity. |
WLAN_ACTIVE |
WLAN |
Indicates when WLAN has taken the antenna. |
PTA (Packet Traffic Arbitration ) Algorithm#
BT weights and WLAN weights are programmed in the hardware by the driver. Hardware infers the Bluetooth activity by sampling the BT_ACTIVE signal. Whenever there’s Bluetooth activity, hardware compares the assigned weight of Bluetooth traffic and the current WLAN traffic. If Bluetooth traffic has a lower priority, hardware will continue WLAN traffic, thus stomping on the Bluetooth side (and possible interference on WLAN side as well). If Bluetooth traffic has a higher priority, hardware will abort WLAN traffic and treat it as if there’s collision on-air.