Don't apply a recolation that the dynamic linker will rewrite.
authorRafael Espindola <rafael.espindola@gmail.com>
Fri, 1 Apr 2016 16:21:09 +0000 (16:21 +0000)
committerRafael Espindola <rafael.espindola@gmail.com>
Fri, 1 Apr 2016 16:21:09 +0000 (16:21 +0000)
This matches the behavior of both bfd and gold. Looks like we just got
here for mips because of a bad ordering of an if else chain.

llvm-svn: 265147

lld/ELF/InputSection.cpp
lld/test/ELF/mips-32.s

index b5448ac..21cd720 100644 (file)
@@ -316,11 +316,11 @@ void InputSectionBase<ELFT>::relocate(uint8_t *Buf, uint8_t *BufEnd,
     } else if (Target->needsThunk(Type, *this->getFile(), Body)) {
       // Get address of a thunk code related to the symbol.
       SymVA = Body.getThunkVA<ELFT>();
-    } else if (Config->EMachine == EM_MIPS) {
-      SymVA = adjustMipsSymVA<ELFT>(Type, *File, Body, AddrLoc, SymVA);
     } else if (!Target->needsCopyRel<ELFT>(Type, Body) &&
                Body.isPreemptible()) {
       continue;
+    } else if (Config->EMachine == EM_MIPS) {
+      SymVA = adjustMipsSymVA<ELFT>(Type, *File, Body, AddrLoc, SymVA);
     }
     if (Target->isSizeRel(Type))
       SymVA = Body.getSize<ELFT>() + A;
index 918d00d..5cfd556 100644 (file)
@@ -32,11 +32,11 @@ v2:
   .word v1   # R_MIPS_32 target v1 addend 0
 
 # BE: Contents of section .data:
-# BE-NEXT: 30000 00000000 00030008 00030000
+# BE-NEXT: 30000 00000000 00000004 00030000
 #                         ^-- v2+4 ^-- v1
 
 # EL: Contents of section .data:
-# EL-NEXT: 30000 00000000 08000300 00000300
+# EL-NEXT: 30000 00000000 04000000 00000300
 #                         ^-- v2+4 ^-- v1
 
 # SYM: SYMBOL TABLE: