Ping [Patch v2] bfd elfxx-ia64: share code between elf32 and elf64

Aurelien Jarno aurelien@aurel32.net
Tue Jul 5 19:06:00 GMT 2011


Hello Tristan,

On Wed, May 25, 2011 at 02:02:49PM +0200, Tristan Gingold wrote:
> 
> On May 25, 2011, at 9:21 AM, Nick Clifton wrote:
> 
> > Hi Tristan,
> > 
> >> bfd/
> >> 2011-05-17  Tristan Gingold<gingold@adacore.com>
> >> 
> >> 	* configure.in (bfd_elf32_ia64_big_vec, bfd_elf32_ia64_hpux_big_vec)
> >> 	(bfd_elf64_ia64_big_vec, bfd_elf64_ia64_hpux_big_vec)
> >> 	(bfd_elf64_ia64_little_vec, bfd_elf64_ia64_vms_vec): Add elfxx-ia64.lo
> >> 	* Makefile.am (BFD64_BACKENDS): Add elfxx-ia64.lo
> >> 	(BFD64_BACKENDS_CFILES): Add elfxx-ia64.c
> >> 	(elf32-ia64.c): Created from elfnn-ia64.c
> >> 	(elf64-ia64.c): Likewise.
> >> 	* elfxx-ia64.h: New file.
> >> 	* elfxx-ia64.c: Split with elfnn-ia64.c.  Keep only the following
> >> 	functions.Includes elfxx-ia64.h.
> >> 	(elfNN_ia64_reloc): Renames to ia64_elf_reloc.  Adjust error message.
> >> 	(IA64_HOWTO): Adjust.
> >> 	(lookup_howto): Renames to ia64_elf_lookup_howto.  Make it public.
> >> 	(elfNN_ia64_reloc_type_lookup): Renames to
> >> 	ia64_elf_reloc_type_lookup. Make it public. Adjust calls.
> >> 	(elfNN_ia64_reloc_name_lookup): Renames to
> >> 	ia64_elf_reloc_name_lookup. Make it public.
> >> 	(elfNN_ia64_relax_br): Renames to ia64_elf_relax_br.  Make it public.
> >> 	(elfNN_ia64_relax_brl): Renames to ia64_elf_relax_brl. Make it
> >> 	public.
> >> 	(elfNN_ia64_relax_ldxmov): Renames to ia64_elf_relax_ldxmov.
> >> 	Move it and make it public.  Move prototype to elfxx-ia64.h
> >> 	(elfNN_ia64_install_value): Renames to ia64_elf_install_value.
> >> 	Move prototype to elfxx-ia64.h
> >> 	* elfnn-ia64.c: New file, split from elfxx-ia64.c.
> >> 	(elfNN_ia64_info_to_howto): Adjust calls.
> >> 	(elfNN_ia64_relax_section): Adjust calls.
> >> 	(count_dyn_reloc): Fix typo.
> >> 	(elfNN_ia64_relocate_section): Adjust calls.
> >> 	(elfNN_ia64_finish_dynamic_symbol): Likewise.
> >> 	(bfd_elfNN_bfd_reloc_type_lookup)
> >> 	(bfd_elfNN_bfd_reloc_name_lookup): Adjust macros.
> > 
> > Approved - please apply.
> 
> Thanks, committed.
> 

This patch seems to break libc on ia64. ld-2.13.so produced with
binutils using this patch works when called as a standalone, but just
segfault when used with other binaries:

| $ ./ld.so 
| Usage: ld.so [OPTION]... EXECUTABLE-FILE [ARGS-FOR-PROGRAM...]
| You have invoked `ld.so', the helper program for shared library executables.
| This program usually lives in the file `/lib/ld.so', and special directives
| in executable files using ELF shared libraries tell the system's program
| loader to load the helper program from this file.  This helper program loads
| the shared libraries needed by the program executable, prepares the program
| to run, and runs it.  You may invoke this helper program directly from the
| command line to load and run an ELF executable file; this is like executing
| that file itself, but always uses this helper program from the file you
| specified, instead of the helper program file specified in the executable
| file you run.  This is mostly of use for maintainers to test new versions
| of this helper program; chances are you did not intend to run this program.
| 
|   --list                list all dependencies and how they are resolved
|   --verify              verify that given object really is a dynamically linked
|                         object we can handle
|   --library-path PATH   use given PATH instead of content of the environment
|                         variable LD_LIBRARY_PATH
|   --inhibit-rpath LIST  ignore RUNPATH and RPATH information in object names
|                         in LIST
|   --audit LIST          use objects named in LIST as auditors
| $ ./ld.so  /bin/ls
| Segmentation fault
| 

I don't know what is the best way to proceed for debugging this issue. I
can provide you the correct and the broken ld.so if it can help.

Thanks,
Aurelien

-- 
Aurelien Jarno                          GPG: 1024D/F1BCDB73
aurelien@aurel32.net                 http://www.aurel32.net



More information about the Binutils mailing list