From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-10.0 required=3.0 tests=DKIM_SIGNED,DKIM_VALID, HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_PATCH,MAILING_LIST_MULTI,SIGNED_OFF_BY, SPF_HELO_NONE,SPF_PASS,USER_AGENT_GIT autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id AA405C48BDC for ; Sun, 7 Jul 2019 14:02:22 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by mail.kernel.org (Postfix) with ESMTP id 7A94A2082F for ; Sun, 7 Jul 2019 14:02:22 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (2048-bit key) header.d=netronome-com.20150623.gappssmtp.com header.i=@netronome-com.20150623.gappssmtp.com header.b="SRfNeuqX" Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726792AbfGGOCT (ORCPT ); Sun, 7 Jul 2019 10:02:19 -0400 Received: from mail-ed1-f65.google.com ([209.85.208.65]:37366 "EHLO mail-ed1-f65.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726005AbfGGOCT (ORCPT ); Sun, 7 Jul 2019 10:02:19 -0400 Received: by mail-ed1-f65.google.com with SMTP id w13so12181178eds.4 for ; Sun, 07 Jul 2019 07:02:17 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=netronome-com.20150623.gappssmtp.com; s=20150623; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=qrrSE2sr4fMjyTJHINO5enXhpmzvWiVFpDqTTc4FYas=; b=SRfNeuqXKKcTDrkpPCqrBrlgGC+1Ulv2ZdpChy61Bae9EkOTN0kd63oHw+CCla8zEX h/onMXE4bz1f4mdkkwEIPqtX41PvEUXgQsv+BJ3IddjGlLwBF7cpQBO4+ImWfSAg/ET/ F/nFI/o/eQvJlFXPiZ5Jlafk+zGnPVMJbmLTQzkKYXqOhaMZSmLqby8tzuGLT/cBjyVJ mpve8UFyZp+T6/q8R4RqjQeahq+QnHx2MYZEgU9EhXhiXgAhXsSdP1E1B2kvWwAt5okz Htv926gO5J03WUR7OP4PEROvuG+d8hcw53TPSbK6r8LCVZ1VM3QD6pw28wcZ7owr7FPe 2yWA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references; bh=qrrSE2sr4fMjyTJHINO5enXhpmzvWiVFpDqTTc4FYas=; b=nLFzL+ZQDoUdBHjOETUIumCmUZ0RPTWiXWFQaLUvqUA37ae+jsDyrmWfaj/Bw+RucV vPDhu3xGHRHVLpWnPDVeIlmcg56K8MdW5UI/f3nYU8O9pREs5OQ/rvwq5tx3RfSOokka euA/FlXCQC0ykURAJ55xD6D08sMtZ/ozOSgdL3Oa3E3zqrTbZa2tM0h5Z0luh7Yvij24 AZ3xs3s86ixuWlyQc1ICP65XjBzD7t6FejhHzqp3rSxSofsVIqjOPU9Hjl8qE2dtQZrL 4OMuZCMrljVb1XDbBCpnKoOorKBKCcsQzjFQi36S/qNcBC9eUEMxALJ1GJmKL5mZZoCs pQ4Q== X-Gm-Message-State: APjAAAVMPI4gait0gahbHBB4f6k+2UZhCJPOX6KI9FqjFhyXTRy2W4F4 Y5G3RcHCdZT6FytLcw12HAokQQT98zo= X-Google-Smtp-Source: APXvYqwKi3Pp2rZNfTqZVls/WHJpWrxxjd4ZJc16Kp19XDiBjKtp0RNs/WesdzfVdGcqWu4jsNlFOw== X-Received: by 2002:a50:883b:: with SMTP id b56mr14913183edb.178.1562508136623; Sun, 07 Jul 2019 07:02:16 -0700 (PDT) Received: from jhurley-Precision-Tower-3420.netronome.com ([80.76.204.157]) by smtp.gmail.com with ESMTPSA id t2sm4673327eda.95.2019.07.07.07.02.15 (version=TLS1_2 cipher=ECDHE-RSA-AES128-SHA bits=128/128); Sun, 07 Jul 2019 07:02:16 -0700 (PDT) From: John Hurley To: netdev@vger.kernel.org Cc: davem@davemloft.net, jiri@mellanox.com, xiyou.wangcong@gmail.com, dsahern@gmail.com, willemdebruijn.kernel@gmail.com, dcaratti@redhat.com, mrv@mojatatu.com, simon.horman@netronome.com, jakub.kicinski@netronome.com, oss-drivers@netronome.com, John Hurley Subject: [PATCH net-next v7 2/5] net: core: move pop MPLS functionality from OvS to core helper Date: Sun, 7 Jul 2019 15:01:55 +0100 Message-Id: <1562508118-28841-3-git-send-email-john.hurley@netronome.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1562508118-28841-1-git-send-email-john.hurley@netronome.com> References: <1562508118-28841-1-git-send-email-john.hurley@netronome.com> Sender: netdev-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: netdev@vger.kernel.org Open vSwitch provides code to pop an MPLS header to a packet. In preparation for supporting this in TC, move the pop code to an skb helper that can be reused. Remove the, now unused, update_ethertype static function from OvS. Signed-off-by: John Hurley Reviewed-by: Jakub Kicinski Reviewed-by: Simon Horman Reviewed-by: Willem de Bruijn Acked-by: Cong Wang --- include/linux/skbuff.h | 1 + net/core/skbuff.c | 42 ++++++++++++++++++++++++++++++++++++++++++ net/openvswitch/actions.c | 37 ++----------------------------------- 3 files changed, 45 insertions(+), 35 deletions(-) diff --git a/include/linux/skbuff.h b/include/linux/skbuff.h index 10387d0..88b34fe 100644 --- a/include/linux/skbuff.h +++ b/include/linux/skbuff.h @@ -3447,6 +3447,7 @@ int __skb_vlan_pop(struct sk_buff *skb, u16 *vlan_tci); int skb_vlan_pop(struct sk_buff *skb); int skb_vlan_push(struct sk_buff *skb, __be16 vlan_proto, u16 vlan_tci); int skb_mpls_push(struct sk_buff *skb, __be32 mpls_lse, __be16 mpls_proto); +int skb_mpls_pop(struct sk_buff *skb, __be16 next_proto); struct sk_buff *pskb_extract(struct sk_buff *skb, int off, int to_copy, gfp_t gfp); diff --git a/net/core/skbuff.c b/net/core/skbuff.c index f1d1e47..ce30989 100644 --- a/net/core/skbuff.c +++ b/net/core/skbuff.c @@ -5391,6 +5391,48 @@ int skb_mpls_push(struct sk_buff *skb, __be32 mpls_lse, __be16 mpls_proto) EXPORT_SYMBOL_GPL(skb_mpls_push); /** + * skb_mpls_pop() - pop the outermost MPLS header + * + * @skb: buffer + * @next_proto: ethertype of header after popped MPLS header + * + * Expects skb->data at mac header. + * + * Returns 0 on success, -errno otherwise. + */ +int skb_mpls_pop(struct sk_buff *skb, __be16 next_proto) +{ + int err; + + if (unlikely(!eth_p_mpls(skb->protocol))) + return -EINVAL; + + err = skb_ensure_writable(skb, skb->mac_len + MPLS_HLEN); + if (unlikely(err)) + return err; + + skb_postpull_rcsum(skb, mpls_hdr(skb), MPLS_HLEN); + memmove(skb_mac_header(skb) + MPLS_HLEN, skb_mac_header(skb), + skb->mac_len); + + __skb_pull(skb, MPLS_HLEN); + skb_reset_mac_header(skb); + skb_set_network_header(skb, skb->mac_len); + + if (skb->dev && skb->dev->type == ARPHRD_ETHER) { + struct ethhdr *hdr; + + /* use mpls_hdr() to get ethertype to account for VLANs. */ + hdr = (struct ethhdr *)((void *)mpls_hdr(skb) - ETH_HLEN); + skb_mod_eth_type(skb, hdr, next_proto); + } + skb->protocol = next_proto; + + return 0; +} +EXPORT_SYMBOL_GPL(skb_mpls_pop); + +/** * alloc_skb_with_frags - allocate skb with page frags * * @header_len: size of linear part diff --git a/net/openvswitch/actions.c b/net/openvswitch/actions.c index a9a6c9c..62715bb 100644 --- a/net/openvswitch/actions.c +++ b/net/openvswitch/actions.c @@ -160,18 +160,6 @@ static int do_execute_actions(struct datapath *dp, struct sk_buff *skb, struct sw_flow_key *key, const struct nlattr *attr, int len); -static void update_ethertype(struct sk_buff *skb, struct ethhdr *hdr, - __be16 ethertype) -{ - if (skb->ip_summed == CHECKSUM_COMPLETE) { - __be16 diff[] = { ~(hdr->h_proto), ethertype }; - - skb->csum = csum_partial((char *)diff, sizeof(diff), skb->csum); - } - - hdr->h_proto = ethertype; -} - static int push_mpls(struct sk_buff *skb, struct sw_flow_key *key, const struct ovs_action_push_mpls *mpls) { @@ -190,31 +178,10 @@ static int pop_mpls(struct sk_buff *skb, struct sw_flow_key *key, { int err; - err = skb_ensure_writable(skb, skb->mac_len + MPLS_HLEN); - if (unlikely(err)) + err = skb_mpls_pop(skb, ethertype); + if (err) return err; - skb_postpull_rcsum(skb, mpls_hdr(skb), MPLS_HLEN); - - memmove(skb_mac_header(skb) + MPLS_HLEN, skb_mac_header(skb), - skb->mac_len); - - __skb_pull(skb, MPLS_HLEN); - skb_reset_mac_header(skb); - skb_set_network_header(skb, skb->mac_len); - - if (ovs_key_mac_proto(key) == MAC_PROTO_ETHERNET) { - struct ethhdr *hdr; - - /* mpls_hdr() is used to locate the ethertype field correctly in the - * presence of VLAN tags. - */ - hdr = (struct ethhdr *)((void *)mpls_hdr(skb) - ETH_HLEN); - update_ethertype(skb, hdr, ethertype); - } - if (eth_p_mpls(skb->protocol)) - skb->protocol = ethertype; - invalidate_flow_key(key); return 0; } -- 2.7.4