Mark __dso_handle as hidden [BZ #18822]
authorH.J. Lu <hjl.tools@gmail.com>
Tue, 26 Sep 2017 23:53:25 +0000 (16:53 -0700)
committerH.J. Lu <hjl.tools@gmail.com>
Tue, 26 Sep 2017 23:53:44 +0000 (16:53 -0700)
Since __dso_handle is always defined by either crtbegin.o from GCC or
dso_handle.c, it should be marked as hidden and be passed directly.

[BZ #18822]
* dlfcn/modatexit.c (foo): Remove __dso_handle check.
* dlfcn/modcxaatexit.c: Include <dso_handle.h>.
(__dso_handle): Remove declaration.
* dlfcn/tstatexit.c (__dso_handle): Removed.
(main): Don't check __dso_handle.
* dlfcn/tstcxaatexit.c (__dso_handle): Removed.
(main): Don't check __dso_handle.
* include/dso_handle.h: New file.
* malloc/mtrace.c: Include <dso_handle.h>.
(mtrace): Pass __dso_handle directly.
* nptl/pthread_atfork.c: Include <dso_handle.h>.
(__dso_handle): Remove declaration.
(__pthread_atfork): Pass __dso_handle directly.
* nptl/tst-atfork2mod.c: Include <dso_handle.h>.
(__dso_handle): Removed.
* posix/wordexp-test.c: Include <dso_handle.h>.
(__dso_handle): Remove declaration.
(__app_register_atfork): Pass __dso_handle directly.
* stdlib/at_quick_exit.c: Include <dso_handle.h>.
(__dso_handle): Remove declaration.
(at_quick_exit): Pass __dso_handle directly.
* stdlib/atexit.c: Include <dso_handle.h>.
(__dso_handle): Remove declaration.
(atexit): Pass __dso_handle directly.
* stdlib/tst-tls-atexit-lib.c: Include <dso_handle.h>.
(__dso_handle): Removed.

13 files changed:
ChangeLog
dlfcn/modatexit.c
dlfcn/modcxaatexit.c
dlfcn/tstatexit.c
dlfcn/tstcxaatexit.c
include/dso_handle.h [new file with mode: 0644]
malloc/mtrace.c
nptl/pthread_atfork.c
nptl/tst-atfork2mod.c
posix/wordexp-test.c
stdlib/at_quick_exit.c
stdlib/atexit.c
stdlib/tst-tls-atexit-lib.c

index 91c77515db466613969b1b9ff7e1d36e919be361..a731980f8028d77cf74f686c7723a3373d8fa8bc 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,33 @@
+2017-09-26  H.J. Lu  <hongjiu.lu@intel.com>
+
+       [BZ #18822]
+       * dlfcn/modatexit.c (foo): Remove __dso_handle check.
+       * dlfcn/modcxaatexit.c: Include <dso_handle.h>.
+       (__dso_handle): Remove declaration.
+       * dlfcn/tstatexit.c (__dso_handle): Removed.
+       (main): Don't check __dso_handle.
+       * dlfcn/tstcxaatexit.c (__dso_handle): Removed.
+       (main): Don't check __dso_handle.
+       * include/dso_handle.h: New file.
+       * malloc/mtrace.c: Include <dso_handle.h>.
+       (mtrace): Pass __dso_handle directly.
+       * nptl/pthread_atfork.c: Include <dso_handle.h>.
+       (__dso_handle): Remove declaration.
+       (__pthread_atfork): Pass __dso_handle directly.
+       * nptl/tst-atfork2mod.c: Include <dso_handle.h>.
+       (__dso_handle): Removed.
+       * posix/wordexp-test.c: Include <dso_handle.h>.
+       (__dso_handle): Remove declaration.
+       (__app_register_atfork): Pass __dso_handle directly.
+       * stdlib/at_quick_exit.c: Include <dso_handle.h>.
+       (__dso_handle): Remove declaration.
+       (at_quick_exit): Pass __dso_handle directly.
+       * stdlib/atexit.c: Include <dso_handle.h>.
+       (__dso_handle): Remove declaration.
+       (atexit): Pass __dso_handle directly.
+       * stdlib/tst-tls-atexit-lib.c: Include <dso_handle.h>.
+       (__dso_handle): Removed.
+
 2017-09-26  Joseph Myers  <joseph@codesourcery.com>
 
        * sysdeps/unix/make-syscalls.sh: Use __ifunc to define symbols
index e620d10c705ed4eee695614806373cc08f361ffe..95c18dcbac276b7bc0241a4d1ab10ceda4bd3123 100644 (file)
@@ -35,9 +35,7 @@ dummy (void)
 void
 foo (void *p)
 {
-  extern void *__dso_handle __attribute__ ((__weak__));
   printf ("This is %s\n", __FUNCTION__);
   atexit (dummy);
-  if (&__dso_handle) puts ("have dso handle"); else puts ("no dso handle");
   ip = p;
 }
index fbda2f3c9f49d6762e018e58b8affc946c690f0b..917a97d813d29187765db02add9ee1c1e547a7e4 100644 (file)
@@ -17,6 +17,7 @@
 
 #include <stdio.h>
 #include <stdlib.h>
+#include <dso_handle.h>
 
 extern void fluffy (void *p);
 extern void bar (void *p);
@@ -34,7 +35,6 @@ fluffy (void *p)
 void
 bar (void *p)
 {
-  extern void *__dso_handle;
   printf ("This is %s\n", __FUNCTION__);
   __cxa_atexit (fluffy, p, __dso_handle);
 }
index 2073843b8f88d3e4589204980ca91a1255999e1a..e25a3f80000a1f62f48a10f33ff3b55e5916e6b4 100644 (file)
@@ -20,8 +20,6 @@
 #include <stdlib.h>
 
 
-extern void *__dso_handle __attribute__ ((__weak__));
-
 int
 main (void)
 {
@@ -30,12 +28,6 @@ main (void)
   void (*fp) (void *);
   int v = 0;
 
-  if (&__dso_handle == NULL)
-    {
-      puts ("__dso_handle not available, cannot perform the test");
-      exit (0);
-    }
-
   h = dlopen (fname, RTLD_NOW);
   if (h == NULL)
     {
index fde645c16b4979ff685fa07427895af56fd136c1..37f25d63d477ff36b2247d23e3aaef9a563f7b27 100644 (file)
@@ -19,8 +19,6 @@
 #include <stdio.h>
 #include <stdlib.h>
 
-extern void *__dso_handle __attribute__ ((__weak__));
-
 int
 main (void)
 {
@@ -29,12 +27,6 @@ main (void)
   void (*fp) (void *);
   int v = 0;
 
-  if (&__dso_handle == NULL)
-    {
-      puts ("__dso_handle not available, cannot perform the test");
-      exit (0);
-    }
-
   h = dlopen (fname, RTLD_LAZY);
   if (h == NULL)
     {
diff --git a/include/dso_handle.h b/include/dso_handle.h
new file mode 100644 (file)
index 0000000..d9c1ebb
--- /dev/null
@@ -0,0 +1,3 @@
+/* __dso_handle is always defined by either crtbegin.o from GCC or our
+   dso_handle.c.  */
+extern void *__dso_handle __attribute__ ((__visibility__ ("hidden")));
index 6c362d967984a15a0a49e33edf86697a11c7d05c..9eb2f5f1c7b3196afdaa18a01b0da198689ee102 100644 (file)
@@ -34,6 +34,7 @@
 #include <_itoa.h>
 
 #include <libc-internal.h>
+#include <dso_handle.h>
 
 #include <libio/iolibio.h>
 #define setvbuf(s, b, f, l) _IO_setvbuf (s, b, f, l)
@@ -315,10 +316,9 @@ mtrace (void)
 #ifdef _LIBC
           if (!added_atexit_handler)
             {
-              extern void *__dso_handle __attribute__ ((__weak__));
               added_atexit_handler = 1;
               __cxa_atexit ((void (*)(void *))release_libc_mem, NULL,
-                            &__dso_handle ? __dso_handle : NULL);
+                           __dso_handle);
             }
 #endif
         }
index dc2ea07887ab47bdce9e3d70f9985c362bdf7ab8..f1aa2b3cf18606d758dec20e871a798536bb0261 100644 (file)
 
 #include "pthreadP.h"
 #include <fork.h>
-
-/* This is defined by newer gcc version unique for each module.  */
-extern void *__dso_handle __attribute__ ((__weak__,
-                                         __visibility__ ("hidden")));
+#include <dso_handle.h>
 
 
 /* Hide the symbol so that no definition but the one locally in the
@@ -51,8 +48,7 @@ attribute_hidden
 __pthread_atfork (void (*prepare) (void), void (*parent) (void),
                  void (*child) (void))
 {
-  return __register_atfork (prepare, parent, child,
-                           &__dso_handle == NULL ? NULL : __dso_handle);
+  return __register_atfork (prepare, parent, child, __dso_handle);
 }
 #ifndef __pthread_atfork
 extern int pthread_atfork (void (*prepare) (void), void (*parent) (void),
index fe64046d3ccd89bdbfc8ffe820f52e3333eb68a8..ea47d5825a22d402da84fa203c0a66c622461a97 100644 (file)
@@ -19,6 +19,7 @@
 #include <pthread.h>
 #include <stdio.h>
 #include <stdlib.h>
+#include <dso_handle.h>
 
 
 extern int val;
@@ -46,7 +47,6 @@ static void
 __attribute__ ((constructor))
 init (void)
 {
-  extern void *__dso_handle;
   printf ("dsohandle = %p\n", __dso_handle);
 
   if (pthread_atfork (prepare, parent, child) != 0)
index 17ae812346979a576845f625887a59cf85653430..c030a4d6705254e20bce2158f4c1b8218a9d515c 100644 (file)
 #include <string.h>
 #include <wordexp.h>
 #include <libc-pointer-arith.h>
+#include <dso_handle.h>
 
 #define IFS " \n\t"
 
-extern void *__dso_handle __attribute__ ((__weak__, __visibility__ ("hidden")));
 extern int __register_atfork (void (*) (void), void (*) (void), void (*) (void), void *);
 
 static int __app_register_atfork (void (*prepare) (void), void (*parent) (void), void (*child) (void))
 {
-  return __register_atfork (prepare, parent, child,
-                           &__dso_handle == NULL ? NULL : __dso_handle);
+  return __register_atfork (prepare, parent, child, __dso_handle);
 }
 
 /* Number of forks seen.  */
index 3b74d0a688d0be510057aaa069a348629a1f62c1..0f1c1fde9ea506eb85f28535501f9fc50c902711 100644 (file)
    <http://www.gnu.org/licenses/>.  */
 
 #include <stdlib.h>
+#include <dso_handle.h>
 #include "exit.h"
 
 
-/* This is defined by newer gcc version unique for each module.  */
-extern void *__dso_handle __attribute__ ((__weak__));
-
-
 /* Register FUNC to be executed by `quick_exit'.  */
 int
 attribute_hidden
 at_quick_exit (void (*func) (void))
 {
-  return __cxa_at_quick_exit ((void (*) (void *)) func,
-                             &__dso_handle == NULL ? NULL : __dso_handle);
+  return __cxa_at_quick_exit ((void (*) (void *)) func, __dso_handle);
 }
index f28b6ba1b7d7dad833d8172494a288cd820f3ad4..aaecb4a50323719f51457f2d5f2b4507eddfa692 100644 (file)
    <http://www.gnu.org/licenses/>.  */
 
 #include <stdlib.h>
+#include <dso_handle.h>
 #include "exit.h"
 
-
-/* This is defined by newer gcc version unique for each module.  */
-extern void *__dso_handle __attribute__ ((__weak__));
-
-
 /* Register FUNC to be executed by `exit'.  */
 int
 #ifndef atexit
@@ -47,6 +43,5 @@ attribute_hidden
 #endif
 atexit (void (*func) (void))
 {
-  return __cxa_atexit ((void (*) (void *)) func, NULL,
-                      &__dso_handle == NULL ? NULL : __dso_handle);
+  return __cxa_atexit ((void (*) (void *)) func, NULL, __dso_handle);
 }
index a227e4653c11611143065065312421b054401214..06ec02f4ee324eb6fcc2b736d2f22699238ff42b 100644 (file)
@@ -17,8 +17,7 @@
    <http://www.gnu.org/licenses/>.  */
 
 #include <stdlib.h>
-
-extern void *__dso_handle;
+#include <dso_handle.h>
 
 typedef struct
 {