Correctly handle two gd relocations to the same symbol.
Fixes PR26676.
llvm-svn: 261561
diff --git a/lld/ELF/Writer.cpp b/lld/ELF/Writer.cpp
index e8fbc2c..8ba203f 100644
--- a/lld/ELF/Writer.cpp
+++ b/lld/ELF/Writer.cpp
@@ -253,12 +253,13 @@
return false;
if (Target->isTlsGlobalDynamicRel(Type)) {
- if (!Target->canRelaxTls(Type, Body) &&
- Out<ELFT>::Got->addDynTlsEntry(Body)) {
- Out<ELFT>::RelaDyn->addReloc(
- {Target->TlsModuleIndexRel, DynamicReloc<ELFT>::Off_GTlsIndex, Body});
- Out<ELFT>::RelaDyn->addReloc(
- {Target->TlsOffsetRel, DynamicReloc<ELFT>::Off_GTlsOffset, Body});
+ if (!Target->canRelaxTls(Type, Body)) {
+ if (Out<ELFT>::Got->addDynTlsEntry(Body)) {
+ Out<ELFT>::RelaDyn->addReloc({Target->TlsModuleIndexRel,
+ DynamicReloc<ELFT>::Off_GTlsIndex, Body});
+ Out<ELFT>::RelaDyn->addReloc(
+ {Target->TlsOffsetRel, DynamicReloc<ELFT>::Off_GTlsOffset, Body});
+ }
return true;
}
if (!canBePreempted(Body, true))