aboutsummaryrefslogtreecommitdiff
path: root/sim/testsuite/riscv
diff options
context:
space:
mode:
authorMike Frysinger <vapier@gentoo.org>2015-05-21 23:16:45 +0800
committerMike Frysinger <vapier@gentoo.org>2021-02-04 19:02:19 -0500
commitb9249c461c72b35dd9b6f274406c336f6a68ae98 (patch)
tree2f2314445c8c95e8dc1c3c8de6d824e9042b15fe /sim/testsuite/riscv
parenta9ab6e2ea07829d89b97d1f47ecb524c251252e7 (diff)
downloadbinutils-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/ChangeLog3
-rw-r--r--sim/testsuite/riscv/allinsn.exp15
-rw-r--r--sim/testsuite/riscv/pass.s7
-rw-r--r--sim/testsuite/riscv/testutils.inc52
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