From 2cb19ac699b51d38fba57f4acb1ce02f06e7548f Mon Sep 17 00:00:00 2001 From: Anup Patel Date: Mon, 22 Jun 2020 08:38:44 +0530 Subject: Add bootargs command-line option to Spike We add bootargs command-line option to Spike which allows us to provide custom kernel parameters to Linux and Xvisor. Signed-off-by: Anup Patel --- riscv/dts.cc | 17 ++++++++++++++--- 1 file changed, 14 insertions(+), 3 deletions(-) (limited to 'riscv/dts.cc') diff --git a/riscv/dts.cc b/riscv/dts.cc index 6a38ba0..56b76e6 100644 --- a/riscv/dts.cc +++ b/riscv/dts.cc @@ -11,6 +11,7 @@ std::string make_dts(size_t insns_per_rtc_tick, size_t cpu_hz, reg_t initrd_start, reg_t initrd_end, + const char* bootargs, std::vector procs, std::vector> mems) { @@ -25,12 +26,22 @@ std::string make_dts(size_t insns_per_rtc_tick, size_t cpu_hz, " model = \"ucbbar,spike-bare\";\n" " chosen {\n"; if (initrd_start < initrd_end) { - s << " bootargs = \"root=/dev/ram console=hvc0 earlycon=sbi\";\n" - " linux,initrd-start = <" << (size_t)initrd_start << ">;\n" + s << " linux,initrd-start = <" << (size_t)initrd_start << ">;\n" " linux,initrd-end = <" << (size_t)initrd_end << ">;\n"; + if (!bootargs) + bootargs = "root=/dev/ram console=hvc0 earlycon=sbi"; } else { - s << " bootargs = \"console=hvc0 earlycon=sbi\";\n"; + if (!bootargs) + bootargs = "console=hvc0 earlycon=sbi"; } + s << " bootargs = \""; + for (size_t i = 0; i < strlen(bootargs); i++) { + if (bootargs[i] == '"') + s << '\\' << bootargs[i]; + else + s << bootargs[i]; + } + s << "\";\n"; s << " };\n" " cpus {\n" " #address-cells = <1>;\n" -- cgit v1.1