Replace __attribute__((visibility("protected")))
authorH.J. Lu <hjl.tools@gmail.com>
Fri, 6 Mar 2015 12:55:56 +0000 (04:55 -0800)
committerH.J. Lu <hjl.tools@gmail.com>
Sat, 7 Mar 2015 01:05:42 +0000 (17:05 -0800)
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.

ChangeLog
elf/ifuncdep2.c
elf/ifuncmod1.c
elf/ifuncmod5.c

index eaccb2cf5006e5e50ac94f40d016fb49feff188c..7f2e14bcd5fe64c2dca36f48d06dc3b9dd8b3dfd 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -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
index 99d19263ae9dd3fa622b69e3932b438d536c8ad3..6e66d318a6a036bb772244819ce9c47c79d70da1 100644 (file)
@@ -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)
index 2b8195ce553dfa66614bf5c0908bb1c301407ea1..0b6138056daf7c7dfed2f455cc0845197100a995 100644 (file)
@@ -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)
index 9a08e8cf53c471c8f0fc998673cc46a2eccdb399..0e65a63691f2e65e7fd0b1897e14c72c1b89605d 100644 (file)
@@ -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)