]> git.ipfire.org Git - thirdparty/glibc.git/commitdiff
Y2038: add function __localtime64_r
authorAlbert ARIBAUD (3ADEV) <albert.aribaud@3adev.fr>
Tue, 18 Dec 2018 22:11:08 +0000 (23:11 +0100)
committerAlbert ARIBAUD (3ADEV) <albert.aribaud@3adev.fr>
Tue, 18 Dec 2018 22:11:08 +0000 (23:11 +0100)
Tested with 'make check' on x86_64-linux-gnu and i686-linux.gnu.

* include/time.h
(__localtime64_r): Add.
* time/localtime.c
(__localtime64_r): Add.
[__TIMESIZE != 64] (__localtime_r): Turn into a wrapper.

ChangeLog
include/time.h
time/localtime.c

index 1e555377d279aa33183734ec086fe67ef6155ba2..4724c84e0832141e69d60631b3b422dbcd0ae2c3 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,11 @@
+2018-12-18  Albert ARIBAUD <albert.aribaud@3adev.fr>
+
+       * include/time.h
+       (__localtime64_r): Add.
+       * time/localtime.c
+       (__localtime64_r): Add.
+       [__TIMESIZE != 64] (__localtime_r): Turn into a wrapper.
+
 2018-12-18  Adhemerval Zanella  <adhemerval.zanella@linaro.org>
 
        * sysdeps/unix/sysv/linux/s390/kernel_sigaction.h: Use Linux generic
index 3bc303a36e34b143a49adcde5eec4dccb78592b6..876b8a2b5fab65b4a3c5e1fa8013878b91a49a11 100644 (file)
@@ -67,6 +67,14 @@ libc_hidden_proto (__localtime64)
 extern struct tm *__localtime_r (const time_t *__timer,
                                 struct tm *__tp) attribute_hidden;
 
+#if __TIMESIZE == 64
+# define __localtime64_r __localtime_r
+#else
+extern struct tm *__localtime64_r (const __time64_t *__timer,
+                                  struct tm *__tp);
+libc_hidden_proto (__localtime64_r)
+#endif
+
 extern struct tm *__gmtime_r (const time_t *__restrict __timer,
                              struct tm *__restrict __tp);
 libc_hidden_proto (__gmtime_r)
index 96879d4ec05588b20b09691dea455d5b1fbf5b86..9367c7082b1546d99907c1d9a1ec5da4f36591d7 100644 (file)
@@ -25,10 +25,25 @@ struct tm _tmbuf;
 /* Return the `struct tm' representation of *T in local time,
    using *TP to store the result.  */
 struct tm *
-__localtime_r (const time_t *t, struct tm *tp)
+__localtime64_r (const __time64_t *t, struct tm *tp)
 {
   return __tz_convert (*t, 1, tp);
 }
+
+/* Provide a 32-bit variant if needed.  */
+
+#if __TIMESIZE != 64
+
+struct tm *
+__localtime_r (const time_t *t, struct tm *tp)
+{
+  __time64_t t64 = *t;
+  return __localtime64_r (&t64, tp);
+}
+libc_hidden_def (__localtime64_r)
+
+#endif
+
 weak_alias (__localtime_r, localtime_r)