Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp1008719yba; Thu, 4 Apr 2019 02:18:55 -0700 (PDT) X-Google-Smtp-Source: APXvYqxxvpvFj/9p6hguD2eljU1ebjpe3OhImlDOMRX3QN2F2bPUQVqlLhXbgViuM5V0naxzxbaa X-Received: by 2002:a63:c54a:: with SMTP id g10mr4697059pgd.71.1554369535816; Thu, 04 Apr 2019 02:18:55 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1554369535; cv=none; d=google.com; s=arc-20160816; b=qoVQM9/SIMBmIsAfxrAD4iTWDHe8r+GumeHKI9P+s77/4pQbRrOuwEigEJBlO4JnGx nUAs21HRqGF6VW+kaNtWgXuYToNlb2ZLuHO4hksllPqXGiFNp3XPvmcNxr+GeXCFDN0E lAz60F/4eCGj5qGB9isUnmJg7ZJSGG2KNLFvvwmaGzI9mkTXWnpVjg9s26CHv3E1K1Y+ 7yw37513MlIehxExLBEkgxbAJEsUMBeU7JCbGsLPSOqPUW4Cq6GMgenBxbPgecpyqRUR kpCPxBgm4A76J0JFkbM2B/azOawClgDaIZHXN9nJTdGE5Ohp8gG1Pki1Pw5uKRgVoGTg a9KA== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=h/GMuxKJ2egRhs3MhG51tP9qEw4tu5sfka5BaLDhWzs=; b=uA2Ous9Z9MaI1d5SyjozdHGI91zL3mnV2TgpEO8BX+nehbxGZFmn8r7t2vrSH1kKLr 3qaSEyYrU6MftvfoTTgE3QZZBiZrGsj7BN3+agoOet20bllxsEtpIu4CR+0FEgfWLitL BXz7b17HjErBV8TVe6t38IMRB4+OZWp6Xch+zjViB45HhUAhEIGD2tp3yFAYhUUfcAM+ v9QONw0/IPhJsbsYEPNwS02w1x0dV/SJmahVECijYtQqKRgNGFLxgq/UJZ4EnhFp6iGL vyLt+P+pfnDkM9B6ejc8XIpls5mUjlJxDnq0uv4XdVWF02Aax5PXp74dARU+j4J9tzcD PeVg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=mtimH7z+; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id g14si7276495plo.287.2019.04.04.02.18.40; Thu, 04 Apr 2019 02:18:55 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=mtimH7z+; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2388128AbfDDJQ4 (ORCPT + 99 others); Thu, 4 Apr 2019 05:16:56 -0400 Received: from mail.kernel.org ([198.145.29.99]:58190 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2388121AbfDDJQx (ORCPT ); Thu, 4 Apr 2019 05:16:53 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (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 3834120693; Thu, 4 Apr 2019 09:16:52 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1554369412; bh=r5DgWeTdEcF1hOAtTU54is8LPwLqAafydhWJ7i6ef5U=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=mtimH7z+hZOBMB80/eWkKcFp6JAtmXeRKsOKDuobmkctv/Ycjr8OpidI7E6+EUbc+ SyO97vFF3NebuJTczQk/IG1HniBDK4PTbhhM6wBKkRv/gcSVbZAWbBnCHTuNc6KuEw dv8UjvkvDXuWl3/xo3BhgK+8MtXz77sKCMNaIKkU= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Peter Zijlstra , Valentin Schneider , Andrew Morton , Linus Torvalds , "Paul E. McKenney" , Thomas Gleixner , Will Deacon , cai@gmx.us, daniel.lezcano@linaro.org, dietmar.eggemann@arm.com, linux-arm-kernel@lists.infradead.org, longman@redhat.com, marc.zyngier@arm.com, mark.rutland@arm.com, Ingo Molnar , Sasha Levin Subject: [PATCH 5.0 214/246] cpu/hotplug: Mute hotplug lockdep during init Date: Thu, 4 Apr 2019 10:48:34 +0200 Message-Id: <20190404084626.685559617@linuxfoundation.org> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20190404084619.236418459@linuxfoundation.org> References: <20190404084619.236418459@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review X-Patchwork-Hint: ignore MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 5.0-stable review patch. If anyone has any objections, please let me know. ------------------ [ Upstream commit ce48c457b95316b9a01b5aa9d4456ce820df94b4 ] Since we've had: commit cb538267ea1e ("jump_label/lockdep: Assert we hold the hotplug lock for _cpuslocked() operations") we've been getting some lockdep warnings during init, such as on HiKey960: [ 0.820495] WARNING: CPU: 4 PID: 0 at kernel/cpu.c:316 lockdep_assert_cpus_held+0x3c/0x48 [ 0.820498] Modules linked in: [ 0.820509] CPU: 4 PID: 0 Comm: swapper/4 Tainted: G S 4.20.0-rc5-00051-g4cae42a #34 [ 0.820511] Hardware name: HiKey960 (DT) [ 0.820516] pstate: 600001c5 (nZCv dAIF -PAN -UAO) [ 0.820520] pc : lockdep_assert_cpus_held+0x3c/0x48 [ 0.820523] lr : lockdep_assert_cpus_held+0x38/0x48 [ 0.820526] sp : ffff00000a9cbe50 [ 0.820528] x29: ffff00000a9cbe50 x28: 0000000000000000 [ 0.820533] x27: 00008000b69e5000 x26: ffff8000bff4cfe0 [ 0.820537] x25: ffff000008ba69e0 x24: 0000000000000001 [ 0.820541] x23: ffff000008fce000 x22: ffff000008ba70c8 [ 0.820545] x21: 0000000000000001 x20: 0000000000000003 [ 0.820548] x19: ffff00000a35d628 x18: ffffffffffffffff [ 0.820552] x17: 0000000000000000 x16: 0000000000000000 [ 0.820556] x15: ffff00000958f848 x14: 455f3052464d4d34 [ 0.820559] x13: 00000000769dde98 x12: ffff8000bf3f65a8 [ 0.820564] x11: 0000000000000000 x10: ffff00000958f848 [ 0.820567] x9 : ffff000009592000 x8 : ffff00000958f848 [ 0.820571] x7 : ffff00000818ffa0 x6 : 0000000000000000 [ 0.820574] x5 : 0000000000000000 x4 : 0000000000000001 [ 0.820578] x3 : 0000000000000000 x2 : 0000000000000001 [ 0.820582] x1 : 00000000ffffffff x0 : 0000000000000000 [ 0.820587] Call trace: [ 0.820591] lockdep_assert_cpus_held+0x3c/0x48 [ 0.820598] static_key_enable_cpuslocked+0x28/0xd0 [ 0.820606] arch_timer_check_ool_workaround+0xe8/0x228 [ 0.820610] arch_timer_starting_cpu+0xe4/0x2d8 [ 0.820615] cpuhp_invoke_callback+0xe8/0xd08 [ 0.820619] notify_cpu_starting+0x80/0xb8 [ 0.820625] secondary_start_kernel+0x118/0x1d0 We've also had a similar warning in sched_init_smp() for every asymmetric system that would enable the sched_asym_cpucapacity static key, although that was singled out in: commit 40fa3780bac2 ("sched/core: Take the hotplug lock in sched_init_smp()") Those warnings are actually harmless, since we cannot have hotplug operations at the time they appear. Instead of starting to sprinkle useless hotplug lock operations in the init codepaths, mute the warnings until they start warning about real problems. Suggested-by: Peter Zijlstra Signed-off-by: Valentin Schneider Signed-off-by: Peter Zijlstra (Intel) Cc: Andrew Morton Cc: Linus Torvalds Cc: Paul E. McKenney Cc: Thomas Gleixner Cc: Will Deacon Cc: cai@gmx.us Cc: daniel.lezcano@linaro.org Cc: dietmar.eggemann@arm.com Cc: linux-arm-kernel@lists.infradead.org Cc: longman@redhat.com Cc: marc.zyngier@arm.com Cc: mark.rutland@arm.com Link: https://lkml.kernel.org/r/1545243796-23224-2-git-send-email-valentin.schneider@arm.com Signed-off-by: Ingo Molnar Signed-off-by: Sasha Levin --- kernel/cpu.c | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/kernel/cpu.c b/kernel/cpu.c index 47f695d80dd1..6754f3ecfd94 100644 --- a/kernel/cpu.c +++ b/kernel/cpu.c @@ -313,6 +313,15 @@ void cpus_write_unlock(void) void lockdep_assert_cpus_held(void) { + /* + * We can't have hotplug operations before userspace starts running, + * and some init codepaths will knowingly not take the hotplug lock. + * This is all valid, so mute lockdep until it makes sense to report + * unheld locks. + */ + if (system_state < SYSTEM_RUNNING) + return; + percpu_rwsem_assert_held(&cpu_hotplug_lock); } -- 2.19.1