linux-kernel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Daniel Bristot de Oliveira <bristot@redhat.com>
To: Steven Rostedt <rostedt@goodmis.org>
Cc: Phil Auld <pauld@redhat.com>,
	Sebastian Andrzej Siewior <bigeasy@linutronix.de>,
	Kate Carcia <kcarcia@redhat.com>,
	Daniel Bristot de Oliveira <bristot@redhat.com>,
	Jonathan Corbet <corbet@lwn.net>, Ingo Molnar <mingo@redhat.com>,
	Peter Zijlstra <peterz@infradead.org>,
	Thomas Gleixner <tglx@linutronix.de>,
	Alexandre Chartre <alexandre.chartre@oracle.com>,
	Clark Willaims <williams@redhat.com>,
	John Kacur <jkacur@redhat.com>,
	Juri Lelli <juri.lelli@redhat.com>,
	Borislav Petkov <bp@alien8.de>, "H. Peter Anvin" <hpa@zytor.com>,
	x86@kernel.org, linux-doc@vger.kernel.org,
	linux-kernel@vger.kernel.org
Subject: [PATCH V4 08/12] trace/hwlat: Remove printk from sampling loop
Date: Tue, 15 Jun 2021 11:28:47 +0200	[thread overview]
Message-ID: <ed452f4329d99cce4581417bb484f89759f302e7.1623746916.git.bristot@redhat.com> (raw)
In-Reply-To: <cover.1623746916.git.bristot@redhat.com>

hwlat has some time operation checks on the sample loop, and it is
currently using pr_err (printk) to report them. The problem is that
this can lead the system to an unresponsible state due to an overflow of
printk messages. This problem can be mitigated by writing the error
message to the trace buffer.

Remove the printk messages from the sampling loop, switching the to
messages in the trace buffer.

No functional change.

Cc: Jonathan Corbet <corbet@lwn.net>
Cc: Steven Rostedt <rostedt@goodmis.org>
Cc: Ingo Molnar <mingo@redhat.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Thomas Gleixner <tglx@linutronix.de>
Cc: Alexandre Chartre <alexandre.chartre@oracle.com>
Cc: Clark Willaims <williams@redhat.com>
Cc: John Kacur <jkacur@redhat.com>
Cc: Juri Lelli <juri.lelli@redhat.com>
Cc: Borislav Petkov <bp@alien8.de>
Cc: "H. Peter Anvin" <hpa@zytor.com>
Cc: x86@kernel.org
Cc: linux-doc@vger.kernel.org
Cc: linux-kernel@vger.kernel.org
Signed-off-by: Daniel Bristot de Oliveira <bristot@redhat.com>
---
 kernel/trace/trace_hwlat.c | 15 ++++++++++++---
 1 file changed, 12 insertions(+), 3 deletions(-)

diff --git a/kernel/trace/trace_hwlat.c b/kernel/trace/trace_hwlat.c
index 0ab6acf6ae9a..86e8541d4331 100644
--- a/kernel/trace/trace_hwlat.c
+++ b/kernel/trace/trace_hwlat.c
@@ -182,6 +182,15 @@ void trace_hwlat_callback(bool enter)
 		kdata->nmi_count++;
 }
 
+/*
+ * hwlat_err - report a hwlat error.
+ */
+#define hwlat_err(msg) ({							\
+	struct trace_array *tr = hwlat_trace;					\
+										\
+	trace_array_printk_buf(tr->array_buffer.buffer, _THIS_IP_, msg);	\
+})
+
 /**
  * get_sample - sample the CPU TSC and look for likely hardware latencies
  *
@@ -225,7 +234,7 @@ static int get_sample(void)
 			outer_diff = time_to_us(time_sub(t1, last_t2));
 			/* This shouldn't happen */
 			if (outer_diff < 0) {
-				pr_err(BANNER "time running backwards\n");
+				hwlat_err(BANNER "time running backwards\n");
 				goto out;
 			}
 			if (outer_diff > outer_sample)
@@ -237,7 +246,7 @@ static int get_sample(void)
 
 		/* Check for possible overflows */
 		if (total < last_total) {
-			pr_err("Time total overflowed\n");
+			hwlat_err("Time total overflowed\n");
 			break;
 		}
 		last_total = total;
@@ -253,7 +262,7 @@ static int get_sample(void)
 
 		/* This shouldn't happen */
 		if (diff < 0) {
-			pr_err(BANNER "time running backwards\n");
+			hwlat_err(BANNER "time running backwards\n");
 			goto out;
 		}
 
-- 
2.31.1


  parent reply	other threads:[~2021-06-15  9:29 UTC|newest]

Thread overview: 28+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2021-06-15  9:28 [PATCH V4 00/12] hwlat improvements and osnoise/timerlat tracers Daniel Bristot de Oliveira
2021-06-15  9:28 ` [PATCH V4 01/12] trace/hwlat: Fix Clark's email Daniel Bristot de Oliveira
2021-06-15  9:28 ` [PATCH V4 02/12] trace/hwlat: Implement the mode config option Daniel Bristot de Oliveira
2021-06-15  9:28 ` [PATCH V4 03/12] trace/hwlat: Switch disable_migrate to mode none Daniel Bristot de Oliveira
2021-06-15  9:28 ` [PATCH V4 04/12] trace/hwlat: Implement the per-cpu mode Daniel Bristot de Oliveira
2021-06-15  9:28 ` [PATCH V4 05/12] trace/hwlat: Support hotplug operations Daniel Bristot de Oliveira
2021-06-18 16:45   ` Steven Rostedt
2021-06-18 19:00     ` Steven Rostedt
2021-06-21 11:34       ` Daniel Bristot de Oliveira
2021-06-21 15:25         ` Steven Rostedt
2021-06-21 16:14           ` Daniel Bristot de Oliveira
2021-06-21 17:46             ` Steven Rostedt
2021-06-22 14:05               ` Daniel Bristot de Oliveira
2021-06-15  9:28 ` [PATCH V4 06/12] trace: Add a generic function to read/write u64 values from tracefs Daniel Bristot de Oliveira
2021-06-18 16:56   ` Steven Rostedt
2021-06-21 11:50     ` Daniel Bristot de Oliveira
2021-06-15  9:28 ` [PATCH V4 07/12] trace/hwlat: Use trace_min_max_param for width and window params Daniel Bristot de Oliveira
2021-06-15  9:28 ` Daniel Bristot de Oliveira [this message]
2021-06-15  9:28 ` [PATCH V4 09/12] trace: Add __print_ns_to_secs() and __print_ns_without_secs() helpers Daniel Bristot de Oliveira
2021-06-15  9:28 ` [PATCH V4 10/12] trace: Add osnoise tracer Daniel Bristot de Oliveira
2021-06-18 17:55   ` Steven Rostedt
2021-06-21 12:09     ` Daniel Bristot de Oliveira
2021-06-18 18:27   ` Steven Rostedt
2021-06-21 12:09     ` Daniel Bristot de Oliveira
2021-06-15  9:28 ` [PATCH V4 11/12] trace: Add timerlat tracer Daniel Bristot de Oliveira
2021-06-15  9:28 ` [PATCH V4 12/12] trace/osnoise: Support hotplug operations Daniel Bristot de Oliveira
2021-06-18 19:04   ` Steven Rostedt
2021-06-21 12:18     ` Daniel Bristot de Oliveira

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=ed452f4329d99cce4581417bb484f89759f302e7.1623746916.git.bristot@redhat.com \
    --to=bristot@redhat.com \
    --cc=alexandre.chartre@oracle.com \
    --cc=bigeasy@linutronix.de \
    --cc=bp@alien8.de \
    --cc=corbet@lwn.net \
    --cc=hpa@zytor.com \
    --cc=jkacur@redhat.com \
    --cc=juri.lelli@redhat.com \
    --cc=kcarcia@redhat.com \
    --cc=linux-doc@vger.kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=mingo@redhat.com \
    --cc=pauld@redhat.com \
    --cc=peterz@infradead.org \
    --cc=rostedt@goodmis.org \
    --cc=tglx@linutronix.de \
    --cc=williams@redhat.com \
    --cc=x86@kernel.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).