Skip to content

Commit

Permalink
Revert "printk: Wait for the global console lock when the system is g…
Browse files Browse the repository at this point in the history
…oing down"

This reverts commit b87f023.

The testing of 5.19 release candidates revealed missing synchronization
between early and regular console functionality.

It would be possible to start the console kthreads later as a workaround.
But it is clear that console lock serialized console drivers between
each other. It opens a big area of possible problems that were not
considered by people involved in the development and review.

printk() is crucial for debugging kernel issues and console output is
very important part of it. The number of consoles is huge and a proper
review would take some time. As a result it need to be reverted for 5.19.

Link: https://lore.kernel.org/r/YrBdjVwBOVgLfHyb@alley
Signed-off-by: Petr Mladek <[email protected]>
Link: https://lore.kernel.org/r/[email protected]
  • Loading branch information
pmladek committed Jun 23, 2022
1 parent b87f023 commit 20fb0c8
Show file tree
Hide file tree
Showing 6 changed files with 0 additions and 47 deletions.
5 changes: 0 additions & 5 deletions include/linux/printk.h
Original file line number Diff line number Diff line change
Expand Up @@ -174,7 +174,6 @@ extern void printk_prefer_direct_enter(void);
extern void printk_prefer_direct_exit(void);

extern bool pr_flush(int timeout_ms, bool reset_on_progress);
extern void try_block_console_kthreads(int timeout_ms);

/*
* Please don't use printk_ratelimit(), because it shares ratelimiting state
Expand Down Expand Up @@ -239,10 +238,6 @@ static inline bool pr_flush(int timeout_ms, bool reset_on_progress)
return true;
}

static inline void try_block_console_kthreads(int timeout_ms)
{
}

static inline int printk_ratelimit(void)
{
return 0;
Expand Down
2 changes: 0 additions & 2 deletions kernel/panic.c
Original file line number Diff line number Diff line change
Expand Up @@ -273,15 +273,13 @@ void panic(const char *fmt, ...)
* unfortunately means it may not be hardened to work in a
* panic situation.
*/
try_block_console_kthreads(10000);
smp_send_stop();
} else {
/*
* If we want to do crash dump after notifier calls and
* kmsg_dump, we will need architecture dependent extra
* works in addition to stopping other CPUs.
*/
try_block_console_kthreads(10000);
crash_smp_send_stop();
}

Expand Down
2 changes: 0 additions & 2 deletions kernel/printk/internal.h
Original file line number Diff line number Diff line change
Expand Up @@ -20,8 +20,6 @@ enum printk_info_flags {
LOG_CONT = 8, /* text is a fragment of a continuation line */
};

extern bool block_console_kthreads;

__printf(4, 0)
int vprintk_store(int facility, int level,
const struct dev_printk_info *dev_info,
Expand Down
4 changes: 0 additions & 4 deletions kernel/printk/printk.c
Original file line number Diff line number Diff line change
Expand Up @@ -250,9 +250,6 @@ static atomic_t console_kthreads_active = ATOMIC_INIT(0);
#define console_kthread_printing_exit() \
atomic_dec(&console_kthreads_active)

/* Block console kthreads to avoid processing new messages. */
bool block_console_kthreads;

/*
* Helper macros to handle lockdep when locking/unlocking console_sem. We use
* macros instead of functions so that _RET_IP_ contains useful information.
Expand Down Expand Up @@ -3733,7 +3730,6 @@ static bool printer_should_wake(struct console *con, u64 seq)

if (con->blocked ||
console_kthreads_atomically_blocked() ||
block_console_kthreads ||
system_state > SYSTEM_RUNNING ||
oops_in_progress) {
return false;
Expand Down
32 changes: 0 additions & 32 deletions kernel/printk/printk_safe.c
Original file line number Diff line number Diff line change
Expand Up @@ -8,9 +8,7 @@
#include <linux/smp.h>
#include <linux/cpumask.h>
#include <linux/printk.h>
#include <linux/console.h>
#include <linux/kprobes.h>
#include <linux/delay.h>

#include "internal.h"

Expand Down Expand Up @@ -52,33 +50,3 @@ asmlinkage int vprintk(const char *fmt, va_list args)
return vprintk_default(fmt, args);
}
EXPORT_SYMBOL(vprintk);

/**
* try_block_console_kthreads() - Try to block console kthreads and
* make the global console_lock() avaialble
*
* @timeout_ms: The maximum time (in ms) to wait.
*
* Prevent console kthreads from starting processing new messages. Wait
* until the global console_lock() become available.
*
* Context: Can be called in any context.
*/
void try_block_console_kthreads(int timeout_ms)
{
block_console_kthreads = true;

/* Do not wait when the console lock could not be safely taken. */
if (this_cpu_read(printk_context) || in_nmi())
return;

while (timeout_ms > 0) {
if (console_trylock()) {
console_unlock();
return;
}

udelay(1000);
timeout_ms -= 1;
}
}
2 changes: 0 additions & 2 deletions kernel/reboot.c
Original file line number Diff line number Diff line change
Expand Up @@ -74,7 +74,6 @@ void kernel_restart_prepare(char *cmd)
{
blocking_notifier_call_chain(&reboot_notifier_list, SYS_RESTART, cmd);
system_state = SYSTEM_RESTART;
try_block_console_kthreads(10000);
usermodehelper_disable();
device_shutdown();
}
Expand Down Expand Up @@ -263,7 +262,6 @@ static void kernel_shutdown_prepare(enum system_states state)
blocking_notifier_call_chain(&reboot_notifier_list,
(state == SYSTEM_HALT) ? SYS_HALT : SYS_POWER_OFF, NULL);
system_state = state;
try_block_console_kthreads(10000);
usermodehelper_disable();
device_shutdown();
}
Expand Down

0 comments on commit 20fb0c8

Please sign in to comment.