[lld] r249353 - Include existing addend when computing R_X86_64_RELATIVE.

Rafael Espindola via llvm-commits llvm-commits at lists.llvm.org
Mon Oct 5 14:09:37 PDT 2015


Author: rafael
Date: Mon Oct  5 16:09:37 2015
New Revision: 249353

URL: http://llvm.org/viewvc/llvm-project?rev=249353&view=rev
Log:
Include existing addend when computing R_X86_64_RELATIVE.

Modified:
    lld/trunk/ELF/OutputSections.cpp
    lld/trunk/ELF/OutputSections.h
    lld/trunk/test/elf2/relative-dynamic-reloc.s

Modified: lld/trunk/ELF/OutputSections.cpp
URL: http://llvm.org/viewvc/llvm-project/lld/trunk/ELF/OutputSections.cpp?rev=249353&r1=249352&r2=249353&view=diff
==============================================================================
--- lld/trunk/ELF/OutputSections.cpp (original)
+++ lld/trunk/ELF/OutputSections.cpp Mon Oct  5 16:09:37 2015
@@ -110,17 +110,23 @@ template <class ELFT> void RelocationSec
                           Target->getGotReloc(), IsMips64EL);
     } else {
       P->r_offset = RI.r_offset + C.getOutputSectionOff() + Out->getVA();
+      uintX_t Addent = 0;
+      if (IsRela)
+        Addent = static_cast<const Elf_Rela &>(RI).r_addend;
+
       if (Body && Body->isShared()) {
         P->setSymbolAndType(Body->getDynamicSymbolTableIndex(), Type,
                             IsMips64EL);
-        if (IsRela)
-          static_cast<Elf_Rela *>(P)->r_addend =
-              static_cast<const Elf_Rela &>(RI).r_addend;
       } else {
         P->setSymbolAndType(0, Target->getRelativeReloc(), IsMips64EL);
-        if (IsRela)
-          static_cast<Elf_Rela *>(P)->r_addend = P->r_offset;
+        if (IsRela) {
+          Addent += C.getOutputSectionOff() + Out->getVA();
+          if (Body)
+            Addent += cast<DefinedRegular<ELFT>>(Body)->Sym.st_value;
+        }
       }
+      if (IsRela)
+        static_cast<Elf_Rela *>(P)->r_addend = Addent;
     }
   }
 }

Modified: lld/trunk/ELF/OutputSections.h
URL: http://llvm.org/viewvc/llvm-project/lld/trunk/ELF/OutputSections.h?rev=249353&r1=249352&r2=249353&view=diff
==============================================================================
--- lld/trunk/ELF/OutputSections.h (original)
+++ lld/trunk/ELF/OutputSections.h Mon Oct  5 16:09:37 2015
@@ -189,6 +189,7 @@ template <class ELFT>
 class RelocationSection final : public OutputSectionBase<ELFT::Is64Bits> {
   typedef typename llvm::object::ELFFile<ELFT>::Elf_Rel Elf_Rel;
   typedef typename llvm::object::ELFFile<ELFT>::Elf_Rela Elf_Rela;
+  typedef typename llvm::object::ELFFile<ELFT>::uintX_t uintX_t;
 
 public:
   RelocationSection(SymbolTableSection<ELFT> &DynSymSec,

Modified: lld/trunk/test/elf2/relative-dynamic-reloc.s
URL: http://llvm.org/viewvc/llvm-project/lld/trunk/test/elf2/relative-dynamic-reloc.s?rev=249353&r1=249352&r2=249353&view=diff
==============================================================================
--- lld/trunk/test/elf2/relative-dynamic-reloc.s (original)
+++ lld/trunk/test/elf2/relative-dynamic-reloc.s Mon Oct  5 16:09:37 2015
@@ -9,6 +9,7 @@
 // CHECK-NEXT:   Section ({{.*}}) .rela.dyn {
 // CHECK-NEXT:     0x[[FOO_ADDR:.*]] R_X86_64_RELATIVE - 0x[[FOO_ADDR]]
 // CHECK-NEXT:     0x[[BAR_ADDR:.*]] R_X86_64_RELATIVE - 0x[[BAR_ADDR]]
+// CHECK-NEXT:     0x2010 R_X86_64_RELATIVE - 0x2009
 // CHECK-NEXT:   }
 // CHECK-NEXT: ]
 
@@ -38,3 +39,4 @@ foo:
         .global bar
 bar:
         .quad bar
+        .quad bar + 1




More information about the llvm-commits mailing list