diff options
-rw-r--r-- | include/libc-symbols.h | 18 | ||||
-rw-r--r-- | sysdeps/unix/sysv/linux/i386/makecontext.S | 4 |
2 files changed, 14 insertions, 8 deletions
diff --git a/include/libc-symbols.h b/include/libc-symbols.h index 74fea25e9e..03602327f5 100644 --- a/include/libc-symbols.h +++ b/include/libc-symbols.h @@ -508,16 +508,22 @@ are defined by its normal name and we need to create the __GI_* alias to it, in C __REDIRECT causes the function definition to use __GI_* name and we need to add alias to the real name. - hidden_proto and hidden_weak don't make sense for assembly. */ -# define hidden_def(name) strong_alias (name, __GI_##name) -# define hidden_weak(name) weak_alias (name, __GI_##name) + There is no reason to use hidden_weak over hidden_def in assembly, + but we provide it for consistency with the C usage. + hidden_proto doesn't make sense for assembly but the equivalent + is to call via the HIDDEN_JUMPTARGET macro einstead of JUMPTARGET. */ +# define hidden_def(name) strong_alias (name, __GI_##name) +# define hidden_weak(name) hidden_def (name) # define hidden_ver(local, name) strong_alias (local, __GI_##name) +# define HIDDEN_JUMPTARGET(name) __GI_##name # endif #else -# ifndef __ASSEMBLY__ +# ifndef __ASSEMBLER__ # define hidden_proto(name) -# define hidden_weak(name) -# endif +# else +# define HIDDEN_JUMPTARGET(name) JUMPTARGET(name) +# endif /* Not __ASSEMBLER__ */ +# define hidden_weak(name) # define hidden_def(name) # define hidden_ver(local, name) #endif diff --git a/sysdeps/unix/sysv/linux/i386/makecontext.S b/sysdeps/unix/sysv/linux/i386/makecontext.S index 56b5537ce3..ec49b74b9a 100644 --- a/sysdeps/unix/sysv/linux/i386/makecontext.S +++ b/sysdeps/unix/sysv/linux/i386/makecontext.S @@ -1,5 +1,5 @@ /* Create new context. - Copyright (C) 2001 Free Software Foundation, Inc. + Copyright (C) 2001,02 Free Software Foundation, Inc. This file is part of the GNU C Library. Contributed by Ulrich Drepper <drepper@redhat.com>, 2001. @@ -104,7 +104,7 @@ L(exitcode): exit the program with the return error value (-1). */ 2: pushl %eax - call JUMPTARGET(exit) + call HIDDEN_JUMPTARGET(exit) /* The 'exit' call should never return. In case it does cause the process to terminate. */ hlt |