Received: by 2002:ac0:bc90:0:0:0:0:0 with SMTP id a16csp5641242img; Wed, 27 Mar 2019 12:15:47 -0700 (PDT) X-Google-Smtp-Source: APXvYqx7JQhugSd1CqAlYX4CEWch1MCsyoZjIGPtr2PCuLMzdhYGzBOfOKQ8XYGLc01qGDL195RU X-Received: by 2002:a17:902:6b08:: with SMTP id o8mr38932783plk.105.1553714147729; Wed, 27 Mar 2019 12:15:47 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1553714147; cv=none; d=google.com; s=arc-20160816; b=LnWK7wa1bwLmuVzpFosL1A0ZeaXAx5P4MmcURblTtx30qH6BXqiYzdSucZ6g1+4iZN Q6nNPSTrSpvswfzedMLUIqewnqzNl0M5zYKJ8RPqVU+eqFkM1eIgB33nV4CIqzt7s+6a /nwBNHjiwPwfMJcZa6vgTRQ0+Ngz2wwqVavJ6qNVC/shHet8jo93X4xreFfNDtCqZg+A 3PkQ+/MHW+kuIEuLydM+HZXKYaa8yfQnqRbHbGWOsxkCeNjK5E+qSNYA422+CqW8Sed/ JKRG8QcKK3XzzsY2QFJnFlrjmmo1TNlEpiLqzxswo2o1zGfaEH3EGCVXXv54gf8F/vL0 NqQA== 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=H2LRK5EaOs4j8jKeeO2+CtAH0DAkak6YP+VkGgY/rzw=; b=mz+9fhjMc7RuKcDaxt8ONe0UBe1FCAvjepbRfs7k3Tsu7KUCugvKgvZnnnPKKjyVof QpxN0BWVsi0KI3FBFx7ExVAeDAMjUhHtvu2bHIyBREbezCR/RPYmks9ezB26LVK0vXXy JsDBpmyNgOQkkG/LWSCB5Sx/hsImASx5JaYKa3P6e+iud5aej+RKAc5piebaSAK+gWP1 L0OSowDCGgnfxLhwERMLWxuCh24EuEElOPT6c7NQ4w48/Bl1Fw7JMoDbMNvo5Gs9kdsT 59KeAgwTMX7dm4QLKBDn1V+mv8q/zzxbbzCMG7e6gaOmrZRRYfXeZXK0Lyc1UJXfG+TD +fiw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=s7hcGVJh; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id m7si17386363pgg.78.2019.03.27.12.15.32; Wed, 27 Mar 2019 12:15:47 -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=s7hcGVJh; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2387618AbfC0SJb (ORCPT + 99 others); Wed, 27 Mar 2019 14:09:31 -0400 Received: from mail.kernel.org ([198.145.29.99]:51258 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2388564AbfC0SJ1 (ORCPT ); Wed, 27 Mar 2019 14:09:27 -0400 Received: from sasha-vm.mshome.net (c-73-47-72-35.hsd1.nh.comcast.net [73.47.72.35]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 0EAC6217D9; Wed, 27 Mar 2019 18:09:23 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1553710165; bh=8VuFBaLEkf8mdppgFFuBuHokOjCw2Of3H8Zc96e82eQ=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=s7hcGVJhHSeK7LqTBCFm0x1WQLyRRwblnhtZGaYcYYKOKJ5N7C5slwGDIiKK5VUvj cA9Yj64ewr8A65Tf1kTf2xV9EnujGExIQ+87UsHYXLb7RTG86KUjDyN/xhJzcHsh4p AhBMR1dWolaR6auisMjWbHyf80xDssaUXTi5kF4E= From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: Valentin Schneider , Peter Zijlstra , 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 AUTOSEL 5.0 229/262] cpu/hotplug: Mute hotplug lockdep during init Date: Wed, 27 Mar 2019 14:01:24 -0400 Message-Id: <20190327180158.10245-229-sashal@kernel.org> X-Mailer: git-send-email 2.19.1 In-Reply-To: <20190327180158.10245-1-sashal@kernel.org> References: <20190327180158.10245-1-sashal@kernel.org> MIME-Version: 1.0 X-Patchwork-Hint: Ignore Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Valentin Schneider [ 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 d1c6d152da89..025f419d16f6 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