aboutsummaryrefslogtreecommitdiff
path: root/sysdeps/unix
diff options
context:
space:
mode:
authorLukasz Majewski <lukma@denx.de>2020-04-21 19:12:17 +0200
committerLukasz Majewski <lukma@denx.de>2020-05-05 19:36:25 +0200
commit898f3793164c0e811b28a37827f4bedce334066f (patch)
tree2a95e6287af7c80db168da3e7f22f73da1e5e98e /sysdeps/unix
parentdbf8178fdc1cc1c884efd2f5b55703da5adfb051 (diff)
downloadglibc-898f3793164c0e811b28a37827f4bedce334066f.tar
glibc-898f3793164c0e811b28a37827f4bedce334066f.tar.gz
glibc-898f3793164c0e811b28a37827f4bedce334066f.tar.bz2
glibc-898f3793164c0e811b28a37827f4bedce334066f.zip
y2038: Provide conversion helpers for struct __timex64
Those functions allow easy conversion between Y2038 safe, glibc internal struct __timex64 and struct timex. Those functions are put in Linux specific sys/timex.h file, as putting them into glibc's local include/time.h would cause build break on HURD as it doesn't support struct timex related syscalls. Build tests: ./src/scripts/build-many-glibcs.py glibcs Reviewed-by: Alistair Francis <alistair.francis@wdc.com> Reviewed-by: Adhemerval Zanella <adhemerval.zanella@linaro.org>
Diffstat (limited to 'sysdeps/unix')
-rw-r--r--sysdeps/unix/sysv/linux/include/sys/timex.h61
1 files changed, 61 insertions, 0 deletions
diff --git a/sysdeps/unix/sysv/linux/include/sys/timex.h b/sysdeps/unix/sysv/linux/include/sys/timex.h
index c555509c82..3efe7cd306 100644
--- a/sysdeps/unix/sysv/linux/include/sys/timex.h
+++ b/sysdeps/unix/sysv/linux/include/sys/timex.h
@@ -25,6 +25,7 @@
libc_hidden_proto (__adjtimex)
+# include <time.h>
# include <struct___timeval64.h>
/* Local definition of 64 bit time supporting timex struct */
# if __TIMESIZE == 64
@@ -71,5 +72,65 @@ struct __timex64
int :32;
};
# endif
+
+/* Convert a known valid struct timex into a struct __timex64. */
+static inline struct __timex64
+valid_timex_to_timex64 (const struct timex tx)
+{
+ struct __timex64 tx64;
+
+ tx64.modes = tx.modes;
+ tx64.offset = tx.offset;
+ tx64.freq = tx.freq;
+ tx64.maxerror = tx.maxerror;
+ tx64.esterror = tx.esterror;
+ tx64.status = tx.status;
+ tx64.constant = tx.constant;
+ tx64.precision = tx.precision;
+ tx64.tolerance = tx.tolerance;
+ tx64.time = valid_timeval_to_timeval64 (tx.time);
+ tx64.tick = tx.tick;
+ tx64.ppsfreq = tx.ppsfreq;
+ tx64.jitter = tx.jitter;
+ tx64.shift = tx.shift;
+ tx64.stabil = tx.stabil;
+ tx64.jitcnt = tx.jitcnt;
+ tx64.calcnt = tx.calcnt;
+ tx64.errcnt = tx.errcnt;
+ tx64.stbcnt = tx.stbcnt;
+ tx64.tai = tx.tai;
+
+ return tx64;
+}
+
+/* Convert a known valid struct __timex64 into a struct timex. */
+static inline struct timex
+valid_timex64_to_timex (const struct __timex64 tx64)
+{
+ struct timex tx;
+
+ tx.modes = tx64.modes;
+ tx.offset = tx64.offset;
+ tx.freq = tx64.freq;
+ tx.maxerror = tx64.maxerror;
+ tx.esterror = tx64.esterror;
+ tx.status = tx64.status;
+ tx.constant = tx64.constant;
+ tx.precision = tx64.precision;
+ tx.tolerance = tx64.tolerance;
+ tx.time = valid_timeval64_to_timeval (tx64.time);
+ tx.tick = tx64.tick;
+ tx.ppsfreq = tx64.ppsfreq;
+ tx.jitter = tx64.jitter;
+ tx.shift = tx64.shift;
+ tx.stabil = tx64.stabil;
+ tx.jitcnt = tx64.jitcnt;
+ tx.calcnt = tx64.calcnt;
+ tx.errcnt = tx64.errcnt;
+ tx.stbcnt = tx64.stbcnt;
+ tx.tai = tx64.tai;
+
+ return tx;
+}
# endif /* _ISOMAC */
#endif /* sys/timex.h */