2010-03-17 14:25:25 +05:30
/*
2011-05-17 13:36:18 +05:30
* Copyright ( c ) 2010 - 2011 Atheros Communications Inc .
2010-03-17 14:25:25 +05:30
*
* Permission to use , copy , modify , and / or distribute this software for any
* purpose with or without fee is hereby granted , provided that the above
* copyright notice and this permission notice appear in all copies .
*
* THE SOFTWARE IS PROVIDED " AS IS " AND THE AUTHOR DISCLAIMS ALL WARRANTIES
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS . IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
* ANY SPECIAL , DIRECT , INDIRECT , OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
* WHATSOEVER RESULTING FROM LOSS OF USE , DATA OR PROFITS , WHETHER IN AN
* ACTION OF CONTRACT , NEGLIGENCE OR OTHER TORTIOUS ACTION , ARISING OUT OF
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE .
*/
# ifndef HTC_H
# define HTC_H
# include <linux/module.h>
# include <linux/usb.h>
# include <linux/firmware.h>
# include <linux/skbuff.h>
# include <linux/netdevice.h>
2013-02-22 21:37:25 +01:00
# include <linux/etherdevice.h>
2010-03-17 14:25:25 +05:30
# include <linux/leds.h>
2010-03-30 02:52:38 +09:00
# include <linux/slab.h>
2010-03-17 14:25:25 +05:30
# include <net/mac80211.h>
# include "common.h"
# include "htc_hst.h"
# include "hif_usb.h"
# include "wmi.h"
# define ATH_STA_SHORT_CALINTERVAL 1000 /* 1 second */
2011-02-21 07:49:38 +05:30
# define ATH_AP_SHORT_CALINTERVAL 100 /* 100 ms */
2010-03-17 14:25:25 +05:30
# define ATH_ANI_POLLINTERVAL 100 /* 100 ms */
# define ATH_LONG_CALINTERVAL 30000 /* 30 seconds */
# define ATH_RESTART_CALINTERVAL 1200000 /* 20 minutes */
# define ATH_DEFAULT_BMISS_LIMIT 10
# define TSF_TO_TU(_h, _l) \
( ( ( ( u32 ) ( _h ) ) < < 22 ) | ( ( ( u32 ) ( _l ) ) > > 10 ) )
extern struct ieee80211_ops ath9k_htc_ops ;
2010-03-24 13:42:13 +05:30
extern int htc_modparam_nohwcrypt ;
2015-01-11 11:45:53 -08:00
# ifdef CONFIG_MAC80211_LEDS
2015-01-24 03:34:03 -08:00
extern int ath9k_htc_led_blink ;
2015-01-11 11:45:53 -08:00
# endif
2010-03-17 14:25:25 +05:30
enum htc_phymode {
2011-05-17 12:41:20 +05:30
HTC_MODE_11NA = 0 ,
HTC_MODE_11NG = 1
2010-03-17 14:25:25 +05:30
} ;
enum htc_opmode {
HTC_M_STA = 1 ,
HTC_M_IBSS = 0 ,
HTC_M_AHDEMO = 3 ,
HTC_M_HOSTAP = 6 ,
HTC_M_MONITOR = 8 ,
HTC_M_WDS = 2
} ;
2011-04-13 11:24:31 +05:30
# define ATH9K_HTC_AMPDU 1
2010-03-17 14:25:25 +05:30
# define ATH9K_HTC_NORMAL 2
2011-04-13 11:24:31 +05:30
# define ATH9K_HTC_BEACON 3
# define ATH9K_HTC_MGMT 4
2010-03-17 14:25:25 +05:30
# define ATH9K_HTC_TX_CTSONLY 0x1
# define ATH9K_HTC_TX_RTSCTS 0x2
struct tx_frame_hdr {
u8 data_type ;
u8 node_idx ;
u8 vif_idx ;
u8 tidno ;
2011-01-16 10:56:37 +05:30
__be32 flags ; /* ATH9K_HTC_TX_* */
2010-03-17 14:25:25 +05:30
u8 key_type ;
u8 keyix ;
2011-04-13 11:25:12 +05:30
u8 cookie ;
u8 pad ;
2010-03-17 14:25:25 +05:30
} __packed ;
struct tx_mgmt_hdr {
u8 node_idx ;
u8 vif_idx ;
u8 tidno ;
u8 flags ;
u8 key_type ;
u8 keyix ;
2011-04-13 11:25:12 +05:30
u8 cookie ;
u8 pad ;
2010-03-17 14:25:25 +05:30
} __packed ;
struct tx_beacon_header {
u8 vif_index ;
2011-04-13 11:22:59 +05:30
u8 len_changed ;
2010-03-17 14:25:25 +05:30
u16 rev ;
} __packed ;
2011-04-20 14:33:28 +05:30
# define MAX_TX_AMPDU_SUBFRAMES_9271 17
# define MAX_TX_AMPDU_SUBFRAMES_7010 22
2010-03-17 14:25:25 +05:30
struct ath9k_htc_cap_target {
2011-04-20 14:33:28 +05:30
__be32 ampdu_limit ;
2010-03-17 14:25:25 +05:30
u8 ampdu_subframes ;
2011-04-20 14:33:28 +05:30
u8 enable_coex ;
2010-03-17 14:25:25 +05:30
u8 tx_chainmask ;
2011-04-13 11:24:49 +05:30
u8 pad ;
2010-03-17 14:25:25 +05:30
} __packed ;
struct ath9k_htc_target_vif {
u8 index ;
2011-04-13 11:24:43 +05:30
u8 opmode ;
2010-03-17 14:25:25 +05:30
u8 myaddr [ ETH_ALEN ] ;
u8 ath_cap ;
2011-04-13 11:24:43 +05:30
__be16 rtsthreshold ;
u8 pad ;
2010-03-17 14:25:25 +05:30
} __packed ;
struct ath9k_htc_target_sta {
u8 macaddr [ ETH_ALEN ] ;
u8 bssid [ ETH_ALEN ] ;
u8 sta_index ;
u8 vif_index ;
u8 is_vif_sta ;
2011-05-17 12:41:31 +05:30
__be16 flags ;
2011-04-13 11:24:37 +05:30
__be16 htcap ;
__be16 maxampdu ;
u8 pad ;
2010-03-17 14:25:25 +05:30
} __packed ;
struct ath9k_htc_target_aggr {
u8 sta_index ;
u8 tidno ;
u8 aggr_enable ;
u8 padding ;
} __packed ;
# define ATH_HTC_RATE_MAX 30
# define WLAN_RC_DS_FLAG 0x01
# define WLAN_RC_40_FLAG 0x02
# define WLAN_RC_SGI_FLAG 0x04
# define WLAN_RC_HT_FLAG 0x08
2013-06-09 18:51:24 +02:00
# define ATH_RC_TX_STBC_FLAG 0x20
2010-03-17 14:25:25 +05:30
struct ath9k_htc_rateset {
u8 rs_nrates ;
u8 rs_rates [ ATH_HTC_RATE_MAX ] ;
} ;
struct ath9k_htc_rate {
struct ath9k_htc_rateset legacy_rates ;
struct ath9k_htc_rateset ht_rates ;
} __packed ;
struct ath9k_htc_target_rate {
u8 sta_index ;
u8 isnew ;
2010-04-16 11:54:03 +05:30
__be32 capflags ;
2010-03-17 14:25:25 +05:30
struct ath9k_htc_rate rates ;
} ;
2011-04-27 17:13:23 +05:30
struct ath9k_htc_target_rate_mask {
u8 vif_index ;
u8 band ;
__be32 mask ;
u16 pad ;
} __packed ;
2011-04-13 11:26:58 +05:30
struct ath9k_htc_target_int_stats {
__be32 rx ;
__be32 rxorn ;
__be32 rxeol ;
__be32 txurn ;
__be32 txto ;
__be32 cst ;
} __packed ;
struct ath9k_htc_target_tx_stats {
__be32 xretries ;
__be32 fifoerr ;
__be32 filtered ;
__be32 timer_exp ;
__be32 shortretries ;
__be32 longretries ;
__be32 qnull ;
__be32 encap_fail ;
__be32 nobuf ;
} __packed ;
struct ath9k_htc_target_rx_stats {
__be32 nobuf ;
__be32 host_send ;
__be32 host_done ;
2010-03-17 14:25:25 +05:30
} __packed ;
2011-02-21 07:48:00 +05:30
# define ATH9K_HTC_MAX_VIF 2
2011-02-21 07:49:23 +05:30
# define ATH9K_HTC_MAX_BCN_VIF 2
2011-02-21 07:48:00 +05:30
2011-02-21 07:49:15 +05:30
# define INC_VIF(_priv, _type) do { \
switch ( _type ) { \
case NL80211_IFTYPE_STATION : \
_priv - > num_sta_vif + + ; \
break ; \
case NL80211_IFTYPE_ADHOC : \
_priv - > num_ibss_vif + + ; \
break ; \
2011-02-21 07:49:23 +05:30
case NL80211_IFTYPE_AP : \
_priv - > num_ap_vif + + ; \
break ; \
2013-05-08 10:16:46 -07:00
case NL80211_IFTYPE_MESH_POINT : \
_priv - > num_mbss_vif + + ; \
break ; \
2011-02-21 07:49:15 +05:30
default : \
break ; \
} \
} while ( 0 )
# define DEC_VIF(_priv, _type) do { \
switch ( _type ) { \
case NL80211_IFTYPE_STATION : \
_priv - > num_sta_vif - - ; \
break ; \
case NL80211_IFTYPE_ADHOC : \
_priv - > num_ibss_vif - - ; \
break ; \
2011-02-21 07:49:23 +05:30
case NL80211_IFTYPE_AP : \
_priv - > num_ap_vif - - ; \
break ; \
2013-05-08 10:16:46 -07:00
case NL80211_IFTYPE_MESH_POINT : \
_priv - > num_mbss_vif - - ; \
break ; \
2011-02-21 07:49:15 +05:30
default : \
break ; \
} \
} while ( 0 )
2010-03-17 14:25:25 +05:30
struct ath9k_htc_vif {
u8 index ;
2011-02-21 07:48:53 +05:30
u16 seq_no ;
2011-02-27 09:20:40 +05:30
bool beacon_configured ;
2011-04-13 11:23:08 +05:30
int bslot ;
2011-04-13 11:23:17 +05:30
__le64 tsfadjust ;
2010-03-17 14:25:25 +05:30
} ;
2011-02-21 07:48:46 +05:30
struct ath9k_vif_iter_data {
const u8 * hw_macaddr ;
u8 mask [ ETH_ALEN ] ;
} ;
2010-03-17 14:25:25 +05:30
# define ATH9K_HTC_MAX_STA 8
# define ATH9K_HTC_MAX_TID 8
enum tid_aggr_state {
AGGR_STOP = 0 ,
AGGR_PROGRESS ,
AGGR_START ,
AGGR_OPERATIONAL
} ;
struct ath9k_htc_sta {
u8 index ;
enum tid_aggr_state tid_state [ ATH9K_HTC_MAX_TID ] ;
2014-02-03 11:45:51 +01:00
struct work_struct rc_update_work ;
struct ath9k_htc_priv * htc_priv ;
2010-03-17 14:25:25 +05:30
} ;
# define ATH9K_HTC_RXBUF 256
# define HTC_RX_FRAME_HEADER_SIZE 40
struct ath9k_htc_rxbuf {
bool in_process ;
struct sk_buff * skb ;
struct ath_htc_rx_status rxstatus ;
struct list_head list ;
} ;
struct ath9k_htc_rx {
struct list_head rxbuf ;
spinlock_t rxbuflock ;
} ;
2011-04-13 11:26:39 +05:30
# define ATH9K_HTC_TX_CLEANUP_INTERVAL 50 /* ms */
2011-05-17 12:42:34 +05:30
# define ATH9K_HTC_TX_TIMEOUT_INTERVAL 3000 /* ms */
2011-04-13 11:26:39 +05:30
# define ATH9K_HTC_TX_RESERVE 10
2011-05-17 12:42:34 +05:30
# define ATH9K_HTC_TX_TIMEOUT_COUNT 40
2011-04-13 11:25:29 +05:30
# define ATH9K_HTC_TX_THRESHOLD (MAX_TX_BUF_NUM - ATH9K_HTC_TX_RESERVE)
# define ATH9K_HTC_OP_TX_QUEUES_STOP BIT(0)
2011-04-13 11:26:18 +05:30
# define ATH9K_HTC_OP_TX_DRAIN BIT(1)
2011-04-13 11:25:00 +05:30
2011-04-13 11:25:29 +05:30
struct ath9k_htc_tx {
u8 flags ;
int queued_cnt ;
2011-04-13 11:26:18 +05:30
struct sk_buff_head mgmt_ep_queue ;
struct sk_buff_head cab_ep_queue ;
struct sk_buff_head data_be_queue ;
struct sk_buff_head data_bk_queue ;
struct sk_buff_head data_vi_queue ;
struct sk_buff_head data_vo_queue ;
2011-04-13 11:25:59 +05:30
struct sk_buff_head tx_failed ;
2011-04-13 11:25:47 +05:30
DECLARE_BITMAP ( tx_slot , MAX_TX_BUF_NUM ) ;
2011-04-13 11:26:39 +05:30
struct timer_list cleanup_timer ;
2011-04-13 11:25:29 +05:30
spinlock_t tx_lock ;
2011-04-13 11:25:00 +05:30
} ;
2010-03-17 14:25:25 +05:30
struct ath9k_htc_tx_ctl {
u8 type ; /* ATH9K_HTC_* */
2011-04-13 11:25:35 +05:30
u8 epid ;
2011-04-13 11:25:41 +05:30
u8 txok ;
2011-04-13 11:26:11 +05:30
u8 sta_idx ;
2011-04-13 11:26:39 +05:30
unsigned long timestamp ;
2010-03-17 14:25:25 +05:30
} ;
2011-04-13 11:24:31 +05:30
static inline struct ath9k_htc_tx_ctl * HTC_SKB_CB ( struct sk_buff * skb )
{
struct ieee80211_tx_info * tx_info = IEEE80211_SKB_CB ( skb ) ;
BUILD_BUG_ON ( sizeof ( struct ath9k_htc_tx_ctl ) >
IEEE80211_TX_INFO_DRIVER_DATA_SIZE ) ;
return ( struct ath9k_htc_tx_ctl * ) & tx_info - > driver_data ;
}
2010-03-17 14:25:25 +05:30
# ifdef CONFIG_ATH9K_HTC_DEBUGFS
# define TX_STAT_INC(c) (hif_dev->htc_handle->drv_priv->debug.tx_stats.c++)
2013-06-19 14:02:15 -07:00
# define TX_STAT_ADD(c, a) (hif_dev->htc_handle->drv_priv->debug.tx_stats.c += a)
2014-05-11 10:04:36 +02:00
# define RX_STAT_INC(c) (hif_dev->htc_handle->drv_priv->debug.skbrx_stats.c++)
# define RX_STAT_ADD(c, a) (hif_dev->htc_handle->drv_priv->debug.skbrx_stats.c += a)
2011-04-13 11:23:34 +05:30
# define CAB_STAT_INC priv->debug.tx_stats.cab_queued++
2010-03-17 14:25:25 +05:30
2010-05-14 11:18:54 +05:30
# define TX_QSTAT_INC(q) (priv->debug.tx_stats.queue_stats[q]++)
2011-04-13 11:24:10 +05:30
void ath9k_htc_err_stat_rx ( struct ath9k_htc_priv * priv ,
2014-05-11 10:04:36 +02:00
struct ath_rx_status * rs ) ;
2011-04-13 11:24:10 +05:30
2010-03-17 14:25:25 +05:30
struct ath_tx_stats {
u32 buf_queued ;
u32 buf_completed ;
u32 skb_queued ;
2011-04-13 11:25:59 +05:30
u32 skb_success ;
2013-06-19 14:02:15 -07:00
u32 skb_success_bytes ;
2011-04-13 11:25:59 +05:30
u32 skb_failed ;
2011-04-13 11:23:34 +05:30
u32 cab_queued ;
2012-11-21 18:13:10 +05:30
u32 queue_stats [ IEEE80211_NUM_ACS ] ;
2010-03-17 14:25:25 +05:30
} ;
2014-05-11 10:04:36 +02:00
struct ath_skbrx_stats {
2010-03-17 14:25:25 +05:30
u32 skb_allocated ;
u32 skb_completed ;
2013-06-19 14:02:15 -07:00
u32 skb_completed_bytes ;
2010-03-17 14:25:25 +05:30
u32 skb_dropped ;
} ;
struct ath9k_debug {
struct dentry * debugfs_phy ;
struct ath_tx_stats tx_stats ;
struct ath_rx_stats rx_stats ;
2014-05-11 10:04:36 +02:00
struct ath_skbrx_stats skbrx_stats ;
2010-03-17 14:25:25 +05:30
} ;
2013-06-19 14:02:15 -07:00
void ath9k_htc_get_et_strings ( struct ieee80211_hw * hw ,
struct ieee80211_vif * vif ,
u32 sset , u8 * data ) ;
int ath9k_htc_get_et_sset_count ( struct ieee80211_hw * hw ,
struct ieee80211_vif * vif , int sset ) ;
void ath9k_htc_get_et_stats ( struct ieee80211_hw * hw ,
struct ieee80211_vif * vif ,
struct ethtool_stats * stats , u64 * data ) ;
2010-03-17 14:25:25 +05:30
# else
# define TX_STAT_INC(c) do { } while (0)
2013-06-19 14:02:15 -07:00
# define TX_STAT_ADD(c, a) do { } while (0)
2010-03-17 14:25:25 +05:30
# define RX_STAT_INC(c) do { } while (0)
2013-06-19 14:02:15 -07:00
# define RX_STAT_ADD(c, a) do { } while (0)
2011-04-13 11:23:34 +05:30
# define CAB_STAT_INC do { } while (0)
2010-03-17 14:25:25 +05:30
2010-06-02 16:53:58 -04:00
# define TX_QSTAT_INC(c) do { } while (0)
2011-04-13 11:24:10 +05:30
static inline void ath9k_htc_err_stat_rx ( struct ath9k_htc_priv * priv ,
2014-05-20 15:34:37 -04:00
struct ath_rx_status * rs )
2011-04-13 11:24:10 +05:30
{
}
2010-03-17 14:25:25 +05:30
# endif /* CONFIG_ATH9K_HTC_DEBUGFS */
# define ATH_LED_PIN_DEF 1
2011-03-15 19:55:35 +05:30
# define ATH_LED_PIN_9287 10
2010-03-17 14:25:25 +05:30
# define ATH_LED_PIN_9271 15
2010-06-30 14:46:31 +05:30
# define ATH_LED_PIN_7010 12
2010-03-17 14:25:25 +05:30
2011-04-13 11:23:08 +05:30
# define BSTUCK_THRESHOLD 10
2011-04-13 11:23:44 +05:30
/*
* Adjust these when the max . no of beaconing interfaces is
* increased .
*/
# define DEFAULT_SWBA_RESPONSE 40 /* in TUs */
# define MIN_SWBA_RESPONSE 10 /* in TUs */
2014-03-01 21:15:45 +01:00
struct htc_beacon {
2014-03-01 21:15:52 +01:00
enum {
OK , /* no change needed */
UPDATE , /* update pending */
COMMIT /* beacon sent, commit change */
} updateslot ; /* slot time update fsm */
2011-04-13 11:23:08 +05:30
struct ieee80211_vif * bslot [ ATH9K_HTC_MAX_BCN_VIF ] ;
2014-03-01 21:15:45 +01:00
u32 bmisscnt ;
2014-03-01 21:15:46 +01:00
u32 beaconq ;
2014-03-01 21:15:52 +01:00
int slottime ;
int slotupdate ;
2010-04-05 14:48:06 +05:30
} ;
2010-08-18 19:57:49 +05:30
struct ath_btcoex {
u32 bt_priority_cnt ;
unsigned long bt_priority_time ;
int bt_stomp_type ; /* Types of BT stomping */
u32 btcoex_no_stomp ;
u32 btcoex_period ;
u32 btscan_no_stomp ;
} ;
2012-02-22 12:41:47 +05:30
# ifdef CONFIG_ATH9K_BTCOEX_SUPPORT
2012-02-22 12:41:41 +05:30
void ath9k_htc_init_btcoex ( struct ath9k_htc_priv * priv , char * product ) ;
2012-02-22 12:41:36 +05:30
void ath9k_htc_start_btcoex ( struct ath9k_htc_priv * priv ) ;
void ath9k_htc_stop_btcoex ( struct ath9k_htc_priv * priv ) ;
2012-02-22 12:41:47 +05:30
# else
static inline void ath9k_htc_init_btcoex ( struct ath9k_htc_priv * priv , char * product )
{
}
static inline void ath9k_htc_start_btcoex ( struct ath9k_htc_priv * priv )
{
}
static inline void ath9k_htc_stop_btcoex ( struct ath9k_htc_priv * priv )
{
}
# endif /* CONFIG_ATH9K_BTCOEX_SUPPORT */
2010-08-18 19:57:49 +05:30
2015-05-14 11:34:48 +03:00
# define OP_BT_PRIORITY_DETECTED 3
# define OP_BT_SCAN 4
# define OP_TSF_RESET 6
2010-03-17 14:25:25 +05:30
2015-03-22 19:29:46 +01:00
enum htc_op_flags {
HTC_FWFLAG_NO_RMW ,
} ;
2010-03-17 14:25:25 +05:30
struct ath9k_htc_priv {
struct device * dev ;
struct ieee80211_hw * hw ;
struct ath_hw * ah ;
struct htc_target * htc ;
struct wmi * wmi ;
2011-04-13 11:22:51 +05:30
u16 fw_version_major ;
u16 fw_version_minor ;
2010-03-17 14:25:25 +05:30
enum htc_endpoint_id wmi_cmd_ep ;
enum htc_endpoint_id beacon_ep ;
enum htc_endpoint_id cab_ep ;
enum htc_endpoint_id uapsd_ep ;
enum htc_endpoint_id mgmt_ep ;
enum htc_endpoint_id data_be_ep ;
enum htc_endpoint_id data_bk_ep ;
enum htc_endpoint_id data_vi_ep ;
enum htc_endpoint_id data_vo_ep ;
2011-02-21 07:48:00 +05:30
u8 vif_slot ;
u8 mon_vif_idx ;
u8 sta_slot ;
u8 vif_sta_pos [ ATH9K_HTC_MAX_VIF ] ;
2011-02-21 07:49:15 +05:30
u8 num_ibss_vif ;
2013-05-08 10:16:46 -07:00
u8 num_mbss_vif ;
2011-02-21 07:49:15 +05:30
u8 num_sta_vif ;
2011-05-17 12:42:03 +05:30
u8 num_sta_assoc_vif ;
2011-02-21 07:49:23 +05:30
u8 num_ap_vif ;
2011-02-21 07:48:00 +05:30
2010-03-17 14:25:25 +05:30
u16 curtxpow ;
u16 txpowlimit ;
u16 nvifs ;
u16 nstations ;
2011-02-21 07:48:39 +05:30
bool rearm_ani ;
bool reconfig_beacon ;
2011-04-13 11:25:00 +05:30
unsigned int rxfilter ;
2012-06-25 13:54:41 +05:30
unsigned long op_flags ;
2015-03-22 19:29:46 +01:00
unsigned long fw_flags ;
2010-03-17 14:25:25 +05:30
2011-01-15 01:33:28 +05:30
struct ath9k_hw_cal_data caldata ;
2014-11-06 08:53:34 +01:00
struct ath_spec_scan_priv spec_priv ;
2010-07-31 00:12:00 +02:00
2010-03-17 14:25:25 +05:30
spinlock_t beacon_lock ;
2014-03-01 21:15:45 +01:00
struct ath_beacon_config cur_beacon_conf ;
struct htc_beacon beacon ;
2010-03-17 14:25:25 +05:30
2011-04-13 11:25:00 +05:30
struct ath9k_htc_rx rx ;
struct ath9k_htc_tx tx ;
2010-03-29 16:07:17 +05:30
2010-12-28 14:28:27 +05:30
struct tasklet_struct swba_tasklet ;
2010-03-17 14:25:25 +05:30
struct tasklet_struct rx_tasklet ;
2011-02-21 07:49:38 +05:30
struct delayed_work ani_work ;
2011-04-13 11:26:18 +05:30
struct tasklet_struct tx_failed_tasklet ;
2010-04-05 14:48:05 +05:30
struct work_struct ps_work ;
2010-12-28 14:28:27 +05:30
struct work_struct fatal_work ;
2010-04-05 14:48:05 +05:30
struct mutex htc_pm_lock ;
unsigned long ps_usecount ;
bool ps_enabled ;
2010-04-27 13:05:37 +05:30
bool ps_idle ;
2010-03-17 14:25:25 +05:30
2011-04-28 16:14:05 +05:30
# ifdef CONFIG_MAC80211_LEDS
enum led_brightness brightness ;
bool led_registered ;
char led_name [ 32 ] ;
struct led_classdev led_cdev ;
struct work_struct led_work ;
# endif
2010-05-14 11:18:56 +05:30
int cabq ;
2012-11-21 18:13:10 +05:30
int hwq_map [ IEEE80211_NUM_ACS ] ;
2010-03-17 14:25:25 +05:30
2012-02-22 12:41:47 +05:30
# ifdef CONFIG_ATH9K_BTCOEX_SUPPORT
2010-08-18 19:57:49 +05:30
struct ath_btcoex btcoex ;
2012-02-22 12:41:47 +05:30
# endif
2010-08-18 19:57:49 +05:30
struct delayed_work coex_period_work ;
struct delayed_work duty_cycle_work ;
2010-03-17 14:25:25 +05:30
# ifdef CONFIG_ATH9K_HTC_DEBUGFS
struct ath9k_debug debug ;
# endif
struct mutex mutex ;
2015-06-09 15:59:49 +08:00
struct ieee80211_vif * csa_vif ;
2010-03-17 14:25:25 +05:30
} ;
static inline void ath_read_cachesize ( struct ath_common * common , int * csz )
{
common - > bus_ops - > read_cachesize ( common , csz ) ;
}
2010-12-28 14:28:27 +05:30
void ath9k_htc_reset ( struct ath9k_htc_priv * priv ) ;
2011-04-13 11:23:08 +05:30
void ath9k_htc_assign_bslot ( struct ath9k_htc_priv * priv ,
struct ieee80211_vif * vif ) ;
void ath9k_htc_remove_bslot ( struct ath9k_htc_priv * priv ,
struct ieee80211_vif * vif ) ;
2011-04-13 11:23:17 +05:30
void ath9k_htc_set_tsfadjust ( struct ath9k_htc_priv * priv ,
struct ieee80211_vif * vif ) ;
2010-06-01 15:14:19 +05:30
void ath9k_htc_beaconq_config ( struct ath9k_htc_priv * priv ) ;
2010-03-17 14:25:25 +05:30
void ath9k_htc_beacon_config ( struct ath9k_htc_priv * priv ,
2010-04-05 14:48:06 +05:30
struct ieee80211_vif * vif ) ;
2011-02-21 07:48:39 +05:30
void ath9k_htc_beacon_reconfig ( struct ath9k_htc_priv * priv ) ;
2011-04-13 11:23:52 +05:30
void ath9k_htc_swba ( struct ath9k_htc_priv * priv ,
struct wmi_event_swba * swba ) ;
2010-03-17 14:25:25 +05:30
void ath9k_htc_rxep ( void * priv , struct sk_buff * skb ,
enum htc_endpoint_id ep_id ) ;
void ath9k_htc_txep ( void * priv , struct sk_buff * skb , enum htc_endpoint_id ep_id ,
bool txok ) ;
2010-05-06 14:45:47 +05:30
void ath9k_htc_beaconep ( void * drv_priv , struct sk_buff * skb ,
enum htc_endpoint_id ep_id , bool txok ) ;
2010-03-17 14:25:25 +05:30
2011-04-20 14:33:28 +05:30
int ath9k_htc_update_cap_target ( struct ath9k_htc_priv * priv ,
u8 enable_coex ) ;
2011-02-21 07:49:38 +05:30
void ath9k_htc_ani_work ( struct work_struct * work ) ;
void ath9k_htc_start_ani ( struct ath9k_htc_priv * priv ) ;
void ath9k_htc_stop_ani ( struct ath9k_htc_priv * priv ) ;
2010-03-17 14:25:25 +05:30
int ath9k_tx_init ( struct ath9k_htc_priv * priv ) ;
2011-04-13 11:23:34 +05:30
int ath9k_htc_tx_start ( struct ath9k_htc_priv * priv ,
2012-07-23 21:33:42 +02:00
struct ieee80211_sta * sta ,
2011-04-13 11:25:47 +05:30
struct sk_buff * skb , u8 slot , bool is_cab ) ;
2010-03-17 14:25:25 +05:30
void ath9k_tx_cleanup ( struct ath9k_htc_priv * priv ) ;
2010-06-12 00:33:50 -04:00
bool ath9k_htc_txq_setup ( struct ath9k_htc_priv * priv , int subtype ) ;
2010-05-14 11:18:56 +05:30
int ath9k_htc_cabq_setup ( struct ath9k_htc_priv * priv ) ;
2010-03-17 14:25:25 +05:30
int get_hw_qnum ( u16 queue , int * hwq_map ) ;
2010-03-24 13:42:13 +05:30
int ath_htc_txq_update ( struct ath9k_htc_priv * priv , int qnum ,
struct ath9k_tx_queue_info * qinfo ) ;
2011-04-13 11:25:29 +05:30
void ath9k_htc_check_stop_queues ( struct ath9k_htc_priv * priv ) ;
void ath9k_htc_check_wake_queues ( struct ath9k_htc_priv * priv ) ;
2011-04-13 11:25:47 +05:30
int ath9k_htc_tx_get_slot ( struct ath9k_htc_priv * priv ) ;
void ath9k_htc_tx_clear_slot ( struct ath9k_htc_priv * priv , int slot ) ;
2011-04-13 11:25:59 +05:30
void ath9k_htc_tx_drain ( struct ath9k_htc_priv * priv ) ;
2011-04-13 11:26:18 +05:30
void ath9k_htc_txstatus ( struct ath9k_htc_priv * priv , void * wmi_event ) ;
void ath9k_tx_failed_tasklet ( unsigned long data ) ;
2017-10-24 02:29:54 -07:00
void ath9k_htc_tx_cleanup_timer ( struct timer_list * t ) ;
2015-06-09 15:59:49 +08:00
bool ath9k_htc_csa_is_finished ( struct ath9k_htc_priv * priv ) ;
2010-03-17 14:25:25 +05:30
int ath9k_rx_init ( struct ath9k_htc_priv * priv ) ;
void ath9k_rx_cleanup ( struct ath9k_htc_priv * priv ) ;
void ath9k_host_rx_init ( struct ath9k_htc_priv * priv ) ;
void ath9k_rx_tasklet ( unsigned long data ) ;
2010-03-29 16:07:09 +05:30
u32 ath9k_htc_calcrxfilter ( struct ath9k_htc_priv * priv ) ;
2010-03-17 14:25:25 +05:30
2010-04-05 14:48:05 +05:30
void ath9k_htc_ps_wakeup ( struct ath9k_htc_priv * priv ) ;
void ath9k_htc_ps_restore ( struct ath9k_htc_priv * priv ) ;
void ath9k_ps_work ( struct work_struct * work ) ;
2010-12-01 12:30:27 +05:30
bool ath9k_htc_setpower ( struct ath9k_htc_priv * priv ,
enum ath9k_power_mode mode ) ;
2010-04-05 14:48:05 +05:30
2010-03-17 14:25:25 +05:30
void ath9k_start_rfkill_poll ( struct ath9k_htc_priv * priv ) ;
2010-12-28 14:28:52 +05:30
void ath9k_htc_rfkill_poll_state ( struct ieee80211_hw * hw ) ;
2011-04-28 16:14:05 +05:30
2013-06-19 14:02:14 -07:00
struct base_eep_header * ath9k_htc_get_eeprom_base ( struct ath9k_htc_priv * priv ) ;
2011-04-28 16:14:05 +05:30
# ifdef CONFIG_MAC80211_LEDS
2013-12-12 15:30:36 +01:00
void ath9k_configure_leds ( struct ath9k_htc_priv * priv ) ;
2010-03-17 14:25:25 +05:30
void ath9k_init_leds ( struct ath9k_htc_priv * priv ) ;
void ath9k_deinit_leds ( struct ath9k_htc_priv * priv ) ;
2011-04-28 16:14:05 +05:30
void ath9k_led_work ( struct work_struct * work ) ;
# else
2013-12-12 15:30:36 +01:00
static inline void ath9k_configure_leds ( struct ath9k_htc_priv * priv )
{
}
2011-04-28 16:14:05 +05:30
static inline void ath9k_init_leds ( struct ath9k_htc_priv * priv )
{
}
static inline void ath9k_deinit_leds ( struct ath9k_htc_priv * priv )
{
}
static inline void ath9k_led_work ( struct work_struct * work )
{
}
# endif
2010-03-17 14:25:25 +05:30
int ath9k_htc_probe_device ( struct htc_target * htc_handle , struct device * dev ,
2010-11-19 16:53:22 +05:30
u16 devid , char * product , u32 drv_info ) ;
2010-03-17 14:25:25 +05:30
void ath9k_htc_disconnect_device ( struct htc_target * htc_handle , bool hotunplug ) ;
# ifdef CONFIG_PM
2010-12-01 12:30:27 +05:30
void ath9k_htc_suspend ( struct htc_target * htc_handle ) ;
2010-03-17 14:25:25 +05:30
int ath9k_htc_resume ( struct htc_target * htc_handle ) ;
# endif
# ifdef CONFIG_ATH9K_HTC_DEBUGFS
2010-03-24 13:42:13 +05:30
int ath9k_htc_init_debug ( struct ath_hw * ah ) ;
2014-11-06 08:53:38 +01:00
void ath9k_htc_deinit_debug ( struct ath9k_htc_priv * priv ) ;
2010-03-17 14:25:25 +05:30
# else
2010-03-24 13:42:13 +05:30
static inline int ath9k_htc_init_debug ( struct ath_hw * ah ) { return 0 ; } ;
2014-11-11 17:12:17 -05:00
static inline void ath9k_htc_deinit_debug ( struct ath9k_htc_priv * priv )
{
}
2010-03-17 14:25:25 +05:30
# endif /* CONFIG_ATH9K_HTC_DEBUGFS */
# endif /* HTC_H */