]> git.ipfire.org Git - thirdparty/glibc.git/commitdiff
Add missing VDSO_{NAME,HASH}_* macros and use them for PREPARE_VERSION_KNOWN
authorTobias Klauser <tklauser@distanz.ch>
Fri, 21 Jun 2019 13:36:52 +0000 (10:36 -0300)
committerAdhemerval Zanella <adhemerval.zanella@linaro.org>
Fri, 21 Jun 2019 13:43:22 +0000 (10:43 -0300)
Define all currently used Linux versions used for
PREPARE_VERSION{,_KNOWN} in sysdeps/unix/sysv/linux/dl-vdso.h and use
them instead of duplicating the versions and precomputed hashes across
architecture specific files.

* sysdeps/unix/sysv/linux/aarch64/gettimeofday.c (INIT_ARCH): Use
PREPARE_VERSION_KNOWN.
* sysdeps/unix/sysv/linux/aarch64/init-first.c: Likewise.
* sysdeps/unix/sysv/linux/dl-vdso.h (VDSO_NAME_LINUX_2_6_39): New
define.
(VDSO_HASH_LINUX_2_6_39): Likewise.
(VDSO_NAME_LINUX_4_9): Likewise.
(VDSO_HASH_LINUX_4_9): Likewise.
* sysdeps/unix/sysv/linux/powerpc/gettimeofday.c (INIT_ARCH): Likewise.
* sysdeps/unix/sysv/linux/powerpc/init-first.c
(_libc_vdso_platform_setup): Likewise.
* sysdeps/unix/sysv/linux/powerpc/time.c (INIT_ARCH): Likewise.
* sysdeps/unix/sysv/linux/s390/init-first.c (_libc_vdso_platform_setup):
Likewise.
* sysdeps/unix/sysv/linux/x86_64/init-first.c (__vdso_platform_setup):
Likewise.

Reviewed-by: Adhemerval Zanella <adhemerval.zanella@linaro.org>
ChangeLog
sysdeps/unix/sysv/linux/aarch64/gettimeofday.c
sysdeps/unix/sysv/linux/aarch64/init-first.c
sysdeps/unix/sysv/linux/dl-vdso.h
sysdeps/unix/sysv/linux/powerpc/gettimeofday.c
sysdeps/unix/sysv/linux/powerpc/init-first.c
sysdeps/unix/sysv/linux/powerpc/time.c
sysdeps/unix/sysv/linux/s390/init-first.c
sysdeps/unix/sysv/linux/x86_64/init-first.c

index d09b70b28783d6cf78b6f7b94f74dc3315a3cd2f..0833ead403b7a2ba4741e48da41b852b3ca2f381 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,22 @@
+2019-06-21  Tobias Klauser  <tklauser@distanz.ch>
+
+       * sysdeps/unix/sysv/linux/aarch64/gettimeofday.c (INIT_ARCH): Use
+       PREPARE_VERSION_KNOWN.
+       * sysdeps/unix/sysv/linux/aarch64/init-first.c: Likewise.
+       * sysdeps/unix/sysv/linux/dl-vdso.h (VDSO_NAME_LINUX_2_6_39): New
+       define.
+       (VDSO_HASH_LINUX_2_6_39): Likewise.
+       (VDSO_NAME_LINUX_4_9): Likewise.
+       (VDSO_HASH_LINUX_4_9): Likewise.
+       * sysdeps/unix/sysv/linux/powerpc/gettimeofday.c (INIT_ARCH): Likewise.
+       * sysdeps/unix/sysv/linux/powerpc/init-first.c
+       (_libc_vdso_platform_setup): Likewise.
+       * sysdeps/unix/sysv/linux/powerpc/time.c (INIT_ARCH): Likewise.
+       * sysdeps/unix/sysv/linux/s390/init-first.c (_libc_vdso_platform_setup):
+       Likewise.
+       * sysdeps/unix/sysv/linux/x86_64/init-first.c (__vdso_platform_setup):
+       Likewise.
+
 2019-06-20  Mike Crowe  <mac@mcrowe.com>
 
        * nptl/eintr.c: Use libsupport.
index 6c008ed9357ff172c45ae0276da2a0c3f104cd82..9180b50bf7c36d4d10c781f06b92753f675127de 100644 (file)
@@ -38,13 +38,13 @@ __gettimeofday_vsyscall (struct timeval *tv, struct timezone *tz)
   return INLINE_VSYSCALL (gettimeofday, 2, tv, tz);
 }
 
-/* PREPARE_VERSION will need an __LP64__ ifdef when ILP32 support
+/* PREPARE_VERSION_KNOWN will need an __LP64__ ifdef when ILP32 support
    goes in.  See _libc_vdso_platform_setup in
    sysdeps/unix/sysv/linux/aarch64/init-first.c.  */
 
 # undef INIT_ARCH
 # define INIT_ARCH() \
-          PREPARE_VERSION (linux_version, "LINUX_2.6.39", 123718537); \
+          PREPARE_VERSION_KNOWN (linux_version, LINUX_2_6_39); \
           void *vdso_gettimeofday = \
             _dl_vdso_vsym ("__kernel_gettimeofday", &linux_version);
 
index ce7319f3c95bb85b19997b64296e65b8535943e8..80f7ed91ef0af2f7124a3b3e454ec2180119a471 100644 (file)
@@ -27,9 +27,9 @@ static inline void
 _libc_vdso_platform_setup (void)
 {
 #ifdef __LP64__
-  PREPARE_VERSION (linux_version, "LINUX_2.6.39", 123718537);
+  PREPARE_VERSION_KNOWN (linux_version, LINUX_2_6_39);
 #else
-  PREPARE_VERSION (linux_version, "LINUX_4.9", 61765625);
+  PREPARE_VERSION_KNOWN (linux_version, LINUX_4_9);
 #endif
 
   void *p = _dl_vdso_vsym ("__kernel_gettimeofday", &linux_version);
index 50ee29067d0be92b8f82554a015964aceddf500c..9e61ca7423630bfd146b126c8d035bf50d9ee612 100644 (file)
 #define VDSO_HASH_LINUX_2_6_15 123718565
 #define VDSO_NAME_LINUX_2_6_29 "LINUX_2.6.29"
 #define VDSO_HASH_LINUX_2_6_29 123718585
+#define VDSO_NAME_LINUX_2_6_39 "LINUX_2.6.39"
+#define VDSO_HASH_LINUX_2_6_39 123718537
+#define VDSO_NAME_LINUX_4_9    "LINUX_4.9"
+#define VDSO_HASH_LINUX_4_9    61765625
 #define VDSO_NAME_LINUX_4_15   "LINUX_4.15"
 #define VDSO_HASH_LINUX_4_15   182943605
 
index c8d7790d8adc43f0ceddb00f885fba38305cf973..463b678ad935aadbb81026c1ba95bcbad7ac7350 100644 (file)
@@ -57,8 +57,8 @@ __gettimeofday_syscall (struct timeval *tv, struct timezone *tz)
   return INLINE_SYSCALL (gettimeofday, 2, tv, tz);
 }
 
-# define INIT_ARCH()                                                   \
-  PREPARE_VERSION (linux2615, "LINUX_2.6.15", 123718565);              \
+# define INIT_ARCH()                                           \
+  PREPARE_VERSION_KNOWN (linux2615, LINUX_2_6_15);             \
   void *vdso_gettimeofday = _dl_vdso_vsym ("__kernel_gettimeofday", &linux2615);
 
 /* If the vDSO is not available we fall back syscall.  */
index 237b5abbf9b0ad6308b1f5c4238683eaad0eb262..831f910788b3c924146d32c3ce09f5cb0adda4f6 100644 (file)
@@ -37,7 +37,7 @@ void *VDSO_SYMBOL(sigtramp_rt32);
 static inline void
 _libc_vdso_platform_setup (void)
 {
-  PREPARE_VERSION (linux2615, "LINUX_2.6.15", 123718565);
+  PREPARE_VERSION_KNOWN (linux2615, LINUX_2_6_15);
 
   void *p = _dl_vdso_vsym ("__kernel_gettimeofday", &linux2615);
   PTR_MANGLE (p);
index c2f171b6228cbb39544ab7c5ea3a8c193ac935ed..cb3e8b9a73a59adbf00f03c95c5d3c1457217645 100644 (file)
@@ -66,8 +66,8 @@ time_syscall (time_t *t)
   return result;
 }
 
-# define INIT_ARCH()                                                   \
-  PREPARE_VERSION (linux2615, "LINUX_2.6.15", 123718565);              \
+# define INIT_ARCH()                                           \
+  PREPARE_VERSION_KNOWN (linux2615, LINUX_2_6_15);             \
   void *vdso_time = _dl_vdso_vsym ("__kernel_time", &linux2615);
 
 /* If the vDSO is not available we fall back to the syscall.  */
index 71dd43f738bf93e4256bab0ad339ce4236e200a9..1f46e8052a37421c84afca0d6a81dc05ac85aa40 100644 (file)
@@ -35,7 +35,7 @@ long int (*VDSO_SYMBOL(getcpu)) (unsigned *, unsigned *, void *)
 static inline void
 _libc_vdso_platform_setup (void)
 {
-  PREPARE_VERSION (linux2629, "LINUX_2.6.29", 123718585);
+  PREPARE_VERSION_KNOWN (linux2629, LINUX_2_6_29);
 
   void *p = _dl_vdso_vsym ("__kernel_gettimeofday", &linux2629);
   PTR_MANGLE (p);
index 6a347becbe0da3344c369c8584106af547b3c72d..85333e5ff3097b399d6c90cc27b2be0f4d9cfbaf 100644 (file)
@@ -32,7 +32,7 @@ extern __typeof (clock_gettime) __syscall_clock_gettime attribute_hidden;
 static inline void
 __vdso_platform_setup (void)
 {
-  PREPARE_VERSION (linux26, "LINUX_2.6", 61765110);
+  PREPARE_VERSION_KNOWN (linux26, LINUX_2_6);
 
   void *p = _dl_vdso_vsym ("__vdso_clock_gettime", &linux26);
   if (p == NULL)