Manually sync form upstrem master:
- Add back x86 vDSO support. - Fix rtkaio build to reference clock_* functions from libc.
This commit is contained in:
parent
a086cd2399
commit
85a0930b02
@ -1,655 +0,0 @@
|
||||
commit ca677d3c3cd0eba7d1f03092517aea553a0e8569
|
||||
Author: Adhemerval Zanella <azanella@linux.vnet.ibm.com>
|
||||
Date: Fri Jun 27 14:00:18 2014 -0700
|
||||
|
||||
Add x86 32 bit vDSO time function support
|
||||
|
||||
Linux 3.15 adds support for clock_gettime, gettimeofday, and time vDSO
|
||||
(commit id 37c975545ec63320789962bf307f000f08fabd48). This patch adds
|
||||
GLIBC supports to use such symbol when they are avaiable.
|
||||
|
||||
Along with x86 vDSO support, this patch cleanup x86_64 code by moving
|
||||
all common code to x86 common folder. Only init-first.c is different
|
||||
between implementations.
|
||||
|
||||
diff --git a/sysdeps/unix/sysv/linux/i386/gettimeofday.c b/sysdeps/unix/sysv/linux/i386/gettimeofday.c
|
||||
new file mode 100644
|
||||
index 0000000..3e00eb4
|
||||
--- /dev/null
|
||||
+++ b/sysdeps/unix/sysv/linux/i386/gettimeofday.c
|
||||
@@ -0,0 +1,39 @@
|
||||
+/* gettimeofday - get the time. Linux/i386 version.
|
||||
+ Copyright (C) 2015 Free Software Foundation, Inc.
|
||||
+ This file is part of the GNU C Library.
|
||||
+
|
||||
+ The GNU C Library is free software; you can redistribute it and/or
|
||||
+ modify it under the terms of the GNU Lesser General Public
|
||||
+ License as published by the Free Software Foundation; either
|
||||
+ version 2.1 of the License, or (at your option) any later version.
|
||||
+
|
||||
+ The GNU C Library is distributed in the hope that it will be useful,
|
||||
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
+ Lesser General Public License for more details.
|
||||
+
|
||||
+ You should have received a copy of the GNU Lesser General Public
|
||||
+ License along with the GNU C Library; if not, see
|
||||
+ <http://www.gnu.org/licenses/>. */
|
||||
+
|
||||
+#include <sys/time.h>
|
||||
+
|
||||
+#ifdef SHARED
|
||||
+
|
||||
+# include <dl-vdso.h>
|
||||
+# include <errno.h>
|
||||
+
|
||||
+/* If the vDSO is not available we fall back on the syscall. */
|
||||
+static int
|
||||
+__gettimeofday_syscall (struct timeval *tv, struct timezone *tz)
|
||||
+{
|
||||
+ return INLINE_SYSCALL (gettimeofday, 2, tv, tz);
|
||||
+}
|
||||
+# define GETTIMEOFAY_FALLBACK (void*) (&__gettimeofday_syscall)
|
||||
+# undef libc_ifunc_hidden_def
|
||||
+# define libc_ifunc_hidden_def(name) \
|
||||
+ libc_ifunc_hidden_def1 (__GI_##name, __gettimeofday_syscall)
|
||||
+
|
||||
+#endif
|
||||
+
|
||||
+#include <sysdeps/unix/sysv/linux/x86/gettimeofday.c>
|
||||
diff --git a/sysdeps/unix/sysv/linux/i386/init-first.c b/sysdeps/unix/sysv/linux/i386/init-first.c
|
||||
new file mode 100644
|
||||
index 0000000..4be65d7
|
||||
--- /dev/null
|
||||
+++ b/sysdeps/unix/sysv/linux/i386/init-first.c
|
||||
@@ -0,0 +1,52 @@
|
||||
+/* Initialization code run first thing by the ELF startup code. Linux/i386.
|
||||
+ Copyright (C) 2015 Free Software Foundation, Inc.
|
||||
+ This file is part of the GNU C Library.
|
||||
+
|
||||
+ The GNU C Library is free software; you can redistribute it and/or
|
||||
+ modify it under the terms of the GNU Lesser General Public
|
||||
+ License as published by the Free Software Foundation; either
|
||||
+ version 2.1 of the License, or (at your option) any later version.
|
||||
+
|
||||
+ The GNU C Library is distributed in the hope that it will be useful,
|
||||
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
+ Lesser General Public License for more details.
|
||||
+
|
||||
+ You should have received a copy of the GNU Lesser General Public
|
||||
+ License along with the GNU C Library; if not, see
|
||||
+ <http://www.gnu.org/licenses/>. */
|
||||
+
|
||||
+#ifdef SHARED
|
||||
+# include <time.h>
|
||||
+# include <sysdep.h>
|
||||
+# include <dl-vdso.h>
|
||||
+# include <libc-vdso.h>
|
||||
+
|
||||
+long int (*__vdso_clock_gettime) (clockid_t, struct timespec *)
|
||||
+ __attribute__ ((nocommon));
|
||||
+libc_hidden_proto (__vdso_clock_gettime)
|
||||
+libc_hidden_data_def (__vdso_clock_gettime)
|
||||
+
|
||||
+static long int
|
||||
+clock_gettime_syscall (clockid_t id, struct timespec *tp)
|
||||
+{
|
||||
+ INTERNAL_SYSCALL_DECL (err);
|
||||
+ return INTERNAL_SYSCALL (clock_gettime, err, 2, id, tp);
|
||||
+}
|
||||
+
|
||||
+static inline void
|
||||
+__vdso_platform_setup (void)
|
||||
+{
|
||||
+ PREPARE_VERSION_KNOWN (linux26, LINUX_2_6);
|
||||
+
|
||||
+ void *p = _dl_vdso_vsym ("__vdso_clock_gettime", &linux26);
|
||||
+ if (p == NULL)
|
||||
+ p = clock_gettime_syscall;
|
||||
+ PTR_MANGLE (p);
|
||||
+ __vdso_clock_gettime = p;
|
||||
+}
|
||||
+
|
||||
+# define VDSO_SETUP __vdso_platform_setup
|
||||
+#endif
|
||||
+
|
||||
+#include <csu/init-first.c>
|
||||
diff --git a/sysdeps/unix/sysv/linux/i386/time.c b/sysdeps/unix/sysv/linux/i386/time.c
|
||||
new file mode 100644
|
||||
index 0000000..e8a4e59
|
||||
--- /dev/null
|
||||
+++ b/sysdeps/unix/sysv/linux/i386/time.c
|
||||
@@ -0,0 +1,37 @@
|
||||
+/* time -- Get number of seconds since Epoch. Linux/i386 version.
|
||||
+ Copyright (C) 2015 Free Software Foundation, Inc.
|
||||
+ This file is part of the GNU C Library.
|
||||
+
|
||||
+ The GNU C Library is free software; you can redistribute it and/or
|
||||
+ modify it under the terms of the GNU Lesser General Public
|
||||
+ License as published by the Free Software Foundation; either
|
||||
+ version 2.1 of the License, or (at your option) any later version.
|
||||
+
|
||||
+ The GNU C Library is distributed in the hope that it will be useful,
|
||||
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
+ Lesser General Public License for more details.
|
||||
+
|
||||
+ You should have received a copy of the GNU Lesser General Public
|
||||
+ License along with the GNU C Library; if not, see
|
||||
+ <http://www.gnu.org/licenses/>. */
|
||||
+
|
||||
+#ifdef SHARED
|
||||
+
|
||||
+# include <dl-vdso.h>
|
||||
+# include <errno.h>
|
||||
+
|
||||
+/* If the vDSO is not available we fall back on the old vsyscall. */
|
||||
+static time_t
|
||||
+__time_syscall (time_t *t)
|
||||
+{
|
||||
+ INTERNAL_SYSCALL_DECL (err);
|
||||
+ return INTERNAL_SYSCALL (time, err, 1, t);
|
||||
+}
|
||||
+# define TIME_FALLBACK (void*) &__time_syscall
|
||||
+# undef libc_ifunc_hidden_def
|
||||
+# define libc_ifunc_hidden_def(name) \
|
||||
+ libc_ifunc_hidden_def1 (__GI_##name, __time_syscall)
|
||||
+#endif
|
||||
+
|
||||
+#include <sysdeps/unix/sysv/linux/x86/time.c>
|
||||
diff --git a/sysdeps/unix/sysv/linux/x86/Makefile b/sysdeps/unix/sysv/linux/x86/Makefile
|
||||
index 0281f87..d6be472 100644
|
||||
--- a/sysdeps/unix/sysv/linux/x86/Makefile
|
||||
+++ b/sysdeps/unix/sysv/linux/x86/Makefile
|
||||
@@ -19,3 +19,7 @@ libpthread-sysdep_routines += init-arch
|
||||
libpthread-sysdep_routines += elision-lock elision-unlock elision-timed \
|
||||
elision-trylock
|
||||
endif
|
||||
+
|
||||
+ifeq ($(subdir),elf)
|
||||
+sysdep_routines += dl-vdso
|
||||
+endif
|
||||
diff --git a/sysdeps/unix/sysv/linux/x86/clock_gettime.c b/sysdeps/unix/sysv/linux/x86/clock_gettime.c
|
||||
new file mode 100644
|
||||
index 0000000..98ffb01
|
||||
--- /dev/null
|
||||
+++ b/sysdeps/unix/sysv/linux/x86/clock_gettime.c
|
||||
@@ -0,0 +1,34 @@
|
||||
+/* Get the current value of a clock. Linux/x86 version.
|
||||
+ Copyright (C) 2015 Free Software Foundation, Inc.
|
||||
+ This file is part of the GNU C Library.
|
||||
+
|
||||
+ The GNU C Library is free software; you can redistribute it and/or
|
||||
+ modify it under the terms of the GNU Lesser General Public
|
||||
+ License as published by the Free Software Foundation; either
|
||||
+ version 2.1 of the License, or (at your option) any later version.
|
||||
+
|
||||
+ The GNU C Library is distributed in the hope that it will be useful,
|
||||
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
+ Lesser General Public License for more details.
|
||||
+
|
||||
+ You should have received a copy of the GNU Lesser General Public
|
||||
+ License along with the GNU C Library; if not, see
|
||||
+ <http://www.gnu.org/licenses/>. */
|
||||
+
|
||||
+#include <libc-vdso.h>
|
||||
+
|
||||
+#ifdef SHARED
|
||||
+# define SYSCALL_GETTIME(id, tp) \
|
||||
+ ({ long int (*f) (clockid_t, struct timespec *) = __vdso_clock_gettime; \
|
||||
+ long int v_ret; \
|
||||
+ PTR_DEMANGLE (f); \
|
||||
+ v_ret = (*f) (id, tp); \
|
||||
+ if (INTERNAL_SYSCALL_ERROR_P (v_ret, )) { \
|
||||
+ __set_errno (INTERNAL_SYSCALL_ERRNO (v_ret, )); \
|
||||
+ v_ret = -1; \
|
||||
+ } \
|
||||
+ v_ret; })
|
||||
+#endif
|
||||
+
|
||||
+#include <sysdeps/unix/sysv/linux/clock_gettime.c>
|
||||
diff --git a/sysdeps/unix/sysv/linux/x86/gettimeofday.c b/sysdeps/unix/sysv/linux/x86/gettimeofday.c
|
||||
new file mode 100644
|
||||
index 0000000..c820fd7
|
||||
--- /dev/null
|
||||
+++ b/sysdeps/unix/sysv/linux/x86/gettimeofday.c
|
||||
@@ -0,0 +1,54 @@
|
||||
+/* gettimeofday - get the time. Linux/x86 version.
|
||||
+ Copyright (C) 2015 Free Software Foundation, Inc.
|
||||
+ This file is part of the GNU C Library.
|
||||
+
|
||||
+ The GNU C Library is free software; you can redistribute it and/or
|
||||
+ modify it under the terms of the GNU Lesser General Public
|
||||
+ License as published by the Free Software Foundation; either
|
||||
+ version 2.1 of the License, or (at your option) any later version.
|
||||
+
|
||||
+ The GNU C Library is distributed in the hope that it will be useful,
|
||||
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
+ Lesser General Public License for more details.
|
||||
+
|
||||
+ You should have received a copy of the GNU Lesser General Public
|
||||
+ License along with the GNU C Library; if not, see
|
||||
+ <http://www.gnu.org/licenses/>. */
|
||||
+
|
||||
+#include <sys/time.h>
|
||||
+
|
||||
+#ifdef SHARED
|
||||
+
|
||||
+# include <dl-vdso.h>
|
||||
+
|
||||
+void *gettimeofday_ifunc (void) __asm__ ("__gettimeofday");
|
||||
+
|
||||
+void *
|
||||
+gettimeofday_ifunc (void)
|
||||
+{
|
||||
+ PREPARE_VERSION_KNOWN (linux26, LINUX_2_6);
|
||||
+
|
||||
+ /* If the vDSO is not available we fall back on the old vsyscall. */
|
||||
+ return (_dl_vdso_vsym ("__vdso_gettimeofday", &linux26)
|
||||
+ ?: GETTIMEOFAY_FALLBACK);
|
||||
+}
|
||||
+asm (".type __gettimeofday, %gnu_indirect_function");
|
||||
+
|
||||
+libc_ifunc_hidden_def(__gettimeofday)
|
||||
+
|
||||
+#else
|
||||
+
|
||||
+# include <sysdep.h>
|
||||
+# include <errno.h>
|
||||
+
|
||||
+int
|
||||
+__gettimeofday (struct timeval *tv, struct timezone *tz)
|
||||
+{
|
||||
+ return INLINE_SYSCALL (gettimeofday, 2, tv, tz);
|
||||
+}
|
||||
+libc_hidden_def (__gettimeofday)
|
||||
+
|
||||
+#endif
|
||||
+weak_alias (__gettimeofday, gettimeofday)
|
||||
+libc_hidden_weak (gettimeofday)
|
||||
diff --git a/sysdeps/unix/sysv/linux/x86/libc-vdso.h b/sysdeps/unix/sysv/linux/x86/libc-vdso.h
|
||||
new file mode 100644
|
||||
index 0000000..03ff875
|
||||
--- /dev/null
|
||||
+++ b/sysdeps/unix/sysv/linux/x86/libc-vdso.h
|
||||
@@ -0,0 +1,31 @@
|
||||
+/* Resolve function pointers to VDSO functions.
|
||||
+ Copyright (C) 2005-2015 Free Software Foundation, Inc.
|
||||
+ This file is part of the GNU C Library.
|
||||
+
|
||||
+ The GNU C Library is free software; you can redistribute it and/or
|
||||
+ modify it under the terms of the GNU Lesser General Public
|
||||
+ License as published by the Free Software Foundation; either
|
||||
+ version 2.1 of the License, or (at your option) any later version.
|
||||
+
|
||||
+ The GNU C Library is distributed in the hope that it will be useful,
|
||||
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
+ Lesser General Public License for more details.
|
||||
+
|
||||
+ You should have received a copy of the GNU Lesser General Public
|
||||
+ License along with the GNU C Library; if not, see
|
||||
+ <http://www.gnu.org/licenses/>. */
|
||||
+
|
||||
+#ifndef _LIBC_VDSO_H
|
||||
+#define _LIBC_VDSO_H
|
||||
+
|
||||
+#include <time.h>
|
||||
+#include <sys/time.h>
|
||||
+
|
||||
+#ifdef SHARED
|
||||
+
|
||||
+extern long int (*__vdso_clock_gettime) (clockid_t, struct timespec *);
|
||||
+
|
||||
+#endif
|
||||
+
|
||||
+#endif /* _LIBC_VDSO_H */
|
||||
diff --git a/sysdeps/unix/sysv/linux/x86/time.c b/sysdeps/unix/sysv/linux/x86/time.c
|
||||
new file mode 100644
|
||||
index 0000000..1ab9248
|
||||
--- /dev/null
|
||||
+++ b/sysdeps/unix/sysv/linux/x86/time.c
|
||||
@@ -0,0 +1,49 @@
|
||||
+/* time -- Get number of seconds since Epoch. Linux/x86 version.
|
||||
+ Copyright (C) 2015 Free Software Foundation, Inc.
|
||||
+ This file is part of the GNU C Library.
|
||||
+
|
||||
+ The GNU C Library is free software; you can redistribute it and/or
|
||||
+ modify it under the terms of the GNU Lesser General Public
|
||||
+ License as published by the Free Software Foundation; either
|
||||
+ version 2.1 of the License, or (at your option) any later version.
|
||||
+
|
||||
+ The GNU C Library is distributed in the hope that it will be useful,
|
||||
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
+ Lesser General Public License for more details.
|
||||
+
|
||||
+ You should have received a copy of the GNU Lesser General Public
|
||||
+ License along with the GNU C Library; if not, see
|
||||
+ <http://www.gnu.org/licenses/>. */
|
||||
+
|
||||
+#include <time.h>
|
||||
+
|
||||
+#ifdef SHARED
|
||||
+
|
||||
+#include <dl-vdso.h>
|
||||
+
|
||||
+void *time_ifunc (void) __asm__ ("time");
|
||||
+
|
||||
+void *
|
||||
+time_ifunc (void)
|
||||
+{
|
||||
+ PREPARE_VERSION_KNOWN (linux26, LINUX_2_6);
|
||||
+
|
||||
+ return _dl_vdso_vsym ("__vdso_time", &linux26) ?: TIME_FALLBACK;
|
||||
+}
|
||||
+asm (".type time, %gnu_indirect_function");
|
||||
+
|
||||
+libc_ifunc_hidden_def(time)
|
||||
+
|
||||
+#else
|
||||
+
|
||||
+# include <sysdep.h>
|
||||
+
|
||||
+time_t
|
||||
+time (time_t *t)
|
||||
+{
|
||||
+ INTERNAL_SYSCALL_DECL (err);
|
||||
+ return INTERNAL_SYSCALL (time, err, 1, t);
|
||||
+}
|
||||
+
|
||||
+#endif
|
||||
diff --git a/sysdeps/unix/sysv/linux/x86/timespec_get.c b/sysdeps/unix/sysv/linux/x86/timespec_get.c
|
||||
new file mode 100644
|
||||
index 0000000..b21efce
|
||||
--- /dev/null
|
||||
+++ b/sysdeps/unix/sysv/linux/x86/timespec_get.c
|
||||
@@ -0,0 +1,29 @@
|
||||
+/* timespec_get -- returns the calendar time based on a given time base.
|
||||
+ Linux/x86 version.
|
||||
+ Copyright (C) 2015 Free Software Foundation, Inc.
|
||||
+ This file is part of the GNU C Library.
|
||||
+
|
||||
+ The GNU C Library is free software; you can redistribute it and/or
|
||||
+ modify it under the terms of the GNU Lesser General Public
|
||||
+ License as published by the Free Software Foundation; either
|
||||
+ version 2.1 of the License, or (at your option) any later version.
|
||||
+
|
||||
+ The GNU C Library is distributed in the hope that it will be useful,
|
||||
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
+ Lesser General Public License for more details.
|
||||
+
|
||||
+ You should have received a copy of the GNU Lesser General Public
|
||||
+ License along with the GNU C Library; if not, see
|
||||
+ <http://www.gnu.org/licenses/>. */
|
||||
+
|
||||
+#include <libc-vdso.h>
|
||||
+
|
||||
+#ifdef SHARED
|
||||
+# define INTERNAL_GETTIME(id, tp) \
|
||||
+ ({ long int (*f) (clockid_t, struct timespec *) = __vdso_clock_gettime; \
|
||||
+ PTR_DEMANGLE (f); \
|
||||
+ (*f) (id, tp); })
|
||||
+#endif
|
||||
+
|
||||
+#include <sysdeps/unix/sysv/linux/timespec_get.c>
|
||||
diff --git a/sysdeps/unix/sysv/linux/x86_64/Makefile b/sysdeps/unix/sysv/linux/x86_64/Makefile
|
||||
index d6a9d36..9b82155 100644
|
||||
--- a/sysdeps/unix/sysv/linux/x86_64/Makefile
|
||||
+++ b/sysdeps/unix/sysv/linux/x86_64/Makefile
|
||||
@@ -13,7 +13,3 @@ endif
|
||||
ifeq ($(subdir),misc)
|
||||
gen-as-const-headers += sigaltstack-offsets.sym
|
||||
endif
|
||||
-
|
||||
-ifeq ($(subdir),elf)
|
||||
-sysdep_routines += dl-vdso
|
||||
-endif
|
||||
diff --git a/sysdeps/unix/sysv/linux/x86_64/bits/libc-vdso.h b/sysdeps/unix/sysv/linux/x86_64/bits/libc-vdso.h
|
||||
deleted file mode 100644
|
||||
index 03ff875..0000000
|
||||
--- a/sysdeps/unix/sysv/linux/x86_64/bits/libc-vdso.h
|
||||
+++ /dev/null
|
||||
@@ -1,31 +0,0 @@
|
||||
-/* Resolve function pointers to VDSO functions.
|
||||
- Copyright (C) 2005-2015 Free Software Foundation, Inc.
|
||||
- This file is part of the GNU C Library.
|
||||
-
|
||||
- The GNU C Library is free software; you can redistribute it and/or
|
||||
- modify it under the terms of the GNU Lesser General Public
|
||||
- License as published by the Free Software Foundation; either
|
||||
- version 2.1 of the License, or (at your option) any later version.
|
||||
-
|
||||
- The GNU C Library is distributed in the hope that it will be useful,
|
||||
- but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
- Lesser General Public License for more details.
|
||||
-
|
||||
- You should have received a copy of the GNU Lesser General Public
|
||||
- License along with the GNU C Library; if not, see
|
||||
- <http://www.gnu.org/licenses/>. */
|
||||
-
|
||||
-#ifndef _LIBC_VDSO_H
|
||||
-#define _LIBC_VDSO_H
|
||||
-
|
||||
-#include <time.h>
|
||||
-#include <sys/time.h>
|
||||
-
|
||||
-#ifdef SHARED
|
||||
-
|
||||
-extern long int (*__vdso_clock_gettime) (clockid_t, struct timespec *);
|
||||
-
|
||||
-#endif
|
||||
-
|
||||
-#endif /* _LIBC_VDSO_H */
|
||||
diff --git a/sysdeps/unix/sysv/linux/x86_64/clock_gettime.c b/sysdeps/unix/sysv/linux/x86_64/clock_gettime.c
|
||||
deleted file mode 100644
|
||||
index f712110..0000000
|
||||
--- a/sysdeps/unix/sysv/linux/x86_64/clock_gettime.c
|
||||
+++ /dev/null
|
||||
@@ -1,20 +0,0 @@
|
||||
-#include "bits/libc-vdso.h"
|
||||
-
|
||||
-#ifdef SHARED
|
||||
-# define SYSCALL_GETTIME(id, tp) \
|
||||
- ({ long int (*f) (clockid_t, struct timespec *) = __vdso_clock_gettime; \
|
||||
- long int v_ret; \
|
||||
- PTR_DEMANGLE (f); \
|
||||
- v_ret = f (id, tp); \
|
||||
- if (INTERNAL_SYSCALL_ERROR_P (v_ret, )) { \
|
||||
- __set_errno (INTERNAL_SYSCALL_ERRNO (v_ret, )); \
|
||||
- v_ret = -1; \
|
||||
- } \
|
||||
- v_ret; })
|
||||
-# define INTERNAL_GETTIME(id, tp) \
|
||||
- ({ long int (*f) (clockid_t, struct timespec *) = __vdso_clock_gettime; \
|
||||
- PTR_DEMANGLE (f); \
|
||||
- f (id, tp); })
|
||||
-#endif
|
||||
-
|
||||
-#include "../clock_gettime.c"
|
||||
diff --git a/sysdeps/unix/sysv/linux/x86_64/gettimeofday.c b/sysdeps/unix/sysv/linux/x86_64/gettimeofday.c
|
||||
index 866d9c1..daa14de 100644
|
||||
--- a/sysdeps/unix/sysv/linux/x86_64/gettimeofday.c
|
||||
+++ b/sysdeps/unix/sysv/linux/x86_64/gettimeofday.c
|
||||
@@ -18,42 +18,9 @@
|
||||
#include <sys/time.h>
|
||||
|
||||
#ifdef SHARED
|
||||
-
|
||||
-# include <dl-vdso.h>
|
||||
-
|
||||
+/* If the vDSO is not available we fall back on the old vsyscall. */
|
||||
# define VSYSCALL_ADDR_vgettimeofday 0xffffffffff600000ul
|
||||
-
|
||||
-void *gettimeofday_ifunc (void) __asm__ ("__gettimeofday");
|
||||
-
|
||||
-void *
|
||||
-gettimeofday_ifunc (void)
|
||||
-{
|
||||
- PREPARE_VERSION (linux26, "LINUX_2.6", 61765110);
|
||||
-
|
||||
- /* If the vDSO is not available we fall back on the old vsyscall. */
|
||||
- return (_dl_vdso_vsym ("__vdso_gettimeofday", &linux26)
|
||||
- ?: (void *) VSYSCALL_ADDR_vgettimeofday);
|
||||
-}
|
||||
-asm (".type __gettimeofday, %gnu_indirect_function");
|
||||
-
|
||||
-/* This is doing "libc_hidden_def (__gettimeofday)" but the compiler won't
|
||||
- let us do it in C because it doesn't know we're defining __gettimeofday
|
||||
- here in this file. */
|
||||
-asm (".globl __GI___gettimeofday\n"
|
||||
- "__GI___gettimeofday = __gettimeofday");
|
||||
-
|
||||
-#else
|
||||
-
|
||||
-# include <sysdep.h>
|
||||
-# include <errno.h>
|
||||
-
|
||||
-int
|
||||
-__gettimeofday (struct timeval *tv, struct timezone *tz)
|
||||
-{
|
||||
- return INLINE_SYSCALL (gettimeofday, 2, tv, tz);
|
||||
-}
|
||||
-libc_hidden_def (__gettimeofday)
|
||||
-
|
||||
+# define GETTIMEOFAY_FALLBACK (void*)VSYSCALL_ADDR_vgettimeofday
|
||||
#endif
|
||||
-weak_alias (__gettimeofday, gettimeofday)
|
||||
-libc_hidden_weak (gettimeofday)
|
||||
+
|
||||
+#include <sysdeps/unix/sysv/linux/x86/gettimeofday.c>
|
||||
diff --git a/sysdeps/unix/sysv/linux/x86_64/init-first.c b/sysdeps/unix/sysv/linux/x86_64/init-first.c
|
||||
index e3bc712..36f9afc 100644
|
||||
--- a/sysdeps/unix/sysv/linux/x86_64/init-first.c
|
||||
+++ b/sysdeps/unix/sysv/linux/x86_64/init-first.c
|
||||
@@ -20,20 +20,20 @@
|
||||
# include <time.h>
|
||||
# include <sysdep.h>
|
||||
# include <dl-vdso.h>
|
||||
-# include <bits/libc-vdso.h>
|
||||
+# include <libc-vdso.h>
|
||||
|
||||
long int (*__vdso_clock_gettime) (clockid_t, struct timespec *)
|
||||
__attribute__ ((nocommon));
|
||||
-strong_alias (__vdso_clock_gettime, __GI___vdso_clock_gettime attribute_hidden)
|
||||
+libc_hidden_proto (__vdso_clock_gettime)
|
||||
+libc_hidden_data_def (__vdso_clock_gettime)
|
||||
|
||||
long int (*__vdso_getcpu) (unsigned *, unsigned *, void *) attribute_hidden;
|
||||
|
||||
-
|
||||
extern long int __syscall_clock_gettime (clockid_t, struct timespec *);
|
||||
|
||||
|
||||
static inline void
|
||||
-_libc_vdso_platform_setup (void)
|
||||
+__vdso_platform_setup (void)
|
||||
{
|
||||
PREPARE_VERSION (linux26, "LINUX_2.6", 61765110);
|
||||
|
||||
@@ -41,7 +41,7 @@ _libc_vdso_platform_setup (void)
|
||||
if (p == NULL)
|
||||
p = __syscall_clock_gettime;
|
||||
PTR_MANGLE (p);
|
||||
- __GI___vdso_clock_gettime = p;
|
||||
+ __vdso_clock_gettime = p;
|
||||
|
||||
p = _dl_vdso_vsym ("__vdso_getcpu", &linux26);
|
||||
/* If the vDSO is not available we fall back on the old vsyscall. */
|
||||
@@ -52,7 +52,7 @@ _libc_vdso_platform_setup (void)
|
||||
__vdso_getcpu = p;
|
||||
}
|
||||
|
||||
-# define VDSO_SETUP _libc_vdso_platform_setup
|
||||
+# define VDSO_SETUP __vdso_platform_setup
|
||||
#endif
|
||||
|
||||
#include <csu/init-first.c>
|
||||
diff --git a/sysdeps/unix/sysv/linux/x86_64/time.c b/sysdeps/unix/sysv/linux/x86_64/time.c
|
||||
index c00b5be..6ceb819 100644
|
||||
--- a/sysdeps/unix/sysv/linux/x86_64/time.c
|
||||
+++ b/sysdeps/unix/sysv/linux/x86_64/time.c
|
||||
@@ -16,45 +16,9 @@
|
||||
<http://www.gnu.org/licenses/>. */
|
||||
|
||||
#ifdef SHARED
|
||||
-/* Redefine time so that the compiler won't complain about the type
|
||||
- mismatch with the IFUNC selector in strong_alias, below. */
|
||||
-#undef time
|
||||
-#define time __redirect_time
|
||||
-#include <time.h>
|
||||
-
|
||||
-#include <dl-vdso.h>
|
||||
-
|
||||
+/* If the vDSO is not available we fall back on the old vsyscall. */
|
||||
#define VSYSCALL_ADDR_vtime 0xffffffffff600400
|
||||
-
|
||||
-/* Avoid DWARF definition DIE on ifunc symbol so that GDB can handle
|
||||
- ifunc symbol properly. */
|
||||
-extern __typeof (__redirect_time) __libc_time;
|
||||
-void *time_ifunc (void) __asm__ ("__libc_time");
|
||||
-
|
||||
-void *
|
||||
-time_ifunc (void)
|
||||
-{
|
||||
- PREPARE_VERSION (linux26, "LINUX_2.6", 61765110);
|
||||
-
|
||||
- /* If the vDSO is not available we fall back on the old vsyscall. */
|
||||
- return _dl_vdso_vsym ("__vdso_time", &linux26) ?: (void *) VSYSCALL_ADDR_vtime;
|
||||
-}
|
||||
-__asm (".type __libc_time, %gnu_indirect_function");
|
||||
-
|
||||
-#undef time
|
||||
-strong_alias (__libc_time, time)
|
||||
-libc_hidden_ver (__libc_time, time)
|
||||
-
|
||||
-#else
|
||||
-
|
||||
-# include <time.h>
|
||||
-# include <sysdep.h>
|
||||
-
|
||||
-time_t
|
||||
-time (time_t *t)
|
||||
-{
|
||||
- INTERNAL_SYSCALL_DECL (err);
|
||||
- return INTERNAL_SYSCALL (time, err, 1, t);
|
||||
-}
|
||||
-
|
||||
+#define TIME_FALLBACK (void*)VSYSCALL_ADDR_vtime
|
||||
#endif
|
||||
+
|
||||
+#include <sysdeps/unix/sysv/linux/x86/time.c>
|
||||
diff --git a/sysdeps/unix/sysv/linux/x86_64/timespec_get.c b/sysdeps/unix/sysv/linux/x86_64/timespec_get.c
|
||||
deleted file mode 100644
|
||||
index cb26068..0000000
|
||||
--- a/sysdeps/unix/sysv/linux/x86_64/timespec_get.c
|
||||
+++ /dev/null
|
||||
@@ -1,10 +0,0 @@
|
||||
-#include "bits/libc-vdso.h"
|
||||
-
|
||||
-#ifdef SHARED
|
||||
-# define INTERNAL_GETTIME(id, tp) \
|
||||
- ({ long int (*f) (clockid_t, struct timespec *) = __vdso_clock_gettime; \
|
||||
- PTR_DEMANGLE (f); \
|
||||
- f (id, tp); })
|
||||
-#endif
|
||||
-
|
||||
-#include "../timespec_get.c"
|
||||
diff --git a/sysdeps/unix/sysv/linux/x86_64/x32/init-first.c b/sysdeps/unix/sysv/linux/x86_64/x32/init-first.c
|
||||
index 88369e5..93e0508 100644
|
||||
--- a/sysdeps/unix/sysv/linux/x86_64/x32/init-first.c
|
||||
+++ b/sysdeps/unix/sysv/linux/x86_64/x32/init-first.c
|
||||
@@ -18,7 +18,7 @@
|
||||
|
||||
#ifdef SHARED
|
||||
# include <dl-vdso.h>
|
||||
-# include <bits/libc-vdso.h>
|
||||
+# include <libc-vdso.h>
|
||||
|
||||
long int (*__vdso_clock_gettime) (clockid_t, struct timespec *)
|
||||
__attribute__ ((nocommon));
|
102
glibc-rtkaio-clock.patch
Normal file
102
glibc-rtkaio-clock.patch
Normal file
@ -0,0 +1,102 @@
|
||||
#
|
||||
# Based on the following upstream commit:
|
||||
#
|
||||
# commit 6e6249d0b461b952d0f544792372663feb6d792a
|
||||
# Author: Roland McGrath <roland@hack.frob.com>
|
||||
# Date: Wed Oct 24 14:50:46 2012 -0700
|
||||
#
|
||||
# BZ#14743: Move clock_* symbols from librt to libc.
|
||||
#
|
||||
# We remove the clock* functions from librtkaio.so.1 and
|
||||
# use those provided in libc.so.6, matching librt.so.
|
||||
#
|
||||
diff -urN glibc-2.21-59-gd35273f.mod/rtkaio/clock-compat.c glibc-2.21-59-gd35273f/rtkaio/clock-compat.c
|
||||
--- glibc-2.21-59-gd35273f.mod/rtkaio/clock-compat.c 1969-12-31 19:00:00.000000000 -0500
|
||||
+++ glibc-2.21-59-gd35273f/rtkaio/clock-compat.c 2015-02-11 22:52:29.912765683 -0500
|
||||
@@ -0,0 +1 @@
|
||||
+#include <rt/clock-compat.c>
|
||||
diff -urN glibc-2.21-59-gd35273f.mod/rtkaio/kaio_clock_getcpuclockid.c glibc-2.21-59-gd35273f/rtkaio/kaio_clock_getcpuclockid.c
|
||||
--- glibc-2.21-59-gd35273f.mod/rtkaio/kaio_clock_getcpuclockid.c 2015-02-11 13:00:55.105400863 -0500
|
||||
+++ glibc-2.21-59-gd35273f/rtkaio/kaio_clock_getcpuclockid.c 1969-12-31 19:00:00.000000000 -0500
|
||||
@@ -1 +0,0 @@
|
||||
-#include <clock_getcpuclockid.c>
|
||||
diff -urN glibc-2.21-59-gd35273f.mod/rtkaio/kaio_clock_getres.c glibc-2.21-59-gd35273f/rtkaio/kaio_clock_getres.c
|
||||
--- glibc-2.21-59-gd35273f.mod/rtkaio/kaio_clock_getres.c 2015-02-11 13:00:55.105400863 -0500
|
||||
+++ glibc-2.21-59-gd35273f/rtkaio/kaio_clock_getres.c 1969-12-31 19:00:00.000000000 -0500
|
||||
@@ -1 +0,0 @@
|
||||
-#include <clock_getres.c>
|
||||
diff -urN glibc-2.21-59-gd35273f.mod/rtkaio/kaio_clock_gettime.c glibc-2.21-59-gd35273f/rtkaio/kaio_clock_gettime.c
|
||||
--- glibc-2.21-59-gd35273f.mod/rtkaio/kaio_clock_gettime.c 2015-02-11 13:00:55.109400738 -0500
|
||||
+++ glibc-2.21-59-gd35273f/rtkaio/kaio_clock_gettime.c 1969-12-31 19:00:00.000000000 -0500
|
||||
@@ -1 +0,0 @@
|
||||
-#include <clock_gettime.c>
|
||||
diff -urN glibc-2.21-59-gd35273f.mod/rtkaio/kaio_clock_nanosleep.c glibc-2.21-59-gd35273f/rtkaio/kaio_clock_nanosleep.c
|
||||
--- glibc-2.21-59-gd35273f.mod/rtkaio/kaio_clock_nanosleep.c 2015-02-11 13:00:55.115400552 -0500
|
||||
+++ glibc-2.21-59-gd35273f/rtkaio/kaio_clock_nanosleep.c 1969-12-31 19:00:00.000000000 -0500
|
||||
@@ -1 +0,0 @@
|
||||
-#include <clock_nanosleep.c>
|
||||
diff -urN glibc-2.21-59-gd35273f.mod/rtkaio/kaio_clock_settime.c glibc-2.21-59-gd35273f/rtkaio/kaio_clock_settime.c
|
||||
--- glibc-2.21-59-gd35273f.mod/rtkaio/kaio_clock_settime.c 2015-02-11 13:00:55.110400708 -0500
|
||||
+++ glibc-2.21-59-gd35273f/rtkaio/kaio_clock_settime.c 1969-12-31 19:00:00.000000000 -0500
|
||||
@@ -1 +0,0 @@
|
||||
-#include <clock_settime.c>
|
||||
diff -urN glibc-2.21-59-gd35273f.mod/rtkaio/kaio_get_clockfreq.c glibc-2.21-59-gd35273f/rtkaio/kaio_get_clockfreq.c
|
||||
--- glibc-2.21-59-gd35273f.mod/rtkaio/kaio_get_clockfreq.c 2015-02-11 13:00:55.118400459 -0500
|
||||
+++ glibc-2.21-59-gd35273f/rtkaio/kaio_get_clockfreq.c 1969-12-31 19:00:00.000000000 -0500
|
||||
@@ -1 +0,0 @@
|
||||
-#include <get_clockfreq.c>
|
||||
diff -urN glibc-2.21-59-gd35273f.mod/rtkaio/Makefile glibc-2.21-59-gd35273f/rtkaio/Makefile
|
||||
--- glibc-2.21-59-gd35273f.mod/rtkaio/Makefile 2015-02-11 13:00:55.107400801 -0500
|
||||
+++ glibc-2.21-59-gd35273f/rtkaio/Makefile 2015-02-11 22:46:46.930374298 -0500
|
||||
@@ -25,9 +25,6 @@
|
||||
aio_read64 aio_return aio_suspend aio_write \
|
||||
aio_write64 lio_listio lio_listio64 aio_sigqueue \
|
||||
aio_notify
|
||||
-clock-routines := get_clockfreq clock_getcpuclockid \
|
||||
- clock_getres clock_gettime clock_settime \
|
||||
- clock_nanosleep
|
||||
timer-routines := timer_create timer_delete timer_getoverr \
|
||||
timer_gettime timer_settime
|
||||
shm-routines := shm_open shm_unlink
|
||||
@@ -36,8 +33,9 @@
|
||||
mq_timedreceive
|
||||
|
||||
librtkaio-routines = $(patsubst %,k%,$(aio-routines)) \
|
||||
- $(patsubst %,kaio_%,$(clock-routines) $(timer-routines) \
|
||||
- $(shm-routines) $(mq-routines))
|
||||
+ $(patsubst %,kaio_%,$(timer-routines) \
|
||||
+ $(shm-routines) $(mq-routines)) \
|
||||
+ clock-compat
|
||||
|
||||
tests := tst-shm tst-clock tst-clock_nanosleep tst-timer tst-timer2 \
|
||||
tst-aio tst-aio64 tst-aio2 tst-aio3 tst-aio4 tst-aio5 tst-aio6 \
|
||||
@@ -64,7 +62,6 @@
|
||||
include $(..)Rules
|
||||
|
||||
CFLAGS-kaio_suspend.c = -fexceptions
|
||||
-CFLAGS-kaio_clock_nanosleep.c = -fexceptions -fasynchronous-unwind-tables
|
||||
CFLAGS-kaio_librt-cancellation.c = -fasynchronous-unwind-tables
|
||||
|
||||
LDFLAGS-rtkaio.so = -Wl,-soname=lib$(libprefix)rt.so$(librt.so-version) \
|
||||
@@ -88,9 +85,6 @@
|
||||
else
|
||||
$(addprefix $(objpfx),$(tests)): $(objpfx)librtkaio.a $(static-thread-library)
|
||||
endif
|
||||
-ifeq (yes,$(build-bounded))
|
||||
-$(tests:%=$(objpfx)%-bp): $(objpfx)librtkaio_b.a $(bounded-thread-library)
|
||||
-endif
|
||||
|
||||
tst-mqueue7-ARGS = -- $(built-program-file)
|
||||
|
||||
diff -urN glibc-2.21-59-gd35273f.mod/rtkaio/Versions glibc-2.21-59-gd35273f/rtkaio/Versions
|
||||
--- glibc-2.21-59-gd35273f.mod/rtkaio/Versions 2015-02-11 13:00:55.118400459 -0500
|
||||
+++ glibc-2.21-59-gd35273f/rtkaio/Versions 2015-02-11 22:36:11.974051389 -0500
|
||||
@@ -6,7 +6,7 @@
|
||||
aio_suspend64; aio_write; aio_write64; lio_listio; lio_listio64;
|
||||
}
|
||||
GLIBC_2.2 {
|
||||
- # c*
|
||||
+ # These have moved to libc and are still here only for compatibility.
|
||||
clock_getres; clock_gettime; clock_settime; clock_getcpuclockid;
|
||||
clock_nanosleep;
|
||||
|
14
glibc.spec
14
glibc.spec
@ -1,6 +1,6 @@
|
||||
%define glibcsrcdir glibc-2.20-549-g86bba16
|
||||
%define glibcversion 2.20.90
|
||||
%define glibcrelease 20%{?dist}
|
||||
%define glibcversion 2.21.90
|
||||
%define glibcrelease 1%{?dist}
|
||||
# Pre-release tarballs are pulled in from git using a command that is
|
||||
# effectively:
|
||||
#
|
||||
@ -206,8 +206,8 @@ Patch0052: %{name}-disable-rwlock-elision.patch
|
||||
# symlink to it.
|
||||
Patch0053: %{name}-cs-path.patch
|
||||
|
||||
# Temporary revert till I fix rtkaio build on i686.
|
||||
Patch0054: %{name}-revert-x86-vdso.patch
|
||||
# Remove the clock_* functions and use the ones in libc like librt does.
|
||||
Patch0054: %{name}-rtkaio-clock.patch
|
||||
|
||||
##############################################################################
|
||||
#
|
||||
@ -578,7 +578,7 @@ package or when debugging this package.
|
||||
%patch0050 -p1
|
||||
%patch0052 -p1
|
||||
%patch0053 -p1
|
||||
%patch0054 -p1 -R
|
||||
%patch0054 -p1
|
||||
|
||||
##############################################################################
|
||||
# %%prep - Additional prep required...
|
||||
@ -1751,6 +1751,10 @@ rm -f *.filelist*
|
||||
%endif
|
||||
|
||||
%changelog
|
||||
* Wed Feb 11 2015 Carlos O'Donell <carlos@systemhalted.org> - 2.21.90-1
|
||||
- Add back x86 vDSO support.
|
||||
- Fix rtkaio build to reference clock_* functions from libc.
|
||||
|
||||
* Wed Jan 21 2015 Siddhesh Poyarekar <siddhesh@redhat.com> - 2.20.90-20
|
||||
- Sync with upstream master.
|
||||
- Disable werror on s390x.
|
||||
|
Loading…
Reference in New Issue
Block a user