xref: /openbmc/linux/drivers/net/wireless/realtek/rtlwifi/btcoexist/halbtcoutsrc.h (revision 8dd06ef34b6e2f41b29fbf5fc1663780f2524285)
18c086312SLarry Finger /* SPDX-License-Identifier: GPL-2.0 */
28c086312SLarry Finger /* Copyright(c) 2009-2012  Realtek Corporation.*/
38c086312SLarry Finger 
4f1d2b4d3SLarry Finger #ifndef	__HALBTC_OUT_SRC_H__
5f1d2b4d3SLarry Finger #define __HALBTC_OUT_SRC_H__
6f1d2b4d3SLarry Finger 
7f1d2b4d3SLarry Finger #include	"../wifi.h"
8f1d2b4d3SLarry Finger 
9f1d2b4d3SLarry Finger #define		NORMAL_EXEC				false
10f1d2b4d3SLarry Finger #define		FORCE_EXEC				true
11f1d2b4d3SLarry Finger 
123ceac0a7SPing-Ke Shih #define		BTC_RF_OFF				0x0
133ceac0a7SPing-Ke Shih #define		BTC_RF_ON				0x1
143ceac0a7SPing-Ke Shih 
15f1d2b4d3SLarry Finger #define		BTC_RF_A				RF90_PATH_A
16f1d2b4d3SLarry Finger #define		BTC_RF_B				RF90_PATH_B
17f1d2b4d3SLarry Finger #define		BTC_RF_C				RF90_PATH_C
18f1d2b4d3SLarry Finger #define		BTC_RF_D				RF90_PATH_D
19f1d2b4d3SLarry Finger 
20f1d2b4d3SLarry Finger #define		BTC_SMSP				SINGLEMAC_SINGLEPHY
21f1d2b4d3SLarry Finger #define		BTC_DMDP				DUALMAC_DUALPHY
22f1d2b4d3SLarry Finger #define		BTC_DMSP				DUALMAC_SINGLEPHY
23f1d2b4d3SLarry Finger #define		BTC_MP_UNKNOWN				0xff
24f1d2b4d3SLarry Finger 
25f1d2b4d3SLarry Finger #define		IN
26f1d2b4d3SLarry Finger #define		OUT
27f1d2b4d3SLarry Finger 
28f1d2b4d3SLarry Finger #define		BT_TMP_BUF_SIZE				100
29f1d2b4d3SLarry Finger 
30f1d2b4d3SLarry Finger #define		BT_COEX_ANT_TYPE_PG			0
31f1d2b4d3SLarry Finger #define		BT_COEX_ANT_TYPE_ANTDIV			1
32f1d2b4d3SLarry Finger #define		BT_COEX_ANT_TYPE_DETECTED		2
33f1d2b4d3SLarry Finger 
34f1d2b4d3SLarry Finger #define		BTC_MIMO_PS_STATIC			0
35f1d2b4d3SLarry Finger #define		BTC_MIMO_PS_DYNAMIC			1
36f1d2b4d3SLarry Finger 
37f1d2b4d3SLarry Finger #define		BTC_RATE_DISABLE			0
38f1d2b4d3SLarry Finger #define		BTC_RATE_ENABLE				1
39f1d2b4d3SLarry Finger 
40f1d2b4d3SLarry Finger /* single Antenna definition */
41f1d2b4d3SLarry Finger #define		BTC_ANT_PATH_WIFI			0
42f1d2b4d3SLarry Finger #define		BTC_ANT_PATH_BT				1
43f1d2b4d3SLarry 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
46f1d2b4d3SLarry Finger /* dual Antenna definition */
47f1d2b4d3SLarry Finger #define		BTC_ANT_WIFI_AT_MAIN			0
48f1d2b4d3SLarry Finger #define		BTC_ANT_WIFI_AT_AUX			1
49f1d2b4d3SLarry Finger /* coupler Antenna definition */
50f1d2b4d3SLarry Finger #define		BTC_ANT_WIFI_AT_CPL_MAIN		0
51f1d2b4d3SLarry Finger #define		BTC_ANT_WIFI_AT_CPL_AUX			1
52f1d2b4d3SLarry 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 
62f1d2b4d3SLarry Finger enum btc_chip_interface {
63f1d2b4d3SLarry Finger 	BTC_INTF_UNKNOWN	= 0,
64f1d2b4d3SLarry Finger 	BTC_INTF_PCI		= 1,
65f1d2b4d3SLarry Finger 	BTC_INTF_USB		= 2,
66f1d2b4d3SLarry Finger 	BTC_INTF_SDIO		= 3,
67f1d2b4d3SLarry Finger 	BTC_INTF_GSPI		= 4,
68f1d2b4d3SLarry Finger 	BTC_INTF_MAX
69f1d2b4d3SLarry Finger };
70f1d2b4d3SLarry Finger 
71f1d2b4d3SLarry Finger enum btc_chip_type {
72f1d2b4d3SLarry Finger 	BTC_CHIP_UNDEF		= 0,
73f1d2b4d3SLarry Finger 	BTC_CHIP_CSR_BC4	= 1,
74f1d2b4d3SLarry Finger 	BTC_CHIP_CSR_BC8	= 2,
75f1d2b4d3SLarry Finger 	BTC_CHIP_RTL8723A	= 3,
76f1d2b4d3SLarry Finger 	BTC_CHIP_RTL8821	= 4,
77f1d2b4d3SLarry Finger 	BTC_CHIP_RTL8723B	= 5,
78f1d2b4d3SLarry Finger 	BTC_CHIP_MAX
79f1d2b4d3SLarry Finger };
80f1d2b4d3SLarry Finger 
81f1d2b4d3SLarry Finger enum btc_msg_type {
82f1d2b4d3SLarry Finger 	BTC_MSG_INTERFACE	= 0x0,
83f1d2b4d3SLarry Finger 	BTC_MSG_ALGORITHM	= 0x1,
84f1d2b4d3SLarry Finger 	BTC_MSG_MAX
85f1d2b4d3SLarry Finger };
86f1d2b4d3SLarry Finger 
87f1d2b4d3SLarry Finger /* following is for BTC_MSG_INTERFACE */
88f1d2b4d3SLarry Finger #define		INTF_INIT				BIT0
89f1d2b4d3SLarry Finger #define		INTF_NOTIFY				BIT2
90f1d2b4d3SLarry Finger 
91f1d2b4d3SLarry Finger /* following is for BTC_ALGORITHM */
92f1d2b4d3SLarry Finger #define		ALGO_BT_RSSI_STATE			BIT0
93f1d2b4d3SLarry Finger #define		ALGO_WIFI_RSSI_STATE			BIT1
94f1d2b4d3SLarry Finger #define		ALGO_BT_MONITOR				BIT2
95f1d2b4d3SLarry Finger #define		ALGO_TRACE				BIT3
96f1d2b4d3SLarry Finger #define		ALGO_TRACE_FW				BIT4
97f1d2b4d3SLarry Finger #define		ALGO_TRACE_FW_DETAIL			BIT5
98f1d2b4d3SLarry Finger #define		ALGO_TRACE_FW_EXEC			BIT6
99f1d2b4d3SLarry Finger #define		ALGO_TRACE_SW				BIT7
100f1d2b4d3SLarry Finger #define		ALGO_TRACE_SW_DETAIL			BIT8
101f1d2b4d3SLarry Finger #define		ALGO_TRACE_SW_EXEC			BIT9
102f1d2b4d3SLarry Finger 
103f1d2b4d3SLarry Finger /* following is for wifi link status */
104f1d2b4d3SLarry Finger #define		WIFI_STA_CONNECTED			BIT0
105f1d2b4d3SLarry Finger #define		WIFI_AP_CONNECTED			BIT1
106f1d2b4d3SLarry Finger #define		WIFI_HS_CONNECTED			BIT2
107f1d2b4d3SLarry Finger #define		WIFI_P2P_GO_CONNECTED			BIT3
108f1d2b4d3SLarry Finger #define		WIFI_P2P_GC_CONNECTED			BIT4
109f1d2b4d3SLarry Finger 
110f1d2b4d3SLarry Finger #define	BTC_RSSI_HIGH(_rssi_)	\
111f1d2b4d3SLarry Finger 	((_rssi_ == BTC_RSSI_STATE_HIGH ||	\
112f1d2b4d3SLarry Finger 	  _rssi_ == BTC_RSSI_STATE_STAY_HIGH) ? true : false)
113f1d2b4d3SLarry Finger #define	BTC_RSSI_MEDIUM(_rssi_)	\
114f1d2b4d3SLarry Finger 	((_rssi_ == BTC_RSSI_STATE_MEDIUM ||	\
115f1d2b4d3SLarry Finger 	  _rssi_ == BTC_RSSI_STATE_STAY_MEDIUM) ? true : false)
116f1d2b4d3SLarry Finger #define	BTC_RSSI_LOW(_rssi_)	\
117f1d2b4d3SLarry Finger 	((_rssi_ == BTC_RSSI_STATE_LOW ||	\
118f1d2b4d3SLarry Finger 	  _rssi_ == BTC_RSSI_STATE_STAY_LOW) ? true : false)
119f1d2b4d3SLarry Finger 
120f1d2b4d3SLarry Finger enum btc_power_save_type {
121f1d2b4d3SLarry Finger 	BTC_PS_WIFI_NATIVE = 0,
122f1d2b4d3SLarry Finger 	BTC_PS_LPS_ON = 1,
123f1d2b4d3SLarry Finger 	BTC_PS_LPS_OFF = 2,
124f1d2b4d3SLarry Finger 	BTC_PS_LPS_MAX
125f1d2b4d3SLarry Finger };
126f1d2b4d3SLarry Finger 
127f1d2b4d3SLarry Finger struct btc_board_info {
128f1d2b4d3SLarry Finger 	/* The following is some board information */
129f1d2b4d3SLarry Finger 	u8 bt_chip_type;
130f1d2b4d3SLarry Finger 	u8 pg_ant_num;	/* pg ant number */
131f1d2b4d3SLarry Finger 	u8 btdm_ant_num;	/* ant number for btdm */
132f1d2b4d3SLarry 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;
139f1d2b4d3SLarry Finger };
140f1d2b4d3SLarry Finger 
141f1d2b4d3SLarry Finger enum btc_dbg_opcode {
142f1d2b4d3SLarry Finger 	BTC_DBG_SET_COEX_NORMAL = 0x0,
143f1d2b4d3SLarry Finger 	BTC_DBG_SET_COEX_WIFI_ONLY = 0x1,
144f1d2b4d3SLarry Finger 	BTC_DBG_SET_COEX_BT_ONLY = 0x2,
145f1d2b4d3SLarry Finger 	BTC_DBG_MAX
146f1d2b4d3SLarry Finger };
147f1d2b4d3SLarry Finger 
148f1d2b4d3SLarry Finger enum btc_rssi_state {
149f1d2b4d3SLarry Finger 	BTC_RSSI_STATE_HIGH = 0x0,
150f1d2b4d3SLarry Finger 	BTC_RSSI_STATE_MEDIUM = 0x1,
151f1d2b4d3SLarry Finger 	BTC_RSSI_STATE_LOW = 0x2,
152f1d2b4d3SLarry Finger 	BTC_RSSI_STATE_STAY_HIGH = 0x3,
153f1d2b4d3SLarry Finger 	BTC_RSSI_STATE_STAY_MEDIUM = 0x4,
154f1d2b4d3SLarry Finger 	BTC_RSSI_STATE_STAY_LOW = 0x5,
155f1d2b4d3SLarry Finger 	BTC_RSSI_MAX
156f1d2b4d3SLarry Finger };
157f1d2b4d3SLarry Finger 
158f1d2b4d3SLarry Finger enum btc_wifi_role {
159f1d2b4d3SLarry Finger 	BTC_ROLE_STATION = 0x0,
160f1d2b4d3SLarry Finger 	BTC_ROLE_AP = 0x1,
161f1d2b4d3SLarry Finger 	BTC_ROLE_IBSS = 0x2,
162f1d2b4d3SLarry Finger 	BTC_ROLE_HS_MODE = 0x3,
163f1d2b4d3SLarry Finger 	BTC_ROLE_MAX
164f1d2b4d3SLarry Finger };
165f1d2b4d3SLarry 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 
172f1d2b4d3SLarry Finger enum btc_wifi_bw_mode {
173f1d2b4d3SLarry Finger 	BTC_WIFI_BW_LEGACY = 0x0,
174f1d2b4d3SLarry Finger 	BTC_WIFI_BW_HT20 = 0x1,
175f1d2b4d3SLarry Finger 	BTC_WIFI_BW_HT40 = 0x2,
17666d0f9deSPing-Ke Shih 	BTC_WIFI_BW_HT80 = 0x3,
177f1d2b4d3SLarry Finger 	BTC_WIFI_BW_MAX
178f1d2b4d3SLarry Finger };
179f1d2b4d3SLarry Finger 
180f1d2b4d3SLarry Finger enum btc_wifi_traffic_dir {
181f1d2b4d3SLarry Finger 	BTC_WIFI_TRAFFIC_TX = 0x0,
182f1d2b4d3SLarry Finger 	BTC_WIFI_TRAFFIC_RX = 0x1,
183f1d2b4d3SLarry Finger 	BTC_WIFI_TRAFFIC_MAX
184f1d2b4d3SLarry Finger };
185f1d2b4d3SLarry Finger 
186f1d2b4d3SLarry Finger enum btc_wifi_pnp {
187f1d2b4d3SLarry Finger 	BTC_WIFI_PNP_WAKE_UP = 0x0,
188f1d2b4d3SLarry Finger 	BTC_WIFI_PNP_SLEEP = 0x1,
189b82f5e0fSPing-Ke Shih 	BTC_WIFI_PNP_SLEEP_KEEP_ANT = 0x2,
190f1d2b4d3SLarry Finger 	BTC_WIFI_PNP_MAX
191f1d2b4d3SLarry Finger };
192f1d2b4d3SLarry 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 
231f1d2b4d3SLarry Finger enum btc_get_type {
232f1d2b4d3SLarry Finger 	/* type bool */
233f1d2b4d3SLarry Finger 	BTC_GET_BL_HS_OPERATION,
234f1d2b4d3SLarry Finger 	BTC_GET_BL_HS_CONNECTING,
235f1d2b4d3SLarry Finger 	BTC_GET_BL_WIFI_CONNECTED,
236123068f2SPing-Ke Shih 	BTC_GET_BL_WIFI_DUAL_BAND_CONNECTED,
237f1d2b4d3SLarry Finger 	BTC_GET_BL_WIFI_BUSY,
238f1d2b4d3SLarry Finger 	BTC_GET_BL_WIFI_SCAN,
239f1d2b4d3SLarry Finger 	BTC_GET_BL_WIFI_LINK,
240f1d2b4d3SLarry Finger 	BTC_GET_BL_WIFI_DHCP,
241f1d2b4d3SLarry Finger 	BTC_GET_BL_WIFI_SOFTAP_IDLE,
242f1d2b4d3SLarry Finger 	BTC_GET_BL_WIFI_SOFTAP_LINKING,
243f1d2b4d3SLarry Finger 	BTC_GET_BL_WIFI_IN_EARLY_SUSPEND,
244f1d2b4d3SLarry Finger 	BTC_GET_BL_WIFI_ROAM,
245f1d2b4d3SLarry Finger 	BTC_GET_BL_WIFI_4_WAY_PROGRESS,
246f1d2b4d3SLarry Finger 	BTC_GET_BL_WIFI_UNDER_5G,
247f1d2b4d3SLarry Finger 	BTC_GET_BL_WIFI_AP_MODE_ENABLE,
248f1d2b4d3SLarry Finger 	BTC_GET_BL_WIFI_ENABLE_ENCRYPTION,
249f1d2b4d3SLarry Finger 	BTC_GET_BL_WIFI_UNDER_B_MODE,
250f1d2b4d3SLarry 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,
255f1d2b4d3SLarry Finger 
256f1d2b4d3SLarry Finger 	/* type s4Byte */
257f1d2b4d3SLarry Finger 	BTC_GET_S4_WIFI_RSSI,
258f1d2b4d3SLarry Finger 	BTC_GET_S4_HS_RSSI,
259f1d2b4d3SLarry Finger 
260f1d2b4d3SLarry Finger 	/* type u32 */
261f1d2b4d3SLarry Finger 	BTC_GET_U4_WIFI_BW,
262f1d2b4d3SLarry Finger 	BTC_GET_U4_WIFI_TRAFFIC_DIRECTION,
263f1d2b4d3SLarry Finger 	BTC_GET_U4_WIFI_FW_VER,
264f1d2b4d3SLarry Finger 	BTC_GET_U4_WIFI_LINK_STATUS,
265f1d2b4d3SLarry 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,
274f1d2b4d3SLarry Finger 
275f1d2b4d3SLarry Finger 	/* type u1Byte */
276f1d2b4d3SLarry Finger 	BTC_GET_U1_WIFI_DOT11_CHNL,
277f1d2b4d3SLarry Finger 	BTC_GET_U1_WIFI_CENTRAL_CHNL,
278f1d2b4d3SLarry Finger 	BTC_GET_U1_WIFI_HS_CHNL,
279f1d2b4d3SLarry Finger 	BTC_GET_U1_MAC_PHY_MODE,
280f1d2b4d3SLarry Finger 	BTC_GET_U1_AP_NUM,
281c42ea613SYan-Hsuan Chuang 	BTC_GET_U1_ANT_TYPE,
28286aeb825SYan-Hsuan Chuang 	BTC_GET_U1_IOT_PEER,
283f1d2b4d3SLarry Finger 
284f1d2b4d3SLarry Finger 	/* for 1Ant */
285f1d2b4d3SLarry Finger 	BTC_GET_U1_LPS_MODE,
286f1d2b4d3SLarry Finger 	BTC_GET_BL_BT_SCO_BUSY,
287f1d2b4d3SLarry Finger 
288f1d2b4d3SLarry Finger 	/* for test mode */
289f1d2b4d3SLarry Finger 	BTC_GET_DRIVER_TEST_CFG,
290f1d2b4d3SLarry Finger 	BTC_GET_MAX
291f1d2b4d3SLarry Finger };
292f1d2b4d3SLarry 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 
299f1d2b4d3SLarry Finger enum btc_set_type {
300f1d2b4d3SLarry Finger 	/* type bool */
301f1d2b4d3SLarry Finger 	BTC_SET_BL_BT_DISABLE,
302f1d2b4d3SLarry Finger 	BTC_SET_BL_BT_TRAFFIC_BUSY,
303f1d2b4d3SLarry Finger 	BTC_SET_BL_BT_LIMITED_DIG,
304f1d2b4d3SLarry Finger 	BTC_SET_BL_FORCE_TO_ROAM,
305f1d2b4d3SLarry Finger 	BTC_SET_BL_TO_REJ_AP_AGG_PKT,
306f1d2b4d3SLarry Finger 	BTC_SET_BL_BT_CTRL_AGG_SIZE,
307f1d2b4d3SLarry 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,
310f1d2b4d3SLarry Finger 
311f1d2b4d3SLarry Finger 	/* type u1Byte */
312f1d2b4d3SLarry Finger 	BTC_SET_U1_RSSI_ADJ_VAL_FOR_AGC_TABLE_ON,
313f1d2b4d3SLarry Finger 	BTC_SET_UI_SCAN_SIG_COMPENSATION,
314f1d2b4d3SLarry Finger 	BTC_SET_U1_AGG_BUF_SIZE,
315f1d2b4d3SLarry Finger 
316f1d2b4d3SLarry Finger 	/* type trigger some action */
317f1d2b4d3SLarry Finger 	BTC_SET_ACT_GET_BT_RSSI,
318f1d2b4d3SLarry Finger 	BTC_SET_ACT_AGGREGATE_CTRL,
3196f85c03bSPing-Ke Shih 	BTC_SET_ACT_ANTPOSREGRISTRY_CTRL,
320c3788947SPing-Ke Shih 	BTC_SET_MIMO_PS_MODE,
321f1d2b4d3SLarry Finger 
322f1d2b4d3SLarry Finger 	/********* for 1Ant **********/
323f1d2b4d3SLarry Finger 	/* type bool */
324f1d2b4d3SLarry Finger 	BTC_SET_BL_BT_SCO_BUSY,
325f1d2b4d3SLarry Finger 	/* type u1Byte */
326f1d2b4d3SLarry Finger 	BTC_SET_U1_RSSI_ADJ_VAL_FOR_1ANT_COEX_TYPE,
327f1d2b4d3SLarry Finger 	BTC_SET_U1_LPS_VAL,
328f1d2b4d3SLarry Finger 	BTC_SET_U1_RPWM_VAL,
329f1d2b4d3SLarry Finger 	BTC_SET_U1_1ANT_LPS,
330f1d2b4d3SLarry Finger 	BTC_SET_U1_1ANT_RPWM,
331f1d2b4d3SLarry Finger 	/* type trigger some action */
332f1d2b4d3SLarry Finger 	BTC_SET_ACT_LEAVE_LPS,
333f1d2b4d3SLarry Finger 	BTC_SET_ACT_ENTER_LPS,
334f1d2b4d3SLarry Finger 	BTC_SET_ACT_NORMAL_LPS,
335c3468950SPing-Ke Shih 	BTC_SET_ACT_PRE_NORMAL_LPS,
336c3468950SPing-Ke Shih 	BTC_SET_ACT_POST_NORMAL_LPS,
337f1d2b4d3SLarry Finger 	BTC_SET_ACT_INC_FORCE_EXEC_PWR_CMD_CNT,
338f1d2b4d3SLarry 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,
341f1d2b4d3SLarry Finger 	BTC_SET_ACT_SEND_MIMO_PS,
342f1d2b4d3SLarry Finger 	/* BT Coex related */
343f1d2b4d3SLarry Finger 	BTC_SET_ACT_CTRL_BT_INFO,
344f1d2b4d3SLarry Finger 	BTC_SET_ACT_CTRL_BT_COEX,
345c42ea613SYan-Hsuan Chuang 	BTC_SET_ACT_CTRL_8723B_ANT,
346f1d2b4d3SLarry Finger 	/***************************/
347f1d2b4d3SLarry Finger 	BTC_SET_MAX
348f1d2b4d3SLarry Finger };
349f1d2b4d3SLarry Finger 
350f1d2b4d3SLarry Finger enum btc_dbg_disp_type {
351f1d2b4d3SLarry Finger 	BTC_DBG_DISP_COEX_STATISTICS = 0x0,
352f1d2b4d3SLarry Finger 	BTC_DBG_DISP_BT_LINK_INFO = 0x1,
353f1d2b4d3SLarry Finger 	BTC_DBG_DISP_BT_FW_VER = 0x2,
354f1d2b4d3SLarry Finger 	BTC_DBG_DISP_FW_PWR_MODE_CMD = 0x3,
35508431b62SPing-Ke Shih 	BTC_DBG_DISP_WIFI_STATUS = 0x04,
356f1d2b4d3SLarry Finger 	BTC_DBG_DISP_MAX
357f1d2b4d3SLarry Finger };
358f1d2b4d3SLarry Finger 
359f1d2b4d3SLarry Finger enum btc_notify_type_ips {
360f1d2b4d3SLarry Finger 	BTC_IPS_LEAVE = 0x0,
361f1d2b4d3SLarry Finger 	BTC_IPS_ENTER = 0x1,
362f1d2b4d3SLarry Finger 	BTC_IPS_MAX
363f1d2b4d3SLarry Finger };
364f1d2b4d3SLarry Finger 
365f1d2b4d3SLarry Finger enum btc_notify_type_lps {
366f1d2b4d3SLarry Finger 	BTC_LPS_DISABLE = 0x0,
367f1d2b4d3SLarry Finger 	BTC_LPS_ENABLE = 0x1,
368f1d2b4d3SLarry Finger 	BTC_LPS_MAX
369f1d2b4d3SLarry Finger };
370f1d2b4d3SLarry Finger 
371f1d2b4d3SLarry Finger enum btc_notify_type_scan {
372f1d2b4d3SLarry Finger 	BTC_SCAN_FINISH = 0x0,
373f1d2b4d3SLarry Finger 	BTC_SCAN_START = 0x1,
374b82f5e0fSPing-Ke Shih 	BTC_SCAN_START_2G = 0x2,
375f1d2b4d3SLarry Finger 	BTC_SCAN_MAX
376f1d2b4d3SLarry Finger };
377f1d2b4d3SLarry 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 
386f1d2b4d3SLarry Finger enum btc_notify_type_associate {
387f1d2b4d3SLarry Finger 	BTC_ASSOCIATE_FINISH = 0x0,
388f1d2b4d3SLarry Finger 	BTC_ASSOCIATE_START = 0x1,
3890843e98aSPing-Ke Shih 	BTC_ASSOCIATE_5G_FINISH = 0x2,
3900843e98aSPing-Ke Shih 	BTC_ASSOCIATE_5G_START = 0x3,
391f1d2b4d3SLarry Finger 	BTC_ASSOCIATE_MAX
392f1d2b4d3SLarry Finger };
393f1d2b4d3SLarry Finger 
394f1d2b4d3SLarry Finger enum btc_notify_type_media_status {
395f1d2b4d3SLarry Finger 	BTC_MEDIA_DISCONNECT = 0x0,
396f1d2b4d3SLarry Finger 	BTC_MEDIA_CONNECT = 0x1,
397f1d2b4d3SLarry Finger 	BTC_MEDIA_MAX
398f1d2b4d3SLarry Finger };
399f1d2b4d3SLarry Finger 
400f1d2b4d3SLarry Finger enum btc_notify_type_special_packet {
401f1d2b4d3SLarry Finger 	BTC_PACKET_UNKNOWN = 0x0,
402f1d2b4d3SLarry Finger 	BTC_PACKET_DHCP = 0x1,
403f1d2b4d3SLarry Finger 	BTC_PACKET_ARP = 0x2,
404f1d2b4d3SLarry Finger 	BTC_PACKET_EAPOL = 0x3,
405f1d2b4d3SLarry Finger 	BTC_PACKET_MAX
406f1d2b4d3SLarry Finger };
407f1d2b4d3SLarry Finger 
408f1d2b4d3SLarry Finger enum hci_ext_bt_operation {
409f1d2b4d3SLarry Finger 	HCI_BT_OP_NONE = 0x0,
410f1d2b4d3SLarry Finger 	HCI_BT_OP_INQUIRY_START = 0x1,
411f1d2b4d3SLarry Finger 	HCI_BT_OP_INQUIRY_FINISH = 0x2,
412f1d2b4d3SLarry Finger 	HCI_BT_OP_PAGING_START = 0x3,
413f1d2b4d3SLarry Finger 	HCI_BT_OP_PAGING_SUCCESS = 0x4,
414f1d2b4d3SLarry Finger 	HCI_BT_OP_PAGING_UNSUCCESS = 0x5,
415f1d2b4d3SLarry Finger 	HCI_BT_OP_PAIRING_START = 0x6,
416f1d2b4d3SLarry Finger 	HCI_BT_OP_PAIRING_FINISH = 0x7,
417f1d2b4d3SLarry Finger 	HCI_BT_OP_BT_DEV_ENABLE = 0x8,
418f1d2b4d3SLarry Finger 	HCI_BT_OP_BT_DEV_DISABLE = 0x9,
419f1d2b4d3SLarry Finger 	HCI_BT_OP_MAX
420f1d2b4d3SLarry Finger };
421f1d2b4d3SLarry Finger 
422f1d2b4d3SLarry Finger enum btc_notify_type_stack_operation {
423f1d2b4d3SLarry Finger 	BTC_STACK_OP_NONE = 0x0,
424f1d2b4d3SLarry Finger 	BTC_STACK_OP_INQ_PAGE_PAIR_START = 0x1,
425f1d2b4d3SLarry Finger 	BTC_STACK_OP_INQ_PAGE_PAIR_FINISH = 0x2,
426f1d2b4d3SLarry Finger 	BTC_STACK_OP_MAX
427f1d2b4d3SLarry Finger };
428f1d2b4d3SLarry 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 
530f1d2b4d3SLarry Finger struct btc_bt_info {
531f1d2b4d3SLarry Finger 	bool bt_disabled;
532f1d2b4d3SLarry Finger 	u8 rssi_adjust_for_agc_table_on;
533f1d2b4d3SLarry Finger 	u8 rssi_adjust_for_1ant_coex_type;
5340199103eSYan-Hsuan Chuang 	bool pre_bt_ctrl_agg_buf_size;
535f1d2b4d3SLarry Finger 	bool bt_busy;
5360199103eSYan-Hsuan Chuang 	u8 pre_agg_buf_size;
537f1d2b4d3SLarry Finger 	u8 agg_buf_size;
538f1d2b4d3SLarry Finger 	bool limited_dig;
5390199103eSYan-Hsuan Chuang 	bool pre_reject_agg_pkt;
540f1d2b4d3SLarry Finger 	bool reject_agg_pkt;
541f1d2b4d3SLarry Finger 	bool bt_ctrl_buf_size;
542f1d2b4d3SLarry 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;
546f1d2b4d3SLarry Finger 	u16 bt_hci_ver;
547f1d2b4d3SLarry Finger 	u16 bt_real_fw_ver;
548f1d2b4d3SLarry Finger 	u8 bt_fw_ver;
549b82f5e0fSPing-Ke Shih 	u32 bt_get_fw_ver;
550f1d2b4d3SLarry Finger 
551f1d2b4d3SLarry Finger 	bool bt_disable_low_pwr;
552f1d2b4d3SLarry Finger 
553f1d2b4d3SLarry Finger 	/* the following is for 1Ant solution */
554f1d2b4d3SLarry Finger 	bool bt_ctrl_lps;
555f1d2b4d3SLarry Finger 	bool bt_pwr_save_mode;
556f1d2b4d3SLarry Finger 	bool bt_lps_on;
557f1d2b4d3SLarry Finger 	bool force_to_roam;
558f1d2b4d3SLarry Finger 	u8 force_exec_pwr_cmd_cnt;
559f1d2b4d3SLarry Finger 	u8 lps_val;
560f1d2b4d3SLarry Finger 	u8 rpwm_val;
561f1d2b4d3SLarry 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;
573f1d2b4d3SLarry Finger };
574f1d2b4d3SLarry Finger 
575f1d2b4d3SLarry Finger struct btc_stack_info {
576f1d2b4d3SLarry Finger 	bool profile_notified;
577f1d2b4d3SLarry Finger 	u16 hci_version;	/* stack hci version */
578f1d2b4d3SLarry Finger 	u8 num_of_link;
579f1d2b4d3SLarry Finger 	bool bt_link_exist;
580f1d2b4d3SLarry Finger 	bool sco_exist;
581f1d2b4d3SLarry Finger 	bool acl_exist;
582f1d2b4d3SLarry Finger 	bool a2dp_exist;
583f1d2b4d3SLarry Finger 	bool hid_exist;
584f1d2b4d3SLarry Finger 	u8 num_of_hid;
585f1d2b4d3SLarry Finger 	bool pan_exist;
586f1d2b4d3SLarry Finger 	bool unknown_acl_exist;
58708aba42fSArnd Bergmann 	s8 min_bt_rssi;
588f1d2b4d3SLarry Finger };
589f1d2b4d3SLarry Finger 
590f1d2b4d3SLarry Finger struct btc_statistics {
591f1d2b4d3SLarry Finger 	u32 cnt_bind;
592f1d2b4d3SLarry Finger 	u32 cnt_init_hw_config;
593f1d2b4d3SLarry Finger 	u32 cnt_init_coex_dm;
594f1d2b4d3SLarry Finger 	u32 cnt_ips_notify;
595f1d2b4d3SLarry Finger 	u32 cnt_lps_notify;
596f1d2b4d3SLarry Finger 	u32 cnt_scan_notify;
597f1d2b4d3SLarry Finger 	u32 cnt_connect_notify;
598f1d2b4d3SLarry Finger 	u32 cnt_media_status_notify;
599f1d2b4d3SLarry Finger 	u32 cnt_special_packet_notify;
600f1d2b4d3SLarry Finger 	u32 cnt_bt_info_notify;
601f1d2b4d3SLarry Finger 	u32 cnt_periodical;
602f1d2b4d3SLarry Finger 	u32 cnt_coex_dm_switch;
603f1d2b4d3SLarry Finger 	u32 cnt_stack_operation_notify;
604f1d2b4d3SLarry Finger 	u32 cnt_dbg_ctrl;
6056fbbc82aSYan-Hsuan Chuang 	u32 cnt_pre_load_firmware;
60660f44100SYan-Hsuan Chuang 	u32 cnt_power_on;
607f1d2b4d3SLarry Finger };
608f1d2b4d3SLarry Finger 
609f1d2b4d3SLarry Finger struct btc_bt_link_info {
610f1d2b4d3SLarry Finger 	bool bt_link_exist;
61175717802SPing-Ke Shih 	bool bt_hi_pri_link_exist;
612f1d2b4d3SLarry Finger 	bool sco_exist;
613f1d2b4d3SLarry Finger 	bool sco_only;
614f1d2b4d3SLarry Finger 	bool a2dp_exist;
615f1d2b4d3SLarry Finger 	bool a2dp_only;
616f1d2b4d3SLarry Finger 	bool hid_exist;
617f1d2b4d3SLarry Finger 	bool hid_only;
618f1d2b4d3SLarry Finger 	bool pan_exist;
619f1d2b4d3SLarry Finger 	bool pan_only;
62061d80261SYan-Hsuan Chuang 	bool slave_role;
621b82f5e0fSPing-Ke Shih 	bool acl_busy;
622f1d2b4d3SLarry Finger };
623f1d2b4d3SLarry Finger 
624f1d2b4d3SLarry Finger enum btc_antenna_pos {
625f1d2b4d3SLarry Finger 	BTC_ANTENNA_AT_MAIN_PORT = 0x1,
626f1d2b4d3SLarry Finger 	BTC_ANTENNA_AT_AUX_PORT = 0x2,
627f1d2b4d3SLarry Finger };
628f1d2b4d3SLarry 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 
663f1d2b4d3SLarry Finger struct btc_coexist {
664f1d2b4d3SLarry Finger 	/* make sure only one adapter can bind the data context  */
665f1d2b4d3SLarry Finger 	bool binded;
666f1d2b4d3SLarry Finger 	/* default adapter */
667f1d2b4d3SLarry Finger 	void *adapter;
668f1d2b4d3SLarry Finger 	struct btc_board_info board_info;
669f1d2b4d3SLarry Finger 	/* some bt info referenced by non-bt module */
670f1d2b4d3SLarry Finger 	struct btc_bt_info bt_info;
671f1d2b4d3SLarry Finger 	struct btc_stack_info stack_info;
672f1d2b4d3SLarry Finger 	enum btc_chip_interface	chip_interface;
673f1d2b4d3SLarry Finger 	struct btc_bt_link_info bt_link_info;
674f1d2b4d3SLarry 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;
683f1d2b4d3SLarry Finger 	bool stop_coex_dm;
684f1d2b4d3SLarry Finger 	bool manual_control;
685f1d2b4d3SLarry Finger 	struct btc_statistics statistics;
686f1d2b4d3SLarry Finger 	u8 pwr_mode_val[10];
687f1d2b4d3SLarry Finger 
688b2283dadSPing-Ke Shih 	struct completion bt_mp_comp;
689b2283dadSPing-Ke Shih 
690f1d2b4d3SLarry 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);
699f1d2b4d3SLarry 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);
710f1d2b4d3SLarry Finger 
7113afb7da4SLarry Finger 	void (*btc_fill_h2c)(void *btc_context, u8 element_id,
7123afb7da4SLarry Finger 			     u32 cmd_len, u8 *cmd_buffer);
713f1d2b4d3SLarry Finger 
7143afb7da4SLarry Finger 	void (*btc_disp_dbg_msg)(void *btcoexist, u8 disp_type,
7153afb7da4SLarry Finger 				 struct seq_file *m);
716f1d2b4d3SLarry 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);
719f1d2b4d3SLarry 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);
736f1d2b4d3SLarry Finger };
737f1d2b4d3SLarry Finger 
738f1d2b4d3SLarry Finger bool halbtc_is_wifi_uplink(struct rtl_priv *adapter);
739f1d2b4d3SLarry 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;
746f1d2b4d3SLarry 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);
754f1d2b4d3SLarry Finger void exhalbtc_init_coex_dm(struct btc_coexist *btcoexist);
755f1d2b4d3SLarry Finger void exhalbtc_ips_notify(struct btc_coexist *btcoexist, u8 type);
756f1d2b4d3SLarry Finger void exhalbtc_lps_notify(struct btc_coexist *btcoexist, u8 type);
757f1d2b4d3SLarry 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);
760f1d2b4d3SLarry Finger void exhalbtc_connect_notify(struct btc_coexist *btcoexist, u8 action);
761f1d2b4d3SLarry Finger void exhalbtc_mediastatus_notify(struct btc_coexist *btcoexist,
762f1d2b4d3SLarry Finger 				 enum rt_media_status media_status);
763f1d2b4d3SLarry Finger void exhalbtc_special_packet_notify(struct btc_coexist *btcoexist, u8 pkt_type);
764f1d2b4d3SLarry Finger void exhalbtc_bt_info_notify(struct btc_coexist *btcoexist, u8 *tmp_buf,
765f1d2b4d3SLarry Finger 			     u8 length);
766f2f6026aSPing-Ke Shih void exhalbtc_rf_status_notify(struct btc_coexist *btcoexist, u8 type);
767f1d2b4d3SLarry Finger void exhalbtc_halt_notify(struct btc_coexist *btcoexist);
768f1d2b4d3SLarry Finger void exhalbtc_pnp_notify(struct btc_coexist *btcoexist, u8 pnp_state);
769f1d2b4d3SLarry Finger void exhalbtc_coex_dm_switch(struct btc_coexist *btcoexist);
770f1d2b4d3SLarry Finger void exhalbtc_periodical(struct btc_coexist *btcoexist);
771f1d2b4d3SLarry Finger void exhalbtc_dbg_control(struct btc_coexist *btcoexist, u8 code, u8 len,
772f1d2b4d3SLarry Finger 			  u8 *data);
773f2f6026aSPing-Ke Shih void exhalbtc_antenna_detection(struct btc_coexist *btcoexist, u32 cent_freq,
774f2f6026aSPing-Ke Shih 				u32 offset, u32 span, u32 seconds);
775f1d2b4d3SLarry Finger void exhalbtc_stack_update_profile_info(void);
77640d9dd4fSPing-Ke Shih void exhalbtc_set_hci_version(struct btc_coexist *btcoexist, u16 hci_version);
77740d9dd4fSPing-Ke Shih void exhalbtc_set_bt_patch_version(struct btc_coexist *btcoexist,
77840d9dd4fSPing-Ke Shih 				   u16 bt_hci_version, u16 bt_patch_version);
77940d9dd4fSPing-Ke Shih void exhalbtc_update_min_bt_rssi(struct btc_coexist *btcoexist, s8 bt_rssi);
78040d9dd4fSPing-Ke Shih void exhalbtc_set_bt_exist(struct btc_coexist *btcoexist, bool bt_exist);
78140d9dd4fSPing-Ke Shih void exhalbtc_set_chip_type(struct btc_coexist *btcoexist, u8 chip_type);
782baa17022SLarry Finger void exhalbtc_set_ant_num(struct rtl_priv *rtlpriv, u8 type, u8 ant_num);
783610247f4SPing-Ke Shih void exhalbtc_display_bt_coex_info(struct btc_coexist *btcoexist,
784610247f4SPing-Ke Shih 				   struct seq_file *m);
78517bf8510SPing-Ke Shih void exhalbtc_switch_band_notify(struct btc_coexist *btcoexist, u8 type);
7869177c336SPing-Ke Shih void exhalbtc_switch_band_notify_wifi_only(struct wifi_only_cfg *wifionly_cfg,
7879177c336SPing-Ke Shih 					   u8 is_5g);
788f1d2b4d3SLarry Finger void exhalbtc_signal_compensation(struct btc_coexist *btcoexist,
789f1d2b4d3SLarry Finger 				  u8 *rssi_wifi, u8 *rssi_bt);
790f1d2b4d3SLarry Finger void exhalbtc_lps_leave(struct btc_coexist *btcoexist);
791f1d2b4d3SLarry Finger void exhalbtc_low_wifi_traffic_notify(struct btc_coexist *btcoexist);
79240d9dd4fSPing-Ke Shih void exhalbtc_set_single_ant_path(struct btc_coexist *btcoexist,
79340d9dd4fSPing-Ke Shih 				  u8 single_ant_path);
794d7297a86SPing-Ke Shih void halbtc_send_wifi_port_id_cmd(void *bt_context);
795d7297a86SPing-Ke Shih void halbtc_set_default_port_id_cmd(void *bt_context);
796f1d2b4d3SLarry Finger 
7979177c336SPing-Ke Shih /* The following are used by wifi_only case */
7989177c336SPing-Ke Shih enum wifionly_chip_interface {
7999177c336SPing-Ke Shih 	WIFIONLY_INTF_UNKNOWN	= 0,
8009177c336SPing-Ke Shih 	WIFIONLY_INTF_PCI		= 1,
8019177c336SPing-Ke Shih 	WIFIONLY_INTF_USB		= 2,
8029177c336SPing-Ke Shih 	WIFIONLY_INTF_SDIO		= 3,
8039177c336SPing-Ke Shih 	WIFIONLY_INTF_MAX
8049177c336SPing-Ke Shih };
8059177c336SPing-Ke Shih 
8069177c336SPing-Ke Shih enum wifionly_customer_id {
8079177c336SPing-Ke Shih 	CUSTOMER_NORMAL			= 0,
8089177c336SPing-Ke Shih 	CUSTOMER_HP_1			= 1,
8099177c336SPing-Ke Shih };
8109177c336SPing-Ke Shih 
8119177c336SPing-Ke Shih struct wifi_only_haldata {
8129177c336SPing-Ke Shih 	u16		customer_id;
8139177c336SPing-Ke Shih 	u8		efuse_pg_antnum;
8149177c336SPing-Ke Shih 	u8		efuse_pg_antpath;
8159177c336SPing-Ke Shih 	u8		rfe_type;
8169177c336SPing-Ke Shih 	u8		ant_div_cfg;
8179177c336SPing-Ke Shih };
8189177c336SPing-Ke Shih 
8199177c336SPing-Ke Shih struct wifi_only_cfg {
8209177c336SPing-Ke Shih 	void				*adapter;
8219177c336SPing-Ke Shih 	struct wifi_only_haldata	haldata_info;
8229177c336SPing-Ke Shih 	enum wifionly_chip_interface	chip_interface;
8239177c336SPing-Ke Shih };
8249177c336SPing-Ke Shih 
8259177c336SPing-Ke Shih static inline
halwifionly_phy_set_bb_reg(struct wifi_only_cfg * wifi_conly_cfg,u32 regaddr,u32 bitmask,u32 data)8269177c336SPing-Ke Shih void halwifionly_phy_set_bb_reg(struct wifi_only_cfg *wifi_conly_cfg,
8279177c336SPing-Ke Shih 				u32 regaddr, u32 bitmask, u32 data)
8289177c336SPing-Ke Shih {
8299177c336SPing-Ke Shih 	struct rtl_priv *rtlpriv = (struct rtl_priv *)wifi_conly_cfg->adapter;
8309177c336SPing-Ke Shih 
8319177c336SPing-Ke Shih 	rtl_set_bbreg(rtlpriv->hw, regaddr, bitmask, data);
8329177c336SPing-Ke Shih }
8339177c336SPing-Ke Shih 
834f1d2b4d3SLarry Finger #endif
835