new attempt at working around the gcc 3 visibility bug
authorRich Felker <dalias@aerifal.cx>
Sat, 25 Feb 2012 01:07:21 +0000 (20:07 -0500)
committerRich Felker <dalias@aerifal.cx>
Sat, 25 Feb 2012 01:07:21 +0000 (20:07 -0500)
since gcc is failing to generate the necessary ".hidden" directive in
the output asm, generate it explicitly with an __asm__ statement...

src/internal/libc.c
src/internal/libc.h
src/multibyte/internal.c

index 5f12e29..c1e21ca 100644 (file)
@@ -9,3 +9,7 @@ struct __libc *__libc_loc()
 #else
 struct __libc __libc;
 #endif
+
+#ifdef BROKEN_VISIBILITY
+__asm__(".hidden __libc");
+#endif
index 45d5c9e..39a1865 100644 (file)
@@ -22,6 +22,9 @@ struct __libc {
 #if !defined(__PIC__) || 100*__GNUC__+__GNUC_MINOR__ >= 303 || defined(__PCC__) || defined(__TINYC__)
 
 #ifdef __PIC__
+#if __GNUC__ < 4
+#define BROKEN_VISIBILITY 1
+#endif
 #define ATTR_LIBC_VISIBILITY __attribute__((visibility("hidden"))) 
 #else
 #define ATTR_LIBC_VISIBILITY
index 11b9818..ab22806 100644 (file)
@@ -32,3 +32,7 @@ const uint32_t bittab[] = {
        E(0x8),E(0x9),E(0xa),E(0xb),E(0xc),E(0xd),E(0xe),E(0xf),
        F(0x0),F(0x1),F(0x2),F(0x3),F(0x4)
 };
+
+#ifdef BROKEN_VISIBILITY
+__asm__(".hidden __fsmu8");
+#endif