Commit 2da6a804 authored by David S. Miller's avatar David S. Miller

Merge branch 'octeontx2-pf-round-robin-sched'

Hariprasad Kelam says:

====================
octeontx2-pf: support Round Robin scheduling

octeontx2 and CN10K silicons support 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 in htb offload.

This series of patches adds support for the same.

Patch1: implement transmit schedular allocation algorithm as preparation
        for support round robin scheduling.

Patch2: Allow quantum parameter in HTB offload mode.

Patch3: extends octeontx2 htb offload support for Round Robin scheduling

Patch4: extend QOS documentation for Round Robin scheduling

Hariprasad Kelam (1):
  docs: octeontx2: extend documentation for Round Robin scheduling

Naveen Mamindlapalli (3):
  octeontx2-pf: implement transmit schedular allocation algorithm
  sch_htb: Allow HTB quantum parameter in offload mode
  octeontx2-pf: htb offload support for Round Robin scheduling
---
v4 * update classid values in documentation.

v3 * 1. update QOS documentation for round robin scheduling
     2. added out of bound checks for quantum parameter

v2 * change data type of otx2_index_used to reduce size of structure
     otx2_qos_cfg
====================
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parents c6514f36 6f71051f
...@@ -332,3 +332,11 @@ Setup HTB offload ...@@ -332,3 +332,11 @@ Setup HTB offload
# tc class add dev <interface> parent 1: classid 1:1 htb rate 10Gbit prio 1 # tc class add dev <interface> parent 1: classid 1:1 htb rate 10Gbit prio 1
# tc class add dev <interface> parent 1: classid 1:2 htb rate 10Gbit prio 7 # tc class add dev <interface> parent 1: classid 1:2 htb rate 10Gbit prio 7
4. Create tc classes with same priorities and different quantum::
# tc class add dev <interface> parent 1: classid 1:1 htb rate 10Gbit prio 2 quantum 409600
# tc class add dev <interface> parent 1: classid 1:2 htb rate 10Gbit prio 2 quantum 188416
# tc class add dev <interface> parent 1: classid 1:3 htb rate 10Gbit prio 2 quantum 32768
...@@ -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;
......
...@@ -35,6 +35,7 @@ struct otx2_qos_cfg { ...@@ -35,6 +35,7 @@ struct otx2_qos_cfg {
int dwrr_node_pos[NIX_TXSCH_LVL_CNT]; int dwrr_node_pos[NIX_TXSCH_LVL_CNT];
u16 schq_contig_list[NIX_TXSCH_LVL_CNT][MAX_TXSCHQ_PER_FUNC]; u16 schq_contig_list[NIX_TXSCH_LVL_CNT][MAX_TXSCHQ_PER_FUNC];
u16 schq_list[NIX_TXSCH_LVL_CNT][MAX_TXSCHQ_PER_FUNC]; u16 schq_list[NIX_TXSCH_LVL_CNT][MAX_TXSCHQ_PER_FUNC];
bool schq_index_used[NIX_TXSCH_LVL_CNT][MAX_TXSCHQ_PER_FUNC];
}; };
struct otx2_qos { struct otx2_qos {
...@@ -59,10 +60,18 @@ struct otx2_qos_node { ...@@ -59,10 +60,18 @@ 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 child_dwrr_cnt;
u16 child_static_cnt;
u16 child_dwrr_prio;
u16 txschq_idx; /* txschq allocation index */
u8 level; u8 level;
bool is_static;
}; };
......
...@@ -379,9 +379,9 @@ int mlx5e_htb_setup_tc(struct mlx5e_priv *priv, struct tc_htb_qopt_offload *htb_ ...@@ -379,9 +379,9 @@ int mlx5e_htb_setup_tc(struct mlx5e_priv *priv, struct tc_htb_qopt_offload *htb_
if (!htb && htb_qopt->command != TC_HTB_CREATE) if (!htb && htb_qopt->command != TC_HTB_CREATE)
return -EINVAL; return -EINVAL;
if (htb_qopt->prio) { if (htb_qopt->prio || htb_qopt->quantum) {
NL_SET_ERR_MSG_MOD(htb_qopt->extack, NL_SET_ERR_MSG_MOD(htb_qopt->extack,
"prio parameter is not supported by device with HTB offload enabled."); "prio and quantum parameters are not supported by device with HTB offload enabled.");
return -EOPNOTSUPP; return -EOPNOTSUPP;
} }
......
...@@ -866,6 +866,7 @@ struct tc_htb_qopt_offload { ...@@ -866,6 +866,7 @@ struct tc_htb_qopt_offload {
u32 parent_classid; u32 parent_classid;
u16 classid; u16 classid;
u16 qid; u16 qid;
u32 quantum;
u64 rate; u64 rate;
u64 ceil; u64 ceil;
u8 prio; u8 prio;
......
...@@ -1810,10 +1810,6 @@ static int htb_change_class(struct Qdisc *sch, u32 classid, ...@@ -1810,10 +1810,6 @@ static int htb_change_class(struct Qdisc *sch, u32 classid,
NL_SET_ERR_MSG(extack, "HTB offload doesn't support the mpu parameter"); NL_SET_ERR_MSG(extack, "HTB offload doesn't support the mpu parameter");
goto failure; goto failure;
} }
if (hopt->quantum) {
NL_SET_ERR_MSG(extack, "HTB offload doesn't support the quantum parameter");
goto failure;
}
} }
/* Keeping backward compatible with rate_table based iproute2 tc */ /* Keeping backward compatible with rate_table based iproute2 tc */
...@@ -1910,6 +1906,7 @@ static int htb_change_class(struct Qdisc *sch, u32 classid, ...@@ -1910,6 +1906,7 @@ static int htb_change_class(struct Qdisc *sch, u32 classid,
.rate = max_t(u64, hopt->rate.rate, rate64), .rate = max_t(u64, hopt->rate.rate, rate64),
.ceil = max_t(u64, hopt->ceil.rate, ceil64), .ceil = max_t(u64, hopt->ceil.rate, ceil64),
.prio = hopt->prio, .prio = hopt->prio,
.quantum = hopt->quantum,
.extack = extack, .extack = extack,
}; };
err = htb_offload(dev, &offload_opt); err = htb_offload(dev, &offload_opt);
...@@ -1931,6 +1928,7 @@ static int htb_change_class(struct Qdisc *sch, u32 classid, ...@@ -1931,6 +1928,7 @@ static int htb_change_class(struct Qdisc *sch, u32 classid,
.rate = max_t(u64, hopt->rate.rate, rate64), .rate = max_t(u64, hopt->rate.rate, rate64),
.ceil = max_t(u64, hopt->ceil.rate, ceil64), .ceil = max_t(u64, hopt->ceil.rate, ceil64),
.prio = hopt->prio, .prio = hopt->prio,
.quantum = hopt->quantum,
.extack = extack, .extack = extack,
}; };
err = htb_offload(dev, &offload_opt); err = htb_offload(dev, &offload_opt);
...@@ -2017,6 +2015,7 @@ static int htb_change_class(struct Qdisc *sch, u32 classid, ...@@ -2017,6 +2015,7 @@ static int htb_change_class(struct Qdisc *sch, u32 classid,
.rate = max_t(u64, hopt->rate.rate, rate64), .rate = max_t(u64, hopt->rate.rate, rate64),
.ceil = max_t(u64, hopt->ceil.rate, ceil64), .ceil = max_t(u64, hopt->ceil.rate, ceil64),
.prio = hopt->prio, .prio = hopt->prio,
.quantum = hopt->quantum,
.extack = extack, .extack = extack,
}; };
err = htb_offload(dev, &offload_opt); err = htb_offload(dev, &offload_opt);
......
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