162306a36Sopenharmony_ci/* 262306a36Sopenharmony_ci * Copyright (c) 2014 Redpine Signals Inc. 362306a36Sopenharmony_ci * 462306a36Sopenharmony_ci * Permission to use, copy, modify, and/or distribute this software for any 562306a36Sopenharmony_ci * purpose with or without fee is hereby granted, provided that the above 662306a36Sopenharmony_ci * copyright notice and this permission notice appear in all copies. 762306a36Sopenharmony_ci * 862306a36Sopenharmony_ci * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES 962306a36Sopenharmony_ci * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF 1062306a36Sopenharmony_ci * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR 1162306a36Sopenharmony_ci * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES 1262306a36Sopenharmony_ci * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN 1362306a36Sopenharmony_ci * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF 1462306a36Sopenharmony_ci * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. 1562306a36Sopenharmony_ci */ 1662306a36Sopenharmony_ci 1762306a36Sopenharmony_ci#ifndef __RSI_MAIN_H__ 1862306a36Sopenharmony_ci#define __RSI_MAIN_H__ 1962306a36Sopenharmony_ci 2062306a36Sopenharmony_ci#include <linux/string.h> 2162306a36Sopenharmony_ci#include <linux/skbuff.h> 2262306a36Sopenharmony_ci#include <net/mac80211.h> 2362306a36Sopenharmony_ci#include <net/rsi_91x.h> 2462306a36Sopenharmony_ci 2562306a36Sopenharmony_cistruct rsi_sta { 2662306a36Sopenharmony_ci struct ieee80211_sta *sta; 2762306a36Sopenharmony_ci s16 sta_id; 2862306a36Sopenharmony_ci u16 seq_start[IEEE80211_NUM_TIDS]; 2962306a36Sopenharmony_ci bool start_tx_aggr[IEEE80211_NUM_TIDS]; 3062306a36Sopenharmony_ci}; 3162306a36Sopenharmony_ci 3262306a36Sopenharmony_cistruct rsi_hw; 3362306a36Sopenharmony_ci 3462306a36Sopenharmony_ci#include "rsi_ps.h" 3562306a36Sopenharmony_ci 3662306a36Sopenharmony_ci#define ERR_ZONE BIT(0) /* For Error Msgs */ 3762306a36Sopenharmony_ci#define INFO_ZONE BIT(1) /* For General Status Msgs */ 3862306a36Sopenharmony_ci#define INIT_ZONE BIT(2) /* For Driver Init Seq Msgs */ 3962306a36Sopenharmony_ci#define MGMT_TX_ZONE BIT(3) /* For TX Mgmt Path Msgs */ 4062306a36Sopenharmony_ci#define MGMT_RX_ZONE BIT(4) /* For RX Mgmt Path Msgs */ 4162306a36Sopenharmony_ci#define DATA_TX_ZONE BIT(5) /* For TX Data Path Msgs */ 4262306a36Sopenharmony_ci#define DATA_RX_ZONE BIT(6) /* For RX Data Path Msgs */ 4362306a36Sopenharmony_ci#define FSM_ZONE BIT(7) /* For State Machine Msgs */ 4462306a36Sopenharmony_ci#define ISR_ZONE BIT(8) /* For Interrupt Msgs */ 4562306a36Sopenharmony_ci 4662306a36Sopenharmony_cienum RSI_FSM_STATES { 4762306a36Sopenharmony_ci FSM_FW_NOT_LOADED, 4862306a36Sopenharmony_ci FSM_CARD_NOT_READY, 4962306a36Sopenharmony_ci FSM_COMMON_DEV_PARAMS_SENT, 5062306a36Sopenharmony_ci FSM_BOOT_PARAMS_SENT, 5162306a36Sopenharmony_ci FSM_EEPROM_READ_MAC_ADDR, 5262306a36Sopenharmony_ci FSM_EEPROM_READ_RF_TYPE, 5362306a36Sopenharmony_ci FSM_RESET_MAC_SENT, 5462306a36Sopenharmony_ci FSM_RADIO_CAPS_SENT, 5562306a36Sopenharmony_ci FSM_BB_RF_PROG_SENT, 5662306a36Sopenharmony_ci FSM_MAC_INIT_DONE, 5762306a36Sopenharmony_ci 5862306a36Sopenharmony_ci NUM_FSM_STATES 5962306a36Sopenharmony_ci}; 6062306a36Sopenharmony_ci 6162306a36Sopenharmony_ciextern u32 rsi_zone_enabled; 6262306a36Sopenharmony_ciextern __printf(2, 3) void rsi_dbg(u32 zone, const char *fmt, ...); 6362306a36Sopenharmony_ci 6462306a36Sopenharmony_ci#define RSI_MAX_BANDS 2 6562306a36Sopenharmony_ci#define RSI_MAX_VIFS 3 6662306a36Sopenharmony_ci#define NUM_EDCA_QUEUES 4 6762306a36Sopenharmony_ci#define IEEE80211_ADDR_LEN 6 6862306a36Sopenharmony_ci#define FRAME_DESC_SZ 16 6962306a36Sopenharmony_ci#define MIN_802_11_HDR_LEN 24 7062306a36Sopenharmony_ci#define RSI_DEF_KEEPALIVE 90 7162306a36Sopenharmony_ci#define RSI_WOW_KEEPALIVE 5 7262306a36Sopenharmony_ci#define RSI_BCN_MISS_THRESHOLD 24 7362306a36Sopenharmony_ci 7462306a36Sopenharmony_ci#define DATA_QUEUE_WATER_MARK 400 7562306a36Sopenharmony_ci#define MIN_DATA_QUEUE_WATER_MARK 300 7662306a36Sopenharmony_ci#define MULTICAST_WATER_MARK 200 7762306a36Sopenharmony_ci#define MAC_80211_HDR_FRAME_CONTROL 0 7862306a36Sopenharmony_ci#define WME_NUM_AC 4 7962306a36Sopenharmony_ci#define NUM_SOFT_QUEUES 6 8062306a36Sopenharmony_ci#define MAX_HW_QUEUES 12 8162306a36Sopenharmony_ci#define INVALID_QUEUE 0xff 8262306a36Sopenharmony_ci#define MAX_CONTINUOUS_VO_PKTS 8 8362306a36Sopenharmony_ci#define MAX_CONTINUOUS_VI_PKTS 4 8462306a36Sopenharmony_ci 8562306a36Sopenharmony_ci/* Hardware queue info */ 8662306a36Sopenharmony_ci#define BROADCAST_HW_Q 9 8762306a36Sopenharmony_ci#define MGMT_HW_Q 10 8862306a36Sopenharmony_ci#define BEACON_HW_Q 11 8962306a36Sopenharmony_ci 9062306a36Sopenharmony_ci#define IEEE80211_MGMT_FRAME 0x00 9162306a36Sopenharmony_ci#define IEEE80211_CTL_FRAME 0x04 9262306a36Sopenharmony_ci 9362306a36Sopenharmony_ci#define RSI_MAX_ASSOC_STAS 32 9462306a36Sopenharmony_ci#define IEEE80211_QOS_TID 0x0f 9562306a36Sopenharmony_ci#define IEEE80211_NONQOS_TID 16 9662306a36Sopenharmony_ci 9762306a36Sopenharmony_ci#define MAX_DEBUGFS_ENTRIES 4 9862306a36Sopenharmony_ci 9962306a36Sopenharmony_ci#define TID_TO_WME_AC(_tid) ( \ 10062306a36Sopenharmony_ci ((_tid) == 0 || (_tid) == 3) ? BE_Q : \ 10162306a36Sopenharmony_ci ((_tid) < 3) ? BK_Q : \ 10262306a36Sopenharmony_ci ((_tid) < 6) ? VI_Q : \ 10362306a36Sopenharmony_ci VO_Q) 10462306a36Sopenharmony_ci 10562306a36Sopenharmony_ci#define WME_AC(_q) ( \ 10662306a36Sopenharmony_ci ((_q) == BK_Q) ? IEEE80211_AC_BK : \ 10762306a36Sopenharmony_ci ((_q) == BE_Q) ? IEEE80211_AC_BE : \ 10862306a36Sopenharmony_ci ((_q) == VI_Q) ? IEEE80211_AC_VI : \ 10962306a36Sopenharmony_ci IEEE80211_AC_VO) 11062306a36Sopenharmony_ci 11162306a36Sopenharmony_ci/* WoWLAN flags */ 11262306a36Sopenharmony_ci#define RSI_WOW_ENABLED BIT(0) 11362306a36Sopenharmony_ci#define RSI_WOW_NO_CONNECTION BIT(1) 11462306a36Sopenharmony_ci 11562306a36Sopenharmony_ci#define RSI_MAX_RX_PKTS 64 11662306a36Sopenharmony_ci 11762306a36Sopenharmony_cienum rsi_dev_model { 11862306a36Sopenharmony_ci RSI_DEV_9113 = 0, 11962306a36Sopenharmony_ci RSI_DEV_9116 12062306a36Sopenharmony_ci}; 12162306a36Sopenharmony_ci 12262306a36Sopenharmony_cistruct version_info { 12362306a36Sopenharmony_ci u16 major; 12462306a36Sopenharmony_ci u16 minor; 12562306a36Sopenharmony_ci u8 release_num; 12662306a36Sopenharmony_ci u8 patch_num; 12762306a36Sopenharmony_ci union { 12862306a36Sopenharmony_ci struct { 12962306a36Sopenharmony_ci u8 fw_ver[8]; 13062306a36Sopenharmony_ci } info; 13162306a36Sopenharmony_ci } ver; 13262306a36Sopenharmony_ci} __packed; 13362306a36Sopenharmony_ci 13462306a36Sopenharmony_cistruct skb_info { 13562306a36Sopenharmony_ci s8 rssi; 13662306a36Sopenharmony_ci u32 flags; 13762306a36Sopenharmony_ci u16 channel; 13862306a36Sopenharmony_ci s8 tid; 13962306a36Sopenharmony_ci s8 sta_id; 14062306a36Sopenharmony_ci u8 internal_hdr_size; 14162306a36Sopenharmony_ci struct ieee80211_vif *vif; 14262306a36Sopenharmony_ci u8 vap_id; 14362306a36Sopenharmony_ci bool have_key; 14462306a36Sopenharmony_ci}; 14562306a36Sopenharmony_ci 14662306a36Sopenharmony_cienum edca_queue { 14762306a36Sopenharmony_ci BK_Q, 14862306a36Sopenharmony_ci BE_Q, 14962306a36Sopenharmony_ci VI_Q, 15062306a36Sopenharmony_ci VO_Q, 15162306a36Sopenharmony_ci MGMT_SOFT_Q, 15262306a36Sopenharmony_ci MGMT_BEACON_Q 15362306a36Sopenharmony_ci}; 15462306a36Sopenharmony_ci 15562306a36Sopenharmony_cistruct security_info { 15662306a36Sopenharmony_ci u32 ptk_cipher; 15762306a36Sopenharmony_ci u32 gtk_cipher; 15862306a36Sopenharmony_ci}; 15962306a36Sopenharmony_ci 16062306a36Sopenharmony_cistruct wmm_qinfo { 16162306a36Sopenharmony_ci s32 weight; 16262306a36Sopenharmony_ci s32 wme_params; 16362306a36Sopenharmony_ci s32 pkt_contended; 16462306a36Sopenharmony_ci s32 txop; 16562306a36Sopenharmony_ci}; 16662306a36Sopenharmony_ci 16762306a36Sopenharmony_cistruct transmit_q_stats { 16862306a36Sopenharmony_ci u32 total_tx_pkt_send[NUM_EDCA_QUEUES + 2]; 16962306a36Sopenharmony_ci u32 total_tx_pkt_freed[NUM_EDCA_QUEUES + 2]; 17062306a36Sopenharmony_ci}; 17162306a36Sopenharmony_ci 17262306a36Sopenharmony_ci#define MAX_BGSCAN_CHANNELS_DUAL_BAND 38 17362306a36Sopenharmony_ci#define MAX_BGSCAN_PROBE_REQ_LEN 0x64 17462306a36Sopenharmony_ci#define RSI_DEF_BGSCAN_THRLD 0x0 17562306a36Sopenharmony_ci#define RSI_DEF_ROAM_THRLD 0xa 17662306a36Sopenharmony_ci#define RSI_BGSCAN_PERIODICITY 0x1e 17762306a36Sopenharmony_ci#define RSI_ACTIVE_SCAN_TIME 0x14 17862306a36Sopenharmony_ci#define RSI_PASSIVE_SCAN_TIME 0x46 17962306a36Sopenharmony_ci#define RSI_CHANNEL_SCAN_TIME 20 18062306a36Sopenharmony_cistruct rsi_bgscan_params { 18162306a36Sopenharmony_ci u16 bgscan_threshold; 18262306a36Sopenharmony_ci u16 roam_threshold; 18362306a36Sopenharmony_ci u16 bgscan_periodicity; 18462306a36Sopenharmony_ci u8 num_bgscan_channels; 18562306a36Sopenharmony_ci u8 two_probe; 18662306a36Sopenharmony_ci u16 active_scan_duration; 18762306a36Sopenharmony_ci u16 passive_scan_duration; 18862306a36Sopenharmony_ci}; 18962306a36Sopenharmony_ci 19062306a36Sopenharmony_cistruct vif_priv { 19162306a36Sopenharmony_ci bool is_ht; 19262306a36Sopenharmony_ci bool sgi; 19362306a36Sopenharmony_ci u16 seq_start; 19462306a36Sopenharmony_ci int vap_id; 19562306a36Sopenharmony_ci}; 19662306a36Sopenharmony_ci 19762306a36Sopenharmony_cistruct rsi_event { 19862306a36Sopenharmony_ci atomic_t event_condition; 19962306a36Sopenharmony_ci wait_queue_head_t event_queue; 20062306a36Sopenharmony_ci}; 20162306a36Sopenharmony_ci 20262306a36Sopenharmony_cistruct rsi_thread { 20362306a36Sopenharmony_ci void (*thread_function)(void *); 20462306a36Sopenharmony_ci struct completion completion; 20562306a36Sopenharmony_ci struct task_struct *task; 20662306a36Sopenharmony_ci struct rsi_event event; 20762306a36Sopenharmony_ci atomic_t thread_done; 20862306a36Sopenharmony_ci}; 20962306a36Sopenharmony_ci 21062306a36Sopenharmony_cistruct cqm_info { 21162306a36Sopenharmony_ci s8 last_cqm_event_rssi; 21262306a36Sopenharmony_ci int rssi_thold; 21362306a36Sopenharmony_ci u32 rssi_hyst; 21462306a36Sopenharmony_ci}; 21562306a36Sopenharmony_ci 21662306a36Sopenharmony_cienum rsi_dfs_regions { 21762306a36Sopenharmony_ci RSI_REGION_FCC = 0, 21862306a36Sopenharmony_ci RSI_REGION_ETSI, 21962306a36Sopenharmony_ci RSI_REGION_TELEC, 22062306a36Sopenharmony_ci RSI_REGION_WORLD 22162306a36Sopenharmony_ci}; 22262306a36Sopenharmony_ci 22362306a36Sopenharmony_cistruct rsi_9116_features { 22462306a36Sopenharmony_ci u8 pll_mode; 22562306a36Sopenharmony_ci u8 rf_type; 22662306a36Sopenharmony_ci u8 wireless_mode; 22762306a36Sopenharmony_ci u8 afe_type; 22862306a36Sopenharmony_ci u8 enable_ppe; 22962306a36Sopenharmony_ci u8 dpd; 23062306a36Sopenharmony_ci u32 sifs_tx_enable; 23162306a36Sopenharmony_ci u32 ps_options; 23262306a36Sopenharmony_ci}; 23362306a36Sopenharmony_ci 23462306a36Sopenharmony_cistruct rsi_rate_config { 23562306a36Sopenharmony_ci u32 configured_mask; /* configured by mac80211 bits 0-11=legacy 12+ mcs */ 23662306a36Sopenharmony_ci u16 fixed_hw_rate; 23762306a36Sopenharmony_ci bool fixed_enabled; 23862306a36Sopenharmony_ci}; 23962306a36Sopenharmony_ci 24062306a36Sopenharmony_cistruct rsi_common { 24162306a36Sopenharmony_ci struct rsi_hw *priv; 24262306a36Sopenharmony_ci struct vif_priv vif_info[RSI_MAX_VIFS]; 24362306a36Sopenharmony_ci 24462306a36Sopenharmony_ci void *coex_cb; 24562306a36Sopenharmony_ci bool mgmt_q_block; 24662306a36Sopenharmony_ci struct version_info lmac_ver; 24762306a36Sopenharmony_ci 24862306a36Sopenharmony_ci struct rsi_thread tx_thread; 24962306a36Sopenharmony_ci struct sk_buff_head tx_queue[NUM_EDCA_QUEUES + 2]; 25062306a36Sopenharmony_ci struct completion wlan_init_completion; 25162306a36Sopenharmony_ci /* Mutex declaration */ 25262306a36Sopenharmony_ci struct mutex mutex; 25362306a36Sopenharmony_ci /* Mutex used for tx thread */ 25462306a36Sopenharmony_ci struct mutex tx_lock; 25562306a36Sopenharmony_ci /* Mutex used for rx thread */ 25662306a36Sopenharmony_ci struct mutex rx_lock; 25762306a36Sopenharmony_ci u8 endpoint; 25862306a36Sopenharmony_ci 25962306a36Sopenharmony_ci /* Channel/band related */ 26062306a36Sopenharmony_ci u8 band; 26162306a36Sopenharmony_ci u8 num_supp_bands; 26262306a36Sopenharmony_ci u8 channel_width; 26362306a36Sopenharmony_ci 26462306a36Sopenharmony_ci u16 rts_threshold; 26562306a36Sopenharmony_ci u32 bitrate_mask[RSI_MAX_BANDS]; 26662306a36Sopenharmony_ci struct rsi_rate_config rate_config[RSI_MAX_BANDS]; 26762306a36Sopenharmony_ci 26862306a36Sopenharmony_ci u8 rf_reset; 26962306a36Sopenharmony_ci struct transmit_q_stats tx_stats; 27062306a36Sopenharmony_ci struct security_info secinfo; 27162306a36Sopenharmony_ci struct wmm_qinfo tx_qinfo[NUM_EDCA_QUEUES]; 27262306a36Sopenharmony_ci struct ieee80211_tx_queue_params edca_params[NUM_EDCA_QUEUES]; 27362306a36Sopenharmony_ci u8 mac_addr[IEEE80211_ADDR_LEN]; 27462306a36Sopenharmony_ci 27562306a36Sopenharmony_ci /* state related */ 27662306a36Sopenharmony_ci u32 fsm_state; 27762306a36Sopenharmony_ci bool init_done; 27862306a36Sopenharmony_ci u8 bb_rf_prog_count; 27962306a36Sopenharmony_ci bool iface_down; 28062306a36Sopenharmony_ci 28162306a36Sopenharmony_ci /* Generic */ 28262306a36Sopenharmony_ci u8 channel; 28362306a36Sopenharmony_ci u8 *rx_data_pkt; 28462306a36Sopenharmony_ci u8 mac_id; 28562306a36Sopenharmony_ci u8 radio_id; 28662306a36Sopenharmony_ci u16 rate_pwr[20]; 28762306a36Sopenharmony_ci 28862306a36Sopenharmony_ci /* WMM algo related */ 28962306a36Sopenharmony_ci u8 selected_qnum; 29062306a36Sopenharmony_ci u32 pkt_cnt; 29162306a36Sopenharmony_ci u8 min_weight; 29262306a36Sopenharmony_ci 29362306a36Sopenharmony_ci /* bgscan related */ 29462306a36Sopenharmony_ci struct cqm_info cqm_info; 29562306a36Sopenharmony_ci 29662306a36Sopenharmony_ci bool hw_data_qs_blocked; 29762306a36Sopenharmony_ci u8 driver_mode; 29862306a36Sopenharmony_ci u8 coex_mode; 29962306a36Sopenharmony_ci u16 oper_mode; 30062306a36Sopenharmony_ci u8 lp_ps_handshake_mode; 30162306a36Sopenharmony_ci u8 ulp_ps_handshake_mode; 30262306a36Sopenharmony_ci u8 uapsd_bitmap; 30362306a36Sopenharmony_ci u8 rf_power_val; 30462306a36Sopenharmony_ci u8 wlan_rf_power_mode; 30562306a36Sopenharmony_ci u8 obm_ant_sel_val; 30662306a36Sopenharmony_ci int tx_power; 30762306a36Sopenharmony_ci u8 ant_in_use; 30862306a36Sopenharmony_ci /* Mutex used for writing packet to bus */ 30962306a36Sopenharmony_ci struct mutex tx_bus_mutex; 31062306a36Sopenharmony_ci bool hibernate_resume; 31162306a36Sopenharmony_ci bool reinit_hw; 31262306a36Sopenharmony_ci u8 wow_flags; 31362306a36Sopenharmony_ci u16 beacon_interval; 31462306a36Sopenharmony_ci u8 dtim_cnt; 31562306a36Sopenharmony_ci 31662306a36Sopenharmony_ci /* AP mode parameters */ 31762306a36Sopenharmony_ci u8 beacon_enabled; 31862306a36Sopenharmony_ci u16 beacon_cnt; 31962306a36Sopenharmony_ci struct rsi_sta stations[RSI_MAX_ASSOC_STAS + 1]; 32062306a36Sopenharmony_ci int num_stations; 32162306a36Sopenharmony_ci int max_stations; 32262306a36Sopenharmony_ci struct ieee80211_key_conf *key; 32362306a36Sopenharmony_ci 32462306a36Sopenharmony_ci /* Wi-Fi direct mode related */ 32562306a36Sopenharmony_ci bool p2p_enabled; 32662306a36Sopenharmony_ci struct timer_list roc_timer; 32762306a36Sopenharmony_ci struct ieee80211_vif *roc_vif; 32862306a36Sopenharmony_ci 32962306a36Sopenharmony_ci bool eapol4_confirm; 33062306a36Sopenharmony_ci bool bt_defer_attach; 33162306a36Sopenharmony_ci void *bt_adapter; 33262306a36Sopenharmony_ci 33362306a36Sopenharmony_ci struct cfg80211_scan_request *hwscan; 33462306a36Sopenharmony_ci struct rsi_bgscan_params bgscan; 33562306a36Sopenharmony_ci struct rsi_9116_features w9116_features; 33662306a36Sopenharmony_ci u8 bgscan_en; 33762306a36Sopenharmony_ci u8 mac_ops_resumed; 33862306a36Sopenharmony_ci}; 33962306a36Sopenharmony_ci 34062306a36Sopenharmony_cistruct eepromrw_info { 34162306a36Sopenharmony_ci u32 offset; 34262306a36Sopenharmony_ci u32 length; 34362306a36Sopenharmony_ci u8 write; 34462306a36Sopenharmony_ci u16 eeprom_erase; 34562306a36Sopenharmony_ci u8 data[480]; 34662306a36Sopenharmony_ci}; 34762306a36Sopenharmony_ci 34862306a36Sopenharmony_cistruct eeprom_read { 34962306a36Sopenharmony_ci u16 length; 35062306a36Sopenharmony_ci u16 off_set; 35162306a36Sopenharmony_ci}; 35262306a36Sopenharmony_ci 35362306a36Sopenharmony_cistruct rsi_hw { 35462306a36Sopenharmony_ci struct rsi_common *priv; 35562306a36Sopenharmony_ci enum rsi_dev_model device_model; 35662306a36Sopenharmony_ci struct ieee80211_hw *hw; 35762306a36Sopenharmony_ci struct ieee80211_vif *vifs[RSI_MAX_VIFS]; 35862306a36Sopenharmony_ci struct ieee80211_tx_queue_params edca_params[NUM_EDCA_QUEUES]; 35962306a36Sopenharmony_ci struct ieee80211_supported_band sbands[NUM_NL80211_BANDS]; 36062306a36Sopenharmony_ci 36162306a36Sopenharmony_ci struct device *device; 36262306a36Sopenharmony_ci u8 sc_nvifs; 36362306a36Sopenharmony_ci 36462306a36Sopenharmony_ci enum rsi_host_intf rsi_host_intf; 36562306a36Sopenharmony_ci u16 block_size; 36662306a36Sopenharmony_ci enum ps_state ps_state; 36762306a36Sopenharmony_ci struct rsi_ps_info ps_info; 36862306a36Sopenharmony_ci spinlock_t ps_lock; /*To protect power save config*/ 36962306a36Sopenharmony_ci u32 usb_buffer_status_reg; 37062306a36Sopenharmony_ci#ifdef CONFIG_RSI_DEBUGFS 37162306a36Sopenharmony_ci struct rsi_debugfs *dfsentry; 37262306a36Sopenharmony_ci u8 num_debugfs_entries; 37362306a36Sopenharmony_ci#endif 37462306a36Sopenharmony_ci char *fw_file_name; 37562306a36Sopenharmony_ci struct timer_list bl_cmd_timer; 37662306a36Sopenharmony_ci bool blcmd_timer_expired; 37762306a36Sopenharmony_ci u32 flash_capacity; 37862306a36Sopenharmony_ci struct eepromrw_info eeprom; 37962306a36Sopenharmony_ci u32 interrupt_status; 38062306a36Sopenharmony_ci u8 dfs_region; 38162306a36Sopenharmony_ci char country[2]; 38262306a36Sopenharmony_ci void *rsi_dev; 38362306a36Sopenharmony_ci struct rsi_host_intf_ops *host_intf_ops; 38462306a36Sopenharmony_ci int (*check_hw_queue_status)(struct rsi_hw *adapter, u8 q_num); 38562306a36Sopenharmony_ci int (*determine_event_timeout)(struct rsi_hw *adapter); 38662306a36Sopenharmony_ci}; 38762306a36Sopenharmony_ci 38862306a36Sopenharmony_civoid rsi_print_version(struct rsi_common *common); 38962306a36Sopenharmony_ci 39062306a36Sopenharmony_cistruct rsi_host_intf_ops { 39162306a36Sopenharmony_ci int (*read_pkt)(struct rsi_hw *adapter, u8 *pkt, u32 len); 39262306a36Sopenharmony_ci int (*write_pkt)(struct rsi_hw *adapter, u8 *pkt, u32 len); 39362306a36Sopenharmony_ci int (*master_access_msword)(struct rsi_hw *adapter, u16 ms_word); 39462306a36Sopenharmony_ci int (*read_reg_multiple)(struct rsi_hw *adapter, u32 addr, 39562306a36Sopenharmony_ci u8 *data, u16 count); 39662306a36Sopenharmony_ci int (*write_reg_multiple)(struct rsi_hw *adapter, u32 addr, 39762306a36Sopenharmony_ci u8 *data, u16 count); 39862306a36Sopenharmony_ci int (*master_reg_read)(struct rsi_hw *adapter, u32 addr, 39962306a36Sopenharmony_ci u32 *read_buf, u16 size); 40062306a36Sopenharmony_ci int (*master_reg_write)(struct rsi_hw *adapter, 40162306a36Sopenharmony_ci unsigned long addr, unsigned long data, 40262306a36Sopenharmony_ci u16 size); 40362306a36Sopenharmony_ci int (*load_data_master_write)(struct rsi_hw *adapter, u32 addr, 40462306a36Sopenharmony_ci u32 instructions_size, u16 block_size, 40562306a36Sopenharmony_ci u8 *fw); 40662306a36Sopenharmony_ci int (*reinit_device)(struct rsi_hw *adapter); 40762306a36Sopenharmony_ci int (*ta_reset)(struct rsi_hw *adapter); 40862306a36Sopenharmony_ci}; 40962306a36Sopenharmony_ci 41062306a36Sopenharmony_cienum rsi_host_intf rsi_get_host_intf(void *priv); 41162306a36Sopenharmony_civoid rsi_set_bt_context(void *priv, void *bt_context); 41262306a36Sopenharmony_civoid rsi_attach_bt(struct rsi_common *common); 41362306a36Sopenharmony_ci 41462306a36Sopenharmony_ci#endif 415