[RuntimeDyld] Fix MachO i386 SECTDIFF relocation to support non-zero addends.

Previously, relocations of the form 'A - B + C' would fail on i386 when C was
non-zero.



git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@238356 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Lang Hames 2015-05-27 20:50:01 +00:00
parent deae59fceb
commit 8cc212a07e
2 changed files with 7 additions and 8 deletions

View File

@ -167,20 +167,19 @@ private:
uint32_t SectionBID = uint32_t SectionBID =
findOrEmitSection(Obj, SectionB, IsCode, ObjSectionToID); findOrEmitSection(Obj, SectionB, IsCode, ObjSectionToID);
if (Addend != AddrA - AddrB) // Compute the addend 'C' from the original expression 'A - B + C'.
Error("Unexpected SECTDIFF relocation addend."); Addend -= AddrA - AddrB;
DEBUG(dbgs() << "Found SECTDIFF: AddrA: " << AddrA << ", AddrB: " << AddrB DEBUG(dbgs() << "Found SECTDIFF: AddrA: " << AddrA << ", AddrB: " << AddrB
<< ", Addend: " << Addend << ", SectionA ID: " << SectionAID << ", Addend: " << Addend << ", SectionA ID: " << SectionAID
<< ", SectionAOffset: " << SectionAOffset << ", SectionAOffset: " << SectionAOffset
<< ", SectionB ID: " << SectionBID << ", SectionB ID: " << SectionBID
<< ", SectionBOffset: " << SectionBOffset << "\n"); << ", SectionBOffset: " << SectionBOffset << "\n");
RelocationEntry R(SectionID, Offset, RelocType, 0, SectionAID, RelocationEntry R(SectionID, Offset, RelocType, Addend, SectionAID,
SectionAOffset, SectionBID, SectionBOffset, IsPCRel, SectionAOffset, SectionBID, SectionBOffset,
Size); IsPCRel, Size);
addRelocationForSection(R, SectionAID); addRelocationForSection(R, SectionAID);
addRelocationForSection(R, SectionBID);
return ++RelI; return ++RelI;
} }

View File

@ -9,9 +9,9 @@ bar:
tmp0$pb: tmp0$pb:
popl %eax popl %eax
# Test section difference relocation to non-lazy ptr section. # Test section difference relocation to non-lazy ptr section.
# rtdyld-check: decode_operand(inst1, 4) = x$non_lazy_ptr - tmp0$pb # rtdyld-check: decode_operand(inst1, 4) = x$non_lazy_ptr - tmp0$pb + 8
inst1: inst1:
movl x$non_lazy_ptr-tmp0$pb(%eax), %eax movl (x$non_lazy_ptr-tmp0$pb)+8(%eax), %eax
movl (%eax), %ebx movl (%eax), %ebx
# Test VANILLA relocation to jump table. # Test VANILLA relocation to jump table.