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-31 17:26:27 -0700 |
commit | e77b1d821369f00e39c6f7c974ae5759a5ea4b84 (patch) | |
tree | adcb3b59d36b5e077b176bb71cf8ceff5da56b04 /elf/ifuncmod1.c | |
parent | b5344eca1895da9192fb4b9c2c470a40e41dda03 (diff) | |
download | glibc-e77b1d821369f00e39c6f7c974ae5759a5ea4b84.tar.gz glibc-e77b1d821369f00e39c6f7c974ae5759a5ea4b84.tar.xz glibc-e77b1d821369f00e39c6f7c974ae5759a5ea4b84.zip |
Replace __attribute__((visibility("protected"))) hjl/pr17711/2.19
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. Cherry-pick from master: e0ed2fb40a0e29c43cf60addc74741dab15f2e05 * elf/ifuncdep2.c (global): Replace __attribute__((visibility("protected"))) with asm (".protected global"). * elf/ifuncmod1.c (global): Likewise. * elf/ifuncmod5.c (global): Likewise.
Diffstat (limited to 'elf/ifuncmod1.c')
-rw-r--r-- | elf/ifuncmod1.c | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/elf/ifuncmod1.c b/elf/ifuncmod1.c index 2b8195ce55..0b6138056d 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) |