OSDN Git Service

x86_64: fix multiple definition of chk functions
authorAustin Foxley <austinf@cetoncorp.com>
Sat, 19 Dec 2009 21:35:52 +0000 (13:35 -0800)
committerAustin Foxley <austinf@cetoncorp.com>
Sat, 19 Dec 2009 21:35:52 +0000 (13:35 -0800)
also enable __chk_fail and only try to call it when SSP is on

Signed-off-by: Austin Foxley <austinf@cetoncorp.com>
libc/string/x86_64/bzero.S
libc/string/x86_64/memcpy.S
libc/string/x86_64/mempcpy.S
libc/string/x86_64/memset.S
libc/sysdeps/linux/common/ssp.c

index 4d179ec..231d7cb 100644 (file)
@@ -1,5 +1,6 @@
 #include <features.h>
 #ifdef __UCLIBC_SUSV3_LEGACY__
 # define memset bzero
+# define __memset_chk __bzero_chk
 # include "memset.S"
 #endif
index 0112914..6d941e0 100644 (file)
@@ -29,7 +29,9 @@
 #if defined __PIC__ && !defined NOT_IN_libc
 ENTRY (__memcpy_chk)
        cmpq    %rdx, %rcx
+#if defined __UCLIBC_HAS_SSP__
        jb      HIDDEN_JUMPTARGET (__chk_fail)
+#endif
 END (__memcpy_chk)
 #endif
 ENTRY (BP_SYM (memcpy))
index 3816d9f..b0607aa 100644 (file)
@@ -1,3 +1,4 @@
 #define memcpy mempcpy
+#define __memcpy_chk __mempcpy_chk
 #include "memcpy.S"
 libc_hidden_def(mempcpy)
index 562574a..df265f3 100644 (file)
 #define LARGE $120000
 
         .text
-#if !BZERO_P && defined __PIC__ && !defined NOT_IN_libc
+#if defined __PIC__ && !defined NOT_IN_libc
 ENTRY (__memset_chk)
        cmpq    %rdx, %rcx
+#if defined __UCLIBC_HAS_SSP__
        jb      HIDDEN_JUMPTARGET (__chk_fail)
+#endif
 END (__memset_chk)
 #endif
 ENTRY (memset)
index 69611ca..a2d7ff2 100644 (file)
@@ -100,7 +100,6 @@ void __stack_chk_fail(void)
                terminate();
 }
 
-#if 0
 void __chk_fail(void) attribute_noreturn;
 void __chk_fail(void)
 {
@@ -115,4 +114,4 @@ void __chk_fail(void)
        while(1)
                terminate();
 }
-#endif
+