old-cross-binutils/sim/testsuite/mips64vr5900el-elf/t-macros.i
1997-09-01 09:47:03 +00:00

108 lines
1.2 KiB
OpenEdge ABL

# NB: In the below, the 64bit values are embeded into the
# machine code. The address of which being determined
# by a jal (after a jump to an aligned address).
.macro load reg hi lo
j 1f
nop
.align 3
1: jal 2f
nop
.quad \hi
.quad \lo
2:
ld \reg, 0($31)
pcpyld \reg, \reg, $0
ld \reg, 8($31)
.endm
.macro check10 hi lo
j 1f
nop
.align 3
1: jal 2f
nop
.quad \hi
.quad \lo
2: pcpyud $11, $10, $0
ld $5, 0($31)
beq $11, $5, 3f
nop
li $4, 47
break 1023
nop
3: nop
ld $5, 8($31)
beq $10, $5, 3f
nop
li $4, 47
break 1023
nop
3: nop
.endm
.macro checkHI hi lo
j 1f
nop
.align 3
1: jal 2f
nop
.quad \hi
.quad \lo
2: mfhi1 $11
ld $5, 0($31)
beq $11, $5, 3f
nop
li $4, 47
break 1023
nop
3: nop
mfhi $11
ld $5, 8($31)
beq $11, $5, 3f
nop
li $4, 47
break 1023
nop
3: nop
.endm
.macro checkLO hi lo
j 1f
nop
.align 3
1: jal 2f
nop
.quad \hi
.quad \lo
2: mflo1 $11
ld $5, 0($31)
beq $11, $5, 3f
nop
li $4, 47
break 1023
nop
3: nop
mflo $11
ld $5, 8($31)
beq $11, $5, 3f
nop
li $4, 47
break 1023
nop
3: nop
.endm
.macro start
.text
.globl _start
.set noreorder
_start:
.endm
.macro exit0
li $4, 0
break 1023
nop
.endm