Received: by 2002:ac0:a594:0:0:0:0:0 with SMTP id m20-v6csp1521261imm; Wed, 23 May 2018 18:25:19 -0700 (PDT) X-Google-Smtp-Source: AB8JxZqR3Z2ZXj/BeAqbS3aQ4k/vUagnhXputo75dvC0HncaHpIiYU6oGcWds2PRugk9q/ZeCztd X-Received: by 2002:a63:b046:: with SMTP id z6-v6mr4017128pgo.16.1527125119674; Wed, 23 May 2018 18:25:19 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1527125119; cv=none; d=google.com; s=arc-20160816; b=VbJbtVxl9P2CApnQzX6gsznhFYTBs3N/IYJdhjT69eaCFkRISVIZwwthyIjaGqs55n t0+7W4lFWedeeLLemTde/fWTjnlttZgiL6+1tkQK9vs1hPca876JYZBfwq//a3GenUqk y0py4LmgKwGutdI1WBBnipalZDmm08MtsdFoY6V8Vtl+xXsYtWGrJlnaKOVa3iP61ovp 3r9xf8hRU+0GzZeNdqfaFeqyoAf8cWQBqArW5JmKMrMf5Zy91j2xtkCmTXE1ln+vNHzs 8qTt1ZdCaFapQoMHx54XdtbkYfMrA4ca3ERpPss3kqqvfQm4N5DQTN3/ktZamPbiSUUw IBcw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature:arc-authentication-results; bh=AEGV6heGcjUpaeyw6p8+XTTxa7HsHy0/1gDIOZxxLL4=; b=HhE5AoQWpWSA7vrMVIxlmV4sGIpdOgLkB5bsFSIlSyPSa0RhSUM0Je1N2d1mv4QA5a z9QU9Uyw4ft+Zch275yEWBe+31fjMjpCHQBdPWygOXPPLewwWp1re6udNtuGLz8/xI+a wx/LSRnQocpZJw+mgNy+9YP2yi9GiMUzxsNIWsHXxnRiRrghfTE5GkLaWBTHkI23Tufz nIiQSugIby63vtEZWCRMGmTlzYmK5FPe8ycfSOAtPJfgWABDZ35XITO1PUFPaxK1dyv8 N2DQ3jqkh3+HT3acg6cCyvB8ikW8WrnM9KcgxuCjw1mgcixjygpFS65wZ+XRejsIOtRI 8ogg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=Kj3Kongc; 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=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id t28-v6si20005706pfi.221.2018.05.23.18.25.05; Wed, 23 May 2018 18:25:19 -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=@google.com header.s=20161025 header.b=Kj3Kongc; 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=REJECT sp=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S935422AbeEXBWd (ORCPT + 99 others); Wed, 23 May 2018 21:22:33 -0400 Received: from mail-pl0-f68.google.com ([209.85.160.68]:44560 "EHLO mail-pl0-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S935333AbeEXBW3 (ORCPT ); Wed, 23 May 2018 21:22:29 -0400 Received: by mail-pl0-f68.google.com with SMTP id m24-v6so2701868pls.11 for ; Wed, 23 May 2018 18:22:28 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=AEGV6heGcjUpaeyw6p8+XTTxa7HsHy0/1gDIOZxxLL4=; b=Kj3KongcPCtBlTybgluhLNJBp7qNq6XTR7FhSfPz9R8iZWczQrEHF9Ll76H3D05eBs H/BX/2sVxsA3QedCN50beaUNT97pKLeVKDEdYzSozPs0+OiCU8oG3h4it9WhFZzXqd1N iwcRXx7S75lFmcn04ZEdBU/9PQy05Tkn1eGotvSgFRzBrNQmPlIwqih0pDLSpk8rgpn9 P2J40c/LUI8GXKaXM0PR5hcf5m2DIUSHA23siTECU4zTJSRBNMhHnxel48q6smm7LBXG 2dN3NOKolJ8uggS1KMTWrdaY6vy8eXGOru26lvr0Ic7jZyGlUofXQMTuievmFH/gO9Zn zsdA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references; bh=AEGV6heGcjUpaeyw6p8+XTTxa7HsHy0/1gDIOZxxLL4=; b=rp1wYPZiINrXDpL7rcQzkg2VO1qze6Qz2bjz+ctNGAGOe/XUb65STiS0giU94wye84 UwlV/WCqiHOfZdmAB5SNSdv9WCLPOKhMJgdOir0a4rggptExw3xp8bo3PcaGL6fH6zO0 8F1wuDGoOs+nWL+oCNtijTm2IvQxYczAb6N1gplWTqu+j4M8I4wpieZhqtdBJYmkgt4g tv81MLlN9Ms2TwBXm0Y7+TfLkwenRx98C8hp2PDUm9tTijHcaml6KLUIL/rOQhwRmAsM RfDSy9hbb3gJPafnLrCJzGxeYMDtTCiEzJZOWEeSbHQjo7dxtBlmyXlhX668JKGG80T2 NYWw== X-Gm-Message-State: ALKqPwd5RYakob30TS2u7ILdpVJ2C+9N2rCpkx4YTsgvaUN4Xme4P6Xe ZWDxT7MKfS9wJwB5R1XnyXfUyaoIyHk= X-Received: by 2002:a17:902:6b09:: with SMTP id o9-v6mr952185plk.256.1527124948081; Wed, 23 May 2018 18:22:28 -0700 (PDT) Received: from joelaf.mtv.corp.google.com ([2620:0:1000:1600:3122:ea9c:d178:eb]) by smtp.gmail.com with ESMTPSA id g15-v6sm26070996pgv.58.2018.05.23.18.22.26 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Wed, 23 May 2018 18:22:27 -0700 (PDT) From: Joel Fernandes X-Google-Original-From: Joel Fernandes To: linux-kernel@vger.kernel.org Cc: kernel-team@android.com, "Joel Fernandes (Google)" , stable@vger.kernel.org, Boqun Feng , Byungchul Park , Erick Reyes , Ingo Molnar , Julia Cartwright , linux-kselftest@vger.kernel.org, Masami Hiramatsu , Mathieu Desnoyers , Namhyung Kim , Paul McKenney , Peter Zijlstra , Shuah Khan , Steven Rostedt , Thomas Glexiner , Todd Kjos , Tom Zanussi Subject: [PATCH v7 1/8] softirq: reorder trace_softirqs_on to prevent lockdep splat Date: Wed, 23 May 2018 18:21:50 -0700 Message-Id: <20180524012157.181277-2-joel@joelfernandes.org> X-Mailer: git-send-email 2.17.0.441.gb46fe60e1d-goog In-Reply-To: <20180524012157.181277-1-joel@joelfernandes.org> References: <20180524012157.181277-1-joel@joelfernandes.org> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: "Joel Fernandes (Google)" I'm able to reproduce a lockdep splat with config options: CONFIG_PROVE_LOCKING=y, CONFIG_DEBUG_LOCK_ALLOC=y and CONFIG_PREEMPTIRQ_EVENTS=y $ echo 1 > /d/tracing/events/preemptirq/preempt_enable/enable [ 26.112609] DEBUG_LOCKS_WARN_ON(current->softirqs_enabled) [ 26.112636] WARNING: CPU: 0 PID: 118 at kernel/locking/lockdep.c:3854 [...] [ 26.144229] Call Trace: [ 26.144926] [ 26.145506] lock_acquire+0x55/0x1b0 [ 26.146499] ? __do_softirq+0x46f/0x4d9 [ 26.147571] ? __do_softirq+0x46f/0x4d9 [ 26.148646] trace_preempt_on+0x8f/0x240 [ 26.149744] ? trace_preempt_on+0x4d/0x240 [ 26.150862] ? __do_softirq+0x46f/0x4d9 [ 26.151930] preempt_count_sub+0x18a/0x1a0 [ 26.152985] __do_softirq+0x46f/0x4d9 [ 26.153937] irq_exit+0x68/0xe0 [ 26.154755] smp_apic_timer_interrupt+0x271/0x280 [ 26.156056] apic_timer_interrupt+0xf/0x20 [ 26.157105] The issue was this: preempt_count = 1 << SOFTIRQ_SHIFT __local_bh_enable(cnt = 1 << SOFTIRQ_SHIFT) { if (softirq_count() == (cnt && SOFTIRQ_MASK)) { trace_softirqs_on() { current->softirqs_enabled = 1; } } preempt_count_sub(cnt) { trace_preempt_on() { tracepoint() { rcu_read_lock_sched() { // jumps into lockdep Where preempt_count still has softirqs disabled, but current->softirqs_enabled is true, and we get a splat. Cc: stable@vger.kernel.org Reviewed-by: Steven Rostedt (VMware) Fixes: d59158162e032 ("tracing: Add support for preempt and irq enable/disable events") Signed-off-by: Joel Fernandes (Google) --- kernel/softirq.c | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/kernel/softirq.c b/kernel/softirq.c index 177de3640c78..8a040bcaa033 100644 --- a/kernel/softirq.c +++ b/kernel/softirq.c @@ -139,9 +139,13 @@ static void __local_bh_enable(unsigned int cnt) { lockdep_assert_irqs_disabled(); + if (preempt_count() == cnt) + trace_preempt_on(CALLER_ADDR0, get_lock_parent_ip()); + if (softirq_count() == (cnt & SOFTIRQ_MASK)) trace_softirqs_on(_RET_IP_); - preempt_count_sub(cnt); + + __preempt_count_sub(cnt); } /* -- 2.17.0.441.gb46fe60e1d-goog