DPDK patches and discussions
 help / color / mirror / Atom feed
From: Jijiang Liu <jijiang.liu@intel.com>
To: dev@dpdk.org
Subject: [dpdk-dev] [PATCH 1/4] rte_mbuf:add packet types
Date: Tue, 18 Nov 2014 15:37:28 +0800	[thread overview]
Message-ID: <1416296251-7534-2-git-send-email-jijiang.liu@intel.com> (raw)
In-Reply-To: <1416296251-7534-1-git-send-email-jijiang.liu@intel.com>

This patch abstracts packet types of L2 packet, Non Tunneled IPv4/6, IP in IP, IP in GRE, MAC in GRE and MAC in UDP, and add 4 MACROS to check packet IP header.

Signed-off-by: Jijiang Liu <jijiang.liu@intel.com>
---
 lib/librte_mbuf/rte_mbuf.h |  223 ++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 223 insertions(+), 0 deletions(-)

diff --git a/lib/librte_mbuf/rte_mbuf.h b/lib/librte_mbuf/rte_mbuf.h
index f5f8658..678db0d 100644
--- a/lib/librte_mbuf/rte_mbuf.h
+++ b/lib/librte_mbuf/rte_mbuf.h
@@ -125,6 +125,229 @@ extern "C" {
  */
 #define PKT_TX_OFFLOAD_MASK (PKT_TX_VLAN_PKT | PKT_TX_IP_CKSUM | PKT_TX_L4_MASK)
 
+/**
+ * Ethernet packet type
+ */
+enum rte_eth_packet_type {
+
+	/* undefined packet type, means HW can't recognise it */
+	RTE_PTYPE_UNDEF = 0,
+
+	/* L2 Packet types */
+	RTE_PTYPE_PAY2,
+	RTE_PTYPE_TimeSync_PAY2, /**< IEEE1588 and 802.1AS */
+	RTE_PTYPE_FIP_PAY2,      /**< FCoE Initiation Protocol */
+	RTE_PTYPE_LLDP_PAY2,     /**< Link Layer Discovery Protocol */
+	RTE_PTYPE_ECP_PAY2,      /**< Edge Control Protocol */
+	RTE_PTYPE_EAPOL_PAY2,
+	/**< IEEE 802.1X Extensible Authentication Protocol over LAN */
+	RTE_PTYPE_ARP,
+	RTE_PTYPE_FCOE_PAY3,
+	RTE_PTYPE_FCOE_FCDATA,
+	RTE_PTYPE_FCOE_FCRDY,
+	RTE_PTYPE_FCOE_FCRSP,
+	RTE_PTYPE_FCOE_FCOTHER,
+	RTE_PTYPE_FCOE_VFT,
+	RTE_PTYPE_FCOE_VFT_FCDATA,
+	RTE_PTYPE_FCOE_VFT_FCRDY,
+	RTE_PTYPE_FCOE_VFT_FCRSP,
+	RTE_PTYPE_FCOE_VFT_FCOTHER,
+
+	/* Non Tunneled IPv4 */
+	RTE_PTYPE_IPv4FRAG,
+	RTE_PTYPE_IPv4,
+	RTE_PTYPE_IPv4_UDP,
+	RTE_PTYPE_IPv4_TCP,
+	RTE_PTYPE_IPv4_SCTP,
+	RTE_PTYPE_IPv4_ICMP,
+
+	/* IP in IP Tunneling (IPv4 --> IPv4) */
+	RTE_PTYPE_IPv4_IPv4FRAG,
+	RTE_PTYPE_IPv4_IPv4,
+	RTE_PTYPE_IPv4_IPv4_UDP,
+	RTE_PTYPE_IPv4_IPv4_TCP,
+	RTE_PTYPE_IPv4_IPv4_SCTP,
+	RTE_PTYPE_IPv4_IPv4_ICMP,
+
+	/* IP in IP Tunneling (IPv4 --> IPv6) */
+	RTE_PTYPE_IPv4_IPv6FRAG,
+	RTE_PTYPE_IPv4_IPv6,
+	RTE_PTYPE_IPv4_IPv6_UDP,
+	RTE_PTYPE_IPv4_IPv6_TCP,
+	RTE_PTYPE_IPv4_IPv6_SCTP,
+	RTE_PTYPE_IPv4_IPv6_ICMP,
+
+	/* IPv4 --> GRE/Teredo/VXLAN */
+	RTE_PTYPE_IPv4_GRENAT_PAY3,
+
+	/* IPv4 --> GRE/Teredo/VXLAN --> IPv4 */
+	RTE_PTYPE_IPv4_GRENAT_IPv4FRAG,
+	RTE_PTYPE_IPv4_GRENAT_IPv4,
+	RTE_PTYPE_IPv4_GRENAT_IPv4_UDP,
+	RTE_PTYPE_IPv4_GRENAT_IPv4_TCP,
+	RTE_PTYPE_IPv4_GRENAT_IPv4_SCTP,
+	RTE_PTYPE_IPv4_GRENAT_IPv4_ICMP,
+
+	/* IPv4 --> GRE/Teredo/VXLAN --> IPv6 */
+	RTE_PTYPE_IPv4_GRENAT_IPv6FRAG,
+	RTE_PTYPE_IPv4_GRENAT_IPv6,
+	RTE_PTYPE_IPv4_GRENAT_IPv6_UDP,
+	RTE_PTYPE_IPv4_GRENAT_IPv6_TCP,
+	RTE_PTYPE_IPv4_GRENAT_IPv6_SCTP,
+	RTE_PTYPE_IPv4_GRENAT_IPv6_ICMP,
+
+	/* IPv4 --> GRE/Teredo/VXLAN --> MAC */
+	RTE_PTYPE_IPv4_GRENAT_MAC_PAY3,
+
+	/* IPv4 --> GRE/Teredo/VXLAN --> MAC --> IPv4 */
+	RTE_PTYPE_IPv4_GRENAT_MAC_IPv4FRAG,
+	RTE_PTYPE_IPv4_GRENAT_MAC_IPv4,
+	RTE_PTYPE_IPv4_GRENAT_MAC_IPv4_UDP,
+	RTE_PTYPE_IPv4_GRENAT_MAC_IPv4_TCP,
+	RTE_PTYPE_IPv4_GRENAT_MAC_IPv4_SCTP,
+	RTE_PTYPE_IPv4_GRENAT_MAC_IPv4_ICMP,
+
+	/* IPv4 --> GRE/Teredo/VXLAN --> MAC --> IPv6 */
+	RTE_PTYPE_IPv4_GRENAT_MAC_IPv6FRAG,
+	RTE_PTYPE_IPv4_GRENAT_MAC_IPv6,
+	RTE_PTYPE_IPv4_GRENAT_MAC_IPv6_UDP,
+	RTE_PTYPE_IPv4_GRENAT_MAC_IPv6_TCP,
+	RTE_PTYPE_IPv4_GRENAT_MAC_IPv6_SCTP,
+	RTE_PTYPE_IPv4_GRENAT_MAC_IPv6_ICMP,
+
+	/* IPv4 --> GRE/Teredo/VXLAN --> MAC/VLAN */
+	RTE_PTYPE_IPv4_GRENAT_MACVLAN_PAY3,
+
+	/* IPv4 --> GRE/Teredo/VXLAN --> MAC/VLAN --> IPv4 */
+	RTE_PTYPE_IPv4_GRENAT_MACVLAN_IPv4FRAG,
+	RTE_PTYPE_IPv4_GRENAT_MACVLAN_IPv4,
+	RTE_PTYPE_IPv4_GRENAT_MACVLAN_IPv4_UDP,
+	RTE_PTYPE_IPv4_GRENAT_MACVLAN_IPv4_TCP,
+	RTE_PTYPE_IPv4_GRENAT_MACVLAN_IPv4_SCTP,
+	RTE_PTYPE_IPv4_GRENAT_MACVLAN_IPv4_ICMP,
+
+	/* IPv4 --> GRE/Teredo/VXLAN --> MAC/VLAN --> IPv6 */
+	RTE_PTYPE_IPv4_GRENAT_MACVLAN_IPv6FRAG,
+	RTE_PTYPE_IPv4_GRENAT_MACVLAN_IPv6,
+	RTE_PTYPE_IPv4_GRENAT_MACVLAN_IPv6_UDP,
+	RTE_PTYPE_IPv4_GRENAT_MACVLAN_IPv6_TCP,
+	RTE_PTYPE_IPv4_GRENAT_MACVLAN_IPv6_SCTP,
+	RTE_PTYPE_IPv4_GRENAT_MACVLAN_IPv6_ICMP,
+
+	/* Non Tunneled IPv6 */
+	RTE_PTYPE_IPv6FRAG,
+	RTE_PTYPE_IPv6,
+	RTE_PTYPE_IPv6_UDP,
+	RTE_PTYPE_IPv6_TCP,
+	RTE_PTYPE_IPv6_SCTP,
+	RTE_PTYPE_IPv6_ICMP,
+
+	/* IP in IP Tunneling (IPv6 --> IPv4) */
+	RTE_PTYPE_IPv6_IPv4FRAG,
+	RTE_PTYPE_IPv6_IPv4,
+	RTE_PTYPE_IPv6_IPv4_UDP,
+	RTE_PTYPE_IPv6_IPv4_TCP,
+	RTE_PTYPE_IPv6_IPv4_SCTP,
+	RTE_PTYPE_IPv6_IPv4_ICMP,
+
+	/* IP in IP Tunneling (IPv6 --> IPv6) */
+	RTE_PTYPE_IPv6_IPv6FRAG,
+	RTE_PTYPE_IPv6_IPv6,
+	RTE_PTYPE_IPv6_IPv6_UDP,
+	RTE_PTYPE_IPv6_IPv6_TCP,
+	RTE_PTYPE_IPv6_IPv6_SCTP,
+	RTE_PTYPE_IPv6_IPv6_ICMP,
+
+	/* IPv6 --> GRE/Teredo/VXLAN */
+	RTE_PTYPE_IPv6_GRENAT_PAY3,
+
+	/* IPv6 --> GRE/Teredo/VXLAN --> IPv4 */
+	RTE_PTYPE_IPv6_GRENAT_IPv4FRAG,
+	RTE_PTYPE_IPv6_GRENAT_IPv4,
+	RTE_PTYPE_IPv6_GRENAT_IPv4_UDP,
+	RTE_PTYPE_IPv6_GRENAT_IPv4_TCP,
+	RTE_PTYPE_IPv6_GRENAT_IPv4_SCTP,
+	RTE_PTYPE_IPv6_GRENAT_IPv4_ICMP,
+
+	/* IPv6 --> GRE/Teredo/VXLAN --> IPv6 */
+	RTE_PTYPE_IPv6_GRENAT_IPv6FRAG,
+	RTE_PTYPE_IPv6_GRENAT_IPv6,
+	RTE_PTYPE_IPv6_GRENAT_IPv6_UDP,
+	RTE_PTYPE_IPv6_GRENAT_IPv6_TCP,
+	RTE_PTYPE_IPv6_GRENAT_IPv6_SCTP,
+	RTE_PTYPE_IPv6_GRENAT_IPv6_ICMP,
+
+	/* IPv6 --> GRE/Teredo/VXLAN --> MAC */
+	RTE_PTYPE_IPv6_GRENAT_MAC_PAY3,
+
+	/* IPv6 --> GRE/Teredo/VXLAN --> MAC --> IPv4 */
+	RTE_PTYPE_IPv6_GRENAT_MAC_IPv4FRAG,
+	RTE_PTYPE_IPv6_GRENAT_MAC_IPv4,
+	RTE_PTYPE_IPv6_GRENAT_MAC_IPv4_UDP,
+	RTE_PTYPE_IPv6_GRENAT_MAC_IPv4_TCP,
+	RTE_PTYPE_IPv6_GRENAT_MAC_IPv4_SCTP,
+	RTE_PTYPE_IPv6_GRENAT_MAC_IPv4_ICMP,
+
+	/* IPv6 --> GRE/Teredo/VXLAN --> MAC --> IPv6 */
+	RTE_PTYPE_IPv6_GRENAT_MAC_IPv6FRAG,
+	RTE_PTYPE_IPv6_GRENAT_MAC_IPv6,
+	RTE_PTYPE_IPv6_GRENAT_MAC_IPv6_UDP,
+	RTE_PTYPE_IPv6_GRENAT_MAC_IPv6_TCP,
+	RTE_PTYPE_IPv6_GRENAT_MAC_IPv6_SCTP,
+	RTE_PTYPE_IPv6_GRENAT_MAC_IPv6_ICMP,
+
+	/* IPv6 --> GRE/Teredo/VXLAN --> MAC/VLAN */
+	RTE_PTYPE_IPv6_GRENAT_MACVLAN_PAY3,
+
+	/* IPv6 --> GRE/Teredo/VXLAN --> MAC/VLAN --> IPv4 */
+	RTE_PTYPE_IPv6_GRENAT_MACVLAN_IPv4FRAG,
+	RTE_PTYPE_IPv6_GRENAT_MACVLAN_IPv4,
+	RTE_PTYPE_IPv6_GRENAT_MACVLAN_IPv4_UDP,
+	RTE_PTYPE_IPv6_GRENAT_MACVLAN_IPv4_TCP,
+	RTE_PTYPE_IPv6_GRENAT_MACVLAN_IPv4_SCTP,
+	RTE_PTYPE_IPv6_GRENAT_MACVLAN_IPv4_ICMP,
+
+	/* IPv6 --> GRE/Teredo/VXLAN --> MAC/VLAN --> IPv6 */
+	RTE_PTYPE_IPv6_GRENAT_MACVLAN_IPv6FRAG,
+	RTE_PTYPE_IPv6_GRENAT_MACVLAN_IPv6,
+	RTE_PTYPE_IPv6_GRENAT_MACVLAN_IPv6_UDP,
+	RTE_PTYPE_IPv6_GRENAT_MACVLAN_IPv6_TCP,
+	RTE_PTYPE_IPv6_GRENAT_MACVLAN_IPv6_SCTP,
+	RTE_PTYPE_IPv6_GRENAT_MACVLAN_IPv6_ICMP,
+};
+
+/**
+ * Given the packet type returns if it is a packet with IPv4 header,
+ * which includes IPv4 tunneling.
+ */
+#define RTE_ETH_IS_IPV4_HDR(ptype) \
+	((ptype >= RTE_PTYPE_IPv4FRAG) && \
+	(ptype <= RTE_PTYPE_IPv4_GRENAT_MACVLAN_IPv6_ICMP))
+
+/**
+ * Given the packet type returns if it is a tunneling packet
+ * with IPv4 header.
+ */
+#define RTE_ETH_IS_TUNNEL_IPV4_HDR(ptype) \
+	((ptype >= RTE_PTYPE_IPv4FRAG) && \
+	(ptype <= RTE_PTYPE_IPv4_GRENAT_MACVLAN_IPv6_ICMP))
+
+/**
+ * Given the packet type returns if it is a packet with IPv6 header,
+ * which includes IPv6 tunneling.
+ */
+#define RTE_ETH_IS_IPV6_HDR(ptype) \
+	((ptype >= RTE_PTYPE_IPv6FRAG) && \
+	(ptype <= RTE_PTYPE_IPv6_GRENAT_MACVLAN_IPv6_ICMP))
+
+/**
+ * Given the packet type returns if it is a tunneling packet with
+ * IPv6 header
+ */
+#define RTE_ETH_IS_TUNNEL_IPV6_HDR(ptype) \
+	((ptype >= RTE_PTYPE_IPv6_IPv4FRAG) && \
+	(ptype <= RTE_PTYPE_IPv6_GRENAT_MACVLAN_IPv6_ICMP))
+
 /* define a set of marker types that can be used to refer to set points in the
  * mbuf */
 typedef void    *MARKER[0];   /**< generic marker for a point in a structure */
-- 
1.7.7.6

  reply	other threads:[~2014-11-18  7:27 UTC|newest]

Thread overview: 17+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2014-11-18  7:37 [dpdk-dev] [PATCH 0/4] Translate packet types for i40e Jijiang Liu
2014-11-18  7:37 ` Jijiang Liu [this message]
2014-11-19 10:38   ` [dpdk-dev] [PATCH 1/4] rte_mbuf:add packet types Olivier MATZ
2014-11-21 12:26     ` Liu, Jijiang
2014-11-21 13:25       ` Olivier MATZ
2014-11-18  7:37 ` [dpdk-dev] [PATCH 2/4] rte_mbuf:remove tunneling IP offload flags Jijiang Liu
2014-11-18  7:37 ` [dpdk-dev] [PATCH 3/4] i40e:translate i40e packet types Jijiang Liu
2014-11-18  7:37 ` [dpdk-dev] [PATCH 4/4] testpmd:application changes Jijiang Liu
2014-11-18 11:33 ` [dpdk-dev] [PATCH 0/4] Translate packet types for i40e Ananyev, Konstantin
2014-11-18 13:08   ` Bruce Richardson
2014-11-18 15:29     ` Ananyev, Konstantin
2014-11-19  3:52       ` Liu, Jijiang
2014-11-19  9:47         ` Ananyev, Konstantin
2014-11-18 14:12   ` Zhang, Helin
2014-11-18 15:26     ` Ananyev, Konstantin
2014-11-18 15:55       ` Ananyev, Konstantin
2014-11-19  0:29       ` Zhang, Helin

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=1416296251-7534-2-git-send-email-jijiang.liu@intel.com \
    --to=jijiang.liu@intel.com \
    --cc=dev@dpdk.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).