[llvm-objdump] Fix unstable disassembly output for sections with same address
authorJames Henderson <james.henderson@sony.com>
Tue, 7 Apr 2020 10:51:26 +0000 (11:51 +0100)
committerJames Henderson <james.henderson@sony.com>
Wed, 8 Apr 2020 09:57:12 +0000 (10:57 +0100)
commitabd335a339cb2c5aaf30463ff8451f1eb6e223c7
treed87b18f7ede5a06ebc1b7d28712bd45c37d593f8
parent01d97a35493a8a306bfaa3ceb3e6fa49b05dea89
[llvm-objdump] Fix unstable disassembly output for sections with same address

When two sections shared the same address, the disassembly code was
using pointer values when sorting (see the SectionRef less than
operator). Since those values aren't guaranteed to have a specific
order, this meant the disassembly code would sometimes change which
section to pick when finding symbols targeted by calls in fully linked
objects.

This change fixes the non-determinism, so that the same section is
always picked. This might have a negative impact in that now a section
without any symbol might be picked over a section with symbols, but this
will be addressed in a later commit.

Fixes https://bugs.llvm.org/show_bug.cgi?id=45411.

Reviewed by: grimar, MaskRay

Differential Revision: https://reviews.llvm.org/D77640
llvm/test/tools/llvm-objdump/X86/disassemble-same-section-addr.test [new file with mode: 0644]
llvm/tools/llvm-objdump/llvm-objdump.cpp