aboutsummaryrefslogtreecommitdiff
path: root/spike_main/spike.cc
diff options
context:
space:
mode:
authorAnup Patel <anup.patel@wdc.com>2020-02-14 11:31:38 +0530
committerAnup Patel <anup@brainfault.org>2020-02-14 11:31:38 +0530
commit813ab1718417e09465edc2ed2e4910ce4a58f07a (patch)
tree2d646f0a1b7fc1fa76e7f15f5dd7c2473d1e8ac4 /spike_main/spike.cc
parent6baf42ac1d93c82ff59669c00a6a8991e3b7e4e1 (diff)
downloadspike-813ab1718417e09465edc2ed2e4910ce4a58f07a.zip
spike-813ab1718417e09465edc2ed2e4910ce4a58f07a.tar.gz
spike-813ab1718417e09465edc2ed2e4910ce4a58f07a.tar.bz2
Make spike capable of booting Linux
Latest Linux does not boot Spike mainly because: 1. Spike does not set bootargs in DTS 2. Spike does not provide mechanism to load initrd for Linux This patch addresses both above issues and we can now get latest Linux to prompt on Spike. Signed-off-by: Anup Patel <anup.patel@wdc.com>
Diffstat (limited to 'spike_main/spike.cc')
-rw-r--r--spike_main/spike.cc40
1 files changed, 39 insertions, 1 deletions
diff --git a/spike_main/spike.cc b/spike_main/spike.cc
index 4656a0a..f14ef87 100644
--- a/spike_main/spike.cc
+++ b/spike_main/spike.cc
@@ -12,6 +12,7 @@
#include <vector>
#include <string>
#include <memory>
+#include <fstream>
#include "../VERSION"
static void help(int exit_code = 1)
@@ -49,6 +50,7 @@ static void help(int exit_code = 1)
fprintf(stderr, " --rbb-port=<port> Listen on <port> for remote bitbang connection\n");
fprintf(stderr, " --dump-dts Print device tree string and exit\n");
fprintf(stderr, " --disable-dtb Don't write the device tree blob into memory\n");
+ fprintf(stderr, " --initrd=<path> Load kernel initrd into memory\n");
fprintf(stderr, " --dm-progsize=<words> Progsize for the debug module [default 2]\n");
fprintf(stderr, " --dm-sba=<bits> Debug bus master supports up to "
"<bits> wide accesses [default 0]\n");
@@ -70,6 +72,26 @@ static void suggest_help()
exit(1);
}
+static bool check_file_exists(const char *fileName)
+{
+ std::ifstream infile(fileName);
+ return infile.good();
+}
+
+static std::ifstream::pos_type get_file_size(const char *filename)
+{
+ std::ifstream in(filename, std::ios::ate | std::ios::binary);
+ return in.tellg();
+}
+
+static void read_file_bytes(const char *filename,size_t fileoff,
+ char *read_buf, size_t read_sz)
+{
+ std::ifstream in(filename, std::ios::in | std::ios::binary);
+ in.seekg(fileoff, std::ios::beg);
+ in.read(read_buf, read_sz);
+}
+
static std::vector<std::pair<reg_t, mem_t*>> make_mems(const char* arg)
{
// handle legacy mem argument
@@ -110,6 +132,8 @@ int main(int argc, char** argv)
bool dump_dts = false;
bool dtb_enabled = true;
size_t nprocs = 1;
+ size_t initrd_size;
+ reg_t initrd_start = 0, initrd_end = 0;
reg_t start_pc = reg_t(-1);
std::vector<std::pair<reg_t, mem_t*>> mems;
std::vector<std::pair<reg_t, abstract_device_t*>> plugin_devices;
@@ -119,6 +143,7 @@ int main(int argc, char** argv)
bool log_cache = false;
bool log_commits = false;
std::function<extension_t*()> extension;
+ const char* initrd = NULL;
const char* isa = DEFAULT_ISA;
const char* priv = DEFAULT_PRIV;
const char* varch = DEFAULT_VARCH;
@@ -215,6 +240,7 @@ int main(int argc, char** argv)
parser.option(0, "extension", 1, [&](const char* s){extension = find_extension(s);});
parser.option(0, "dump-dts", 0, [&](const char *s){dump_dts = true;});
parser.option(0, "disable-dtb", 0, [&](const char *s){dtb_enabled = false;});
+ parser.option(0, "initrd", 1, [&](const char* s){initrd = s;});
parser.option(0, "extlib", 1, [&](const char *s){
void *lib = dlopen(s, RTLD_NOW | RTLD_GLOBAL);
if (lib == NULL) {
@@ -248,7 +274,19 @@ int main(int argc, char** argv)
if (!*argv1)
help();
- sim_t s(isa, priv, varch, nprocs, halted, start_pc, mems, plugin_devices, htif_args,
+ if (initrd && check_file_exists(initrd)) {
+ initrd_size = get_file_size(initrd);
+ for (auto& m : mems) {
+ if (initrd_size && (initrd_size + 0x1000) < m.second->size()) {
+ initrd_end = m.first + m.second->size() - 0x1000;
+ initrd_start = initrd_end - initrd_size;
+ read_file_bytes(initrd, 0, m.second->contents() + (initrd_start - m.first), initrd_size);
+ break;
+ }
+ }
+ }
+
+ sim_t s(isa, priv, varch, nprocs, halted, initrd_start, initrd_end, start_pc, mems, plugin_devices, htif_args,
std::move(hartids), dm_config);
std::unique_ptr<remote_bitbang_t> remote_bitbang((remote_bitbang_t *) NULL);
std::unique_ptr<jtag_dtm_t> jtag_dtm(