diff options
author | Mark Mitchell <mark@codesourcery.com> | 2002-07-08 05:34:08 +0000 |
---|---|---|
committer | Mark Mitchell <mark@codesourcery.com> | 2002-07-08 05:34:08 +0000 |
commit | e9168c1e2b14c89a5701688c93d42a6c9ae4bb12 (patch) | |
tree | 95e9ce6d557087cd520e261a83dea14bd2fe336c /bfd/coffcode.h | |
parent | d1e122bd6a4a3280358caa7978abc54034f8e137 (diff) | |
download | gdb-e9168c1e2b14c89a5701688c93d42a6c9ae4bb12.zip gdb-e9168c1e2b14c89a5701688c93d42a6c9ae4bb12.tar.gz gdb-e9168c1e2b14c89a5701688c93d42a6c9ae4bb12.tar.bz2 |
* cofflink.c (_bfd_coff_final_link): On PE COFF systems, take into
account the impact of relocation count overflow when computing
section offsets.
* coffcode.h (coff_write_relocs): Use obj_pe when deciding whether
or not to apply the PE COFF reloc overflow handling. Fix a
fencepost error in deciding whether or not to use that technique.
Diffstat (limited to 'bfd/coffcode.h')
-rw-r--r-- | bfd/coffcode.h | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/bfd/coffcode.h b/bfd/coffcode.h index 6040026..bb777aa 100644 --- a/bfd/coffcode.h +++ b/bfd/coffcode.h @@ -2394,7 +2394,7 @@ coff_write_relocs (abfd, first_undef) return false; #ifdef COFF_WITH_PE - if (s->reloc_count > 0xffff) + if (obj_pe (abfd) && s->reloc_count >= 0xffff) { /* encode real count here as first reloc */ struct internal_reloc n; @@ -3420,7 +3420,7 @@ coff_write_object_contents (abfd) { #ifdef COFF_WITH_PE /* we store the actual reloc count in the first reloc's addr */ - if (current->reloc_count > 0xffff) + if (obj_pe (abfd) && current->reloc_count >= 0xffff) reloc_count ++; #endif reloc_count += current->reloc_count; @@ -3451,7 +3451,7 @@ coff_write_object_contents (abfd) reloc_base += current->reloc_count * bfd_coff_relsz (abfd); #ifdef COFF_WITH_PE /* extra reloc to hold real count */ - if (current->reloc_count > 0xffff) + if (obj_pe (abfd) && current->reloc_count >= 0xffff) reloc_base += bfd_coff_relsz (abfd); #endif } |