net/ionic: fix Tx fragment limits
Checks
Commit Message
The reported nb_seg_max should include the main fragment in the
descriptor and the fragments in the accompanying SGL.
Update the Tx prep check as well.
These were missed when updating to the v1 Tx queue structures.
Fixes: 786c64763b50 ("net/ionic: clean up Tx queue version support")
Signed-off-by: Andrew Boyer <aboyer@pensando.io>
---
drivers/net/ionic/ionic_ethdev.c | 4 ++--
drivers/net/ionic/ionic_rxtx.c | 2 +-
2 files changed, 3 insertions(+), 3 deletions(-)
Comments
On 2/4/2021 8:37 PM, Andrew Boyer wrote:
> The reported nb_seg_max should include the main fragment in the
> descriptor and the fragments in the accompanying SGL.
>
> Update the Tx prep check as well.
>
> These were missed when updating to the v1 Tx queue structures.
>
> Fixes: 786c64763b50 ("net/ionic: clean up Tx queue version support" >
> Signed-off-by: Andrew Boyer <aboyer@pensando.io>
Applied to dpdk-next-net/main, thanks.
@@ -74,8 +74,8 @@ static const struct rte_eth_desc_lim tx_desc_lim_v1 = {
.nb_max = IONIC_MAX_RING_DESC,
.nb_min = IONIC_MIN_RING_DESC,
.nb_align = 1,
- .nb_seg_max = IONIC_TX_MAX_SG_ELEMS_V1,
- .nb_mtu_seg_max = IONIC_TX_MAX_SG_ELEMS_V1,
+ .nb_seg_max = IONIC_TX_MAX_SG_ELEMS_V1 + 1,
+ .nb_mtu_seg_max = IONIC_TX_MAX_SG_ELEMS_V1 + 1,
};
static const struct eth_dev_ops ionic_eth_dev_ops = {
@@ -596,7 +596,7 @@ ionic_prep_pkts(void *tx_queue __rte_unused, struct rte_mbuf **tx_pkts,
for (i = 0; i < nb_pkts; i++) {
txm = tx_pkts[i];
- if (txm->nb_segs > IONIC_TX_MAX_SG_ELEMS) {
+ if (txm->nb_segs > IONIC_TX_MAX_SG_ELEMS_V1 + 1) {
rte_errno = -EINVAL;
break;
}