riscv: always honor the CONFIG_CMDLINE_FORCE when parsing dtb
authorWenting Zhang <zephray@outlook.com>
Fri, 8 Jul 2022 20:38:22 +0000 (16:38 -0400)
committerPalmer Dabbelt <palmer@rivosinc.com>
Wed, 12 Oct 2022 02:53:08 +0000 (19:53 -0700)
When CONFIG_CMDLINE_FORCE is enabled, cmdline provided by
CONFIG_CMDLINE are always used. This allows CONFIG_CMDLINE to be
used regardless of the result of device tree scanning.

This especially fixes the case where a device tree without the
chosen node is supplied to the kernel. In such cases,
early_init_dt_scan would return true. But inside
early_init_dt_scan_chosen, the cmdline won't be updated as there
is no chosen node in the device tree. As a result, CONFIG_CMDLINE
is not copied into boot_command_line even if CONFIG_CMDLINE_FORCE
is enabled. This commit allows properly update boot_command_line
in this situation.

Fixes: 8fd6e05c7463 ("arch: riscv: support kernel command line forcing when no DTB passed")
Signed-off-by: Wenting Zhang <zephray@outlook.com>
Reviewed-by: Björn Töpel <bjorn@kernel.org>
Reviewed-by: Conor Dooley <conor.dooley@microchip.com>
Link: https://lore.kernel.org/r/PSBPR04MB399135DFC54928AB958D0638B1829@PSBPR04MB3991.apcprd04.prod.outlook.com
Cc: stable@vger.kernel.org
Signed-off-by: Palmer Dabbelt <palmer@rivosinc.com>
arch/riscv/kernel/setup.c

index 2dfc463b86bb3d7b601b30d83360b9a4b1492826..ad76bb59b0590d8e67fa2825d69de741de7f8f31 100644 (file)
@@ -252,10 +252,10 @@ static void __init parse_dtb(void)
                        pr_info("Machine model: %s\n", name);
                        dump_stack_set_arch_desc("%s (DT)", name);
                }
-               return;
+       } else {
+               pr_err("No DTB passed to the kernel\n");
        }
 
-       pr_err("No DTB passed to the kernel\n");
 #ifdef CONFIG_CMDLINE_FORCE
        strscpy(boot_command_line, CONFIG_CMDLINE, COMMAND_LINE_SIZE);
        pr_info("Forcing kernel command line to: %s\n", boot_command_line);