1 /* SPDX-License-Identifier: GPL-2.0 */
2 /******************************************************************************
4 * Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
6 ******************************************************************************/
7 #ifndef __HALBTC_OUT_SRC_H__
8 #define __HALBTC_OUT_SRC_H__
10 #define NORMAL_EXEC false
11 #define FORCE_EXEC true
13 #define BTC_RF_OFF 0x0
21 #define BTC_SMSP SINGLEMAC_SINGLEPHY
22 #define BTC_DMDP DUALMAC_DUALPHY
23 #define BTC_DMSP DUALMAC_SINGLEPHY
24 #define BTC_MP_UNKNOWN 0xff
26 #define BT_COEX_ANT_TYPE_PG 0
27 #define BT_COEX_ANT_TYPE_ANTDIV 1
28 #define BT_COEX_ANT_TYPE_DETECTED 2
30 #define BTC_MIMO_PS_STATIC 0 /* 1ss */
31 #define BTC_MIMO_PS_DYNAMIC 1 /* 2ss */
33 #define BTC_RATE_DISABLE 0
34 #define BTC_RATE_ENABLE 1
36 /* single Antenna definition */
37 #define BTC_ANT_PATH_WIFI 0
38 #define BTC_ANT_PATH_BT 1
39 #define BTC_ANT_PATH_PTA 2
40 /* dual Antenna definition */
41 #define BTC_ANT_WIFI_AT_MAIN 0
42 #define BTC_ANT_WIFI_AT_AUX 1
43 /* coupler Antenna definition */
44 #define BTC_ANT_WIFI_AT_CPL_MAIN 0
45 #define BTC_ANT_WIFI_AT_CPL_AUX 1
48 BTC_PS_WIFI_NATIVE = 0, /* wifi original power save behavior */
57 BTC_BT_REG_BLUEWIZE = 2,
58 BTC_BT_REG_VENDOR = 3,
63 enum btc_chip_interface {
71 /* following is for wifi link status */
72 #define WIFI_STA_CONNECTED BIT0
73 #define WIFI_AP_CONNECTED BIT1
74 #define WIFI_HS_CONNECTED BIT2
75 #define WIFI_P2P_GO_CONNECTED BIT3
76 #define WIFI_P2P_GC_CONNECTED BIT4
78 struct btc_board_info {
79 /* The following is some board information */
80 u8 pgAntNum; /* pg ant number */
81 u8 btdmAntNum; /* ant number for btdm */
82 u8 btdmAntPos; /* Bryant Add to indicate Antenna Position for (pgAntNum = 2) && (btdmAntNum = 1) (DPDT+1Ant case) */
83 u8 singleAntPath; /* current used for 8723b only, 1 =>s0, 0 =>s1 */
88 BTC_RSSI_STATE_HIGH = 0x0,
89 BTC_RSSI_STATE_MEDIUM = 0x1,
90 BTC_RSSI_STATE_LOW = 0x2,
91 BTC_RSSI_STATE_STAY_HIGH = 0x3,
92 BTC_RSSI_STATE_STAY_MEDIUM = 0x4,
93 BTC_RSSI_STATE_STAY_LOW = 0x5,
96 #define BTC_RSSI_HIGH(_rssi_) ((_rssi_ == BTC_RSSI_STATE_HIGH || _rssi_ == BTC_RSSI_STATE_STAY_HIGH) ? true : false)
97 #define BTC_RSSI_MEDIUM(_rssi_) ((_rssi_ == BTC_RSSI_STATE_MEDIUM || _rssi_ == BTC_RSSI_STATE_STAY_MEDIUM) ? true : false)
98 #define BTC_RSSI_LOW(_rssi_) ((_rssi_ == BTC_RSSI_STATE_LOW || _rssi_ == BTC_RSSI_STATE_STAY_LOW) ? true : false)
101 BTC_WIFI_BW_LEGACY = 0x0,
102 BTC_WIFI_BW_HT20 = 0x1,
103 BTC_WIFI_BW_HT40 = 0x2,
108 BTC_WIFI_TRAFFIC_TX = 0x0,
109 BTC_WIFI_TRAFFIC_RX = 0x1,
114 BTC_WIFI_PNP_WAKE_UP = 0x0,
115 BTC_WIFI_PNP_SLEEP = 0x1,
119 /* defined for BFP_BTC_GET */
122 BTC_GET_BL_HS_OPERATION,
123 BTC_GET_BL_HS_CONNECTING,
124 BTC_GET_BL_WIFI_CONNECTED,
125 BTC_GET_BL_WIFI_BUSY,
126 BTC_GET_BL_WIFI_SCAN,
127 BTC_GET_BL_WIFI_LINK,
128 BTC_GET_BL_WIFI_ROAM,
129 BTC_GET_BL_WIFI_4_WAY_PROGRESS,
130 BTC_GET_BL_WIFI_AP_MODE_ENABLE,
131 BTC_GET_BL_WIFI_ENABLE_ENCRYPTION,
132 BTC_GET_BL_WIFI_UNDER_B_MODE,
133 BTC_GET_BL_EXT_SWITCH,
134 BTC_GET_BL_WIFI_IS_IN_MP_MODE,
137 BTC_GET_S4_WIFI_RSSI,
142 BTC_GET_U4_WIFI_TRAFFIC_DIRECTION,
143 BTC_GET_U4_WIFI_FW_VER,
144 BTC_GET_U4_WIFI_LINK_STATUS,
145 BTC_GET_U4_BT_PATCH_VER,
148 BTC_GET_U1_WIFI_DOT11_CHNL,
149 BTC_GET_U1_WIFI_CENTRAL_CHNL,
150 BTC_GET_U1_WIFI_HS_CHNL,
151 BTC_GET_U1_MAC_PHY_MODE,
154 /* for 1Ant ====== */
160 /* defined for BFP_BTC_SET */
163 BTC_SET_BL_BT_DISABLE,
164 BTC_SET_BL_BT_TRAFFIC_BUSY,
165 BTC_SET_BL_BT_LIMITED_DIG,
166 BTC_SET_BL_FORCE_TO_ROAM,
167 BTC_SET_BL_TO_REJ_AP_AGG_PKT,
168 BTC_SET_BL_BT_CTRL_AGG_SIZE,
169 BTC_SET_BL_INC_SCAN_DEV_NUM,
170 BTC_SET_BL_BT_TX_RX_MASK,
173 BTC_SET_U1_RSSI_ADJ_VAL_FOR_AGC_TABLE_ON,
174 BTC_SET_U1_AGG_BUF_SIZE,
176 /* type trigger some action */
177 BTC_SET_ACT_GET_BT_RSSI,
178 BTC_SET_ACT_AGGREGATE_CTRL,
179 /* for 1Ant ====== */
183 BTC_SET_U1_RSSI_ADJ_VAL_FOR_1ANT_COEX_TYPE,
186 /* type trigger some action */
187 BTC_SET_ACT_LEAVE_LPS,
188 BTC_SET_ACT_ENTER_LPS,
189 BTC_SET_ACT_NORMAL_LPS,
190 BTC_SET_ACT_DISABLE_LOW_POWER,
191 BTC_SET_ACT_UPDATE_RAMASK,
192 BTC_SET_ACT_SEND_MIMO_PS,
193 /* BT Coex related */
194 BTC_SET_ACT_CTRL_BT_INFO,
195 BTC_SET_ACT_CTRL_BT_COEX,
196 BTC_SET_ACT_CTRL_8723B_ANT,
202 BTC_DBG_DISP_COEX_STATISTICS = 0x0,
203 BTC_DBG_DISP_BT_LINK_INFO = 0x1,
204 BTC_DBG_DISP_FW_PWR_MODE_CMD = 0x2,
215 BTC_LPS_DISABLE = 0x0,
216 BTC_LPS_ENABLE = 0x1,
221 BTC_SCAN_FINISH = 0x0,
222 BTC_SCAN_START = 0x1,
227 BTC_ASSOCIATE_FINISH = 0x0,
228 BTC_ASSOCIATE_START = 0x1,
233 BTC_MEDIA_DISCONNECT = 0x0,
234 BTC_MEDIA_CONNECT = 0x1,
239 BTC_PACKET_UNKNOWN = 0x0,
240 BTC_PACKET_DHCP = 0x1,
241 BTC_PACKET_ARP = 0x2,
242 BTC_PACKET_EAPOL = 0x3,
248 BTC_ANTENNA_AT_MAIN_PORT = 0x1,
249 BTC_ANTENNA_AT_AUX_PORT = 0x2,
252 typedef u8 (*BFP_BTC_R1)(void *pBtcContext, u32 RegAddr);
253 typedef u16(*BFP_BTC_R2)(void *pBtcContext, u32 RegAddr);
254 typedef u32 (*BFP_BTC_R4)(void *pBtcContext, u32 RegAddr);
255 typedef void (*BFP_BTC_W1)(void *pBtcContext, u32 RegAddr, u8 Data);
256 typedef void(*BFP_BTC_W1_BIT_MASK)(
257 void *pBtcContext, u32 regAddr, u8 bitMask, u8 data1b
259 typedef void (*BFP_BTC_W2)(void *pBtcContext, u32 RegAddr, u16 Data);
260 typedef void (*BFP_BTC_W4)(void *pBtcContext, u32 RegAddr, u32 Data);
261 typedef void (*BFP_BTC_LOCAL_REG_W1)(void *pBtcContext, u32 RegAddr, u8 Data);
262 typedef void (*BFP_BTC_SET_BB_REG)(
263 void *pBtcContext, u32 RegAddr, u32 BitMask, u32 Data
265 typedef u32 (*BFP_BTC_GET_BB_REG)(void *pBtcContext, u32 RegAddr, u32 BitMask);
266 typedef void (*BFP_BTC_SET_RF_REG)(
267 void *pBtcContext, u8 eRFPath, u32 RegAddr, u32 BitMask, u32 Data
269 typedef u32 (*BFP_BTC_GET_RF_REG)(
270 void *pBtcContext, u8 eRFPath, u32 RegAddr, u32 BitMask
272 typedef void (*BFP_BTC_FILL_H2C)(
273 void *pBtcContext, u8 elementId, u32 cmdLen, u8 *pCmdBuffer
276 typedef u8 (*BFP_BTC_GET)(void *pBtCoexist, u8 getType, void *pOutBuf);
278 typedef u8 (*BFP_BTC_SET)(void *pBtCoexist, u8 setType, void *pInBuf);
279 typedef void (*BFP_BTC_SET_BT_REG)(
280 void *pBtcContext, u8 regType, u32 offset, u32 value
282 typedef u32 (*BFP_BTC_GET_BT_REG)(void *pBtcContext, u8 regType, u32 offset);
283 typedef void (*BFP_BTC_DISP_DBG_MSG)(void *pBtCoexist, u8 dispType);
287 u8 rssiAdjustForAgcTableOn;
288 u8 rssiAdjustFor1AntCoexType;
289 bool bPreBtCtrlAggBufSize;
290 bool bBtCtrlAggBufSize;
292 bool bIncreaseScanDevNum;
303 bool bBtDisableLowPwr;
307 bool bForceToRoam; /* for 1Ant solution */
313 struct btc_stack_info {
314 bool bProfileNotified;
315 u16 hciVersion; /* stack hci version */
324 bool bUnknownAclExist;
328 struct btc_bt_link_info {
341 struct btc_statistics {
349 u32 cntConnectNotify;
350 u32 cntMediaStatusNotify;
351 u32 cntSpecialPacketNotify;
353 u32 cntRfStatusNotify;
356 u32 cntStackOperationNotify;
361 bool bBinded; /* make sure only one adapter can bind the data context */
362 void *Adapter; /* default adapter */
363 struct btc_board_info boardInfo;
364 struct btc_bt_info btInfo; /* some bt info referenced by non-bt module */
365 struct btc_stack_info stackInfo;
366 struct btc_bt_link_info btLinkInfo;
367 enum btc_chip_interface chipInterface;
372 struct btc_statistics statistics;
375 /* function pointers */
377 BFP_BTC_R1 fBtcRead1Byte;
378 BFP_BTC_W1 fBtcWrite1Byte;
379 BFP_BTC_W1_BIT_MASK fBtcWrite1ByteBitMask;
380 BFP_BTC_R2 fBtcRead2Byte;
381 BFP_BTC_W2 fBtcWrite2Byte;
382 BFP_BTC_R4 fBtcRead4Byte;
383 BFP_BTC_W4 fBtcWrite4Byte;
384 BFP_BTC_LOCAL_REG_W1 fBtcWriteLocalReg1Byte;
385 /* read/write bb related */
386 BFP_BTC_SET_BB_REG fBtcSetBbReg;
387 BFP_BTC_GET_BB_REG fBtcGetBbReg;
389 /* read/write rf related */
390 BFP_BTC_SET_RF_REG fBtcSetRfReg;
391 BFP_BTC_GET_RF_REG fBtcGetRfReg;
393 /* fill h2c related */
394 BFP_BTC_FILL_H2C fBtcFillH2c;
395 /* normal get/set related */
399 BFP_BTC_GET_BT_REG fBtcGetBtReg;
400 BFP_BTC_SET_BT_REG fBtcSetBtReg;
403 extern struct btc_coexist GLBtCoexist;
405 void EXhalbtcoutsrc_PowerOnSetting(struct btc_coexist *pBtCoexist);
406 void EXhalbtcoutsrc_InitHwConfig(struct btc_coexist *pBtCoexist, u8 bWifiOnly);
407 void EXhalbtcoutsrc_InitCoexDm(struct btc_coexist *pBtCoexist);
408 void EXhalbtcoutsrc_IpsNotify(struct btc_coexist *pBtCoexist, u8 type);
409 void EXhalbtcoutsrc_LpsNotify(struct btc_coexist *pBtCoexist, u8 type);
410 void EXhalbtcoutsrc_ScanNotify(struct btc_coexist *pBtCoexist, u8 type);
411 void EXhalbtcoutsrc_ConnectNotify(struct btc_coexist *pBtCoexist, u8 action);
412 void EXhalbtcoutsrc_MediaStatusNotify(
413 struct btc_coexist *pBtCoexist, enum rt_media_status mediaStatus
415 void EXhalbtcoutsrc_SpecialPacketNotify(struct btc_coexist *pBtCoexist, u8 pktType);
416 void EXhalbtcoutsrc_BtInfoNotify(
417 struct btc_coexist *pBtCoexist, u8 *tmpBuf, u8 length
419 void EXhalbtcoutsrc_HaltNotify(struct btc_coexist *pBtCoexist);
420 void EXhalbtcoutsrc_PnpNotify(struct btc_coexist *pBtCoexist, u8 pnpState);
421 void EXhalbtcoutsrc_Periodical(struct btc_coexist *pBtCoexist);
422 void EXhalbtcoutsrc_SetChipType(u8 chipType);
423 void EXhalbtcoutsrc_SetAntNum(u8 type, u8 antNum);
424 void EXhalbtcoutsrc_SetSingleAntPath(u8 singleAntPath);