1
0
Fork 0
mirror of https://github.com/tobast/libunwind-eh_elf.git synced 2024-11-22 07:37:38 +01:00

Separate bundle template directive from instruction with a semicolon. The Intel

assembler wants this.

(Logical change 1.68)
This commit is contained in:
mostang.com!davidm 2003-03-27 04:29:07 +00:00
parent a4e77a211a
commit 16192f7eac

View file

@ -1,7 +1,7 @@
.globl func_add1, func_add1_end
.proc func_add1
func_add1:
{.mib add r8 = 1, r32
{.mib; add r8 = 1, r32
nop.i 0
br.ret.sptk.many rp
}
@ -11,42 +11,36 @@ func_add1_end:
.globl func_add3, func_add3_end
.proc func_add3
func_add3:
{.mmi alloc loc0 = ar.pfs, 2, 1, 2, 0
{.mmi; alloc loc0 = ar.pfs, 2, 1, 2, 0
mov r2 = sp
add sp = -16, sp
} ;;
{.mii
ld8 r8 = [in1], 8 // load the function pointer
{.mii; ld8 r8 = [in1], 8 // load the function pointer
mov r3 = rp
mov rp = loc0 // trash rp
} ;;
{.mmi
ld8 r9 = [r8], 8 // load the entry-point
{.mmi; ld8 r9 = [r8], 8 // load the entry-point
st8 [r2] = r3
mov out0 = in0
} ;;
{.mii ld8 gp = [r8] // load the gp
{.mii; ld8 gp = [r8] // load the gp
mov b6 = r9
mov out1 = in1
}
{.mib
nop 0
{.mib; nop 0
nop 0
br.call.sptk rp = b6
}
{.mmi
add r2 = 16, sp
{.mmi; add r2 = 16, sp
;;
ld8 r3 = [r2] // r3 = saved rp
mov ar.pfs = loc0
} ;;
{.mii
nop 0
{.mii; nop 0
mov rp = r3
adds sp = 16, sp
} ;;
{.mib
st8 [sp] = in0 // trash rp save location
{.mib; st8 [sp] = in0 // trash rp save location
add r8 = 2, r8
br.ret.sptk.many rp
}
@ -56,46 +50,46 @@ func_add3_end:
.globl func_vframe, func_vframe_end
.proc func_vframe
func_vframe:
{.mii alloc r16 = ar.pfs, 1, 2, 0, 0 // 0
{.mii; alloc r16 = ar.pfs, 1, 2, 0, 0 // 0
mov loc0 = rp
mov loc1 = sp
} ;;
{.mmi sub sp = sp, in0
{.mmi; sub sp = sp, in0
st8 [loc1] = r16
mov r2 = -99 // 0
} ;;
{.mii nop 0
{.mii; nop 0
mov rp = r2
mov ar.pfs = r0
}
{.mib mov r16 = r2
{.mib; mov r16 = r2
tbit.nz p6, p0 = in0, 4
(p6) br.cond.sptk.many 1f
(p6) br.cond.sptk.many .exit
} ;;
{.mmi ld8 r16 = [loc1]
{.mmi; ld8 r16 = [loc1]
;;
mov r3 = loc0 // 8 move saved rp to r3
mov ar.pfs = r16
} ;;
{.mmi mov sp = loc1 // 10
{.mmi; mov sp = loc1 // 10
st8 [loc1] = r0 // trash saved pfs
mov loc0 = r2
} ;;
{.mib mov r8 = 10
{.mib; mov r8 = 10
mov rp = r3
br.ret.sptk.many rp
}
1:
{.mmi ld8 r16 = [loc1]
.exit:
{.mmi; ld8 r16 = [loc1]
;;
sub sp = 32, sp
mov ar.pfs = r16
} ;;
{.mmi mov sp = loc1
{.mmi; mov sp = loc1
st8 [loc1] = r0 // trash saved pfs
mov rp = loc0
}
{.mib nop 0
{.mib; nop 0
mov r8 = 4
br.ret.sptk.many rp
}