x86: Add support for frame pointer less mcount

This commit is contained in:
Andi Kleen 2010-08-07 21:24:05 -07:00 committed by Ulrich Drepper
parent 805bc17d68
commit d22e4cc939
5 changed files with 74 additions and 0 deletions

View File

@ -1,3 +1,10 @@
2010-07-17 Andi Kleen <ak@linux.intel.com>
* sysdeps/i386/i386-mcount.S (__fentry__): Define.
* sysdeps/x86_64/_mcount.S (__fentry__): Define.
* stdlib/Versions (__fentry__): Add for GLIBC 2.13
* Versions.def [GLIBC_2.13]: Add.
2010-08-06 Ulrich Drepper <drepper@redhat.com>
* sysdeps/unix/sysv/linux/getlogin_r.c (__getlogin_r_loginuid):

View File

@ -29,6 +29,7 @@ libc {
GLIBC_2.10
GLIBC_2.11
GLIBC_2.12
GLIBC_2.13
%ifdef USE_IN_LIBIO
HURD_CTHREADS_0.3
%endif

View File

@ -100,6 +100,9 @@ libc {
GLIBC_2.10 {
quick_exit; __cxa_at_quick_exit;
}
GLIBC_2.13 {
__fentry__;
}
GLIBC_PRIVATE {
# functions which have an additional interface since they are
# are cancelable.

View File

@ -53,3 +53,28 @@ C_LABEL(_mcount)
#undef mcount
weak_alias (_mcount, mcount)
/* Same as above, but doesn't require a frame pointer */
ASM_GLOBAL_DIRECTIVE C_SYMBOL_NAME(__fentry__)
ASM_TYPE_DIRECTIVE(C_SYMBOL_NAME(__fentry__), @function)
.align ALIGNARG(4)
C_LABEL(__fentry__)
/* Save the caller-clobbered registers. */
pushl %eax
pushl %ecx
pushl %edx
movl 12(%esp), %edx
movl 16(%esp), %eax
/* No need to access the PLT or GOT, __mcount_internal is an
internal function and we can make a relative call. */
call C_SYMBOL_NAME(__mcount_internal)
/* Pop the saved registers. Please note that `__fentry__' has no
return value. */
popl %edx
popl %ecx
popl %eax
ret
ASM_SIZE_DIRECTIVE(C_SYMBOL_NAME(__fentry__))

View File

@ -65,3 +65,41 @@ C_LABEL(_mcount)
#undef mcount
weak_alias (_mcount, mcount)
ASM_GLOBAL_DIRECTIVE C_SYMBOL_NAME(__fentry__)
ASM_TYPE_DIRECTIVE(C_SYMBOL_NAME(__fentry__), @function)
.align ALIGNARG(4)
C_LABEL(__fentry__)
/* Allocate space for 7 registers. */
subq $64,%rsp
movq %rax,(%rsp)
movq %rcx,8(%rsp)
movq %rdx,16(%rsp)
movq %rsi,24(%rsp)
movq %rdi,32(%rsp)
movq %r8,40(%rsp)
movq %r9,48(%rsp)
/* Setup parameter for __mcount_internal. */
/* selfpc is the return address on the stack. */
movq 64(%rsp),%rsi
/* caller is the return address above it */
movq 72(%rsp),%rdi
#ifdef PIC
call C_SYMBOL_NAME(__mcount_internal)@PLT
#else
call C_SYMBOL_NAME(__mcount_internal)
#endif
/* Pop the saved registers. Please note that `__fentry__' has no
return value. */
movq 48(%rsp),%r9
movq 40(%rsp),%r8
movq 32(%rsp),%rdi
movq 24(%rsp),%rsi
movq 16(%rsp),%rdx
movq 8(%rsp),%rcx
movq (%rsp),%rax
addq $64,%rsp
ret
ASM_SIZE_DIRECTIVE(C_SYMBOL_NAME(__fentry__))