aboutsummaryrefslogtreecommitdiff
path: root/bfd/elfcode.h
diff options
context:
space:
mode:
authorIan Lance Taylor <ian@airs.com>1994-09-23 19:19:41 +0000
committerIan Lance Taylor <ian@airs.com>1994-09-23 19:19:41 +0000
commit57b400818d0793d8bd7df95143fc1432953d43a4 (patch)
treed732ef78fa3eca21143ab025c19db2450fdf3053 /bfd/elfcode.h
parenta67d9a42cc378bebc1ec1ebda4b1641907050f0e (diff)
downloadgdb-57b400818d0793d8bd7df95143fc1432953d43a4.zip
gdb-57b400818d0793d8bd7df95143fc1432953d43a4.tar.gz
gdb-57b400818d0793d8bd7df95143fc1432953d43a4.tar.bz2
* elfcode.h (map_program_segments): Don't abort if we allocated
too much space for the program header, only if we allocated too little.
Diffstat (limited to 'bfd/elfcode.h')
-rw-r--r--bfd/elfcode.h10
1 files changed, 4 insertions, 6 deletions
diff --git a/bfd/elfcode.h b/bfd/elfcode.h
index 2ba4856..60e8957 100644
--- a/bfd/elfcode.h
+++ b/bfd/elfcode.h
@@ -1924,8 +1924,9 @@ map_program_segments (abfd, off, first, phdr_size)
}
/* Make sure the return value from get_program_header_size matches
- what we computed here. */
- if (phdr_count != phdr_size / sizeof (Elf_External_Phdr))
+ what we computed here. Actually, it's OK if we allocated too
+ much space in the program header. */
+ if (phdr_count > phdr_size / sizeof (Elf_External_Phdr))
abort ();
/* Set up program header information. */
@@ -5855,10 +5856,7 @@ elf_link_output_extsym (h, data)
sym.st_size = h->size;
sym.st_other = 0;
if (h->root.type == bfd_link_hash_weak
- || ((h->elf_link_hash_flags & ELF_LINK_HASH_DEFINED_WEAK) != 0
- && ((h->elf_link_hash_flags & (ELF_LINK_HASH_REF_REGULAR
- | ELF_LINK_HASH_REF_DYNAMIC))
- == 0)))
+ || (h->elf_link_hash_flags & ELF_LINK_HASH_DEFINED_WEAK) != 0)
sym.st_info = ELF_ST_INFO (STB_WEAK, h->type);
else
sym.st_info = ELF_ST_INFO (STB_GLOBAL, h->type);