Received: by 2002:a25:e7d8:0:0:0:0:0 with SMTP id e207csp1753814ybh; Sun, 15 Mar 2020 10:11:51 -0700 (PDT) X-Google-Smtp-Source: ADFU+vvZTPwWeLeVT5ucB6PTyb5DwaUOoxVQ7zAAmgVAAAzsxHdWyWFO/VitmG5/T5CWd0GU831c X-Received: by 2002:a05:6830:1b68:: with SMTP id d8mr18911679ote.56.1584292311014; Sun, 15 Mar 2020 10:11:51 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1584292311; cv=none; d=google.com; s=arc-20160816; b=v2HLMoWYq24sfUbOWDXYWMEhsHHoSrIVk9u8/uI2RgMJZwkGrFrVUm3ng6tdjaTVj1 WOLfR2/wWyGEuLodIfHMNW1xs+BhTiuEbOxhIdyiIXwYkIACxSsdMCm6geHcIvPl0+xL w3CcGcd3Z5Euaubx1bqYY/AVhB9d7+ys3V6QdlW3RmwETU+CvCQUbfIHy+al4GpSBdZm BQisCJQolZsuNKyFFS5Enun4JGD3AaoBzPpbyPx11A2q0Pk7A37ca+H2vjWeG6sdIE0M OhT63wjwy0eXtPpyH+mKXmPLaB9RQCcoFnYzdIfRPwYxy8C5mSE/iGKz1Jpsd5NIQz80 Ebaw== 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:date:subject:cc:to:from :dkim-signature; bh=VGGErCaRDrsGcqGzSXzlpb80blPvQ3i+L003GfY75Rs=; b=lwhDL247yUke+yYjgf8ONUlN0GUQBxASMyS7J+kBJ57Khyx8tNXykcVlx8VNSdd7jF oQ8FaIfDL7f1whS6FAQNO/aqxRK9A2eY3aXZP5afQNhFcA+CPlivUaF5vmyUTOZrp82Z FwudVSQYvWBaEN45MevF/dV8ly9iHqItajFHdY6BHzH6cntI6E9GLXzAK3GvO3MYifPZ XS77rdEAive0yaOjqkyjtGjBPPJFSk7sQhFR6lv+gPnQFk17lS+2xevGFYIKUWguuxkP JlP+7+y6E8W6LRW+wr3e004qR4SUOHo2SGBDblhtbKObpl1hbP26+BO9sq+MWtyGDzti JItw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=qRWB9gB1; 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 k1si7834381oic.245.2020.03.15.10.11.39; Sun, 15 Mar 2020 10:11:50 -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=qRWB9gB1; 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 S1728987AbgCORJ5 (ORCPT + 99 others); Sun, 15 Mar 2020 13:09:57 -0400 Received: from mail-wm1-f68.google.com ([209.85.128.68]:38878 "EHLO mail-wm1-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728915AbgCORJ5 (ORCPT ); Sun, 15 Mar 2020 13:09:57 -0400 Received: by mail-wm1-f68.google.com with SMTP id t13so9118966wmi.3 for ; Sun, 15 Mar 2020 10:09:54 -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 :mime-version:content-transfer-encoding; bh=VGGErCaRDrsGcqGzSXzlpb80blPvQ3i+L003GfY75Rs=; b=qRWB9gB1qIdAqhbWMeSB1KFeJIgWWfz6ns1d12N6tcugRewO27xI6k4CpPodrmipDa 6JU+9j1VDmCjoDDFslDwKOdhZdutaYH354vS3y1xiCzWExxh0Vu3NDo7oTM++0LNJ9+A qPurrzoTs+lzMiUrGuxFbWzi3fprnOC45XidOV4GL4TmvrSad0a7zahFBZpjrf5OD+e2 or2NAE+SpDcgHSJVMSZyJ3gPfMhtNxCs/0ZT9maiAdNWIhLZ6mGbP7yNd09HIMDv78Zu V+rXQfaERY5XBMB6bXEgQT+HY2pY6YUNNytM6aw66tlzYzJMItdr5pyvWMeSQsDjhglL t+zg== 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:mime-version:content-transfer-encoding; bh=VGGErCaRDrsGcqGzSXzlpb80blPvQ3i+L003GfY75Rs=; b=P6wV8YXvVTQ4GUTSrGKElE1cNqD4vYxC3BY5CKE8+fJg0HIwpn7OI+aL+gRFlpMkOe /JDAg+dDDLOFUECnlmNNzKSU0nQ+mO0RORxhO6ZlFIczQeHJ8rUiF8cpt6jDFF/dAJzD odkU6F5G66S/slVM1EVpCIFrKz1rxfbx+H5DVN7p/FVbjXw2GihQyFveNLNH6GT0/hyE oLHSLmnBwqjhTRocDSX29U7EVzJBlfYbpq8hPnnaP5ewTYBdgot7mdHy50Ccf0fU0l9C 9lpmHIVlSrjCMWCiZOHAqTRuRYnu5xLgOEf5wXVMPMpgVAIc8SZez2CImzHzIYl9D9Cd KQqg== X-Gm-Message-State: ANhLgQ3mEnbQ0ZBeYVcciTGRLaP8Pl+qqI101rnkxTQ+O7QlbG0lmjey 8bYg/XRBDQ4lRG7GxTyztX98yY1l8znPeEA6 X-Received: by 2002:a1c:a502:: with SMTP id o2mr22227586wme.94.1584292193895; Sun, 15 Mar 2020 10:09:53 -0700 (PDT) Received: from localhost.localdomain (ipb218f56a.dynamic.kabel-deutschland.de. [178.24.245.106]) by smtp.gmail.com with ESMTPSA id u25sm25874774wml.17.2020.03.15.10.09.52 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sun, 15 Mar 2020 10:09:53 -0700 (PDT) From: Eugeniu Rosca X-Google-Original-From: Eugeniu Rosca To: linux-kernel@vger.kernel.org Cc: Petr Mladek , Sergey Senozhatsky , Steven Rostedt , Ingo Molnar , Thomas Gleixner , Peter Zijlstra , Jisheng Zhang , Valdis Kletnieks , Sebastian Andrzej Siewior , Andrew Gabbasov , Dirk Behme , Eugeniu Rosca Subject: [RFC PATCH 2/3] printk: add console_verbose_{start,end} Date: Sun, 15 Mar 2020 18:09:02 +0100 Message-Id: <20200315170903.17393-3-erosca@de.adit-jv.com> X-Mailer: git-send-email 2.25.0 In-Reply-To: <20200315170903.17393-1-erosca@de.adit-jv.com> References: <20200315170903.17393-1-erosca@de.adit-jv.com> 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 Consider below example scenarios: - soft lockup - hard lockup - hung task - scheduling while atomic - rcu stall - oops - oom - WARN In most of the above situations, it is up to the user to terminate the execution with a panic (see panic_on_* in kernel/sysctl.c) or to decide not to abort and try to recover. A general concern applicable to the above use-cases is that, depending on the console loglevel set by the user, precious information conveyed by show_regs(), print_modules(), dump_stack() and friends may simply not appear on the console. Below example commits tackle this exact concern in the panic paths: * commit 168e06f7937d96 ("kernel/hung_task.c: force console verbose before panic") * commit 5b530fc1832460 ("panic: call console_verbose() in panic") The approach behind the above commits is straightforward. Whenever panic is imminent, they simply call console_verbose(). Unfortunately, the same technique does not apply to non-panic paths. It requires a counterpart of console_verbose(), which currently does not exist. With that in mind, create a pair of functions named console_verbose_start() and console_verbose_end() which turn the console verbosity on and off in a lockless and SMP safe way. Cc: Petr Mladek Cc: Sergey Senozhatsky Cc: Steven Rostedt Cc: Ingo Molnar Signed-off-by: Eugeniu Rosca --- include/linux/printk.h | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/include/linux/printk.h b/include/linux/printk.h index 1e6108b8d15f..14755ef7b017 100644 --- a/include/linux/printk.h +++ b/include/linux/printk.h @@ -3,6 +3,7 @@ #define __KERNEL_PRINTK__ #include +#include #include #include #include @@ -77,6 +78,15 @@ static inline void console_verbose(void) console_loglevel = CONSOLE_LOGLEVEL_MOTORMOUTH; } +#ifdef CONFIG_PRINTK +extern atomic_t ignore_loglevel; +static inline void console_verbose_start(void) { atomic_inc(&ignore_loglevel); } +static inline void console_verbose_end(void) { atomic_dec(&ignore_loglevel); } +#else +static inline void console_verbose_start(void) { } +static inline void console_verbose_end(void) { } +#endif + /* strlen("ratelimit") + 1 */ #define DEVKMSG_STR_MAX_SIZE 10 extern char devkmsg_log_str[]; -- 2.25.0