]> git.ipfire.org Git - thirdparty/glibc.git/blame - sysdeps/i386/i386-mcount.S
Update copyright dates with scripts/update-copyrights.
[thirdparty/glibc.git] / sysdeps / i386 / i386-mcount.S
CommitLineData
12f1ae05 1/* i386-specific implementation of profiling support.
04277e02 2 Copyright (C) 1997-2019 Free Software Foundation, Inc.
5ae9d168
UD
3 This file is part of the GNU C Library.
4 Contributed by Ulrich Drepper <drepper@cygnus.com>, 1997.
5
6 The GNU C Library is free software; you can redistribute it and/or
41bdb6e2
AJ
7 modify it under the terms of the GNU Lesser General Public
8 License as published by the Free Software Foundation; either
9 version 2.1 of the License, or (at your option) any later version.
5ae9d168
UD
10
11 The GNU C Library is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
41bdb6e2 14 Lesser General Public License for more details.
5ae9d168 15
41bdb6e2 16 You should have received a copy of the GNU Lesser General Public
59ba27a6
PE
17 License along with the GNU C Library; if not, see
18 <http://www.gnu.org/licenses/>. */
5ae9d168
UD
19
20#include <sysdep.h>
21
22/* We need a special version of the `mcount' function since for ix86 it
23 must not clobber any register. This has several reasons:
24 - there is a bug in gcc as of version 2.7.2.2 which prohibits the
25 use of profiling together with nested functions
26 - the ELF `fixup' function uses GCC's regparm feature
27 - some (future) systems might want to pass parameters in registers. */
28
7b8e0d49 29 .globl C_SYMBOL_NAME(_mcount)
b67e9372 30 .type C_SYMBOL_NAME(_mcount), @function
5ae9d168
UD
31 .align ALIGNARG(4)
32C_LABEL(_mcount)
33 /* Save the caller-clobbered registers. */
34 pushl %eax
35 pushl %ecx
36 pushl %edx
37
dff07c4b
UD
38 movl 12(%esp), %edx
39 movl 4(%ebp), %eax
5ae9d168 40
dff07c4b
UD
41 /* No need to access the PLT or GOT, __mcount_internal is an
42 internal function and we can make a relative call. */
5ae9d168 43 call C_SYMBOL_NAME(__mcount_internal)
5ae9d168
UD
44
45 /* Pop the saved registers. Please note that `mcount' has no
46 return value. */
47 popl %edx
48 popl %ecx
49 popl %eax
50 ret
51 ASM_SIZE_DIRECTIVE(C_SYMBOL_NAME(_mcount))
52
53#undef mcount
1ab18a5b 54weak_alias (_mcount, mcount)
d22e4cc9
AK
55
56 /* Same as above, but doesn't require a frame pointer */
7b8e0d49 57 .globl C_SYMBOL_NAME(__fentry__)
b67e9372 58 .type C_SYMBOL_NAME(__fentry__), @function
d22e4cc9
AK
59 .align ALIGNARG(4)
60C_LABEL(__fentry__)
61 /* Save the caller-clobbered registers. */
62 pushl %eax
63 pushl %ecx
64 pushl %edx
65
66 movl 12(%esp), %edx
67 movl 16(%esp), %eax
68
69 /* No need to access the PLT or GOT, __mcount_internal is an
70 internal function and we can make a relative call. */
71 call C_SYMBOL_NAME(__mcount_internal)
72
73 /* Pop the saved registers. Please note that `__fentry__' has no
74 return value. */
75 popl %edx
76 popl %ecx
77 popl %eax
78 ret
79 ASM_SIZE_DIRECTIVE(C_SYMBOL_NAME(__fentry__))