hal_wbm.h 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163
  1. /*
  2. * Copyright (c) 2016-2019 The Linux Foundation. All rights reserved.
  3. *
  4. * Permission to use, copy, modify, and/or distribute this software for
  5. * any purpose with or without fee is hereby granted, provided that the
  6. * above copyright notice and this permission notice appear in all
  7. * copies.
  8. *
  9. * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
  10. * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
  11. * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
  12. * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
  13. * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
  14. * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
  15. * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
  16. * PERFORMANCE OF THIS SOFTWARE.
  17. */
  18. /**
  19. * hal_setup_link_idle_list - Setup scattered idle list using the
  20. * buffer list provided
  21. *
  22. * @hal_soc: Opaque HAL SOC handle
  23. * @scatter_bufs_base_paddr: Array of physical base addresses
  24. * @scatter_bufs_base_vaddr: Array of virtual base addresses
  25. * @num_scatter_bufs: Number of scatter buffers in the above lists
  26. * @scatter_buf_size: Size of each scatter buffer
  27. * @last_buf_end_offset: Offset to the last entry
  28. * @num_entries: Total entries of all scatter bufs
  29. *
  30. */
  31. static void hal_setup_link_idle_list_generic(void *hal_soc,
  32. qdf_dma_addr_t scatter_bufs_base_paddr[],
  33. void *scatter_bufs_base_vaddr[], uint32_t num_scatter_bufs,
  34. uint32_t scatter_buf_size, uint32_t last_buf_end_offset,
  35. uint32_t num_entries)
  36. {
  37. int i;
  38. uint32_t *prev_buf_link_ptr = NULL;
  39. struct hal_soc *soc = (struct hal_soc *)hal_soc;
  40. uint32_t reg_scatter_buf_size, reg_tot_scatter_buf_size;
  41. uint32_t val;
  42. /* Link the scatter buffers */
  43. for (i = 0; i < num_scatter_bufs; i++) {
  44. if (i > 0) {
  45. prev_buf_link_ptr[0] =
  46. scatter_bufs_base_paddr[i] & 0xffffffff;
  47. prev_buf_link_ptr[1] = HAL_SM(
  48. HWIO_WBM_R0_SCATTERED_LINK_DESC_LIST_BASE_MSB,
  49. BASE_ADDRESS_39_32,
  50. ((uint64_t)(scatter_bufs_base_paddr[i])
  51. >> 32)) | HAL_SM(
  52. HWIO_WBM_R0_SCATTERED_LINK_DESC_LIST_BASE_MSB,
  53. ADDRESS_MATCH_TAG,
  54. ADDRESS_MATCH_TAG_VAL);
  55. }
  56. prev_buf_link_ptr = (uint32_t *)(scatter_bufs_base_vaddr[i] +
  57. scatter_buf_size - WBM_IDLE_SCATTER_BUF_NEXT_PTR_SIZE);
  58. }
  59. /* TBD: Register programming partly based on MLD & the rest based on
  60. * inputs from HW team. Not complete yet.
  61. */
  62. reg_scatter_buf_size = (scatter_buf_size -
  63. WBM_IDLE_SCATTER_BUF_NEXT_PTR_SIZE)/64;
  64. reg_tot_scatter_buf_size = ((scatter_buf_size -
  65. WBM_IDLE_SCATTER_BUF_NEXT_PTR_SIZE) * num_scatter_bufs)/64;
  66. HAL_REG_WRITE(soc,
  67. HWIO_WBM_R0_IDLE_LIST_CONTROL_ADDR(
  68. SEQ_WCSS_UMAC_WBM_REG_OFFSET),
  69. HAL_SM(HWIO_WBM_R0_IDLE_LIST_CONTROL, SCATTER_BUFFER_SIZE,
  70. reg_scatter_buf_size) |
  71. HAL_SM(HWIO_WBM_R0_IDLE_LIST_CONTROL, LINK_DESC_IDLE_LIST_MODE,
  72. 0x1));
  73. HAL_REG_WRITE(soc,
  74. HWIO_WBM_R0_IDLE_LIST_SIZE_ADDR(
  75. SEQ_WCSS_UMAC_WBM_REG_OFFSET),
  76. HAL_SM(HWIO_WBM_R0_IDLE_LIST_SIZE,
  77. SCATTER_RING_SIZE_OF_IDLE_LINK_DESC_LIST,
  78. reg_tot_scatter_buf_size));
  79. HAL_REG_WRITE(soc,
  80. HWIO_WBM_R0_SCATTERED_LINK_DESC_LIST_BASE_LSB_ADDR(
  81. SEQ_WCSS_UMAC_WBM_REG_OFFSET),
  82. scatter_bufs_base_paddr[0] & 0xffffffff);
  83. HAL_REG_WRITE(soc,
  84. HWIO_WBM_R0_SCATTERED_LINK_DESC_LIST_BASE_MSB_ADDR(
  85. SEQ_WCSS_UMAC_WBM_REG_OFFSET),
  86. ((uint64_t)(scatter_bufs_base_paddr[0]) >> 32) &
  87. HWIO_WBM_R0_SCATTERED_LINK_DESC_LIST_BASE_MSB_BASE_ADDRESS_39_32_BMSK);
  88. HAL_REG_WRITE(soc,
  89. HWIO_WBM_R0_SCATTERED_LINK_DESC_LIST_BASE_MSB_ADDR(
  90. SEQ_WCSS_UMAC_WBM_REG_OFFSET),
  91. HAL_SM(HWIO_WBM_R0_SCATTERED_LINK_DESC_LIST_BASE_MSB,
  92. BASE_ADDRESS_39_32, ((uint64_t)(scatter_bufs_base_paddr[0])
  93. >> 32)) |
  94. HAL_SM(HWIO_WBM_R0_SCATTERED_LINK_DESC_LIST_BASE_MSB,
  95. ADDRESS_MATCH_TAG, ADDRESS_MATCH_TAG_VAL));
  96. /* ADDRESS_MATCH_TAG field in the above register is expected to match
  97. * with the upper bits of link pointer. The above write sets this field
  98. * to zero and we are also setting the upper bits of link pointers to
  99. * zero while setting up the link list of scatter buffers above
  100. */
  101. /* Setup head and tail pointers for the idle list */
  102. HAL_REG_WRITE(soc,
  103. HWIO_WBM_R0_SCATTERED_LINK_DESC_PTR_HEAD_INFO_IX0_ADDR(
  104. SEQ_WCSS_UMAC_WBM_REG_OFFSET),
  105. scatter_bufs_base_paddr[num_scatter_bufs-1] & 0xffffffff);
  106. HAL_REG_WRITE(soc,
  107. HWIO_WBM_R0_SCATTERED_LINK_DESC_PTR_HEAD_INFO_IX1_ADDR(
  108. SEQ_WCSS_UMAC_WBM_REG_OFFSET),
  109. HAL_SM(HWIO_WBM_R0_SCATTERED_LINK_DESC_PTR_HEAD_INFO_IX1,
  110. BUFFER_ADDRESS_39_32,
  111. ((uint64_t)(scatter_bufs_base_paddr[num_scatter_bufs-1])
  112. >> 32)) |
  113. HAL_SM(HWIO_WBM_R0_SCATTERED_LINK_DESC_PTR_HEAD_INFO_IX1,
  114. HEAD_POINTER_OFFSET, last_buf_end_offset >> 2));
  115. HAL_REG_WRITE(soc,
  116. HWIO_WBM_R0_SCATTERED_LINK_DESC_PTR_HEAD_INFO_IX0_ADDR(
  117. SEQ_WCSS_UMAC_WBM_REG_OFFSET),
  118. scatter_bufs_base_paddr[0] & 0xffffffff);
  119. HAL_REG_WRITE(soc,
  120. HWIO_WBM_R0_SCATTERED_LINK_DESC_PTR_TAIL_INFO_IX0_ADDR(
  121. SEQ_WCSS_UMAC_WBM_REG_OFFSET),
  122. scatter_bufs_base_paddr[0] & 0xffffffff);
  123. HAL_REG_WRITE(soc,
  124. HWIO_WBM_R0_SCATTERED_LINK_DESC_PTR_TAIL_INFO_IX1_ADDR(
  125. SEQ_WCSS_UMAC_WBM_REG_OFFSET),
  126. HAL_SM(HWIO_WBM_R0_SCATTERED_LINK_DESC_PTR_TAIL_INFO_IX1,
  127. BUFFER_ADDRESS_39_32,
  128. ((uint64_t)(scatter_bufs_base_paddr[0]) >>
  129. 32)) | HAL_SM(HWIO_WBM_R0_SCATTERED_LINK_DESC_PTR_TAIL_INFO_IX1,
  130. TAIL_POINTER_OFFSET, 0));
  131. HAL_REG_WRITE(soc,
  132. HWIO_WBM_R0_SCATTERED_LINK_DESC_PTR_HP_ADDR(
  133. SEQ_WCSS_UMAC_WBM_REG_OFFSET),
  134. 2*num_entries);
  135. /* Set RING_ID_DISABLE */
  136. val = HAL_SM(HWIO_WBM_R0_WBM_IDLE_LINK_RING_MISC, RING_ID_DISABLE, 1);
  137. /*
  138. * SRNG_ENABLE bit is not available in HWK v1 (QCA8074v1). Hence
  139. * check the presence of the bit before toggling it.
  140. */
  141. #ifdef HWIO_WBM_R0_WBM_IDLE_LINK_RING_MISC_SRNG_ENABLE_BMSK
  142. val |= HAL_SM(HWIO_WBM_R0_WBM_IDLE_LINK_RING_MISC, SRNG_ENABLE, 1);
  143. #endif
  144. HAL_REG_WRITE(soc,
  145. HWIO_WBM_R0_WBM_IDLE_LINK_RING_MISC_ADDR(SEQ_WCSS_UMAC_WBM_REG_OFFSET),
  146. val);
  147. }