qcacmn: Move tso fields in extended desc structure

Move tso fields in msdu_ext_desc structure from dp_tx_desc_s structure

Change-Id: I0cbd366ece753fc4266e08538f30b255ccdc0bd1
This commit is contained in:
Neha Bisht
2021-10-19 17:37:02 +05:30
committed by Madan Koyyalamudi
父節點 918c6cfdeb
當前提交 9a2423839d
共有 2 個文件被更改,包括 31 次插入20 次删除

查看文件

@@ -434,28 +434,31 @@ static void dp_tx_tso_desc_release(struct dp_soc *soc,
struct dp_tx_desc_s *tx_desc) struct dp_tx_desc_s *tx_desc)
{ {
TSO_DEBUG("%s: Free the tso descriptor", __func__); TSO_DEBUG("%s: Free the tso descriptor", __func__);
if (qdf_unlikely(!tx_desc->tso_desc)) { if (qdf_unlikely(!tx_desc->msdu_ext_desc->tso_desc)) {
dp_tx_err("SO desc is NULL!"); dp_tx_err("SO desc is NULL!");
qdf_assert(0); qdf_assert(0);
} else if (qdf_unlikely(!tx_desc->tso_num_desc)) { } else if (qdf_unlikely(!tx_desc->msdu_ext_desc->tso_num_desc)) {
dp_tx_err("TSO num desc is NULL!"); dp_tx_err("TSO num desc is NULL!");
qdf_assert(0); qdf_assert(0);
} else { } else {
struct qdf_tso_num_seg_elem_t *tso_num_desc = struct qdf_tso_num_seg_elem_t *tso_num_desc =
(struct qdf_tso_num_seg_elem_t *)tx_desc->tso_num_desc; (struct qdf_tso_num_seg_elem_t *)tx_desc->
msdu_ext_desc->tso_num_desc;
/* Add the tso num segment into the free list */ /* Add the tso num segment into the free list */
if (tso_num_desc->num_seg.tso_cmn_num_seg == 0) { if (tso_num_desc->num_seg.tso_cmn_num_seg == 0) {
dp_tso_num_seg_free(soc, tx_desc->pool_id, dp_tso_num_seg_free(soc, tx_desc->pool_id,
tx_desc->tso_num_desc); tx_desc->msdu_ext_desc->
tx_desc->tso_num_desc = NULL; tso_num_desc);
tx_desc->msdu_ext_desc->tso_num_desc = NULL;
DP_STATS_INC(tx_desc->pdev, tso_stats.tso_comp, 1); DP_STATS_INC(tx_desc->pdev, tso_stats.tso_comp, 1);
} }
/* Add the tso segment into the free list*/ /* Add the tso segment into the free list*/
dp_tx_tso_desc_free(soc, dp_tx_tso_desc_free(soc,
tx_desc->pool_id, tx_desc->tso_desc); tx_desc->pool_id, tx_desc->msdu_ext_desc->
tx_desc->tso_desc = NULL; tso_desc);
tx_desc->msdu_ext_desc->tso_desc = NULL;
} }
} }
#else #else
@@ -503,7 +506,8 @@ dp_tx_desc_release(struct dp_tx_desc_s *tx_desc, uint8_t desc_pool_id)
dp_tx_ext_desc_free(soc, tx_desc->msdu_ext_desc, desc_pool_id); dp_tx_ext_desc_free(soc, tx_desc->msdu_ext_desc, desc_pool_id);
if (tx_desc->flags & DP_TX_DESC_FLAG_ME) if (tx_desc->flags & DP_TX_DESC_FLAG_ME)
dp_tx_me_free_buf(tx_desc->pdev, tx_desc->me_buffer); dp_tx_me_free_buf(tx_desc->pdev, tx_desc->msdu_ext_desc->
me_buffer);
if (tx_desc->flags & DP_TX_DESC_FLAG_TO_FW) if (tx_desc->flags & DP_TX_DESC_FLAG_TO_FW)
qdf_atomic_dec(&soc->num_tx_exception); qdf_atomic_dec(&soc->num_tx_exception);
@@ -1198,8 +1202,9 @@ static struct dp_tx_desc_s *dp_tx_prepare_desc(struct dp_vdev *vdev,
tx_desc->vdev_id = vdev->vdev_id; tx_desc->vdev_id = vdev->vdev_id;
tx_desc->pdev = pdev; tx_desc->pdev = pdev;
tx_desc->pkt_offset = 0; tx_desc->pkt_offset = 0;
tx_desc->tso_desc = msdu_info->u.tso_info.curr_seg; tx_desc->msdu_ext_desc->tso_desc = msdu_info->u.tso_info.curr_seg;
tx_desc->tso_num_desc = msdu_info->u.tso_info.tso_num_seg_list; tx_desc->msdu_ext_desc->tso_num_desc = msdu_info->u.tso_info.
tso_num_seg_list;
dp_tx_trace_pkt(soc, nbuf, tx_desc->id, vdev->vdev_id); dp_tx_trace_pkt(soc, nbuf, tx_desc->id, vdev->vdev_id);
@@ -2008,11 +2013,14 @@ static inline void dp_tx_comp_free_buf(struct dp_soc *soc,
desc->msdu_ext_desc->vaddr)) { desc->msdu_ext_desc->vaddr)) {
dp_tx_desc_history_add(soc, desc->dma_addr, desc->nbuf, dp_tx_desc_history_add(soc, desc->dma_addr, desc->nbuf,
desc->id, DP_TX_COMP_MSDU_EXT); desc->id, DP_TX_COMP_MSDU_EXT);
dp_tx_tso_seg_history_add(soc, desc->tso_desc, dp_tx_tso_seg_history_add(soc,
desc->msdu_ext_desc->tso_desc,
desc->nbuf, desc->id, type); desc->nbuf, desc->id, type);
/* unmap eash TSO seg before free the nbuf */ /* unmap eash TSO seg before free the nbuf */
dp_tx_tso_unmap_segment(soc, desc->tso_desc, dp_tx_tso_unmap_segment(soc,
desc->tso_num_desc); desc->msdu_ext_desc->tso_desc,
desc->msdu_ext_desc->
tso_num_desc);
qdf_nbuf_free(nbuf); qdf_nbuf_free(nbuf);
return; return;
} }
@@ -2134,8 +2142,9 @@ qdf_nbuf_t dp_tx_send_msdu_multiple(struct dp_vdev *vdev, qdf_nbuf_t nbuf,
} }
if (msdu_info->frm_type == dp_tx_frm_me) { if (msdu_info->frm_type == dp_tx_frm_me) {
tx_desc->me_buffer = tx_desc->msdu_ext_desc->me_buffer =
msdu_info->u.sg_info.curr_seg->frags[0].vaddr; (struct dp_tx_me_buf_t *)msdu_info->
u.sg_info.curr_seg->frags[0].vaddr;
tx_desc->flags |= DP_TX_DESC_FLAG_ME; tx_desc->flags |= DP_TX_DESC_FLAG_ME;
} }

查看文件

@@ -485,12 +485,19 @@ struct rx_desc_pool {
* @vaddr: hlos virtual address pointer * @vaddr: hlos virtual address pointer
* @paddr: physical address pointer for descriptor * @paddr: physical address pointer for descriptor
* @flags: mark features for extension descriptor * @flags: mark features for extension descriptor
* @me_buffer: Pointer to ME buffer - store this so that it can be freed on
* Tx completion of ME packet
* @tso_desc: Pointer to Tso desc
* @tso_num_desc: Pointer to tso_num_desc
*/ */
struct dp_tx_ext_desc_elem_s { struct dp_tx_ext_desc_elem_s {
struct dp_tx_ext_desc_elem_s *next; struct dp_tx_ext_desc_elem_s *next;
void *vaddr; void *vaddr;
qdf_dma_addr_t paddr; qdf_dma_addr_t paddr;
uint16_t flags; uint16_t flags;
struct dp_tx_me_buf_t *me_buffer;
struct qdf_tso_seg_elem_t *tso_desc;
struct qdf_tso_num_seg_elem_t *tso_num_desc;
}; };
/** /**
@@ -534,8 +541,6 @@ struct dp_tx_ext_desc_pool_s {
* @buffer_src: buffer source TQM, REO, FW etc. * @buffer_src: buffer source TQM, REO, FW etc.
* @frm_type: Frame Type - ToDo check if this is redundant * @frm_type: Frame Type - ToDo check if this is redundant
* @pkt_offset: Offset from which the actual packet data starts * @pkt_offset: Offset from which the actual packet data starts
* @me_buffer: Pointer to ME buffer - store this so that it can be freed on
* Tx completion of ME packet
* @pool: handle to flow_pool this descriptor belongs to. * @pool: handle to flow_pool this descriptor belongs to.
*/ */
struct dp_tx_desc_s { struct dp_tx_desc_s {
@@ -556,9 +561,6 @@ struct dp_tx_desc_s {
uint8_t pkt_offset; uint8_t pkt_offset;
uint8_t pool_id; uint8_t pool_id;
struct dp_tx_ext_desc_elem_s *msdu_ext_desc; struct dp_tx_ext_desc_elem_s *msdu_ext_desc;
void *me_buffer;
void *tso_desc;
void *tso_num_desc;
uint64_t timestamp; uint64_t timestamp;
struct hal_tx_desc_comp_s comp; struct hal_tx_desc_comp_s comp;
}; };