symbian-qemu-0.9.1-12/qemu-symbian-svp/tests/cris/check_mulv32.s
author Shane McErlean <shane.mcerlean@accenture.com>
Thu, 19 Aug 2010 17:55:25 +0100
changeset 100 99a56c5faf9c
parent 1 2fb8b9db1c86
permissions -rw-r--r--
SF Bug 1284 - QEMU has faulty instruction emulation for VMOV (between two ARM core registers and two single-precision registers)

# mach: crisv32
# output: fffffffe\n
# output: ffffffff\n
# output: fffffffe\n
# output: 1\n
# output: fffffffe\n
# output: ffffffff\n
# output: fffffffe\n
# output: 1\n

; Check that carry is not modified on v32.

 .include "testutils.inc"
 start
 moveq -1,r3
 moveq 2,r4
 setf c
 muls.d r4,r3
 test_cc 1 0 0 1
 checkr3 fffffffe
 move mof,r3
 checkr3 ffffffff

 moveq -1,r3
 moveq 2,r4
 setf c
 mulu.d r4,r3
 test_cc 0 0 1 1
 checkr3 fffffffe
 move mof,r3
 checkr3 1

 moveq -1,r3
 moveq 2,r4
 clearf c
 muls.d r4,r3
 test_cc 1 0 0 0
 checkr3 fffffffe
 move mof,r3
 checkr3 ffffffff

 moveq -1,r3
 moveq 2,r4
 clearf c
 mulu.d r4,r3
 test_cc 0 0 1 0
 checkr3 fffffffe
 move mof,r3
 checkr3 1

 quit