aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--riscv/sim.cc13
1 files changed, 13 insertions, 0 deletions
diff --git a/riscv/sim.cc b/riscv/sim.cc
index 97b3746..2ee05d6 100644
--- a/riscv/sim.cc
+++ b/riscv/sim.cc
@@ -6,6 +6,7 @@
#include "remote_bitbang.h"
#include "byteorder.h"
#include "platform.h"
+#include "libfdt.h"
#include <fstream>
#include <map>
#include <iostream>
@@ -296,6 +297,18 @@ void sim_t::make_dtb()
dts = make_dts(INSNS_PER_RTC_TICK, CPU_HZ, initrd_start, initrd_end, bootargs, procs, mems);
dtb = dts_compile(dts);
}
+
+ int fdt_code = fdt_check_header(dtb.c_str());
+ if (fdt_code) {
+ std::cerr << "Failed to read DTB from ";
+ if (dtb_file.empty()) {
+ std::cerr << "auto-generated DTS string";
+ } else {
+ std::cerr << "`" << dtb_file << "'";
+ }
+ std::cerr << ": " << fdt_strerror(fdt_code) << ".\n";
+ exit(-1);
+ }
}
void sim_t::set_rom()