hal_wbm.h 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154
  1. /*
  2. * Copyright (c) 2016-2018 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. /* Link the scatter buffers */
  42. for (i = 0; i < num_scatter_bufs; i++) {
  43. if (i > 0) {
  44. prev_buf_link_ptr[0] =
  45. scatter_bufs_base_paddr[i] & 0xffffffff;
  46. prev_buf_link_ptr[1] = HAL_SM(
  47. HWIO_WBM_R0_SCATTERED_LINK_DESC_LIST_BASE_MSB,
  48. BASE_ADDRESS_39_32,
  49. ((uint64_t)(scatter_bufs_base_paddr[i])
  50. >> 32)) | HAL_SM(
  51. HWIO_WBM_R0_SCATTERED_LINK_DESC_LIST_BASE_MSB,
  52. ADDRESS_MATCH_TAG,
  53. ADDRESS_MATCH_TAG_VAL);
  54. }
  55. prev_buf_link_ptr = (uint32_t *)(scatter_bufs_base_vaddr[i] +
  56. scatter_buf_size - WBM_IDLE_SCATTER_BUF_NEXT_PTR_SIZE);
  57. }
  58. /* TBD: Register programming partly based on MLD & the rest based on
  59. * inputs from HW team. Not complete yet.
  60. */
  61. reg_scatter_buf_size = (scatter_buf_size -
  62. WBM_IDLE_SCATTER_BUF_NEXT_PTR_SIZE)/64;
  63. reg_tot_scatter_buf_size = ((scatter_buf_size -
  64. WBM_IDLE_SCATTER_BUF_NEXT_PTR_SIZE) * num_scatter_bufs)/64;
  65. HAL_REG_WRITE(soc,
  66. HWIO_WBM_R0_IDLE_LIST_CONTROL_ADDR(
  67. SEQ_WCSS_UMAC_WBM_REG_OFFSET),
  68. HAL_SM(HWIO_WBM_R0_IDLE_LIST_CONTROL, SCATTER_BUFFER_SIZE,
  69. reg_scatter_buf_size) |
  70. HAL_SM(HWIO_WBM_R0_IDLE_LIST_CONTROL, LINK_DESC_IDLE_LIST_MODE,
  71. 0x1));
  72. HAL_REG_WRITE(soc,
  73. HWIO_WBM_R0_IDLE_LIST_SIZE_ADDR(
  74. SEQ_WCSS_UMAC_WBM_REG_OFFSET),
  75. HAL_SM(HWIO_WBM_R0_IDLE_LIST_SIZE,
  76. SCATTER_RING_SIZE_OF_IDLE_LINK_DESC_LIST,
  77. reg_tot_scatter_buf_size));
  78. HAL_REG_WRITE(soc,
  79. HWIO_WBM_R0_SCATTERED_LINK_DESC_LIST_BASE_LSB_ADDR(
  80. SEQ_WCSS_UMAC_WBM_REG_OFFSET),
  81. scatter_bufs_base_paddr[0] & 0xffffffff);
  82. HAL_REG_WRITE(soc,
  83. HWIO_WBM_R0_SCATTERED_LINK_DESC_LIST_BASE_MSB_ADDR(
  84. SEQ_WCSS_UMAC_WBM_REG_OFFSET),
  85. ((uint64_t)(scatter_bufs_base_paddr[0]) >> 32) &
  86. HWIO_WBM_R0_SCATTERED_LINK_DESC_LIST_BASE_MSB_BASE_ADDRESS_39_32_BMSK);
  87. HAL_REG_WRITE(soc,
  88. HWIO_WBM_R0_SCATTERED_LINK_DESC_LIST_BASE_MSB_ADDR(
  89. SEQ_WCSS_UMAC_WBM_REG_OFFSET),
  90. HAL_SM(HWIO_WBM_R0_SCATTERED_LINK_DESC_LIST_BASE_MSB,
  91. BASE_ADDRESS_39_32, ((uint64_t)(scatter_bufs_base_paddr[0])
  92. >> 32)) |
  93. HAL_SM(HWIO_WBM_R0_SCATTERED_LINK_DESC_LIST_BASE_MSB,
  94. ADDRESS_MATCH_TAG, ADDRESS_MATCH_TAG_VAL));
  95. /* ADDRESS_MATCH_TAG field in the above register is expected to match
  96. * with the upper bits of link pointer. The above write sets this field
  97. * to zero and we are also setting the upper bits of link pointers to
  98. * zero while setting up the link list of scatter buffers above
  99. */
  100. /* Setup head and tail pointers for the idle list */
  101. HAL_REG_WRITE(soc,
  102. HWIO_WBM_R0_SCATTERED_LINK_DESC_PTR_HEAD_INFO_IX0_ADDR(
  103. SEQ_WCSS_UMAC_WBM_REG_OFFSET),
  104. scatter_bufs_base_paddr[num_scatter_bufs-1] & 0xffffffff);
  105. HAL_REG_WRITE(soc,
  106. HWIO_WBM_R0_SCATTERED_LINK_DESC_PTR_HEAD_INFO_IX1_ADDR(
  107. SEQ_WCSS_UMAC_WBM_REG_OFFSET),
  108. HAL_SM(HWIO_WBM_R0_SCATTERED_LINK_DESC_PTR_HEAD_INFO_IX1,
  109. BUFFER_ADDRESS_39_32,
  110. ((uint64_t)(scatter_bufs_base_paddr[num_scatter_bufs-1])
  111. >> 32)) |
  112. HAL_SM(HWIO_WBM_R0_SCATTERED_LINK_DESC_PTR_HEAD_INFO_IX1,
  113. HEAD_POINTER_OFFSET, last_buf_end_offset >> 2));
  114. HAL_REG_WRITE(soc,
  115. HWIO_WBM_R0_SCATTERED_LINK_DESC_PTR_HEAD_INFO_IX0_ADDR(
  116. SEQ_WCSS_UMAC_WBM_REG_OFFSET),
  117. scatter_bufs_base_paddr[0] & 0xffffffff);
  118. HAL_REG_WRITE(soc,
  119. HWIO_WBM_R0_SCATTERED_LINK_DESC_PTR_TAIL_INFO_IX0_ADDR(
  120. SEQ_WCSS_UMAC_WBM_REG_OFFSET),
  121. scatter_bufs_base_paddr[0] & 0xffffffff);
  122. HAL_REG_WRITE(soc,
  123. HWIO_WBM_R0_SCATTERED_LINK_DESC_PTR_TAIL_INFO_IX1_ADDR(
  124. SEQ_WCSS_UMAC_WBM_REG_OFFSET),
  125. HAL_SM(HWIO_WBM_R0_SCATTERED_LINK_DESC_PTR_TAIL_INFO_IX1,
  126. BUFFER_ADDRESS_39_32,
  127. ((uint64_t)(scatter_bufs_base_paddr[0]) >>
  128. 32)) | HAL_SM(HWIO_WBM_R0_SCATTERED_LINK_DESC_PTR_TAIL_INFO_IX1,
  129. TAIL_POINTER_OFFSET, 0));
  130. HAL_REG_WRITE(soc,
  131. HWIO_WBM_R0_SCATTERED_LINK_DESC_PTR_HP_ADDR(
  132. SEQ_WCSS_UMAC_WBM_REG_OFFSET),
  133. 2*num_entries);
  134. /* Enable the SRNG */
  135. HAL_REG_WRITE(soc,
  136. HWIO_WBM_R0_WBM_IDLE_LINK_RING_MISC_ADDR(
  137. SEQ_WCSS_UMAC_WBM_REG_OFFSET),
  138. 0x40);
  139. }