timex: Use 64-bit fields on 32-bit TIMESIZE=64 systems (BZ #28469)
authorStafford Horne <shorne@gmail.com>
Thu, 14 Oct 2021 21:17:41 +0000 (06:17 +0900)
committerAdhemerval Zanella <adhemerval.zanella@linaro.org>
Mon, 18 Oct 2021 20:17:20 +0000 (17:17 -0300)
commit1d550265a75b412cea4889a50b101395f6a8e025
tree00b87206c3fc25b70893277d273e831e52462edb
parentad6feef1b0c2cc6d7ad29c5cc4e14ba16f360f06
timex: Use 64-bit fields on 32-bit TIMESIZE=64 systems (BZ #28469)

This was found when testing the OpenRISC port I am working on.  These
two tests fail with SIGSEGV:

  FAIL: misc/tst-ntp_gettime
  FAIL: misc/tst-ntp_gettimex

This was found to be due to the kernel overwriting the stack space
allocated by the timex structure.  The reason for the overwrite being
that the kernel timex has 64-bit fields and user space code only
allocates enough stack space for timex with 32-bit fields.

On 32-bit systems with TIMESIZE=64 __USE_TIME_BITS64 is not defined.
This causes the timex structure to use 32-bit fields with type
__syscall_slong_t.

This patch adjusts the ifdef condition to allow 32-bit systems with
TIMESIZE=64 to use the 64-bit long long timex definition.

Reviewed-by: Adhemerval Zanella <adhemerval.zanella@linaro.org>
sysdeps/unix/sysv/linux/bits/timex.h