diff options
author | andrew <andrew@FreeBSD.org> | 2012-12-15 21:24:31 +0000 |
---|---|---|
committer | andrew <andrew@FreeBSD.org> | 2012-12-15 21:24:31 +0000 |
commit | ebd063486fc717748793e6a0a99efa40f170f19b (patch) | |
tree | e397f1a3f7d20e598ce1e878c7d82fc83b7933b0 /contrib/gcc/config | |
parent | 20e1774582916800a1d85e6877886ecc1e9e51af (diff) | |
download | FreeBSD-src-ebd063486fc717748793e6a0a99efa40f170f19b.zip FreeBSD-src-ebd063486fc717748793e6a0a99efa40f170f19b.tar.gz |
Don't define CTORS_SECTION_ASM_OP and DTORS_SECTION_ASM_OP on arm when
built with clang. When these are defined the lists are defined similar to:
asm(".section .ctors");
STATIC func_ptr __CTOR_LIST__[1] = { (func_ptr) (-1) };
asm(".section .dtors");
STATIC func_ptr __DTOR_LIST__[1] = { (func_ptr) (-1) };
The problem is clang will move the two arrays out of the .ctors and .dtors
sections causing these sections to contain a single null address. By not
defining these macros we use the version of the code that places the arrays
is their sections by using __attribute__((section(".ctors"))) and similar
for .dtors.
Submitted by: Daisuke Aoyama <aoyama AT peach.ne.jp>
Diffstat (limited to 'contrib/gcc/config')
-rw-r--r-- | contrib/gcc/config/arm/arm.h | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/contrib/gcc/config/arm/arm.h b/contrib/gcc/config/arm/arm.h index 20a869f..89b8a38 100644 --- a/contrib/gcc/config/arm/arm.h +++ b/contrib/gcc/config/arm/arm.h @@ -1866,8 +1866,10 @@ typedef struct # define DTOR_LIST_BEGIN asm (ARM_EABI_DTORS_SECTION_OP) # define DTOR_LIST_END /* empty */ # else /* !defined (__ARM_EABI__) */ +# ifndef __clang__ # define CTORS_SECTION_ASM_OP ARM_CTORS_SECTION_OP # define DTORS_SECTION_ASM_OP ARM_DTORS_SECTION_OP +# endif # endif /* !defined (__ARM_EABI__) */ #endif /* !defined (IN_LIBCC2) */ |