mirror of
https://sourceware.org/git/glibc.git
synced 2025-07-30 22:43:12 +03:00
x86: Add support for frame pointer less mcount
This commit is contained in:
committed by
Ulrich Drepper
parent
805bc17d68
commit
d22e4cc939
@ -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>
|
2010-08-06 Ulrich Drepper <drepper@redhat.com>
|
||||||
|
|
||||||
* sysdeps/unix/sysv/linux/getlogin_r.c (__getlogin_r_loginuid):
|
* sysdeps/unix/sysv/linux/getlogin_r.c (__getlogin_r_loginuid):
|
||||||
|
@ -29,6 +29,7 @@ libc {
|
|||||||
GLIBC_2.10
|
GLIBC_2.10
|
||||||
GLIBC_2.11
|
GLIBC_2.11
|
||||||
GLIBC_2.12
|
GLIBC_2.12
|
||||||
|
GLIBC_2.13
|
||||||
%ifdef USE_IN_LIBIO
|
%ifdef USE_IN_LIBIO
|
||||||
HURD_CTHREADS_0.3
|
HURD_CTHREADS_0.3
|
||||||
%endif
|
%endif
|
||||||
|
@ -100,6 +100,9 @@ libc {
|
|||||||
GLIBC_2.10 {
|
GLIBC_2.10 {
|
||||||
quick_exit; __cxa_at_quick_exit;
|
quick_exit; __cxa_at_quick_exit;
|
||||||
}
|
}
|
||||||
|
GLIBC_2.13 {
|
||||||
|
__fentry__;
|
||||||
|
}
|
||||||
GLIBC_PRIVATE {
|
GLIBC_PRIVATE {
|
||||||
# functions which have an additional interface since they are
|
# functions which have an additional interface since they are
|
||||||
# are cancelable.
|
# are cancelable.
|
||||||
|
@ -53,3 +53,28 @@ C_LABEL(_mcount)
|
|||||||
|
|
||||||
#undef mcount
|
#undef mcount
|
||||||
weak_alias (_mcount, 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__))
|
||||||
|
@ -65,3 +65,41 @@ C_LABEL(_mcount)
|
|||||||
|
|
||||||
#undef mcount
|
#undef mcount
|
||||||
weak_alias (_mcount, 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__))
|
||||||
|
Reference in New Issue
Block a user