From patchwork Thu May 12 12:36:14 2016 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: "Elo, Matias \(Nokia - FI/Espoo\)" X-Patchwork-Id: 67662 Delivered-To: patch@linaro.org Received: by 10.140.92.199 with SMTP id b65csp731096qge; Thu, 12 May 2016 05:37:07 -0700 (PDT) X-Received: by 10.55.108.7 with SMTP id h7mr9582091qkc.136.1463056626881; Thu, 12 May 2016 05:37:06 -0700 (PDT) Return-Path: Received: from lists.linaro.org (lists.linaro.org. [54.225.227.206]) by mx.google.com with ESMTP id p4si8414252qki.191.2016.05.12.05.37.06; Thu, 12 May 2016 05:37:06 -0700 (PDT) Received-SPF: pass (google.com: domain of lng-odp-bounces@lists.linaro.org designates 54.225.227.206 as permitted sender) client-ip=54.225.227.206; Authentication-Results: mx.google.com; spf=pass (google.com: domain of lng-odp-bounces@lists.linaro.org designates 54.225.227.206 as permitted sender) smtp.mailfrom=lng-odp-bounces@lists.linaro.org; dmarc=fail (p=NONE dis=NONE) header.from=nokia.com Received: by lists.linaro.org (Postfix, from userid 109) id 8AC3061647; Thu, 12 May 2016 12:37:06 +0000 (UTC) X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on ip-10-142-244-252 X-Spam-Level: X-Spam-Status: No, score=-6.9 required=5.0 tests=BAYES_00, RCVD_IN_DNSWL_HI, RCVD_IN_MSPIKE_H3, RCVD_IN_MSPIKE_WL, URIBL_BLOCKED autolearn=disabled version=3.4.0 Received: from [127.0.0.1] (localhost [127.0.0.1]) by lists.linaro.org (Postfix) with ESMTP id 2FF20615E3; Thu, 12 May 2016 12:36:36 +0000 (UTC) X-Original-To: lng-odp@lists.linaro.org Delivered-To: lng-odp@lists.linaro.org Received: by lists.linaro.org (Postfix, from userid 109) id 845A5615E3; Thu, 12 May 2016 12:36:21 +0000 (UTC) Received: from demumfd001.nsn-inter.net (demumfd001.nsn-inter.net [93.183.12.32]) by lists.linaro.org (Postfix) with ESMTPS id 4B8506156A for ; Thu, 12 May 2016 12:36:20 +0000 (UTC) Received: from demuprx016.emea.nsn-intra.net ([10.150.129.55]) by demumfd001.nsn-inter.net (8.15.2/8.15.2) with ESMTPS id u4CCaJAx013832 (version=TLSv1 cipher=DHE-RSA-AES256-SHA bits=256 verify=OK) for ; Thu, 12 May 2016 12:36:19 GMT Received: from 10.144.19.15 ([10.144.104.109]) by demuprx016.emea.nsn-intra.net (8.12.11.20060308/8.12.11) with ESMTP id u4CCaHtr002243 (version=TLSv1/SSLv3 cipher=AES128-SHA bits=128 verify=NO) for ; Thu, 12 May 2016 14:36:18 +0200 From: Matias Elo To: lng-odp@lists.linaro.org Date: Thu, 12 May 2016 15:36:14 +0300 Message-Id: <1463056577-31920-2-git-send-email-matias.elo@nokia.com> X-Mailer: git-send-email 1.9.1 In-Reply-To: <1463056577-31920-1-git-send-email-matias.elo@nokia.com> References: <1463056577-31920-1-git-send-email-matias.elo@nokia.com> X-purgate-type: clean X-purgate-Ad: Categorized by eleven eXpurgate (R) http://www.eleven.de X-purgate: clean X-purgate: This mail is considered clean (visit http://www.eleven.de for further information) X-purgate-size: 4630 X-purgate-ID: 151667::1463056579-00001B3D-47D92AEB/0/0 X-Topics: patch Subject: [lng-odp] [PATCH 1/4] linux-generic: packet: remove l3_protocol and l4_protocol members from odp_packet_hdr_t X-BeenThere: lng-odp@lists.linaro.org X-Mailman-Version: 2.1.16 Precedence: list List-Id: "The OpenDataPlane \(ODP\) List" List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , MIME-Version: 1.0 Errors-To: lng-odp-bounces@lists.linaro.org Sender: "lng-odp" Remove unnecessary struct odp_packet_hdr_t members l3_protocol and l4_protocol to reduce struct size. l4_protocol was only used by IPsec and is now replaced by two new input flags ipsec_ah and ipsec_esp. Signed-off-by: Matias Elo --- platform/linux-generic/include/odp_classification_inlines.h | 7 ++----- platform/linux-generic/include/odp_packet_internal.h | 10 +++++----- platform/linux-generic/odp_packet.c | 9 +++++---- 3 files changed, 12 insertions(+), 14 deletions(-) diff --git a/platform/linux-generic/include/odp_classification_inlines.h b/platform/linux-generic/include/odp_classification_inlines.h index b8b04ce..08300f5 100644 --- a/platform/linux-generic/include/odp_classification_inlines.h +++ b/platform/linux-generic/include/odp_classification_inlines.h @@ -217,16 +217,13 @@ static inline int verify_pmr_ipsec_spi(const uint8_t *pkt_addr, { uint32_t spi; - if (!pkt_hdr->input_flags.ipsec) - return 0; - pkt_addr += pkt_hdr->l4_offset; - if (pkt_hdr->l4_protocol == ODPH_IPPROTO_AH) { + if (pkt_hdr->input_flags.ipsec_ah) { const odph_ahhdr_t *ahhdr = (const odph_ahhdr_t *)pkt_addr; spi = odp_be_to_cpu_32(ahhdr->spi); - } else if (pkt_hdr->l4_protocol == ODPH_IPPROTO_ESP) { + } else if (pkt_hdr->input_flags.ipsec_esp) { const odph_esphdr_t *esphdr = (const odph_esphdr_t *)pkt_addr; spi = odp_be_to_cpu_32(esphdr->spi); diff --git a/platform/linux-generic/include/odp_packet_internal.h b/platform/linux-generic/include/odp_packet_internal.h index 93a92a0..508adf8 100644 --- a/platform/linux-generic/include/odp_packet_internal.h +++ b/platform/linux-generic/include/odp_packet_internal.h @@ -64,8 +64,12 @@ typedef union { uint32_t ip_mcast:1; /**< IP multicast */ uint32_t ipfrag:1; /**< IP fragment */ uint32_t ipopt:1; /**< IP optional headers */ - uint32_t ipsec:1; /**< IPSec decryption may be needed */ + uint32_t ipsec:1; /**< IPSec packet. Required by the + odp_packet_has_ipsec_set() func. */ + uint32_t ipsec_ah:1; /**< IPSec authentication header */ + uint32_t ipsec_esp:1; /**< IPSec encapsulating security + payload */ uint32_t udp:1; /**< UDP */ uint32_t tcp:1; /**< TCP */ uint32_t tcpopt:1; /**< TCP options present */ @@ -141,9 +145,7 @@ typedef struct { uint32_t vlan_s_tag; /**< Parsed 1st VLAN header (S-TAG) */ uint32_t vlan_c_tag; /**< Parsed 2nd VLAN header (C-TAG) */ - uint32_t l3_protocol; /**< Parsed L3 protocol */ uint32_t l3_len; /**< Layer 3 length */ - uint32_t l4_protocol; /**< Parsed L4 protocol */ uint32_t l4_len; /**< Layer 4 length */ uint32_t frame_len; @@ -184,9 +186,7 @@ static inline void copy_packet_parser_metadata(odp_packet_hdr_t *src_hdr, dst_hdr->vlan_s_tag = src_hdr->vlan_s_tag; dst_hdr->vlan_c_tag = src_hdr->vlan_c_tag; - dst_hdr->l3_protocol = src_hdr->l3_protocol; dst_hdr->l3_len = src_hdr->l3_len; - dst_hdr->l4_protocol = src_hdr->l4_protocol; dst_hdr->l4_len = src_hdr->l4_len; } diff --git a/platform/linux-generic/odp_packet.c b/platform/linux-generic/odp_packet.c index b002492..8681c08 100644 --- a/platform/linux-generic/odp_packet.c +++ b/platform/linux-generic/odp_packet.c @@ -44,8 +44,6 @@ void packet_parse_reset(odp_packet_hdr_t *pkt_hdr) pkt_hdr->payload_offset = ODP_PACKET_OFFSET_INVALID; pkt_hdr->vlan_s_tag = 0; pkt_hdr->vlan_c_tag = 0; - pkt_hdr->l3_protocol = 0; - pkt_hdr->l4_protocol = 0; } /** @@ -1242,7 +1240,6 @@ int _odp_parse_common(odp_packet_hdr_t *pkt_hdr, const uint8_t *ptr) /* Set l3_offset+flag only for known ethtypes */ pkt_hdr->input_flags.l3 = 1; pkt_hdr->l3_offset = offset; - pkt_hdr->l3_protocol = ethtype; /* Parse Layer 3 headers */ switch (ethtype) { @@ -1270,7 +1267,6 @@ int _odp_parse_common(odp_packet_hdr_t *pkt_hdr, const uint8_t *ptr) /* Set l4_offset+flag only for known ip_proto */ pkt_hdr->input_flags.l4 = 1; pkt_hdr->l4_offset = offset; - pkt_hdr->l4_protocol = ip_proto; /* Parse Layer 4 headers */ switch (ip_proto) { @@ -1289,8 +1285,13 @@ int _odp_parse_common(odp_packet_hdr_t *pkt_hdr, const uint8_t *ptr) break; case ODPH_IPPROTO_AH: + pkt_hdr->input_flags.ipsec = 1; + pkt_hdr->input_flags.ipsec_ah = 1; + break; + case ODPH_IPPROTO_ESP: pkt_hdr->input_flags.ipsec = 1; + pkt_hdr->input_flags.ipsec_esp = 1; break; default: