* sysdeps/unix/sysv/linux/x86_64/sysdep.h (PTR_MANGLE): Define C
authorUlrich Drepper <drepper@redhat.com>
Sun, 18 Dec 2005 21:09:20 +0000 (21:09 +0000)
committerUlrich Drepper <drepper@redhat.com>
Sun, 18 Dec 2005 21:09:20 +0000 (21:09 +0000)
version for inside ld.so.

* elf/rtld.c (dl_main): Don't use hp timing code unless it's available.

ChangeLog
elf/rtld.c
sysdeps/unix/sysv/linux/x86_64/sysdep.h

index 3ad8ff9..12f5cba 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,10 @@
 2005-12-18  Ulrich Drepper  <drepper@redhat.com>
 
+       * sysdeps/unix/sysv/linux/x86_64/sysdep.h (PTR_MANGLE): Define C
+       version for inside ld.so.
+
+       * elf/rtld.c (dl_main): Don't use hp timing code unless it's available.
+
        * sysdeps/powerpc/powerpc32/setjmp-common.S [IS_IN_rtld]: Avoid
        call to __sigjmp_save.
        * sysdeps/powerpc/powerpc64/setjmp-common.S: Likewise.
index 9ef58bb..aee3ea9 100644 (file)
@@ -1837,10 +1837,12 @@ ERROR: ld.so: object '%s' cannot be loaded as audit interface: %s; ignored.\n",
   if (GLRO(dl_pointer_guard))
     {
       // XXX If it is cheap, we should use a separate value.
-      uintptr_t pointer_chk_guard;
+      uintptr_t pointer_chk_guard = stack_chk_guard;
+#ifndef HP_TIMING_NONAVAIL
       hp_timing_t now;
       HP_TIMING_NOW (now);
-      pointer_chk_guard = stack_chk_guard ^ now;
+      pointer_chk_guard ^= now;
+#endif
 #ifdef THREAD_SET_POINTER_GUARD
       THREAD_SET_POINTER_GUARD (pointer_chk_guard);
 #endif
index bb0b604..5dfffca 100644 (file)
 #  define PTR_MANGLE(reg)      xorq __pointer_chk_guard_local(%rip), reg
 #  define PTR_DEMANGLE(reg)    PTR_MANGLE (reg)
 # else
-#  error "Define these if necessary"
+#  define PTR_MANGLE(reg)      asm ("xorq __pointer_chk_guard_local(%%rip), %0"\
+                                    : "=r" (reg) : "0" (reg))
+#  define PTR_DEMANGLE(reg)    PTR_MANGLE (reg)
 # endif
 #else
 # ifdef __ASSEMBLER__