mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2025-01-12 12:16:04 +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.
1023 lines
20 KiB
ArmAsm
1023 lines
20 KiB
ArmAsm
# Hitachi H8 testcase 'neg.b, neg.w, neg.l'
|
|
# 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"
|
|
|
|
# Instructions tested:
|
|
# neg.b rd ; 1 7 8 rd
|
|
# neg.b @erd ; 7 d rd ???? 1 7 8 ignore
|
|
# neg.b @erd+ ; 0 1 7 4 6 c rd 1??? 1 7 8 ignore
|
|
# neg.b @erd- ; 0 1 7 6 6 c rd 1??? 1 7 8 ignore
|
|
# neg.b @+erd ; 0 1 7 5 6 c rd 1??? 1 7 8 ignore
|
|
# neg.b @-erd ; 0 1 7 7 6 c rd 1??? 1 7 8 ignore
|
|
# neg.b @(d:2, erd) ; 0 1 7 01dd 6 8 rd 8 1 7 8 ignore
|
|
# neg.b @(d:16, erd) ; 0 1 7 4 6 e rd 1??? dd:16 1 7 8 ignore
|
|
# neg.b @(d:32, erd) ; 7 8 rd 4 6 a 2 1??? dd:32 1 7 8 ignore
|
|
# neg.b @aa:16 ; 6 a 1 1??? aa:16 1 7 8 ignore
|
|
# neg.b @aa:32 ; 6 a 3 1??? aa:32 1 7 8 ignore
|
|
# word operations
|
|
# long operations
|
|
#
|
|
# Coming soon:
|
|
# neg.b @aa:8 ; 7 f aaaaaaaa 1 7 8 ignore
|
|
#
|
|
|
|
.data
|
|
byte_dest: .byte 0xa5
|
|
.align 2
|
|
word_dest: .word 0xa5a5
|
|
.align 4
|
|
long_dest: .long 0xa5a5a5a5
|
|
start
|
|
|
|
#
|
|
# Note: apparently carry is set for neg of anything except zero.
|
|
#
|
|
|
|
#
|
|
# 8-bit byte operations
|
|
#
|
|
|
|
neg_b_reg8:
|
|
set_grs_a5a5 ; Fill all general regs with a fixed pattern
|
|
set_ccr_zero
|
|
|
|
;; neg.b Rd
|
|
neg r0l ; 8-bit register
|
|
;;; .word 0x1788
|
|
|
|
test_carry_set ; H=0 N=0 Z=0 V=0 C=1
|
|
test_ovf_clear
|
|
test_zero_clear
|
|
test_neg_clear
|
|
|
|
cmp.b #0x5b, r0l ; result of "neg 0xa5"
|
|
beq .Lbrd
|
|
fail
|
|
.Lbrd:
|
|
test_h_gr16 0xa55b r0 ; r0 changed by 'neg'
|
|
.if (sim_cpu) ; non-zero means h8300h, s, or sx
|
|
test_h_gr32 0xa5a5a55b er0 ; er0 changed by 'neg'
|
|
.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 == h8sx)
|
|
neg_b_rdind:
|
|
set_grs_a5a5 ; Fill all general regs with a fixed pattern
|
|
set_ccr_zero
|
|
|
|
;; neg.b @eRd
|
|
mov #byte_dest, er0
|
|
neg.b @er0 ; register indirect operand
|
|
;;; .word 0x7d00
|
|
;;; .word 0x1780
|
|
|
|
test_carry_set ; H=0 N=0 Z=0 V=0 C=1
|
|
test_ovf_clear
|
|
test_zero_clear
|
|
test_neg_clear
|
|
|
|
test_h_gr32 byte_dest er0 ; er0 still contains address
|
|
cmp.b #0x5b, @er0 ; memory contents changed
|
|
beq .Lbind
|
|
fail
|
|
.Lbind:
|
|
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
|
|
|
|
neg_b_rdpostinc:
|
|
set_grs_a5a5 ; Fill all general regs with a fixed pattern
|
|
set_ccr_zero
|
|
|
|
;; neg.b @eRd+
|
|
mov #byte_dest, er0 ; register post-increment operand
|
|
neg.b @er0+
|
|
;;; .word 0x0174
|
|
;;; .word 0x6c08
|
|
;;; .word 0x1780
|
|
|
|
test_carry_set ; H=0 N=1 Z=0 V=0 C=1
|
|
test_ovf_clear
|
|
test_zero_clear
|
|
test_neg_set
|
|
|
|
test_h_gr32 byte_dest+1 er0 ; er0 contains address plus one
|
|
cmp.b #0xa5, @-er0
|
|
beq .Lbpostinc
|
|
fail
|
|
.Lbpostinc:
|
|
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
|
|
|
|
neg_b_rdpostdec:
|
|
set_grs_a5a5 ; Fill all general regs with a fixed pattern
|
|
set_ccr_zero
|
|
|
|
;; neg.b @eRd-
|
|
mov #byte_dest, er0 ; register post-decrement operand
|
|
neg.b @er0-
|
|
;;; .word 0x0176
|
|
;;; .word 0x6c08
|
|
;;; .word 0x1780
|
|
|
|
test_carry_set ; H=0 N=0 Z=0 V=0 C=1
|
|
test_ovf_clear
|
|
test_zero_clear
|
|
test_neg_clear
|
|
|
|
test_h_gr32 byte_dest-1 er0 ; er0 contains address minus one
|
|
cmp.b #0x5b, @+er0
|
|
beq .Lbpostdec
|
|
fail
|
|
.Lbpostdec:
|
|
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
|
|
|
|
neg_b_rdpreinc:
|
|
set_grs_a5a5 ; Fill all general regs with a fixed pattern
|
|
set_ccr_zero
|
|
|
|
;; neg.b @+eRd
|
|
mov #byte_dest-1, er0
|
|
neg.b @+er0 ; reg pre-increment operand
|
|
;;; .word 0x0175
|
|
;;; .word 0x6c08
|
|
;;; .word 0x1780
|
|
|
|
test_carry_set ; H=0 N=1 Z=0 V=0 C=1
|
|
test_ovf_clear
|
|
test_zero_clear
|
|
test_neg_set
|
|
|
|
cmp.b #0xa5, @er0
|
|
beq .Lbpreinc
|
|
fail
|
|
.Lbpreinc:
|
|
test_h_gr32 byte_dest er0 ; er0 contains destination address
|
|
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
|
|
|
|
neg_b_rdpredec:
|
|
set_grs_a5a5 ; Fill all general regs with a fixed pattern
|
|
set_ccr_zero
|
|
|
|
;; neg.b @-eRd
|
|
mov #byte_dest+1, er0
|
|
neg.b @-er0 ; reg pre-decr operand
|
|
;;; .word 0x0177
|
|
;;; .word 0x6c08
|
|
;;; .word 0x1780
|
|
|
|
test_carry_set ; H=0 N=0 Z=0 V=0 C=1
|
|
test_ovf_clear
|
|
test_zero_clear
|
|
test_neg_clear
|
|
|
|
cmp.b #0x5b, @er0
|
|
beq .Lbpredec
|
|
fail
|
|
.Lbpredec:
|
|
test_h_gr32 byte_dest er0 ; er0 contains destination address
|
|
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
|
|
|
|
neg_b_disp2dst:
|
|
set_grs_a5a5 ; Fill all general regs with a fixed pattern
|
|
set_ccr_zero
|
|
|
|
;; neg.b @(dd:2, erd)
|
|
mov #byte_dest-1, er0
|
|
neg.b @(1:2, er0) ; reg plus 2-bit displacement
|
|
;;; .word 0x0175
|
|
;;; .word 0x6808
|
|
;;; .word 0x1780
|
|
|
|
test_carry_set ; H=0 N=1 Z=0 V=0 C=1
|
|
test_ovf_clear
|
|
test_zero_clear
|
|
test_neg_set
|
|
|
|
cmp.b #0xa5, @+er0
|
|
beq .Lbdisp2
|
|
fail
|
|
.Lbdisp2:
|
|
test_h_gr32 byte_dest er0 ; er0 contains destination address
|
|
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
|
|
|
|
neg_b_disp16dst:
|
|
set_grs_a5a5 ; Fill all general regs with a fixed pattern
|
|
set_ccr_zero
|
|
|
|
;; neg.b @(dd:16, erd)
|
|
mov #byte_dest+100, er0
|
|
neg.b @(-100:16, er0) ; reg plus 16-bit displacement
|
|
;;; .word 0x0174
|
|
;;; .word 0x6e08
|
|
;;; .word -100
|
|
;;; .word 0x1780
|
|
|
|
test_carry_set ; H=0 N=0 Z=0 V=0 C=1
|
|
test_ovf_clear
|
|
test_zero_clear
|
|
test_neg_clear
|
|
|
|
cmp.b #0x5b, @byte_dest
|
|
beq .Lbdisp16
|
|
fail
|
|
.Lbdisp16:
|
|
test_h_gr32 byte_dest+100 er0 ; er0 contains destination address
|
|
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
|
|
|
|
neg_b_disp32dst:
|
|
set_grs_a5a5 ; Fill all general regs with a fixed pattern
|
|
set_ccr_zero
|
|
|
|
;; neg.b @(dd:32, erd)
|
|
mov #byte_dest-0xfffff, er0
|
|
neg.b @(0xfffff:32, er0) ; reg plus 32-bit displacement
|
|
;;; .word 0x7804
|
|
;;; .word 0x6a28
|
|
;;; .long 0xfffff
|
|
;;; .word 0x1780
|
|
|
|
test_carry_set ; H=0 N=1 Z=0 V=0 C=1
|
|
test_ovf_clear
|
|
test_zero_clear
|
|
test_neg_set
|
|
|
|
cmp.b #0xa5, @byte_dest
|
|
beq .Lbdisp32
|
|
fail
|
|
.Lbdisp32:
|
|
test_h_gr32 byte_dest-0xfffff er0 ; er0 contains destination address
|
|
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
|
|
|
|
neg_b_abs16dst:
|
|
set_grs_a5a5 ; Fill all general regs with a fixed pattern
|
|
set_ccr_zero
|
|
|
|
;; neg.b @aa:16
|
|
neg.b @byte_dest:16 ; 16-bit absolute address
|
|
;;; .word 0x6a18
|
|
;;; .word byte_dest
|
|
;;; .word 0x1780
|
|
|
|
test_carry_set ; H=0 N=0 Z=0 V=0 C=1
|
|
test_ovf_clear
|
|
test_zero_clear
|
|
test_neg_clear
|
|
|
|
cmp.b #0x5b, @byte_dest
|
|
beq .Lbabs16
|
|
fail
|
|
.Lbabs16:
|
|
test_gr_a5a5 0 ; Make sure ALL 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
|
|
|
|
neg_b_abs32dst:
|
|
set_grs_a5a5 ; Fill all general regs with a fixed pattern
|
|
set_ccr_zero
|
|
|
|
;; neg.b @aa:32
|
|
neg.b @byte_dest:32 ; 32-bit absolute address
|
|
;;; .word 0x6a38
|
|
;;; .long byte_dest
|
|
;;; .word 0x1780
|
|
|
|
test_carry_set ; H=0 N=1 Z=0 V=0 C=1
|
|
test_ovf_clear
|
|
test_zero_clear
|
|
test_neg_set
|
|
|
|
cmp.b #0xa5, @byte_dest
|
|
beq .Lbabs32
|
|
fail
|
|
.Lbabs32:
|
|
test_gr_a5a5 0 ; Make sure ALL 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
|
|
.endif
|
|
|
|
#
|
|
# 16-bit word operations
|
|
#
|
|
|
|
.if (sim_cpu) ; any except plain-vanilla h8/300
|
|
neg_w_reg16:
|
|
set_grs_a5a5 ; Fill all general regs with a fixed pattern
|
|
set_ccr_zero
|
|
|
|
;; neg.w Rd
|
|
neg r1 ; 16-bit register operand
|
|
;;; .word 0x1791
|
|
|
|
test_carry_set ; H=0 N=0 Z=0 V=0 C=1
|
|
test_ovf_clear
|
|
test_zero_clear
|
|
test_neg_clear
|
|
|
|
cmp.w #0x5a5b, r1 ; result of "neg 0xa5a5"
|
|
beq .Lwrd
|
|
fail
|
|
.Lwrd:
|
|
test_h_gr32 0xa5a55a5b er1 ; er1 changed by 'neg'
|
|
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
|
|
|
|
.if (sim_cpu == h8sx)
|
|
neg_w_rdind:
|
|
set_grs_a5a5 ; Fill all general regs with a fixed pattern
|
|
set_ccr_zero
|
|
|
|
;; neg.w @eRd
|
|
mov #word_dest, er1
|
|
neg.w @er1 ; register indirect operand
|
|
;;; .word 0x0154
|
|
;;; .word 0x6d18
|
|
;;; .word 0x1790
|
|
|
|
test_carry_set ; H=0 N=0 Z=0 V=0 C=1
|
|
test_ovf_clear
|
|
test_zero_clear
|
|
test_neg_clear
|
|
|
|
cmp.w #0x5a5b, @word_dest ; memory contents changed
|
|
beq .Lwind
|
|
fail
|
|
.Lwind:
|
|
test_h_gr32 word_dest 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
|
|
|
|
neg_w_rdpostinc:
|
|
set_grs_a5a5 ; Fill all general regs with a fixed pattern
|
|
set_ccr_zero
|
|
|
|
;; neg.w @eRd+
|
|
mov #word_dest, er1 ; register post-increment operand
|
|
neg.w @er1+
|
|
;;; .word 0x0154
|
|
;;; .word 0x6d18
|
|
;;; .word 0x1790
|
|
|
|
test_carry_set ; H=0 N=1 Z=0 V=0 C=1
|
|
test_ovf_clear
|
|
test_zero_clear
|
|
test_neg_set
|
|
|
|
cmp.w #0xa5a5, @word_dest
|
|
beq .Lwpostinc
|
|
fail
|
|
.Lwpostinc:
|
|
test_h_gr32 word_dest+2 er1 ; er1 contains address plus two
|
|
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
|
|
|
|
neg_w_rdpostdec:
|
|
set_grs_a5a5 ; Fill all general regs with a fixed pattern
|
|
set_ccr_zero
|
|
|
|
;; neg.w @eRd-
|
|
mov #word_dest, er1
|
|
neg.w @er1-
|
|
;;; .word 0x0156
|
|
;;; .word 0x6d18
|
|
;;; .word 0x1790
|
|
|
|
test_carry_set ; H=0 N=0 Z=0 V=0 C=1
|
|
test_ovf_clear
|
|
test_zero_clear
|
|
test_neg_clear
|
|
|
|
cmp.w #0x5a5b, @word_dest
|
|
beq .Lwpostdec
|
|
fail
|
|
.Lwpostdec:
|
|
test_h_gr32 word_dest-2 er1 ; er1 contains address minus two
|
|
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
|
|
|
|
neg_w_rdpreinc:
|
|
set_grs_a5a5 ; Fill all general regs with a fixed pattern
|
|
set_ccr_zero
|
|
|
|
;; neg.w @+eRd
|
|
mov #word_dest-2, er1
|
|
neg.w @+er1 ; reg pre-increment operand
|
|
;;; .word 0x0155
|
|
;;; .word 0x6d18
|
|
;;; .word 0x1790
|
|
|
|
test_carry_set ; H=0 N=1 Z=0 V=0 C=1
|
|
test_ovf_clear
|
|
test_zero_clear
|
|
test_neg_set
|
|
|
|
cmp.w #0xa5a5, @word_dest
|
|
beq .Lwpreinc
|
|
fail
|
|
.Lwpreinc:
|
|
test_h_gr32 word_dest er1 ; er1 contains destination 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
|
|
|
|
neg_w_rdpredec:
|
|
set_grs_a5a5 ; Fill all general regs with a fixed pattern
|
|
set_ccr_zero
|
|
|
|
;; neg.w @-eRd
|
|
mov #word_dest+2, er1
|
|
neg.w @-er1 ; reg pre-decr operand
|
|
;;; .word 0x0157
|
|
;;; .word 0x6d18
|
|
;;; .word 0x1790
|
|
|
|
test_carry_set ; H=0 N=0 Z=0 V=0 C=1
|
|
test_ovf_clear
|
|
test_zero_clear
|
|
test_neg_clear
|
|
|
|
cmp.w #0x5a5b, @word_dest
|
|
beq .Lwpredec
|
|
fail
|
|
.Lwpredec:
|
|
test_h_gr32 word_dest er1 ; er1 contains destination 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
|
|
|
|
neg_w_disp2dst:
|
|
set_grs_a5a5 ; Fill all general regs with a fixed pattern
|
|
set_ccr_zero
|
|
|
|
;; neg.w @(dd:2, erd)
|
|
mov #word_dest-2, er1
|
|
neg.w @(2:2, er1) ; reg plus 2-bit displacement
|
|
;;; .word 0x0155
|
|
;;; .word 0x6918
|
|
;;; .word 0x1790
|
|
|
|
test_carry_set ; H=0 N=1 Z=0 V=0 C=1
|
|
test_ovf_clear
|
|
test_zero_clear
|
|
test_neg_set
|
|
|
|
cmp.w #0xa5a5, @word_dest
|
|
beq .Lwdisp2
|
|
fail
|
|
.Lwdisp2:
|
|
test_h_gr32 word_dest-2 er1 ; er1 contains address minus one
|
|
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
|
|
|
|
neg_w_disp16dst:
|
|
set_grs_a5a5 ; Fill all general regs with a fixed pattern
|
|
set_ccr_zero
|
|
|
|
;; neg.w @(dd:16, erd)
|
|
mov #word_dest+100, er1
|
|
neg.w @(-100:16, er1) ; reg plus 16-bit displacement
|
|
;;; .word 0x0154
|
|
;;; .word 0x6f18
|
|
;;; .word -100
|
|
;;; .word 0x1790
|
|
|
|
test_carry_set ; H=0 N=0 Z=0 V=0 C=1
|
|
test_ovf_clear
|
|
test_zero_clear
|
|
test_neg_clear
|
|
|
|
cmp.w #0x5a5b, @word_dest
|
|
beq .Lwdisp16
|
|
fail
|
|
.Lwdisp16:
|
|
test_h_gr32 word_dest+100 er1 ; er1 contains destination 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
|
|
|
|
neg_w_disp32dst:
|
|
set_grs_a5a5 ; Fill all general regs with a fixed pattern
|
|
set_ccr_zero
|
|
|
|
;; neg.w @(dd:32, erd)
|
|
mov #word_dest-0xfffff, er1
|
|
neg.w @(0xfffff:32, er1) ; reg plus 32-bit displacement
|
|
;;; .word 0x7814
|
|
;;; .word 0x6b28
|
|
;;; .long 0xfffff
|
|
;;; .word 0x1790
|
|
|
|
test_carry_set ; H=0 N=1 Z=0 V=0 C=1
|
|
test_ovf_clear
|
|
test_zero_clear
|
|
test_neg_set
|
|
|
|
cmp.w #0xa5a5, @word_dest
|
|
beq .Lwdisp32
|
|
fail
|
|
.Lwdisp32:
|
|
test_h_gr32 word_dest-0xfffff er1 ; er1 contains destination 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
|
|
|
|
neg_w_abs16dst:
|
|
set_grs_a5a5 ; Fill all general regs with a fixed pattern
|
|
set_ccr_zero
|
|
|
|
;; neg.w @aa:16
|
|
neg.w @word_dest:16 ; 16-bit absolute address
|
|
;;; .word 0x6b18
|
|
;;; .word word_dest
|
|
;;; .word 0x1790
|
|
|
|
test_carry_set ; H=0 N=0 Z=0 V=0 C=1
|
|
test_ovf_clear
|
|
test_zero_clear
|
|
test_neg_clear
|
|
|
|
cmp.w #0x5a5b, @word_dest
|
|
beq .Lwabs16
|
|
fail
|
|
.Lwabs16:
|
|
test_gr_a5a5 0 ; Make sure ALL 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
|
|
|
|
neg_w_abs32dst:
|
|
set_grs_a5a5 ; Fill all general regs with a fixed pattern
|
|
set_ccr_zero
|
|
|
|
;; neg.w @aa:32
|
|
neg.w @word_dest:32 ; 32-bit absolute address
|
|
;;; .word 0x6b38
|
|
;;; .long word_dest
|
|
;;; .word 0x1790
|
|
|
|
test_carry_set ; H=0 N=1 Z=0 V=0 C=1
|
|
test_ovf_clear
|
|
test_zero_clear
|
|
test_neg_set
|
|
|
|
cmp.w #0xa5a5, @word_dest
|
|
beq .Lwabs32
|
|
fail
|
|
.Lwabs32:
|
|
test_gr_a5a5 0 ; Make sure ALL 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
|
|
|
|
.endif ; h8sx
|
|
.endif ; h8/300
|
|
|
|
#
|
|
# 32-bit word operations
|
|
#
|
|
|
|
.if (sim_cpu) ; any except plain-vanilla h8/300
|
|
neg_l_reg16:
|
|
set_grs_a5a5 ; Fill all general regs with a fixed pattern
|
|
set_ccr_zero
|
|
|
|
;; neg.l eRd
|
|
neg er1 ; 32-bit register operand
|
|
;;; .word 0x17b1
|
|
|
|
test_carry_set ; H=0 N=0 Z=0 V=0 C=1
|
|
test_ovf_clear
|
|
test_zero_clear
|
|
test_neg_clear
|
|
|
|
cmp.l #0x5a5a5a5b, er1 ; result of "neg 0xa5a5a5a5"
|
|
beq .Llrd
|
|
fail
|
|
.Llrd:
|
|
test_h_gr32 0x5a5a5a5b er1 ; er1 changed by 'neg'
|
|
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
|
|
|
|
.if (sim_cpu == h8sx)
|
|
neg_l_rdind:
|
|
set_grs_a5a5 ; Fill all general regs with a fixed pattern
|
|
set_ccr_zero
|
|
|
|
;; neg.l @eRd
|
|
mov #long_dest, er1
|
|
neg.l @er1 ; register indirect operand
|
|
;;; .word 0x0104
|
|
;;; .word 0x6d18
|
|
;;; .word 0x17b0
|
|
|
|
test_carry_set ; H=0 N=0 Z=0 V=0 C=1
|
|
test_ovf_clear
|
|
test_zero_clear
|
|
test_neg_clear
|
|
|
|
cmp.l #0x5a5a5a5b, @long_dest ; memory contents changed
|
|
beq .Llind
|
|
fail
|
|
.Llind:
|
|
test_h_gr32 long_dest 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
|
|
|
|
neg_l_rdpostinc:
|
|
set_grs_a5a5 ; Fill all general regs with a fixed pattern
|
|
set_ccr_zero
|
|
|
|
;; neg.l @eRd+
|
|
mov #long_dest, er1 ; register post-increment operand
|
|
neg.l @er1+
|
|
;;; .word 0x0104
|
|
;;; .word 0x6d18
|
|
;;; .word 0x17b0
|
|
|
|
test_carry_set ; H=0 N=1 Z=0 V=0 C=1
|
|
test_ovf_clear
|
|
test_zero_clear
|
|
test_neg_set
|
|
|
|
cmp.l #0xa5a5a5a5, @long_dest
|
|
beq .Llpostinc
|
|
fail
|
|
.Llpostinc:
|
|
test_h_gr32 long_dest+4 er1 ; er1 contains address plus two
|
|
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
|
|
|
|
neg_l_rdpostdec:
|
|
set_grs_a5a5 ; Fill all general regs with a fixed pattern
|
|
set_ccr_zero
|
|
|
|
;; neg.l @eRd-
|
|
mov #long_dest, er1
|
|
neg.l @er1-
|
|
;;; .word 0x0106
|
|
;;; .word 0x6d18
|
|
;;; .word 0x17b0
|
|
|
|
test_carry_set ; H=0 N=0 Z=0 V=0 C=1
|
|
test_ovf_clear
|
|
test_zero_clear
|
|
test_neg_clear
|
|
|
|
cmp.l #0x5a5a5a5b, @long_dest
|
|
beq .Llpostdec
|
|
fail
|
|
.Llpostdec:
|
|
test_h_gr32 long_dest-4 er1 ; er1 contains address minus two
|
|
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
|
|
|
|
neg_l_rdpreinc:
|
|
set_grs_a5a5 ; Fill all general regs with a fixed pattern
|
|
set_ccr_zero
|
|
|
|
;; neg.l @+eRd
|
|
mov #long_dest-4, er1
|
|
neg.l @+er1 ; reg pre-increment operand
|
|
;;; .word 0x0105
|
|
;;; .word 0x6d18
|
|
;;; .word 0x17b0
|
|
|
|
test_carry_set ; H=0 N=1 Z=0 V=0 C=1
|
|
test_ovf_clear
|
|
test_zero_clear
|
|
test_neg_set
|
|
|
|
cmp.l #0xa5a5a5a5, @long_dest
|
|
beq .Llpreinc
|
|
fail
|
|
.Llpreinc:
|
|
test_h_gr32 long_dest er1 ; er1 contains destination 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
|
|
|
|
neg_l_rdpredec:
|
|
set_grs_a5a5 ; Fill all general regs with a fixed pattern
|
|
set_ccr_zero
|
|
|
|
;; neg.l @-eRd
|
|
mov #long_dest+4, er1
|
|
neg.l @-er1 ; reg pre-decr operand
|
|
;;; .word 0x0107
|
|
;;; .word 0x6d18
|
|
;;; .word 0x17b0
|
|
|
|
test_carry_set ; H=0 N=0 Z=0 V=0 C=1
|
|
test_ovf_clear
|
|
test_zero_clear
|
|
test_neg_clear
|
|
|
|
cmp.l #0x5a5a5a5b, @long_dest
|
|
beq .Llpredec
|
|
fail
|
|
.Llpredec:
|
|
test_h_gr32 long_dest er1 ; er1 contains destination 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
|
|
|
|
neg_l_disp2dst:
|
|
set_grs_a5a5 ; Fill all general regs with a fixed pattern
|
|
set_ccr_zero
|
|
|
|
;; neg.l @(dd:2, erd)
|
|
mov #long_dest-4, er1
|
|
neg.l @(4:2, er1) ; reg plus 2-bit displacement
|
|
;;; .word 0x0105
|
|
;;; .word 0x6918
|
|
;;; .word 0x17b0
|
|
|
|
test_carry_set ; H=0 N=1 Z=0 V=0 C=1
|
|
test_ovf_clear
|
|
test_zero_clear
|
|
test_neg_set
|
|
|
|
cmp.l #0xa5a5a5a5, @long_dest
|
|
beq .Lldisp2
|
|
fail
|
|
.Lldisp2:
|
|
test_h_gr32 long_dest-4 er1 ; er1 contains address minus one
|
|
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
|
|
|
|
neg_l_disp16dst:
|
|
set_grs_a5a5 ; Fill all general regs with a fixed pattern
|
|
set_ccr_zero
|
|
|
|
;; neg.l @(dd:16, erd)
|
|
mov #long_dest+100, er1
|
|
neg.l @(-100:16, er1) ; reg plus 16-bit displacement
|
|
;;; .word 0x0104
|
|
;;; .word 0x6f18
|
|
;;; .word -100
|
|
;;; .word 0x17b0
|
|
|
|
test_carry_set ; H=0 N=0 Z=0 V=0 C=1
|
|
test_ovf_clear
|
|
test_zero_clear
|
|
test_neg_clear
|
|
|
|
cmp.l #0x5a5a5a5b, @long_dest
|
|
beq .Lldisp16
|
|
fail
|
|
.Lldisp16:
|
|
test_h_gr32 long_dest+100 er1 ; er1 contains destination 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
|
|
|
|
neg_l_disp32dst:
|
|
set_grs_a5a5 ; Fill all general regs with a fixed pattern
|
|
set_ccr_zero
|
|
|
|
;; neg.l @(dd:32, erd)
|
|
mov #long_dest-0xfffff, er1
|
|
neg.l @(0xfffff:32, er1) ; reg plus 32-bit displacement
|
|
;;; .word 0x7894
|
|
;;; .word 0x6b28
|
|
;;; .long 0xfffff
|
|
;;; .word 0x17b0
|
|
|
|
test_carry_set ; H=0 N=1 Z=0 V=0 C=1
|
|
test_ovf_clear
|
|
test_zero_clear
|
|
test_neg_set
|
|
|
|
cmp.l #0xa5a5a5a5, @long_dest
|
|
beq .Lldisp32
|
|
fail
|
|
.Lldisp32:
|
|
test_h_gr32 long_dest-0xfffff er1 ; er1 contains destination 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
|
|
|
|
neg_l_abs16dst:
|
|
set_grs_a5a5 ; Fill all general regs with a fixed pattern
|
|
set_ccr_zero
|
|
|
|
;; neg.l @aa:16
|
|
neg.l @long_dest:16 ; 16-bit absolute address
|
|
;;; .word 0x0104
|
|
;;; .word 0x6b08
|
|
;;; .word long_dest
|
|
;;; .word 0x17b0
|
|
|
|
test_carry_set ; H=0 N=0 Z=0 V=0 C=1
|
|
test_ovf_clear
|
|
test_zero_clear
|
|
test_neg_clear
|
|
|
|
cmp.l #0x5a5a5a5b, @long_dest
|
|
beq .Llabs16
|
|
fail
|
|
.Llabs16:
|
|
test_gr_a5a5 0 ; Make sure ALL 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
|
|
|
|
neg_l_abs32dst:
|
|
set_grs_a5a5 ; Fill all general regs with a fixed pattern
|
|
set_ccr_zero
|
|
|
|
;; neg.l @aa:32
|
|
neg.l @long_dest:32 ; 32-bit absolute address
|
|
;;; .word 0x0104
|
|
;;; .word 0x6b28
|
|
;;; .long long_dest
|
|
;;; .word 0x17b0
|
|
|
|
test_carry_set ; H=0 N=1 Z=0 V=0 C=1
|
|
test_ovf_clear
|
|
test_zero_clear
|
|
test_neg_set
|
|
|
|
cmp.l #0xa5a5a5a5, @long_dest
|
|
beq .Llabs32
|
|
fail
|
|
.Llabs32:
|
|
test_gr_a5a5 0 ; Make sure ALL 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
|
|
|
|
.endif ; h8sx
|
|
.endif ; h8/300
|
|
|
|
pass
|
|
|
|
exit 0
|