diff options
author | Andreas Schwab <schwab@linux-m68k.org> | 2012-05-16 22:05:58 +0200 |
---|---|---|
committer | Andreas Schwab <schwab@linux-m68k.org> | 2012-05-18 11:59:44 +0200 |
commit | b53ef01aa25acc4c4f0b41dd120e90d6eb69e370 (patch) | |
tree | c4ac2ab3480acb745f32f805da4edade8a09ed32 | |
parent | 7a185db2b7f9853d35fbd1396a56d0c7a64b4bd9 (diff) | |
download | glibc-b53ef01aa25acc4c4f0b41dd120e90d6eb69e370.tar.gz glibc-b53ef01aa25acc4c4f0b41dd120e90d6eb69e370.tar.xz glibc-b53ef01aa25acc4c4f0b41dd120e90d6eb69e370.zip |
Fix undefined reference to _dl_prof_resolve in profiled libc
-rw-r--r-- | ChangeLog | 6 | ||||
-rw-r--r-- | sysdeps/powerpc/powerpc32/dl-machine.c | 13 |
2 files changed, 15 insertions, 4 deletions
diff --git a/ChangeLog b/ChangeLog index d36463942f..6c9bc16e8e 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,9 @@ +2012-05-18 Andreas Schwab <schwab@linux-m68k.org> + + * sysdeps/powerpc/powerpc32/dl-machine.c + (__elf_machine_runtime_setup) [PROF]: Don't reference + _dl_prof_resolve. + 2012-05-18 Andreas Jaeger <aj@suse.de> * sysdeps/x86_64/fpu/bits/mathinline.h (lrintf): Make inline diff --git a/sysdeps/powerpc/powerpc32/dl-machine.c b/sysdeps/powerpc/powerpc32/dl-machine.c index e535480133..26c38fdd72 100644 --- a/sysdeps/powerpc/powerpc32/dl-machine.c +++ b/sysdeps/powerpc/powerpc32/dl-machine.c @@ -1,5 +1,5 @@ /* Machine-dependent ELF dynamic relocation functions. PowerPC version. - Copyright (C) 1995-2006, 2008, 2011 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 @@ -235,16 +235,21 @@ __elf_machine_runtime_setup (struct link_map *map, int lazy, int profile) if (lazy) { Elf32_Word *tramp = plt + PLT_TRAMPOLINE_ENTRY_WORDS; - Elf32_Word dlrr = (Elf32_Word)(profile - ? _dl_prof_resolve - : _dl_runtime_resolve); + Elf32_Word dlrr; Elf32_Word offset; +#ifndef PROF + dlrr = (Elf32_Word) (profile + ? _dl_prof_resolve + : _dl_runtime_resolve); if (profile && GLRO(dl_profile) != NULL && _dl_name_match_p (GLRO(dl_profile), map)) /* This is the object we are looking for. Say that we really want profiling and the timers are started. */ GL(dl_profile_map) = map; +#else + dlrr = (Elf32_Word) _dl_runtime_resolve; +#endif /* For the long entries, subtract off data_words. */ tramp[0] = OPCODE_ADDIS_HI (11, 11, -data_words); |