qemu-patch-raspberry4/tests/tcg/cris/bare/check_addxm.s
Alex Bennée d4f6e58fcb tests/tcg: split cris tests into bare and libc directories
Bare tests are standalone assembly tests that don't require linking to
any libc and hence can be built with kernel only compilers. The libc
tests need a compiler capable of building properly linked userspace
binaries. As we don't have such a cross compiler at the moment we
won't be building those tests.

Signed-off-by: Alex Bennée <alex.bennee@linaro.org>
2019-03-12 17:05:21 +00:00

107 lines
1.5 KiB
ArmAsm

# mach: crisv0 crisv3 crisv8 crisv10 crisv32
# output: 1\n1\n101\n10001\n100fe\n1fffe\nfffe\nfffe\nfffffffe\nfe\nfffffffe\n781344db\n781343db\n78143bdb\n78133bdb\n800000ed\n0\n
.include "testutils.inc"
.data
x:
.byte 0xff
.word 0xffff
.word 0xff
.word 0xffff
.byte 0x89
.word 0xf789
.byte 0xff
.word 0xffff
start
moveq 2,r3
move.d x,r5
adds.b [r5+],r3
test_cc 0 0 0 1
checkr3 1
moveq 2,r3
adds.w [r5+],r3
test_cc 0 0 0 1
checkr3 1
moveq 2,r3
subq 3,r5
addu.b [r5+],r3
test_cc 0 0 0 0
checkr3 101
moveq 2,r3
addu.w [r5+],r3
subq 3,r5
test_cc 0 0 0 0
checkr3 10001
move.d 0xffff,r3
addu.b [r5],r3
test_cc 0 0 0 0
checkr3 100fe
move.d 0xffff,r3
addu.w [r5],r3
test_cc 0 0 0 0
checkr3 1fffe
move.d 0xffff,r3
adds.b [r5],r3
test_cc 0 0 0 1
checkr3 fffe
move.d 0xffff,r3
adds.w [r5],r3
test_cc 0 0 0 1
checkr3 fffe
moveq -1,r3
adds.b [r5],r3
test_cc 1 0 0 1
addq 3,r5
checkr3 fffffffe
moveq -1,r3
adds.w [r5+],r3
test_cc 0 0 0 1
checkr3 fe
moveq -1,r3
adds.w [r5+],r3
test_cc 1 0 0 1
checkr3 fffffffe
move.d 0x78134452,r3
addu.b [r5],r3
test_cc 0 0 0 0
checkr3 781344db
move.d 0x78134452,r3
adds.b [r5+],r3
test_cc 0 0 0 1
checkr3 781343db
move.d 0x78134452,r3
addu.w [r5],r3
test_cc 0 0 0 0
checkr3 78143bdb
move.d 0x78134452,r3
adds.w [r5+],r3
test_cc 0 0 0 1
checkr3 78133bdb
move.d 0x7fffffee,r3
addu.b [r5+],r3
test_cc 1 0 1 0
checkr3 800000ed
move.d 0x1,r3
adds.w [r5+],r3
test_cc 0 1 0 1
checkr3 0
quit