On Mon, Nov 14, 2022 at 4:23 PM Rahul Bhansali <rbhans...@marvell.com> wrote: > > Update IPsec handling with reference from UCODE version > OCPT-04-IE-IPSEC-MC-30-01-28-00 > > Signed-off-by: Rahul Bhansali <rbhans...@marvell.com>
Series applied to dpdk-next-net-mrvl/for-next-net. Thanks > --- > drivers/net/cnxk/cn10k_rx.h | 170 ++++++++++++++++++++---------------- > 1 file changed, 95 insertions(+), 75 deletions(-) > > diff --git a/drivers/net/cnxk/cn10k_rx.h b/drivers/net/cnxk/cn10k_rx.h > index 4e22ceda02..ff01c2d8b3 100644 > --- a/drivers/net/cnxk/cn10k_rx.h > +++ b/drivers/net/cnxk/cn10k_rx.h > @@ -42,17 +42,12 @@ > (uint64_t *)(((uintptr_t)((uint64_t *)(b))[i]) - (o)) : > \ > (uint64_t *)(((uintptr_t)(b)) + CQE_SZ(i) - (o))) > > -#define NIX_RX_SEC_UCC_CONST > \ > - ((RTE_MBUF_F_RX_IP_CKSUM_BAD >> 1) << 8 | > \ > - ((RTE_MBUF_F_RX_IP_CKSUM_GOOD | RTE_MBUF_F_RX_L4_CKSUM_GOOD) >> 1) > \ > - << 24 | > \ > - ((RTE_MBUF_F_RX_IP_CKSUM_GOOD | RTE_MBUF_F_RX_L4_CKSUM_BAD) >> 1) > \ > - << 32 | > \ > - ((RTE_MBUF_F_RX_IP_CKSUM_GOOD | RTE_MBUF_F_RX_L4_CKSUM_GOOD) >> 1) > \ > - << 40 | > \ > - ((RTE_MBUF_F_RX_IP_CKSUM_GOOD | RTE_MBUF_F_RX_L4_CKSUM_GOOD) >> 1) > \ > - << 48 | > \ > - (RTE_MBUF_F_RX_IP_CKSUM_GOOD >> 1) << 56) > +#define NIX_RX_SEC_UCC_CONST > \ > + ((RTE_MBUF_F_RX_IP_CKSUM_BAD >> 1) | > \ > + ((RTE_MBUF_F_RX_IP_CKSUM_GOOD | RTE_MBUF_F_RX_L4_CKSUM_GOOD) >> 1) > << 8 | \ > + ((RTE_MBUF_F_RX_IP_CKSUM_GOOD | RTE_MBUF_F_RX_L4_CKSUM_BAD) >> 1) << > 16 | \ > + ((RTE_MBUF_F_RX_IP_CKSUM_GOOD | RTE_MBUF_F_RX_L4_CKSUM_GOOD) >> 1) > << 32 | \ > + ((RTE_MBUF_F_RX_IP_CKSUM_GOOD | RTE_MBUF_F_RX_L4_CKSUM_GOOD) >> 1) > << 48) > > #ifdef RTE_LIBRTE_MEMPOOL_DEBUG > static inline void > @@ -475,16 +470,23 @@ nix_sec_meta_to_mbuf_sc(uint64_t cq_w1, uint64_t cq_w5, > const uint64_t sa_base, > inner->data_len = len; > *(uint64_t *)(&inner->rearm_data) = mbuf_init; > > - inner->ol_flags = ((ucc == CPT_COMP_WARN) ? > + inner->ol_flags = ((CPT_COMP_HWGOOD_MASK & (1U << > ucc)) ? > RTE_MBUF_F_RX_SEC_OFFLOAD : > (RTE_MBUF_F_RX_SEC_OFFLOAD | > > RTE_MBUF_F_RX_SEC_OFFLOAD_FAILED)); > > ucc = hdr->w3.uc_ccode; > - inner->ol_flags |= ((ucc & 0xF0) == 0xF0) ? > - ((NIX_RX_SEC_UCC_CONST >> ((ucc & 0xF) << 3)) > - & 0xFF) << 1 : 0; > - } else if (!(hdr->w0.err_sum) && !(hdr->w0.reas_sts)) { > + > + if (ucc && ucc < 0xED) { > + inner->ol_flags |= > RTE_MBUF_F_RX_SEC_OFFLOAD_FAILED; > + } else { > + ucc += 3; /* To make codes in 0xFx series > except 0 */ > + inner->ol_flags |= ((ucc & 0xF0) == 0xF0) ? > + ((NIX_RX_SEC_UCC_CONST >> > ((ucc & 0xF) << 3)) > + & 0xFF) << 1 : > RTE_MBUF_F_RX_IP_CKSUM_GOOD; > + } > + } else if ((!(hdr->w0.err_sum) || > roc_ie_ot_ucc_is_success(hdr->w3.uc_ccode)) && > + !(hdr->w0.reas_sts)) { > /* Reassembly success */ > inner = nix_sec_reassemble_frags(hdr, cq_w1, cq_w5, > mbuf_init); > @@ -541,15 +543,21 @@ nix_sec_meta_to_mbuf_sc(uint64_t cq_w1, uint64_t cq_w5, > const uint64_t sa_base, > inner->data_len = len; > *(uint64_t *)(&inner->rearm_data) = mbuf_init; > > - inner->ol_flags = ((ucc == CPT_COMP_WARN) ? > + inner->ol_flags = ((CPT_COMP_HWGOOD_MASK & (1U << ucc)) ? > RTE_MBUF_F_RX_SEC_OFFLOAD : > (RTE_MBUF_F_RX_SEC_OFFLOAD | > RTE_MBUF_F_RX_SEC_OFFLOAD_FAILED)); > > ucc = hdr->w3.uc_ccode; > - inner->ol_flags |= ((ucc & 0xF0) == 0xF0) ? > - ((NIX_RX_SEC_UCC_CONST >> ((ucc & 0xF) << 3)) > - & 0xFF) << 1 : 0; > + > + if (ucc && ucc < 0xED) { > + inner->ol_flags |= RTE_MBUF_F_RX_SEC_OFFLOAD_FAILED; > + } else { > + ucc += 3; /* To make codes in 0xFx series except 0 */ > + inner->ol_flags |= ((ucc & 0xF0) == 0xF0) ? > + ((NIX_RX_SEC_UCC_CONST >> ((ucc & > 0xF) << 3)) > + & 0xFF) << 1 : > RTE_MBUF_F_RX_IP_CKSUM_GOOD; > + } > > /* Store meta in lmtline to free > * Assume all meta's from same aura. > @@ -596,7 +604,8 @@ nix_sec_meta_to_mbuf(uint64_t cq_w1, uint64_t cq_w5, > uintptr_t inb_sa, > RTE_MEMPOOL_CHECK_COOKIES(inner->pool, (void **)&inner, 1, 1); > > if (flags & NIX_RX_REAS_F && hdr->w0.num_frags) { > - if (!(hdr->w0.err_sum) && !(hdr->w0.reas_sts)) { > + if ((!(hdr->w0.err_sum) || > roc_ie_ot_ucc_is_success(hdr->w3.uc_ccode)) && > + !(hdr->w0.reas_sts)) { > /* Reassembly success */ > nix_sec_reassemble_frags(hdr, cq_w1, cq_w5, > mbuf_init); > > @@ -1317,6 +1326,7 @@ cn10k_nix_recv_pkts_vector(void *args, struct rte_mbuf > **mbufs, uint16_t pkts, > uintptr_t cpth1 = (uintptr_t)mbuf1 + d_off; > uintptr_t cpth2 = (uintptr_t)mbuf2 + d_off; > uintptr_t cpth3 = (uintptr_t)mbuf3 + d_off; > + uint8_t code; > > uint64x2_t inner0, inner1, inner2, inner3; > uint64x2_t wqe01, wqe23, sa01, sa23; > @@ -1352,42 +1362,46 @@ cn10k_nix_recv_pkts_vector(void *args, struct > rte_mbuf **mbufs, uint16_t pkts, > sa01 = vaddq_u64(sa01, vdupq_n_u64(sa_base)); > sa23 = vaddq_u64(sa23, vdupq_n_u64(sa_base)); > > - const uint8x16_t tbl = { > - /* ROC_IE_OT_UCC_SUCCESS_SA_SOFTEXP_FIRST */ > - 0, > - /* ROC_IE_OT_UCC_SUCCESS_PKT_IP_BADCSUM */ > - RTE_MBUF_F_RX_IP_CKSUM_BAD >> 1, > - /* ROC_IE_OT_UCC_SUCCESS_SA_SOFTEXP_AGAIN */ > - 0, > - /* ROC_IE_OT_UCC_SUCCESS_PKT_L4_GOODCSUM */ > - (RTE_MBUF_F_RX_IP_CKSUM_GOOD | > - RTE_MBUF_F_RX_L4_CKSUM_GOOD) >> 1, > - /* ROC_IE_OT_UCC_SUCCESS_PKT_L4_BADCSUM */ > - (RTE_MBUF_F_RX_IP_CKSUM_GOOD | > - RTE_MBUF_F_RX_L4_CKSUM_BAD) >> 1, > - /* ROC_IE_OT_UCC_SUCCESS_PKT_UDPESP_NZCSUM */ > - (RTE_MBUF_F_RX_IP_CKSUM_GOOD | > - RTE_MBUF_F_RX_L4_CKSUM_GOOD) >> 1, > - /* ROC_IE_OT_UCC_SUCCESS_PKT_UDP_ZEROCSUM */ > - (RTE_MBUF_F_RX_IP_CKSUM_GOOD | > - RTE_MBUF_F_RX_L4_CKSUM_GOOD) >> 1, > - /* ROC_IE_OT_UCC_SUCCESS_PKT_IP_GOODCSUM */ > - RTE_MBUF_F_RX_IP_CKSUM_GOOD >> 1, > - /* HW_CCODE -> > RTE_MBUF_F_RX_SEC_OFFLOAD_FAILED */ > - 1, 0, 1, 1, 1, 1, 0, 1, > - }; > - > - const int8x8_t err_off = { > - /* UCC of significance starts from 0xF0 */ > - 0xF0, > - /* Move HW_CCODE from 0:6 -> 8:14 */ > - -8, > - 0xF0, > - -8, > - 0xF0, > - -8, > - 0xF0, > - -8, > + const uint8x16x2_t tbl = {{ > + { > + /* > ROC_IE_OT_UCC_SUCCESS_PKT_IP_BADCSUM */ > + RTE_MBUF_F_RX_IP_CKSUM_BAD >> 1, > + /* > ROC_IE_OT_UCC_SUCCESS_PKT_L4_GOODCSUM */ > + (RTE_MBUF_F_RX_IP_CKSUM_GOOD | > + RTE_MBUF_F_RX_L4_CKSUM_GOOD) >> 1, > + /* > ROC_IE_OT_UCC_SUCCESS_PKT_L4_BADCSUM */ > + (RTE_MBUF_F_RX_IP_CKSUM_GOOD | > + RTE_MBUF_F_RX_L4_CKSUM_BAD) >> 1, > + 1, > + /* > ROC_IE_OT_UCC_SUCCESS_PKT_UDPESP_NZCSUM */ > + (RTE_MBUF_F_RX_IP_CKSUM_GOOD | > + RTE_MBUF_F_RX_L4_CKSUM_GOOD) >> 1, > + 1, > + /* > ROC_IE_OT_UCC_SUCCESS_PKT_UDP_ZEROCSUM */ > + (RTE_MBUF_F_RX_IP_CKSUM_GOOD | > + RTE_MBUF_F_RX_L4_CKSUM_GOOD) >> 1, > + 3, 1, 3, 3, 3, 3, 1, 3, 1, > + }, > + { > + 1, 1, 1, > + /* > ROC_IE_OT_UCC_SUCCESS_PKT_IP_GOODCSUM */ > + RTE_MBUF_F_RX_IP_CKSUM_GOOD >> 1, > + /* Rest 0 to indicate > RTE_MBUF_F_RX_SEC_OFFLOAD_FAILED */ > + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, > + }, > + }}; > + > + const uint8x8_t err_off = { > + /* UCC */ > + 0xED, > + /* HW_CCODE 0:6 -> 7:D */ > + -7, > + 0xED, > + -7, > + 0xED, > + -7, > + 0xED, > + -7, > }; > > ucc = vdup_n_u8(0); > @@ -1395,8 +1409,13 @@ cn10k_nix_recv_pkts_vector(void *args, struct rte_mbuf > **mbufs, uint16_t pkts, > ucc = vset_lane_u16(*(uint16_t *)(cpth1 + 30), ucc, > 1); > ucc = vset_lane_u16(*(uint16_t *)(cpth2 + 30), ucc, > 2); > ucc = vset_lane_u16(*(uint16_t *)(cpth3 + 30), ucc, > 3); > - ucc = vsub_s8(ucc, err_off); > - ucc = vqtbl1_u8(tbl, ucc); > + ucc = vsub_u8(ucc, err_off); > + > + /* Table lookup to get the corresponding flags, Out > of the range > + * from this lookup will have value 0 and consider as > + * RTE_MBUF_F_RX_SEC_OFFLOAD_FAILED. > + */ > + ucc = vqtbl2_u8(tbl, ucc); > > RTE_BUILD_BUG_ON(NPC_LT_LC_IP != 2); > RTE_BUILD_BUG_ON(NPC_LT_LC_IP_OPT != 3); > @@ -1478,10 +1497,11 @@ cn10k_nix_recv_pkts_vector(void *args, struct > rte_mbuf **mbufs, uint16_t pkts, > nix_sec_meta_to_mbuf(cq0_w1, cq0_w5, sa, > cpth0, > mbuf0, &f0, &ol_flags0, > flags, &rearm0); > - ol_flags0 |= ((uint64_t)vget_lane_u8(ucc, 0)) > - << 1; > - ol_flags0 |= (RTE_MBUF_F_RX_SEC_OFFLOAD | > - (uint64_t)vget_lane_u8(ucc, 1) << 19); > + code = vget_lane_u8(ucc, 0); > + ol_flags0 |= code ? (code > 1 ? > ((uint64_t)code) << 1 : 0) : > + > RTE_MBUF_F_RX_SEC_OFFLOAD_FAILED; > + > + ol_flags0 |= ((uint64_t)(vget_lane_u8(ucc, > 1)) << 18); > } > > if (cq1_w1 & BIT(11)) { > @@ -1502,10 +1522,10 @@ cn10k_nix_recv_pkts_vector(void *args, struct > rte_mbuf **mbufs, uint16_t pkts, > nix_sec_meta_to_mbuf(cq1_w1, cq1_w5, sa, > cpth1, > mbuf1, &f1, &ol_flags1, > flags, &rearm1); > - ol_flags1 |= ((uint64_t)vget_lane_u8(ucc, 2)) > - << 1; > - ol_flags1 |= (RTE_MBUF_F_RX_SEC_OFFLOAD | > - (uint64_t)vget_lane_u8(ucc, 3) << 19); > + code = vget_lane_u8(ucc, 2); > + ol_flags1 |= code ? (code > 1 ? > ((uint64_t)code) << 1 : 0) : > + > RTE_MBUF_F_RX_SEC_OFFLOAD_FAILED; > + ol_flags1 |= ((uint64_t)(vget_lane_u8(ucc, > 3)) << 18); > } > > if (cq2_w1 & BIT(11)) { > @@ -1526,10 +1546,10 @@ cn10k_nix_recv_pkts_vector(void *args, struct > rte_mbuf **mbufs, uint16_t pkts, > nix_sec_meta_to_mbuf(cq2_w1, cq2_w5, sa, > cpth2, > mbuf2, &f2, &ol_flags2, > flags, &rearm2); > - ol_flags2 |= ((uint64_t)vget_lane_u8(ucc, 4)) > - << 1; > - ol_flags2 |= (RTE_MBUF_F_RX_SEC_OFFLOAD | > - (uint64_t)vget_lane_u8(ucc, 5) << 19); > + code = vget_lane_u8(ucc, 4); > + ol_flags2 |= code ? (code > 1 ? > ((uint64_t)code) << 1 : 0) : > + > RTE_MBUF_F_RX_SEC_OFFLOAD_FAILED; > + ol_flags2 |= ((uint64_t)(vget_lane_u8(ucc, > 5)) << 18); > } > > if (cq3_w1 & BIT(11)) { > @@ -1550,10 +1570,10 @@ cn10k_nix_recv_pkts_vector(void *args, struct > rte_mbuf **mbufs, uint16_t pkts, > nix_sec_meta_to_mbuf(cq3_w1, cq3_w5, sa, > cpth3, > mbuf3, &f3, &ol_flags3, > flags, &rearm3); > - ol_flags3 |= ((uint64_t)vget_lane_u8(ucc, 6)) > - << 1; > - ol_flags3 |= (RTE_MBUF_F_RX_SEC_OFFLOAD | > - (uint64_t)vget_lane_u8(ucc, 7) << 19); > + code = vget_lane_u8(ucc, 6); > + ol_flags3 |= code ? (code > 1 ? > ((uint64_t)code) << 1 : 0) : > + > RTE_MBUF_F_RX_SEC_OFFLOAD_FAILED; > + ol_flags3 |= ((uint64_t)(vget_lane_u8(ucc, > 7)) << 18); > } > } > > -- > 2.25.1 >