diff mbox series

[API-NEXT,v2,1/2] linux-gen: packet: implement packet l3/l4 proto types

Message ID 1518832812-30752-2-git-send-email-odpbot@yandex.ru
State Superseded
Headers show
Series [API-NEXT,v2,1/2] linux-gen: packet: implement packet l3/l4 proto types | expand

Commit Message

Github ODP bot Feb. 17, 2018, 2 a.m. UTC
From: Dmitry Eremin-Solenikov <dmitry.ereminsolenikov@linaro.org>


Signed-off-by: Dmitry Eremin-Solenikov <dmitry.ereminsolenikov@linaro.org>

---
/** Email created from pull request 463 (lumag:packet-types-3)
 ** https://github.com/Linaro/odp/pull/463
 ** Patch: https://github.com/Linaro/odp/pull/463.patch
 ** Base sha: 27328232ed2f01dd70aa431f5fa19bd058014305
 ** Merge commit sha: 3ec0fc44633d6121faf2394ffb88fdfd1867402b
 **/
 platform/linux-generic/odp_packet.c | 38 +++++++++++++++++++++++++++++++++++++
 1 file changed, 38 insertions(+)
diff mbox series

Patch

diff --git a/platform/linux-generic/odp_packet.c b/platform/linux-generic/odp_packet.c
index 82001103b..46b11cba1 100644
--- a/platform/linux-generic/odp_packet.c
+++ b/platform/linux-generic/odp_packet.c
@@ -2505,3 +2505,41 @@  int odp_packet_has_ref(odp_packet_t pkt)
 
 	return 0;
 }
+
+odp_proto_l3_type_t odp_packet_l3_type(odp_packet_t pkt)
+{
+	odp_packet_hdr_t *pkt_hdr = packet_hdr(pkt);
+
+	if (pkt_hdr->p.input_flags.ipv4)
+		return ODP_PROTO_L3_TYPE_IPV4;
+	else if (pkt_hdr->p.input_flags.ipv6)
+		return ODP_PROTO_L3_TYPE_IPV6;
+	else if (pkt_hdr->p.input_flags.arp)
+		return ODP_PROTO_L3_TYPE_ARP;
+
+	return ODP_PROTO_L3_TYPE_NONE;
+}
+
+odp_proto_l4_type_t odp_packet_l4_type(odp_packet_t pkt)
+{
+	odp_packet_hdr_t *pkt_hdr = packet_hdr(pkt);
+
+	if (pkt_hdr->p.input_flags.tcp)
+		return ODP_PROTO_L4_TYPE_TCP;
+	else if (pkt_hdr->p.input_flags.udp)
+		return ODP_PROTO_L4_TYPE_UDP;
+	else if (pkt_hdr->p.input_flags.sctp)
+		return ODP_PROTO_L4_TYPE_SCTP;
+	else if (pkt_hdr->p.input_flags.ipsec_ah)
+		return ODP_PROTO_L4_TYPE_AH;
+	else if (pkt_hdr->p.input_flags.ipsec_esp)
+		return ODP_PROTO_L4_TYPE_ESP;
+	else if (pkt_hdr->p.input_flags.icmp &&
+		 pkt_hdr->p.input_flags.ipv4)
+		return ODP_PROTO_L4_TYPE_ICMPV4;
+	else if (pkt_hdr->p.input_flags.icmp &&
+		 pkt_hdr->p.input_flags.ipv6)
+		return ODP_PROTO_L4_TYPE_ICMPV6;
+
+	return ODP_PROTO_L4_TYPE_NONE;
+}