Received: by 2002:ac0:a5b6:0:0:0:0:0 with SMTP id m51-v6csp1841971imm; Sat, 2 Jun 2018 10:15:35 -0700 (PDT) X-Google-Smtp-Source: ADUXVKISsmG3urcdsK66w1MTLUom7aSnBaT2x5SquubnEbcgkZWEU7/riyErq69a8cY7wRCte4QB X-Received: by 2002:a17:902:f83:: with SMTP id 3-v6mr15413982plz.336.1527959735317; Sat, 02 Jun 2018 10:15:35 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1527959735; cv=none; d=google.com; s=arc-20160816; b=IdIdmDvZK7ujtZk8CUmGxwGhxy2Q41LOVkHnC0PiENh8r7g6plfJ1927a68qpqIYdu rWHOonaaeGUBXWGimrFks0wdbBFL4zGhqwHFZGzXB866htQUZca9HoJKylwWswLLs57X wwTp7KSnBaSUXrW/almEYE+izYQb5KmaI5VODciWACoYKzIFfouzG3I/Jxvlrm7bReq+ 0xEcx0G+jz8WK16tdgkmXIi5mDyp0CcYg2df1QJF0HsFHIZpQAT9d0+kKjkYLlCvV/9N 3hmfK9aFxaD7NgWS+1+t5Dl1V8mssuleQ5pdYicVhwdT96YIHQqfTtTqx5K4TEhKkY2T Xyyg== 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:subject:cc:to:from:date :arc-authentication-results; bh=EVq74EeFmIE01ETEY6kYIDpoWKv0Sm8nXBtEjCn5r+0=; b=E45dReP5fU6qPHTIzbGyzBMMxgY508Rhr5jpDm4/krZHcR0QfzScOMReq/zr+3SNlG /tLHFb+wRxbNhB6ywlnWvaJIQeopdzRbQpbJsqT7nLzDNnuVnVFOUe+7XB2uF4hFn26o PsgCYoI1zfC3svG10nQm0l1E4E7IbLjHA9w/lmhAsO3DsPNcnZ/gtuLFNT8jrqtLNcVG 8LRbCTxuiQB35s3b8HC9Zjh9GvtzoYU0HNsjsZkNghL5kp1TmbYEvQmtlLFm/jyuHchn 0IyLwNaNQawLinUt9S+G1UQkTvvRu1wM/bSMcspUcNgYjddqcpbCGT2JkRX/P5p9L0ry EDQA== ARC-Authentication-Results: i=1; mx.google.com; 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 x1-v6si42050346plb.8.2018.06.02.10.15.07; Sat, 02 Jun 2018 10:15:35 -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; 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 S1751838AbeFBRO3 (ORCPT + 99 others); Sat, 2 Jun 2018 13:14:29 -0400 Received: from mail.kernel.org ([198.145.29.99]:54942 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751653AbeFBRO1 (ORCPT ); Sat, 2 Jun 2018 13:14:27 -0400 Received: from vmware.local.home (unknown [216.9.110.8]) (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 2495220844; Sat, 2 Jun 2018 17:14:26 +0000 (UTC) Date: Sat, 2 Jun 2018 13:14:24 -0400 From: Steven Rostedt To: Joel Fernandes Cc: Joel Fernandes , linux-kernel@vger.kernel.org, Peter Zilstra , Ingo Molnar , Mathieu Desnoyers , Tom Zanussi , Namhyung Kim , Thomas Glexiner , Boqun Feng , Paul McKenney , Frederic Weisbecker , Randy Dunlap , Masami Hiramatsu , Fenguang Wu , Baohong Liu , Vedang Patel , stable@vger.kernel.org Subject: Re: [PATCH] softirq: reorder trace_softirqs_on to prevent lockdep splat Message-ID: <20180602131424.3e4b3f0f@vmware.local.home> In-Reply-To: <20180601045215.GA168630@joelaf.mtv.corp.google.com> References: <20180502014439.87828-1-joelaf@google.com> <20180507142117.35310ff2@gandalf.local.home> <20180601045215.GA168630@joelaf.mtv.corp.google.com> X-Mailer: Claws Mail 3.15.1 (GTK+ 2.24.32; x86_64-pc-linux-gnu) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, 31 May 2018 21:52:15 -0700 Joel Fernandes wrote: > On Mon, May 07, 2018 at 02:21:17PM -0400, Steven Rostedt wrote: > > Peter, Ingo or Thomas, > > > > Can you queue this up? Or would you prefer that I take it? > > This patch is a bug fix, could it be queued for v4.17 -rc cycle or for > linux-next? > > I have also included it below again: Thanks. I can't pull it without an ack as I'm not the softirq maintainer. Thomas, can you just ack it, and I'll take it, if that will be easire for you? -- Steve > > thanks, > > - Joel > > ---8<----------------------- > > From: "Joel Fernandes (Google)" > Date: Tue, 1 May 2018 18:44:39 -0700 > Subject: [PATCH] softirq: reorder trace_softirqs_on to prevent lockdep splat > > 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); > } > > /*