From patchwork Fri Oct 27 14:40:47 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Frederic Weisbecker X-Patchwork-Id: 158974 Return-Path: Delivered-To: ouuuleilei@gmail.com Received: by 2002:a59:d641:0:b0:403:3b70:6f57 with SMTP id cy1csp655525vqb; Fri, 27 Oct 2023 07:43:02 -0700 (PDT) X-Google-Smtp-Source: AGHT+IG+sCyAnXhqYGMMUxkRLH7brJZHqiQLArXk8jJA74kXCvKAZkNVJTKO0RXWd/97oToMinhn X-Received: by 2002:a25:e601:0:b0:da0:3922:d7bb with SMTP id d1-20020a25e601000000b00da03922d7bbmr10553146ybh.17.1698417782448; Fri, 27 Oct 2023 07:43:02 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1698417782; cv=none; d=google.com; s=arc-20160816; b=FdpZHGG9F7kKg+HtjYR6tzndNCa/AOoHb31VeYhCTdSOysUgoUi2wvAS0ZmcS9XuIw GV58NpIDilKMRMCrwX4MqrOgTOC/PoLSyonqWSSFSkmoM7lPueZjUSjTMWaAcbq/mRAf 9EvtcZUEki1FFgFdLDoVjn6XJIGYkhRWaZObGOHuFN6kMRPNmOPLZcyQpSgP5apxjaTh piTKviVozA5m7taVrzLajbrByj7kcF+4FWmIpHPuzz2KmNatneZRROZHHXqWLzvMylBo 08WLovvz60vQxwlCxCZjQUpmI1ar5h2zc5C/9Ba+ntNt2Zd9NpjExqjjTs1kRaaeKWsy gZYg== 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=oPJ6O5eps6NDOQjKmjqdygoO2PHIy2OS60u5mwzHI8s=; fh=Z5RfXUdA7RqZB5lwRaxglRkGuBAkH08O6zmnqH6r62g=; b=L6PmwyCOCsLncI7V+c22LF5XEmZs5VVBo7qMop61C+OWjHfP+sswEIhIFni4I58oqq /nujhBBskQNtvFCxvXP8MUFIH797Lv2RNSfXW8JAB1hZQ5MlK2TsTGI9sw+mqL7MJ6O8 Hph6lqt8k9HRg+kYzY4nh6+5XaFXQl0OWFx7UJV3fggaFYI2srWs3MW5q1IStsrf4KRu RnOsDEAtygiE6hCWiANnsAKow5PgjoObS0AhupfIZB7y7UNmCnFQEhuVt/rODcHeHwV9 W8AcvRTgV0pLEW90/bRcN9pIzVtg04kOaBVwe0LoDSyJeKJ8MmTl5rrfRiJJHoqPYyha /xXw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=FfBAW1p2; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.37 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: from snail.vger.email (snail.vger.email. [23.128.96.37]) by mx.google.com with ESMTPS id 204-20020a2503d5000000b00da1c6c86120si1907004ybd.560.2023.10.27.07.42.56 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 27 Oct 2023 07:43:02 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.37 as permitted sender) client-ip=23.128.96.37; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=FfBAW1p2; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.37 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by snail.vger.email (Postfix) with ESMTP id 17472801B335; Fri, 27 Oct 2023 07:41:16 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at snail.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1345914AbjJ0OlI (ORCPT + 25 others); Fri, 27 Oct 2023 10:41:08 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:51464 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1345868AbjJ0OlF (ORCPT ); Fri, 27 Oct 2023 10:41:05 -0400 Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id C10F0C4; Fri, 27 Oct 2023 07:41:03 -0700 (PDT) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 95924C43395; Fri, 27 Oct 2023 14:41:00 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1698417663; bh=quyhYQ3j6IeBsmp/D+pIjVv3njLC2nvqNbVgvWxgsXw=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=FfBAW1p2HHmIIhCOdMUI7oJ2srPdQzfPdJX8oxj2aZqpMy+fiZbLneWX9qNACJvjl pde4exRsDU0/CsbJjMyjLJM/+HmivjhoJQ/CY3Ti/mGKBN9HwHVkoIa1gPIBw4sQEL QAKlUgdR4LWAOlYyAuCjdLBiyrHI2t6PjVA56/yqzCExU62QzPqFoVPuCU9qLPPc2g tbp4qrhmfu23Mz+TdxTr/psCUXAV7sved5Y82f5Fjoofj+U08uM31AX22BBputrdso FUw1LzcjzzpCVtvMEQN0UtJcZA9kEKqdn8DUPzexWFEK1lvodM4tf6tdTzgv8Ur9nJ vOrbOREDggimQ== From: Frederic Weisbecker To: LKML Cc: Frederic Weisbecker , Boqun Feng , Joel Fernandes , Josh Triplett , Mathieu Desnoyers , Neeraj Upadhyay , "Paul E . McKenney" , Steven Rostedt , Uladzislau Rezki , rcu , Zqiang , "Liam R . Howlett" , Peter Zijlstra Subject: [PATCH 1/4] rcu: Introduce rcu_cpu_online() Date: Fri, 27 Oct 2023 16:40:47 +0200 Message-Id: <20231027144050.110601-2-frederic@kernel.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20231027144050.110601-1-frederic@kernel.org> References: <20231027144050.110601-1-frederic@kernel.org> MIME-Version: 1.0 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_PASS 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 X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (snail.vger.email [0.0.0.0]); Fri, 27 Oct 2023 07:41:17 -0700 (PDT) X-getmail-retrieved-from-mailbox: INBOX X-GMAIL-THRID: 1780920124538465025 X-GMAIL-MSGID: 1780920124538465025 Export the RCU point of view as to when a CPU is considered offline (ie: when does RCU consider that a CPU is sufficiently down in the hotplug process to not feature any possible read side). This will be used by RCU-tasks whose vision of an offline CPU should reasonably match the one of RCU core. Fixes: cff9b2332ab7 ("kernel/sched: Modify initial boot task idle setup") Signed-off-by: Frederic Weisbecker --- kernel/rcu/rcu.h | 2 ++ kernel/rcu/tree.c | 7 +++++++ 2 files changed, 9 insertions(+) diff --git a/kernel/rcu/rcu.h b/kernel/rcu/rcu.h index 0d866eaa4cc8..b531c33e9545 100644 --- a/kernel/rcu/rcu.h +++ b/kernel/rcu/rcu.h @@ -500,6 +500,7 @@ static inline void rcu_expedite_gp(void) { } static inline void rcu_unexpedite_gp(void) { } static inline void rcu_async_hurry(void) { } static inline void rcu_async_relax(void) { } +static inline bool rcu_cpu_online(int cpu) { return true; } #else /* #ifdef CONFIG_TINY_RCU */ bool rcu_gp_is_normal(void); /* Internal RCU use. */ bool rcu_gp_is_expedited(void); /* Internal RCU use. */ @@ -509,6 +510,7 @@ void rcu_unexpedite_gp(void); void rcu_async_hurry(void); void rcu_async_relax(void); void rcupdate_announce_bootup_oddness(void); +bool rcu_cpu_online(int cpu); #ifdef CONFIG_TASKS_RCU_GENERIC void show_rcu_tasks_gp_kthreads(void); #else /* #ifdef CONFIG_TASKS_RCU_GENERIC */ diff --git a/kernel/rcu/tree.c b/kernel/rcu/tree.c index 700524726079..54f04c1aa371 100644 --- a/kernel/rcu/tree.c +++ b/kernel/rcu/tree.c @@ -4202,6 +4202,13 @@ static bool rcu_rdp_cpu_online(struct rcu_data *rdp) return !!(rdp->grpmask & rcu_rnp_online_cpus(rdp->mynode)); } +bool rcu_cpu_online(int cpu) +{ + struct rcu_data *rdp = per_cpu_ptr(&rcu_data, cpu); + + return rcu_rdp_cpu_online(rdp); +} + #if defined(CONFIG_PROVE_RCU) && defined(CONFIG_HOTPLUG_CPU) /*