18c086312SLarry Finger /* SPDX-License-Identifier: GPL-2.0 */
28c086312SLarry Finger /* Copyright(c) 2009-2012 Realtek Corporation.*/
38c086312SLarry Finger
4aa45a673SLarry Finger #ifndef __HALBTC_OUT_SRC_H__
5aa45a673SLarry Finger #define __HALBTC_OUT_SRC_H__
6aa45a673SLarry Finger
7aa45a673SLarry Finger #include "../wifi.h"
8aa45a673SLarry Finger
9aa45a673SLarry Finger #define NORMAL_EXEC false
10aa45a673SLarry Finger #define FORCE_EXEC true
11aa45a673SLarry Finger
123ceac0a7SPing-Ke Shih #define BTC_RF_OFF 0x0
133ceac0a7SPing-Ke Shih #define BTC_RF_ON 0x1
143ceac0a7SPing-Ke Shih
15aa45a673SLarry Finger #define BTC_RF_A RF90_PATH_A
16aa45a673SLarry Finger #define BTC_RF_B RF90_PATH_B
17aa45a673SLarry Finger #define BTC_RF_C RF90_PATH_C
18aa45a673SLarry Finger #define BTC_RF_D RF90_PATH_D
19aa45a673SLarry Finger
20aa45a673SLarry Finger #define BTC_SMSP SINGLEMAC_SINGLEPHY
21aa45a673SLarry Finger #define BTC_DMDP DUALMAC_DUALPHY
22aa45a673SLarry Finger #define BTC_DMSP DUALMAC_SINGLEPHY
23aa45a673SLarry Finger #define BTC_MP_UNKNOWN 0xff
24aa45a673SLarry Finger
25aa45a673SLarry Finger #define IN
26aa45a673SLarry Finger #define OUT
27aa45a673SLarry Finger
28aa45a673SLarry Finger #define BT_TMP_BUF_SIZE 100
29aa45a673SLarry Finger
30aa45a673SLarry Finger #define BT_COEX_ANT_TYPE_PG 0
31aa45a673SLarry Finger #define BT_COEX_ANT_TYPE_ANTDIV 1
32aa45a673SLarry Finger #define BT_COEX_ANT_TYPE_DETECTED 2
33aa45a673SLarry Finger
34aa45a673SLarry Finger #define BTC_MIMO_PS_STATIC 0
35aa45a673SLarry Finger #define BTC_MIMO_PS_DYNAMIC 1
36aa45a673SLarry Finger
37aa45a673SLarry Finger #define BTC_RATE_DISABLE 0
38aa45a673SLarry Finger #define BTC_RATE_ENABLE 1
39aa45a673SLarry Finger
40e79fff28SLarry Finger /* single Antenna definition */
41e79fff28SLarry Finger #define BTC_ANT_PATH_WIFI 0
42e79fff28SLarry Finger #define BTC_ANT_PATH_BT 1
43e79fff28SLarry Finger #define BTC_ANT_PATH_PTA 2
44b82f5e0fSPing-Ke Shih #define BTC_ANT_PATH_WIFI5G 3
45b82f5e0fSPing-Ke Shih #define BTC_ANT_PATH_AUTO 4
46e79fff28SLarry Finger /* dual Antenna definition */
47e79fff28SLarry Finger #define BTC_ANT_WIFI_AT_MAIN 0
48e79fff28SLarry Finger #define BTC_ANT_WIFI_AT_AUX 1
49e79fff28SLarry Finger /* coupler Antenna definition */
50e79fff28SLarry Finger #define BTC_ANT_WIFI_AT_CPL_MAIN 0
51e79fff28SLarry Finger #define BTC_ANT_WIFI_AT_CPL_AUX 1
52e79fff28SLarry Finger
53588a290bSYan-Hsuan Chuang enum btc_bt_reg_type {
54588a290bSYan-Hsuan Chuang BTC_BT_REG_RF = 0,
55588a290bSYan-Hsuan Chuang BTC_BT_REG_MODEM = 1,
56588a290bSYan-Hsuan Chuang BTC_BT_REG_BLUEWIZE = 2,
57588a290bSYan-Hsuan Chuang BTC_BT_REG_VENDOR = 3,
58588a290bSYan-Hsuan Chuang BTC_BT_REG_LE = 4,
59588a290bSYan-Hsuan Chuang BTC_BT_REG_MAX
60588a290bSYan-Hsuan Chuang };
61588a290bSYan-Hsuan Chuang
62aa45a673SLarry Finger enum btc_chip_interface {
63aa45a673SLarry Finger BTC_INTF_UNKNOWN = 0,
64aa45a673SLarry Finger BTC_INTF_PCI = 1,
65aa45a673SLarry Finger BTC_INTF_USB = 2,
66aa45a673SLarry Finger BTC_INTF_SDIO = 3,
67aa45a673SLarry Finger BTC_INTF_GSPI = 4,
68aa45a673SLarry Finger BTC_INTF_MAX
69aa45a673SLarry Finger };
70aa45a673SLarry Finger
71ed364abfSLarry Finger enum btc_chip_type {
72aa45a673SLarry Finger BTC_CHIP_UNDEF = 0,
73aa45a673SLarry Finger BTC_CHIP_CSR_BC4 = 1,
74aa45a673SLarry Finger BTC_CHIP_CSR_BC8 = 2,
75aa45a673SLarry Finger BTC_CHIP_RTL8723A = 3,
76aa45a673SLarry Finger BTC_CHIP_RTL8821 = 4,
77aa45a673SLarry Finger BTC_CHIP_RTL8723B = 5,
78aa45a673SLarry Finger BTC_CHIP_MAX
79aa45a673SLarry Finger };
80aa45a673SLarry Finger
81ed364abfSLarry Finger enum btc_msg_type {
82aa45a673SLarry Finger BTC_MSG_INTERFACE = 0x0,
83aa45a673SLarry Finger BTC_MSG_ALGORITHM = 0x1,
84aa45a673SLarry Finger BTC_MSG_MAX
85aa45a673SLarry Finger };
86ed364abfSLarry Finger
87aa45a673SLarry Finger /* following is for BTC_MSG_INTERFACE */
88aa45a673SLarry Finger #define INTF_INIT BIT0
89aa45a673SLarry Finger #define INTF_NOTIFY BIT2
90aa45a673SLarry Finger
91aa45a673SLarry Finger /* following is for BTC_ALGORITHM */
92aa45a673SLarry Finger #define ALGO_BT_RSSI_STATE BIT0
93aa45a673SLarry Finger #define ALGO_WIFI_RSSI_STATE BIT1
94aa45a673SLarry Finger #define ALGO_BT_MONITOR BIT2
95aa45a673SLarry Finger #define ALGO_TRACE BIT3
96aa45a673SLarry Finger #define ALGO_TRACE_FW BIT4
97aa45a673SLarry Finger #define ALGO_TRACE_FW_DETAIL BIT5
98aa45a673SLarry Finger #define ALGO_TRACE_FW_EXEC BIT6
99aa45a673SLarry Finger #define ALGO_TRACE_SW BIT7
100aa45a673SLarry Finger #define ALGO_TRACE_SW_DETAIL BIT8
101aa45a673SLarry Finger #define ALGO_TRACE_SW_EXEC BIT9
102aa45a673SLarry Finger
103ed364abfSLarry Finger /* following is for wifi link status */
104ed364abfSLarry Finger #define WIFI_STA_CONNECTED BIT0
105ed364abfSLarry Finger #define WIFI_AP_CONNECTED BIT1
106ed364abfSLarry Finger #define WIFI_HS_CONNECTED BIT2
107ed364abfSLarry Finger #define WIFI_P2P_GO_CONNECTED BIT3
108ed364abfSLarry Finger #define WIFI_P2P_GC_CONNECTED BIT4
109aa45a673SLarry Finger
110e79fff28SLarry Finger #define BTC_RSSI_HIGH(_rssi_) \
111e79fff28SLarry Finger ((_rssi_ == BTC_RSSI_STATE_HIGH || \
112e79fff28SLarry Finger _rssi_ == BTC_RSSI_STATE_STAY_HIGH) ? true : false)
113e79fff28SLarry Finger #define BTC_RSSI_MEDIUM(_rssi_) \
114e79fff28SLarry Finger ((_rssi_ == BTC_RSSI_STATE_MEDIUM || \
115e79fff28SLarry Finger _rssi_ == BTC_RSSI_STATE_STAY_MEDIUM) ? true : false)
116e79fff28SLarry Finger #define BTC_RSSI_LOW(_rssi_) \
117e79fff28SLarry Finger ((_rssi_ == BTC_RSSI_STATE_LOW || \
118e79fff28SLarry Finger _rssi_ == BTC_RSSI_STATE_STAY_LOW) ? true : false)
119e79fff28SLarry Finger
120aa45a673SLarry Finger enum btc_power_save_type {
121aa45a673SLarry Finger BTC_PS_WIFI_NATIVE = 0,
122aa45a673SLarry Finger BTC_PS_LPS_ON = 1,
123aa45a673SLarry Finger BTC_PS_LPS_OFF = 2,
124aa45a673SLarry Finger BTC_PS_LPS_MAX
125aa45a673SLarry Finger };
126aa45a673SLarry Finger
127aa45a673SLarry Finger struct btc_board_info {
128aa45a673SLarry Finger /* The following is some board information */
129aa45a673SLarry Finger u8 bt_chip_type;
130aa45a673SLarry Finger u8 pg_ant_num; /* pg ant number */
131aa45a673SLarry Finger u8 btdm_ant_num; /* ant number for btdm */
132aa45a673SLarry Finger u8 btdm_ant_pos;
1334e6becc0SYan-Hsuan Chuang u8 single_ant_path; /* current used for 8723b only, 1=>s0, 0=>s1 */
1340199103eSYan-Hsuan Chuang bool tfbga_package;
135188b6b09SPing-Ke Shih
136188b6b09SPing-Ke Shih u8 rfe_type;
137f243bca1SPing-Ke Shih u8 ant_div_cfg;
138a1ee1a09SPing-Ke Shih u8 customer_id;
139aa45a673SLarry Finger };
140aa45a673SLarry Finger
141aa45a673SLarry Finger enum btc_dbg_opcode {
142aa45a673SLarry Finger BTC_DBG_SET_COEX_NORMAL = 0x0,
143aa45a673SLarry Finger BTC_DBG_SET_COEX_WIFI_ONLY = 0x1,
144aa45a673SLarry Finger BTC_DBG_SET_COEX_BT_ONLY = 0x2,
145aa45a673SLarry Finger BTC_DBG_MAX
146aa45a673SLarry Finger };
147aa45a673SLarry Finger
148aa45a673SLarry Finger enum btc_rssi_state {
149aa45a673SLarry Finger BTC_RSSI_STATE_HIGH = 0x0,
150aa45a673SLarry Finger BTC_RSSI_STATE_MEDIUM = 0x1,
151aa45a673SLarry Finger BTC_RSSI_STATE_LOW = 0x2,
152aa45a673SLarry Finger BTC_RSSI_STATE_STAY_HIGH = 0x3,
153aa45a673SLarry Finger BTC_RSSI_STATE_STAY_MEDIUM = 0x4,
154aa45a673SLarry Finger BTC_RSSI_STATE_STAY_LOW = 0x5,
155aa45a673SLarry Finger BTC_RSSI_MAX
156aa45a673SLarry Finger };
157aa45a673SLarry Finger
158aa45a673SLarry Finger enum btc_wifi_role {
159aa45a673SLarry Finger BTC_ROLE_STATION = 0x0,
160aa45a673SLarry Finger BTC_ROLE_AP = 0x1,
161aa45a673SLarry Finger BTC_ROLE_IBSS = 0x2,
162aa45a673SLarry Finger BTC_ROLE_HS_MODE = 0x3,
163aa45a673SLarry Finger BTC_ROLE_MAX
164aa45a673SLarry Finger };
165aa45a673SLarry Finger
16608431b62SPing-Ke Shih enum btc_wireless_freq {
16708431b62SPing-Ke Shih BTC_FREQ_2_4G = 0x0,
16808431b62SPing-Ke Shih BTC_FREQ_5G = 0x1,
16908431b62SPing-Ke Shih BTC_FREQ_MAX
17008431b62SPing-Ke Shih };
17108431b62SPing-Ke Shih
172aa45a673SLarry Finger enum btc_wifi_bw_mode {
173aa45a673SLarry Finger BTC_WIFI_BW_LEGACY = 0x0,
174aa45a673SLarry Finger BTC_WIFI_BW_HT20 = 0x1,
175aa45a673SLarry Finger BTC_WIFI_BW_HT40 = 0x2,
17666d0f9deSPing-Ke Shih BTC_WIFI_BW_HT80 = 0x3,
177aa45a673SLarry Finger BTC_WIFI_BW_MAX
178aa45a673SLarry Finger };
179aa45a673SLarry Finger
180aa45a673SLarry Finger enum btc_wifi_traffic_dir {
181aa45a673SLarry Finger BTC_WIFI_TRAFFIC_TX = 0x0,
182aa45a673SLarry Finger BTC_WIFI_TRAFFIC_RX = 0x1,
183aa45a673SLarry Finger BTC_WIFI_TRAFFIC_MAX
184aa45a673SLarry Finger };
185aa45a673SLarry Finger
186aa45a673SLarry Finger enum btc_wifi_pnp {
187aa45a673SLarry Finger BTC_WIFI_PNP_WAKE_UP = 0x0,
188aa45a673SLarry Finger BTC_WIFI_PNP_SLEEP = 0x1,
189b82f5e0fSPing-Ke Shih BTC_WIFI_PNP_SLEEP_KEEP_ANT = 0x2,
190aa45a673SLarry Finger BTC_WIFI_PNP_MAX
191aa45a673SLarry Finger };
192aa45a673SLarry Finger
19386aeb825SYan-Hsuan Chuang enum btc_iot_peer {
19486aeb825SYan-Hsuan Chuang BTC_IOT_PEER_UNKNOWN = 0,
19586aeb825SYan-Hsuan Chuang BTC_IOT_PEER_REALTEK = 1,
19686aeb825SYan-Hsuan Chuang BTC_IOT_PEER_REALTEK_92SE = 2,
19786aeb825SYan-Hsuan Chuang BTC_IOT_PEER_BROADCOM = 3,
19886aeb825SYan-Hsuan Chuang BTC_IOT_PEER_RALINK = 4,
19986aeb825SYan-Hsuan Chuang BTC_IOT_PEER_ATHEROS = 5,
20086aeb825SYan-Hsuan Chuang BTC_IOT_PEER_CISCO = 6,
20186aeb825SYan-Hsuan Chuang BTC_IOT_PEER_MERU = 7,
20286aeb825SYan-Hsuan Chuang BTC_IOT_PEER_MARVELL = 8,
20386aeb825SYan-Hsuan Chuang BTC_IOT_PEER_REALTEK_SOFTAP = 9,
20486aeb825SYan-Hsuan Chuang BTC_IOT_PEER_SELF_SOFTAP = 10, /* Self is SoftAP */
20586aeb825SYan-Hsuan Chuang BTC_IOT_PEER_AIRGO = 11,
20686aeb825SYan-Hsuan Chuang BTC_IOT_PEER_REALTEK_JAGUAR_BCUTAP = 12,
20786aeb825SYan-Hsuan Chuang BTC_IOT_PEER_REALTEK_JAGUAR_CCUTAP = 13,
20886aeb825SYan-Hsuan Chuang BTC_IOT_PEER_MAX,
20986aeb825SYan-Hsuan Chuang };
21086aeb825SYan-Hsuan Chuang
211c42ea613SYan-Hsuan Chuang /* for 8723b-d cut large current issue */
212c42ea613SYan-Hsuan Chuang enum bt_wifi_coex_state {
213c42ea613SYan-Hsuan Chuang BTC_WIFI_STAT_INIT,
214c42ea613SYan-Hsuan Chuang BTC_WIFI_STAT_IQK,
215c42ea613SYan-Hsuan Chuang BTC_WIFI_STAT_NORMAL_OFF,
216c42ea613SYan-Hsuan Chuang BTC_WIFI_STAT_MP_OFF,
217c42ea613SYan-Hsuan Chuang BTC_WIFI_STAT_NORMAL,
218c42ea613SYan-Hsuan Chuang BTC_WIFI_STAT_ANT_DIV,
219c42ea613SYan-Hsuan Chuang BTC_WIFI_STAT_MAX
220c42ea613SYan-Hsuan Chuang };
221c42ea613SYan-Hsuan Chuang
222c42ea613SYan-Hsuan Chuang enum bt_ant_type {
223c42ea613SYan-Hsuan Chuang BTC_ANT_TYPE_0,
224c42ea613SYan-Hsuan Chuang BTC_ANT_TYPE_1,
225c42ea613SYan-Hsuan Chuang BTC_ANT_TYPE_2,
226c42ea613SYan-Hsuan Chuang BTC_ANT_TYPE_3,
227c42ea613SYan-Hsuan Chuang BTC_ANT_TYPE_4,
228c42ea613SYan-Hsuan Chuang BTC_ANT_TYPE_MAX
229c42ea613SYan-Hsuan Chuang };
230c42ea613SYan-Hsuan Chuang
231aa45a673SLarry Finger enum btc_get_type {
232aa45a673SLarry Finger /* type bool */
233aa45a673SLarry Finger BTC_GET_BL_HS_OPERATION,
234aa45a673SLarry Finger BTC_GET_BL_HS_CONNECTING,
235aa45a673SLarry Finger BTC_GET_BL_WIFI_CONNECTED,
236123068f2SPing-Ke Shih BTC_GET_BL_WIFI_DUAL_BAND_CONNECTED,
237aa45a673SLarry Finger BTC_GET_BL_WIFI_BUSY,
238aa45a673SLarry Finger BTC_GET_BL_WIFI_SCAN,
239aa45a673SLarry Finger BTC_GET_BL_WIFI_LINK,
240aa45a673SLarry Finger BTC_GET_BL_WIFI_DHCP,
241aa45a673SLarry Finger BTC_GET_BL_WIFI_SOFTAP_IDLE,
242aa45a673SLarry Finger BTC_GET_BL_WIFI_SOFTAP_LINKING,
243aa45a673SLarry Finger BTC_GET_BL_WIFI_IN_EARLY_SUSPEND,
244aa45a673SLarry Finger BTC_GET_BL_WIFI_ROAM,
245aa45a673SLarry Finger BTC_GET_BL_WIFI_4_WAY_PROGRESS,
246aa45a673SLarry Finger BTC_GET_BL_WIFI_UNDER_5G,
247aa45a673SLarry Finger BTC_GET_BL_WIFI_AP_MODE_ENABLE,
248aa45a673SLarry Finger BTC_GET_BL_WIFI_ENABLE_ENCRYPTION,
249aa45a673SLarry Finger BTC_GET_BL_WIFI_UNDER_B_MODE,
250aa45a673SLarry Finger BTC_GET_BL_EXT_SWITCH,
2517558668dSYan-Hsuan Chuang BTC_GET_BL_WIFI_IS_IN_MP_MODE,
252c42ea613SYan-Hsuan Chuang BTC_GET_BL_IS_ASUS_8723B,
253c42ea613SYan-Hsuan Chuang BTC_GET_BL_FW_READY,
254c42ea613SYan-Hsuan Chuang BTC_GET_BL_RF4CE_CONNECTED,
255aa45a673SLarry Finger
256aa45a673SLarry Finger /* type s4Byte */
257aa45a673SLarry Finger BTC_GET_S4_WIFI_RSSI,
258aa45a673SLarry Finger BTC_GET_S4_HS_RSSI,
259aa45a673SLarry Finger
260aa45a673SLarry Finger /* type u32 */
261aa45a673SLarry Finger BTC_GET_U4_WIFI_BW,
262aa45a673SLarry Finger BTC_GET_U4_WIFI_TRAFFIC_DIRECTION,
263aa45a673SLarry Finger BTC_GET_U4_WIFI_FW_VER,
264ed364abfSLarry Finger BTC_GET_U4_WIFI_LINK_STATUS,
265aa45a673SLarry Finger BTC_GET_U4_BT_PATCH_VER,
2661a281473SPing-Ke Shih BTC_GET_U4_VENDOR,
267c42ea613SYan-Hsuan Chuang BTC_GET_U4_SUPPORTED_VERSION,
268c42ea613SYan-Hsuan Chuang BTC_GET_U4_SUPPORTED_FEATURE,
269b2283dadSPing-Ke Shih BTC_GET_U4_BT_DEVICE_INFO,
270b2283dadSPing-Ke Shih BTC_GET_U4_BT_FORBIDDEN_SLOT_VAL,
271c42ea613SYan-Hsuan Chuang BTC_GET_U4_WIFI_IQK_TOTAL,
272c42ea613SYan-Hsuan Chuang BTC_GET_U4_WIFI_IQK_OK,
273c42ea613SYan-Hsuan Chuang BTC_GET_U4_WIFI_IQK_FAIL,
274aa45a673SLarry Finger
275aa45a673SLarry Finger /* type u1Byte */
276aa45a673SLarry Finger BTC_GET_U1_WIFI_DOT11_CHNL,
277aa45a673SLarry Finger BTC_GET_U1_WIFI_CENTRAL_CHNL,
278aa45a673SLarry Finger BTC_GET_U1_WIFI_HS_CHNL,
279aa45a673SLarry Finger BTC_GET_U1_MAC_PHY_MODE,
280e79fff28SLarry Finger BTC_GET_U1_AP_NUM,
281c42ea613SYan-Hsuan Chuang BTC_GET_U1_ANT_TYPE,
28286aeb825SYan-Hsuan Chuang BTC_GET_U1_IOT_PEER,
283aa45a673SLarry Finger
284aa45a673SLarry Finger /* for 1Ant */
285aa45a673SLarry Finger BTC_GET_U1_LPS_MODE,
286aa45a673SLarry Finger BTC_GET_BL_BT_SCO_BUSY,
287aa45a673SLarry Finger
288aa45a673SLarry Finger /* for test mode */
289aa45a673SLarry Finger BTC_GET_DRIVER_TEST_CFG,
290aa45a673SLarry Finger BTC_GET_MAX
291aa45a673SLarry Finger };
292aa45a673SLarry Finger
2931a281473SPing-Ke Shih enum btc_vendor {
2941a281473SPing-Ke Shih BTC_VENDOR_LENOVO,
2951a281473SPing-Ke Shih BTC_VENDOR_ASUS,
2961a281473SPing-Ke Shih BTC_VENDOR_OTHER
2971a281473SPing-Ke Shih };
2981a281473SPing-Ke Shih
299aa45a673SLarry Finger enum btc_set_type {
300aa45a673SLarry Finger /* type bool */
301aa45a673SLarry Finger BTC_SET_BL_BT_DISABLE,
302aa45a673SLarry Finger BTC_SET_BL_BT_TRAFFIC_BUSY,
303aa45a673SLarry Finger BTC_SET_BL_BT_LIMITED_DIG,
304aa45a673SLarry Finger BTC_SET_BL_FORCE_TO_ROAM,
305aa45a673SLarry Finger BTC_SET_BL_TO_REJ_AP_AGG_PKT,
306aa45a673SLarry Finger BTC_SET_BL_BT_CTRL_AGG_SIZE,
307aa45a673SLarry Finger BTC_SET_BL_INC_SCAN_DEV_NUM,
308588a290bSYan-Hsuan Chuang BTC_SET_BL_BT_TX_RX_MASK,
309a8570896SYan-Hsuan Chuang BTC_SET_BL_MIRACAST_PLUS_BT,
310aa45a673SLarry Finger
311aa45a673SLarry Finger /* type u1Byte */
312aa45a673SLarry Finger BTC_SET_U1_RSSI_ADJ_VAL_FOR_AGC_TABLE_ON,
313aa45a673SLarry Finger BTC_SET_UI_SCAN_SIG_COMPENSATION,
314aa45a673SLarry Finger BTC_SET_U1_AGG_BUF_SIZE,
315aa45a673SLarry Finger
316aa45a673SLarry Finger /* type trigger some action */
317aa45a673SLarry Finger BTC_SET_ACT_GET_BT_RSSI,
318aa45a673SLarry Finger BTC_SET_ACT_AGGREGATE_CTRL,
3196f85c03bSPing-Ke Shih BTC_SET_ACT_ANTPOSREGRISTRY_CTRL,
320c3788947SPing-Ke Shih BTC_SET_MIMO_PS_MODE,
321aa45a673SLarry Finger
322aa45a673SLarry Finger /********* for 1Ant **********/
323aa45a673SLarry Finger /* type bool */
324aa45a673SLarry Finger BTC_SET_BL_BT_SCO_BUSY,
325aa45a673SLarry Finger /* type u1Byte */
326ed364abfSLarry Finger BTC_SET_U1_RSSI_ADJ_VAL_FOR_1ANT_COEX_TYPE,
327ed364abfSLarry Finger BTC_SET_U1_LPS_VAL,
328ed364abfSLarry Finger BTC_SET_U1_RPWM_VAL,
329aa45a673SLarry Finger BTC_SET_U1_1ANT_LPS,
330aa45a673SLarry Finger BTC_SET_U1_1ANT_RPWM,
331aa45a673SLarry Finger /* type trigger some action */
332aa45a673SLarry Finger BTC_SET_ACT_LEAVE_LPS,
333aa45a673SLarry Finger BTC_SET_ACT_ENTER_LPS,
334aa45a673SLarry Finger BTC_SET_ACT_NORMAL_LPS,
335c3468950SPing-Ke Shih BTC_SET_ACT_PRE_NORMAL_LPS,
336c3468950SPing-Ke Shih BTC_SET_ACT_POST_NORMAL_LPS,
337aa45a673SLarry Finger BTC_SET_ACT_INC_FORCE_EXEC_PWR_CMD_CNT,
338aa45a673SLarry Finger BTC_SET_ACT_DISABLE_LOW_POWER,
339c3788947SPing-Ke Shih BTC_SET_BL_BT_LNA_CONSTRAIN_LEVEL,
340c6821613SYan-Hsuan Chuang BTC_SET_ACT_UPDATE_RAMASK,
341aa45a673SLarry Finger BTC_SET_ACT_SEND_MIMO_PS,
342aa45a673SLarry Finger /* BT Coex related */
343aa45a673SLarry Finger BTC_SET_ACT_CTRL_BT_INFO,
344aa45a673SLarry Finger BTC_SET_ACT_CTRL_BT_COEX,
345c42ea613SYan-Hsuan Chuang BTC_SET_ACT_CTRL_8723B_ANT,
346aa45a673SLarry Finger /***************************/
347aa45a673SLarry Finger BTC_SET_MAX
348aa45a673SLarry Finger };
349aa45a673SLarry Finger
350aa45a673SLarry Finger enum btc_dbg_disp_type {
351aa45a673SLarry Finger BTC_DBG_DISP_COEX_STATISTICS = 0x0,
352aa45a673SLarry Finger BTC_DBG_DISP_BT_LINK_INFO = 0x1,
353aa45a673SLarry Finger BTC_DBG_DISP_BT_FW_VER = 0x2,
354aa45a673SLarry Finger BTC_DBG_DISP_FW_PWR_MODE_CMD = 0x3,
35508431b62SPing-Ke Shih BTC_DBG_DISP_WIFI_STATUS = 0x04,
356aa45a673SLarry Finger BTC_DBG_DISP_MAX
357aa45a673SLarry Finger };
358aa45a673SLarry Finger
359aa45a673SLarry Finger enum btc_notify_type_ips {
360aa45a673SLarry Finger BTC_IPS_LEAVE = 0x0,
361aa45a673SLarry Finger BTC_IPS_ENTER = 0x1,
362aa45a673SLarry Finger BTC_IPS_MAX
363aa45a673SLarry Finger };
364aa45a673SLarry Finger
365aa45a673SLarry Finger enum btc_notify_type_lps {
366aa45a673SLarry Finger BTC_LPS_DISABLE = 0x0,
367aa45a673SLarry Finger BTC_LPS_ENABLE = 0x1,
368aa45a673SLarry Finger BTC_LPS_MAX
369aa45a673SLarry Finger };
370aa45a673SLarry Finger
371aa45a673SLarry Finger enum btc_notify_type_scan {
372aa45a673SLarry Finger BTC_SCAN_FINISH = 0x0,
373aa45a673SLarry Finger BTC_SCAN_START = 0x1,
374b82f5e0fSPing-Ke Shih BTC_SCAN_START_2G = 0x2,
375aa45a673SLarry Finger BTC_SCAN_MAX
376aa45a673SLarry Finger };
377aa45a673SLarry Finger
37817bf8510SPing-Ke Shih enum btc_notify_type_switchband {
37917bf8510SPing-Ke Shih BTC_NOT_SWITCH = 0x0,
38017bf8510SPing-Ke Shih BTC_SWITCH_TO_24G = 0x1,
38117bf8510SPing-Ke Shih BTC_SWITCH_TO_5G = 0x2,
38217bf8510SPing-Ke Shih BTC_SWITCH_TO_24G_NOFORSCAN = 0x3,
38317bf8510SPing-Ke Shih BTC_SWITCH_MAX
38417bf8510SPing-Ke Shih };
38517bf8510SPing-Ke Shih
386aa45a673SLarry Finger enum btc_notify_type_associate {
387aa45a673SLarry Finger BTC_ASSOCIATE_FINISH = 0x0,
388aa45a673SLarry Finger BTC_ASSOCIATE_START = 0x1,
3890843e98aSPing-Ke Shih BTC_ASSOCIATE_5G_FINISH = 0x2,
3900843e98aSPing-Ke Shih BTC_ASSOCIATE_5G_START = 0x3,
391aa45a673SLarry Finger BTC_ASSOCIATE_MAX
392aa45a673SLarry Finger };
393aa45a673SLarry Finger
394aa45a673SLarry Finger enum btc_notify_type_media_status {
395aa45a673SLarry Finger BTC_MEDIA_DISCONNECT = 0x0,
396aa45a673SLarry Finger BTC_MEDIA_CONNECT = 0x1,
397aa45a673SLarry Finger BTC_MEDIA_MAX
398aa45a673SLarry Finger };
399aa45a673SLarry Finger
400aa45a673SLarry Finger enum btc_notify_type_special_packet {
401aa45a673SLarry Finger BTC_PACKET_UNKNOWN = 0x0,
402aa45a673SLarry Finger BTC_PACKET_DHCP = 0x1,
403aa45a673SLarry Finger BTC_PACKET_ARP = 0x2,
404aa45a673SLarry Finger BTC_PACKET_EAPOL = 0x3,
405aa45a673SLarry Finger BTC_PACKET_MAX
406aa45a673SLarry Finger };
407aa45a673SLarry Finger
408ed364abfSLarry Finger enum hci_ext_bt_operation {
409ed364abfSLarry Finger HCI_BT_OP_NONE = 0x0,
410ed364abfSLarry Finger HCI_BT_OP_INQUIRY_START = 0x1,
411ed364abfSLarry Finger HCI_BT_OP_INQUIRY_FINISH = 0x2,
412ed364abfSLarry Finger HCI_BT_OP_PAGING_START = 0x3,
413ed364abfSLarry Finger HCI_BT_OP_PAGING_SUCCESS = 0x4,
414ed364abfSLarry Finger HCI_BT_OP_PAGING_UNSUCCESS = 0x5,
415ed364abfSLarry Finger HCI_BT_OP_PAIRING_START = 0x6,
416ed364abfSLarry Finger HCI_BT_OP_PAIRING_FINISH = 0x7,
417ed364abfSLarry Finger HCI_BT_OP_BT_DEV_ENABLE = 0x8,
418ed364abfSLarry Finger HCI_BT_OP_BT_DEV_DISABLE = 0x9,
419ed364abfSLarry Finger HCI_BT_OP_MAX
420ed364abfSLarry Finger };
421ed364abfSLarry Finger
422aa45a673SLarry Finger enum btc_notify_type_stack_operation {
423aa45a673SLarry Finger BTC_STACK_OP_NONE = 0x0,
424aa45a673SLarry Finger BTC_STACK_OP_INQ_PAGE_PAIR_START = 0x1,
425aa45a673SLarry Finger BTC_STACK_OP_INQ_PAGE_PAIR_FINISH = 0x2,
426aa45a673SLarry Finger BTC_STACK_OP_MAX
427aa45a673SLarry Finger };
428aa45a673SLarry Finger
429123068f2SPing-Ke Shih enum {
4301f0ab4fbSPing-Ke Shih BTC_CCK_1,
4311f0ab4fbSPing-Ke Shih BTC_CCK_2,
4321f0ab4fbSPing-Ke Shih BTC_CCK_5_5,
4331f0ab4fbSPing-Ke Shih BTC_CCK_11,
4341f0ab4fbSPing-Ke Shih BTC_OFDM_6,
4351f0ab4fbSPing-Ke Shih BTC_OFDM_9,
4361f0ab4fbSPing-Ke Shih BTC_OFDM_12,
4371f0ab4fbSPing-Ke Shih BTC_OFDM_18,
4381f0ab4fbSPing-Ke Shih BTC_OFDM_24,
4391f0ab4fbSPing-Ke Shih BTC_OFDM_36,
4401f0ab4fbSPing-Ke Shih BTC_OFDM_48,
4411f0ab4fbSPing-Ke Shih BTC_OFDM_54,
4421f0ab4fbSPing-Ke Shih BTC_MCS_0,
4431f0ab4fbSPing-Ke Shih BTC_MCS_1,
4441f0ab4fbSPing-Ke Shih BTC_MCS_2,
4451f0ab4fbSPing-Ke Shih BTC_MCS_3,
4461f0ab4fbSPing-Ke Shih BTC_MCS_4,
4471f0ab4fbSPing-Ke Shih BTC_MCS_5,
4481f0ab4fbSPing-Ke Shih BTC_MCS_6,
4491f0ab4fbSPing-Ke Shih BTC_MCS_7,
4501f0ab4fbSPing-Ke Shih BTC_MCS_8,
4511f0ab4fbSPing-Ke Shih BTC_MCS_9,
4521f0ab4fbSPing-Ke Shih BTC_MCS_10,
4531f0ab4fbSPing-Ke Shih BTC_MCS_11,
4541f0ab4fbSPing-Ke Shih BTC_MCS_12,
4551f0ab4fbSPing-Ke Shih BTC_MCS_13,
4561f0ab4fbSPing-Ke Shih BTC_MCS_14,
4571f0ab4fbSPing-Ke Shih BTC_MCS_15,
4581f0ab4fbSPing-Ke Shih BTC_MCS_16,
4591f0ab4fbSPing-Ke Shih BTC_MCS_17,
4601f0ab4fbSPing-Ke Shih BTC_MCS_18,
4611f0ab4fbSPing-Ke Shih BTC_MCS_19,
4621f0ab4fbSPing-Ke Shih BTC_MCS_20,
4631f0ab4fbSPing-Ke Shih BTC_MCS_21,
4641f0ab4fbSPing-Ke Shih BTC_MCS_22,
4651f0ab4fbSPing-Ke Shih BTC_MCS_23,
4661f0ab4fbSPing-Ke Shih BTC_MCS_24,
4671f0ab4fbSPing-Ke Shih BTC_MCS_25,
4681f0ab4fbSPing-Ke Shih BTC_MCS_26,
4691f0ab4fbSPing-Ke Shih BTC_MCS_27,
4701f0ab4fbSPing-Ke Shih BTC_MCS_28,
4711f0ab4fbSPing-Ke Shih BTC_MCS_29,
4721f0ab4fbSPing-Ke Shih BTC_MCS_30,
4731f0ab4fbSPing-Ke Shih BTC_MCS_31,
4741f0ab4fbSPing-Ke Shih BTC_VHT_1SS_MCS_0,
4751f0ab4fbSPing-Ke Shih BTC_VHT_1SS_MCS_1,
4761f0ab4fbSPing-Ke Shih BTC_VHT_1SS_MCS_2,
4771f0ab4fbSPing-Ke Shih BTC_VHT_1SS_MCS_3,
4781f0ab4fbSPing-Ke Shih BTC_VHT_1SS_MCS_4,
4791f0ab4fbSPing-Ke Shih BTC_VHT_1SS_MCS_5,
4801f0ab4fbSPing-Ke Shih BTC_VHT_1SS_MCS_6,
4811f0ab4fbSPing-Ke Shih BTC_VHT_1SS_MCS_7,
4821f0ab4fbSPing-Ke Shih BTC_VHT_1SS_MCS_8,
4831f0ab4fbSPing-Ke Shih BTC_VHT_1SS_MCS_9,
4841f0ab4fbSPing-Ke Shih BTC_VHT_2SS_MCS_0,
4851f0ab4fbSPing-Ke Shih BTC_VHT_2SS_MCS_1,
4861f0ab4fbSPing-Ke Shih BTC_VHT_2SS_MCS_2,
4871f0ab4fbSPing-Ke Shih BTC_VHT_2SS_MCS_3,
4881f0ab4fbSPing-Ke Shih BTC_VHT_2SS_MCS_4,
4891f0ab4fbSPing-Ke Shih BTC_VHT_2SS_MCS_5,
4901f0ab4fbSPing-Ke Shih BTC_VHT_2SS_MCS_6,
4911f0ab4fbSPing-Ke Shih BTC_VHT_2SS_MCS_7,
4921f0ab4fbSPing-Ke Shih BTC_VHT_2SS_MCS_8,
4931f0ab4fbSPing-Ke Shih BTC_VHT_2SS_MCS_9,
4941f0ab4fbSPing-Ke Shih BTC_VHT_3SS_MCS_0,
4951f0ab4fbSPing-Ke Shih BTC_VHT_3SS_MCS_1,
4961f0ab4fbSPing-Ke Shih BTC_VHT_3SS_MCS_2,
4971f0ab4fbSPing-Ke Shih BTC_VHT_3SS_MCS_3,
4981f0ab4fbSPing-Ke Shih BTC_VHT_3SS_MCS_4,
4991f0ab4fbSPing-Ke Shih BTC_VHT_3SS_MCS_5,
5001f0ab4fbSPing-Ke Shih BTC_VHT_3SS_MCS_6,
5011f0ab4fbSPing-Ke Shih BTC_VHT_3SS_MCS_7,
5021f0ab4fbSPing-Ke Shih BTC_VHT_3SS_MCS_8,
5031f0ab4fbSPing-Ke Shih BTC_VHT_3SS_MCS_9,
5041f0ab4fbSPing-Ke Shih BTC_VHT_4SS_MCS_0,
5051f0ab4fbSPing-Ke Shih BTC_VHT_4SS_MCS_1,
5061f0ab4fbSPing-Ke Shih BTC_VHT_4SS_MCS_2,
5071f0ab4fbSPing-Ke Shih BTC_VHT_4SS_MCS_3,
5081f0ab4fbSPing-Ke Shih BTC_VHT_4SS_MCS_4,
5091f0ab4fbSPing-Ke Shih BTC_VHT_4SS_MCS_5,
5101f0ab4fbSPing-Ke Shih BTC_VHT_4SS_MCS_6,
5111f0ab4fbSPing-Ke Shih BTC_VHT_4SS_MCS_7,
5121f0ab4fbSPing-Ke Shih BTC_VHT_4SS_MCS_8,
5131f0ab4fbSPing-Ke Shih BTC_VHT_4SS_MCS_9,
5141f0ab4fbSPing-Ke Shih BTC_MCS_32,
5151f0ab4fbSPing-Ke Shih BTC_UNKNOWN,
5161f0ab4fbSPing-Ke Shih BTC_PKT_MGNT,
5171f0ab4fbSPing-Ke Shih BTC_PKT_CTRL,
5181f0ab4fbSPing-Ke Shih BTC_PKT_UNKNOWN,
5191f0ab4fbSPing-Ke Shih BTC_PKT_NOT_FOR_ME,
5201f0ab4fbSPing-Ke Shih BTC_RATE_MAX
5211f0ab4fbSPing-Ke Shih };
5221f0ab4fbSPing-Ke Shih
5231f0ab4fbSPing-Ke Shih enum {
524123068f2SPing-Ke Shih BTC_MULTIPORT_SCC,
525123068f2SPing-Ke Shih BTC_MULTIPORT_MCC_2CHANNEL,
526123068f2SPing-Ke Shih BTC_MULTIPORT_MCC_2BAND,
527123068f2SPing-Ke Shih BTC_MULTIPORT_MAX
528123068f2SPing-Ke Shih };
529123068f2SPing-Ke Shih
530aa45a673SLarry Finger struct btc_bt_info {
531aa45a673SLarry Finger bool bt_disabled;
532aa45a673SLarry Finger u8 rssi_adjust_for_agc_table_on;
533aa45a673SLarry Finger u8 rssi_adjust_for_1ant_coex_type;
5340199103eSYan-Hsuan Chuang bool pre_bt_ctrl_agg_buf_size;
535aa45a673SLarry Finger bool bt_busy;
5360199103eSYan-Hsuan Chuang u8 pre_agg_buf_size;
537aa45a673SLarry Finger u8 agg_buf_size;
538aa45a673SLarry Finger bool limited_dig;
5390199103eSYan-Hsuan Chuang bool pre_reject_agg_pkt;
540aa45a673SLarry Finger bool reject_agg_pkt;
541ed364abfSLarry Finger bool bt_ctrl_buf_size;
542aa45a673SLarry Finger bool increase_scan_dev_num;
5430199103eSYan-Hsuan Chuang bool miracast_plus_bt;
5440199103eSYan-Hsuan Chuang bool bt_ctrl_agg_buf_size;
5450199103eSYan-Hsuan Chuang bool bt_tx_rx_mask;
546aa45a673SLarry Finger u16 bt_hci_ver;
547aa45a673SLarry Finger u16 bt_real_fw_ver;
548aa45a673SLarry Finger u8 bt_fw_ver;
549b82f5e0fSPing-Ke Shih u32 bt_get_fw_ver;
550aa45a673SLarry Finger
551ed364abfSLarry Finger bool bt_disable_low_pwr;
552ed364abfSLarry Finger
553aa45a673SLarry Finger /* the following is for 1Ant solution */
554aa45a673SLarry Finger bool bt_ctrl_lps;
555aa45a673SLarry Finger bool bt_pwr_save_mode;
556aa45a673SLarry Finger bool bt_lps_on;
557aa45a673SLarry Finger bool force_to_roam;
558aa45a673SLarry Finger u8 force_exec_pwr_cmd_cnt;
559ed364abfSLarry Finger u8 lps_val;
560ed364abfSLarry Finger u8 rpwm_val;
561aa45a673SLarry Finger u32 ra_mask;
562b2283dadSPing-Ke Shih
563b2283dadSPing-Ke Shih u32 afh_map_l;
564b2283dadSPing-Ke Shih u32 afh_map_m;
565b2283dadSPing-Ke Shih u16 afh_map_h;
566b2283dadSPing-Ke Shih u32 bt_supported_feature;
567b2283dadSPing-Ke Shih u32 bt_supported_version;
568b2283dadSPing-Ke Shih u32 bt_device_info;
569b2283dadSPing-Ke Shih u32 bt_forb_slot_val;
570b2283dadSPing-Ke Shih u8 bt_ant_det_val;
571b2283dadSPing-Ke Shih u8 bt_ble_scan_type;
572b2283dadSPing-Ke Shih u32 bt_ble_scan_para;
573aa45a673SLarry Finger };
574aa45a673SLarry Finger
575aa45a673SLarry Finger struct btc_stack_info {
576aa45a673SLarry Finger bool profile_notified;
577aa45a673SLarry Finger u16 hci_version; /* stack hci version */
578aa45a673SLarry Finger u8 num_of_link;
579aa45a673SLarry Finger bool bt_link_exist;
580aa45a673SLarry Finger bool sco_exist;
581aa45a673SLarry Finger bool acl_exist;
582aa45a673SLarry Finger bool a2dp_exist;
583aa45a673SLarry Finger bool hid_exist;
584aa45a673SLarry Finger u8 num_of_hid;
585aa45a673SLarry Finger bool pan_exist;
586aa45a673SLarry Finger bool unknown_acl_exist;
58708aba42fSArnd Bergmann s8 min_bt_rssi;
588aa45a673SLarry Finger };
589aa45a673SLarry Finger
590aa45a673SLarry Finger struct btc_statistics {
591aa45a673SLarry Finger u32 cnt_bind;
592aa45a673SLarry Finger u32 cnt_init_hw_config;
593aa45a673SLarry Finger u32 cnt_init_coex_dm;
594aa45a673SLarry Finger u32 cnt_ips_notify;
595aa45a673SLarry Finger u32 cnt_lps_notify;
596aa45a673SLarry Finger u32 cnt_scan_notify;
597aa45a673SLarry Finger u32 cnt_connect_notify;
598aa45a673SLarry Finger u32 cnt_media_status_notify;
599aa45a673SLarry Finger u32 cnt_special_packet_notify;
600aa45a673SLarry Finger u32 cnt_bt_info_notify;
601aa45a673SLarry Finger u32 cnt_periodical;
602ed364abfSLarry Finger u32 cnt_coex_dm_switch;
603aa45a673SLarry Finger u32 cnt_stack_operation_notify;
604aa45a673SLarry Finger u32 cnt_dbg_ctrl;
6056fbbc82aSYan-Hsuan Chuang u32 cnt_pre_load_firmware;
60660f44100SYan-Hsuan Chuang u32 cnt_power_on;
607aa45a673SLarry Finger };
608aa45a673SLarry Finger
609aa45a673SLarry Finger struct btc_bt_link_info {
610aa45a673SLarry Finger bool bt_link_exist;
61175717802SPing-Ke Shih bool bt_hi_pri_link_exist;
612aa45a673SLarry Finger bool sco_exist;
613aa45a673SLarry Finger bool sco_only;
614aa45a673SLarry Finger bool a2dp_exist;
615aa45a673SLarry Finger bool a2dp_only;
616aa45a673SLarry Finger bool hid_exist;
617aa45a673SLarry Finger bool hid_only;
618aa45a673SLarry Finger bool pan_exist;
619aa45a673SLarry Finger bool pan_only;
62061d80261SYan-Hsuan Chuang bool slave_role;
621b82f5e0fSPing-Ke Shih bool acl_busy;
622aa45a673SLarry Finger };
623aa45a673SLarry Finger
624aa45a673SLarry Finger enum btc_antenna_pos {
625aa45a673SLarry Finger BTC_ANTENNA_AT_MAIN_PORT = 0x1,
626aa45a673SLarry Finger BTC_ANTENNA_AT_AUX_PORT = 0x2,
627aa45a673SLarry Finger };
628aa45a673SLarry Finger
629b2283dadSPing-Ke Shih enum btc_mp_h2c_op_code {
630b2283dadSPing-Ke Shih BT_OP_GET_BT_VERSION = 0,
631b2283dadSPing-Ke Shih BT_OP_WRITE_REG_ADDR = 12,
632b2283dadSPing-Ke Shih BT_OP_WRITE_REG_VALUE = 13,
633b2283dadSPing-Ke Shih BT_OP_READ_REG = 17,
634b2283dadSPing-Ke Shih BT_OP_GET_AFH_MAP_L = 30,
635b2283dadSPing-Ke Shih BT_OP_GET_AFH_MAP_M = 31,
636b2283dadSPing-Ke Shih BT_OP_GET_AFH_MAP_H = 32,
637b2283dadSPing-Ke Shih BT_OP_GET_BT_COEX_SUPPORTED_FEATURE = 42,
638b2283dadSPing-Ke Shih BT_OP_GET_BT_COEX_SUPPORTED_VERSION = 43,
639b2283dadSPing-Ke Shih BT_OP_GET_BT_ANT_DET_VAL = 44,
640b2283dadSPing-Ke Shih BT_OP_GET_BT_BLE_SCAN_PARA = 45,
641b2283dadSPing-Ke Shih BT_OP_GET_BT_BLE_SCAN_TYPE = 46,
642b2283dadSPing-Ke Shih BT_OP_GET_BT_DEVICE_INFO = 48,
643b2283dadSPing-Ke Shih BT_OP_GET_BT_FORBIDDEN_SLOT_VAL = 49,
644b2283dadSPing-Ke Shih BT_OP_MAX
645b2283dadSPing-Ke Shih };
646b2283dadSPing-Ke Shih
647b2283dadSPing-Ke Shih enum btc_mp_h2c_req_num {
648b2283dadSPing-Ke Shih /* 4 bits only */
649b2283dadSPing-Ke Shih BT_SEQ_DONT_CARE = 0,
650b2283dadSPing-Ke Shih BT_SEQ_GET_BT_VERSION = 0xE,
651b2283dadSPing-Ke Shih BT_SEQ_GET_AFH_MAP_L = 0x5,
652b2283dadSPing-Ke Shih BT_SEQ_GET_AFH_MAP_M = 0x6,
653b2283dadSPing-Ke Shih BT_SEQ_GET_AFH_MAP_H = 0x9,
654b2283dadSPing-Ke Shih BT_SEQ_GET_BT_COEX_SUPPORTED_FEATURE = 0x7,
655b2283dadSPing-Ke Shih BT_SEQ_GET_BT_COEX_SUPPORTED_VERSION = 0x8,
656b2283dadSPing-Ke Shih BT_SEQ_GET_BT_ANT_DET_VAL = 0x2,
657b2283dadSPing-Ke Shih BT_SEQ_GET_BT_BLE_SCAN_PARA = 0x3,
658b2283dadSPing-Ke Shih BT_SEQ_GET_BT_BLE_SCAN_TYPE = 0x4,
659b2283dadSPing-Ke Shih BT_SEQ_GET_BT_DEVICE_INFO = 0xA,
660b2283dadSPing-Ke Shih BT_SEQ_GET_BT_FORB_SLOT_VAL = 0xB,
661b2283dadSPing-Ke Shih };
662b2283dadSPing-Ke Shih
663aa45a673SLarry Finger struct btc_coexist {
664aa45a673SLarry Finger /* make sure only one adapter can bind the data context */
665aa45a673SLarry Finger bool binded;
666aa45a673SLarry Finger /* default adapter */
667aa45a673SLarry Finger void *adapter;
668aa45a673SLarry Finger struct btc_board_info board_info;
669aa45a673SLarry Finger /* some bt info referenced by non-bt module */
670aa45a673SLarry Finger struct btc_bt_info bt_info;
671aa45a673SLarry Finger struct btc_stack_info stack_info;
672aa45a673SLarry Finger enum btc_chip_interface chip_interface;
673aa45a673SLarry Finger struct btc_bt_link_info bt_link_info;
674aa45a673SLarry Finger
675aef9ae46SLarry Finger /* boolean variables to replace BT_AUTO_REPORT_ONLY_XXXXY_ZANT
676aef9ae46SLarry Finger * configuration parameters
677aef9ae46SLarry Finger */
678aef9ae46SLarry Finger bool auto_report_1ant;
679aef9ae46SLarry Finger bool auto_report_2ant;
6808d73e53eSPing-Ke Shih bool dbg_mode_1ant;
6818d73e53eSPing-Ke Shih bool dbg_mode_2ant;
682*f76c3408SColin Ian King bool initialized;
683aa45a673SLarry Finger bool stop_coex_dm;
684aa45a673SLarry Finger bool manual_control;
685aa45a673SLarry Finger struct btc_statistics statistics;
686aa45a673SLarry Finger u8 pwr_mode_val[10];
687aa45a673SLarry Finger
688b2283dadSPing-Ke Shih struct completion bt_mp_comp;
689b2283dadSPing-Ke Shih
690aa45a673SLarry Finger /* function pointers - io related */
6913afb7da4SLarry Finger u8 (*btc_read_1byte)(void *btc_context, u32 reg_addr);
6923afb7da4SLarry Finger void (*btc_write_1byte)(void *btc_context, u32 reg_addr, u32 data);
6933afb7da4SLarry Finger void (*btc_write_1byte_bitmask)(void *btc_context, u32 reg_addr,
6943afb7da4SLarry Finger u32 bit_mask, u8 data1b);
6953afb7da4SLarry Finger u16 (*btc_read_2byte)(void *btc_context, u32 reg_addr);
6963afb7da4SLarry Finger void (*btc_write_2byte)(void *btc_context, u32 reg_addr, u16 data);
6973afb7da4SLarry Finger u32 (*btc_read_4byte)(void *btc_context, u32 reg_addr);
6983afb7da4SLarry Finger void (*btc_write_4byte)(void *btc_context, u32 reg_addr, u32 data);
699aa45a673SLarry Finger
7003afb7da4SLarry Finger void (*btc_write_local_reg_1byte)(void *btc_context, u32 reg_addr,
7013afb7da4SLarry Finger u8 data);
7023afb7da4SLarry Finger void (*btc_set_bb_reg)(void *btc_context, u32 reg_addr,
7033afb7da4SLarry Finger u32 bit_mask, u32 data);
7043afb7da4SLarry Finger u32 (*btc_get_bb_reg)(void *btc_context, u32 reg_addr,
7053afb7da4SLarry Finger u32 bit_mask);
7063afb7da4SLarry Finger void (*btc_set_rf_reg)(void *btc_context, u8 rf_path, u32 reg_addr,
7073afb7da4SLarry Finger u32 bit_mask, u32 data);
7083afb7da4SLarry Finger u32 (*btc_get_rf_reg)(void *btc_context, u8 rf_path,
7093afb7da4SLarry Finger u32 reg_addr, u32 bit_mask);
710aa45a673SLarry Finger
7113afb7da4SLarry Finger void (*btc_fill_h2c)(void *btc_context, u8 element_id,
7123afb7da4SLarry Finger u32 cmd_len, u8 *cmd_buffer);
713aa45a673SLarry Finger
7143afb7da4SLarry Finger void (*btc_disp_dbg_msg)(void *btcoexist, u8 disp_type,
7153afb7da4SLarry Finger struct seq_file *m);
716aa45a673SLarry Finger
7173afb7da4SLarry Finger bool (*btc_get)(void *btcoexist, u8 get_type, void *out_buf);
7183afb7da4SLarry Finger bool (*btc_set)(void *btcoexist, u8 set_type, void *in_buf);
719aa45a673SLarry Finger
7203afb7da4SLarry Finger void (*btc_set_bt_reg)(void *btc_context, u8 reg_type, u32 offset,
7213afb7da4SLarry Finger u32 value);
722c3788947SPing-Ke Shih u32 (*btc_get_bt_reg)(void *btc_context, u8 reg_type, u32 offset);
723b2283dadSPing-Ke Shih u32 (*btc_get_bt_coex_supported_feature)(void *btcoexist);
724b2283dadSPing-Ke Shih u32 (*btc_get_bt_coex_supported_version)(void *btcoexist);
7257fd34dc4SPing-Ke Shih u32 (*btc_get_bt_phydm_version)(void *btcoexist);
7267fd34dc4SPing-Ke Shih void (*btc_phydm_modify_ra_pcr_threshold)(void *btcoexist,
7277fd34dc4SPing-Ke Shih u8 ra_offset_direction,
7287fd34dc4SPing-Ke Shih u8 ra_threshold_offset);
7297fd34dc4SPing-Ke Shih u32 (*btc_phydm_query_phy_counter)(void *btcoexist,
7307fd34dc4SPing-Ke Shih enum dm_info_query dm_id);
731b2283dadSPing-Ke Shih u8 (*btc_get_ant_det_val_from_bt)(void *btcoexist);
732b2283dadSPing-Ke Shih u8 (*btc_get_ble_scan_type_from_bt)(void *btcoexist);
733b2283dadSPing-Ke Shih u32 (*btc_get_ble_scan_para_from_bt)(void *btcoexist, u8 scan_type);
734b2283dadSPing-Ke Shih bool (*btc_get_bt_afh_map_from_bt)(void *btcoexist, u8 map_type,
735b2283dadSPing-Ke Shih u8 *afh_map);
736aa45a673SLarry Finger };
737aa45a673SLarry Finger
738aa45a673SLarry Finger bool halbtc_is_wifi_uplink(struct rtl_priv *adapter);
739aa45a673SLarry Finger
74040d9dd4fSPing-Ke Shih #define rtl_btc_coexist(rtlpriv) \
74140d9dd4fSPing-Ke Shih ((struct btc_coexist *)((rtlpriv)->btcoexist.btc_context))
7429177c336SPing-Ke Shih #define rtl_btc_wifi_only(rtlpriv) \
7439177c336SPing-Ke Shih ((struct wifi_only_cfg *)((rtlpriv)->btcoexist.wifi_only_context))
7449177c336SPing-Ke Shih
7459177c336SPing-Ke Shih struct wifi_only_cfg;
746aa45a673SLarry Finger
74740d9dd4fSPing-Ke Shih bool exhalbtc_initlize_variables(struct rtl_priv *rtlpriv);
7489177c336SPing-Ke Shih bool exhalbtc_initlize_variables_wifi_only(struct rtl_priv *rtlpriv);
74987d8a9f3SPing-Ke Shih bool exhalbtc_bind_bt_coex_withadapter(void *adapter);
750a44709bbSPing-Ke Shih void exhalbtc_power_on_setting(struct btc_coexist *btcoexist);
751f2f6026aSPing-Ke Shih void exhalbtc_pre_load_firmware(struct btc_coexist *btcoexist);
75243f5644aSPing-Ke Shih void exhalbtc_init_hw_config(struct btc_coexist *btcoexist, bool wifi_only);
7539177c336SPing-Ke Shih void exhalbtc_init_hw_config_wifi_only(struct wifi_only_cfg *wifionly_cfg);
754aa45a673SLarry Finger void exhalbtc_init_coex_dm(struct btc_coexist *btcoexist);
755aa45a673SLarry Finger void exhalbtc_ips_notify(struct btc_coexist *btcoexist, u8 type);
756aa45a673SLarry Finger void exhalbtc_lps_notify(struct btc_coexist *btcoexist, u8 type);
757aa45a673SLarry Finger void exhalbtc_scan_notify(struct btc_coexist *btcoexist, u8 type);
7589177c336SPing-Ke Shih void exhalbtc_scan_notify_wifi_only(struct wifi_only_cfg *wifionly_cfg,
7599177c336SPing-Ke Shih u8 is_5g);
760aa45a673SLarry Finger void exhalbtc_connect_notify(struct btc_coexist *btcoexist, u8 action);
761aa45a673SLarry Finger void exhalbtc_mediastatus_notify(struct btc_coexist *btcoexist,
762ed364abfSLarry Finger enum rt_media_status media_status);
763aa45a673SLarry Finger void exhalbtc_special_packet_notify(struct btc_coexist *btcoexist, u8 pkt_type);
764aa45a673SLarry Finger void exhalbtc_bt_info_notify(struct btc_coexist *btcoexist, u8 *tmp_buf,
765aa45a673SLarry Finger u8 length);
766aa45a673SLarry Finger void exhalbtc_halt_notify(struct btc_coexist *btcoexist);
767aa45a673SLarry Finger void exhalbtc_pnp_notify(struct btc_coexist *btcoexist, u8 pnp_state);
768aa45a673SLarry Finger void exhalbtc_periodical(struct btc_coexist *btcoexist);
76940d9dd4fSPing-Ke Shih void exhalbtc_update_min_bt_rssi(struct btc_coexist *btcoexist, s8 bt_rssi);
77040d9dd4fSPing-Ke Shih void exhalbtc_set_bt_exist(struct btc_coexist *btcoexist, bool bt_exist);
77140d9dd4fSPing-Ke Shih void exhalbtc_set_chip_type(struct btc_coexist *btcoexist, u8 chip_type);
772baa17022SLarry Finger void exhalbtc_set_ant_num(struct rtl_priv *rtlpriv, u8 type, u8 ant_num);
773610247f4SPing-Ke Shih void exhalbtc_display_bt_coex_info(struct btc_coexist *btcoexist,
774610247f4SPing-Ke Shih struct seq_file *m);
77517bf8510SPing-Ke Shih void exhalbtc_switch_band_notify(struct btc_coexist *btcoexist, u8 type);
7769177c336SPing-Ke Shih void exhalbtc_switch_band_notify_wifi_only(struct wifi_only_cfg *wifionly_cfg,
7779177c336SPing-Ke Shih u8 is_5g);
778aa45a673SLarry Finger void exhalbtc_signal_compensation(struct btc_coexist *btcoexist,
779aa45a673SLarry Finger u8 *rssi_wifi, u8 *rssi_bt);
780aa45a673SLarry Finger void exhalbtc_lps_leave(struct btc_coexist *btcoexist);
781aa45a673SLarry Finger void exhalbtc_low_wifi_traffic_notify(struct btc_coexist *btcoexist);
78240d9dd4fSPing-Ke Shih void exhalbtc_set_single_ant_path(struct btc_coexist *btcoexist,
78340d9dd4fSPing-Ke Shih u8 single_ant_path);
784d7297a86SPing-Ke Shih void halbtc_send_wifi_port_id_cmd(void *bt_context);
785d7297a86SPing-Ke Shih void halbtc_set_default_port_id_cmd(void *bt_context);
786aa45a673SLarry Finger
7879177c336SPing-Ke Shih /* The following are used by wifi_only case */
7889177c336SPing-Ke Shih enum wifionly_chip_interface {
7899177c336SPing-Ke Shih WIFIONLY_INTF_UNKNOWN = 0,
7909177c336SPing-Ke Shih WIFIONLY_INTF_PCI = 1,
7919177c336SPing-Ke Shih WIFIONLY_INTF_USB = 2,
7929177c336SPing-Ke Shih WIFIONLY_INTF_SDIO = 3,
7939177c336SPing-Ke Shih WIFIONLY_INTF_MAX
7949177c336SPing-Ke Shih };
7959177c336SPing-Ke Shih
7969177c336SPing-Ke Shih enum wifionly_customer_id {
7979177c336SPing-Ke Shih CUSTOMER_NORMAL = 0,
7989177c336SPing-Ke Shih CUSTOMER_HP_1 = 1,
7999177c336SPing-Ke Shih };
8009177c336SPing-Ke Shih
8019177c336SPing-Ke Shih struct wifi_only_haldata {
8029177c336SPing-Ke Shih u16 customer_id;
8039177c336SPing-Ke Shih u8 efuse_pg_antnum;
8049177c336SPing-Ke Shih u8 efuse_pg_antpath;
8059177c336SPing-Ke Shih u8 rfe_type;
8069177c336SPing-Ke Shih u8 ant_div_cfg;
8079177c336SPing-Ke Shih };
8089177c336SPing-Ke Shih
8099177c336SPing-Ke Shih struct wifi_only_cfg {
8109177c336SPing-Ke Shih void *adapter;
8119177c336SPing-Ke Shih struct wifi_only_haldata haldata_info;
8129177c336SPing-Ke Shih enum wifionly_chip_interface chip_interface;
8139177c336SPing-Ke Shih };
8149177c336SPing-Ke Shih
8159177c336SPing-Ke Shih static inline
halwifionly_phy_set_bb_reg(struct wifi_only_cfg * wifi_conly_cfg,u32 regaddr,u32 bitmask,u32 data)8169177c336SPing-Ke Shih void halwifionly_phy_set_bb_reg(struct wifi_only_cfg *wifi_conly_cfg,
8179177c336SPing-Ke Shih u32 regaddr, u32 bitmask, u32 data)
8189177c336SPing-Ke Shih {
8199177c336SPing-Ke Shih struct rtl_priv *rtlpriv = (struct rtl_priv *)wifi_conly_cfg->adapter;
8209177c336SPing-Ke Shih
8219177c336SPing-Ke Shih rtl_set_bbreg(rtlpriv->hw, regaddr, bitmask, data);
8229177c336SPing-Ke Shih }
8239177c336SPing-Ke Shih
824aa45a673SLarry Finger #endif
825