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 */ |