12a7274eeSLarry Finger /* SPDX-License-Identifier: GPL-2.0 */
22a7274eeSLarry Finger /* Copyright(c) 2009-2014  Realtek Corporation.*/
3f1d2b4d3SLarry Finger 
4f1d2b4d3SLarry Finger #ifndef __FW_COMMON_H__
5f1d2b4d3SLarry Finger #define __FW_COMMON_H__
6f1d2b4d3SLarry Finger 
7f1d2b4d3SLarry Finger #define REG_SYS_FUNC_EN				0x0002
8f1d2b4d3SLarry Finger #define REG_MCUFWDL				0x0080
9f1d2b4d3SLarry Finger #define FW_8192C_PAGE_SIZE			4096
10f1d2b4d3SLarry Finger #define FW_8723A_POLLING_TIMEOUT_COUNT		1000
11f1d2b4d3SLarry Finger #define FW_8723B_POLLING_TIMEOUT_COUNT		6000
12f1d2b4d3SLarry Finger #define FW_8192C_POLLING_DELAY			5
13f1d2b4d3SLarry Finger 
14f1d2b4d3SLarry Finger #define MCUFWDL_RDY				BIT(1)
15f1d2b4d3SLarry Finger #define FWDL_CHKSUM_RPT				BIT(2)
16f1d2b4d3SLarry Finger #define WINTINI_RDY				BIT(6)
17f1d2b4d3SLarry Finger 
18f1d2b4d3SLarry Finger #define REG_RSV_CTRL				0x001C
19f1d2b4d3SLarry Finger #define REG_HMETFR				0x01CC
20f1d2b4d3SLarry Finger 
21f1d2b4d3SLarry Finger enum version_8723e {
22f1d2b4d3SLarry Finger 	VERSION_TEST_UMC_CHIP_8723 = 0x0081,
23f1d2b4d3SLarry Finger 	VERSION_NORMAL_UMC_CHIP_8723_1T1R_A_CUT = 0x0089,
24f1d2b4d3SLarry Finger 	VERSION_NORMAL_UMC_CHIP_8723_1T1R_B_CUT = 0x1089,
25f1d2b4d3SLarry Finger 	VERSION_TEST_CHIP_1T1R_8723B = 0x0106,
26f1d2b4d3SLarry Finger 	VERSION_NORMAL_SMIC_CHIP_1T1R_8723B = 0x010E,
27f1d2b4d3SLarry Finger 	VERSION_UNKNOWN = 0xFF,
28f1d2b4d3SLarry Finger };
29f1d2b4d3SLarry Finger 
30f1d2b4d3SLarry Finger enum rtl8723be_cmd {
31f1d2b4d3SLarry Finger 	H2C_8723BE_RSVDPAGE = 0,
32f1d2b4d3SLarry Finger 	H2C_8723BE_JOINBSSRPT = 1,
33f1d2b4d3SLarry Finger 	H2C_8723BE_SCAN = 2,
34f1d2b4d3SLarry Finger 	H2C_8723BE_KEEP_ALIVE_CTRL = 3,
35f1d2b4d3SLarry Finger 	H2C_8723BE_DISCONNECT_DECISION = 4,
36f1d2b4d3SLarry Finger 	H2C_8723BE_INIT_OFFLOAD = 6,
37f1d2b4d3SLarry Finger 	H2C_8723BE_AP_OFFLOAD = 8,
38f1d2b4d3SLarry Finger 	H2C_8723BE_BCN_RSVDPAGE = 9,
39f1d2b4d3SLarry Finger 	H2C_8723BE_PROBERSP_RSVDPAGE = 10,
40f1d2b4d3SLarry Finger 
41f1d2b4d3SLarry Finger 	H2C_8723BE_SETPWRMODE = 0x20,
42f1d2b4d3SLarry Finger 	H2C_8723BE_PS_TUNING_PARA = 0x21,
43f1d2b4d3SLarry Finger 	H2C_8723BE_PS_TUNING_PARA2 = 0x22,
44f1d2b4d3SLarry Finger 	H2C_8723BE_PS_LPS_PARA = 0x23,
45f1d2b4d3SLarry Finger 	H2C_8723BE_P2P_PS_OFFLOAD = 0x24,
46f1d2b4d3SLarry Finger 
47f1d2b4d3SLarry Finger 	H2C_8723BE_WO_WLAN = 0x80,
48f1d2b4d3SLarry Finger 	H2C_8723BE_REMOTE_WAKE_CTRL = 0x81,
49f1d2b4d3SLarry Finger 	H2C_8723BE_AOAC_GLOBAL_INFO = 0x82,
50f1d2b4d3SLarry Finger 	H2C_8723BE_AOAC_RSVDPAGE = 0x83,
51f1d2b4d3SLarry Finger 	H2C_8723BE_RSSI_REPORT = 0x42,
52f1d2b4d3SLarry Finger 	H2C_8723BE_RA_MASK = 0x40,
53f1d2b4d3SLarry Finger 	H2C_8723BE_SELECTIVE_SUSPEND_ROF_CMD,
54f1d2b4d3SLarry Finger 	H2C_8723BE_P2P_PS_MODE,
55f1d2b4d3SLarry Finger 	H2C_8723BE_PSD_RESULT,
56f1d2b4d3SLarry Finger 	/*Not defined CTW CMD for P2P yet*/
57f1d2b4d3SLarry Finger 	H2C_8723BE_P2P_PS_CTW_CMD,
58f1d2b4d3SLarry Finger 	MAX_8723BE_H2CCMD
59f1d2b4d3SLarry Finger };
60f1d2b4d3SLarry Finger 
61f1d2b4d3SLarry Finger void rtl8723ae_firmware_selfreset(struct ieee80211_hw *hw);
62f1d2b4d3SLarry Finger void rtl8723be_firmware_selfreset(struct ieee80211_hw *hw);
63f1d2b4d3SLarry Finger void rtl8723_enable_fw_download(struct ieee80211_hw *hw, bool enable);
64f1d2b4d3SLarry Finger void rtl8723_write_fw(struct ieee80211_hw *hw,
65f1d2b4d3SLarry Finger 		      enum version_8723e version,
66f1d2b4d3SLarry Finger 		      u8 *buffer, u32 size, u8 max_page);
67f1d2b4d3SLarry Finger int rtl8723_fw_free_to_go(struct ieee80211_hw *hw, bool is_8723be, int count);
68f1d2b4d3SLarry Finger int rtl8723_download_fw(struct ieee80211_hw *hw, bool is_8723be, int count);
69f1d2b4d3SLarry Finger 
70f1d2b4d3SLarry Finger #endif
71