From: Matthew Smith Date: Mon, 18 Dec 2017 20:19:07 +0000 (-0600) Subject: Patch ENA PMD to skip setting tx flags in rx path X-Git-Tag: v18.04-rc1~512 X-Git-Url: https://gerrit.fd.io/r/gitweb?a=commitdiff_plain;h=a5fb2cf8be8298e589c2b619f7e907a0a1d76262;p=vpp.git Patch ENA PMD to skip setting tx flags in rx path On rx, the ENA PMD sets tx offload flags based on the received packet's l4 protocol. This means you need to turn off those offloads for every packet if you encapsulate packets arriving on an interface using that PMD. Disable this behavior. Change-Id: Icae9f32e3d292d767da440ae5c1280902bdaa083 Signed-off-by: Matthew Smith --- diff --git a/dpdk/dpdk-17.11_patches/0001-ena-pmd-no-tx-flags.patch b/dpdk/dpdk-17.11_patches/0001-ena-pmd-no-tx-flags.patch new file mode 100644 index 00000000000..97dbadd1aa8 --- /dev/null +++ b/dpdk/dpdk-17.11_patches/0001-ena-pmd-no-tx-flags.patch @@ -0,0 +1,21 @@ +diff --git a/drivers/net/ena/ena_ethdev.c b/drivers/net/ena/ena_ethdev.c +index 22db895..6f982f6 100644 +--- a/drivers/net/ena/ena_ethdev.c ++++ b/drivers/net/ena/ena_ethdev.c +@@ -261,16 +261,6 @@ static inline void ena_rx_mbuf_prepare(struct rte_mbuf *mbuf, + { + uint64_t ol_flags = 0; + +- if (ena_rx_ctx->l4_proto == ENA_ETH_IO_L4_PROTO_TCP) +- ol_flags |= PKT_TX_TCP_CKSUM; +- else if (ena_rx_ctx->l4_proto == ENA_ETH_IO_L4_PROTO_UDP) +- ol_flags |= PKT_TX_UDP_CKSUM; +- +- if (ena_rx_ctx->l3_proto == ENA_ETH_IO_L3_PROTO_IPV4) +- ol_flags |= PKT_TX_IPV4; +- else if (ena_rx_ctx->l3_proto == ENA_ETH_IO_L3_PROTO_IPV6) +- ol_flags |= PKT_TX_IPV6; +- + if (unlikely(ena_rx_ctx->l4_csum_err)) + ol_flags |= PKT_RX_L4_CKSUM_BAD; + if (unlikely(ena_rx_ctx->l3_csum_err)) diff --git a/src/plugins/dpdk/device/format.c b/src/plugins/dpdk/device/format.c index 8ea65c12ce2..d9ee2bd2b83 100644 --- a/src/plugins/dpdk/device/format.c +++ b/src/plugins/dpdk/device/format.c @@ -726,7 +726,7 @@ format_dpdk_rte_mbuf (u8 * s, va_list * va) u32 indent = format_get_indent (s) + 2; s = format (s, "PKT MBUF: port %d, nb_segs %d, pkt_len %d" - "\n%Ubuf_len %d, data_len %d, ol_flags 0x%x, data_off %d, phys_addr 0x%x" + "\n%Ubuf_len %d, data_len %d, ol_flags 0x%lx, data_off %d, phys_addr 0x%x" "\n%Upacket_type 0x%x l2_len %u l3_len %u outer_l2_len %u outer_l3_len %u", mb->port, mb->nb_segs, mb->pkt_len, format_white_space, indent,