mirror of
https://github.com/AsahiLinux/u-boot
synced 2024-11-28 15:41:40 +00:00
bootm: Add tests for fixup_silent_linux()
This function currently has no tests. Export it so that we can implement a simple test on sandbox. Use IS_ENABLED() to remove the unused code, instead #ifdef. Signed-off-by: Simon Glass <sjg@chromium.org>
This commit is contained in:
parent
96434a76fd
commit
f158ba15ee
7 changed files with 73 additions and 7 deletions
|
@ -146,6 +146,7 @@ config SANDBOX
|
|||
imply ACPI_PMC_SANDBOX
|
||||
imply CMD_PMC
|
||||
imply CMD_CLONE
|
||||
imply SILENT_CONSOLE
|
||||
|
||||
config SH
|
||||
bool "SuperH architecture"
|
||||
|
|
|
@ -465,18 +465,21 @@ ulong bootm_disable_interrupts(void)
|
|||
return iflag;
|
||||
}
|
||||
|
||||
#if defined(CONFIG_SILENT_CONSOLE) && !defined(CONFIG_SILENT_U_BOOT_ONLY)
|
||||
|
||||
#define CONSOLE_ARG "console="
|
||||
#define CONSOLE_ARG_LEN (sizeof(CONSOLE_ARG) - 1)
|
||||
|
||||
static void fixup_silent_linux(void)
|
||||
void fixup_silent_linux(void)
|
||||
{
|
||||
char *buf;
|
||||
const char *env_val;
|
||||
char *cmdline = env_get("bootargs");
|
||||
char *cmdline;
|
||||
int want_silent;
|
||||
|
||||
if (!IS_ENABLED(CONFIG_SILENT_CONSOLE) &&
|
||||
!IS_ENABLED(CONFIG_SILENT_U_BOOT_ONLY))
|
||||
return;
|
||||
cmdline = env_get("bootargs");
|
||||
|
||||
/*
|
||||
* Only fix cmdline when requested. The environment variable can be:
|
||||
*
|
||||
|
@ -523,7 +526,6 @@ static void fixup_silent_linux(void)
|
|||
debug("after silent fix-up: %s\n", env_val);
|
||||
free(buf);
|
||||
}
|
||||
#endif /* CONFIG_SILENT_CONSOLE */
|
||||
|
||||
/**
|
||||
* Execute selected states of the bootm command.
|
||||
|
@ -627,10 +629,8 @@ int do_bootm_states(struct cmd_tbl *cmdtp, int flag, int argc,
|
|||
if (!ret && (states & BOOTM_STATE_OS_BD_T))
|
||||
ret = boot_fn(BOOTM_STATE_OS_BD_T, argc, argv, images);
|
||||
if (!ret && (states & BOOTM_STATE_OS_PREP)) {
|
||||
#if defined(CONFIG_SILENT_CONSOLE) && !defined(CONFIG_SILENT_U_BOOT_ONLY)
|
||||
if (images->os.os == IH_OS_LINUX)
|
||||
fixup_silent_linux();
|
||||
#endif
|
||||
ret = boot_fn(BOOTM_STATE_OS_PREP, argc, argv, images);
|
||||
}
|
||||
|
||||
|
|
|
@ -85,4 +85,7 @@ void arch_preboot_os(void);
|
|||
*/
|
||||
void board_preboot_os(void);
|
||||
|
||||
/* Adjust the 'bootargs' to ensure that Linux boots silently, if required */
|
||||
void fixup_silent_linux(void);
|
||||
|
||||
#endif
|
||||
|
|
|
@ -26,6 +26,7 @@ int cmd_ut_category(const char *name, const char *prefix,
|
|||
struct unit_test *tests, int n_ents,
|
||||
int argc, char *const argv[]);
|
||||
|
||||
int do_ut_bootm(struct cmd_tbl *cmdtp, int flag, int argc, char *const argv[]);
|
||||
int do_ut_bloblist(struct cmd_tbl *cmdtp, int flag, int argc,
|
||||
char *const argv[]);
|
||||
int do_ut_compression(struct cmd_tbl *cmdtp, int flag, int argc,
|
||||
|
|
|
@ -5,6 +5,7 @@
|
|||
ifneq ($(CONFIG_SANDBOX),)
|
||||
obj-$(CONFIG_$(SPL_)CMDLINE) += bloblist.o
|
||||
endif
|
||||
obj-$(CONFIG_$(SPL_)CMDLINE) += bootm.o
|
||||
obj-$(CONFIG_$(SPL_)CMDLINE) += cmd/
|
||||
obj-$(CONFIG_$(SPL_)CMDLINE) += cmd_ut.o
|
||||
obj-$(CONFIG_$(SPL_)CMDLINE) += command_ut.o
|
||||
|
|
59
test/bootm.c
Normal file
59
test/bootm.c
Normal file
|
@ -0,0 +1,59 @@
|
|||
// SPDX-License-Identifier: GPL-2.0+
|
||||
/*
|
||||
* Tests for bootm routines
|
||||
*
|
||||
* Copyright 2020 Google LLC
|
||||
*/
|
||||
|
||||
#include <common.h>
|
||||
#include <bootm.h>
|
||||
#include <test/suites.h>
|
||||
#include <test/test.h>
|
||||
#include <test/ut.h>
|
||||
|
||||
DECLARE_GLOBAL_DATA_PTR;
|
||||
|
||||
#define BOOTM_TEST(_name, _flags) UNIT_TEST(_name, _flags, bootm_test)
|
||||
|
||||
#define CONSOLE_STR "console=/dev/ttyS0"
|
||||
|
||||
/* Test silent processing in the bootargs variable */
|
||||
static int bootm_test_silent_var(struct unit_test_state *uts)
|
||||
{
|
||||
/* 'silent_linux' not set should do nothing */
|
||||
env_set("silent_linux", NULL);
|
||||
env_set("bootargs", CONSOLE_STR);
|
||||
fixup_silent_linux();
|
||||
ut_asserteq_str(CONSOLE_STR, env_get("bootargs"));
|
||||
|
||||
env_set("bootargs", NULL);
|
||||
fixup_silent_linux();
|
||||
ut_assertnull(env_get("bootargs"));
|
||||
|
||||
ut_assertok(env_set("silent_linux", "no"));
|
||||
env_set("bootargs", CONSOLE_STR);
|
||||
fixup_silent_linux();
|
||||
ut_asserteq_str(CONSOLE_STR, env_get("bootargs"));
|
||||
|
||||
ut_assertok(env_set("silent_linux", "yes"));
|
||||
env_set("bootargs", CONSOLE_STR);
|
||||
fixup_silent_linux();
|
||||
ut_asserteq_str("console=", env_get("bootargs"));
|
||||
|
||||
/* Empty buffer should still add the string */
|
||||
env_set("bootargs", NULL);
|
||||
fixup_silent_linux();
|
||||
ut_asserteq_str("console=", env_get("bootargs"));
|
||||
|
||||
return 0;
|
||||
}
|
||||
BOOTM_TEST(bootm_test_silent_var, 0);
|
||||
|
||||
int do_ut_bootm(struct cmd_tbl *cmdtp, int flag, int argc, char *const argv[])
|
||||
{
|
||||
struct unit_test *tests = ll_entry_start(struct unit_test, bootm_test);
|
||||
const int n_ents = ll_entry_count(struct unit_test, bootm_test);
|
||||
|
||||
return cmd_ut_category("bootm", "bootm_test_", tests, n_ents,
|
||||
argc, argv);
|
||||
}
|
|
@ -88,6 +88,7 @@ static struct cmd_tbl cmd_ut_sub[] = {
|
|||
"", ""),
|
||||
U_BOOT_CMD_MKENT(bloblist, CONFIG_SYS_MAXARGS, 1, do_ut_bloblist,
|
||||
"", ""),
|
||||
U_BOOT_CMD_MKENT(bootm, CONFIG_SYS_MAXARGS, 1, do_ut_bootm, "", ""),
|
||||
U_BOOT_CMD_MKENT(str, CONFIG_SYS_MAXARGS, 1, do_ut_str,
|
||||
"", ""),
|
||||
#endif
|
||||
|
|
Loading…
Reference in a new issue