Fix passing symbol value to pltexit callbacks when ld.so auditing.
authorUlrich Drepper <drepper@gmail.com>
Wed, 2 Feb 2011 16:50:49 +0000 (11:50 -0500)
committerUlrich Drepper <drepper@gmail.com>
Wed, 2 Feb 2011 16:50:49 +0000 (11:50 -0500)
ChangeLog
elf/dl-runtime.c

index 24506f0..6a57302 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,9 @@
+2011-02-02  Ulrich Drepper  <drepper@gmail.com>
+
+       * elf/dl-runtime.c (_dl_call_pltexit): Pass correct address of the
+       function to the callback.
+       Patch partly by Jiri Olsa <jolsa@redhat.com>.
+
 2011-02-02  Andreas Schwab  <schwab@redhat.com>
 
        * shadow/sgetspent.c: Check return value of __sgetspent_r instead
index 6847eda..ae2d05c 100644 (file)
@@ -1,5 +1,5 @@
 /* On-demand PLT fixup for shared objects.
-   Copyright (C) 1995-2009, 2010 Free Software Foundation, Inc.
+   Copyright (C) 1995-2009, 2010, 2011 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
@@ -446,6 +446,7 @@ _dl_call_pltexit (struct link_map *l, ElfW(Word) reloc_arg,
 
   /* Set up the sym parameter.  */
   ElfW(Sym) sym = *defsym;
+  sym.st_value = DL_FIXUP_VALUE_ADDR (reloc_result->addr);
 
   /* Get the symbol name.  */
   const char *strtab = (const void *) D_PTR (reloc_result->bound,