From 408344017e5c829370ab485a50ca944638a1c84d Mon Sep 17 00:00:00 2001 From: Rafael Espindola Date: Mon, 6 Dec 2010 19:55:05 +0000 Subject: Another use of getSymbolOffset. llvm-svn: 121034 --- llvm/lib/MC/MachObjectWriter.cpp | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) (limited to 'llvm/lib/MC/MachObjectWriter.cpp') diff --git a/llvm/lib/MC/MachObjectWriter.cpp b/llvm/lib/MC/MachObjectWriter.cpp index 60b38dc5211..82e95f5d71a 100644 --- a/llvm/lib/MC/MachObjectWriter.cpp +++ b/llvm/lib/MC/MachObjectWriter.cpp @@ -536,10 +536,14 @@ public: if (A_Base == B_Base && A_Base) report_fatal_error("unsupported relocation with identical base"); - Value += Layout.getSymbolAddress(&A_SD) - - (A_Base == NULL ? 0 : Layout.getSymbolAddress(A_Base)); - Value -= Layout.getSymbolAddress(&B_SD) - - (B_Base == NULL ? 0 : Layout.getSymbolAddress(B_Base)); + assert((A_Base == NULL) == (B_Base == NULL)); + assert(A_SD.getFragment()->getParent() == + B_SD.getFragment()->getParent()); + + Value += Layout.getSymbolOffset(&A_SD) - + (A_Base == NULL ? 0 : Layout.getSymbolOffset(A_Base)); + Value -= Layout.getSymbolOffset(&B_SD) - + (B_Base == NULL ? 0 : Layout.getSymbolOffset(B_Base)); if (A_Base) { Index = A_Base->getIndex(); -- cgit v1.2.3