Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp530003ybt; Fri, 19 Jun 2020 07:35:20 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxB1GLi18N7vdHzyHLeCRtI3yOdU9nsUsmWCK3fNOh+IKoa+YvxUcG2Cimw6Ug3BqfCedDZ X-Received: by 2002:a17:906:4c46:: with SMTP id d6mr3532998ejw.503.1592577320575; Fri, 19 Jun 2020 07:35:20 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1592577320; cv=none; d=google.com; s=arc-20160816; b=hFISaEyF/Cnk5Z5lrKsc1lWxYnjySJwkdhRZNGLuYuI4YyhM1cej2y+b3vLNFglIpz TGag16NRncTMYaqmNnhsBWRUAV0MTaNb4J2R7J2B9au0xn81PEtZ6w5Pt9cchuDZgzR+ K5i8OMYRZ6PyqJDY8uohiF7CbKbnBRSSC7IkDaAjp6wfbjANipIo8VoMDdYqlxHX4M0g NjbAqAJsjJsUEBtDJAeDGF0ehZ/rRB9QLXW4dQIdETvXVZyz0qjUQqfjRnGFNj3fOvrG nqirrq8X427ClNbmeEmQYsA3IISY4v1ebDXDeVSVvGToYMSSdifzT3Ng068XDlImaqgs rW9Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=mZRjN4QhW5X6YfR7Z2yjjbULaODEXfUST0bMuVtU8r4=; b=0Ln+oNv34SevAQYfPTxigwC++iLXmQvbo0YAOX9qdRpWNeMPvjnTcTkggF5RWSnS8M 766reTLuNmlUWJdURvqm6yLr/Tg8sCUWjJ+hcFh7A8LobIOCJl4uKP+Vltj0m4FPsCPV gz4j1LyoZ0kx9ELdz7fw9Zfe9gFdHRhVmlWekDVGVoLGbQYQkCfIs+f7oPKnvZSoL+8b O9fL4pHNDYl6o0XxZm/pJ8uei1FH6ZVn7/HMLO8Bgf/upa4nnUC3NqiZBzaXULvZuBo7 ku43Rjf4vd5LdDixHM174pT4rTdD9fMnRw0DRldMDZIVYMkx8UFBcCS73q7awjtSLdgJ lTqg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=ZTIEmzsM; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id g8si4476988edn.160.2020.06.19.07.34.57; Fri, 19 Jun 2020 07:35:20 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=ZTIEmzsM; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1733247AbgFSOcc (ORCPT + 99 others); Fri, 19 Jun 2020 10:32:32 -0400 Received: from us-smtp-1.mimecast.com ([205.139.110.61]:58381 "EHLO us-smtp-delivery-1.mimecast.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1733230AbgFSOca (ORCPT ); Fri, 19 Jun 2020 10:32:30 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1592577149; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=mZRjN4QhW5X6YfR7Z2yjjbULaODEXfUST0bMuVtU8r4=; b=ZTIEmzsMICzOLsBifUmq+B47Og54x9mLUZO3yhtnR/hJC6CHqNsgjgupjQXOcGhndQvIJA ehGgezAWrcnHs6sPs8uJ66Owl5BCk/WWZOiZcZZjumoK8aVjbzPEYDxctcZMZu6764Fchs 33S99oVFiGHjXUQJjeDFNfvrAqhRc9w= Received: from mimecast-mx01.redhat.com (mimecast-mx01.redhat.com [209.132.183.4]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-514-87YmsNg-PGaQebLN2eIXmw-1; Fri, 19 Jun 2020 10:32:16 -0400 X-MC-Unique: 87YmsNg-PGaQebLN2eIXmw-1 Received: from smtp.corp.redhat.com (int-mx03.intmail.prod.int.phx2.redhat.com [10.5.11.13]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx01.redhat.com (Postfix) with ESMTPS id 4076D18FF660; Fri, 19 Jun 2020 14:32:14 +0000 (UTC) Received: from hp-dl360pgen8-07.khw2.lab.eng.bos.redhat.com (hp-dl360pgen8-07.khw2.lab.eng.bos.redhat.com [10.16.210.135]) by smtp.corp.redhat.com (Postfix) with ESMTP id B35AB7CABA; Fri, 19 Jun 2020 14:32:12 +0000 (UTC) From: Jarod Wilson To: linux-kernel@vger.kernel.org Cc: Jarod Wilson , Jay Vosburgh , Veaceslav Falico , Andy Gospodarek , "David S. Miller" , Jeff Kirsher , Jakub Kicinski , Steffen Klassert , Herbert Xu , netdev@vger.kernel.org, intel-wired-lan@lists.osuosl.org Subject: [PATCH net-next v3 1/4] xfrm: bail early on slave pass over skb Date: Fri, 19 Jun 2020 10:31:52 -0400 Message-Id: <20200619143155.20726-2-jarod@redhat.com> In-Reply-To: <20200619143155.20726-1-jarod@redhat.com> References: <20200619143155.20726-1-jarod@redhat.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Scanned-By: MIMEDefang 2.79 on 10.5.11.13 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This is prep work for initial support of bonding hardware encryption pass-through support. The bonding driver will fill in the slave_dev pointer, and we use that to know not to skb_push() again on a given skb that was already processed on the bond device. CC: Jay Vosburgh CC: Veaceslav Falico CC: Andy Gospodarek CC: "David S. Miller" CC: Jeff Kirsher CC: Jakub Kicinski CC: Steffen Klassert CC: Herbert Xu CC: netdev@vger.kernel.org CC: intel-wired-lan@lists.osuosl.org Signed-off-by: Jarod Wilson --- include/net/xfrm.h | 1 + net/xfrm/xfrm_device.c | 34 +++++++++++++++++----------------- 2 files changed, 18 insertions(+), 17 deletions(-) diff --git a/include/net/xfrm.h b/include/net/xfrm.h index 094fe682f5d7..e20b2b27ec48 100644 --- a/include/net/xfrm.h +++ b/include/net/xfrm.h @@ -127,6 +127,7 @@ struct xfrm_state_walk { struct xfrm_state_offload { struct net_device *dev; + struct net_device *slave_dev; unsigned long offload_handle; unsigned int num_exthdrs; u8 flags; diff --git a/net/xfrm/xfrm_device.c b/net/xfrm/xfrm_device.c index f50d1f97cf8e..b8918fc5248b 100644 --- a/net/xfrm/xfrm_device.c +++ b/net/xfrm/xfrm_device.c @@ -106,6 +106,7 @@ struct sk_buff *validate_xmit_xfrm(struct sk_buff *skb, netdev_features_t featur struct sk_buff *skb2, *nskb, *pskb = NULL; netdev_features_t esp_features = features; struct xfrm_offload *xo = xfrm_offload(skb); + struct net_device *dev = skb->dev; struct sec_path *sp; if (!xo) @@ -119,6 +120,10 @@ struct sk_buff *validate_xmit_xfrm(struct sk_buff *skb, netdev_features_t featur if (xo->flags & XFRM_GRO || x->xso.flags & XFRM_OFFLOAD_INBOUND) return skb; + /* This skb was already validated on the master dev */ + if ((x->xso.dev != dev) && (x->xso.slave_dev == dev)) + return skb; + local_irq_save(flags); sd = this_cpu_ptr(&softnet_data); err = !skb_queue_empty(&sd->xfrm_backlog); @@ -129,25 +134,20 @@ struct sk_buff *validate_xmit_xfrm(struct sk_buff *skb, netdev_features_t featur return skb; } - if (skb_is_gso(skb)) { - struct net_device *dev = skb->dev; - - if (unlikely(x->xso.dev != dev)) { - struct sk_buff *segs; + if (skb_is_gso(skb) && unlikely(x->xso.dev != dev)) { + struct sk_buff *segs; - /* Packet got rerouted, fixup features and segment it. */ - esp_features = esp_features & ~(NETIF_F_HW_ESP - | NETIF_F_GSO_ESP); + /* Packet got rerouted, fixup features and segment it. */ + esp_features = esp_features & ~(NETIF_F_HW_ESP | NETIF_F_GSO_ESP); - segs = skb_gso_segment(skb, esp_features); - if (IS_ERR(segs)) { - kfree_skb(skb); - atomic_long_inc(&dev->tx_dropped); - return NULL; - } else { - consume_skb(skb); - skb = segs; - } + segs = skb_gso_segment(skb, esp_features); + if (IS_ERR(segs)) { + kfree_skb(skb); + atomic_long_inc(&dev->tx_dropped); + return NULL; + } else { + consume_skb(skb); + skb = segs; } } -- 2.20.1