Free errstring if _dl_addr doesn't returns 0
authorRoland McGrath <roland@hack.frob.com>
Tue, 9 Oct 2012 22:22:16 +0000 (15:22 -0700)
committerH.J. Lu <hjl.tools@gmail.com>
Tue, 9 Oct 2012 22:22:16 +0000 (15:22 -0700)
ChangeLog
dlfcn/dlerror.c

index 80bce18..4da05b8 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+2012-10-09  Roland McGrath  <roland@hack.frob.com>
+
+       * dlfcn/dlerror.c (check_free): Call _dl_addr only if SHARED is
+       defined.  Don't check if MAP is NULL.
+
 2012-10-09  Joseph Myers  <joseph@codesourcery.com>
 
        * sysdeps/generic/_G_config.h (_G_off64_t): Remove.
index 8138cc2..c30b4f1 100644 (file)
@@ -1,5 +1,5 @@
 /* Return error detail for failing <dlfcn.h> functions.
-   Copyright (C) 1995-2000,2002,2003,2004,2005 Free Software Foundation, Inc.
+   Copyright (C) 1995-2012 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
 
    The GNU C Library is free software; you can redistribute it and/or
@@ -190,11 +190,14 @@ check_free (struct dl_action_result *rec)
     {
       /* We can free the string only if the allocation happened in the
         C library used by the dynamic linker.  This means, it is
-        always the C library in the base namespave.  */
+        always the C library in the base namespace.  When we're statically
+         linked, the dynamic linker is part of the program and so always
+        uses the same C library we use here.  */
+#ifdef SHARED
       struct link_map *map = NULL;
       Dl_info info;
-      if (_dl_addr (check_free, &info, &map, NULL) != 0
-         && map != NULL && map->l_ns == 0)
+      if (_dl_addr (check_free, &info, &map, NULL) != 0 && map->l_ns == 0)
+#endif
        free ((char *) rec->errstring);
     }
 }