[PATCH v4 07/11] printk: Separate code for enabling console
From: Petr Mladek
Date: Thu Jun 04 2026 - 06:33:04 EST
There are several code paths which try to enable a newly registered
console. Move the logic into a separate try_enable_console() function.
It simplifies a bit the long register_console() function definition.
Also followup patches are going to add even more code paths. And it will
be easier to use "return" when it does not make sense to try other
variants.
No behavior change.
Signed-off-by: Petr Mladek <pmladek@xxxxxxxx>
---
kernel/printk/printk.c | 84 ++++++++++++++++++++++++------------------
1 file changed, 48 insertions(+), 36 deletions(-)
diff --git a/kernel/printk/printk.c b/kernel/printk/printk.c
index 4ee98a4d2ce5..5fb9581804c7 100644
--- a/kernel/printk/printk.c
+++ b/kernel/printk/printk.c
@@ -4034,6 +4034,53 @@ static void try_enable_default_console(struct console *newcon)
newcon->flags |= CON_CONSDEV;
}
+#define console_first() \
+ hlist_entry(console_list.first, struct console, node)
+
+static int try_enable_console(struct console *newcon)
+{
+ int err;
+
+ /*
+ * See if we want to enable this console driver by default.
+ *
+ * Nope when a console is preferred by the command line, device
+ * tree, or SPCR.
+ *
+ * The first real console with tty binding (driver) wins. More
+ * consoles might get enabled before the right one is found.
+ *
+ * Note that a console with tty binding will have CON_CONSDEV
+ * flag set and will be first in the list.
+ */
+ if (preferred_dev_console < 0) {
+ if (hlist_empty(&console_list) || !console_first()->device ||
+ console_first()->flags & CON_BOOT) {
+ try_enable_default_console(newcon);
+ }
+ }
+
+ /* See if this console matches one we selected on the command line */
+ err = try_enable_preferred_console(newcon, true);
+ if (err != -ENOENT)
+ return err;
+
+ /* If not, try to match against the platform default(s) */
+ err = try_enable_preferred_console(newcon, false);
+ if (err != -ENOENT)
+ return err;
+
+ /*
+ * Some consoles, such as pstore and netconsole, can be enabled even
+ * without matching. Accept them at this stage when they had a chance
+ * to match() and call setup().
+ */
+ if (newcon->flags & CON_ENABLED)
+ err = 0;
+
+ return err;
+}
+
/* Return the starting sequence number for a newly registered console. */
static u64 get_init_console_seq(struct console *newcon, bool bootcon_registered)
{
@@ -4108,9 +4155,6 @@ static u64 get_init_console_seq(struct console *newcon, bool bootcon_registered)
return init_seq;
}
-#define console_first() \
- hlist_entry(console_list.first, struct console, node)
-
static int unregister_console_locked(struct console *console);
/*
@@ -4172,39 +4216,7 @@ void register_console(struct console *newcon)
goto unlock;
}
- /*
- * See if we want to enable this console driver by default.
- *
- * Nope when a console is preferred by the command line, device
- * tree, or SPCR.
- *
- * The first real console with tty binding (driver) wins. More
- * consoles might get enabled before the right one is found.
- *
- * Note that a console with tty binding will have CON_CONSDEV
- * flag set and will be first in the list.
- */
- if (preferred_dev_console < 0) {
- if (hlist_empty(&console_list) || !console_first()->device ||
- console_first()->flags & CON_BOOT) {
- try_enable_default_console(newcon);
- }
- }
-
- /* See if this console matches one we selected on the command line */
- err = try_enable_preferred_console(newcon, true);
-
- /* If not, try to match against the platform default(s) */
- if (err == -ENOENT)
- err = try_enable_preferred_console(newcon, false);
-
- /*
- * Some consoles, such as pstore and netconsole, can be enabled even
- * without matching. Accept them at this stage when they had a chance
- * to match() and call setup().
- */
- if (err == -ENOENT && (newcon->flags & CON_ENABLED))
- err = 0;
+ err = try_enable_console(newcon);
/* printk() messages are not printed to the Braille console. */
if (err || newcon->flags & CON_BRL) {
--
2.54.0