Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp3083439imm; Sun, 5 Aug 2018 20:42:07 -0700 (PDT) X-Google-Smtp-Source: AAOMgpfzjYODAXFN1kPk00uj+m4xzKlIkArZVJnmK7JhNoR4M+xRembntRicQESa8QtOxfgSfC34 X-Received: by 2002:a63:a5c:: with SMTP id z28-v6mr12761886pgk.209.1533526927774; Sun, 05 Aug 2018 20:42:07 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1533526927; cv=none; d=google.com; s=arc-20160816; b=kdclcdNBUOG87WSVzd5DOkAspYDO7I/SRcND3MQtVObk+48giV0Y3BKt5C3JlPVvDA ANoJagzm3YCWux7dyeIyeSqzTPCpKLzjP5yiNPdGaO4BLN/wMN3PoJuZquYyxMJiaeb3 xdmZ88Vx6dbalt4HzF769zkeu+8E1GswKb+MbTHMVS9bNc0dt/M04jvPdtvjqZ3cGe9i 2CTzi5P7/v6GJQv1Z9XTLmBEiU7spcwOe4XGXr4vNdoAQfsi77/6/nqZJoBxDDeP4Ncg E++iq4SrZvDyXcOdlCM58Y3MwC+76HnENEyU4eeUARJEFoHg2g6Aip1LoMaVDXlEe+Gh cmfg== 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 :message-id:date:subject:cc:to:from:dkim-signature :arc-authentication-results; bh=JKNwJ5EqUfyx9QUAap7+RzSwtUflqtaLiEiMq3Zrg3o=; b=K1rO8ify31EviDdZi6BFso7tewlXiJs4RKWN2urQlb1rTPOMZZf6y8m6J9xZfqpZeG SfQDhHHw26vB4ghVnHQcFqcRjXjrFoXsQcK/f4cBPD4/ezmfKJwybBau9YhG3LWAXEur 7pJchTpzuJW8XT7PUGj7VUx4BWPN3UKgRYnqrVkv6smBNCY78dgoTfPTcyTntSdrAJVs 9zGth0VNPd02mO5v/sj5VOZxuibcwRE8o5V1fgLe+P3xaDfg/sHyf2Kgr/idRLyGHZYP mon4ibXVGdglmEVaKyjOmdrdjnUtaz5KIpc7voEfz815O/xDVACH0kbjemguHb8rpqYg 6RKg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@joelfernandes.org header.s=google header.b="aKOgs/Jm"; 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 e205-v6si13528914pfh.158.2018.08.05.20.41.53; Sun, 05 Aug 2018 20:42:07 -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=@joelfernandes.org header.s=google header.b="aKOgs/Jm"; 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 S1727470AbeHFFsA (ORCPT + 99 others); Mon, 6 Aug 2018 01:48:00 -0400 Received: from mail-qt0-f196.google.com ([209.85.216.196]:43097 "EHLO mail-qt0-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726559AbeHFFsA (ORCPT ); Mon, 6 Aug 2018 01:48:00 -0400 Received: by mail-qt0-f196.google.com with SMTP id f18-v6so12327795qtp.10 for ; Sun, 05 Aug 2018 20:40:55 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=joelfernandes.org; s=google; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=JKNwJ5EqUfyx9QUAap7+RzSwtUflqtaLiEiMq3Zrg3o=; b=aKOgs/JmTeJKhBhIRaQEHgbY0SnvKObCLyGRyIBtK5Zr8pZ1BF5vS9qc058aYoj3hq yj7lnc+Cp/9nOEmiwq0UepZS0ADBXxMtYM3QjhBaga/XhpgZBgcRem6dzTCZrVYFtt3S R3OYgFObR2zarxaOVSu4it5py6fQ9JcQY1ewc= 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:mime-version :content-transfer-encoding; bh=JKNwJ5EqUfyx9QUAap7+RzSwtUflqtaLiEiMq3Zrg3o=; b=s+Hl3cCSznVtvreqTiPGKPhRRuAtaqyQo8t6wU4dFeC7271CxWF3cSWfIvx4E70d5o OrgnR7oZvT5WzlM4lheoy4SuYdmDfwgHK+49guQq29KxjN/NwwD7LQ0Z4++hlPmnvnsR FYItKK3z7sQcl4/7uX/0+pyumbu8DrdVrdJ5i1Zd094xwVHkZAGELZSzrI5vhHbFBc6W R97KGgouOhWCT/VpV2qlyrW7y8VFB4kIslKfFEFLm9OZV9cp+jiYsX/0psTyhL8OxEp7 2vnU2Us/EVzB1af9G13dTx+cVbK0cOpyQk66e6lAtcQlrzMMfY+yFyaUbXbu5cAlip2s 6MEQ== X-Gm-Message-State: AOUpUlEdSgUnHcteIk5PN+ip3Xcep6fsoSIqbxaw5cz6SGaO91BdZ6MT 2oiHZovsz42dxeGzYSQmfxHPfwyuoXHZ8Q== X-Received: by 2002:a0c:9dd0:: with SMTP id p16-v6mr11699787qvf.211.1533526854960; Sun, 05 Aug 2018 20:40:54 -0700 (PDT) Received: from joelaf-glaptop0.roam.corp.google.com ([4.78.42.66]) by smtp.gmail.com with ESMTPSA id 16-v6sm7218620qkd.93.2018.08.05.20.40.53 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Sun, 05 Aug 2018 20:40:54 -0700 (PDT) From: "Joel Fernandes (Google)" To: linux-kernel@vger.kernel.org Cc: kernel-team@android.com, "Joel Fernandes (Google)" , Ingo Molnar , Steven Rostedt , Masami Hiramatsu , paulmck@linux.vnet.ibm.com, mathieu.desnoyers@efficios.com, namhyung@kernel.org, peterz@infradead.org Subject: [PATCH ftrace/core] tracing: irqsoff: Account for additional preempt_disable Date: Sun, 5 Aug 2018 20:40:49 -0700 Message-Id: <20180806034049.67949-1-joel@joelfernandes.org> X-Mailer: git-send-email 2.18.0.597.ga71716f1ad-goog MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Recently we tried to make the preemptirqsoff tracer to use irqsoff tracepoint probes. However this causes issues as reported by Masami: [2.271078] Testing tracer preemptirqsoff: .. no entries found ..FAILED! [2.381015] WARNING: CPU: 0 PID: 1 at /home/mhiramat/ksrc/linux/kernel/ trace/trace.c:1512 run_tracer_selftest+0xf3/0x154 This is due to the tracepoint code increasing the preempt nesting count by calling an additional preempt_disable before calling into the preemptoff tracer which messes up the preempt_count() check in tracer_hardirqs_off. To fix this, make the irqsoff tracer probes balance the additional outer preempt_disable with a preempt_enable_notrace. The other way to fix this is to just use SRCU for all tracepoints. However we can't do that because we can't use NMIs from RCU context. Fixes: c3bc8fd637a9 ("tracing: Centralize preemptirq tracepoints and unify their usage") Fixes: e6753f23d961 ("tracepoint: Make rcuidle tracepoint callers use SRCU") Reported-by: Masami Hiramatsu Signed-off-by: Joel Fernandes (Google) --- kernel/trace/trace_irqsoff.c | 26 ++++++++++++++++++++++++++ 1 file changed, 26 insertions(+) diff --git a/kernel/trace/trace_irqsoff.c b/kernel/trace/trace_irqsoff.c index 770cd30cda40..ffbf1505d5bc 100644 --- a/kernel/trace/trace_irqsoff.c +++ b/kernel/trace/trace_irqsoff.c @@ -603,14 +603,40 @@ static void irqsoff_tracer_stop(struct trace_array *tr) */ static void tracer_hardirqs_on(void *none, unsigned long a0, unsigned long a1) { + /* + * Tracepoint probes are expected to be called with preempt disabled, + * We don't care about being called with preempt disabled but we need + * to know in the future if that changes so we can remove the next + * preempt_enable. + */ + WARN_ON_ONCE(!preempt_count()); + + /* Tracepoint probes disable preemption atleast once, account for that */ + preempt_enable_notrace(); + if (!preempt_trace() && irq_trace()) stop_critical_timing(a0, a1); + + preempt_disable_notrace(); } static void tracer_hardirqs_off(void *none, unsigned long a0, unsigned long a1) { + /* + * Tracepoint probes are expected to be called with preempt disabled, + * We don't care about being called with preempt disabled but we need + * to know in the future if that changes so we can remove the next + * preempt_enable. + */ + WARN_ON_ONCE(!preempt_count()); + + /* Tracepoint probes disable preemption atleast once, account for that */ + preempt_enable_notrace(); + if (!preempt_trace() && irq_trace()) start_critical_timing(a0, a1); + + preempt_disable_notrace(); } static int irqsoff_tracer_init(struct trace_array *tr) -- 2.18.0.597.ga71716f1ad-goog