diff options
author | Albert ARIBAUD (3ADEV) <albert.aribaud@3adev.fr> | 2017-07-08 16:43:24 +0200 |
---|---|---|
committer | Albert ARIBAUD (3ADEV) <albert.aribaud@3adev.fr> | 2017-07-08 16:43:24 +0200 |
commit | a7478751c7abac419e501dd9ffb56c38c14ce3e8 (patch) | |
tree | fbf2eed2c8029a91007fad3ca270cdf6aace0a13 | |
parent | 9bca8bc4e86b496ddb7bb536221329af8e16f6b0 (diff) | |
download | glibc-a7478751c7abac419e501dd9ffb56c38c14ce3e8.tar.gz |
Y2038: implement Y2038-ready sched_rr_get_interval
-rw-r--r-- | posix/Makefile | 3 | ||||
-rw-r--r-- | posix/Versions | 7 | ||||
-rw-r--r-- | posix/sched.h | 9 | ||||
-rw-r--r-- | posix/sched_rr_gi64.c | 51 |
4 files changed, 69 insertions, 1 deletions
diff --git a/posix/Makefile b/posix/Makefile index 8f23d647c8..4c398b9269 100644 --- a/posix/Makefile +++ b/posix/Makefile @@ -59,7 +59,8 @@ routines := \ spawnattr_getsigmask spawnattr_getschedpolicy spawnattr_getschedparam \ spawnattr_setsigmask spawnattr_setschedpolicy spawnattr_setschedparam \ posix_madvise \ - get_child_max sched_cpucount sched_cpualloc sched_cpufree + get_child_max sched_cpucount sched_cpualloc sched_cpufree \ + sched_rr_gi64 aux := init-posix environ tests := tstgetopt testfnm runtests runptests \ diff --git a/posix/Versions b/posix/Versions index bb481a505b..dd6d8340d5 100644 --- a/posix/Versions +++ b/posix/Versions @@ -137,4 +137,11 @@ libc { GLIBC_PRIVATE { __libc_fork; __libc_pread; __libc_pwrite; } + + # Y2038 symbols are given their own version until they can be put in + # the right place + + GLIBC_Y2038 { + __sched_rr_get_interval_t64; + } } diff --git a/posix/sched.h b/posix/sched.h index 7037ab398d..c4f50f63e3 100644 --- a/posix/sched.h +++ b/posix/sched.h @@ -72,6 +72,15 @@ extern int sched_get_priority_max (int __algorithm) __THROW; extern int sched_get_priority_min (int __algorithm) __THROW; /* Get the SCHED_RR interval for the named process. */ +#ifdef __USE_TIME_BITS64 +# if defined(__REDIRECT) +extern int __REDIRECT (sched_rr_get_interval, + (__pid_t __pid, struct timespec *__t), + __sched_rr_get_interval_t64) __THROW; +# else +# define sched_rr_get_interval __sched_rr_get_interval_t64 +# endif +#endif extern int sched_rr_get_interval (__pid_t __pid, struct timespec *__t) __THROW; diff --git a/posix/sched_rr_gi64.c b/posix/sched_rr_gi64.c new file mode 100644 index 0000000000..187a8a4efc --- /dev/null +++ b/posix/sched_rr_gi64.c @@ -0,0 +1,51 @@ +/* Copyright (C) 1996-2017 Free Software Foundation, Inc. + This file is part of the GNU C Library. + + The GNU C Library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + The GNU C Library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with the GNU C Library; if not, see + <http://www.gnu.org/licenses/>. */ + +#include <errno.h> +#include <sched.h> +#include <sys/types.h> + +extern int __y2038_linux_support; + +/* Get the SCHED_RR interval for the named process. */ + +int +__sched_rr_get_interval_t64 (pid_t pid, struct __timespec64 *t) +{ + struct timespec ts32; + int result; + + if (t == NULL) + { + __set_errno(EINVAL); + return -1; + } + + if (__y2038_linux_support) + { + /* TODO: use 64-bit syscall */ + } + + result = sched_rr_get_interval(pid, &ts32); + if (result == 0) + { + t->tv_sec = ts32.tv_sec; + t->tv_nsec = ts32.tv_nsec; + t->tv_pad = 0; + } + return result; +} |