]> git.ipfire.org Git - thirdparty/glibc.git/commitdiff
csu: Update __libgcc_s_init comment
authorFlorian Weimer <fweimer@redhat.com>
Thu, 11 Jan 2018 12:13:28 +0000 (13:13 +0100)
committerFlorian Weimer <fweimer@redhat.com>
Tue, 16 Jan 2018 08:27:28 +0000 (09:27 +0100)
Reviewed-by: Carlos O'Donell <carlos@redhat.com>
(cherry picked from commit 08c6e95234c60a5c2f37532d1111acf084f39345)

ChangeLog
sysdeps/gnu/unwind-resume.c

index a1028fcdff30020b1bdc0e6f9761d9183448f41c..6178a89fa6534252c86ab9ccfb6afd6dc6c911cd 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+2018-01-11  Florian Weimer  <fweimer@redhat.com>
+
+       * sysdeps/gnu/unwind-resume.c (__libgcc_s_init): Update comment
+       and error message.
+
 2018-01-16  Florian Weimer  <fweimer@redhat.com>
 
        * nptl/Makefile (CFLAGS-tst-minstack-throw.o): Compile in C++11
index 1ea833ba9bae2e92bc3f445051d4ccc036956ffb..ecb4ce20670bc4ce053c2c0b7cf3284a272365ae 100644 (file)
@@ -35,13 +35,17 @@ __libgcc_s_init (void)
   void *resume, *personality;
   void *handle;
 
-  handle = __libc_dlopen (LIBGCC_S_SO);
+  /* Use RTLD_NOW here for consistency with pthread_cancel_init.
+     RTLD_NOW will rarely make a difference here because unwinding is
+     already in progress, so libgcc_s.so has already been loaded if
+     its unwinder is used.  */
+  handle = __libc_dlopen_mode (LIBGCC_S_SO, RTLD_NOW | __RTLD_DLOPEN);
 
   if (handle == NULL
       || (resume = __libc_dlsym (handle, "_Unwind_Resume")) == NULL
       || (personality = __libc_dlsym (handle, "__gcc_personality_v0")) == NULL)
     __libc_fatal (LIBGCC_S_SO
-                  " must be installed for pthread_cancel to work\n");
+                  " must be installed for unwinding to work\n");
 
 #ifdef PTR_MANGLE
   PTR_MANGLE (resume);