From d4a54ac6494dd47a9c3d490e02897c69c0432341 Mon Sep 17 00:00:00 2001 From: Joseph Myers Date: Mon, 6 Feb 2012 23:01:25 +0000 Subject: [PATCH] Undefine and redefine __i686 for assembly code. --- ChangeLog | 5 +++++ sysdeps/i386/sysdep.h | 8 +++++++- 2 files changed, 12 insertions(+), 1 deletion(-) diff --git a/ChangeLog b/ChangeLog index b0e625b..0f74311 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,5 +1,10 @@ 2012-02-06 Joseph Myers + [BZ #411] + * sysdeps/i386/sysdep.h (__i686): Undefine and redefine. + +2012-02-06 Joseph Myers + * sysdeps/i386/sysdep.h: Include . (GET_PC_THUNK, GET_PC_THUNK_STR): Define conditionally on compiler version. diff --git a/sysdeps/i386/sysdep.h b/sysdeps/i386/sysdep.h index 1dbb8e1..c1dac6c 100644 --- a/sysdeps/i386/sysdep.h +++ b/sysdeps/i386/sysdep.h @@ -23,7 +23,13 @@ #include /* For __GNUC_PREREQ. */ /* It is desirable that the names of PIC thunks match those used by - GCC so that multiple copies are eliminated by the linker. */ + GCC so that multiple copies are eliminated by the linker. Because + GCC 4.6 and earlier use __i686 in the names, it is necessary to + override that predefined macro. */ +#if defined __i686 && defined __ASSEMBLER__ +#undef __i686 +#define __i686 __i686 +#endif #ifdef __ASSEMBLER__ # if __GNUC_PREREQ (4, 7) -- 2.7.4