hal_generic_api.h 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497
  1. /*
  2. * Copyright (c) 2016-2021 The Linux Foundation. All rights reserved.
  3. * Copyright (c) 2022 Qualcomm Innovation Center, Inc. All rights reserved.
  4. *
  5. * Permission to use, copy, modify, and/or distribute this software for
  6. * any purpose with or without fee is hereby granted, provided that the
  7. * above copyright notice and this permission notice appear in all
  8. * copies.
  9. *
  10. * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
  11. * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
  12. * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
  13. * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
  14. * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
  15. * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
  16. * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
  17. * PERFORMANCE OF THIS SOFTWARE.
  18. */
  19. #ifndef _HAL_GENERIC_API_H_
  20. #define _HAL_GENERIC_API_H_
  21. #include <hal_rx.h>
  22. /**
  23. * hal_get_radiotap_he_gi_ltf() - Convert HE ltf and GI value
  24. * from stats enum to radiotap enum
  25. * @he_gi: HE GI value used in stats
  26. * @he_ltf: HE LTF value used in stats
  27. *
  28. * Return: void
  29. */
  30. static inline void hal_get_radiotap_he_gi_ltf(uint16_t *he_gi, uint16_t *he_ltf)
  31. {
  32. switch (*he_gi) {
  33. case HE_GI_0_8:
  34. *he_gi = HE_GI_RADIOTAP_0_8;
  35. break;
  36. case HE_GI_1_6:
  37. *he_gi = HE_GI_RADIOTAP_1_6;
  38. break;
  39. case HE_GI_3_2:
  40. *he_gi = HE_GI_RADIOTAP_3_2;
  41. break;
  42. default:
  43. *he_gi = HE_GI_RADIOTAP_RESERVED;
  44. }
  45. switch (*he_ltf) {
  46. case HE_LTF_1_X:
  47. *he_ltf = HE_LTF_RADIOTAP_1_X;
  48. break;
  49. case HE_LTF_2_X:
  50. *he_ltf = HE_LTF_RADIOTAP_2_X;
  51. break;
  52. case HE_LTF_4_X:
  53. *he_ltf = HE_LTF_RADIOTAP_4_X;
  54. break;
  55. default:
  56. *he_ltf = HE_LTF_RADIOTAP_UNKNOWN;
  57. }
  58. }
  59. /* channel number to freq conversion */
  60. #define CHANNEL_NUM_14 14
  61. #define CHANNEL_NUM_15 15
  62. #define CHANNEL_NUM_27 27
  63. #define CHANNEL_NUM_35 35
  64. #define CHANNEL_NUM_182 182
  65. #define CHANNEL_NUM_197 197
  66. #define CHANNEL_FREQ_2484 2484
  67. #define CHANNEL_FREQ_2407 2407
  68. #define CHANNEL_FREQ_2512 2512
  69. #define CHANNEL_FREQ_5000 5000
  70. #define CHANNEL_FREQ_5950 5950
  71. #define CHANNEL_FREQ_4000 4000
  72. #define CHANNEL_FREQ_5150 5150
  73. #define CHANNEL_FREQ_5920 5920
  74. #define CHANNEL_FREQ_5935 5935
  75. #define FREQ_MULTIPLIER_CONST_5MHZ 5
  76. #define FREQ_MULTIPLIER_CONST_20MHZ 20
  77. /**
  78. * hal_rx_radiotap_num_to_freq() - Get frequency from chan number
  79. * @chan_num - Input channel number
  80. * @center_freq - Input Channel Center frequency
  81. *
  82. * Return - Channel frequency in Mhz
  83. */
  84. static inline uint16_t
  85. hal_rx_radiotap_num_to_freq(uint16_t chan_num, qdf_freq_t center_freq)
  86. {
  87. if (center_freq > CHANNEL_FREQ_5920 && center_freq < CHANNEL_FREQ_5950)
  88. return CHANNEL_FREQ_5935;
  89. if (center_freq < CHANNEL_FREQ_5950) {
  90. if (chan_num == CHANNEL_NUM_14)
  91. return CHANNEL_FREQ_2484;
  92. if (chan_num < CHANNEL_NUM_14)
  93. return CHANNEL_FREQ_2407 +
  94. (chan_num * FREQ_MULTIPLIER_CONST_5MHZ);
  95. if (chan_num < CHANNEL_NUM_27)
  96. return CHANNEL_FREQ_2512 +
  97. ((chan_num - CHANNEL_NUM_15) *
  98. FREQ_MULTIPLIER_CONST_20MHZ);
  99. if (chan_num > CHANNEL_NUM_182 &&
  100. chan_num < CHANNEL_NUM_197)
  101. return ((chan_num * FREQ_MULTIPLIER_CONST_5MHZ) +
  102. CHANNEL_FREQ_4000);
  103. return CHANNEL_FREQ_5000 +
  104. (chan_num * FREQ_MULTIPLIER_CONST_5MHZ);
  105. } else {
  106. return CHANNEL_FREQ_5950 +
  107. (chan_num * FREQ_MULTIPLIER_CONST_5MHZ);
  108. }
  109. }
  110. /**
  111. * hal_get_hw_hptp_generic() - Get HW head and tail pointer value for any ring
  112. * @hal_soc: Opaque HAL SOC handle
  113. * @hal_ring: Source ring pointer
  114. * @headp: Head Pointer
  115. * @tailp: Tail Pointer
  116. * @ring: Ring type
  117. *
  118. * Return: Update tail pointer and head pointer in arguments.
  119. */
  120. static inline
  121. void hal_get_hw_hptp_generic(struct hal_soc *hal_soc,
  122. hal_ring_handle_t hal_ring_hdl,
  123. uint32_t *headp, uint32_t *tailp,
  124. uint8_t ring)
  125. {
  126. struct hal_srng *srng = (struct hal_srng *)hal_ring_hdl;
  127. struct hal_hw_srng_config *ring_config;
  128. enum hal_ring_type ring_type = (enum hal_ring_type)ring;
  129. if (!hal_soc || !srng) {
  130. QDF_TRACE(QDF_MODULE_ID_HAL, QDF_TRACE_LEVEL_ERROR,
  131. "%s: Context is Null", __func__);
  132. return;
  133. }
  134. ring_config = HAL_SRNG_CONFIG(hal_soc, ring_type);
  135. if (!ring_config->lmac_ring) {
  136. if (srng->ring_dir == HAL_SRNG_SRC_RING) {
  137. *headp = SRNG_SRC_REG_READ(srng, HP);
  138. *tailp = SRNG_SRC_REG_READ(srng, TP);
  139. } else {
  140. *headp = SRNG_DST_REG_READ(srng, HP);
  141. *tailp = SRNG_DST_REG_READ(srng, TP);
  142. }
  143. }
  144. }
  145. #if defined(WBM_IDLE_LSB_WRITE_CONFIRM_WAR)
  146. /**
  147. * hal_wbm_idle_lsb_write_confirm() - Check and update WBM_IDLE_LINK ring LSB
  148. * @srng: srng handle
  149. *
  150. * Return: None
  151. */
  152. static void hal_wbm_idle_lsb_write_confirm(struct hal_srng *srng)
  153. {
  154. if (srng->ring_id == HAL_SRNG_WBM_IDLE_LINK) {
  155. while (SRNG_SRC_REG_READ(srng, BASE_LSB) !=
  156. ((unsigned int)srng->ring_base_paddr & 0xffffffff))
  157. SRNG_SRC_REG_WRITE(srng, BASE_LSB,
  158. srng->ring_base_paddr &
  159. 0xffffffff);
  160. }
  161. }
  162. #else
  163. static void hal_wbm_idle_lsb_write_confirm(struct hal_srng *srng)
  164. {
  165. }
  166. #endif
  167. /**
  168. * hal_srng_src_hw_init - Private function to initialize SRNG
  169. * source ring HW
  170. * @hal_soc: HAL SOC handle
  171. * @srng: SRNG ring pointer
  172. */
  173. static inline
  174. void hal_srng_src_hw_init_generic(struct hal_soc *hal,
  175. struct hal_srng *srng)
  176. {
  177. uint32_t reg_val = 0;
  178. uint64_t tp_addr = 0;
  179. hal_debug("hw_init srng %d", srng->ring_id);
  180. if (srng->flags & HAL_SRNG_MSI_INTR) {
  181. SRNG_SRC_REG_WRITE(srng, MSI1_BASE_LSB,
  182. srng->msi_addr & 0xffffffff);
  183. reg_val = SRNG_SM(SRNG_SRC_FLD(MSI1_BASE_MSB, ADDR),
  184. (uint64_t)(srng->msi_addr) >> 32) |
  185. SRNG_SM(SRNG_SRC_FLD(MSI1_BASE_MSB,
  186. MSI1_ENABLE), 1);
  187. SRNG_SRC_REG_WRITE(srng, MSI1_BASE_MSB, reg_val);
  188. SRNG_SRC_REG_WRITE(srng, MSI1_DATA,
  189. qdf_cpu_to_le32(srng->msi_data));
  190. }
  191. SRNG_SRC_REG_WRITE(srng, BASE_LSB, srng->ring_base_paddr & 0xffffffff);
  192. hal_wbm_idle_lsb_write_confirm(srng);
  193. reg_val = SRNG_SM(SRNG_SRC_FLD(BASE_MSB, RING_BASE_ADDR_MSB),
  194. ((uint64_t)(srng->ring_base_paddr) >> 32)) |
  195. SRNG_SM(SRNG_SRC_FLD(BASE_MSB, RING_SIZE),
  196. srng->entry_size * srng->num_entries);
  197. SRNG_SRC_REG_WRITE(srng, BASE_MSB, reg_val);
  198. reg_val = SRNG_SM(SRNG_SRC_FLD(ID, ENTRY_SIZE), srng->entry_size);
  199. SRNG_SRC_REG_WRITE(srng, ID, reg_val);
  200. /**
  201. * Interrupt setup:
  202. * Default interrupt mode is 'pulse'. Need to setup SW_INTERRUPT_MODE
  203. * if level mode is required
  204. */
  205. reg_val = 0;
  206. /*
  207. * WAR - Hawkeye v1 has a hardware bug which requires timer value to be
  208. * programmed in terms of 1us resolution instead of 8us resolution as
  209. * given in MLD.
  210. */
  211. if (srng->intr_timer_thres_us) {
  212. reg_val |= SRNG_SM(SRNG_SRC_FLD(CONSUMER_INT_SETUP_IX0,
  213. INTERRUPT_TIMER_THRESHOLD),
  214. srng->intr_timer_thres_us);
  215. /* For HK v2 this should be (srng->intr_timer_thres_us >> 3) */
  216. }
  217. if (srng->intr_batch_cntr_thres_entries) {
  218. reg_val |= SRNG_SM(SRNG_SRC_FLD(CONSUMER_INT_SETUP_IX0,
  219. BATCH_COUNTER_THRESHOLD),
  220. srng->intr_batch_cntr_thres_entries *
  221. srng->entry_size);
  222. }
  223. SRNG_SRC_REG_WRITE(srng, CONSUMER_INT_SETUP_IX0, reg_val);
  224. reg_val = 0;
  225. if (srng->flags & HAL_SRNG_LOW_THRES_INTR_ENABLE) {
  226. reg_val |= SRNG_SM(SRNG_SRC_FLD(CONSUMER_INT_SETUP_IX1,
  227. LOW_THRESHOLD), srng->u.src_ring.low_threshold);
  228. }
  229. SRNG_SRC_REG_WRITE(srng, CONSUMER_INT_SETUP_IX1, reg_val);
  230. /* As per HW team, TP_ADDR and HP_ADDR for Idle link ring should
  231. * remain 0 to avoid some WBM stability issues. Remote head/tail
  232. * pointers are not required since this ring is completely managed
  233. * by WBM HW
  234. */
  235. reg_val = 0;
  236. if (srng->ring_id != HAL_SRNG_WBM_IDLE_LINK) {
  237. tp_addr = (uint64_t)(hal->shadow_rdptr_mem_paddr +
  238. ((unsigned long)(srng->u.src_ring.tp_addr) -
  239. (unsigned long)(hal->shadow_rdptr_mem_vaddr)));
  240. SRNG_SRC_REG_WRITE(srng, TP_ADDR_LSB, tp_addr & 0xffffffff);
  241. SRNG_SRC_REG_WRITE(srng, TP_ADDR_MSB, tp_addr >> 32);
  242. } else {
  243. reg_val |= SRNG_SM(SRNG_SRC_FLD(MISC, RING_ID_DISABLE), 1);
  244. }
  245. /* Initilaize head and tail pointers to indicate ring is empty */
  246. SRNG_SRC_REG_WRITE(srng, HP, 0);
  247. SRNG_SRC_REG_WRITE(srng, TP, 0);
  248. *(srng->u.src_ring.tp_addr) = 0;
  249. reg_val |= ((srng->flags & HAL_SRNG_DATA_TLV_SWAP) ?
  250. SRNG_SM(SRNG_SRC_FLD(MISC, DATA_TLV_SWAP_BIT), 1) : 0) |
  251. ((srng->flags & HAL_SRNG_RING_PTR_SWAP) ?
  252. SRNG_SM(SRNG_SRC_FLD(MISC, HOST_FW_SWAP_BIT), 1) : 0) |
  253. ((srng->flags & HAL_SRNG_MSI_SWAP) ?
  254. SRNG_SM(SRNG_SRC_FLD(MISC, MSI_SWAP_BIT), 1) : 0);
  255. /* Loop count is not used for SRC rings */
  256. reg_val |= SRNG_SM(SRNG_SRC_FLD(MISC, LOOPCNT_DISABLE), 1);
  257. /*
  258. * reg_val |= SRNG_SM(SRNG_SRC_FLD(MISC, SRNG_ENABLE), 1);
  259. * todo: update fw_api and replace with above line
  260. * (when SRNG_ENABLE field for the MISC register is available in fw_api)
  261. * (WCSS_UMAC_CE_0_SRC_WFSS_CE_CHANNEL_SRC_R0_SRC_RING_MISC)
  262. */
  263. reg_val |= 0x40;
  264. SRNG_SRC_REG_WRITE(srng, MISC, reg_val);
  265. }
  266. #ifdef WLAN_FEATURE_NEAR_FULL_IRQ
  267. /**
  268. * hal_srng_dst_msi2_setup() - Configure MSI2 register for a SRNG
  269. * @srng: SRNG handle
  270. *
  271. * Return: None
  272. */
  273. static inline void hal_srng_dst_msi2_setup(struct hal_srng *srng)
  274. {
  275. uint32_t reg_val = 0;
  276. if (srng->u.dst_ring.nf_irq_support) {
  277. SRNG_DST_REG_WRITE(srng, MSI2_BASE_LSB,
  278. srng->msi2_addr & 0xffffffff);
  279. reg_val = SRNG_SM(SRNG_DST_FLD(MSI2_BASE_MSB, ADDR),
  280. (uint64_t)(srng->msi2_addr) >> 32) |
  281. SRNG_SM(SRNG_DST_FLD(MSI2_BASE_MSB,
  282. MSI2_ENABLE), 1);
  283. SRNG_DST_REG_WRITE(srng, MSI2_BASE_MSB, reg_val);
  284. SRNG_DST_REG_WRITE(srng, MSI2_DATA,
  285. qdf_cpu_to_le32(srng->msi2_data));
  286. }
  287. }
  288. /**
  289. * hal_srng_dst_near_full_int_setup() - Configure near-full params for SRNG
  290. * @srng: SRNG handle
  291. *
  292. * Return: None
  293. */
  294. static inline void hal_srng_dst_near_full_int_setup(struct hal_srng *srng)
  295. {
  296. uint32_t reg_val = 0;
  297. if (srng->u.dst_ring.nf_irq_support) {
  298. if (srng->intr_timer_thres_us) {
  299. reg_val |= SRNG_SM(SRNG_DST_FLD(PRODUCER_INT2_SETUP,
  300. INTERRUPT2_TIMER_THRESHOLD),
  301. srng->intr_timer_thres_us >> 3);
  302. }
  303. reg_val |= SRNG_SM(SRNG_DST_FLD(PRODUCER_INT2_SETUP,
  304. HIGH_THRESHOLD),
  305. srng->u.dst_ring.high_thresh *
  306. srng->entry_size);
  307. }
  308. SRNG_DST_REG_WRITE(srng, PRODUCER_INT2_SETUP, reg_val);
  309. }
  310. #else
  311. static inline void hal_srng_dst_msi2_setup(struct hal_srng *srng)
  312. {
  313. }
  314. static inline void hal_srng_dst_near_full_int_setup(struct hal_srng *srng)
  315. {
  316. }
  317. #endif
  318. /**
  319. * hal_srng_dst_hw_init - Private function to initialize SRNG
  320. * destination ring HW
  321. * @hal_soc: HAL SOC handle
  322. * @srng: SRNG ring pointer
  323. */
  324. static inline
  325. void hal_srng_dst_hw_init_generic(struct hal_soc *hal,
  326. struct hal_srng *srng)
  327. {
  328. uint32_t reg_val = 0;
  329. uint64_t hp_addr = 0;
  330. hal_debug("hw_init srng %d", srng->ring_id);
  331. if (srng->flags & HAL_SRNG_MSI_INTR) {
  332. SRNG_DST_REG_WRITE(srng, MSI1_BASE_LSB,
  333. srng->msi_addr & 0xffffffff);
  334. reg_val = SRNG_SM(SRNG_DST_FLD(MSI1_BASE_MSB, ADDR),
  335. (uint64_t)(srng->msi_addr) >> 32) |
  336. SRNG_SM(SRNG_DST_FLD(MSI1_BASE_MSB,
  337. MSI1_ENABLE), 1);
  338. SRNG_DST_REG_WRITE(srng, MSI1_BASE_MSB, reg_val);
  339. SRNG_DST_REG_WRITE(srng, MSI1_DATA,
  340. qdf_cpu_to_le32(srng->msi_data));
  341. hal_srng_dst_msi2_setup(srng);
  342. }
  343. SRNG_DST_REG_WRITE(srng, BASE_LSB, srng->ring_base_paddr & 0xffffffff);
  344. reg_val = SRNG_SM(SRNG_DST_FLD(BASE_MSB, RING_BASE_ADDR_MSB),
  345. ((uint64_t)(srng->ring_base_paddr) >> 32)) |
  346. SRNG_SM(SRNG_DST_FLD(BASE_MSB, RING_SIZE),
  347. srng->entry_size * srng->num_entries);
  348. SRNG_DST_REG_WRITE(srng, BASE_MSB, reg_val);
  349. reg_val = SRNG_SM(SRNG_DST_FLD(ID, RING_ID), srng->ring_id) |
  350. SRNG_SM(SRNG_DST_FLD(ID, ENTRY_SIZE), srng->entry_size);
  351. SRNG_DST_REG_WRITE(srng, ID, reg_val);
  352. /**
  353. * Interrupt setup:
  354. * Default interrupt mode is 'pulse'. Need to setup SW_INTERRUPT_MODE
  355. * if level mode is required
  356. */
  357. reg_val = 0;
  358. if (srng->intr_timer_thres_us) {
  359. reg_val |= SRNG_SM(SRNG_DST_FLD(PRODUCER_INT_SETUP,
  360. INTERRUPT_TIMER_THRESHOLD),
  361. srng->intr_timer_thres_us >> 3);
  362. }
  363. if (srng->intr_batch_cntr_thres_entries) {
  364. reg_val |= SRNG_SM(SRNG_DST_FLD(PRODUCER_INT_SETUP,
  365. BATCH_COUNTER_THRESHOLD),
  366. srng->intr_batch_cntr_thres_entries *
  367. srng->entry_size);
  368. }
  369. SRNG_DST_REG_WRITE(srng, PRODUCER_INT_SETUP, reg_val);
  370. /**
  371. * Near-Full Interrupt setup:
  372. * Default interrupt mode is 'pulse'. Need to setup SW_INTERRUPT_MODE
  373. * if level mode is required
  374. */
  375. hal_srng_dst_near_full_int_setup(srng);
  376. hp_addr = (uint64_t)(hal->shadow_rdptr_mem_paddr +
  377. ((unsigned long)(srng->u.dst_ring.hp_addr) -
  378. (unsigned long)(hal->shadow_rdptr_mem_vaddr)));
  379. SRNG_DST_REG_WRITE(srng, HP_ADDR_LSB, hp_addr & 0xffffffff);
  380. SRNG_DST_REG_WRITE(srng, HP_ADDR_MSB, hp_addr >> 32);
  381. /* Initilaize head and tail pointers to indicate ring is empty */
  382. SRNG_DST_REG_WRITE(srng, HP, 0);
  383. SRNG_DST_REG_WRITE(srng, TP, 0);
  384. *(srng->u.dst_ring.hp_addr) = 0;
  385. reg_val = ((srng->flags & HAL_SRNG_DATA_TLV_SWAP) ?
  386. SRNG_SM(SRNG_DST_FLD(MISC, DATA_TLV_SWAP_BIT), 1) : 0) |
  387. ((srng->flags & HAL_SRNG_RING_PTR_SWAP) ?
  388. SRNG_SM(SRNG_DST_FLD(MISC, HOST_FW_SWAP_BIT), 1) : 0) |
  389. ((srng->flags & HAL_SRNG_MSI_SWAP) ?
  390. SRNG_SM(SRNG_DST_FLD(MISC, MSI_SWAP_BIT), 1) : 0);
  391. /*
  392. * reg_val |= SRNG_SM(SRNG_SRC_FLD(MISC, SRNG_ENABLE), 1);
  393. * todo: update fw_api and replace with above line
  394. * (when SRNG_ENABLE field for the MISC register is available in fw_api)
  395. * (WCSS_UMAC_CE_0_SRC_WFSS_CE_CHANNEL_SRC_R0_SRC_RING_MISC)
  396. */
  397. reg_val |= 0x40;
  398. SRNG_DST_REG_WRITE(srng, MISC, reg_val);
  399. }
  400. /**
  401. * hal_srng_hw_reg_offset_init_generic() - Initialize the HW srng reg offset
  402. * @hal_soc: HAL Soc handle
  403. *
  404. * Return: None
  405. */
  406. static inline void hal_srng_hw_reg_offset_init_generic(struct hal_soc *hal_soc)
  407. {
  408. int32_t *hw_reg_offset = hal_soc->hal_hw_reg_offset;
  409. /* dst */
  410. hw_reg_offset[DST_HP] = REG_OFFSET(DST, HP);
  411. hw_reg_offset[DST_TP] = REG_OFFSET(DST, TP);
  412. hw_reg_offset[DST_ID] = REG_OFFSET(DST, ID);
  413. hw_reg_offset[DST_MISC] = REG_OFFSET(DST, MISC);
  414. hw_reg_offset[DST_HP_ADDR_LSB] = REG_OFFSET(DST, HP_ADDR_LSB);
  415. hw_reg_offset[DST_HP_ADDR_MSB] = REG_OFFSET(DST, HP_ADDR_MSB);
  416. hw_reg_offset[DST_MSI1_BASE_LSB] = REG_OFFSET(DST, MSI1_BASE_LSB);
  417. hw_reg_offset[DST_MSI1_BASE_MSB] = REG_OFFSET(DST, MSI1_BASE_MSB);
  418. hw_reg_offset[DST_MSI1_DATA] = REG_OFFSET(DST, MSI1_DATA);
  419. hw_reg_offset[DST_BASE_LSB] = REG_OFFSET(DST, BASE_LSB);
  420. hw_reg_offset[DST_BASE_MSB] = REG_OFFSET(DST, BASE_MSB);
  421. hw_reg_offset[DST_PRODUCER_INT_SETUP] =
  422. REG_OFFSET(DST, PRODUCER_INT_SETUP);
  423. /* src */
  424. hw_reg_offset[SRC_HP] = REG_OFFSET(SRC, HP);
  425. hw_reg_offset[SRC_TP] = REG_OFFSET(SRC, TP);
  426. hw_reg_offset[SRC_ID] = REG_OFFSET(SRC, ID);
  427. hw_reg_offset[SRC_MISC] = REG_OFFSET(SRC, MISC);
  428. hw_reg_offset[SRC_TP_ADDR_LSB] = REG_OFFSET(SRC, TP_ADDR_LSB);
  429. hw_reg_offset[SRC_TP_ADDR_MSB] = REG_OFFSET(SRC, TP_ADDR_MSB);
  430. hw_reg_offset[SRC_MSI1_BASE_LSB] = REG_OFFSET(SRC, MSI1_BASE_LSB);
  431. hw_reg_offset[SRC_MSI1_BASE_MSB] = REG_OFFSET(SRC, MSI1_BASE_MSB);
  432. hw_reg_offset[SRC_MSI1_DATA] = REG_OFFSET(SRC, MSI1_DATA);
  433. hw_reg_offset[SRC_BASE_LSB] = REG_OFFSET(SRC, BASE_LSB);
  434. hw_reg_offset[SRC_BASE_MSB] = REG_OFFSET(SRC, BASE_MSB);
  435. hw_reg_offset[SRC_CONSUMER_INT_SETUP_IX0] =
  436. REG_OFFSET(SRC, CONSUMER_INT_SETUP_IX0);
  437. hw_reg_offset[SRC_CONSUMER_INT_SETUP_IX1] =
  438. REG_OFFSET(SRC, CONSUMER_INT_SETUP_IX1);
  439. }
  440. #endif /* HAL_GENERIC_API_H_ */