Received: by 2002:a05:6a10:9e8c:0:0:0:0 with SMTP id y12csp263340pxx; Thu, 29 Oct 2020 01:54:51 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzArworGnF9curBUYfgs1BNjt5G90vLq3MNgy2FsS89F12vw3TiUM8WFProqpmZbgKgC7mC X-Received: by 2002:a17:906:c0c4:: with SMTP id bn4mr2966476ejb.27.1603961690961; Thu, 29 Oct 2020 01:54:50 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1603961690; cv=none; d=google.com; s=arc-20160816; b=L4SGGuiaT2QLDrcZ/Ji5DOcr9d6Sk2ChfRTtZPCaKv3WDfNkqKCmX6+HtLNMGdpKK/ tk4kxzAf7xpONLxP8jJH1QOGpswBUbzMb/dqQyi1dFBP19/o3419gCmGM+Vm6Az0ynMq lSyb893Z2q4v6B0xiXiRPafZoauDKmPrISyWf11QG8HdS2rnXpQPr+id5V/gA9LOqQO7 RxgieDlj9ljzLH5mBgrCfzcZkvo9g4+U0Sa6EaRFmc+PJ7BCkalL029xl5IoUIh0g/Ol 4ul4sRHIA/1Wc7HNrrUlt3lfU2oB7pcNkLO4d5MUCd1pSgsIAAxlY4Qm0fSDZwBtt6Yz WcvA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:user-agent:in-reply-to:content-disposition :mime-version:references:reply-to:message-id:subject:cc:to:from:date :dkim-signature; bh=xm5rpPPHhkM92PCF51aKgfyOzaUp3BU/UyuhJwJMsJQ=; b=RW+Swvt6sLtSGRioBQOz3c3K+BEqk+gLP7JzC3O3f0Tgd9nVdpqod9FccJzfvt5/oc 68nd+uzxAlPhSINAkmjw/Z03vcVqdo15Q3FWOX+ODSOY6WuU0bXPysYbSvMj8+6tExZv C3H9g1yixh35Jck7yn6lN1AjKKB52hUOD7cMfF6nNxsCwP42BhqwIwwH+1yVEcVvOvxg AnOothiNYHCLksgWDnABAEBSCgmMafg2vXb648WD8PJk6uaKhJetYSuxTKDQnccSCuuQ rgZ3ykNa32W1ElkUi9FoMTdHNbevZxp0Ydy0yT7hVGlwjF/UB+GoX9Qx8kbgFvatQcmy aLRA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=loooxR5X; 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=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id f12si1252847ejd.458.2020.10.29.01.54.29; Thu, 29 Oct 2020 01:54:50 -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=@kernel.org header.s=default header.b=loooxR5X; 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=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729083AbgJ2CLW (ORCPT + 99 others); Wed, 28 Oct 2020 22:11:22 -0400 Received: from mail.kernel.org ([198.145.29.99]:35446 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726934AbgJ1VhX (ORCPT ); Wed, 28 Oct 2020 17:37:23 -0400 Received: from paulmck-ThinkPad-P72.home (50-39-104-11.bvtn.or.frontiernet.net [50.39.104.11]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id F04F624827; Wed, 28 Oct 2020 20:59:22 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1603918763; bh=uhOhRHxQVfGw7MyAyAJTdGF3H9kCy/1BltY5AjTtSN0=; h=Date:From:To:Cc:Subject:Reply-To:References:In-Reply-To:From; b=loooxR5XyCI1oAjmIJHBwJpYv3LJvTxBzAr3RNF9wwefMD6/PYs7CotHJqnLyHWfP iJWhdiBHD8kIx56QNV6L8kXzavPKJe0TMhRs3XZhpvdyH+xqG7bUw64lnu5IOM7ejT MMYu3qltUG0hDSkGZwhklk03zwVcULaE3bL3uyxI= Received: by paulmck-ThinkPad-P72.home (Postfix, from userid 1000) id A1C2935229CE; Wed, 28 Oct 2020 13:59:22 -0700 (PDT) Date: Wed, 28 Oct 2020 13:59:22 -0700 From: "Paul E. McKenney" To: Qian Cai Cc: Peter Zijlstra , Michael Ellerman , Benjamin Herrenschmidt , Paul Mackerras , linuxppc-dev@lists.ozlabs.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH] powerpc/smp: Move rcu_cpu_starting() earlier Message-ID: <20201028205922.GF3249@paulmck-ThinkPad-P72> Reply-To: paulmck@kernel.org References: <20201028182334.13466-1-cai@redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20201028182334.13466-1-cai@redhat.com> User-Agent: Mutt/1.9.4 (2018-02-28) Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, Oct 28, 2020 at 02:23:34PM -0400, Qian Cai wrote: > The call to rcu_cpu_starting() in start_secondary() is not early enough > in the CPU-hotplug onlining process, which results in lockdep splats as > follows: > > WARNING: suspicious RCU usage > ----------------------------- > kernel/locking/lockdep.c:3497 RCU-list traversed in non-reader section!! > > other info that might help us debug this: > > RCU used illegally from offline CPU! > rcu_scheduler_active = 1, debug_locks = 1 > no locks held by swapper/1/0. > > Call Trace: > dump_stack+0xec/0x144 (unreliable) > lockdep_rcu_suspicious+0x128/0x14c > __lock_acquire+0x1060/0x1c60 > lock_acquire+0x140/0x5f0 > _raw_spin_lock_irqsave+0x64/0xb0 > clockevents_register_device+0x74/0x270 > register_decrementer_clockevent+0x94/0x110 > start_secondary+0x134/0x800 > start_secondary_prolog+0x10/0x14 > > This is avoided by moving the call to rcu_cpu_starting up near the > beginning of the start_secondary() function. Note that the > raw_smp_processor_id() is required in order to avoid calling into > lockdep before RCU has declared the CPU to be watched for readers. > > Link: https://lore.kernel.org/lkml/160223032121.7002.1269740091547117869.tip-bot2@tip-bot2/ > Signed-off-by: Qian Cai Acked-by: Paul E. McKenney > --- > arch/powerpc/kernel/smp.c | 3 ++- > 1 file changed, 2 insertions(+), 1 deletion(-) > > diff --git a/arch/powerpc/kernel/smp.c b/arch/powerpc/kernel/smp.c > index 3c6b9822f978..8c2857cbd960 100644 > --- a/arch/powerpc/kernel/smp.c > +++ b/arch/powerpc/kernel/smp.c > @@ -1393,13 +1393,14 @@ static void add_cpu_to_masks(int cpu) > /* Activate a secondary processor. */ > void start_secondary(void *unused) > { > - unsigned int cpu = smp_processor_id(); > + unsigned int cpu = raw_smp_processor_id(); > > mmgrab(&init_mm); > current->active_mm = &init_mm; > > smp_store_cpu_info(cpu); > set_dec(tb_ticks_per_jiffy); > + rcu_cpu_starting(cpu); > preempt_disable(); > cpu_callin_map[cpu] = 1; > > -- > 2.28.0 >