Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp7539992yba; Thu, 2 May 2019 11:39:16 -0700 (PDT) X-Google-Smtp-Source: APXvYqx2EEAkGQ/iRa/yO6TDxO8A7kTZh0lCnLpCbscD78b8t8xpzj0nEz/HBIod870CVHVX8KF7 X-Received: by 2002:a65:5549:: with SMTP id t9mr5498010pgr.388.1556822356382; Thu, 02 May 2019 11:39:16 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1556822356; cv=none; d=google.com; s=arc-20160816; b=y092XQU8F4s39glwXLiOjIOI4wr1rE/5Sa7CNdfTVrFP3iETgCamtAPV0JZHe108lj w6l3q/+esxj8psOamqJssk4PgovlVh7n6lv9/oE9GgLBXu4hYQTp+nlsjypOkEYtW0PF OCvdwReEMtyJssHTRu+zAYxulCud5N4X4Qznuh85MqAcwhlNSG1EQ8At4JDrrRGK6/Qg RmyX1eRlqM5JV5yelcUbl8i+2KKPR/LzLLYWeVoYfYYO4JlcsELche2eeUx4bzpph+1r KL5jrXRP7OY2LpDHx96mOYkehtM5f+ksACbHGJFL8iw0vZM3M2ymVrhfPHit60nyu4ii F1GA== 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; bh=3bTGTbTE8gGlzRl/POqzvQikyqE1rXFDWwJSoA19kt4=; b=Xm0BDdHsZAcoN/fGTRc98e3RS7X/t1iz+sEy8igBMZbVmQrV6X+x5PDO+F0aQRZvXw Wm0Vp3mK9zrYy18LXtttKkPaDwfE98V1B/iR2lw6ii+vP6cZ3S9BjGKvu1R6HNiLxgOG nS5qGD00KGmgzJddiShCelWxq3LrMcwoZeQgZH7fxqYzgB/iuwqBAxrROUAiiHbLEupi IC2zoCH15wJC/TdsVwtzA8ygETaAg9BehHxxFcb98VVVGnRLx2yQyJmd8kNlr6NhopMM /KOwLZ1PA36Nnub0fm8bl+NnzCyVAfxXWwinU1LBPVOiTqkvjvzV0694aS/LA8gGfasS ZQfw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=NqZvTaSO; 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=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id i1si17050431pfa.61.2019.05.02.11.39.00; Thu, 02 May 2019 11:39:16 -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=@gmail.com header.s=20161025 header.b=NqZvTaSO; 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=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726264AbfEBShk (ORCPT + 99 others); Thu, 2 May 2019 14:37:40 -0400 Received: from mail-it1-f193.google.com ([209.85.166.193]:39620 "EHLO mail-it1-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726144AbfEBShk (ORCPT ); Thu, 2 May 2019 14:37:40 -0400 Received: by mail-it1-f193.google.com with SMTP id t200so5158303itf.4 for ; Thu, 02 May 2019 11:37:39 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=3bTGTbTE8gGlzRl/POqzvQikyqE1rXFDWwJSoA19kt4=; b=NqZvTaSOo7uS4QqtoXCyXNDR4MTzOFCymDIYrBV/xH3OHScHgrHDqiUHPGj/nSPzFd K4GHaokfN+BPVUf6IYjKFwjoEPbEyrWttzYY1ZvjO/kzzZDRCyUuDmzE0n4HgIvBWSv7 GoFdgyAfNXliayepT0vgzm0HOpo9mTF87vHTZjfwe7LGne07W+kOrWJ9XnuLTO2fOEdb pNEpBljheyiqrUPD8qVWDu4WgXDL/2GhJm3/ZZA8JmiS8L1zHsggNGt6S8HgP2y03KA3 /mNcgAyQgwjtPf/tPRRcbV3RTztVYzExIX9xPZVn77ds5goQt+FUq6azcpDZYNOk2vKg ycvA== 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=3bTGTbTE8gGlzRl/POqzvQikyqE1rXFDWwJSoA19kt4=; b=WR+vEDgoCdCkotHVxtNw/sSmSYqIxA+AIEyqi9MjwcVirHkmIYXB8D4qBlrEoQo6Oq vD/NFRey8CEEA3QAPErqwE3nxbCLDuJgylBv8KVp9p+I7DvVaeCkLM2edK/rejO/Xsv+ 5dpBurR47l84zFoHTYVLAreKuZp5VprATAGAewEuV5+S+P6rpwMeYZL14eN1AEcRhlaT Em8sNUKPXtMB1uuYVTXYa91uiykCVKRMxIJCuB9Ozg67Y+nrycm+tlA5wF1MUoxB9DvJ sSFz6cfVZ6rA/ROOxcFgaeDDgUKAFjdbum/zd2/jdJZr/3FHSAvNoiKH9Dq5D542tiQi UFKA== X-Gm-Message-State: APjAAAXpUncf8qsvFUooA+HAmj6WcizrdLTQfhWNch3XYT033qwjGQXv pta5YSzod3GSHFUe20Kit+a/t59WEQ== X-Received: by 2002:a24:4614:: with SMTP id j20mr3344210itb.72.1556822259065; Thu, 02 May 2019 11:37:39 -0700 (PDT) Received: from localhost.localdomain ([92.117.168.44]) by smtp.gmail.com with ESMTPSA id y62sm4213ita.15.2019.05.02.11.37.36 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Thu, 02 May 2019 11:37:38 -0700 (PDT) From: Viktor Rosendahl To: Steven Rostedt Cc: Ingo Molnar , linux-kernel@vger.kernel.org, Joel Fernandes , Viktor Rosendahl Subject: Re: [PATCH v2 4/4] ftrace: Add an option for tracing console latencies Date: Thu, 2 May 2019 20:37:31 +0200 Message-Id: <20190502183731.9571-1-viktor.rosendahl@gmail.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20190501213857.157e3741@oasis.local.home> References: <20190501213857.157e3741@oasis.local.home> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org > Instead of this being turned into a nop, don't have a kconfig option > but instead have this call into the trace_irqsoff.c code, and depending > on what the options are, it should stop it. Of course, this would need > to be smart enough to pair it. Perhaps return the result of > console_stop_critical_timings() and have that passed to > console_start_critical_timings(), and only have start do something if > stop did something. This way the option only needs to disable the stop > part. Something like this? I have only compile tested it so far. best regards, Viktor --- include/linux/irqflags.h | 17 +++++++++++++++++ kernel/printk/printk.c | 6 ++++-- kernel/trace/trace.h | 1 + kernel/trace/trace_irqsoff.c | 13 +++++++++++++ 4 files changed, 35 insertions(+), 2 deletions(-) diff --git a/include/linux/irqflags.h b/include/linux/irqflags.h index 21619c92c377..e4f7ebc67a53 100644 --- a/include/linux/irqflags.h +++ b/include/linux/irqflags.h @@ -68,9 +68,26 @@ do { \ defined(CONFIG_PREEMPT_TRACER) extern void stop_critical_timings(void); extern void start_critical_timings(void); + extern bool console_tracing_disabled(void); + +#define console_stop_critical_timings(FLAG) \ + do { \ + FLAG = console_tracing_disabled(); \ + if (FLAG) \ + stop_critical_timings(); \ + } while(0) + +#define console_start_critical_timings(FLAG) \ + do { \ + if (FLAG) \ + start_critical_timings(); \ + } while(0) + #else # define stop_critical_timings() do { } while (0) # define start_critical_timings() do { } while (0) +# define console_stop_critical_timings(FLAG) do { } while (0) +# define console_start_critical_timings(FLAG) do { } while (0) #endif /* diff --git a/kernel/printk/printk.c b/kernel/printk/printk.c index 02ca827b8fac..3a18b7208399 100644 --- a/kernel/printk/printk.c +++ b/kernel/printk/printk.c @@ -2348,6 +2348,7 @@ void console_unlock(void) static char ext_text[CONSOLE_EXT_LOG_MAX]; static char text[LOG_LINE_MAX + PREFIX_MAX]; unsigned long flags; + bool cflag; bool do_cond_resched, retry; if (console_suspended) { @@ -2448,9 +2449,10 @@ void console_unlock(void) */ console_lock_spinning_enable(); - stop_critical_timings(); /* don't trace print latency */ + /* don't trace print latency if it's disabled */ + console_stop_critical_timings(cflag); call_console_drivers(ext_text, ext_len, text, len); - start_critical_timings(); + console_start_critical_timings(cflag); if (console_lock_spinning_disable_and_check()) { printk_safe_exit_irqrestore(flags); diff --git a/kernel/trace/trace.h b/kernel/trace/trace.h index 59dc01ac52fd..3eed4756dba3 100644 --- a/kernel/trace/trace.h +++ b/kernel/trace/trace.h @@ -1253,6 +1253,7 @@ extern int trace_get_user(struct trace_parser *parser, const char __user *ubuf, C(PRINTK_MSGONLY, "printk-msg-only"), \ C(CONTEXT_INFO, "context-info"), /* Print pid/cpu/time */ \ C(LATENCY_FMT, "latency-format"), \ + C(CONSOLE_LATENCY, "console-latency"), \ C(RECORD_CMD, "record-cmd"), \ C(RECORD_TGID, "record-tgid"), \ C(OVERWRITE, "overwrite"), \ diff --git a/kernel/trace/trace_irqsoff.c b/kernel/trace/trace_irqsoff.c index 07a391e845de..659a82209c1e 100644 --- a/kernel/trace/trace_irqsoff.c +++ b/kernel/trace/trace_irqsoff.c @@ -490,6 +490,19 @@ void stop_critical_timings(void) EXPORT_SYMBOL_GPL(stop_critical_timings); NOKPROBE_SYMBOL(stop_critical_timings); +bool console_tracing_disabled(void) +{ + struct trace_array *tr = irqsoff_trace; + int pc = preempt_count(); + + if (!preempt_trace(pc) && !irq_trace()) + return false; + + return !(tr->trace_flags & CONSOLE_LATENCY); +} + +EXPORT_SYMBOL_GPL(console_tracing_disabled); + #ifdef CONFIG_FUNCTION_TRACER static bool function_enabled; -- 2.17.1