0001
0002
0003
0004 #ifndef __RTL92D__FW__H__
0005 #define __RTL92D__FW__H__
0006
0007 #define FW_8192D_START_ADDRESS 0x1000
0008 #define FW_8192D_PAGE_SIZE 4096
0009 #define FW_8192D_POLLING_TIMEOUT_COUNT 1000
0010
0011 #define IS_FW_HEADER_EXIST(_pfwhdr) \
0012 ((GET_FIRMWARE_HDR_SIGNATURE(_pfwhdr) & 0xFFF0) == 0x92C0 || \
0013 (GET_FIRMWARE_HDR_SIGNATURE(_pfwhdr) & 0xFFF0) == 0x88C0 || \
0014 (GET_FIRMWARE_HDR_SIGNATURE(_pfwhdr) & 0xFFFF) == 0x92D0 || \
0015 (GET_FIRMWARE_HDR_SIGNATURE(_pfwhdr) & 0xFFFF) == 0x92D1 || \
0016 (GET_FIRMWARE_HDR_SIGNATURE(_pfwhdr) & 0xFFFF) == 0x92D2 || \
0017 (GET_FIRMWARE_HDR_SIGNATURE(_pfwhdr) & 0xFFFF) == 0x92D3)
0018
0019
0020
0021 #define GET_FIRMWARE_HDR_SIGNATURE(__fwhdr) \
0022 le32_get_bits(*(__le32 *)__fwhdr, GENMASK(15, 0))
0023 #define GET_FIRMWARE_HDR_VERSION(__fwhdr) \
0024 le32_get_bits(*(__le32 *)(__fwhdr + 4), GENMASK(15, 0))
0025 #define GET_FIRMWARE_HDR_SUB_VER(__fwhdr) \
0026 le32_get_bits(*(__le32 *)(__fwhdr + 4), GENMASK(23, 16))
0027
0028 #define pagenum_128(_len) \
0029 (u32)(((_len) >> 7) + ((_len) & 0x7F ? 1 : 0))
0030
0031 #define SET_H2CCMD_JOINBSSRPT_PARM_OPMODE(__ph2ccmd, __val) \
0032 *(u8 *)__ph2ccmd = __val;
0033 #define SET_H2CCMD_RSVDPAGE_LOC_PROBE_RSP(__ph2ccmd, __val) \
0034 *(u8 *)__ph2ccmd = __val;
0035 #define SET_H2CCMD_RSVDPAGE_LOC_PSPOLL(__ph2ccmd, __val) \
0036 *(u8 *)(__ph2ccmd + 1) = __val;
0037 #define SET_H2CCMD_RSVDPAGE_LOC_NULL_DATA(__ph2ccmd, __val) \
0038 *(u8 *)(__ph2ccmd + 2) = __val;
0039
0040 int rtl92d_download_fw(struct ieee80211_hw *hw);
0041 void rtl92d_fill_h2c_cmd(struct ieee80211_hw *hw, u8 element_id,
0042 u32 cmd_len, u8 *p_cmdbuffer);
0043 void rtl92d_firmware_selfreset(struct ieee80211_hw *hw);
0044 void rtl92d_set_fw_rsvdpagepkt(struct ieee80211_hw *hw, bool b_dl_finished);
0045 void rtl92d_set_fw_joinbss_report_cmd(struct ieee80211_hw *hw, u8 mstatus);
0046
0047 #endif