summaryrefslogtreecommitdiffstats
path: root/tests/cris/check_movei.s
diff options
context:
space:
mode:
authorths <ths@c046a42c-6fe2-441c-8c8c-71466251a162>2007-10-08 13:32:20 +0000
committerths <ths@c046a42c-6fe2-441c-8c8c-71466251a162>2007-10-08 13:32:20 +0000
commitdd43edf4e136bff05cbbb6b42b96c024c591dbb9 (patch)
treed1f03b9c92753846ba462c5a1583af5106333d58 /tests/cris/check_movei.s
parent83fa1010ae342c5ad0392182fcdcce438c71b163 (diff)
downloadhqemu-dd43edf4e136bff05cbbb6b42b96c024c591dbb9.zip
hqemu-dd43edf4e136bff05cbbb6b42b96c024c591dbb9.tar.gz
CRIS testsuite, based on the SIM testsuite, by Edgar E. Iglesias.
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@3365 c046a42c-6fe2-441c-8c8c-71466251a162
Diffstat (limited to 'tests/cris/check_movei.s')
-rw-r--r--tests/cris/check_movei.s47
1 files changed, 47 insertions, 0 deletions
diff --git a/tests/cris/check_movei.s b/tests/cris/check_movei.s
new file mode 100644
index 0000000..2defda5
--- /dev/null
+++ b/tests/cris/check_movei.s
@@ -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:
+ checkr3 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:
+ checkr3 fffffffe
+ quit
+
+ .data
+d:
+ .dword 42424242
OpenPOWER on IntegriCloud