olga / rpms / glibc

Forked from rpms/glibc 5 years ago
Clone

Blame SOURCES/glibc-aarch64-add-ptr_mangle-support.patch

ce426f
commit 9188b6818a3d1a6e6d89bf10fa4aea27a591494c
ce426f
Author: Venkataramanan Kumar <venkataramanan.kumar@linaro.org>
ce426f
Date:   Wed Jan 1 17:47:14 2014 +0000
ce426f
ce426f
    [AArch64] Pointer mangling support for AArch64.
ce426f
ce426f
diff --git glibc-2.17-c758a686/ports/sysdeps/aarch64/__longjmp.S glibc-2.17-c758a686/ports/sysdeps/aarch64/__longjmp.S
ce426f
index 250f2af..2d38bbf 100644
ce426f
--- glibc-2.17-c758a686/ports/sysdeps/aarch64/__longjmp.S
ce426f
+++ glibc-2.17-c758a686/ports/sysdeps/aarch64/__longjmp.S
ce426f
@@ -50,8 +50,12 @@ ENTRY (__longjmp)
ce426f
 	ldp	x23, x24, [x0, #JB_X23<<3]
ce426f
 	ldp	x25, x26, [x0, #JB_X25<<3]
ce426f
 	ldp	x27, x28, [x0, #JB_X27<<3]
ce426f
+#ifdef PTR_DEMANGLE
ce426f
+	ldp	x29,  x4, [x0, #JB_X29<<3]
ce426f
+	PTR_DEMANGLE (x30, x4, x3, x2)
ce426f
+#else
ce426f
 	ldp	x29, x30, [x0, #JB_X29<<3]
ce426f
-
ce426f
+#endif
ce426f
 	ldp	 d8,  d9, [x0, #JB_D8<<3]
ce426f
 	ldp	d10, d11, [x0, #JB_D10<<3]
ce426f
 	ldp	d12, d13, [x0, #JB_D12<<3]
ce426f
@@ -87,8 +91,12 @@ ENTRY (__longjmp)
ce426f
 	cfi_same_value(d13)
ce426f
 	cfi_same_value(d14)
ce426f
 	cfi_same_value(d15)
ce426f
-
ce426f
-	ldr	x5,  [x0, #JB_SP<<3]
ce426f
+#ifdef PTR_DEMANGLE
ce426f
+	ldr	x4, [x0, #JB_SP<<3]
ce426f
+	PTR_DEMANGLE (x5, x4, x3, x2)
ce426f
+#else
ce426f
+	ldr	x5, [x0, #JB_SP<<3]
ce426f
+#endif
ce426f
 	mov	sp, x5
ce426f
 	cmp	x1, #0
ce426f
 	mov	x0, #1
ce426f
diff --git glibc-2.17-c758a686/ports/sysdeps/aarch64/jmpbuf-offsets.h glibc-2.17-c758a686/ports/sysdeps/aarch64/jmpbuf-offsets.h
ce426f
index 84c2ccc..bcf2afa 100644
ce426f
--- glibc-2.17-c758a686/ports/sysdeps/aarch64/jmpbuf-offsets.h
ce426f
+++ glibc-2.17-c758a686/ports/sysdeps/aarch64/jmpbuf-offsets.h
ce426f
@@ -39,6 +39,22 @@
ce426f
 #define JB_D14		 20
ce426f
 #define JB_D15		 21
ce426f
 
ce426f
+#ifndef  __ASSEMBLER__
ce426f
+#include <setjmp.h>
ce426f
+#include <stdint.h>
ce426f
+#include <sysdep.h>
ce426f
+
ce426f
+static inline uintptr_t __attribute__ ((unused))
ce426f
+_jmpbuf_sp (__jmp_buf jmpbuf)
ce426f
+{
ce426f
+  uintptr_t sp = jmpbuf[JB_SP];
ce426f
+#ifdef PTR_DEMANGLE
ce426f
+  PTR_DEMANGLE (sp);
ce426f
+#endif
ce426f
+  return sp;
ce426f
+}
ce426f
+#endif
ce426f
+
ce426f
 /* Helper for generic ____longjmp_chk(). */
ce426f
 #define JB_FRAME_ADDRESS(buf) \
ce426f
-  ((void *) (buf[JB_SP]))
ce426f
+  ((void *) _jmpbuf_sp (buf))
ce426f
diff --git glibc-2.17-c758a686/ports/sysdeps/aarch64/jmpbuf-unwind.h glibc-2.17-c758a686/ports/sysdeps/aarch64/jmpbuf-unwind.h
ce426f
index 22c6c2b..39a5dc2 100644
ce426f
--- glibc-2.17-c758a686/ports/sysdeps/aarch64/jmpbuf-unwind.h
ce426f
+++ glibc-2.17-c758a686/ports/sysdeps/aarch64/jmpbuf-unwind.h
ce426f
@@ -29,16 +29,6 @@
ce426f
 #define _JMPBUF_CFA_UNWINDS_ADJ(jmpbuf, context, adj) \
ce426f
   _JMPBUF_UNWINDS_ADJ (jmpbuf, (void *) _Unwind_GetCFA (context), adj)
ce426f
 
ce426f
-static inline uintptr_t __attribute__ ((unused))
ce426f
-_jmpbuf_sp (__jmp_buf jmpbuf)
ce426f
-{
ce426f
-  uintptr_t sp = jmpbuf[JB_SP];
ce426f
-#ifdef PTR_DEMANGLE
ce426f
-  PTR_DEMANGLE (sp);
ce426f
-#endif
ce426f
-  return sp;
ce426f
-}
ce426f
-
ce426f
 #define _JMPBUF_UNWINDS_ADJ(_jmpbuf, _address, _adj) \
ce426f
   ((uintptr_t) (_address) - (_adj) < _jmpbuf_sp (_jmpbuf) - (_adj))
ce426f
 
ce426f
diff --git glibc-2.17-c758a686/ports/sysdeps/aarch64/setjmp.S glibc-2.17-c758a686/ports/sysdeps/aarch64/setjmp.S
ce426f
index cb94e01..5822abd 100644
ce426f
--- glibc-2.17-c758a686/ports/sysdeps/aarch64/setjmp.S
ce426f
+++ glibc-2.17-c758a686/ports/sysdeps/aarch64/setjmp.S
ce426f
@@ -39,13 +39,25 @@ ENTRY (__sigsetjmp)
ce426f
 	stp	x23, x24, [x0, #JB_X23<<3]
ce426f
 	stp	x25, x26, [x0, #JB_X25<<3]
ce426f
 	stp	x27, x28, [x0, #JB_X27<<3]
ce426f
+
ce426f
+#ifdef PTR_MANGLE
ce426f
+	PTR_MANGLE (x4, x30, x3, x2)
ce426f
+	stp	x29,  x4, [x0, #JB_X29<<3]
ce426f
+#else
ce426f
 	stp	x29, x30, [x0, #JB_X29<<3]
ce426f
+#endif
ce426f
 	stp	 d8,  d9, [x0, #JB_D8<<3]
ce426f
 	stp	d10, d11, [x0, #JB_D10<<3]
ce426f
 	stp	d12, d13, [x0, #JB_D12<<3]
ce426f
 	stp	d14, d15, [x0, #JB_D14<<3]
ce426f
+#ifdef PTR_MANGLE
ce426f
+	mov	x4, sp
ce426f
+	PTR_MANGLE (x5, x4, x3, x2)
ce426f
+	str	x5, [x0, #JB_SP<<3]
ce426f
+#else
ce426f
 	mov	x2,  sp
ce426f
 	str	x2,  [x0, #JB_SP<<3]
ce426f
+#endif
ce426f
 #if defined NOT_IN_libc && defined IS_IN_rtld
ce426f
 	/* In ld.so we never save the signal mask */
ce426f
 	mov	w0, #0
ce426f
diff --git glibc-2.17-c758a686/ports/sysdeps/aarch64/sysdep.h glibc-2.17-c758a686/ports/sysdeps/aarch64/sysdep.h
ce426f
index 0dd597a..7169ba7 100644
ce426f
--- glibc-2.17-c758a686/ports/sysdeps/aarch64/sysdep.h
ce426f
+++ glibc-2.17-c758a686/ports/sysdeps/aarch64/sysdep.h
ce426f
@@ -78,6 +78,17 @@
ce426f
 # define L(name)         .L##name
ce426f
 #endif
ce426f
 
ce426f
+/* Load or store to/from a pc-relative EXPR into/from R, using T.  */
ce426f
+#define LDST_PCREL(OP, R, T, EXPR)  \
ce426f
+	adrp	T, EXPR;	    \
ce426f
+	OP	R, [T, #:lo12:EXPR];\
ce426f
+
ce426f
+/* Load or store to/from a got-relative EXPR into/from R, using T.  */
ce426f
+#define LDST_GLOBAL(OP, R, T, EXPR)     \
ce426f
+	adrp	T, :got:EXPR;		\
ce426f
+	ldr	T, [T, #:got_lo12:EXPR];\
ce426f
+	OP	R, [T];
ce426f
+
ce426f
 /* Since C identifiers are not normally prefixed with an underscore
ce426f
    on this system, the asm identifier `syscall_error' intrudes on the
ce426f
    C name space.  Make sure we use an innocuous name.  */
ce426f
diff --git glibc-2.17-c758a686/ports/sysdeps/unix/sysv/linux/aarch64/sysdep.h glibc-2.17-c758a686/ports/sysdeps/unix/sysv/linux/aarch64/sysdep.h
ce426f
index f3f0ada..5ccf1da 100644
ce426f
--- glibc-2.17-c758a686/ports/sysdeps/unix/sysv/linux/aarch64/sysdep.h
ce426f
+++ glibc-2.17-c758a686/ports/sysdeps/unix/sysv/linux/aarch64/sysdep.h
ce426f
@@ -371,8 +371,44 @@ __local_syscall_error:						\
ce426f
 
ce426f
 #endif	/* __ASSEMBLER__ */
ce426f
 
ce426f
-/* Pointer mangling is not yet supported for AArch64.  */
ce426f
-#define PTR_MANGLE(var) (void) (var)
ce426f
-#define PTR_DEMANGLE(var) (void) (var)
ce426f
+/* Pointer mangling is supported for AArch64.  */
ce426f
+#if (defined NOT_IN_libc && defined IS_IN_rtld) || \
ce426f
+  (!defined SHARED && (!defined NOT_IN_libc || defined IS_IN_libpthread))
ce426f
+# ifdef __ASSEMBLER__
ce426f
+#  define PTR_MANGLE(dst, src, guard, tmp)                                \
ce426f
+  LDST_PCREL (ldr, guard, tmp, C_SYMBOL_NAME(__pointer_chk_guard_local)); \
ce426f
+  PTR_MANGLE2 (dst, src, guard)
ce426f
+/* Use PTR_MANGLE2 for efficiency if guard is already loaded.  */
ce426f
+#  define PTR_MANGLE2(dst, src, guard)\
ce426f
+  eor dst, src, guard
ce426f
+#  define PTR_DEMANGLE(dst, src, guard, tmp)\
ce426f
+  PTR_MANGLE (dst, src, guard, tmp)
ce426f
+#  define PTR_DEMANGLE2(dst, src, guard)\
ce426f
+  PTR_MANGLE2 (dst, src, guard)
ce426f
+# else
ce426f
+extern uintptr_t __pointer_chk_guard_local attribute_relro attribute_hidden;
ce426f
+#  define PTR_MANGLE(var) \
ce426f
+  (var) = (__typeof (var)) ((uintptr_t) (var) ^ __pointer_chk_guard_local)
ce426f
+#  define PTR_DEMANGLE(var)     PTR_MANGLE (var)
ce426f
+# endif
ce426f
+#else
ce426f
+# ifdef __ASSEMBLER__
ce426f
+#  define PTR_MANGLE(dst, src, guard, tmp)                             \
ce426f
+  LDST_GLOBAL (ldr, guard, tmp, C_SYMBOL_NAME(__pointer_chk_guard));   \
ce426f
+  PTR_MANGLE2 (dst, src, guard)
ce426f
+/* Use PTR_MANGLE2 for efficiency if guard is already loaded.  */
ce426f
+#  define PTR_MANGLE2(dst, src, guard)\
ce426f
+  eor dst, src, guard
ce426f
+#  define PTR_DEMANGLE(dst, src, guard, tmp)\
ce426f
+  PTR_MANGLE (dst, src, guard, tmp)
ce426f
+#  define PTR_DEMANGLE2(dst, src, guard)\
ce426f
+  PTR_MANGLE2 (dst, src, guard)
ce426f
+# else
ce426f
+extern uintptr_t __pointer_chk_guard attribute_relro;
ce426f
+#  define PTR_MANGLE(var) \
ce426f
+  (var) = (__typeof (var)) ((uintptr_t) (var) ^ __pointer_chk_guard)
ce426f
+#  define PTR_DEMANGLE(var) PTR_MANGLE (var)
ce426f
+# endif
ce426f
+#endif
ce426f
 
ce426f
 #endif /* linux/aarch64/sysdep.h */
ce426f
commit 0b1f8e35640f5b3f7af11764ade3ff060211c309
ce426f
Author: Carlos O'Donell <carlos@redhat.com>
ce426f
Date:   Mon Sep 23 01:44:38 2013 -0400
ce426f
ce426f
    BZ #15754: Fix test case for ARM.
ce426f
    
ce426f
    Statically built binaries use __pointer_chk_guard_local,
ce426f
    while dynamically built binaries use __pointer_chk_guard.
ce426f
    Provide the right definition depending on the test case
ce426f
    we are building.
ce426f
ce426f
diff --git glibc-2.17-c758a686/elf/Makefile glibc-2.17-c758a686/elf/Makefile
ce426f
index cb8da93..27d249b 100644
ce426f
--- glibc-2.17-c758a686/elf/Makefile
ce426f
+++ glibc-2.17-c758a686/elf/Makefile
ce426f
@@ -1019,6 +1019,9 @@ tst-stackguard1-ARGS = --command "$(host-test-program-cmd) --child"
ce426f
 tst-stackguard1-static-ARGS = --command "$(objpfx)tst-stackguard1-static --child"
ce426f
 
ce426f
 tst-ptrguard1-ARGS = --command "$(host-built-program-cmd) --child"
ce426f
+# When built statically, the pointer guard interface uses
ce426f
+# __pointer_chk_guard_local.
ce426f
+CFLAGS-tst-ptrguard1-static.c = -DPTRGUARD_LOCAL
ce426f
 tst-ptrguard1-static-ARGS = --command "$(objpfx)tst-ptrguard1-static --child"
ce426f
 
ce426f
 $(objpfx)tst-leaks1: $(libdl)
ce426f
diff --git glibc-2.17-c758a686/sysdeps/generic/stackguard-macros.h glibc-2.17-c758a686/sysdeps/generic/stackguard-macros.h
ce426f
index 4fa3d96..b4a6b23 100644
ce426f
--- glibc-2.17-c758a686/sysdeps/generic/stackguard-macros.h
ce426f
+++ glibc-2.17-c758a686/sysdeps/generic/stackguard-macros.h
ce426f
@@ -3,5 +3,10 @@
ce426f
 extern uintptr_t __stack_chk_guard;
ce426f
 #define STACK_CHK_GUARD __stack_chk_guard
ce426f
 
ce426f
+#ifdef PTRGUARD_LOCAL
ce426f
 extern uintptr_t __pointer_chk_guard_local;
ce426f
-#define POINTER_CHK_GUARD __pointer_chk_guard_local
ce426f
+# define POINTER_CHK_GUARD __pointer_chk_guard_local
ce426f
+#else
ce426f
+extern uintptr_t __pointer_chk_guard;
ce426f
+# define POINTER_CHK_GUARD __pointer_chk_guard
ce426f
+#endif