hal_tx.c 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160
  1. // SPDX-License-Identifier: BSD-3-Clause-Clear
  2. /*
  3. * Copyright (c) 2018-2019 The Linux Foundation. All rights reserved.
  4. * Copyright (c) 2022 Qualcomm Innovation Center, Inc. All rights reserved.
  5. */
  6. #include "hal_desc.h"
  7. #include "hal.h"
  8. #include "hal_tx.h"
  9. #include "hif.h"
  10. #define DSCP_TID_MAP_TBL_ENTRY_SIZE 64
  11. /* dscp_tid_map - Default DSCP-TID mapping
  12. *
  13. * DSCP TID
  14. * 000000 0
  15. * 001000 1
  16. * 010000 2
  17. * 011000 3
  18. * 100000 4
  19. * 101000 5
  20. * 110000 6
  21. * 111000 7
  22. */
  23. static const u8 dscp_tid_map[DSCP_TID_MAP_TBL_ENTRY_SIZE] = {
  24. 0, 0, 0, 0, 0, 0, 0, 0,
  25. 1, 1, 1, 1, 1, 1, 1, 1,
  26. 2, 2, 2, 2, 2, 2, 2, 2,
  27. 3, 3, 3, 3, 3, 3, 3, 3,
  28. 4, 4, 4, 4, 4, 4, 4, 4,
  29. 5, 5, 5, 5, 5, 5, 5, 5,
  30. 6, 6, 6, 6, 6, 6, 6, 6,
  31. 7, 7, 7, 7, 7, 7, 7, 7,
  32. };
  33. void ath11k_hal_tx_cmd_desc_setup(struct ath11k_base *ab, void *cmd,
  34. struct hal_tx_info *ti)
  35. {
  36. struct hal_tcl_data_cmd *tcl_cmd = cmd;
  37. tcl_cmd->buf_addr_info.info0 =
  38. FIELD_PREP(BUFFER_ADDR_INFO0_ADDR, ti->paddr);
  39. tcl_cmd->buf_addr_info.info1 =
  40. FIELD_PREP(BUFFER_ADDR_INFO1_ADDR,
  41. ((uint64_t)ti->paddr >> HAL_ADDR_MSB_REG_SHIFT));
  42. tcl_cmd->buf_addr_info.info1 |=
  43. FIELD_PREP(BUFFER_ADDR_INFO1_RET_BUF_MGR, ti->rbm_id) |
  44. FIELD_PREP(BUFFER_ADDR_INFO1_SW_COOKIE, ti->desc_id);
  45. tcl_cmd->info0 =
  46. FIELD_PREP(HAL_TCL_DATA_CMD_INFO0_DESC_TYPE, ti->type) |
  47. FIELD_PREP(HAL_TCL_DATA_CMD_INFO0_ENCAP_TYPE, ti->encap_type) |
  48. FIELD_PREP(HAL_TCL_DATA_CMD_INFO0_ENCRYPT_TYPE,
  49. ti->encrypt_type) |
  50. FIELD_PREP(HAL_TCL_DATA_CMD_INFO0_SEARCH_TYPE,
  51. ti->search_type) |
  52. FIELD_PREP(HAL_TCL_DATA_CMD_INFO0_ADDR_EN,
  53. ti->addr_search_flags) |
  54. FIELD_PREP(HAL_TCL_DATA_CMD_INFO0_CMD_NUM,
  55. ti->meta_data_flags);
  56. tcl_cmd->info1 = ti->flags0 |
  57. FIELD_PREP(HAL_TCL_DATA_CMD_INFO1_DATA_LEN, ti->data_len) |
  58. FIELD_PREP(HAL_TCL_DATA_CMD_INFO1_PKT_OFFSET, ti->pkt_offset);
  59. tcl_cmd->info2 = ti->flags1 |
  60. FIELD_PREP(HAL_TCL_DATA_CMD_INFO2_TID, ti->tid) |
  61. FIELD_PREP(HAL_TCL_DATA_CMD_INFO2_LMAC_ID, ti->lmac_id);
  62. tcl_cmd->info3 = FIELD_PREP(HAL_TCL_DATA_CMD_INFO3_DSCP_TID_TABLE_IDX,
  63. ti->dscp_tid_tbl_idx) |
  64. FIELD_PREP(HAL_TCL_DATA_CMD_INFO3_SEARCH_INDEX,
  65. ti->bss_ast_idx) |
  66. FIELD_PREP(HAL_TCL_DATA_CMD_INFO3_CACHE_SET_NUM,
  67. ti->bss_ast_hash);
  68. tcl_cmd->info4 = 0;
  69. if (ti->enable_mesh)
  70. ab->hw_params.hw_ops->tx_mesh_enable(ab, tcl_cmd);
  71. }
  72. void ath11k_hal_tx_set_dscp_tid_map(struct ath11k_base *ab, int id)
  73. {
  74. u32 ctrl_reg_val;
  75. u32 addr;
  76. u8 hw_map_val[HAL_DSCP_TID_TBL_SIZE];
  77. int i;
  78. u32 value;
  79. int cnt = 0;
  80. ctrl_reg_val = ath11k_hif_read32(ab, HAL_SEQ_WCSS_UMAC_TCL_REG +
  81. HAL_TCL1_RING_CMN_CTRL_REG);
  82. /* Enable read/write access */
  83. ctrl_reg_val |= HAL_TCL1_RING_CMN_CTRL_DSCP_TID_MAP_PROG_EN;
  84. ath11k_hif_write32(ab, HAL_SEQ_WCSS_UMAC_TCL_REG +
  85. HAL_TCL1_RING_CMN_CTRL_REG, ctrl_reg_val);
  86. addr = HAL_SEQ_WCSS_UMAC_TCL_REG + HAL_TCL1_RING_DSCP_TID_MAP +
  87. (4 * id * (HAL_DSCP_TID_TBL_SIZE / 4));
  88. /* Configure each DSCP-TID mapping in three bits there by configure
  89. * three bytes in an iteration.
  90. */
  91. for (i = 0; i < DSCP_TID_MAP_TBL_ENTRY_SIZE; i += 8) {
  92. value = FIELD_PREP(HAL_TCL1_RING_FIELD_DSCP_TID_MAP0,
  93. dscp_tid_map[i]) |
  94. FIELD_PREP(HAL_TCL1_RING_FIELD_DSCP_TID_MAP1,
  95. dscp_tid_map[i + 1]) |
  96. FIELD_PREP(HAL_TCL1_RING_FIELD_DSCP_TID_MAP2,
  97. dscp_tid_map[i + 2]) |
  98. FIELD_PREP(HAL_TCL1_RING_FIELD_DSCP_TID_MAP3,
  99. dscp_tid_map[i + 3]) |
  100. FIELD_PREP(HAL_TCL1_RING_FIELD_DSCP_TID_MAP4,
  101. dscp_tid_map[i + 4]) |
  102. FIELD_PREP(HAL_TCL1_RING_FIELD_DSCP_TID_MAP5,
  103. dscp_tid_map[i + 5]) |
  104. FIELD_PREP(HAL_TCL1_RING_FIELD_DSCP_TID_MAP6,
  105. dscp_tid_map[i + 6]) |
  106. FIELD_PREP(HAL_TCL1_RING_FIELD_DSCP_TID_MAP7,
  107. dscp_tid_map[i + 7]);
  108. memcpy(&hw_map_val[cnt], (u8 *)&value, 3);
  109. cnt += 3;
  110. }
  111. for (i = 0; i < HAL_DSCP_TID_TBL_SIZE; i += 4) {
  112. ath11k_hif_write32(ab, addr, *(u32 *)&hw_map_val[i]);
  113. addr += 4;
  114. }
  115. /* Disable read/write access */
  116. ctrl_reg_val = ath11k_hif_read32(ab, HAL_SEQ_WCSS_UMAC_TCL_REG +
  117. HAL_TCL1_RING_CMN_CTRL_REG);
  118. ctrl_reg_val &= ~HAL_TCL1_RING_CMN_CTRL_DSCP_TID_MAP_PROG_EN;
  119. ath11k_hif_write32(ab, HAL_SEQ_WCSS_UMAC_TCL_REG +
  120. HAL_TCL1_RING_CMN_CTRL_REG,
  121. ctrl_reg_val);
  122. }
  123. void ath11k_hal_tx_init_data_ring(struct ath11k_base *ab, struct hal_srng *srng)
  124. {
  125. struct hal_srng_params params;
  126. struct hal_tlv_hdr *tlv;
  127. int i, entry_size;
  128. u8 *desc;
  129. memset(&params, 0, sizeof(params));
  130. entry_size = ath11k_hal_srng_get_entrysize(ab, HAL_TCL_DATA);
  131. ath11k_hal_srng_get_params(ab, srng, &params);
  132. desc = (u8 *)params.ring_base_vaddr;
  133. for (i = 0; i < params.num_entries; i++) {
  134. tlv = (struct hal_tlv_hdr *)desc;
  135. tlv->tl = FIELD_PREP(HAL_TLV_HDR_TAG, HAL_TCL_DATA_CMD) |
  136. FIELD_PREP(HAL_TLV_HDR_LEN,
  137. sizeof(struct hal_tcl_data_cmd));
  138. desc += entry_size;
  139. }
  140. }