Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Refactor: Adjust bootrom reset vector address #196

Merged
merged 9 commits into from
Nov 2, 2023
2 changes: 1 addition & 1 deletion src/main/resources/testchipip/bootrom/bootrom.S
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
#define BOOTADDR_REG 0x4000
#define BOOTADDR_REG 0x1000
jerryz123 marked this conversation as resolved.
Show resolved Hide resolved

// boot all cores (only hart 0) and jump to main program execution
.section .text.start, "ax", @progbits
Expand Down
63 changes: 63 additions & 0 deletions src/main/resources/testchipip/bootrom/bootrom.rv32.dump
Original file line number Diff line number Diff line change
@@ -0,0 +1,63 @@

bootrom.rv32.elf: file format elf32-littleriscv


Disassembly of section .text.hang:

00010000 <_hang>:
10000: 00000517 auipc a0,0x0
10004: 04050513 addi a0,a0,64 # 10040 <_start>
10008: 30551073 csrw mtvec,a0
1000c: 301022f3 csrr t0,misa
10010: 4122d293 srai t0,t0,0x12
10014: 0012f293 andi t0,t0,1
10018: 00028463 beqz t0,10020 <_hang+0x20>
1001c: 30301073 csrw mideleg,zero
10020: 00800513 li a0,8
10024: 30451073 csrw mie,a0
10028: 30052073 csrs mstatus,a0

0001002c <wfi_loop>:
1002c: 10500073 wfi
10030: ffdff06f j 1002c <wfi_loop>

Disassembly of section .text.start:

00010040 <_start>:
10040: 020005b7 lui a1,0x2000
10044: f1402573 csrr a0,mhartid
10048: 00050463 beqz a0,10050 <_start+0x10>
1004c: 0380006f j 10084 <boot_core>
10050: 00458613 addi a2,a1,4 # 2000004 <_dtb+0x1feff44>
10054: 00100693 li a3,1

00010058 <interrupt_loop>:
10058: 00d62023 sw a3,0(a2)
1005c: 00460613 addi a2,a2,4
10060: ffc62683 lw a3,-4(a2)
10064: fe069ae3 bnez a3,10058 <interrupt_loop>
10068: 02c0006f j 10094 <boot_core_hart0>

Disassembly of section .text.hang80:

00010080 <_hang80>:
10080: f81ff06f j 10000 <ROM_BASE>

00010084 <boot_core>:
10084: 0005a283 lw t0,0(a1)
10088: fe029ee3 bnez t0,10084 <boot_core>
1008c: 00251513 slli a0,a0,0x2
10090: 00b505b3 add a1,a0,a1

00010094 <boot_core_hart0>:
10094: 0005a023 sw zero,0(a1)
10098: 00001537 lui a0,0x1
1009c: 00052503 lw a0,0(a0) # 1000 <ROM_BASE-0xf000>
100a0: 34151073 csrw mepc,a0
100a4: f1402573 csrr a0,mhartid
100a8: 00000597 auipc a1,0x0
100ac: 01858593 addi a1,a1,24 # 100c0 <_dtb>
100b0: 08000613 li a2,128
100b4: 30063073 csrc mstatus,a2
100b8: 30200073 mret
100bc: 00000013 nop
Binary file modified src/main/resources/testchipip/bootrom/bootrom.rv32.img
Binary file not shown.
63 changes: 63 additions & 0 deletions src/main/resources/testchipip/bootrom/bootrom.rv64.dump
Original file line number Diff line number Diff line change
@@ -0,0 +1,63 @@

bootrom.rv64.elf: file format elf64-littleriscv


Disassembly of section .text.hang:

0000000000010000 <_hang>:
10000: 00000517 auipc a0,0x0
10004: 04050513 addi a0,a0,64 # 10040 <_start>
10008: 30551073 csrw mtvec,a0
1000c: 301022f3 csrr t0,misa
10010: 4122d293 srai t0,t0,0x12
10014: 0012f293 andi t0,t0,1
10018: 00028463 beqz t0,10020 <_hang+0x20>
1001c: 30301073 csrw mideleg,zero
10020: 00800513 li a0,8
10024: 30451073 csrw mie,a0
10028: 30052073 csrs mstatus,a0

000000000001002c <wfi_loop>:
1002c: 10500073 wfi
10030: ffdff06f j 1002c <wfi_loop>

Disassembly of section .text.start:

0000000000010040 <_start>:
10040: 020005b7 lui a1,0x2000
10044: f1402573 csrr a0,mhartid
10048: 00050463 beqz a0,10050 <_start+0x10>
1004c: 0380006f j 10084 <boot_core>
10050: 00458613 addi a2,a1,4 # 2000004 <_dtb+0x1feff44>
10054: 00100693 li a3,1

0000000000010058 <interrupt_loop>:
10058: 00d62023 sw a3,0(a2)
1005c: 00460613 addi a2,a2,4
10060: ffc62683 lw a3,-4(a2)
10064: fe069ae3 bnez a3,10058 <interrupt_loop>
10068: 02c0006f j 10094 <boot_core_hart0>

Disassembly of section .text.hang80:

0000000000010080 <_hang80>:
10080: f81ff06f j 10000 <ROM_BASE>

0000000000010084 <boot_core>:
10084: 0005a283 lw t0,0(a1)
10088: fe029ee3 bnez t0,10084 <boot_core>
1008c: 00251513 slli a0,a0,0x2
10090: 00b505b3 add a1,a0,a1

0000000000010094 <boot_core_hart0>:
10094: 0005a023 sw zero,0(a1)
10098: 00001537 lui a0,0x1
1009c: 00053503 ld a0,0(a0) # 1000 <ROM_BASE-0xf000>
100a0: 34151073 csrw mepc,a0
100a4: f1402573 csrr a0,mhartid
100a8: 00000597 auipc a1,0x0
100ac: 01858593 addi a1,a1,24 # 100c0 <_dtb>
100b0: 08000613 li a2,128
100b4: 30063073 csrc mstatus,a2
100b8: 30200073 mret
100bc: 00000013 nop
Binary file modified src/main/resources/testchipip/bootrom/bootrom.rv64.img
Binary file not shown.
4 changes: 2 additions & 2 deletions src/main/resources/testchipip/bootrom/linker.ld
Original file line number Diff line number Diff line change
Expand Up @@ -3,9 +3,9 @@ SECTIONS
ROM_BASE = 0x10000; /* ... but actually position independent */

. = ROM_BASE;
.text.start : { *(.text.start) }
. = ROM_BASE + 0x40;
.text.hang : { *(.text.hang) }
. = ROM_BASE + 0x40;
.text.start : { *(.text.start) }
. = ROM_BASE + 0x80;
.text.hang80 : { *(.text.hang80) }
}
10 changes: 7 additions & 3 deletions src/main/resources/testchipip/csrc/cospike_impl.cc
Original file line number Diff line number Diff line change
Expand Up @@ -30,13 +30,17 @@ extern std::map<long long int, backing_data_t> backing_mem_data;
#endif
#endif

#define BOOT_ADDR_BASE (0x1000)
#define CLINT_BASE (0x2000000)
#define CLINT_SIZE (0x10000)
#define UART_BASE (0x54000000)
#define UART_SIZE (0x1000)
#define PLIC_BASE (0xc000000)
#define PLIC_SIZE (0x4000000)

// address of the PC register after reset
#define RESET_VECTOR (0x10000)

#define COSPIKE_PRINTF(...) { \
printf(__VA_ARGS__); \
fprintf(stderr, __VA_ARGS__); \
Expand Down Expand Up @@ -179,7 +183,7 @@ int cospike_cosim(long long int cycle,
info->bootrom.resize(default_boot_rom_size);

std::shared_ptr<rom_device_t> boot_rom = std::make_shared<rom_device_t>(info->bootrom);
std::shared_ptr<mem_t> boot_addr_reg = std::make_shared<mem_t>(0x1000);
std::shared_ptr<mem_t> boot_addr_reg = std::make_shared<mem_t>(BOOT_ADDR_BASE);
uint64_t default_boot_addr = 0x80000000;
boot_addr_reg.get()->store(0, 8, (const uint8_t*)(&default_boot_addr));

Expand All @@ -192,7 +196,7 @@ int cospike_cosim(long long int cycle,
read_override_devices.push_back(plic);

// The device map is hardcoded here for now
devices.push_back(std::pair(0x4000, boot_addr_reg));
devices.push_back(std::pair(BOOT_ADDR_BASE, boot_addr_reg));
devices.push_back(std::pair(default_boot_rom_addr, boot_rom));
devices.push_back(std::pair(CLINT_BASE, clint));
devices.push_back(std::pair(UART_BASE, uart));
Expand Down Expand Up @@ -251,7 +255,7 @@ int cospike_cosim(long long int cycle,
sim->configure_log(true, true);
for (int i = 0; i < info->nharts; i++) {
// Use our own reset vector
sim->get_core(hartid)->get_state()->pc = 0x10040;
sim->get_core(hartid)->get_state()->pc = RESET_VECTOR;
// Set MMU to support up to sv39, as our normal hw configs do
sim->get_core(hartid)->set_impl(IMPL_MMU_SV48, false);
sim->get_core(hartid)->set_impl(IMPL_MMU_SV57, false);
Expand Down
2 changes: 1 addition & 1 deletion src/main/scala/BootAddrReg.scala
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ import freechips.rocketchip.prci._

case class BootAddrRegParams(
defaultBootAddress: BigInt = 0x80000000L, // This should be DRAM_BASE
bootRegAddress: BigInt = 0x4000,
bootRegAddress: BigInt = 0x1000,
jerryz123 marked this conversation as resolved.
Show resolved Hide resolved
slaveWhere: TLBusWrapperLocation = PBUS
)
case object BootAddrRegKey extends Field[Option[BootAddrRegParams]](None)
Expand Down