aboutsummaryrefslogtreecommitdiff
path: root/sysdeps/x86_64
diff options
context:
space:
mode:
authorAdhemerval Zanella <adhemerval.zanella@linaro.org>2020-09-30 16:52:19 -0300
committerAdhemerval Zanella <adhemerval.zanella@linaro.org>2020-09-30 18:03:51 -0300
commit2deb7793907c7995b094b3778017c0ef0bd432d5 (patch)
treecc45621ef69c9007149aa53b50242e76d9ed2d2f /sysdeps/x86_64
parente75fbaaa21563cecccfda9705260ae0b608ed660 (diff)
downloadglibc-2deb7793907c7995b094b3778017c0ef0bd432d5.zip
glibc-2deb7793907c7995b094b3778017c0ef0bd432d5.tar.gz
glibc-2deb7793907c7995b094b3778017c0ef0bd432d5.tar.bz2
sysvipc: Fix semtimedop for Linux < 5.1 for 64-bit ABI
Both powerpc64 and s390x provides semtimedop through __NR_ipc for pre v5.1 kernel. Neither the y2038 support (7c437d3778) nor the attempt to fix an issue for !__ASSUME_DIRECT_SYSVIPC_SYSCALLS (aaa12e9ff0) took this in consideration. This patch fixes it by issuing __NR_semtimedop_time64 iff it is defined, otherwise __NR_semtimeop is issued if both __ASSUME_DIRECT_SYSVIPC_SYSCALLS it set and __NR_semtimedop is define, other __NR_ipc is used instead. To summarize: 1. For 32-bit architetures __NR_semtimedop_time64 is always issued. The fallback is used only for !__ASSUME_TIME64_SYSCALLS and it issues either __NR_ipc or __NR_semtimedop. 2. For 64-bit architecture with wire-up SysV syscall (__ASSUME_DIRECT_SYSVIPC_SYSCALLS and __NR_semtimeop defined) __NR_semtimeop is issued. 3. Otherwise __NR_ipc is used instead. Checked on x86_64-linux-gnu, i686-linux-gnu (kernel 4.15 and 5.4), powerpc64le (kernel 4.18), and s390x (kernel 4.12). Reviewed-by: Matheus Castanho <msc@linux.ibm.com>
Diffstat (limited to 'sysdeps/x86_64')
0 files changed, 0 insertions, 0 deletions