From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (qmail 61281 invoked by alias); 7 Sep 2017 22:42:51 -0000 Mailing-List: contact libc-alpha-help@sourceware.org; run by ezmlm Precedence: bulk List-Id: List-Subscribe: List-Archive: List-Post: List-Help: , Sender: libc-alpha-owner@sourceware.org Received: (qmail 61174 invoked by uid 89); 7 Sep 2017 22:42:51 -0000 Authentication-Results: sourceware.org; auth=none X-Virus-Found: No X-Spam-SWARE-Status: No, score=-26.6 required=5.0 tests=BAYES_00,GIT_PATCH_0,GIT_PATCH_1,GIT_PATCH_2,GIT_PATCH_3,KAM_LAZY_DOMAIN_SECURITY,RCVD_IN_DNSWL_LOW autolearn=ham version=3.3.2 spammy=265 X-HELO: smtp6-g21.free.fr From: "Albert ARIBAUD (3ADEV)" To: libc-alpha@sourceware.org Cc: "Albert ARIBAUD (3ADEV)" Subject: [RFC PATCH 05/52] Y2038: add function __timegm64 Date: Thu, 07 Sep 2017 22:42:00 -0000 Message-Id: <20170907224219.12483-6-albert.aribaud@3adev.fr> In-Reply-To: <20170907224219.12483-5-albert.aribaud@3adev.fr> References: <20170907224219.12483-1-albert.aribaud@3adev.fr> <20170907224219.12483-2-albert.aribaud@3adev.fr> <20170907224219.12483-3-albert.aribaud@3adev.fr> <20170907224219.12483-4-albert.aribaud@3adev.fr> <20170907224219.12483-5-albert.aribaud@3adev.fr> X-SW-Source: 2017-09/txt/msg00321.txt.bz2 Implementation is based on the same __mktime64_internal function which was introduced in the '__mktime64' implementation change. Again, the implementation does not require a Y2038-proof kernel. Signed-off-by: Albert ARIBAUD (3ADEV) --- sysdeps/unix/sysv/linux/arm/Versions | 1 + time/timegm.c | 11 +++++++++++ 2 files changed, 12 insertions(+) diff --git a/sysdeps/unix/sysv/linux/arm/Versions b/sysdeps/unix/sysv/linux/arm/Versions index 546d7c60ee..f7feda3650 100644 --- a/sysdeps/unix/sysv/linux/arm/Versions +++ b/sysdeps/unix/sysv/linux/arm/Versions @@ -26,5 +26,6 @@ libc { __gmtime64; __gmtime64_r; __localtime64; __localtime64_r; __mktime64; __timelocal64_r; + __timegm64; } } diff --git a/time/timegm.c b/time/timegm.c index b0f5d16d16..0c8879285a 100644 --- a/time/timegm.c +++ b/time/timegm.c @@ -36,6 +36,9 @@ time_t __mktime_internal (struct tm *, struct tm * (*) (time_t const *, struct tm *), time_t *); +__time64_t __mktime64_internal (struct tm *, + struct tm * (*) (__time64_t const *, struct tm *), + __time64_t *); #endif time_t @@ -45,3 +48,11 @@ timegm (struct tm *tmp) tmp->tm_isdst = 0; return __mktime_internal (tmp, __gmtime_r, &gmtime_offset); } + +__time64_t +__timegm64 (struct tm *tmp) +{ + static __time64_t gmtime64_offset; + tmp->tm_isdst = 0; + return __mktime64_internal (tmp, __gmtime64_r, &gmtime64_offset); +} -- 2.11.0