Commit 47a9656f authored by Naveen Mamindlapalli's avatar Naveen Mamindlapalli Committed by David S. Miller

octeontx2-pf: htb offload support for Round Robin scheduling

When multiple traffic flows reach Transmit level with the same
priority, with Round robin scheduling traffic flow with the highest
quantum value is picked. With this support, the user can add multiple
classes with the same priority and different quantum. This patch
does necessary changes to support the same.
Signed-off-by: default avatarNaveen Mamindlapalli <naveenm@marvell.com>
Signed-off-by: default avatarHariprasad Kelam <hkelam@marvell.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 9fe63d5f
...@@ -774,6 +774,7 @@ int otx2_txsch_alloc(struct otx2_nic *pfvf) ...@@ -774,6 +774,7 @@ int otx2_txsch_alloc(struct otx2_nic *pfvf)
rsp->schq_list[lvl][schq]; rsp->schq_list[lvl][schq];
pfvf->hw.txschq_link_cfg_lvl = rsp->link_cfg_lvl; pfvf->hw.txschq_link_cfg_lvl = rsp->link_cfg_lvl;
pfvf->hw.txschq_aggr_lvl_rr_prio = rsp->aggr_lvl_rr_prio;
return 0; return 0;
} }
......
...@@ -224,6 +224,7 @@ struct otx2_hw { ...@@ -224,6 +224,7 @@ struct otx2_hw {
/* NIX */ /* NIX */
u8 txschq_link_cfg_lvl; u8 txschq_link_cfg_lvl;
u8 txschq_aggr_lvl_rr_prio;
u16 txschq_list[NIX_TXSCH_LVL_CNT][MAX_TXSCHQ_PER_FUNC]; u16 txschq_list[NIX_TXSCH_LVL_CNT][MAX_TXSCHQ_PER_FUNC];
u16 matchall_ipolicer; u16 matchall_ipolicer;
u32 dwrr_mtu; u32 dwrr_mtu;
......
...@@ -60,12 +60,15 @@ struct otx2_qos_node { ...@@ -60,12 +60,15 @@ struct otx2_qos_node {
u64 ceil; u64 ceil;
u32 classid; u32 classid;
u32 prio; u32 prio;
u16 schq; /* hw txschq */ u32 quantum;
/* hw txschq */
u16 schq;
u16 qid; u16 qid;
u16 prio_anchor; u16 prio_anchor;
u16 max_static_prio; u16 max_static_prio;
u16 child_dwrr_cnt; u16 child_dwrr_cnt;
u16 child_static_cnt; u16 child_static_cnt;
u16 child_dwrr_prio;
u16 txschq_idx; /* txschq allocation index */ u16 txschq_idx; /* txschq allocation index */
u8 level; u8 level;
bool is_static; bool is_static;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment