Path: blob/main/sys/contrib/dev/athk/ath11k/hal_tx.c
48378 views
// SPDX-License-Identifier: BSD-3-Clause-Clear1/*2* Copyright (c) 2018-2019 The Linux Foundation. All rights reserved.3* Copyright (c) 2022 Qualcomm Innovation Center, Inc. All rights reserved.4*/56#include "hal_desc.h"7#include "hal.h"8#include "hal_tx.h"9#include "hif.h"1011#define DSCP_TID_MAP_TBL_ENTRY_SIZE 641213/* dscp_tid_map - Default DSCP-TID mapping14*15* DSCP TID16* 000000 017* 001000 118* 010000 219* 011000 320* 100000 421* 101000 522* 110000 623* 111000 724*/25static const u8 dscp_tid_map[DSCP_TID_MAP_TBL_ENTRY_SIZE] = {260, 0, 0, 0, 0, 0, 0, 0,271, 1, 1, 1, 1, 1, 1, 1,282, 2, 2, 2, 2, 2, 2, 2,293, 3, 3, 3, 3, 3, 3, 3,304, 4, 4, 4, 4, 4, 4, 4,315, 5, 5, 5, 5, 5, 5, 5,326, 6, 6, 6, 6, 6, 6, 6,337, 7, 7, 7, 7, 7, 7, 7,34};3536void ath11k_hal_tx_cmd_desc_setup(struct ath11k_base *ab, void *cmd,37struct hal_tx_info *ti)38{39struct hal_tcl_data_cmd *tcl_cmd = (struct hal_tcl_data_cmd *)cmd;4041tcl_cmd->buf_addr_info.info0 =42FIELD_PREP(BUFFER_ADDR_INFO0_ADDR, ti->paddr);43tcl_cmd->buf_addr_info.info1 =44FIELD_PREP(BUFFER_ADDR_INFO1_ADDR,45((uint64_t)ti->paddr >> HAL_ADDR_MSB_REG_SHIFT));46tcl_cmd->buf_addr_info.info1 |=47FIELD_PREP(BUFFER_ADDR_INFO1_RET_BUF_MGR, ti->rbm_id) |48FIELD_PREP(BUFFER_ADDR_INFO1_SW_COOKIE, ti->desc_id);4950tcl_cmd->info0 =51FIELD_PREP(HAL_TCL_DATA_CMD_INFO0_DESC_TYPE, ti->type) |52FIELD_PREP(HAL_TCL_DATA_CMD_INFO0_ENCAP_TYPE, ti->encap_type) |53FIELD_PREP(HAL_TCL_DATA_CMD_INFO0_ENCRYPT_TYPE,54ti->encrypt_type) |55FIELD_PREP(HAL_TCL_DATA_CMD_INFO0_SEARCH_TYPE,56ti->search_type) |57FIELD_PREP(HAL_TCL_DATA_CMD_INFO0_ADDR_EN,58ti->addr_search_flags) |59FIELD_PREP(HAL_TCL_DATA_CMD_INFO0_CMD_NUM,60ti->meta_data_flags);6162tcl_cmd->info1 = ti->flags0 |63FIELD_PREP(HAL_TCL_DATA_CMD_INFO1_DATA_LEN, ti->data_len) |64FIELD_PREP(HAL_TCL_DATA_CMD_INFO1_PKT_OFFSET, ti->pkt_offset);6566tcl_cmd->info2 = ti->flags1 |67FIELD_PREP(HAL_TCL_DATA_CMD_INFO2_TID, ti->tid) |68FIELD_PREP(HAL_TCL_DATA_CMD_INFO2_LMAC_ID, ti->lmac_id);6970tcl_cmd->info3 = FIELD_PREP(HAL_TCL_DATA_CMD_INFO3_DSCP_TID_TABLE_IDX,71ti->dscp_tid_tbl_idx) |72FIELD_PREP(HAL_TCL_DATA_CMD_INFO3_SEARCH_INDEX,73ti->bss_ast_idx) |74FIELD_PREP(HAL_TCL_DATA_CMD_INFO3_CACHE_SET_NUM,75ti->bss_ast_hash);76tcl_cmd->info4 = 0;7778if (ti->enable_mesh)79ab->hw_params.hw_ops->tx_mesh_enable(ab, tcl_cmd);80}8182void ath11k_hal_tx_set_dscp_tid_map(struct ath11k_base *ab, int id)83{84u32 ctrl_reg_val;85u32 addr;86u8 hw_map_val[HAL_DSCP_TID_TBL_SIZE];87int i;88u32 value;89int cnt = 0;9091ctrl_reg_val = ath11k_hif_read32(ab, HAL_SEQ_WCSS_UMAC_TCL_REG +92HAL_TCL1_RING_CMN_CTRL_REG);93/* Enable read/write access */94ctrl_reg_val |= HAL_TCL1_RING_CMN_CTRL_DSCP_TID_MAP_PROG_EN;95ath11k_hif_write32(ab, HAL_SEQ_WCSS_UMAC_TCL_REG +96HAL_TCL1_RING_CMN_CTRL_REG, ctrl_reg_val);9798addr = HAL_SEQ_WCSS_UMAC_TCL_REG + HAL_TCL1_RING_DSCP_TID_MAP +99(4 * id * (HAL_DSCP_TID_TBL_SIZE / 4));100101/* Configure each DSCP-TID mapping in three bits there by configure102* three bytes in an iteration.103*/104for (i = 0; i < DSCP_TID_MAP_TBL_ENTRY_SIZE; i += 8) {105value = FIELD_PREP(HAL_TCL1_RING_FIELD_DSCP_TID_MAP0,106dscp_tid_map[i]) |107FIELD_PREP(HAL_TCL1_RING_FIELD_DSCP_TID_MAP1,108dscp_tid_map[i + 1]) |109FIELD_PREP(HAL_TCL1_RING_FIELD_DSCP_TID_MAP2,110dscp_tid_map[i + 2]) |111FIELD_PREP(HAL_TCL1_RING_FIELD_DSCP_TID_MAP3,112dscp_tid_map[i + 3]) |113FIELD_PREP(HAL_TCL1_RING_FIELD_DSCP_TID_MAP4,114dscp_tid_map[i + 4]) |115FIELD_PREP(HAL_TCL1_RING_FIELD_DSCP_TID_MAP5,116dscp_tid_map[i + 5]) |117FIELD_PREP(HAL_TCL1_RING_FIELD_DSCP_TID_MAP6,118dscp_tid_map[i + 6]) |119FIELD_PREP(HAL_TCL1_RING_FIELD_DSCP_TID_MAP7,120dscp_tid_map[i + 7]);121memcpy(&hw_map_val[cnt], (u8 *)&value, 3);122cnt += 3;123}124125for (i = 0; i < HAL_DSCP_TID_TBL_SIZE; i += 4) {126ath11k_hif_write32(ab, addr, *(u32 *)&hw_map_val[i]);127addr += 4;128}129130/* Disable read/write access */131ctrl_reg_val = ath11k_hif_read32(ab, HAL_SEQ_WCSS_UMAC_TCL_REG +132HAL_TCL1_RING_CMN_CTRL_REG);133ctrl_reg_val &= ~HAL_TCL1_RING_CMN_CTRL_DSCP_TID_MAP_PROG_EN;134ath11k_hif_write32(ab, HAL_SEQ_WCSS_UMAC_TCL_REG +135HAL_TCL1_RING_CMN_CTRL_REG,136ctrl_reg_val);137}138139void ath11k_hal_tx_init_data_ring(struct ath11k_base *ab, struct hal_srng *srng)140{141struct hal_srng_params params;142struct hal_tlv_hdr *tlv;143int i, entry_size;144u8 *desc;145146memset(¶ms, 0, sizeof(params));147148entry_size = ath11k_hal_srng_get_entrysize(ab, HAL_TCL_DATA);149ath11k_hal_srng_get_params(ab, srng, ¶ms);150desc = (u8 *)params.ring_base_vaddr;151152for (i = 0; i < params.num_entries; i++) {153tlv = (struct hal_tlv_hdr *)desc;154tlv->tl = FIELD_PREP(HAL_TLV_HDR_TAG, HAL_TCL_DATA_CMD) |155FIELD_PREP(HAL_TLV_HDR_LEN,156sizeof(struct hal_tcl_data_cmd));157desc += entry_size;158}159}160161162