aboutsummaryrefslogtreecommitdiff
path: root/sim/testsuite/cris/asm/lapc.ms
diff options
context:
space:
mode:
Diffstat (limited to 'sim/testsuite/cris/asm/lapc.ms')
-rw-r--r--sim/testsuite/cris/asm/lapc.ms78
1 files changed, 78 insertions, 0 deletions
diff --git a/sim/testsuite/cris/asm/lapc.ms b/sim/testsuite/cris/asm/lapc.ms
new file mode 100644
index 0000000..bacd881
--- /dev/null
+++ b/sim/testsuite/cris/asm/lapc.ms
@@ -0,0 +1,78 @@
+# mach: crisv32
+# output: 0\n0\nfffffffa\nfffffffe\nffffffda\n1e\n1e\n0\n
+
+ .include "testutils.inc"
+
+; To accommodate dumpr3 with more than one instruction, keep it
+; out of lapc operand ranges and difference calculations.
+
+ start
+ lapc.d 0f,r3
+0:
+ sub.d .,r3
+ dumpr3 ; 0
+
+ lapcq 0f,r3
+0:
+ sub.d .,r3
+ dumpr3 ; 0
+
+ lapc.d .,r3
+ sub.d .,r3
+ dumpr3 ; fffffffa
+
+ lapcq .,r3
+ sub.d .,r3
+ dumpr3 ; fffffffe
+
+0:
+ .rept 16
+ nop
+ .endr
+ lapc.d 0b,r3
+ sub.d .,r3
+ dumpr3 ; ffffffda
+
+ setf zcvn
+ lapc.d 0f,r3
+ test_cc 1 1 1 1
+ sub.d .,r3
+ nop
+ nop
+ nop
+ nop
+ nop
+ nop
+ nop
+ nop
+ nop
+ nop
+ nop
+ nop
+0:
+ dumpr3 ; 1e
+0:
+ lapcq 0f,r3
+ sub.d 0b,r3
+ nop
+ nop
+ nop
+ nop
+ nop
+ nop
+ nop
+ nop
+ nop
+ nop
+ nop
+0:
+ dumpr3 ; 1e
+ clearf cn
+ setf zv
+1:
+ lapcq .,r3
+ test_cc 0 1 1 0
+ sub.d 1b,r3
+ dumpr3 ; 0
+
+ quit