halmac_h2c_extra_info_ap.h 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220
  1. /******************************************************************************
  2. *
  3. * Copyright(c) 2016 - 2018 Realtek Corporation. All rights reserved.
  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 _HAL_H2CEXTRAINFO_H2C_C2H_AP_H_
  16. #define _HAL_H2CEXTRAINFO_H2C_C2H_AP_H_
  17. #define PARAM_INFO_GET_LEN(extra_info) GET_C2H_FIELD(extra_info + 0X00, 0, 8)
  18. #define PARAM_INFO_SET_LEN(extra_info, value) \
  19. SET_C2H_FIELD_CLR(extra_info + 0X00, 0, 8, value)
  20. #define PARAM_INFO_SET_LEN_NO_CLR(extra_info, value) \
  21. SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 0, 8, value)
  22. #define PARAM_INFO_GET_IO_CMD(extra_info) GET_C2H_FIELD(extra_info + 0X00, 8, 7)
  23. #define PARAM_INFO_SET_IO_CMD(extra_info, value) \
  24. SET_C2H_FIELD_CLR(extra_info + 0X00, 8, 7, value)
  25. #define PARAM_INFO_SET_IO_CMD_NO_CLR(extra_info, value) \
  26. SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 8, 7, value)
  27. #define PARAM_INFO_GET_MSK_EN(extra_info) \
  28. GET_C2H_FIELD(extra_info + 0X00, 15, 1)
  29. #define PARAM_INFO_SET_MSK_EN(extra_info, value) \
  30. SET_C2H_FIELD_CLR(extra_info + 0X00, 15, 1, value)
  31. #define PARAM_INFO_SET_MSK_EN_NO_CLR(extra_info, value) \
  32. SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 15, 1, value)
  33. #define PARAM_INFO_GET_LLT_PG_BNDY(extra_info) \
  34. GET_C2H_FIELD(extra_info + 0X00, 16, 8)
  35. #define PARAM_INFO_SET_LLT_PG_BNDY(extra_info, value) \
  36. SET_C2H_FIELD_CLR(extra_info + 0X00, 16, 8, value)
  37. #define PARAM_INFO_SET_LLT_PG_BNDY_NO_CLR(extra_info, value) \
  38. SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 16, 8, value)
  39. #define PARAM_INFO_GET_EFUSE_RSVDPAGE_LOC(extra_info) \
  40. GET_C2H_FIELD(extra_info + 0X00, 16, 8)
  41. #define PARAM_INFO_SET_EFUSE_RSVDPAGE_LOC(extra_info, value) \
  42. SET_C2H_FIELD_CLR(extra_info + 0X00, 16, 8, value)
  43. #define PARAM_INFO_SET_EFUSE_RSVDPAGE_LOC_NO_CLR(extra_info, value) \
  44. SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 16, 8, value)
  45. #define PARAM_INFO_GET_EFUSE_PATCH_EN(extra_info) \
  46. GET_C2H_FIELD(extra_info + 0X00, 16, 8)
  47. #define PARAM_INFO_SET_EFUSE_PATCH_EN(extra_info, value) \
  48. SET_C2H_FIELD_CLR(extra_info + 0X00, 16, 8, value)
  49. #define PARAM_INFO_SET_EFUSE_PATCH_EN_NO_CLR(extra_info, value) \
  50. SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 16, 8, value)
  51. #define PARAM_INFO_GET_RF_ADDR(extra_info) \
  52. GET_C2H_FIELD(extra_info + 0X00, 16, 8)
  53. #define PARAM_INFO_SET_RF_ADDR(extra_info, value) \
  54. SET_C2H_FIELD_CLR(extra_info + 0X00, 16, 8, value)
  55. #define PARAM_INFO_SET_RF_ADDR_NO_CLR(extra_info, value) \
  56. SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 16, 8, value)
  57. #define PARAM_INFO_GET_IO_ADDR(extra_info) \
  58. GET_C2H_FIELD(extra_info + 0X00, 16, 16)
  59. #define PARAM_INFO_SET_IO_ADDR(extra_info, value) \
  60. SET_C2H_FIELD_CLR(extra_info + 0X00, 16, 16, value)
  61. #define PARAM_INFO_SET_IO_ADDR_NO_CLR(extra_info, value) \
  62. SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 16, 16, value)
  63. #define PARAM_INFO_GET_DELAY_VAL(extra_info) \
  64. GET_C2H_FIELD(extra_info + 0X00, 16, 16)
  65. #define PARAM_INFO_SET_DELAY_VAL(extra_info, value) \
  66. SET_C2H_FIELD_CLR(extra_info + 0X00, 16, 16, value)
  67. #define PARAM_INFO_SET_DELAY_VAL_NO_CLR(extra_info, value) \
  68. SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 16, 16, value)
  69. #define PARAM_INFO_GET_RF_PATH(extra_info) \
  70. GET_C2H_FIELD(extra_info + 0X00, 24, 8)
  71. #define PARAM_INFO_SET_RF_PATH(extra_info, value) \
  72. SET_C2H_FIELD_CLR(extra_info + 0X00, 24, 8, value)
  73. #define PARAM_INFO_SET_RF_PATH_NO_CLR(extra_info, value) \
  74. SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 24, 8, value)
  75. #define PARAM_INFO_GET_DATA(extra_info) GET_C2H_FIELD(extra_info + 0X04, 0, 32)
  76. #define PARAM_INFO_SET_DATA(extra_info, value) \
  77. SET_C2H_FIELD_CLR(extra_info + 0X04, 0, 32, value)
  78. #define PARAM_INFO_SET_DATA_NO_CLR(extra_info, value) \
  79. SET_C2H_FIELD_NO_CLR(extra_info + 0X04, 0, 32, value)
  80. #define PARAM_INFO_GET_MASK(extra_info) GET_C2H_FIELD(extra_info + 0X08, 0, 32)
  81. #define PARAM_INFO_SET_MASK(extra_info, value) \
  82. SET_C2H_FIELD_CLR(extra_info + 0X08, 0, 32, value)
  83. #define PARAM_INFO_SET_MASK_NO_CLR(extra_info, value) \
  84. SET_C2H_FIELD_NO_CLR(extra_info + 0X08, 0, 32, value)
  85. #define CH_INFO_GET_CH(extra_info) GET_C2H_FIELD(extra_info + 0X00, 0, 8)
  86. #define CH_INFO_SET_CH(extra_info, value) \
  87. SET_C2H_FIELD_CLR(extra_info + 0X00, 0, 8, value)
  88. #define CH_INFO_SET_CH_NO_CLR(extra_info, value) \
  89. SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 0, 8, value)
  90. #define CH_INFO_GET_PRI_CH_IDX(extra_info) \
  91. GET_C2H_FIELD(extra_info + 0X00, 8, 4)
  92. #define CH_INFO_SET_PRI_CH_IDX(extra_info, value) \
  93. SET_C2H_FIELD_CLR(extra_info + 0X00, 8, 4, value)
  94. #define CH_INFO_SET_PRI_CH_IDX_NO_CLR(extra_info, value) \
  95. SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 8, 4, value)
  96. #define CH_INFO_GET_BW(extra_info) GET_C2H_FIELD(extra_info + 0X00, 12, 4)
  97. #define CH_INFO_SET_BW(extra_info, value) \
  98. SET_C2H_FIELD_CLR(extra_info + 0X00, 12, 4, value)
  99. #define CH_INFO_SET_BW_NO_CLR(extra_info, value) \
  100. SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 12, 4, value)
  101. #define CH_INFO_GET_TIMEOUT(extra_info) GET_C2H_FIELD(extra_info + 0X00, 16, 8)
  102. #define CH_INFO_SET_TIMEOUT(extra_info, value) \
  103. SET_C2H_FIELD_CLR(extra_info + 0X00, 16, 8, value)
  104. #define CH_INFO_SET_TIMEOUT_NO_CLR(extra_info, value) \
  105. SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 16, 8, value)
  106. #define CH_INFO_GET_ACTION_ID(extra_info) \
  107. GET_C2H_FIELD(extra_info + 0X00, 24, 7)
  108. #define CH_INFO_SET_ACTION_ID(extra_info, value) \
  109. SET_C2H_FIELD_CLR(extra_info + 0X00, 24, 7, value)
  110. #define CH_INFO_SET_ACTION_ID_NO_CLR(extra_info, value) \
  111. SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 24, 7, value)
  112. #define CH_INFO_GET_EXTRA_INFO(extra_info) \
  113. GET_C2H_FIELD(extra_info + 0X00, 31, 1)
  114. #define CH_INFO_SET_EXTRA_INFO(extra_info, value) \
  115. SET_C2H_FIELD_CLR(extra_info + 0X00, 31, 1, value)
  116. #define CH_INFO_SET_EXTRA_INFO_NO_CLR(extra_info, value) \
  117. SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 31, 1, value)
  118. #define CH_EXTRA_INFO_GET_ID(extra_info) GET_C2H_FIELD(extra_info + 0X00, 0, 7)
  119. #define CH_EXTRA_INFO_SET_ID(extra_info, value) \
  120. SET_C2H_FIELD_CLR(extra_info + 0X00, 0, 7, value)
  121. #define CH_EXTRA_INFO_SET_ID_NO_CLR(extra_info, value) \
  122. SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 0, 7, value)
  123. #define CH_EXTRA_INFO_GET_INFO(extra_info) \
  124. GET_C2H_FIELD(extra_info + 0X00, 7, 1)
  125. #define CH_EXTRA_INFO_SET_INFO(extra_info, value) \
  126. SET_C2H_FIELD_CLR(extra_info + 0X00, 7, 1, value)
  127. #define CH_EXTRA_INFO_SET_INFO_NO_CLR(extra_info, value) \
  128. SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 7, 1, value)
  129. #define CH_EXTRA_INFO_GET_SIZE(extra_info) \
  130. GET_C2H_FIELD(extra_info + 0X00, 8, 8)
  131. #define CH_EXTRA_INFO_SET_SIZE(extra_info, value) \
  132. SET_C2H_FIELD_CLR(extra_info + 0X00, 8, 8, value)
  133. #define CH_EXTRA_INFO_SET_SIZE_NO_CLR(extra_info, value) \
  134. SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 8, 8, value)
  135. #define CH_EXTRA_INFO_GET_DATA(extra_info) \
  136. GET_C2H_FIELD(extra_info + 0X00, 16, 1)
  137. #define CH_EXTRA_INFO_SET_DATA(extra_info, value) \
  138. SET_C2H_FIELD_CLR(extra_info + 0X00, 16, 1, value)
  139. #define CH_EXTRA_INFO_SET_DATA_NO_CLR(extra_info, value) \
  140. SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 16, 1, value)
  141. #define HIOE_INSTRUCTION_INFO_GET_BYTEDATA_L(extra_info) \
  142. GET_C2H_FIELD(extra_info + 0X00, 0, 16)
  143. #define HIOE_INSTRUCTION_INFO_SET_BYTEDATA_L(extra_info, value) \
  144. SET_C2H_FIELD_CLR(extra_info + 0X00, 0, 16, value)
  145. #define HIOE_INSTRUCTION_INFO_SET_BYTEDATA_L_NO_CLR(extra_info, value) \
  146. SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 0, 16, value)
  147. #define HIOE_INSTRUCTION_INFO_GET_BITDATA(extra_info) \
  148. GET_C2H_FIELD(extra_info + 0X00, 0, 16)
  149. #define HIOE_INSTRUCTION_INFO_SET_BITDATA(extra_info, value) \
  150. SET_C2H_FIELD_CLR(extra_info + 0X00, 0, 16, value)
  151. #define HIOE_INSTRUCTION_INFO_SET_BITDATA_NO_CLR(extra_info, value) \
  152. SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 0, 16, value)
  153. #define HIOE_INSTRUCTION_INFO_GET_BYTEDATA_H(extra_info) \
  154. GET_C2H_FIELD(extra_info + 0X00, 16, 16)
  155. #define HIOE_INSTRUCTION_INFO_SET_BYTEDATA_H(extra_info, value) \
  156. SET_C2H_FIELD_CLR(extra_info + 0X00, 16, 16, value)
  157. #define HIOE_INSTRUCTION_INFO_SET_BYTEDATA_H_NO_CLR(extra_info, value) \
  158. SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 16, 16, value)
  159. #define HIOE_INSTRUCTION_INFO_GET_BITMASK(extra_info) \
  160. GET_C2H_FIELD(extra_info + 0X00, 16, 16)
  161. #define HIOE_INSTRUCTION_INFO_SET_BITMASK(extra_info, value) \
  162. SET_C2H_FIELD_CLR(extra_info + 0X00, 16, 16, value)
  163. #define HIOE_INSTRUCTION_INFO_SET_BITMASK_NO_CLR(extra_info, value) \
  164. SET_C2H_FIELD_NO_CLR(extra_info + 0X00, 16, 16, value)
  165. #define HIOE_INSTRUCTION_INFO_GET_REG_ADDR(extra_info) \
  166. GET_C2H_FIELD(extra_info + 0X04, 0, 22)
  167. #define HIOE_INSTRUCTION_INFO_SET_REG_ADDR(extra_info, value) \
  168. SET_C2H_FIELD_CLR(extra_info + 0X04, 0, 22, value)
  169. #define HIOE_INSTRUCTION_INFO_SET_REG_ADDR_NO_CLR(extra_info, value) \
  170. SET_C2H_FIELD_NO_CLR(extra_info + 0X04, 0, 22, value)
  171. #define HIOE_INSTRUCTION_INFO_GET_DELAY_VALUE(extra_info) \
  172. GET_C2H_FIELD(extra_info + 0X04, 0, 22)
  173. #define HIOE_INSTRUCTION_INFO_SET_DELAY_VALUE(extra_info, value) \
  174. SET_C2H_FIELD_CLR(extra_info + 0X04, 0, 22, value)
  175. #define HIOE_INSTRUCTION_INFO_SET_DELAY_VALUE_NO_CLR(extra_info, value) \
  176. SET_C2H_FIELD_NO_CLR(extra_info + 0X04, 0, 22, value)
  177. #define HIOE_INSTRUCTION_INFO_GET_MODE_SELECT(extra_info) \
  178. GET_C2H_FIELD(extra_info + 0X04, 22, 1)
  179. #define HIOE_INSTRUCTION_INFO_SET_MODE_SELECT(extra_info, value) \
  180. SET_C2H_FIELD_CLR(extra_info + 0X04, 22, 1, value)
  181. #define HIOE_INSTRUCTION_INFO_SET_MODE_SELECT_NO_CLR(extra_info, value) \
  182. SET_C2H_FIELD_NO_CLR(extra_info + 0X04, 22, 1, value)
  183. #define HIOE_INSTRUCTION_INFO_GET_IO_DELAY(extra_info) \
  184. GET_C2H_FIELD(extra_info + 0X04, 23, 1)
  185. #define HIOE_INSTRUCTION_INFO_SET_IO_DELAY(extra_info, value) \
  186. SET_C2H_FIELD_CLR(extra_info + 0X04, 23, 1, value)
  187. #define HIOE_INSTRUCTION_INFO_SET_IO_DELAY_NO_CLR(extra_info, value) \
  188. SET_C2H_FIELD_NO_CLR(extra_info + 0X04, 23, 1, value)
  189. #define HIOE_INSTRUCTION_INFO_GET_BYTEMASK(extra_info) \
  190. GET_C2H_FIELD(extra_info + 0X04, 24, 4)
  191. #define HIOE_INSTRUCTION_INFO_SET_BYTEMASK(extra_info, value) \
  192. SET_C2H_FIELD_CLR(extra_info + 0X04, 24, 4, value)
  193. #define HIOE_INSTRUCTION_INFO_SET_BYTEMASK_NO_CLR(extra_info, value) \
  194. SET_C2H_FIELD_NO_CLR(extra_info + 0X04, 24, 4, value)
  195. #define HIOE_INSTRUCTION_INFO_GET_RD_EN(extra_info) \
  196. GET_C2H_FIELD(extra_info + 0X04, 28, 1)
  197. #define HIOE_INSTRUCTION_INFO_SET_RD_EN(extra_info, value) \
  198. SET_C2H_FIELD_CLR(extra_info + 0X04, 28, 1, value)
  199. #define HIOE_INSTRUCTION_INFO_SET_RD_EN_NO_CLR(extra_info, value) \
  200. SET_C2H_FIELD_NO_CLR(extra_info + 0X04, 28, 1, value)
  201. #define HIOE_INSTRUCTION_INFO_GET_WR_EN(extra_info) \
  202. GET_C2H_FIELD(extra_info + 0X04, 29, 1)
  203. #define HIOE_INSTRUCTION_INFO_SET_WR_EN(extra_info, value) \
  204. SET_C2H_FIELD_CLR(extra_info + 0X04, 29, 1, value)
  205. #define HIOE_INSTRUCTION_INFO_SET_WR_EN_NO_CLR(extra_info, value) \
  206. SET_C2H_FIELD_NO_CLR(extra_info + 0X04, 29, 1, value)
  207. #define HIOE_INSTRUCTION_INFO_GET_RAW_R(extra_info) \
  208. GET_C2H_FIELD(extra_info + 0X04, 30, 1)
  209. #define HIOE_INSTRUCTION_INFO_SET_RAW_R(extra_info, value) \
  210. SET_C2H_FIELD_CLR(extra_info + 0X04, 30, 1, value)
  211. #define HIOE_INSTRUCTION_INFO_SET_RAW_R_NO_CLR(extra_info, value) \
  212. SET_C2H_FIELD_NO_CLR(extra_info + 0X04, 30, 1, value)
  213. #define HIOE_INSTRUCTION_INFO_GET_RAW(extra_info) \
  214. GET_C2H_FIELD(extra_info + 0X04, 31, 1)
  215. #define HIOE_INSTRUCTION_INFO_SET_RAW(extra_info, value) \
  216. SET_C2H_FIELD_CLR(extra_info + 0X04, 31, 1, value)
  217. #define HIOE_INSTRUCTION_INFO_SET_RAW_NO_CLR(extra_info, value) \
  218. SET_C2H_FIELD_NO_CLR(extra_info + 0X04, 31, 1, value)
  219. #endif