mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2025-01-24 12:35:55 +08:00
1368b914e9
Now that all port tests live under testsuite/sim/*/, and none live in testsuite/ directly, flatten the structure by moving all of the dirs under testsuite/sim/ to testsuite/ directly. We need to stop passing --tool to dejagnu so that it searches all dirs and not just ones that start with "sim". Since we have no other dirs in this tree, and no plans to add any, should be fine.
402 lines
6.8 KiB
ArmAsm
402 lines
6.8 KiB
ArmAsm
# Hitachi H8 testcase 'stc'
|
|
# mach(): all
|
|
# as(h8300): --defsym sim_cpu=0
|
|
# as(h8300h): --defsym sim_cpu=1
|
|
# as(h8300s): --defsym sim_cpu=2
|
|
# as(h8sx): --defsym sim_cpu=3
|
|
# ld(h8300h): -m h8300helf
|
|
# ld(h8300s): -m h8300self
|
|
# ld(h8sx): -m h8300sxelf
|
|
|
|
.include "testutils.inc"
|
|
.data
|
|
byte_dest1:
|
|
.byte 0
|
|
.byte 0
|
|
byte_dest2:
|
|
.byte 0
|
|
.byte 0
|
|
byte_dest3:
|
|
.byte 0
|
|
.byte 0
|
|
byte_dest4:
|
|
.byte 0
|
|
.byte 0
|
|
byte_dest5:
|
|
.byte 0
|
|
.byte 0
|
|
byte_dest6:
|
|
.byte 0
|
|
.byte 0
|
|
byte_dest7:
|
|
.byte 0
|
|
.byte 0
|
|
byte_dest8:
|
|
.byte 0
|
|
.byte 0
|
|
byte_dest9:
|
|
.byte 0
|
|
.byte 0
|
|
byte_dest10:
|
|
.byte 0
|
|
.byte 0
|
|
byte_dest11:
|
|
.byte 0
|
|
.byte 0
|
|
byte_dest12:
|
|
.byte 0
|
|
.byte 0
|
|
|
|
start
|
|
|
|
stc_ccr_reg8:
|
|
set_grs_a5a5
|
|
set_ccr_zero
|
|
|
|
ldc #0xff, ccr ; test value
|
|
stc ccr, r0h ; copy test value to r0h
|
|
|
|
test_h_gr16 0xffa5 r0 ; ff in r0h, a5 in r0l
|
|
.if (sim_cpu) ; h/s/sx
|
|
test_h_gr32 0xa5a5ffa5 er0 ; ff in r0h, a5 everywhere else
|
|
.endif
|
|
test_gr_a5a5 1 ; Make sure other general regs not disturbed
|
|
test_gr_a5a5 2
|
|
test_gr_a5a5 3
|
|
test_gr_a5a5 4
|
|
test_gr_a5a5 5
|
|
test_gr_a5a5 6
|
|
test_gr_a5a5 7
|
|
|
|
.if (sim_cpu == h8300s || sim_cpu == h8sx) ; Earlier versions, no exr
|
|
stc_exr_reg8:
|
|
set_grs_a5a5
|
|
set_ccr_zero
|
|
|
|
ldc #0x87, exr ; set exr to 0x87
|
|
stc exr, r0l ; retrieve and check exr value
|
|
cmp.b #0x87, r0l
|
|
beq .L21
|
|
fail
|
|
.L21:
|
|
test_h_gr32 0xa5a5a587 er0 ; Register 0 modified by test procedure.
|
|
test_gr_a5a5 1 ; Make sure other general regs not disturbed
|
|
test_gr_a5a5 2
|
|
test_gr_a5a5 3
|
|
test_gr_a5a5 4
|
|
test_gr_a5a5 5
|
|
test_gr_a5a5 6
|
|
test_gr_a5a5 7
|
|
|
|
stc_ccr_abs16:
|
|
set_grs_a5a5
|
|
set_ccr_zero
|
|
|
|
ldc #0xff, ccr
|
|
stc ccr, @byte_dest1:16 ; abs16 dest
|
|
|
|
test_gr_a5a5 0 ; Make sure other general regs not disturbed
|
|
test_gr_a5a5 1
|
|
test_gr_a5a5 2
|
|
test_gr_a5a5 3
|
|
test_gr_a5a5 4
|
|
test_gr_a5a5 5
|
|
test_gr_a5a5 6
|
|
test_gr_a5a5 7
|
|
|
|
stc_exr_abs16:
|
|
set_grs_a5a5
|
|
set_ccr_zero
|
|
|
|
ldc #0x87, exr
|
|
stc exr, @byte_dest2:16 ; abs16 dest
|
|
|
|
test_gr_a5a5 0 ; Make sure other general regs not disturbed
|
|
test_gr_a5a5 1
|
|
test_gr_a5a5 2
|
|
test_gr_a5a5 3
|
|
test_gr_a5a5 4
|
|
test_gr_a5a5 5
|
|
test_gr_a5a5 6
|
|
test_gr_a5a5 7
|
|
|
|
stc_ccr_abs32:
|
|
set_grs_a5a5
|
|
set_ccr_zero
|
|
|
|
ldc #0xff, ccr
|
|
stc ccr, @byte_dest3:32 ; abs32 dest
|
|
|
|
test_gr_a5a5 0 ; Make sure other general regs not disturbed
|
|
test_gr_a5a5 1
|
|
test_gr_a5a5 2
|
|
test_gr_a5a5 3
|
|
test_gr_a5a5 4
|
|
test_gr_a5a5 5
|
|
test_gr_a5a5 6
|
|
test_gr_a5a5 7
|
|
|
|
stc_exr_abs32:
|
|
set_grs_a5a5
|
|
set_ccr_zero
|
|
|
|
ldc #0x87, exr
|
|
stc exr, @byte_dest4:32 ; abs32 dest
|
|
|
|
test_gr_a5a5 0 ; Make sure other general regs not disturbed
|
|
test_gr_a5a5 1
|
|
test_gr_a5a5 2
|
|
test_gr_a5a5 3
|
|
test_gr_a5a5 4
|
|
test_gr_a5a5 5
|
|
test_gr_a5a5 6
|
|
test_gr_a5a5 7
|
|
|
|
stc_ccr_disp16:
|
|
set_grs_a5a5
|
|
set_ccr_zero
|
|
|
|
mov #byte_dest5-1, er1
|
|
ldc #0xff, ccr
|
|
stc ccr, @(1:16,er1) ; disp16 dest (5)
|
|
|
|
test_h_gr32 byte_dest5-1, er1 ; er1 still contains address
|
|
|
|
test_gr_a5a5 0 ; Make sure other general regs not disturbed
|
|
test_gr_a5a5 2
|
|
test_gr_a5a5 3
|
|
test_gr_a5a5 4
|
|
test_gr_a5a5 5
|
|
test_gr_a5a5 6
|
|
test_gr_a5a5 7
|
|
|
|
stc_exr_disp16:
|
|
set_grs_a5a5
|
|
set_ccr_zero
|
|
|
|
mov #byte_dest6+1, er1
|
|
ldc #0x87, exr
|
|
stc exr, @(-1:16,er1) ; disp16 dest (6)
|
|
|
|
test_h_gr32 byte_dest6+1, er1 ; er1 still contains address
|
|
|
|
test_gr_a5a5 0 ; Make sure other general regs not disturbed
|
|
test_gr_a5a5 2
|
|
test_gr_a5a5 3
|
|
test_gr_a5a5 4
|
|
test_gr_a5a5 5
|
|
test_gr_a5a5 6
|
|
test_gr_a5a5 7
|
|
|
|
stc_ccr_disp32:
|
|
set_grs_a5a5
|
|
set_ccr_zero
|
|
|
|
mov #byte_dest7-1, er1
|
|
ldc #0xff, ccr
|
|
stc ccr, @(1:32,er1) ; disp32 dest (7)
|
|
|
|
test_h_gr32 byte_dest7-1, er1 ; er1 still contains address
|
|
|
|
test_gr_a5a5 0 ; Make sure other general regs not disturbed
|
|
test_gr_a5a5 2
|
|
test_gr_a5a5 3
|
|
test_gr_a5a5 4
|
|
test_gr_a5a5 5
|
|
test_gr_a5a5 6
|
|
test_gr_a5a5 7
|
|
|
|
stc_exr_disp32:
|
|
set_grs_a5a5
|
|
set_ccr_zero
|
|
|
|
mov #byte_dest8+1, er1
|
|
ldc #0x87, exr
|
|
stc exr, @(-1:32,er1) ; disp16 dest (8)
|
|
|
|
test_h_gr32 byte_dest8+1, er1 ; er1 still contains address
|
|
|
|
test_gr_a5a5 2 ; Make sure other general regs not disturbed
|
|
test_gr_a5a5 3
|
|
test_gr_a5a5 4
|
|
test_gr_a5a5 5
|
|
test_gr_a5a5 6
|
|
test_gr_a5a5 7
|
|
|
|
stc_ccr_predecr:
|
|
set_grs_a5a5
|
|
set_ccr_zero
|
|
|
|
mov #byte_dest9+2, er1
|
|
ldc #0xff, ccr
|
|
stc ccr, @-er1 ; predecr dest (9)
|
|
|
|
test_h_gr32 byte_dest9 er1 ; er1 still contains address
|
|
|
|
test_gr_a5a5 0 ; Make sure other general regs not disturbed
|
|
test_gr_a5a5 2
|
|
test_gr_a5a5 3
|
|
test_gr_a5a5 4
|
|
test_gr_a5a5 5
|
|
test_gr_a5a5 6
|
|
test_gr_a5a5 7
|
|
|
|
stc_exr_predecr:
|
|
set_grs_a5a5
|
|
set_ccr_zero
|
|
|
|
mov #byte_dest10+2, er1
|
|
ldc #0x87, exr
|
|
stc exr, @-er1 ; predecr dest (10)
|
|
|
|
test_h_gr32 byte_dest10, er1 ; er1 still contains address
|
|
|
|
test_gr_a5a5 0 ; Make sure other general regs not disturbed
|
|
test_gr_a5a5 2
|
|
test_gr_a5a5 3
|
|
test_gr_a5a5 4
|
|
test_gr_a5a5 5
|
|
test_gr_a5a5 6
|
|
test_gr_a5a5 7
|
|
|
|
stc_ccr_ind:
|
|
set_grs_a5a5
|
|
set_ccr_zero
|
|
|
|
mov #byte_dest11, er1
|
|
ldc #0xff, ccr
|
|
stc ccr, @er1 ; postinc dest (11)
|
|
|
|
test_h_gr32 byte_dest11, er1 ; er1 still contains address
|
|
|
|
test_gr_a5a5 0 ; Make sure other general regs not disturbed
|
|
test_gr_a5a5 2
|
|
test_gr_a5a5 3
|
|
test_gr_a5a5 4
|
|
test_gr_a5a5 5
|
|
test_gr_a5a5 6
|
|
test_gr_a5a5 7
|
|
|
|
stc_exr_ind:
|
|
set_grs_a5a5
|
|
set_ccr_zero
|
|
|
|
mov #byte_dest12, er1
|
|
ldc #0x87, exr
|
|
stc exr, @er1, exr ; postinc dest (12)
|
|
|
|
test_h_gr32 byte_dest12, er1 ; er1 still contains address
|
|
|
|
test_gr_a5a5 0 ; Make sure other general regs not disturbed
|
|
test_gr_a5a5 2
|
|
test_gr_a5a5 3
|
|
test_gr_a5a5 4
|
|
test_gr_a5a5 5
|
|
test_gr_a5a5 6
|
|
test_gr_a5a5 7
|
|
|
|
.endif
|
|
|
|
.if (sim_cpu == h8sx) ; New vbr and sbr registers for h8sx
|
|
stc_sbr_reg:
|
|
set_grs_a5a5
|
|
set_ccr_zero
|
|
|
|
mov #0xaaaaaaaa, er0
|
|
ldc er0, sbr ; set sbr to 0xaaaaaaaa
|
|
stc sbr, er1 ; retreive and check sbr value
|
|
|
|
test_h_gr32 0xaaaaaaaa er1
|
|
test_h_gr32 0xaaaaaaaa er0 ; Register 0 modified by test procedure.
|
|
test_gr_a5a5 2 ; Make sure other general regs not disturbed
|
|
test_gr_a5a5 3
|
|
test_gr_a5a5 4
|
|
test_gr_a5a5 5
|
|
test_gr_a5a5 6
|
|
test_gr_a5a5 7
|
|
|
|
stc_vbr_reg:
|
|
set_grs_a5a5
|
|
set_ccr_zero
|
|
|
|
mov #0xaaaaaaaa, er0
|
|
ldc er0, vbr ; set sbr to 0xaaaaaaaa
|
|
stc vbr, er1 ; retreive and check sbr value
|
|
|
|
test_h_gr32 0xaaaaaaaa er1
|
|
test_h_gr32 0xaaaaaaaa er0 ; Register 0 modified by test procedure.
|
|
test_gr_a5a5 2 ; Make sure other general regs not disturbed
|
|
test_gr_a5a5 3
|
|
test_gr_a5a5 4
|
|
test_gr_a5a5 5
|
|
test_gr_a5a5 6
|
|
test_gr_a5a5 7
|
|
|
|
check_results:
|
|
;; Now check results
|
|
mov @byte_dest1, r0h
|
|
cmp.b #0xff, r0h
|
|
beq .L1
|
|
fail
|
|
|
|
.L1: mov @byte_dest2, r0h
|
|
cmp.b #0x87, r0h
|
|
beq .L2
|
|
fail
|
|
|
|
.L2: mov @byte_dest3, r0h
|
|
cmp.b #0xff, r0h
|
|
beq .L3
|
|
fail
|
|
|
|
.L3: mov @byte_dest4, r0h
|
|
cmp.b #0x87, r0h
|
|
beq .L4
|
|
fail
|
|
|
|
.L4: mov @byte_dest5, r0h
|
|
cmp.b #0xff, r0h
|
|
beq .L5
|
|
fail
|
|
|
|
.L5: mov @byte_dest6, r0h
|
|
cmp.b #0x87, r0h
|
|
beq .L6
|
|
fail
|
|
|
|
.L6: mov @byte_dest7, r0h
|
|
cmp.b #0xff, r0h
|
|
beq .L7
|
|
fail
|
|
|
|
.L7: mov @byte_dest8, r0h
|
|
cmp.b #0x87, r0h
|
|
beq .L8
|
|
fail
|
|
|
|
.L8: mov @byte_dest9, r0h
|
|
cmp.b #0xff, r0h
|
|
beq .L9
|
|
fail
|
|
|
|
.L9: mov @byte_dest10, r0h
|
|
cmp.b #0x87, r0h
|
|
beq .L10
|
|
fail
|
|
|
|
.L10: mov @byte_dest11, r0h
|
|
cmp.b #0xff, r0h
|
|
beq .L11
|
|
fail
|
|
|
|
.L11: mov @byte_dest12, r0h
|
|
cmp.b #0x87, r0h
|
|
beq .L12
|
|
fail
|
|
|
|
.L12:
|
|
.endif
|
|
pass
|
|
|
|
exit 0
|