From eb3804e39a76a267f13e72a00695f5b18c75b932 Mon Sep 17 00:00:00 2001 From: Daniel Dunbar Date: Wed, 17 Feb 2010 23:45:16 +0000 Subject: [PATCH] MC/Mach-O: Update fixup values for change to X86 offsets. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@96532 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/MC/MCAssembler.cpp | 10 ++++------ 1 file changed, 4 insertions(+), 6 deletions(-) diff --git a/lib/MC/MCAssembler.cpp b/lib/MC/MCAssembler.cpp index 26bd9eb7830..528c5c025d5 100644 --- a/lib/MC/MCAssembler.cpp +++ b/lib/MC/MCAssembler.cpp @@ -439,6 +439,7 @@ public: std::vector &Relocs) { uint32_t Address = Fragment.getOffset() + Fixup.Offset; unsigned IsPCRel = 0; + unsigned Log2Size = getFixupKindLog2Size(Fixup.Kind); unsigned Type = RIT_Vanilla; // See . @@ -454,12 +455,10 @@ public: Value2 = SD->getFragment()->getAddress() + SD->getOffset(); } - unsigned Log2Size = getFixupKindLog2Size(Fixup.Kind); - // The value which goes in the fixup is current value of the expression. Fixup.FixedValue = Value - Value2 + Target.getConstant(); if (isFixupKindPCRel(Fixup.Kind)) { - Fixup.FixedValue -= Address + (1 << Log2Size); + Fixup.FixedValue -= Address; IsPCRel = 1; } @@ -507,6 +506,7 @@ public: uint32_t Value = 0; unsigned Index = 0; unsigned IsPCRel = 0; + unsigned Log2Size = getFixupKindLog2Size(Fixup.Kind); unsigned IsExtern = 0; unsigned Type = 0; @@ -544,10 +544,8 @@ public: // The value which goes in the fixup is current value of the expression. Fixup.FixedValue = Value + Target.getConstant(); - unsigned Log2Size = getFixupKindLog2Size(Fixup.Kind); - if (isFixupKindPCRel(Fixup.Kind)) { - Fixup.FixedValue -= Address + (1<