rtl8710b_cmd.h 9.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175
  1. /******************************************************************************
  2. *
  3. * Copyright(c) 2007 - 2017 Realtek Corporation.
  4. *
  5. * This program is free software; you can redistribute it and/or modify it
  6. * under the terms of version 2 of the GNU General Public License as
  7. * published by the Free Software Foundation.
  8. *
  9. * This program is distributed in the hope that it will be useful, but WITHOUT
  10. * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  11. * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  12. * more details.
  13. *
  14. *****************************************************************************/
  15. #ifndef __RTL8710B_CMD_H__
  16. #define __RTL8710B_CMD_H__
  17. /* ---------------------------------------------------------------------------------------------------------
  18. * ---------------------------------- H2C CMD DEFINITION ------------------------------------------------
  19. * --------------------------------------------------------------------------------------------------------- */
  20. enum h2c_cmd_8710B {
  21. /* Common Class: 000 */
  22. H2C_8710B_RSVD_PAGE = 0x00,
  23. H2C_8710B_MEDIA_STATUS_RPT = 0x01,
  24. H2C_8710B_SCAN_ENABLE = 0x02,
  25. H2C_8710B_KEEP_ALIVE = 0x03,
  26. H2C_8710B_DISCON_DECISION = 0x04,
  27. H2C_8710B_PSD_OFFLOAD = 0x05,
  28. H2C_8710B_AP_OFFLOAD = 0x08,
  29. H2C_8710B_BCN_RSVDPAGE = 0x09,
  30. H2C_8710B_PROBERSP_RSVDPAGE = 0x0A,
  31. H2C_8710B_FCS_RSVDPAGE = 0x10,
  32. H2C_8710B_FCS_INFO = 0x11,
  33. H2C_8710B_AP_WOW_GPIO_CTRL = 0x13,
  34. /* PoweSave Class: 001 */
  35. H2C_8710B_SET_PWR_MODE = 0x20,
  36. H2C_8710B_PS_TUNING_PARA = 0x21,
  37. H2C_8710B_PS_TUNING_PARA2 = 0x22,
  38. H2C_8710B_P2P_LPS_PARAM = 0x23,
  39. H2C_8710B_P2P_PS_OFFLOAD = 0x24,
  40. H2C_8710B_PS_SCAN_ENABLE = 0x25,
  41. H2C_8710B_SAP_PS_ = 0x26,
  42. H2C_8710B_INACTIVE_PS_ = 0x27, /* Inactive_PS */
  43. H2C_8710B_FWLPS_IN_IPS_ = 0x28,
  44. /* Dynamic Mechanism Class: 010 */
  45. H2C_8710B_MACID_CFG = 0x40,
  46. H2C_8710B_TXBF = 0x41,
  47. H2C_8710B_RSSI_SETTING = 0x42,
  48. H2C_8710B_AP_REQ_TXRPT = 0x43,
  49. H2C_8710B_INIT_RATE_COLLECT = 0x44,
  50. H2C_8710B_RA_PARA_ADJUST = 0x46,
  51. /* WOWLAN Class: 100 */
  52. H2C_8710B_WOWLAN = 0x80,
  53. H2C_8710B_REMOTE_WAKE_CTRL = 0x81,
  54. H2C_8710B_AOAC_GLOBAL_INFO = 0x82,
  55. H2C_8710B_AOAC_RSVD_PAGE = 0x83,
  56. H2C_8710B_AOAC_RSVD_PAGE2 = 0x84,
  57. H2C_8710B_D0_SCAN_OFFLOAD_CTRL = 0x85,
  58. H2C_8710B_D0_SCAN_OFFLOAD_INFO = 0x86,
  59. H2C_8710B_CHNL_SWITCH_OFFLOAD = 0x87,
  60. H2C_8710B_P2P_OFFLOAD_RSVD_PAGE = 0x8A,
  61. H2C_8710B_P2P_OFFLOAD = 0x8B,
  62. H2C_8710B_RESET_TSF = 0xC0,
  63. H2C_8710B_MAXID,
  64. };
  65. /* ---------------------------------------------------------------------------------------------------------
  66. * ---------------------------------- H2C CMD CONTENT --------------------------------------------------
  67. * ---------------------------------------------------------------------------------------------------------
  68. * _RSVDPAGE_LOC_CMD_0x00 */
  69. #define SET_8710B_H2CCMD_RSVDPAGE_LOC_PROBE_RSP(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
  70. #define SET_8710B_H2CCMD_RSVDPAGE_LOC_PSPOLL(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 8, __Value)
  71. #define SET_8710B_H2CCMD_RSVDPAGE_LOC_NULL_DATA(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
  72. #define SET_8710B_H2CCMD_RSVDPAGE_LOC_QOS_NULL_DATA(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
  73. #define SET_8710B_H2CCMD_RSVDPAGE_LOC_BT_QOS_NULL_DATA(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
  74. /* _PWR_MOD_CMD_0x20 */
  75. #define SET_8710B_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
  76. #define SET_8710B_H2CCMD_PWRMODE_PARM_RLBM(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 0, 4, __Value)
  77. #define SET_8710B_H2CCMD_PWRMODE_PARM_SMART_PS(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+1, 4, 4, __Value)
  78. #define SET_8710B_H2CCMD_PWRMODE_PARM_BCN_PASS_TIME(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
  79. #define SET_8710B_H2CCMD_PWRMODE_PARM_ALL_QUEUE_UAPSD(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
  80. #define SET_8710B_H2CCMD_PWRMODE_PARM_BCN_EARLY_C2H_RPT(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 2, 1, __Value)
  81. #define SET_8710B_H2CCMD_PWRMODE_PARM_PWR_STATE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
  82. #define GET_8710B_H2CCMD_PWRMODE_PARM_MODE(__pH2CCmd) LE_BITS_TO_1BYTE(__pH2CCmd, 0, 8)
  83. /* _PS_TUNE_PARAM_CMD_0x21 */
  84. #define SET_8710B_H2CCMD_PSTUNE_PARM_BCN_TO_LIMIT(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
  85. #define SET_8710B_H2CCMD_PSTUNE_PARM_DTIM_TIMEOUT(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
  86. #define SET_8710B_H2CCMD_PSTUNE_PARM_ADOPT(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 1, __Value)
  87. #define SET_8710B_H2CCMD_PSTUNE_PARM_PS_TIMEOUT(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 1, 7, __Value)
  88. #define SET_8710B_H2CCMD_PSTUNE_PARM_DTIM_PERIOD(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
  89. /* _MACID_CFG_CMD_0x40 */
  90. #define SET_8710B_H2CCMD_MACID_CFG_MACID(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
  91. #define SET_8710B_H2CCMD_MACID_CFG_RAID(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 5, __Value)
  92. #define SET_8710B_H2CCMD_MACID_CFG_SGI_EN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 7, 1, __Value)
  93. #define SET_8710B_H2CCMD_MACID_CFG_BW(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 2, __Value)
  94. #define SET_8710B_H2CCMD_MACID_CFG_NO_UPDATE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 3, 1, __Value)
  95. #define SET_8710B_H2CCMD_MACID_CFG_VHT_EN(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 4, 2, __Value)
  96. #define SET_8710B_H2CCMD_MACID_CFG_DISPT(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 6, 1, __Value)
  97. #define SET_8710B_H2CCMD_MACID_CFG_DISRA(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 7, 1, __Value)
  98. #define SET_8710B_H2CCMD_MACID_CFG_RATE_MASK0(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
  99. #define SET_8710B_H2CCMD_MACID_CFG_RATE_MASK1(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd+4, 0, 8, __Value)
  100. #define SET_8710B_H2CCMD_MACID_CFG_RATE_MASK2(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd+5, 0, 8, __Value)
  101. #define SET_8710B_H2CCMD_MACID_CFG_RATE_MASK3(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd+6, 0, 8, __Value)
  102. /* _RSSI_SETTING_CMD_0x42 */
  103. #define SET_8710B_H2CCMD_RSSI_SETTING_MACID(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
  104. #define SET_8710B_H2CCMD_RSSI_SETTING_RSSI(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 7, __Value)
  105. #define SET_8710B_H2CCMD_RSSI_SETTING_ULDL_STATE(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
  106. /* _AP_REQ_TXRPT_CMD_0x43 */
  107. #define SET_8710B_H2CCMD_APREQRPT_PARM_MACID1(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
  108. #define SET_8710B_H2CCMD_APREQRPT_PARM_MACID2(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
  109. /* _FORCE_BT_TXPWR_CMD_0x62 */
  110. #define SET_8710B_H2CCMD_BT_PWR_IDX(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 8, __Value)
  111. /* _FORCE_BT_MP_OPER_CMD_0x67 */
  112. #define SET_8710B_H2CCMD_BT_MPOPER_VER(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 0, 4, __Value)
  113. #define SET_8710B_H2CCMD_BT_MPOPER_REQNUM(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd, 4, 4, __Value)
  114. #define SET_8710B_H2CCMD_BT_MPOPER_IDX(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd+1, 0, 8, __Value)
  115. #define SET_8710B_H2CCMD_BT_MPOPER_PARAM1(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd+2, 0, 8, __Value)
  116. #define SET_8710B_H2CCMD_BT_MPOPER_PARAM2(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd+3, 0, 8, __Value)
  117. #define SET_8710B_H2CCMD_BT_MPOPER_PARAM3(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE(__pH2CCmd+4, 0, 8, __Value)
  118. /* _BT_FW_PATCH_0x6A */
  119. #define SET_8710B_H2CCMD_BT_FW_PATCH_SIZE(__pH2CCmd, __Value) SET_BITS_TO_LE_2BYTE((pu1Byte)(__pH2CCmd), 0, 16, __Value)
  120. #define SET_8710B_H2CCMD_BT_FW_PATCH_ADDR0(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+2, 0, 8, __Value)
  121. #define SET_8710B_H2CCMD_BT_FW_PATCH_ADDR1(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+3, 0, 8, __Value)
  122. #define SET_8710B_H2CCMD_BT_FW_PATCH_ADDR2(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+4, 0, 8, __Value)
  123. #define SET_8710B_H2CCMD_BT_FW_PATCH_ADDR3(__pH2CCmd, __Value) SET_BITS_TO_LE_1BYTE((__pH2CCmd)+5, 0, 8, __Value)
  124. /* ---------------------------------------------------------------------------------------------------------
  125. * ------------------------------------------- Structure --------------------------------------------------
  126. * --------------------------------------------------------------------------------------------------------- */
  127. /* ---------------------------------------------------------------------------------------------------------
  128. * ---------------------------------- Function Statement --------------------------------------------------
  129. * --------------------------------------------------------------------------------------------------------- */
  130. /* host message to firmware cmd */
  131. void rtl8710b_set_FwPwrMode_cmd(PADAPTER padapter, u8 Mode);
  132. void rtl8710b_set_FwJoinBssRpt_cmd(PADAPTER padapter, u8 mstatus);
  133. /* s32 rtl8710b_set_lowpwr_lps_cmd(PADAPTER padapter, u8 enable); */
  134. void rtl8710b_set_FwPsTuneParam_cmd(PADAPTER padapter);
  135. void rtl8710b_download_rsvd_page(PADAPTER padapter, u8 mstatus);
  136. #ifdef CONFIG_BT_COEXIST
  137. void rtl8710b_download_BTCoex_AP_mode_rsvd_page(PADAPTER padapter);
  138. #endif /* CONFIG_BT_COEXIST */
  139. #ifdef CONFIG_P2P
  140. void rtl8710b_set_p2p_ps_offload_cmd(PADAPTER padapter, u8 p2p_ps_state);
  141. #endif /* CONFIG_P2P */
  142. #ifdef CONFIG_TDLS
  143. #ifdef CONFIG_TDLS_CH_SW
  144. void rtl8710b_set_BcnEarly_C2H_Rpt_cmd(PADAPTER padapter, u8 enable);
  145. #endif
  146. #endif
  147. #ifdef CONFIG_P2P_WOWLAN
  148. void rtl8710b_set_p2p_wowlan_offload_cmd(PADAPTER padapter);
  149. #endif
  150. s32 FillH2CCmd8710B(PADAPTER padapter, u8 ElementID, u32 CmdLen, u8 *pCmdBuffer);
  151. u8 GetTxBufferRsvdPageNum8710B(_adapter *padapter, bool wowlan);
  152. #endif