mbuf: remove packet type from offload flags
[dpdk.git] / examples / tep_termination / vxlan.c
index 34851d8..5ee1f95 100644 (file)
@@ -144,6 +144,11 @@ process_inner_cksums(struct ether_hdr *eth_hdr, union tunnel_offload_info *info)
                ol_flags |= PKT_TX_TCP_CKSUM;
                tcp_hdr->cksum = get_psd_sum(l3_hdr, ethertype,
                                ol_flags);
+               if (tso_segsz != 0) {
+                       ol_flags |= PKT_TX_TCP_SEG;
+                       info->tso_segsz = tso_segsz;
+                       info->l4_len = sizeof(struct tcp_hdr);
+               }
 
        } else if (l4_proto == IPPROTO_SCTP) {
                sctp_hdr = (struct sctp_hdr *)((char *)l3_hdr + info->l3_len);
@@ -175,8 +180,7 @@ decapsulation(struct rte_mbuf *pkt)
         * (rfc7348) or that the rx offload flag is set (i40e only
         * currently)*/
        if (udp_hdr->dst_port != rte_cpu_to_be_16(DEFAULT_VXLAN_PORT) &&
-                       (pkt->ol_flags & (PKT_RX_TUNNEL_IPV4_HDR |
-                               PKT_RX_TUNNEL_IPV6_HDR)) == 0)
+               (pkt->packet_type & RTE_PTYPE_TUNNEL_MASK) == 0)
                return -1;
        outer_header_len = info.outer_l2_len + info.outer_l3_len
                + sizeof(struct udp_hdr) + sizeof(struct vxlan_hdr);
@@ -226,6 +230,7 @@ encapsulation(struct rte_mbuf *m, uint8_t queue_id)
                ol_flags |= process_inner_cksums(phdr, &tx_offload);
                m->l2_len = tx_offload.l2_len;
                m->l3_len = tx_offload.l3_len;
+               m->l4_len = tx_offload.l4_len;
                m->l2_len += ETHER_VXLAN_HLEN;
        }
 
@@ -233,6 +238,7 @@ encapsulation(struct rte_mbuf *m, uint8_t queue_id)
        m->outer_l3_len = sizeof(struct ipv4_hdr);
 
        m->ol_flags |= ol_flags;
+       m->tso_segsz = tx_offload.tso_segsz;
 
        /*VXLAN HEADER*/
        vxlan->vx_flags = rte_cpu_to_be_32(VXLAN_HF_VNI);