⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 movl.s

📁 gdb-6.8 Linux下的调试程序 最新版本
💻 S
📖 第 1 页 / 共 4 页
字号:
# Hitachi H8 testcase 'mov.l'# mach(): h8300h h8300s h8sx# 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"	start	.data	.align	4long_src:	.long	0x77777777long_dst:	.long	0	.text	;;	;; Move long from immediate source	;; .if (sim_cpu == h8sx)mov_l_imm3_to_reg32:	set_grs_a5a5		; Fill all general regs with a fixed pattern	set_ccr_zero	;; mov.l #xx:3, erd	mov.l	#0x3:3, er0	; Immediate 3-bit operand;;;	.word	0x0fb8	;; test ccr		; H=0 N=0 Z=0 V=0 C=0	test_neg_clear	test_zero_clear	test_ovf_clear	test_carry_clear	test_h_gr32 0x3 er0	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 7mov_l_imm16_to_reg32:	set_grs_a5a5		; Fill all general regs with a fixed pattern	set_ccr_zero	;; mov.l #xx:16, erd	mov.l	#0x1234, er0	; Immediate 16-bit operand;;;	.word	0x7a08;;;	.word	0x1234	;; test ccr		; H=0 N=0 Z=0 V=0 C=0	test_neg_clear	test_zero_clear	test_ovf_clear	test_carry_clear	test_h_gr32 0x1234 er0	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.endifmov_l_imm32_to_reg32:	set_grs_a5a5		; Fill all general regs with a fixed pattern	set_ccr_zero	;; mov.l #xx:32, erd	mov.l	#0x12345678, er0	; Immediate 32-bit operand;;;	.word	0x7a00;;;	.long	0x12345678	;; test ccr		; H=0 N=0 Z=0 V=0 C=0	test_neg_clear	test_zero_clear	test_ovf_clear	test_carry_clear	test_h_gr32 0x12345678 er0	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)mov_l_imm8_to_indirect:	set_grs_a5a5		; Fill all general regs with a fixed pattern	set_ccr_zero	;; mov.l #xx:8, @erd	mov.l	#long_dst, er1	mov.l	#0xa5:8, @er1	; Register indirect operand;;;	.word	0x010d;;;	.word	0x01a5	;; test ccr		; H=0 N=0 Z=0 V=0 C=0	test_neg_clear	test_zero_clear	test_ovf_clear	test_carry_clear	test_gr_a5a5 0		; Make sure other general regs not disturbed	test_h_gr32	long_dst, er1	test_gr_a5a5 2	test_gr_a5a5 3	test_gr_a5a5 4	test_gr_a5a5 5	test_gr_a5a5 6	test_gr_a5a5 7	;; Now check the result of the move to memory.	cmp.l	#0xa5, @long_dst	beq	.Lnext1	fail.Lnext1:	mov.l	#0, @long_dst	; zero it again for the next use.mov_l_imm8_to_postinc:		; post-increment from imm8 to mem	set_grs_a5a5		; Fill all general regs with a fixed pattern	set_ccr_zero	;; mov.l #xx:8, @erd+	mov.l	#long_dst, er1	mov.l	#0xa5:8, @er1+	; Imm8, register post-incr operands.;;;	.word	0x010d;;;	.word	0x81a5	;; test ccr		; H=0 N=0 Z=0 V=0 C=0	test_neg_clear	test_zero_clear	test_ovf_clear	test_carry_clear	test_gr_a5a5 0		; Make sure other general regs not disturbed	test_h_gr32	long_dst+4, er1	test_gr_a5a5 2	test_gr_a5a5 3	test_gr_a5a5 4	test_gr_a5a5 5	test_gr_a5a5 6	test_gr_a5a5 7	;; Now check the result of the move to memory.	cmp.l	#0xa5, @long_dst	beq	.Lnext2	fail.Lnext2:	mov.l	#0, @long_dst	; zero it again for the next use.mov_l_imm8_to_postdec:		; post-decrement from imm8 to mem	set_grs_a5a5		; Fill all general regs with a fixed pattern	set_ccr_zero	;; mov.l #xx:8, @erd-	mov.l	#long_dst, er1	mov.l	#0xa5:8, @er1-	; Imm8, register post-decr operands.;;;	.word	0x010d;;;	.word	0xa1a5	;; test ccr		; H=0 N=0 Z=0 V=0 C=0	test_neg_clear	test_zero_clear	test_ovf_clear	test_carry_clear	test_gr_a5a5 0		; Make sure other general regs not disturbed	test_h_gr32	long_dst-4, er1	test_gr_a5a5 2	test_gr_a5a5 3	test_gr_a5a5 4	test_gr_a5a5 5	test_gr_a5a5 6	test_gr_a5a5 7	;; Now check the result of the move to memory.	cmp.l	#0xa5, @long_dst	beq	.Lnext3	fail.Lnext3:	mov.l	#0, @long_dst	; zero it again for the next use.mov_l_imm8_to_preinc:		; pre-increment from register to mem	set_grs_a5a5		; Fill all general regs with a fixed pattern	set_ccr_zero	;; mov.l #xx:8, @+erd	mov.l	#long_dst-4, er1	mov.l	#0xa5:8, @+er1	; Imm8, register pre-incr operands;;;	.word	0x010d;;;	.word	0x91a5	;; test ccr		; H=0 N=0 Z=0 V=0 C=0	test_neg_clear	test_zero_clear	test_ovf_clear	test_carry_clear	test_gr_a5a5 0		; Make sure other general regs not disturbed	test_h_gr32	long_dst, er1	test_gr_a5a5 2	test_gr_a5a5 3	test_gr_a5a5 4	test_gr_a5a5 5	test_gr_a5a5 6	test_gr_a5a5 7	;; Now check the result of the move to memory.	cmp.l	#0xa5, @long_dst	beq	.Lnext4	fail.Lnext4:	mov.l	#0, @long_dst	; zero it again for the next use.mov_l_imm8_to_predec:		; pre-decrement from register to mem	set_grs_a5a5		; Fill all general regs with a fixed pattern	set_ccr_zero	;; mov.l #xx:8, @-erd	mov.l	#long_dst+4, er1	mov.l	#0xa5:8, @-er1	; Imm8, register pre-decr operands;;;	.word	0x010d;;;	.word	0xb1a5	;; test ccr		; H=0 N=0 Z=0 V=0 C=0	test_neg_clear	test_zero_clear	test_ovf_clear	test_carry_clear	test_gr_a5a5 0		; Make sure other general regs not disturbed	test_h_gr32	long_dst, er1	test_gr_a5a5 2	test_gr_a5a5 3	test_gr_a5a5 4	test_gr_a5a5 5	test_gr_a5a5 6	test_gr_a5a5 7	;; Now check the result of the move to memory.	cmp.l	#0xa5, @long_dst	beq	.Lnext5	fail.Lnext5:	mov.l	#0, @long_dst	; zero it again for the next use.mov_l_imm8_to_disp2:	set_grs_a5a5		; Fill all general regs with a fixed pattern	set_ccr_zero	;; mov.l #xx:8, @(dd:2, erd)	mov.l	#long_dst-12, er1	mov.l	#0xa5:8, @(12:2, er1)	; Imm8, reg plus 2-bit disp. operand;;;	.word	0x010d;;;	.word	0x31a5	;; test ccr		; H=0 N=0 Z=0 V=0 C=0	test_neg_clear	test_zero_clear	test_ovf_clear	test_carry_clear	test_gr_a5a5 0		; Make sure other general regs not disturbed	test_h_gr32	long_dst-12, er1	test_gr_a5a5 2	test_gr_a5a5 3	test_gr_a5a5 4	test_gr_a5a5 5	test_gr_a5a5 6	test_gr_a5a5 7	;; Now check the result of the move to memory.	cmp.l	#0xa5, @long_dst	beq	.Lnext6	fail.Lnext6:	mov.l	#0, @long_dst	; zero it again for the next use.mov_l_imm8_to_disp16:	set_grs_a5a5		; Fill all general regs with a fixed pattern	set_ccr_zero	;; mov.l #xx:8, @(dd:16, erd)	mov.l	#long_dst-4, er1	mov.l	#0xa5:8, @(4:16, er1)	; Register plus 16-bit disp. operand;;;	.word	0x010d;;;	.word	0x6f90;;;	.word	0x0004	;; test ccr		; H=0 N=0 Z=0 V=0 C=0	test_neg_clear	test_zero_clear	test_ovf_clear	test_carry_clear	test_gr_a5a5 0		; Make sure other general regs not disturbed	test_h_gr32	long_dst-4, er1	test_gr_a5a5 2	test_gr_a5a5 3	test_gr_a5a5 4	test_gr_a5a5 5	test_gr_a5a5 6	test_gr_a5a5 7	;; Now check the result of the move to memory.	cmp.l	#0xa5, @long_dst	beq	.Lnext7	fail.Lnext7:	mov.l	#0, @long_dst	; zero it again for the next use.mov_l_imm8_to_disp32:	set_grs_a5a5		; Fill all general regs with a fixed pattern	set_ccr_zero	;; mov.l #xx:8, @(dd:32, erd)	mov.l	#long_dst-8, er1	mov.l	#0xa5:8, @(8:32, er1)	; Register plus 32-bit disp. operand;;;	.word	0x010d;;;	.word	0xc9a5;;;	.long	8	;; test ccr		; H=0 N=0 Z=0 V=0 C=0	test_neg_clear	test_zero_clear	test_ovf_clear	test_carry_clear	test_gr_a5a5 0		; Make sure other general regs not disturbed	test_h_gr32	long_dst-8, er1	test_gr_a5a5 2	test_gr_a5a5 3	test_gr_a5a5 4	test_gr_a5a5 5	test_gr_a5a5 6	test_gr_a5a5 7	;; Now check the result of the move to memory.	cmp.l	#0xa5, @long_dst	beq	.Lnext8	fail.Lnext8:	mov.l	#0, @long_dst	; zero it again for the next use.mov_l_imm8_to_abs16:	set_grs_a5a5		; Fill all general regs with a fixed pattern	set_ccr_zero	;; mov.l #xx:8, @aa:16	mov.l	#0xa5:8, @long_dst:16	; 16-bit address-direct operand;;;	.word	0x010d;;;	.word	0x40a5;;;	.word	@long_dst	;; test ccr		; H=0 N=0 Z=0 V=0 C=0	test_neg_clear	test_zero_clear	test_ovf_clear	test_carry_clear	test_gr_a5a5 0		; Make sure _ALL_ general regs not disturbed	test_gr_a5a5 1		; (first, because on h8/300 we must use one	test_gr_a5a5 2		; to examine the destination memory).	test_gr_a5a5 3	test_gr_a5a5 4	test_gr_a5a5 5	test_gr_a5a5 6	test_gr_a5a5 7	;; Now check the result of the move to memory.	cmp.l	#0xa5, @long_dst	beq	.Lnext9	fail.Lnext9:	mov.l	#0, @long_dst	; zero it again for the next use.mov_l_imm8_to_abs32:	set_grs_a5a5		; Fill all general regs with a fixed pattern	set_ccr_zero	;; mov.l #xx:8, @aa:32	mov.l	#0xa5:8, @long_dst:32	; 32-bit address-direct operand;;;	.word	0x010d;;;	.word	0x48a5;;;	.long	@long_dst	;; test ccr		; H=0 N=0 Z=0 V=0 C=0	test_neg_clear	test_zero_clear	test_ovf_clear	test_carry_clear	test_gr_a5a5 0		; Make sure _ALL_ general regs not disturbed	test_gr_a5a5 1		; (first, because on h8/300 we must use one	test_gr_a5a5 2		; to examine the destination memory).	test_gr_a5a5 3	test_gr_a5a5 4	test_gr_a5a5 5	test_gr_a5a5 6	test_gr_a5a5 7	;; Now check the result of the move to memory.	cmp.l	#0xa5, @long_dst	beq	.Lnext10	fail.Lnext10:	mov.l	#0, @long_dst	; zero it again for the next use.mov_l_imm16_to_indirect:	set_grs_a5a5		; Fill all general regs with a fixed pattern	set_ccr_zero	;; mov.l #xx:16, @erd	mov.l	#long_dst, er1	mov.l	#0xdead:16, @er1	; Register indirect operand;;;	.word	0x7a7c;;;	.word	0xdead;;;	.word	0x0100	;; test ccr		; H=0 N=0 Z=0 V=0 C=0	test_neg_clear	test_zero_clear	test_ovf_clear	test_carry_clear	test_gr_a5a5 0		; Make sure other general regs not disturbed	test_h_gr32	long_dst, er1	test_gr_a5a5 2	test_gr_a5a5 3	test_gr_a5a5 4	test_gr_a5a5 5	test_gr_a5a5 6	test_gr_a5a5 7	;; Now check the result of the move to memory.	cmp.l	#0xdead, @long_dst	beq	.Lnext11	fail.Lnext11:	mov.l	#0, @long_dst	; zero it again for the next use.mov_l_imm16_to_postinc:		; post-increment from imm16 to mem	set_grs_a5a5		; Fill all general regs with a fixed pattern	set_ccr_zero	;; mov.l #xx:16, @erd+	mov.l	#long_dst, er1	mov.l	#0xdead:16, @er1+	; Imm16, register post-incr operands.;;;	.word	0x7a7c;;;	.word	0xdead;;;	.word	0x8100	;; test ccr		; H=0 N=0 Z=0 V=0 C=0	test_neg_clear	test_zero_clear	test_ovf_clear	test_carry_clear	test_gr_a5a5 0		; Make sure other general regs not disturbed	test_h_gr32	long_dst+4, er1	test_gr_a5a5 2	test_gr_a5a5 3	test_gr_a5a5 4	test_gr_a5a5 5	test_gr_a5a5 6	test_gr_a5a5 7	;; Now check the result of the move to memory.	cmp.l	#0xdead, @long_dst	beq	.Lnext12	fail.Lnext12:	mov.l	#0, @long_dst	; zero it again for the next use.mov_l_imm16_to_postdec:		; post-decrement from imm16 to mem	set_grs_a5a5		; Fill all general regs with a fixed pattern	set_ccr_zero	;; mov.l #xx:16, @erd-	mov.l	#long_dst, er1	mov.l	#0xdead:16, @er1-	; Imm16, register post-decr operands.;;;	.word	0x7a7c;;;	.word	0xdead;;;	.word	0xa100	;; test ccr		; H=0 N=0 Z=0 V=0 C=0	test_neg_clear	test_zero_clear	test_ovf_clear	test_carry_clear	test_gr_a5a5 0		; Make sure other general regs not disturbed	test_h_gr32	long_dst-4, er1	test_gr_a5a5 2	test_gr_a5a5 3	test_gr_a5a5 4	test_gr_a5a5 5	test_gr_a5a5 6	test_gr_a5a5 7	;; Now check the result of the move to memory.	cmp.l	#0xdead, @long_dst	beq	.Lnext13	fail.Lnext13:	mov.l	#0, @long_dst	; zero it again for the next use.mov_l_imm16_to_preinc:		; pre-increment from register to mem	set_grs_a5a5		; Fill all general regs with a fixed pattern	set_ccr_zero	;; mov.l #xx:16, @+erd	mov.l	#long_dst-4, er1	mov.l	#0xdead:16, @+er1	; Imm16, register pre-incr operands;;;	.word	0x7a7c;;;	.word	0xdead;;;	.word	0x9100	;; test ccr		; H=0 N=0 Z=0 V=0 C=0	test_neg_clear	test_zero_clear	test_ovf_clear	test_carry_clear

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -