diff options
author | H.J. Lu <hjl.tools@gmail.com> | 2017-10-01 16:04:26 -0700 |
---|---|---|
committer | H.J. Lu <hjl.tools@gmail.com> | 2017-10-01 16:04:41 -0700 |
commit | 6a088436d4c04b8081e86f9e856f10fba97d0612 (patch) | |
tree | 2c229f425eba248cdc13454a71d594d237b87a81 /sysdeps | |
parent | 78cf1d74d28c9312d888dea1ad3de01d38c5fc4a (diff) | |
download | glibc-6a088436d4c04b8081e86f9e856f10fba97d0612.tar.gz glibc-6a088436d4c04b8081e86f9e856f10fba97d0612.tar.xz glibc-6a088436d4c04b8081e86f9e856f10fba97d0612.zip |
Hide internal signal functions [BZ #18822]
Hide internal signal functions to allow direct access within libc.so and libc.a without using GOT nor PLT. __GI___kill and __GI___sigaltstack are defined when syscalls.list is used to generate them. Otherwise libc_hidden_def is needed explicitly. [BZ #18822] * include/signal.h (__kill): Add libc_hidden_proto. (__sigblock): Likewise. (__sigprocmask): Likewise. (__sigaltstack): Likewise. * signal/kill.c (__kill): Add libc_hidden_def. * signal/sigblock.c (__sigblock): Likewise. * signal/sigprocmask.c (__sigprocmask): Likewise. * sysdeps/mach/hurd/kill.c (__kill): Likewise. * sysdeps/mach/hurd/sigaltstack.c (__sigaltstack): Likewise. * sysdeps/mach/hurd/sigprocmask.c (__sigprocmask): Likewise. * sysdeps/posix/sigblock.c (__sigblock): Likewise. * sysdeps/unix/sysv/linux/alpha/sigprocmask.c (__sigprocmask): Likewise. * sysdeps/unix/sysv/linux/ia64/sigprocmask.c (__sigprocmask): Likewise. * sysdeps/unix/sysv/linux/s390/s390-64/sigprocmask.c (__sigprocmask): Likewise. * sysdeps/unix/sysv/linux/sigprocmask.c (__sigprocmask): Likewise. * /sysdeps/unix/sysv/linux/sparc/sparc64/sigprocmask.c (__sigprocmask): Likewise. * sysdeps/unix/sysv/linux/x86_64/sigprocmask.c (__sigprocmask): Likewise.
Diffstat (limited to 'sysdeps')
-rw-r--r-- | sysdeps/mach/hurd/kill.c | 1 | ||||
-rw-r--r-- | sysdeps/mach/hurd/sigaltstack.c | 1 | ||||
-rw-r--r-- | sysdeps/mach/hurd/sigprocmask.c | 1 | ||||
-rw-r--r-- | sysdeps/posix/sigblock.c | 1 | ||||
-rw-r--r-- | sysdeps/unix/sysv/linux/alpha/sigprocmask.c | 1 | ||||
-rw-r--r-- | sysdeps/unix/sysv/linux/ia64/sigprocmask.c | 1 | ||||
-rw-r--r-- | sysdeps/unix/sysv/linux/s390/s390-64/sigprocmask.c | 1 | ||||
-rw-r--r-- | sysdeps/unix/sysv/linux/sigprocmask.c | 1 | ||||
-rw-r--r-- | sysdeps/unix/sysv/linux/sparc/sparc64/sigprocmask.c | 1 | ||||
-rw-r--r-- | sysdeps/unix/sysv/linux/x86_64/sigprocmask.c | 1 |
10 files changed, 10 insertions, 0 deletions
diff --git a/sysdeps/mach/hurd/kill.c b/sysdeps/mach/hurd/kill.c index 2d556dd2ff..5360bb52c5 100644 --- a/sysdeps/mach/hurd/kill.c +++ b/sysdeps/mach/hurd/kill.c @@ -146,4 +146,5 @@ __kill (pid_t pid, int sig) return delivered ? 0 : __hurd_fail (err ?: ESRCH); } +libc_hidden_def (__kill) weak_alias (__kill, kill) diff --git a/sysdeps/mach/hurd/sigaltstack.c b/sysdeps/mach/hurd/sigaltstack.c index 4fba69e766..3fde510e23 100644 --- a/sysdeps/mach/hurd/sigaltstack.c +++ b/sysdeps/mach/hurd/sigaltstack.c @@ -57,4 +57,5 @@ __sigaltstack (const stack_t *argss, stack_t *oss) return 0; } +libc_hidden_def (__sigaltstack) weak_alias (__sigaltstack, sigaltstack) diff --git a/sysdeps/mach/hurd/sigprocmask.c b/sysdeps/mach/hurd/sigprocmask.c index a4ebe580ff..70b9a10a7b 100644 --- a/sysdeps/mach/hurd/sigprocmask.c +++ b/sysdeps/mach/hurd/sigprocmask.c @@ -80,4 +80,5 @@ __sigprocmask (int how, const sigset_t *set, sigset_t *oset) return 0; } +libc_hidden_def (__sigprocmask) weak_alias (__sigprocmask, sigprocmask) diff --git a/sysdeps/posix/sigblock.c b/sysdeps/posix/sigblock.c index 1f8686458b..ab59f2968f 100644 --- a/sysdeps/posix/sigblock.c +++ b/sysdeps/posix/sigblock.c @@ -35,4 +35,5 @@ __sigblock (int mask) return sigset_get_old_mask (&oset); } +libc_hidden_def (__sigblock) weak_alias (__sigblock, sigblock) diff --git a/sysdeps/unix/sysv/linux/alpha/sigprocmask.c b/sysdeps/unix/sysv/linux/alpha/sigprocmask.c index 39a07de475..ebec70cff0 100644 --- a/sysdeps/unix/sysv/linux/alpha/sigprocmask.c +++ b/sysdeps/unix/sysv/linux/alpha/sigprocmask.c @@ -54,4 +54,5 @@ __sigprocmask (int how, const sigset_t *set, sigset_t *oset) return 0; } +libc_hidden_def (__sigprocmask) weak_alias (__sigprocmask, sigprocmask); diff --git a/sysdeps/unix/sysv/linux/ia64/sigprocmask.c b/sysdeps/unix/sysv/linux/ia64/sigprocmask.c index 7e62438b03..920c5fd052 100644 --- a/sysdeps/unix/sysv/linux/ia64/sigprocmask.c +++ b/sysdeps/unix/sysv/linux/ia64/sigprocmask.c @@ -36,4 +36,5 @@ __sigprocmask (int how, const sigset_t *set, sigset_t *oset) real size of the user-level sigset_t. */ return INLINE_SYSCALL (rt_sigprocmask, 4, how, set, oset, _NSIG / 8); } +libc_hidden_def (__sigprocmask) weak_alias (__sigprocmask, sigprocmask) diff --git a/sysdeps/unix/sysv/linux/s390/s390-64/sigprocmask.c b/sysdeps/unix/sysv/linux/s390/s390-64/sigprocmask.c index 4cbbc8e133..a8010e7f14 100644 --- a/sysdeps/unix/sysv/linux/s390/s390-64/sigprocmask.c +++ b/sysdeps/unix/sysv/linux/s390/s390-64/sigprocmask.c @@ -34,4 +34,5 @@ __sigprocmask (int how, const sigset_t *set, sigset_t *oset) real size of the user-level sigset_t. */ return INLINE_SYSCALL (rt_sigprocmask, 4, how, set, oset, _NSIG / 8); } +libc_hidden_def (__sigprocmask) weak_alias (__sigprocmask, sigprocmask) diff --git a/sysdeps/unix/sysv/linux/sigprocmask.c b/sysdeps/unix/sysv/linux/sigprocmask.c index e39e5f6872..d0b8e049b2 100644 --- a/sysdeps/unix/sysv/linux/sigprocmask.c +++ b/sysdeps/unix/sysv/linux/sigprocmask.c @@ -53,4 +53,5 @@ __sigprocmask (int how, const sigset_t *set, sigset_t *oset) return INLINE_SYSCALL (rt_sigprocmask, 4, how, set, oset, _NSIG / 8); } +libc_hidden_def (__sigprocmask) weak_alias (__sigprocmask, sigprocmask) diff --git a/sysdeps/unix/sysv/linux/sparc/sparc64/sigprocmask.c b/sysdeps/unix/sysv/linux/sparc/sparc64/sigprocmask.c index c2205d0044..ef7d7feb49 100644 --- a/sysdeps/unix/sysv/linux/sparc/sparc64/sigprocmask.c +++ b/sysdeps/unix/sysv/linux/sparc/sparc64/sigprocmask.c @@ -30,4 +30,5 @@ __sigprocmask (int how, const sigset_t *set, sigset_t *oset) real size of the user-level sigset_t. */ return INLINE_SYSCALL (rt_sigprocmask, 4, how, set, oset, _NSIG / 8); } +libc_hidden_def (__sigprocmask) weak_alias (__sigprocmask, sigprocmask) diff --git a/sysdeps/unix/sysv/linux/x86_64/sigprocmask.c b/sysdeps/unix/sysv/linux/x86_64/sigprocmask.c index a87ad106ea..1610ddf47f 100644 --- a/sysdeps/unix/sysv/linux/x86_64/sigprocmask.c +++ b/sysdeps/unix/sysv/linux/x86_64/sigprocmask.c @@ -35,4 +35,5 @@ __sigprocmask (int how, const sigset_t *set, sigset_t *oset) real size of the user-level sigset_t. */ return INLINE_SYSCALL (rt_sigprocmask, 4, how, set, oset, _NSIG / 8); } +libc_hidden_def (__sigprocmask) weak_alias (__sigprocmask, sigprocmask) |