]> git.ipfire.org Git - thirdparty/glibc.git/commitdiff
Provide __libc_fatal for rtld.
authorRoland McGrath <roland@hack.frob.com>
Thu, 9 Jul 2015 22:32:32 +0000 (15:32 -0700)
committerRoland McGrath <roland@hack.frob.com>
Thu, 9 Jul 2015 22:32:32 +0000 (15:32 -0700)
ChangeLog
elf/dl-minimal.c
include/stdio.h

index e93052d42019e49ae827ae925a8800582ded9da2..fae6a3052bcb2ca18d5d08f012fd74f5eea4dde9 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,10 @@
 2015-07-09  Roland McGrath  <roland@hack.frob.com>
 
+       * include/stdio.h: Add rtld_hidden_proto (__libc_fatal).
+       * elf/dl-minimal.c: For readability, reorder some definitions and
+       introduce more page breaks.  Include <stdio.h>.
+       (__libc_fatal): New function.
+
        * include/unistd.h: Add rtld_hidden_proto for _exit.
        * posix/_exit.c: Add rtld_hidden_def.
        * sysdeps/mach/hurd/_exit.c: Likewise.
index 04f416dced3d8f8623d892c672acc48f1d8c1e52..ec7fe88d301ffb9972f8ea6bcf095d2fca32627e 100644 (file)
@@ -18,6 +18,7 @@
 
 #include <errno.h>
 #include <limits.h>
+#include <stdio.h>
 #include <string.h>
 #include <tls.h>
 #include <unistd.h>
@@ -193,8 +194,22 @@ __strerror_r (int errnum, char *buf, size_t buflen)
   return msg;
 }
 \f
-#ifndef NDEBUG
+void
+__libc_fatal (const char *message)
+{
+  _dl_fatal_printf ("%s", message);
+}
+rtld_hidden_def (__libc_fatal)
 
+void
+__attribute__ ((noreturn))
+__chk_fail (void)
+{
+  _exit (127);
+}
+rtld_hidden_def (__chk_fail)
+
+#ifndef NDEBUG
 /* Define (weakly) our own assert failure function which doesn't use stdio.
    If we are linked into the user program (-ldl), the normal __assert_fail
    defn can override this one.  */
@@ -209,7 +224,7 @@ Inconsistency detected by ld.so: %s: %u: %s%sAssertion `%s' failed!\n",
                    assertion);
 
 }
-rtld_hidden_weak(__assert_fail)
+rtld_hidden_weak (__assert_fail)
 
 void weak_function
 __assert_perror_fail (int errnum,
@@ -225,7 +240,7 @@ Inconsistency detected by ld.so: %s: %u: %s%sUnexpected error: %s.\n",
 }
 rtld_hidden_weak (__assert_perror_fail)
 #endif
-
+\f
 unsigned long int weak_function
 __strtoul_internal (const char *nptr, char **endptr, int base, int group)
 {
@@ -324,7 +339,11 @@ _itoa (value, buflim, base, upper_case)
   return buflim;
 }
 
-
+/* The '_itoa_lower_digits' variable in libc.so is able to handle bases
+   up to 36.  We don't need this here.  */
+const char _itoa_lower_digits[16] = "0123456789abcdef";
+rtld_hidden_data_def (_itoa_lower_digits)
+\f
 /* The following is not a complete strsep implementation.  It cannot
    handle empty delimiter strings.  But this isn't necessary for the
    execution of ld.so.  */
@@ -367,16 +386,3 @@ __strsep (char **stringp, const char *delim)
 }
 weak_alias (__strsep, strsep)
 strong_alias (__strsep, __strsep_g)
-
-void
-__attribute__ ((noreturn))
-__chk_fail (void)
-{
-  _exit (127);
-}
-rtld_hidden_def (__chk_fail)
-
-/* The '_itoa_lower_digits' variable in libc.so is able to handle bases
-   up to 36.  We don't need this here.  */
-const char _itoa_lower_digits[16] = "0123456789abcdef";
-rtld_hidden_data_def (_itoa_lower_digits)
index 31718f953d3db3f643cdbca88c1ba8052a7801b5..1ffbc40b3dd4990ea02ede61e6c55c81ff807e21 100644 (file)
@@ -172,6 +172,7 @@ libc_hidden_proto (fmemopen)
 extern FILE *__open_memstream (char **, size_t *) __THROW __wur;
 libc_hidden_proto (__open_memstream)
 libc_hidden_proto (__libc_fatal)
+rtld_hidden_proto (__libc_fatal)
 libc_hidden_proto (__vsprintf_chk)
 libc_hidden_proto (__vsnprintf_chk)
 libc_hidden_proto (__vfprintf_chk)