remove legacy clock_gettime and gettimeofday from public syscall.h
authorRich Felker <dalias@aerifal.cx>
Thu, 30 Jan 2020 16:25:07 +0000 (11:25 -0500)
committerRich Felker <dalias@aerifal.cx>
Thu, 30 Jan 2020 16:25:07 +0000 (11:25 -0500)
commit5a105f19b5aae79dd302899e634b6b18b3dcd0d6
treeb96bcfdc32cdbf4a16eaf1fea74e4c52bffd52ba
parente6093b5a870a38ebfb3e54382acd48c698bde15d
remove legacy clock_gettime and gettimeofday from public syscall.h

some nontrivial number of applications have historically performed
direct syscalls for these operations rather than using the public
functions. such usage is invalid now that time_t is 64-bit and these
syscalls no longer match the types they are used with, and it was
already harmful before (by suppressing use of vdso).

since syscall() has no type safety, incorrect usage of these syscalls
can't be caught at compile-time. so, without manually inspecting or
running additional tools to check sources, the risk of such errors
slipping through is high.

this patch renames the syscalls on 32-bit archs to clock_gettime32 and
gettimeofday_time32, so that applications using the original names
will fail to build without being fixed.

note that there are a number of other syscalls that may also be unsafe
to use directly after the time64 switchover, but (1) these are the
main two that seem to be in widespread use, and (2) most of the others
continue to have valid usage with a null timeval/timespec argument, as
the argument is an optional timeout or similar.
arch/arm/bits/syscall.h.in
arch/i386/bits/syscall.h.in
arch/m68k/bits/syscall.h.in
arch/microblaze/bits/syscall.h.in
arch/mips/bits/syscall.h.in
arch/mipsn32/bits/syscall.h.in
arch/or1k/bits/syscall.h.in
arch/powerpc/bits/syscall.h.in
arch/sh/bits/syscall.h.in
src/internal/syscall.h