diff options
author | Jaydeep Patil <Jaydeep.Patil@imgtec.com> | 2023-10-18 17:37:59 +0100 |
---|---|---|
committer | Andrew Burgess <aburgess@redhat.com> | 2023-10-18 17:55:31 +0100 |
commit | 1c37b30945073f34bbb685d2ac47ab01e0c93d45 (patch) | |
tree | 6a930551898f502f4fcaabfc60b03bf6b9544432 /sim | |
parent | 29736fc507c7a9c6e797b7f83e8df4be73d37767 (diff) | |
download | gdb-1c37b30945073f34bbb685d2ac47ab01e0c93d45.zip gdb-1c37b30945073f34bbb685d2ac47ab01e0c93d45.tar.gz gdb-1c37b30945073f34bbb685d2ac47ab01e0c93d45.tar.bz2 |
sim/riscv: fix JALR instruction simulation
Fix 32bit 'jalr rd,ra,imm' integer instruction, where RD was written
before using it to calculate destination address.
This commit also improves testutils.inc for riscv; make use of
pushsection and popsection when adding things to .data, and setup the
%gp global pointer register within the 'start' macro.
Approved-By: Andrew Burgess <aburgess@redhat.com>
Diffstat (limited to 'sim')
-rw-r--r-- | sim/riscv/sim-main.c | 2 | ||||
-rw-r--r-- | sim/testsuite/riscv/jalr.s | 22 | ||||
-rw-r--r-- | sim/testsuite/riscv/testutils.inc | 12 |
3 files changed, 32 insertions, 4 deletions
diff --git a/sim/riscv/sim-main.c b/sim/riscv/sim-main.c index 2507916..afdfcf5 100644 --- a/sim/riscv/sim-main.c +++ b/sim/riscv/sim-main.c @@ -449,8 +449,8 @@ execute_i (SIM_CPU *cpu, unsigned_word iw, const struct riscv_opcode *op) break; case MATCH_JALR: TRACE_INSN (cpu, "jalr %s, %s, %" PRIiTW ";", rd_name, rs1_name, i_imm); - store_rd (cpu, rd, riscv_cpu->pc + 4); pc = riscv_cpu->regs[rs1] + i_imm; + store_rd (cpu, rd, riscv_cpu->pc + 4); TRACE_BRANCH (cpu, "to %#" PRIxTW, pc); break; diff --git a/sim/testsuite/riscv/jalr.s b/sim/testsuite/riscv/jalr.s new file mode 100644 index 0000000..daccf4f --- /dev/null +++ b/sim/testsuite/riscv/jalr.s @@ -0,0 +1,22 @@ +# Basic jalr tests. +# mach: riscv + +.include "testutils.inc" + + start + + # Load desination into register a0. + la a0, good_dest + + # Jump to the destination in a0. + jalr a0, a0, 0 + + # If we write destination into a0 before reading it in order + # to jump, we might end up here. +bad_dest: + fail + + # We should end up here. +good_dest: + pass + fail diff --git a/sim/testsuite/riscv/testutils.inc b/sim/testsuite/riscv/testutils.inc index b9680b9..c5e09eb 100644 --- a/sim/testsuite/riscv/testutils.inc +++ b/sim/testsuite/riscv/testutils.inc @@ -21,8 +21,9 @@ # Trigger OS trap. ecall; exit 0; - .data + .pushsection .data 1: .asciz "pass\n" + .popsection .endm # MACRO: fail @@ -33,14 +34,15 @@ # Use stdout. li a0, 1; # Point to the string. - lla a1, 1f; + la a1, 1f; # Number of bytes to write. li a2, 5; # Trigger OS trap. ecall; exit 0; - .data + .pushsection .data 1: .asciz "fail\n" + .popsection .endm # MACRO: start @@ -49,4 +51,8 @@ .text .global _start _start: + .option push + .option norelax + lla gp, __global_pointer$ + .option pop .endm |