mirror of
https://sourceware.org/git/glibc.git
synced 2024-12-02 22:23:52 +08:00
Prefer real syscalls instead of vsyscalls on x86-64 outside libc.so
This commit is contained in:
parent
6585cb60ee
commit
ef60624956
10
ChangeLog
10
ChangeLog
@ -1,3 +1,13 @@
|
|||||||
|
2011-09-06 Ulrich Drepper <drepper@gmail.com>
|
||||||
|
|
||||||
|
* sysdeps/unix/sysv/linux/kernel-features.h: Add entry for getcpu
|
||||||
|
syscall on x86-64.
|
||||||
|
* sysdeps/unix/sysv/linux/x86_64/gettimeofday.c [!SHARED]: Use real
|
||||||
|
syscall.
|
||||||
|
* sysdeps/unix/sysv/linux/x86_64/time.c: Likewise.
|
||||||
|
* sysdeps/unix/sysv/linux/x86_64/sched_getcpu.S [!SHARED]: Use real
|
||||||
|
syscall if possible.
|
||||||
|
|
||||||
2011-09-05 Ulrich Drepper <drepper@gmail.com>
|
2011-09-05 Ulrich Drepper <drepper@gmail.com>
|
||||||
|
|
||||||
* elf/pldd.c (get_process_info): Don't read whole ELF header, just
|
* elf/pldd.c (get_process_info): Don't read whole ELF header, just
|
||||||
|
@ -546,3 +546,8 @@
|
|||||||
#if __LINUX_KERNEL_VERSION >= 0x020627
|
#if __LINUX_KERNEL_VERSION >= 0x020627
|
||||||
# define __ASSUME_SENDMMSG 1
|
# define __ASSUME_SENDMMSG 1
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/* getcpu is a syscall for x86-64 since 3.1. */
|
||||||
|
#if defined __x86_64__ && __LINUX_KERNEL_VERSION >= 0x030100
|
||||||
|
# define __ASSUME_GETCPU_SYSCALL 1
|
||||||
|
#endif
|
||||||
|
@ -37,11 +37,12 @@ gettimeofday_ifunc (void)
|
|||||||
__asm (".type __gettimeofday, %gnu_indirect_function");
|
__asm (".type __gettimeofday, %gnu_indirect_function");
|
||||||
#else
|
#else
|
||||||
# include <sys/time.h>
|
# include <sys/time.h>
|
||||||
|
# include <sysdep.h>
|
||||||
|
|
||||||
int
|
int
|
||||||
__gettimeofday (struct timeval *tv, struct timezone *tz)
|
__gettimeofday (struct timeval *tv, struct timezone *tz)
|
||||||
{
|
{
|
||||||
return ((int (*) (struct timeval *, struct timezone *)) VSYSCALL_ADDR_vgettimeofday) (tv, tz);
|
return INLINE_SYSCALL (gettimeofday, 2, tv, tz);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -20,6 +20,7 @@
|
|||||||
#include <tls.h>
|
#include <tls.h>
|
||||||
#define _ERRNO_H 1
|
#define _ERRNO_H 1
|
||||||
#include <bits/errno.h>
|
#include <bits/errno.h>
|
||||||
|
#include <kernel-features.h>
|
||||||
|
|
||||||
/* For the calculation see asm/vsyscall.h. */
|
/* For the calculation see asm/vsyscall.h. */
|
||||||
#define VSYSCALL_ADDR_vgetcpu 0xffffffffff600800
|
#define VSYSCALL_ADDR_vgetcpu 0xffffffffff600800
|
||||||
@ -38,10 +39,26 @@ ENTRY (sched_getcpu)
|
|||||||
#ifdef SHARED
|
#ifdef SHARED
|
||||||
movq __vdso_getcpu(%rip), %rax
|
movq __vdso_getcpu(%rip), %rax
|
||||||
PTR_DEMANGLE (%rax)
|
PTR_DEMANGLE (%rax)
|
||||||
#else
|
|
||||||
movq $VSYSCALL_ADDR_vgetcpu, %rax
|
|
||||||
#endif
|
|
||||||
callq *%rax
|
callq *%rax
|
||||||
|
#else
|
||||||
|
# ifdef __NR_getcpu
|
||||||
|
movl $__NR_getcpu, %eax
|
||||||
|
syscall
|
||||||
|
# ifndef __ASSUME_GETCPU_SYSCALL
|
||||||
|
cmpq $-ENOSYS, %rax
|
||||||
|
jne 1f
|
||||||
|
# endif
|
||||||
|
# endif
|
||||||
|
# ifndef __ASSUME_GETCPU_SYSCALL
|
||||||
|
movq $VSYSCALL_ADDR_vgetcpu, %rax
|
||||||
|
callq *%rax
|
||||||
|
1:
|
||||||
|
# else
|
||||||
|
# ifndef __NR_getcpu
|
||||||
|
# error "cannot happen"
|
||||||
|
# endif
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
|
||||||
cmpq $-4095, %rax
|
cmpq $-4095, %rax
|
||||||
jae SYSCALL_ERROR_LABEL
|
jae SYSCALL_ERROR_LABEL
|
||||||
|
@ -36,11 +36,13 @@ time_ifunc (void)
|
|||||||
__asm (".type time, %gnu_indirect_function");
|
__asm (".type time, %gnu_indirect_function");
|
||||||
#else
|
#else
|
||||||
# include <time.h>
|
# include <time.h>
|
||||||
|
# include <sysdep.h>
|
||||||
|
|
||||||
time_t
|
time_t
|
||||||
time (time_t *t)
|
time (time_t *t)
|
||||||
{
|
{
|
||||||
return ((time_t (*) (time_t *)) VSYSCALL_ADDR_vtime) (t);
|
INTERNAL_SYSCALL_DECL (err);
|
||||||
|
return INTERNAL_SYSCALL (time, err, 1, t);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user