about summary refs log tree commit diff
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@redhat.com>2010-05-21 23:51:18 -0700
committerUlrich Drepper <drepper@redhat.com>2010-05-21 23:51:18 -0700
commitb32b8b451b398ebae33d4cf8039c03f4d615c0c3 (patch)
treeeab16ef7b354ad864faced73b62572a78b1c8056
parent9acbe24da8c71704d03e30d1223f997442d4be0c (diff)
downloadglibc-b32b8b451b398ebae33d4cf8039c03f4d615c0c3.tar.gz
glibc-b32b8b451b398ebae33d4cf8039c03f4d615c0c3.tar.xz
glibc-b32b8b451b398ebae33d4cf8039c03f4d615c0c3.zip
Don't crash on unresolved weak symbol reference when auditing.
-rw-r--r--ChangeLog5
-rw-r--r--elf/dl-runtime.c5
2 files changed, 8 insertions, 2 deletions
diff --git a/ChangeLog b/ChangeLog
index 951f367bb4..5571fcf2e7 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+2010-05-21  Ulrich Drepper  <drepper@redhat.com>
+
+	* elf/dl-runtime.c (_dl_profile_fixup): Don't crash on unresolved weak
+	symbol reference.
+
 2010-05-19  Andreas Schwab  <schwab@redhat.com>
 
 	* elf/dl-runtime.c (_dl_fixup): Don't crash on unresolved weak
diff --git a/elf/dl-runtime.c b/elf/dl-runtime.c
index 181af7dfac..6847edafc6 100644
--- a/elf/dl-runtime.c
+++ b/elf/dl-runtime.c
@@ -232,8 +232,9 @@ _dl_profile_fixup (
 				       ? LOOKUP_VALUE_ADDRESS (result)
 					 + defsym->st_value : 0);
 
-	  if (__builtin_expect (ELFW(ST_TYPE) (defsym->st_info)
-				== STT_GNU_IFUNC, 0))
+	  if (defsym != NULL
+	      && __builtin_expect (ELFW(ST_TYPE) (defsym->st_info)
+				   == STT_GNU_IFUNC, 0))
 	    value = ((DL_FIXUP_VALUE_TYPE (*) (void))
 		     DL_FIXUP_VALUE_ADDR (value)) ();
 	}