diff options
author | H.J. Lu <hjl.tools@gmail.com> | 2015-03-06 04:55:56 -0800 |
---|---|---|
committer | H.J. Lu <hjl.tools@gmail.com> | 2015-03-06 17:05:42 -0800 |
commit | e0ed2fb40a0e29c43cf60addc74741dab15f2e05 (patch) | |
tree | 400c1a1de7caeeb732a83957afab9d24b4ec8b85 | |
parent | 0b3467b344c9c30f590e5d67e9a694ea1f33b7ea (diff) | |
download | glibc-e0ed2fb40a0e29c43cf60addc74741dab15f2e05.zip glibc-e0ed2fb40a0e29c43cf60addc74741dab15f2e05.tar.gz glibc-e0ed2fb40a0e29c43cf60addc74741dab15f2e05.tar.bz2 |
Replace __attribute__((visibility("protected")))
With copy relocation, address of protected data defined in the shared
library may be external. Compiler shouldn't asssume protected data will
be local. But due to
https://gcc.gnu.org/bugzilla/show_bug.cgi?id=65248
__attribute__((visibility("protected"))) doesn't work correctly, we need
to use asm (".protected xxx") instead.
* elf/ifuncdep2.c (global): Replace
__attribute__((visibility("protected"))) with
asm (".protected global").
* elf/ifuncmod1.c (global): Likewise.
* elf/ifuncmod5.c (global): Likewise.
-rw-r--r-- | ChangeLog | 8 | ||||
-rw-r--r-- | elf/ifuncdep2.c | 8 | ||||
-rw-r--r-- | elf/ifuncmod1.c | 8 | ||||
-rw-r--r-- | elf/ifuncmod5.c | 8 |
4 files changed, 29 insertions, 3 deletions
@@ -1,3 +1,11 @@ +2015-03-06 H.J. Lu <hongjiu.lu@intel.com> + + * elf/ifuncdep2.c (global): Replace + __attribute__((visibility("protected"))) with + asm (".protected global"). + * elf/ifuncmod1.c (global): Likewise. + * elf/ifuncmod5.c (global): Likewise. + 2015-03-06 Joseph Myers <joseph@codesourcery.com> * soft-fp/soft-fp.h [!_LIBC && __KERNEL__]: Include diff --git a/elf/ifuncdep2.c b/elf/ifuncdep2.c index 99d1926..6e66d31 100644 --- a/elf/ifuncdep2.c +++ b/elf/ifuncdep2.c @@ -2,7 +2,13 @@ #include "ifunc-sel.h" -int global __attribute__ ((visibility ("protected"))) = -1; +int global = -1; +/* Can't use __attribute__((visibility("protected"))) until the GCC bug: + + https://gcc.gnu.org/bugzilla/show_bug.cgi?id=65248 + + is fixed. */ +asm (".protected global"); static int one (void) diff --git a/elf/ifuncmod1.c b/elf/ifuncmod1.c index 2b8195c..0b61380 100644 --- a/elf/ifuncmod1.c +++ b/elf/ifuncmod1.c @@ -6,7 +6,13 @@ */ #include "ifunc-sel.h" -int global __attribute__ ((visibility ("protected"))) = -1; +int global = -1; +/* Can't use __attribute__((visibility("protected"))) until the GCC bug: + + https://gcc.gnu.org/bugzilla/show_bug.cgi?id=65248 + + is fixed. */ +asm (".protected global"); static int one (void) diff --git a/elf/ifuncmod5.c b/elf/ifuncmod5.c index 9a08e8c..0e65a63 100644 --- a/elf/ifuncmod5.c +++ b/elf/ifuncmod5.c @@ -1,7 +1,13 @@ /* Test STT_GNU_IFUNC symbols without direct function call. */ #include "ifunc-sel.h" -int global __attribute__ ((visibility ("protected"))) = -1; +int global = -1; +/* Can't use __attribute__((visibility("protected"))) until the GCC bug: + + https://gcc.gnu.org/bugzilla/show_bug.cgi?id=65248 + + is fixed. */ +asm (".protected global"); static int one (void) |