about summary refs log tree commit diff
path: root/nptl/perf.c
diff options
context:
space:
mode:
authorRoland McGrath <roland@gnu.org>2005-09-22 07:29:50 +0000
committerRoland McGrath <roland@gnu.org>2005-09-22 07:29:50 +0000
commit5eac47606bdec9aa2c4ea52bc0c907b5bb54c4b8 (patch)
treebaded91f2f5267e4e9232835b632f4905f97c9c4 /nptl/perf.c
parentf7ffeb91cd6622472b425f8fa12c577c582ed16c (diff)
downloadglibc-5eac47606bdec9aa2c4ea52bc0c907b5bb54c4b8.tar.gz
glibc-5eac47606bdec9aa2c4ea52bc0c907b5bb54c4b8.tar.xz
glibc-5eac47606bdec9aa2c4ea52bc0c907b5bb54c4b8.zip
* elf/dl-tsd.c (__libc_dl_error_tsd): Use attribute_tls_model_ie for
	static __thread variable.
	From Alexandre Oliva <aoliva@redhat.com>
Diffstat (limited to 'nptl/perf.c')
-rw-r--r--nptl/perf.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/nptl/perf.c b/nptl/perf.c
index 5b920d719d..f0dbc29ca0 100644
--- a/nptl/perf.c
+++ b/nptl/perf.c
@@ -1,4 +1,4 @@
-/* Copyright (C) 2002 Free Software Foundation, Inc.
+/* Copyright (C) 2002, 2005 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
    Contributed by Ulrich Drepper <drepper@redhat.com>, 2002.
 
@@ -705,6 +705,11 @@ clock_getcpuclockid (pid_t pid, clockid_t *clock_id)
 
 #ifdef i386
 #define HP_TIMING_NOW(Var)	__asm__ __volatile__ ("rdtsc" : "=A" (Var))
+#elif defined __x86_64__
+# define HP_TIMING_NOW(Var) \
+  ({ unsigned int _hi, _lo; \
+     asm volatile ("rdtsc" : "=a" (_lo), "=d" (_hi)); \
+     (Var) = ((unsigned long long int) _hi << 32) | _lo; })
 #elif defined __ia64__
 #define HP_TIMING_NOW(Var)	__asm__ __volatile__ ("mov %0=ar.itc" : "=r" (Var) : : "memory")
 #else