summaryrefslogtreecommitdiff
path: root/sim/testsuite/sim/cris/asm/movei.ms
diff options
context:
space:
mode:
Diffstat (limited to 'sim/testsuite/sim/cris/asm/movei.ms')
-rw-r--r--sim/testsuite/sim/cris/asm/movei.ms47
1 files changed, 47 insertions, 0 deletions
diff --git a/sim/testsuite/sim/cris/asm/movei.ms b/sim/testsuite/sim/cris/asm/movei.ms
new file mode 100644
index 00000000000..8d55ae1cb68
--- /dev/null
+++ b/sim/testsuite/sim/cris/asm/movei.ms
@@ -0,0 +1,47 @@
+# mach: crisv32
+# output: fffffffe\n
+# output: fffffffe\n
+
+; Check basic integral-write semantics regarding flags.
+
+ .include "testutils.inc"
+ start
+
+; A write that works. Check that flags are set correspondingly.
+ move.d d,r4
+ moveq -2,r5
+ setf c
+ clearf p
+ move.d [r4],r3
+ ax
+ move.d r5,[r4]
+ move.d [r4],r3
+
+ bcc 0f
+ nop
+ fail
+
+0:
+ dumpr3 ; fffffffe
+
+; A write that fails; check flags too.
+ move.d d,r4
+ moveq 23,r5
+ setf p
+ clearf c
+ move.d [r4],r3
+ ax
+ move.d r5,[r4]
+ move.d [r4],r3
+
+ bcs 0f
+ nop
+ fail
+
+0:
+ dumpr3 ; fffffffe
+ quit
+
+ .data
+d:
+ .dword 42424242