1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29#ifndef __RTL92C__FW__H__
30#define __RTL92C__FW__H__
31
32#define FW_8192C_SIZE 0x3000
33#define FW_8192C_START_ADDRESS 0x1000
34#define FW_8192C_END_ADDRESS 0x3FFF
35#define FW_8192C_PAGE_SIZE 4096
36#define FW_8192C_POLLING_DELAY 5
37
38#define IS_FW_HEADER_EXIST(_pfwhdr) \
39 ((_pfwhdr->signature&0xFFFF) == 0x2300 ||\
40 (_pfwhdr->signature&0xFFFF) == 0x2301 ||\
41 (_pfwhdr->signature&0xFFFF) == 0x2302)
42
43#define pagenum_128(_len) (u32)(((_len)>>7) + ((_len)&0x7F ? 1 : 0))
44
45#define SET_H2CCMD_PWRMODE_PARM_MODE(__ph2ccmd, __val) \
46 SET_BITS_TO_LE_1BYTE(__ph2ccmd, 0, 8, __val)
47#define SET_H2CCMD_PWRMODE_PARM_SMART_PS(__ph2ccmd, __val) \
48 SET_BITS_TO_LE_1BYTE((__ph2ccmd)+1, 0, 8, __val)
49#define SET_H2CCMD_PWRMODE_PARM_BCN_PASS_TIME(__ph2ccmd, __val) \
50 SET_BITS_TO_LE_1BYTE((__ph2ccmd)+2, 0, 8, __val)
51#define SET_H2CCMD_JOINBSSRPT_PARM_OPMODE(__ph2ccmd, __val) \
52 SET_BITS_TO_LE_1BYTE(__ph2ccmd, 0, 8, __val)
53#define SET_H2CCMD_RSVDPAGE_LOC_PROBE_RSP(__ph2ccmd, __val) \
54 SET_BITS_TO_LE_1BYTE(__ph2ccmd, 0, 8, __val)
55#define SET_H2CCMD_RSVDPAGE_LOC_PSPOLL(__ph2ccmd, __val) \
56 SET_BITS_TO_LE_1BYTE((__ph2ccmd)+1, 0, 8, __val)
57#define SET_H2CCMD_RSVDPAGE_LOC_NULL_DATA(__ph2ccmd, __val) \
58 SET_BITS_TO_LE_1BYTE((__ph2ccmd)+2, 0, 8, __val)
59
60void rtl8723e_fill_h2c_cmd(struct ieee80211_hw *hw, u8 element_id,
61 u32 cmd_len, u8 *p_cmdbuffer);
62void rtl8723e_set_fw_pwrmode_cmd(struct ieee80211_hw *hw, u8 mode);
63void rtl8723e_set_fw_rsvdpagepkt(struct ieee80211_hw *hw, bool b_dl_finished);
64void rtl8723e_set_fw_joinbss_report_cmd(struct ieee80211_hw *hw, u8 mstatus);
65void rtl8723e_set_p2p_ps_offload_cmd(struct ieee80211_hw *hw, u8 p2p_ps_state);
66#endif
67