hal_wbm.c 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158
  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. #include "hal_api.h"
  19. #include "qdf_module.h"
  20. /**
  21. * hal_setup_link_idle_list - Setup scattered idle list using the
  22. * buffer list provided
  23. *
  24. * @hal_soc: Opaque HAL SOC handle
  25. * @scatter_bufs_base_paddr: Array of physical base addresses
  26. * @scatter_bufs_base_vaddr: Array of virtual base addresses
  27. * @num_scatter_bufs: Number of scatter buffers in the above lists
  28. * @scatter_buf_size: Size of each scatter buffer
  29. * @last_buf_end_offset: Offset to the last entry
  30. * @num_entries: Total entries of all scatter bufs
  31. *
  32. */
  33. void hal_setup_link_idle_list(void *hal_soc,
  34. qdf_dma_addr_t scatter_bufs_base_paddr[],
  35. void *scatter_bufs_base_vaddr[], uint32_t num_scatter_bufs,
  36. uint32_t scatter_buf_size, uint32_t last_buf_end_offset,
  37. uint32_t num_entries)
  38. {
  39. int i;
  40. uint32_t *prev_buf_link_ptr = NULL;
  41. struct hal_soc *soc = (struct hal_soc *)hal_soc;
  42. uint32_t reg_scatter_buf_size, reg_tot_scatter_buf_size;
  43. /* Link the scatter buffers */
  44. for (i = 0; i < num_scatter_bufs; i++) {
  45. if (i > 0) {
  46. prev_buf_link_ptr[0] =
  47. scatter_bufs_base_paddr[i] & 0xffffffff;
  48. prev_buf_link_ptr[1] = HAL_SM(
  49. HWIO_WBM_R0_SCATTERED_LINK_DESC_LIST_BASE_MSB,
  50. BASE_ADDRESS_39_32,
  51. ((uint64_t)(scatter_bufs_base_paddr[i])
  52. >> 32)) | HAL_SM(
  53. HWIO_WBM_R0_SCATTERED_LINK_DESC_LIST_BASE_MSB,
  54. ADDRESS_MATCH_TAG,
  55. ADDRESS_MATCH_TAG_VAL);
  56. }
  57. prev_buf_link_ptr = (uint32_t *)(scatter_bufs_base_vaddr[i] +
  58. scatter_buf_size - WBM_IDLE_SCATTER_BUF_NEXT_PTR_SIZE);
  59. }
  60. /* TBD: Register programming partly based on MLD & the rest based on
  61. * inputs from HW team. Not complete yet.
  62. */
  63. reg_scatter_buf_size = (scatter_buf_size -
  64. WBM_IDLE_SCATTER_BUF_NEXT_PTR_SIZE)/64;
  65. reg_tot_scatter_buf_size = ((scatter_buf_size -
  66. WBM_IDLE_SCATTER_BUF_NEXT_PTR_SIZE) * num_scatter_bufs)/64;
  67. HAL_REG_WRITE(soc,
  68. HWIO_WBM_R0_IDLE_LIST_CONTROL_ADDR(
  69. SEQ_WCSS_UMAC_WBM_REG_OFFSET),
  70. HAL_SM(HWIO_WBM_R0_IDLE_LIST_CONTROL, SCATTER_BUFFER_SIZE,
  71. reg_scatter_buf_size) |
  72. HAL_SM(HWIO_WBM_R0_IDLE_LIST_CONTROL, LINK_DESC_IDLE_LIST_MODE,
  73. 0x1));
  74. HAL_REG_WRITE(soc,
  75. HWIO_WBM_R0_IDLE_LIST_SIZE_ADDR(
  76. SEQ_WCSS_UMAC_WBM_REG_OFFSET),
  77. HAL_SM(HWIO_WBM_R0_IDLE_LIST_SIZE,
  78. SCATTER_RING_SIZE_OF_IDLE_LINK_DESC_LIST,
  79. reg_tot_scatter_buf_size));
  80. HAL_REG_WRITE(soc,
  81. HWIO_WBM_R0_SCATTERED_LINK_DESC_LIST_BASE_LSB_ADDR(
  82. SEQ_WCSS_UMAC_WBM_REG_OFFSET),
  83. scatter_bufs_base_paddr[0] & 0xffffffff);
  84. HAL_REG_WRITE(soc,
  85. HWIO_WBM_R0_SCATTERED_LINK_DESC_LIST_BASE_MSB_ADDR(
  86. SEQ_WCSS_UMAC_WBM_REG_OFFSET),
  87. ((uint64_t)(scatter_bufs_base_paddr[0]) >> 32) &
  88. HWIO_WBM_R0_SCATTERED_LINK_DESC_LIST_BASE_MSB_BASE_ADDRESS_39_32_BMSK);
  89. HAL_REG_WRITE(soc,
  90. HWIO_WBM_R0_SCATTERED_LINK_DESC_LIST_BASE_MSB_ADDR(
  91. SEQ_WCSS_UMAC_WBM_REG_OFFSET),
  92. HAL_SM(HWIO_WBM_R0_SCATTERED_LINK_DESC_LIST_BASE_MSB,
  93. BASE_ADDRESS_39_32, ((uint64_t)(scatter_bufs_base_paddr[0])
  94. >> 32)) |
  95. HAL_SM(HWIO_WBM_R0_SCATTERED_LINK_DESC_LIST_BASE_MSB,
  96. ADDRESS_MATCH_TAG, ADDRESS_MATCH_TAG_VAL));
  97. /* ADDRESS_MATCH_TAG field in the above register is expected to match
  98. * with the upper bits of link pointer. The above write sets this field
  99. * to zero and we are also setting the upper bits of link pointers to
  100. * zero while setting up the link list of scatter buffers above
  101. */
  102. /* Setup head and tail pointers for the idle list */
  103. HAL_REG_WRITE(soc,
  104. HWIO_WBM_R0_SCATTERED_LINK_DESC_PTR_HEAD_INFO_IX0_ADDR(
  105. SEQ_WCSS_UMAC_WBM_REG_OFFSET),
  106. scatter_bufs_base_paddr[num_scatter_bufs-1] & 0xffffffff);
  107. HAL_REG_WRITE(soc,
  108. HWIO_WBM_R0_SCATTERED_LINK_DESC_PTR_HEAD_INFO_IX1_ADDR(
  109. SEQ_WCSS_UMAC_WBM_REG_OFFSET),
  110. HAL_SM(HWIO_WBM_R0_SCATTERED_LINK_DESC_PTR_HEAD_INFO_IX1,
  111. BUFFER_ADDRESS_39_32,
  112. ((uint64_t)(scatter_bufs_base_paddr[num_scatter_bufs-1])
  113. >> 32)) |
  114. HAL_SM(HWIO_WBM_R0_SCATTERED_LINK_DESC_PTR_HEAD_INFO_IX1,
  115. HEAD_POINTER_OFFSET, last_buf_end_offset >> 2));
  116. HAL_REG_WRITE(soc,
  117. HWIO_WBM_R0_SCATTERED_LINK_DESC_PTR_HEAD_INFO_IX0_ADDR(
  118. SEQ_WCSS_UMAC_WBM_REG_OFFSET),
  119. scatter_bufs_base_paddr[0] & 0xffffffff);
  120. HAL_REG_WRITE(soc,
  121. HWIO_WBM_R0_SCATTERED_LINK_DESC_PTR_TAIL_INFO_IX0_ADDR(
  122. SEQ_WCSS_UMAC_WBM_REG_OFFSET),
  123. scatter_bufs_base_paddr[0] & 0xffffffff);
  124. HAL_REG_WRITE(soc,
  125. HWIO_WBM_R0_SCATTERED_LINK_DESC_PTR_TAIL_INFO_IX1_ADDR(
  126. SEQ_WCSS_UMAC_WBM_REG_OFFSET),
  127. HAL_SM(HWIO_WBM_R0_SCATTERED_LINK_DESC_PTR_TAIL_INFO_IX1,
  128. BUFFER_ADDRESS_39_32,
  129. ((uint64_t)(scatter_bufs_base_paddr[0]) >>
  130. 32)) | HAL_SM(HWIO_WBM_R0_SCATTERED_LINK_DESC_PTR_TAIL_INFO_IX1,
  131. TAIL_POINTER_OFFSET, 0));
  132. HAL_REG_WRITE(soc,
  133. HWIO_WBM_R0_SCATTERED_LINK_DESC_PTR_HP_ADDR(
  134. SEQ_WCSS_UMAC_WBM_REG_OFFSET),
  135. 2*num_entries);
  136. /* Enable the SRNG */
  137. HAL_REG_WRITE(soc,
  138. HWIO_WBM_R0_WBM_IDLE_LINK_RING_MISC_ADDR(
  139. SEQ_WCSS_UMAC_WBM_REG_OFFSET),
  140. 0x40);
  141. }
  142. qdf_export_symbol(hal_setup_link_idle_list);