mirror of
https://sourceware.org/git/glibc.git
synced 2025-01-05 17:11:06 +00:00
dba2bdbe75
* hurd/hurdauth.c (_S_msg_add_auth): Call __vm_allocate and __vm_deallocate instead of vm_allocate and vm_deallocate. * hurd/hurdmsg.c (_S_msg_set_env_variable): Call __setenv instead of setenv. * hurd/hurdprio.c (_hurd_priority_which_map): Call __geteuid instead of geteuid. * hurd/path-lookup.c (file_name_path_scan): Call __strdup instead of strdup. * hurd/siginfo.c: Include <libioP.h>. (_hurd_siginfo_handler): Call _IO_puts instead of puts. * hurd/xattr.c (_hurd_xattr_get, _hurd_xattr_set): Call __munmap instead of munmap. * io/fts.c (fts_build): Call __dirfd instead of dirfd. * mach/devstream.c: Include <libioP.h>. (dealloc_ref): Call __mach_port_deallocate instead of mach_port_deallocate. (mach_open_devstream): Call _IO_fopencookie instead of fopencookie. Call __mach_port_deallocate instead of mach_port_deallocate. * stdlib/canonicalize.c (__realpath): Call __pathconf instead of pathconf. * sysdeps/mach/hurd/ifreq.c (__ifreq): Call __munmap instead of munmap. * sysdeps/mach/hurd/ifreq.h (__if_freereq): Likewise. * sysdeps/mach/hurd/ptrace.c (ptrace): Call __kill instead of kill. * sysdeps/mach/hurd/sendfile64.c (sendfile64): Call __munmap instead of munmap. * sysdeps/mach/hurd/socketpair.c (__socketpair): Call __close instead of close. * sysdeps/posix/clock_getres.c (realtime_getres): Call __sysconf instead of sysconf. * sysdeps/pthread/timer_gettime.c (timer_gettime): Call __clock_gettime instead of clock_gettime. * sysdeps/pthread/timer_routines.c (thread_func): Likewise. * sysdeps/pthread/timer_settime.c (timer_settime): Likewise. * sysdeps/unix/bsd/gtty.c (gtty): Call __ioctl instead of ioctl. * sysdeps/unix/bsd/stty.c (stty): Likewise. * sysdeps/unix/bsd/tcflow.c (tcflow): Call __tcgetattr instead of tcgetattr. * sysdeps/unix/clock_nanosleep.c (__clock_nanosleep): Call __clock_gettime and __nanosleep instead of clock_gettime and nanosleep.
119 lines
2.9 KiB
C
119 lines
2.9 KiB
C
/* clock_getres -- Get the resolution of a POSIX clockid_t.
|
|
Copyright (C) 1999-2018 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 <stdint.h>
|
|
#include <time.h>
|
|
#include <unistd.h>
|
|
#include <sys/param.h>
|
|
#include <libc-internal.h>
|
|
|
|
|
|
#if HP_TIMING_AVAIL
|
|
static long int nsec; /* Clock frequency of the processor. */
|
|
|
|
static int
|
|
hp_timing_getres (struct timespec *res)
|
|
{
|
|
if (__glibc_unlikely (nsec == 0))
|
|
{
|
|
hp_timing_t freq;
|
|
|
|
/* This can only happen if we haven't initialized the `nsec'
|
|
variable yet. Do this now. We don't have to protect this
|
|
code against multiple execution since all of them should
|
|
lead to the same result. */
|
|
freq = __get_clockfreq ();
|
|
if (__glibc_unlikely (freq == 0))
|
|
/* Something went wrong. */
|
|
return -1;
|
|
|
|
nsec = MAX (UINT64_C (1000000000) / freq, 1);
|
|
}
|
|
|
|
/* Fill in the values.
|
|
The seconds are always zero (unless we have a 1Hz machine). */
|
|
res->tv_sec = 0;
|
|
res->tv_nsec = nsec;
|
|
|
|
return 0;
|
|
}
|
|
#endif
|
|
|
|
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)
|
|
{
|
|
#ifdef SYSDEP_GETRES
|
|
SYSDEP_GETRES;
|
|
#endif
|
|
|
|
#ifndef HANDLED_REALTIME
|
|
case CLOCK_REALTIME:
|
|
retval = realtime_getres (res);
|
|
break;
|
|
#endif /* handled REALTIME */
|
|
|
|
default:
|
|
#ifdef SYSDEP_GETRES_CPU
|
|
SYSDEP_GETRES_CPU;
|
|
#endif
|
|
#if HP_TIMING_AVAIL
|
|
if ((clock_id & ((1 << CLOCK_IDFIELD_SIZE) - 1))
|
|
== CLOCK_THREAD_CPUTIME_ID)
|
|
retval = hp_timing_getres (res);
|
|
else
|
|
#endif
|
|
__set_errno (EINVAL);
|
|
break;
|
|
|
|
#if HP_TIMING_AVAIL && !defined HANDLED_CPUTIME
|
|
case CLOCK_PROCESS_CPUTIME_ID:
|
|
case CLOCK_THREAD_CPUTIME_ID:
|
|
retval = hp_timing_getres (res);
|
|
break;
|
|
#endif
|
|
}
|
|
|
|
return retval;
|
|
}
|
|
weak_alias (__clock_getres, clock_getres)
|