Hi Koh, Please see question below
Tuesday, May 22, 2018 9:57 AM, Yongseok Koh: > Subject: [PATCH v2 2/2] net/mlx5: remove redundant checks > > Signed-off-by: Yongseok Koh <[email protected]> > Acked-by: Xueming Li <[email protected]> > --- > > v2: > * add missing 'Acked-by' tag. > > drivers/net/mlx5/mlx5_rxtx.c | 6 ++---- drivers/net/mlx5/mlx5_rxtx.h | 14 > +++++++------- > 2 files changed, 9 insertions(+), 11 deletions(-) > > diff --git a/drivers/net/mlx5/mlx5_rxtx.c b/drivers/net/mlx5/mlx5_rxtx.c > index cdd373e3e..527859461 100644 > --- a/drivers/net/mlx5/mlx5_rxtx.c > +++ b/drivers/net/mlx5/mlx5_rxtx.c > @@ -522,7 +522,6 @@ mlx5_tx_burst(void *dpdk_txq, struct rte_mbuf > **pkts, uint16_t pkts_n) > uint16_t ehdr; > uint8_t cs_flags; > uint8_t tso = txq->tso_en && (buf->ol_flags & > PKT_TX_TCP_SEG); > - uint8_t is_vlan = !!(buf->ol_flags & PKT_TX_VLAN_PKT); > uint32_t swp_offsets = 0; > uint8_t swp_types = 0; > uint16_t tso_segsz = 0; > @@ -566,11 +565,10 @@ mlx5_tx_burst(void *dpdk_txq, struct rte_mbuf > **pkts, uint16_t pkts_n) > rte_prefetch0( > rte_pktmbuf_mtod(*(pkts + 1), volatile void *)); > cs_flags = txq_ol_cksum_to_cs(buf); > - txq_mbuf_to_swp(txq, buf, tso, is_vlan, > - (uint8_t *)&swp_offsets, &swp_types); > + txq_mbuf_to_swp(txq, buf, (uint8_t *)&swp_offsets, > &swp_types); > raw = ((uint8_t *)(uintptr_t)wqe) + 2 * > MLX5_WQE_DWORD_SIZE; > /* Replace the Ethernet type by the VLAN if necessary. */ > - if (is_vlan) { > + if (buf->ol_flags & PKT_TX_VLAN_PKT) { > uint32_t vlan = rte_cpu_to_be_32(0x81000000 | > buf->vlan_tci); > unsigned int len = 2 * ETHER_ADDR_LEN - 2; diff --git > a/drivers/net/mlx5/mlx5_rxtx.h b/drivers/net/mlx5/mlx5_rxtx.h index > 1e4b2fdb9..5d9a7dffd 100644 > --- a/drivers/net/mlx5/mlx5_rxtx.h > +++ b/drivers/net/mlx5/mlx5_rxtx.h > @@ -651,10 +651,10 @@ mlx5_tx_dbrec(struct mlx5_txq_data *txq, volatile > struct mlx5_wqe *wqe) > */ > static __rte_always_inline void > txq_mbuf_to_swp(struct mlx5_txq_data *txq, struct rte_mbuf *buf, > - uint8_t tso, uint64_t vlan, > - uint8_t *offsets, uint8_t *swp_types) > + uint8_t *offsets, uint8_t *swp_types) > { > - uint64_t tunnel = buf->ol_flags & PKT_TX_TUNNEL_MASK; > + const uint64_t vlan = buf->ol_flags & PKT_TX_VLAN_PKT; > + const uint64_t tunnel = buf->ol_flags & PKT_TX_TUNNEL_MASK; > const uint64_t csum_flags = buf->ol_flags & PKT_TX_L4_MASK; > const uint64_t inner_ip = > buf->ol_flags & (PKT_TX_IPV4 | PKT_TX_IPV6); @@ -663,8 > +663,8 @@ txq_mbuf_to_swp(struct mlx5_txq_data *txq, struct rte_mbuf > *buf, > uint16_t idx; > uint16_t off; > > - if (likely(!tunnel || !txq->swp_en || > - (tunnel != PKT_TX_TUNNEL_UDP && tunnel != > PKT_TX_TUNNEL_IP))) > + if (likely(!txq->swp_en || (tunnel != PKT_TX_TUNNEL_UDP && > + tunnel != PKT_TX_TUNNEL_IP))) > return; > /* > * The index should have: > @@ -684,7 +684,7 @@ txq_mbuf_to_swp(struct mlx5_txq_data *txq, struct > rte_mbuf *buf, > * in if any of SWP offsets is set. Therefore, all of the L3 offsets > * should be set regardless of HW offload. > */ > - off = buf->outer_l2_len + (vlan ? 4 : 0); > + off = buf->outer_l2_len + (vlan ? sizeof(struct vlan_hdr) : 0); > offsets[1] = off >> 1; /* Outer L3 offset. */ > if (tunnel == PKT_TX_TUNNEL_UDP) { > off += buf->outer_l3_len; > @@ -693,7 +693,7 @@ txq_mbuf_to_swp(struct mlx5_txq_data *txq, struct > rte_mbuf *buf, > if (inner_ip) { > off += buf->l2_len; > offsets[3] = off >> 1; /* Inner L3 offset. */ > - if (csum_flags == PKT_TX_TCP_CKSUM || tso || > + if (csum_flags == PKT_TX_TCP_CKSUM || Why are you removing the tso? Per my understanding application can set only the PKT_TX_TCP_SEG for TSO and this implies TCP checksum. > csum_flags == PKT_TX_UDP_CKSUM) { > off += buf->l3_len; > offsets[2] = off >> 1; /* Inner L4 offset. */ > -- > 2.11.0

