diff options
author | Alan Modra <amodra@gmail.com> | 2021-07-30 12:58:12 +0930 |
---|---|---|
committer | Alan Modra <amodra@gmail.com> | 2021-07-30 15:08:55 +0930 |
commit | 5cfe19e51ee06feb191b33a934bcf6cfaaace7b1 (patch) | |
tree | 1a42267c12b11f94e66e1cf5141b4ffd8fae25c5 | |
parent | 472dd8b357e878b09ffa0703ad80b2915aaa4ec6 (diff) | |
download | gdb-5cfe19e51ee06feb191b33a934bcf6cfaaace7b1.zip gdb-5cfe19e51ee06feb191b33a934bcf6cfaaace7b1.tar.gz gdb-5cfe19e51ee06feb191b33a934bcf6cfaaace7b1.tar.bz2 |
reloc_upper_bound size calculations
Section reloc_count is an unsigned int. Adding one for a NULL
terminator to an array of arelent pointers can wrap the count to
zero. Avoid that by doing the addition as longs.
* coffgen.c (coff_get_reloc_upper_bound): Don't overflow unsigned
int expression.
* elf.c (_bfd_elf_get_reloc_upper_bound): Likewise.
* elf64-sparc.c (elf64_sparc_get_reloc_upper_bound): Likewise.
* mach-o.c (bfd_mach_o_get_reloc_upper_bound): Likewise.
* vms-alpha.c (alpha_vms_get_reloc_upper_bound): Likewise.
-rw-r--r-- | bfd/coffgen.c | 2 | ||||
-rw-r--r-- | bfd/elf.c | 2 | ||||
-rw-r--r-- | bfd/elf64-sparc.c | 2 | ||||
-rw-r--r-- | bfd/mach-o.c | 2 | ||||
-rw-r--r-- | bfd/vms-alpha.c | 2 |
5 files changed, 5 insertions, 5 deletions
diff --git a/bfd/coffgen.c b/bfd/coffgen.c index ca93682..77bda9e 100644 --- a/bfd/coffgen.c +++ b/bfd/coffgen.c @@ -1996,7 +1996,7 @@ coff_get_reloc_upper_bound (bfd *abfd, sec_ptr asect) return -1; } #endif - return (asect->reloc_count + 1) * sizeof (arelent *); + return (asect->reloc_count + 1L) * sizeof (arelent *); } asymbol * @@ -8559,7 +8559,7 @@ _bfd_elf_get_reloc_upper_bound (bfd *abfd, sec_ptr asect) return -1; } #endif - return (asect->reloc_count + 1) * sizeof (arelent *); + return (asect->reloc_count + 1L) * sizeof (arelent *); } /* Canonicalize the relocs. */ diff --git a/bfd/elf64-sparc.c b/bfd/elf64-sparc.c index 035ebdd..d43784a 100644 --- a/bfd/elf64-sparc.c +++ b/bfd/elf64-sparc.c @@ -44,7 +44,7 @@ elf64_sparc_get_reloc_upper_bound (bfd *abfd ATTRIBUTE_UNUSED, asection *sec) return -1; } #endif - return (sec->reloc_count * 2 + 1) * sizeof (arelent *); + return (sec->reloc_count * 2L + 1) * sizeof (arelent *); } static long diff --git a/bfd/mach-o.c b/bfd/mach-o.c index ff18ded..a26a68f 100644 --- a/bfd/mach-o.c +++ b/bfd/mach-o.c @@ -1427,7 +1427,7 @@ bfd_mach_o_get_reloc_upper_bound (bfd *abfd ATTRIBUTE_UNUSED, return -1; } #endif - return (asect->reloc_count + 1) * sizeof (arelent *); + return (asect->reloc_count + 1L) * sizeof (arelent *); } /* In addition to the need to byte-swap the symbol number, the bit positions diff --git a/bfd/vms-alpha.c b/bfd/vms-alpha.c index 41cc944..bd49b7a 100644 --- a/bfd/vms-alpha.c +++ b/bfd/vms-alpha.c @@ -5443,7 +5443,7 @@ alpha_vms_get_reloc_upper_bound (bfd *abfd ATTRIBUTE_UNUSED, asection *section) { alpha_vms_slurp_relocs (abfd); - return (section->reloc_count + 1) * sizeof (arelent *); + return (section->reloc_count + 1L) * sizeof (arelent *); } /* Convert relocations from VMS (external) form into BFD internal |