diff options
author | Mike Frysinger <vapier@gentoo.org> | 2015-05-21 23:16:45 +0800 |
---|---|---|
committer | Mike Frysinger <vapier@gentoo.org> | 2021-02-04 19:02:19 -0500 |
commit | b9249c461c72b35dd9b6f274406c336f6a68ae98 (patch) | |
tree | 2f2314445c8c95e8dc1c3c8de6d824e9042b15fe /sim/testsuite/riscv | |
parent | a9ab6e2ea07829d89b97d1f47ecb524c251252e7 (diff) | |
download | binutils-b9249c461c72b35dd9b6f274406c336f6a68ae98.zip binutils-b9249c461c72b35dd9b6f274406c336f6a68ae98.tar.gz binutils-b9249c461c72b35dd9b6f274406c336f6a68ae98.tar.bz2 |
sim: riscv: new port
This is a hand-written implementation that should have fairly complete
coverage for the base integer instruction set ("i"), and for the atomic
("a") and integer multiplication+division ("m") extensions. It also
covers 32-bit & 64-bit targets.
The unittest coverage is a bit weak atm, but should get better.
Diffstat (limited to 'sim/testsuite/riscv')
-rw-r--r-- | sim/testsuite/riscv/ChangeLog | 3 | ||||
-rw-r--r-- | sim/testsuite/riscv/allinsn.exp | 15 | ||||
-rw-r--r-- | sim/testsuite/riscv/pass.s | 7 | ||||
-rw-r--r-- | sim/testsuite/riscv/testutils.inc | 52 |
4 files changed, 77 insertions, 0 deletions
diff --git a/sim/testsuite/riscv/ChangeLog b/sim/testsuite/riscv/ChangeLog new file mode 100644 index 0000000..c222209 --- /dev/null +++ b/sim/testsuite/riscv/ChangeLog @@ -0,0 +1,3 @@ +2021-02-04 Mike Frysinger <vapier@gentoo.org> + + * allinsn.exp, pass.s, testutils.inc: New files. diff --git a/sim/testsuite/riscv/allinsn.exp b/sim/testsuite/riscv/allinsn.exp new file mode 100644 index 0000000..03bec1b --- /dev/null +++ b/sim/testsuite/riscv/allinsn.exp @@ -0,0 +1,15 @@ +# RISC-V simulator testsuite. + +if [istarget riscv*-*] { + # all machines + set all_machs "riscv" + + foreach src [lsort [glob -nocomplain $srcdir/$subdir/*.s]] { + # If we're only testing specific files and this isn't one of them, + # skip it. + if ![runtest_file_p $runtests $src] { + continue + } + run_sim_test $src $all_machs + } +} diff --git a/sim/testsuite/riscv/pass.s b/sim/testsuite/riscv/pass.s new file mode 100644 index 0000000..bd428ca --- /dev/null +++ b/sim/testsuite/riscv/pass.s @@ -0,0 +1,7 @@ +# check that the sim doesn't die immediately. +# mach: riscv + +.include "testutils.inc" + + start + pass diff --git a/sim/testsuite/riscv/testutils.inc b/sim/testsuite/riscv/testutils.inc new file mode 100644 index 0000000..b9680b9 --- /dev/null +++ b/sim/testsuite/riscv/testutils.inc @@ -0,0 +1,52 @@ +# MACRO: exit + .macro exit nr + li a0, \nr + # The exit utility function. + li a7, 93; + # Trigger OS trap. + ecall; + .endm + +# MACRO: pass +# Write 'pass' to stdout and quit. + .macro pass + # syscall write(). + li a7, 64; + # Use stdout. + li a0, 1; + # Point to the string. + lla a1, 1f; + # Number of bytes to write. + li a2, 5; + # Trigger OS trap. + ecall; + exit 0; + .data + 1: .asciz "pass\n" + .endm + +# MACRO: fail +# Write 'fail' to stdout and quit. + .macro fail + # syscall write(). + li a7, 64; + # Use stdout. + li a0, 1; + # Point to the string. + lla a1, 1f; + # Number of bytes to write. + li a2, 5; + # Trigger OS trap. + ecall; + exit 0; + .data + 1: .asciz "fail\n" + .endm + +# MACRO: start +# All assembler tests should start with a call to "start". + .macro start + .text +.global _start +_start: + .endm |