[llvm-objcopy] Fix major layout bugs in llvm-objcopy
authorJake Ehrlich <jakehehrlich@google.com>
Wed, 4 Oct 2017 17:44:42 +0000 (17:44 +0000)
committerJake Ehrlich <jakehehrlich@google.com>
Wed, 4 Oct 2017 17:44:42 +0000 (17:44 +0000)
commit084400bad95254f612c2eb0bbd4a614b01ca2a66
treeda8814e699869778cf4fe33eb2095d15e96eed88
parent68fc036e1d255259adb167e55ad6e680f4b8539c
[llvm-objcopy] Fix major layout bugs in llvm-objcopy

Somehow a few massive errors slipped though the cracks of testing.

1. The code in Segment::finalize was left over from the old layout
algorithm. In certain situations this would cause very strange issues
with segment layout. For instance in the shift-segments.test case it
would cause the second segment to have the same offset as the first.

2. In debugging this I discovered another issue. Namely section alignment
was not being computed based on Section->Align but instead
Section->Offset which is bizarre and makes no sense. I have no clue how
it worked in the first place. This issue is also fixed

3. Fixing #2 exposed a bug where things were not being written past the end
of the file that technically should have been. This was because in
certain cases (like overlapping-segments) the end of the file wouldn't
always be bumped if the offset could be chosen relative to an existing
segment that already had it's offset chosen. For fully nested segments
this is fine but for overlapping segments this leaves the end of the
file short. So I changed how the offset is bumped when looping though
segments.

Differential Revision: https://reviews.llvm.org/D38436

llvm-svn: 314918
llvm/test/tools/llvm-objcopy/segment-shift.test [new file with mode: 0644]
llvm/tools/llvm-objcopy/Object.cpp
llvm/tools/llvm-objcopy/Object.h