| Index: bfd/elfcode.h
|
| diff --git a/bfd/elfcode.h b/bfd/elfcode.h
|
| index b7e022614ca59648f0c8e941a9fc0a7789f53674..30bda73d86d19c20657beb9d344a63228732b769 100644
|
| --- a/bfd/elfcode.h
|
| +++ b/bfd/elfcode.h
|
| @@ -1,6 +1,6 @@
|
| /* ELF executable support for BFD.
|
| Copyright 1991, 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000,
|
| - 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011
|
| + 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011, 2012
|
| Free Software Foundation, Inc.
|
|
|
| Written by Fred Fish @ Cygnus Support, from information published
|
| @@ -633,8 +633,9 @@ elf_object_p (bfd *abfd)
|
| if (i_ehdrp->e_shnum == SHN_UNDEF)
|
| {
|
| i_ehdrp->e_shnum = i_shdr.sh_size;
|
| - if (i_ehdrp->e_shnum != i_shdr.sh_size
|
| - || i_ehdrp->e_shnum == 0)
|
| + if (i_ehdrp->e_shnum >= SHN_LORESERVE
|
| + || i_ehdrp->e_shnum != i_shdr.sh_size
|
| + || i_ehdrp->e_shnum == 0)
|
| goto got_wrong_format_error;
|
| }
|
|
|
| @@ -1097,8 +1098,28 @@ elf_checksum_contents (bfd *abfd,
|
| elf_swap_shdr_out (abfd, &i_shdr, &x_shdr);
|
| (*process) (&x_shdr, sizeof x_shdr, arg);
|
|
|
| + /* PR ld/12451:
|
| + Process the section's contents, if it has some. Read them in if necessary. */
|
| if (i_shdr.contents)
|
| (*process) (i_shdr.contents, i_shdr.sh_size, arg);
|
| + else if (i_shdr.sh_type != SHT_NOBITS)
|
| + {
|
| + asection *sec;
|
| +
|
| + sec = bfd_section_from_elf_index (abfd, count);
|
| + if (sec != NULL)
|
| + {
|
| + if (sec->contents == NULL)
|
| + {
|
| + /* Force rereading from file. */
|
| + sec->flags &= ~SEC_IN_MEMORY;
|
| + if (! bfd_malloc_and_get_section (abfd, sec, & sec->contents))
|
| + continue;
|
| + }
|
| + if (sec->contents != NULL)
|
| + (*process) (sec->contents, i_shdr.sh_size, arg);
|
| + }
|
| + }
|
| }
|
|
|
| return TRUE;
|
| @@ -1430,7 +1451,7 @@ elf_slurp_reloc_table_from_section (bfd *abfd,
|
| (*_bfd_error_handler)
|
| (_("%s(%s): relocation %d has invalid symbol index %ld"),
|
| abfd->filename, asect->name, i, ELF_R_SYM (rela.r_info));
|
| - relent->sym_ptr_ptr = bfd_abs_section.symbol_ptr_ptr;
|
| + relent->sym_ptr_ptr = bfd_abs_section_ptr->symbol_ptr_ptr;
|
| }
|
| else
|
| {
|
| @@ -1595,7 +1616,7 @@ NAME(_bfd_elf,bfd_from_remote_memory)
|
| (bfd *templ,
|
| bfd_vma ehdr_vma,
|
| bfd_vma *loadbasep,
|
| - int (*target_read_memory) (bfd_vma, bfd_byte *, int))
|
| + int (*target_read_memory) (bfd_vma, bfd_byte *, bfd_size_type))
|
| {
|
| Elf_External_Ehdr x_ehdr; /* Elf file header, external form */
|
| Elf_Internal_Ehdr i_ehdr; /* Elf file header, internal form */
|
|
|