diff options
author | Alan Modra <amodra@gmail.com> | 2020-03-16 19:34:00 +1030 |
---|---|---|
committer | Alan Modra <amodra@gmail.com> | 2020-03-16 19:35:12 +1030 |
commit | 4b3ecb3b91b1b6154a6444efdcbadb90854a6654 (patch) | |
tree | 9949842cb26ed8573ddb283fa8eff87be76058fd /bfd/elf.c | |
parent | 28d1356774c2c61adc7d6e6723de2351cd9f4ddc (diff) | |
download | gdb-4b3ecb3b91b1b6154a6444efdcbadb90854a6654.zip gdb-4b3ecb3b91b1b6154a6444efdcbadb90854a6654.tar.gz gdb-4b3ecb3b91b1b6154a6444efdcbadb90854a6654.tar.bz2 |
PR25675: SIGSEGV in bfd_octets_per_byte
PR 25675
* elf.c (elf_sort_segments): Don't call bfd_octets_per_byte unless
we have a non-zero section count. Do lma comparison in octets.
Diffstat (limited to 'bfd/elf.c')
-rw-r--r-- | bfd/elf.c | 20 |
1 files changed, 13 insertions, 7 deletions
@@ -5312,19 +5312,25 @@ elf_sort_segments (const void *arg1, const void *arg2) return m1->no_sort_lma ? -1 : 1; if (m1->p_type == PT_LOAD && !m1->no_sort_lma) { - unsigned int opb = bfd_octets_per_byte (m1->sections[0]->owner, - m1->sections[0]); - bfd_vma lma1, lma2; /* Bytes. */ + bfd_vma lma1, lma2; /* Octets. */ lma1 = 0; if (m1->p_paddr_valid) - lma1 = m1->p_paddr / opb; + lma1 = m1->p_paddr; else if (m1->count != 0) - lma1 = m1->sections[0]->lma + m1->p_vaddr_offset; + { + unsigned int opb = bfd_octets_per_byte (m1->sections[0]->owner, + m1->sections[0]); + lma1 = (m1->sections[0]->lma + m1->p_vaddr_offset) * opb; + } lma2 = 0; if (m2->p_paddr_valid) - lma2 = m2->p_paddr / opb; + lma2 = m2->p_paddr; else if (m2->count != 0) - lma2 = m2->sections[0]->lma + m2->p_vaddr_offset; + { + unsigned int opb = bfd_octets_per_byte (m2->sections[0]->owner, + m2->sections[0]); + lma2 = (m2->sections[0]->lma + m2->p_vaddr_offset) * opb; + } if (lma1 != lma2) return lma1 < lma2 ? -1 : 1; } |