From 7c48b06930eef41207b15581cf6a8fe7e95f94ef Mon Sep 17 00:00:00 2001 From: Rafael Espindola Date: Mon, 4 Oct 2010 15:28:43 +0000 Subject: Correctly compute the relocation when it is not in the first fragment. llvm-svn: 115506 --- llvm/lib/MC/ELFObjectWriter.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) (limited to 'llvm/lib/MC/ELFObjectWriter.cpp') diff --git a/llvm/lib/MC/ELFObjectWriter.cpp b/llvm/lib/MC/ELFObjectWriter.cpp index 614e3967130..cc6d51efb0b 100644 --- a/llvm/lib/MC/ELFObjectWriter.cpp +++ b/llvm/lib/MC/ELFObjectWriter.cpp @@ -539,7 +539,7 @@ void ELFObjectWriterImpl::RecordRelocation(const MCAssembler &Asm, const MCSymbol &SymbolB = RefB->getSymbol(); MCSymbolData &SDB = Asm.getSymbolData(SymbolB); IsPCRel = true; - Value += Fixup.getOffset() - Layout.getSymbolAddress(&SDB); + Value += Layout.getFragmentOffset(Fragment) + Fixup.getOffset() - Layout.getSymbolAddress(&SDB); } // Check that this case has already been fully resolved before we get -- cgit v1.2.3