mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-04 00:03:54 -06:00
riscv/sifive_u: Add QSPI memory region
The HiFive Unleashed uses is25wp256 SPI NOR flash. There is currently no model of this in QEMU, so to allow boot firmware developers to use QEMU to target the Unleashed let's add a chunk of memory to represent the QSPI0 memory mapped flash. This can be targeted using QEMU's -device loader command line option. In the future we can look at adding a model for the is25wp256 flash. Signed-off-by: Alistair Francis <alistair.francis@wdc.com> Reviewed-by: Bin Meng <bmeng.cn@gmail.com> Signed-off-by: Palmer Dabbelt <palmer@sifive.com>
This commit is contained in:
parent
a6902ef0e3
commit
1b3a230870
2 changed files with 9 additions and 0 deletions
|
@ -71,6 +71,7 @@ static const struct MemmapEntry {
|
|||
[SIFIVE_U_UART0] = { 0x10010000, 0x1000 },
|
||||
[SIFIVE_U_UART1] = { 0x10011000, 0x1000 },
|
||||
[SIFIVE_U_OTP] = { 0x10070000, 0x1000 },
|
||||
[SIFIVE_U_FLASH0] = { 0x20000000, 0x10000000 },
|
||||
[SIFIVE_U_DRAM] = { 0x80000000, 0x0 },
|
||||
[SIFIVE_U_GEM] = { 0x10090000, 0x2000 },
|
||||
[SIFIVE_U_GEM_MGMT] = { 0x100a0000, 0x1000 },
|
||||
|
@ -314,6 +315,7 @@ static void riscv_sifive_u_init(MachineState *machine)
|
|||
SiFiveUState *s = g_new0(SiFiveUState, 1);
|
||||
MemoryRegion *system_memory = get_system_memory();
|
||||
MemoryRegion *main_mem = g_new(MemoryRegion, 1);
|
||||
MemoryRegion *flash0 = g_new(MemoryRegion, 1);
|
||||
int i;
|
||||
|
||||
/* Initialize SoC */
|
||||
|
@ -329,6 +331,12 @@ static void riscv_sifive_u_init(MachineState *machine)
|
|||
memory_region_add_subregion(system_memory, memmap[SIFIVE_U_DRAM].base,
|
||||
main_mem);
|
||||
|
||||
/* register QSPI0 Flash */
|
||||
memory_region_init_ram(flash0, NULL, "riscv.sifive.u.flash0",
|
||||
memmap[SIFIVE_U_FLASH0].size, &error_fatal);
|
||||
memory_region_add_subregion(system_memory, memmap[SIFIVE_U_FLASH0].base,
|
||||
flash0);
|
||||
|
||||
/* create device tree */
|
||||
create_fdt(s, memmap, machine->ram_size, machine->kernel_cmdline);
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue