mirror of
https://sourceware.org/git/glibc.git
synced 2025-01-15 21:40:05 +00:00
1e372ded4f
This patch refactor how hp-timing is used on loader code for statistics report. The HP_TIMING_AVAIL and HP_SMALL_TIMING_AVAIL are removed and HP_TIMING_INLINE is used instead to check for hp-timing avaliability. For alpha, which only defines HP_SMALL_TIMING_AVAIL, the HP_TIMING_INLINE is set iff for IS_IN(rtld). Checked on aarch64-linux-gnu, x86_64-linux-gnu, and i686-linux-gnu. I also checked the builds for all afected ABIs. * benchtests/bench-timing.h: Replace HP_TIMING_AVAIL with HP_TIMING_INLINE. * nptl/descr.h: Likewise. * elf/rtld.c (RLTD_TIMING_DECLARE, RTLD_TIMING_NOW, RTLD_TIMING_DIFF, RTLD_TIMING_ACCUM_NT, RTLD_TIMING_SET): Define. (dl_start_final_info, _dl_start_final, dl_main, print_statistics): Abstract hp-timing usage with RTLD_* macros. * sysdeps/alpha/hp-timing.h (HP_TIMING_INLINE): Define iff IS_IN(rtld). (HP_TIMING_AVAIL, HP_SMALL_TIMING_AVAIL): Remove. * sysdeps/generic/hp-timing.h (HP_TIMING_AVAIL, HP_SMALL_TIMING_AVAIL, HP_TIMING_NONAVAIL): Likewise. * sysdeps/ia64/hp-timing.h (HP_TIMING_AVAIL, HP_SMALL_TIMING_AVAIL): Likewise. * sysdeps/powerpc/powerpc32/power4/hp-timing.h (HP_TIMING_AVAIL, HP_SMALL_TIMING_AVAIL): Likewise. * sysdeps/powerpc/powerpc64/hp-timing.h (HP_TIMING_AVAIL, HP_SMALL_TIMING_AVAIL): Likewise. * sysdeps/sparc/sparc32/sparcv9/hp-timing.h (HP_TIMING_AVAIL, HP_SMALL_TIMING_AVAIL): Likewise. * sysdeps/sparc/sparc64/hp-timing.h (HP_TIMING_AVAIL, HP_SMALL_TIMING_AVAIL): Likewise. * sysdeps/x86/hp-timing.h (HP_TIMING_AVAIL, HP_SMALL_TIMING_AVAIL): Likewise. * sysdeps/generic/hp-timing-common.h: Update comment with HP_TIMING_AVAIL removal.
62 lines
2.2 KiB
C
62 lines
2.2 KiB
C
/* High precision, low overhead timing functions. x86 version.
|
|
Copyright (C) 2018-2019 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/>. */
|
|
|
|
#ifndef _HP_TIMING_H
|
|
#define _HP_TIMING_H 1
|
|
|
|
#include <isa.h>
|
|
|
|
#if MINIMUM_ISA == 686 || MINIMUM_ISA == 8664
|
|
/* We indeed have inlined functions. */
|
|
# define HP_TIMING_INLINE (1)
|
|
|
|
/* We use 64bit values for the times. */
|
|
typedef unsigned long long int hp_timing_t;
|
|
|
|
/* That's quite simple. Use the `rdtsc' instruction. Note that the value
|
|
might not be 100% accurate since there might be some more instructions
|
|
running in this moment. This could be changed by using a barrier like
|
|
'cpuid' right before the `rdtsc' instruciton. But we are not interested
|
|
in accurate clock cycles here so we don't do this.
|
|
|
|
NB: Use __builtin_ia32_rdtsc directly since including <x86intrin.h>
|
|
makes building glibc very slow. */
|
|
# ifdef USE_RDTSCP
|
|
/* RDTSCP waits until all previous instructions have executed and all
|
|
previous loads are globally visible before reading the counter.
|
|
RDTSC doesn't wait until all previous instructions have been executed
|
|
before reading the counter. */
|
|
# define HP_TIMING_NOW(Var) \
|
|
(__extension__ ({ \
|
|
unsigned int __aux; \
|
|
(Var) = __builtin_ia32_rdtscp (&__aux); \
|
|
}))
|
|
# else
|
|
# define HP_TIMING_NOW(Var) ((Var) = __builtin_ia32_rdtsc ())
|
|
# endif
|
|
|
|
# include <hp-timing-common.h>
|
|
#else
|
|
/* NB: Undefine _HP_TIMING_H so that <sysdeps/generic/hp-timing.h> will
|
|
be included. */
|
|
# undef _HP_TIMING_H
|
|
# include <sysdeps/generic/hp-timing.h>
|
|
#endif
|
|
|
|
#endif /* hp-timing.h */
|