mirror of
git://sourceware.org/git/glibc.git
synced 2025-01-18 12:16:13 +08:00
e5ac7bd679
ISO C2X adds a timespec_getres function alongside the C11 timespec_get, with functionality similar to that of POSIX clock_getres (including allowing a NULL pointer to be passed to the function). Implement this function for glibc, similarly to the implementation of timespec_get. This includes a basic test like that of timespec_get, but no documentation in the manual, given that TIME_UTC and timespec_get aren't documented in the manual at all. The handling of 64-bit time follows that in timespec_get; people maintaining patch series for 64-bit time will need to update them accordingly (to export __timespec_getres64, redirect calls in time.h and run the test for _TIME_BITS=64). Tested for x86_64 and x86, and (previous version; only testcase differs) with build-many-glibcs.py.
74 lines
2.1 KiB
C
74 lines
2.1 KiB
C
/* clock_getres -- Get the resolution of a POSIX clockid_t.
|
|
Copyright (C) 1999-2021 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
|
|
<https://www.gnu.org/licenses/>. */
|
|
|
|
#include <errno.h>
|
|
#include <stdint.h>
|
|
#include <time.h>
|
|
#include <unistd.h>
|
|
#include <sys/param.h>
|
|
#include <libc-internal.h>
|
|
#include <shlib-compat.h>
|
|
|
|
static inline int
|
|
realtime_getres (struct timespec *res)
|
|
{
|
|
long int clk_tck = __sysconf (_SC_CLK_TCK);
|
|
|
|
if (__glibc_likely (clk_tck != -1))
|
|
{
|
|
/* This implementation assumes that the realtime clock has a
|
|
resolution higher than 1 second. This is the case for any
|
|
reasonable implementation. */
|
|
res->tv_sec = 0;
|
|
res->tv_nsec = 1000000000 / clk_tck;
|
|
return 0;
|
|
}
|
|
|
|
return -1;
|
|
}
|
|
|
|
|
|
/* Get resolution of clock. */
|
|
int
|
|
__clock_getres (clockid_t clock_id, struct timespec *res)
|
|
{
|
|
int retval = -1;
|
|
|
|
switch (clock_id)
|
|
{
|
|
case CLOCK_REALTIME:
|
|
retval = realtime_getres (res);
|
|
break;
|
|
|
|
default:
|
|
__set_errno (EINVAL);
|
|
break;
|
|
}
|
|
|
|
return retval;
|
|
}
|
|
libc_hidden_def (__clock_getres)
|
|
|
|
versioned_symbol (libc, __clock_getres, clock_getres, GLIBC_2_17);
|
|
/* clock_getres moved to libc in version 2.17;
|
|
old binaries may expect the symbol version it had in librt. */
|
|
#if SHLIB_COMPAT (libc, GLIBC_2_2, GLIBC_2_17)
|
|
strong_alias (__clock_getres, __clock_getres_2);
|
|
compat_symbol (libc, __clock_getres_2, clock_getres, GLIBC_2_2);
|
|
#endif
|