Received: by 2002:a05:6359:6284:b0:131:369:b2a3 with SMTP id se4csp347340rwb; Fri, 4 Aug 2023 13:51:02 -0700 (PDT) X-Google-Smtp-Source: AGHT+IGcdbauuR3w7cXxrDqZ6cYILOGIixh3e/ZTUi7qT55gdhPYrcTO2jY48DqzeOeLdW24ax8R X-Received: by 2002:a05:6a00:15c4:b0:687:5763:ef27 with SMTP id o4-20020a056a0015c400b006875763ef27mr3236062pfu.33.1691182261878; Fri, 04 Aug 2023 13:51:01 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1691182261; cv=none; d=google.com; s=arc-20160816; b=dB2hmc6BEYfvhATl3Y536I6mdLR8fz2Xo8j8waoRd45gWmd2lwN5rzBQr4v2jawL3m 1Kv1htXzt+yZfgAPqj9sNIg6PzzTeU7jl2PGuGi3SrBxDuIA1fVT1g8pdaLVswNPMWUH 7ku9YYO42xUO6E+K+nkfpB6sOK40g6tDnTYhJS4TL1wAAfwmJ5QYrBiOxEH/jpactHff 36fhP8CkwMfUqWkvkTtnw0+2fp88THlVbHPB+rvUktKI9Kx6ZGTdhoM2BvjUMWjw4oeE gSbsWtbDXyQ6bPkr5kboz3B6/OHYhPWoL6KXowHPA3mH8Ch78trP6KtmWgIgnzyUYKW9 coow== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=xIS//mWivAOAsi3XOjMqfz/h5GTPEmOZ/HPEr4yrQKQ=; fh=3HE1xXs4s0z3NpKSg+MkyPw1+1QpKlxno2HY1HR9bAc=; b=0qgqm58GKV+btT5NxLRuqu6CdbttCnpiQZPQ7t/z4V7wSq2RiWZSpglWAj8BqgS9yN mp8B9xp9yNwme+7lFH+C0N2Eq11MKcmZH2r9PxYi9Ph3BMXa00f5F770Yf98spPmvD/8 4QWac9DT4GGYPkVPkyBZ6mh8qsvoUxHmY00PohFN0Vd8jAZHur4nv5TG3KC4bx+Ug3+J T/cIWF4qUocKfa6OFT5bF8pott/tMR934gFgPXKLPW9xq08okrjyh1pb0iR/piBl4WG5 DidRwxTkEW2InunrulN1jf8IOwBaHAxqz4xIr9qxBMOkPJ8V5anJC4uo0HFLA/hSwxj+ WWNw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b="T2/5HdHv"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id a23-20020a056a001d1700b006824bcb19b5si2106959pfx.4.2023.08.04.13.50.41; Fri, 04 Aug 2023 13:51:01 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b="T2/5HdHv"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230269AbjHDSGp (ORCPT + 99 others); Fri, 4 Aug 2023 14:06:45 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:42396 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230236AbjHDSGg (ORCPT ); Fri, 4 Aug 2023 14:06:36 -0400 Received: from mgamail.intel.com (mgamail.intel.com [134.134.136.31]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id B6E594C3E; Fri, 4 Aug 2023 11:06:25 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1691172385; x=1722708385; h=from:to:cc:subject:date:message-id:in-reply-to: references:mime-version:content-transfer-encoding; bh=yC3uIe0tSBLBI12LM3uJtXCP5bvqTWQRcMrArt23Bjc=; b=T2/5HdHvl8dUerTFVG+DKpuZDxs9zCcEX3JkhRYAXw8V4d2UyPX7im6z zBPXQNm+BUMo1vCguHA1mM8QhQo/dF1bmERnsoLT3TlEtpYzb8qSyFrbd 2kPrAp+7YUukrVW/HrBI+MAYZ4KWXc2bULiAA/b7RpJHAdI/mkBOwAdB6 uj0nBYsRsvbQWZAxBRe9jor0NpSsnbPoWXfCao/alf2Y4Pl/UZeoupe4X nCWE25oHyyavAO6nLpiLYxwrbWHruVAIqzWcpvn5y/TG3k8INXnRWb6oy 1npBqgLnNVyuKVtVi9JnEh72umTR63JbJ5hUvrISTAyxoqrueFc0xr0CU Q==; X-IronPort-AV: E=McAfee;i="6600,9927,10792"; a="434061750" X-IronPort-AV: E=Sophos;i="6.01,255,1684825200"; d="scan'208";a="434061750" Received: from orsmga008.jf.intel.com ([10.7.209.65]) by orsmga104.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 04 Aug 2023 11:06:25 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=McAfee;i="6600,9927,10792"; a="759673608" X-IronPort-AV: E=Sophos;i="6.01,255,1684825200"; d="scan'208";a="759673608" Received: from newjersey.igk.intel.com ([10.102.20.203]) by orsmga008.jf.intel.com with ESMTP; 04 Aug 2023 11:06:22 -0700 From: Alexander Lobakin To: "David S. Miller" , Eric Dumazet , Jakub Kicinski , Paolo Abeni Cc: Alexander Lobakin , Maciej Fijalkowski , Larysa Zaremba , Yunsheng Lin , Alexander Duyck , Jesper Dangaard Brouer , Ilias Apalodimas , Simon Horman , netdev@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH net-next v4 6/6] net: skbuff: always try to recycle PP pages directly when in softirq Date: Fri, 4 Aug 2023 20:05:29 +0200 Message-ID: <20230804180529.2483231-7-aleksander.lobakin@intel.com> X-Mailer: git-send-email 2.41.0 In-Reply-To: <20230804180529.2483231-1-aleksander.lobakin@intel.com> References: <20230804180529.2483231-1-aleksander.lobakin@intel.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF, RCVD_IN_DNSWL_BLOCKED,SPF_HELO_NONE,SPF_NONE,URIBL_BLOCKED autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Commit 8c48eea3adf3 ("page_pool: allow caching from safely localized NAPI") allowed direct recycling of skb pages to their PP for some cases, but unfortunately missed a couple of other majors. For example, %XDP_DROP in skb mode. The netstack just calls kfree_skb(), which unconditionally passes `false` as @napi_safe. Thus, all pages go through ptr_ring and locks, although most of time we're actually inside the NAPI polling this PP is linked with, so that it would be perfectly safe to recycle pages directly. Let's address such. If @napi_safe is true, we're fine, don't change anything for this path. But if it's false, check whether we are in the softirq context. It will most likely be so and then if ->list_owner is our current CPU, we're good to use direct recycling, even though @napi_safe is false -- concurrent access is excluded. in_softirq() protection is needed mostly due to we can hit this place in the process context (not the hardirq though). For the mentioned xdp-drop-skb-mode case, the improvement I got is 3-4% in Mpps. As for page_pool stats, recycle_ring is now 0 and alloc_slow counter doesn't change most of time, which means the MM layer is not even called to allocate any new pages. Suggested-by: Jakub Kicinski # in_softirq() Signed-off-by: Alexander Lobakin --- net/core/skbuff.c | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/net/core/skbuff.c b/net/core/skbuff.c index 85f82a6a08dc..33fdf04d4334 100644 --- a/net/core/skbuff.c +++ b/net/core/skbuff.c @@ -902,8 +902,10 @@ bool napi_pp_put_page(struct page *page, bool napi_safe) /* Allow direct recycle if we have reasons to believe that we are * in the same context as the consumer would run, so there's * no possible race. + * __page_pool_put_page() makes sure we're not in hardirq context + * and interrupts are enabled prior to accessing the cache. */ - if (napi_safe) { + if (napi_safe || in_softirq()) { const struct napi_struct *napi = READ_ONCE(pp->p.napi); allow_direct = napi && -- 2.41.0