aboutsummaryrefslogtreecommitdiff
path: root/debug/programs/trigger.S
diff options
context:
space:
mode:
authorTim Newsome <tim@sifive.com>2016-09-01 10:07:54 -0700
committerTim Newsome <tim@sifive.com>2016-09-01 16:35:15 -0700
commit83e90dd49da860c4af50325dec13355abe5386bb (patch)
treecac89ae5f82bece728d6eabe9d6a53bb08b9f0e8 /debug/programs/trigger.S
parent1099c0dadd3c315d81ba5ef2e8712b6c08076ae2 (diff)
downloadriscv-tests-83e90dd49da860c4af50325dec13355abe5386bb.zip
riscv-tests-83e90dd49da860c4af50325dec13355abe5386bb.tar.gz
riscv-tests-83e90dd49da860c4af50325dec13355abe5386bb.tar.bz2
Create TriggerTest.
Diffstat (limited to 'debug/programs/trigger.S')
-rw-r--r--debug/programs/trigger.S97
1 files changed, 97 insertions, 0 deletions
diff --git a/debug/programs/trigger.S b/debug/programs/trigger.S
new file mode 100644
index 0000000..e5dfa67
--- /dev/null
+++ b/debug/programs/trigger.S
@@ -0,0 +1,97 @@
+#include "../../env/encoding.h"
+
+#undef MCONTROL_TYPE
+#undef MCONTROL_DMODE
+#ifdef __riscv64
+# define MCONTROL_TYPE (0xfU<<((64)-4))
+# define MCONTROL_DMODE (1U<<((64)-5))
+#else
+# define MCONTROL_TYPE (0xfU<<((32)-4))
+# define MCONTROL_DMODE (1U<<((32)-5))
+#endif
+
+ .global main
+
+ .section .text
+main:
+
+ la a0, data
+ li t0, 0
+ li t2, 16
+read_loop:
+ lw t1, 0(a0)
+ addi a0, a0, 4
+ addi t0, t0, 1
+ blt t0, t2, read_loop
+
+ la a0, data
+ li t0, 0
+write_loop:
+ addi t0, t0, 1
+ sw t0, 0(a0)
+ addi a0, a0, 4
+ blt t0, t2, write_loop
+
+ j main_exit
+
+write_valid:
+ li t0, 0
+ li t2, MCONTROL_DMODE
+ li t3, MCONTROL_TYPE
+write_valid_loop:
+ csrw CSR_TSELECT, t0
+ csrr t1, CSR_TSELECT
+ bne t0, t1, main_exit
+ addi t0, t0, 1
+ csrr t1, CSR_TDATA1
+ and t4, t1, t3
+ beqz t4, main_error # type is 0
+ and t1, t1, t2
+ bnez t1, write_valid_loop
+ # Found an entry with dmode=0
+ csrw CSR_TDATA1, zero # this should succeed
+
+write_invalid:
+ li t0, 0
+ li t2, MCONTROL_DMODE
+ li t3, MCONTROL_TYPE
+write_invalid_loop:
+ csrw CSR_TSELECT, t0
+ csrr t1, CSR_TSELECT
+ bne t0, t1, main_exit
+ addi t0, t0, 1
+ csrr t1, CSR_TDATA1
+ and t4, t1, t3
+ beqz t4, main_error # type is 0
+ and t1, t1, t2
+ beqz t1, write_invalid_loop
+ # Found an entry with dmode=1
+write_invalid_illegal:
+ csrw CSR_TDATA1, zero # this should fail
+
+
+main_exit:
+ li a0, 0
+ j _exit
+
+main_error:
+ li a0, 1
+ j _exit
+
+ .data
+data: .word 0x40
+ .word 0x41
+ .word 0x42
+ .word 0x43
+ .word 0x44
+ .word 0x45
+ .word 0x46
+ .word 0x47
+ .word 0x48
+ .word 0x49
+ .word 0x4a
+ .word 0x4b
+ .word 0x4c
+ .word 0x4d
+ .word 0x4e
+ .word 0x4f