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>
This commit is contained in:
parent
384f99dea7
commit
d131070105
@ -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) */
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user