diff --git a/llvm/lib/Target/TargetMachine.cpp b/llvm/lib/Target/TargetMachine.cpp --- a/llvm/lib/Target/TargetMachine.cpp +++ b/llvm/lib/Target/TargetMachine.cpp @@ -101,15 +101,11 @@ // dso_preemptable. At this point in time, the various IR producers // have not been transitioned to always produce a dso_local when it // is possible to do so. - // In the case of ExternalSymbolSDNode, GV is null and we should just return - // false. However, COFF currently relies on this to be true // // As a result we still have some logic in here to improve the quality of the // generated code. - // FIXME: Add a module level metadata for whether intrinsics should be assumed - // local. if (!GV) - return TT.isOSBinFormatCOFF(); + return false; // If the IR producer requested that this GV be treated as dso local, obey. if (GV->isDSOLocal()) diff --git a/llvm/lib/Target/X86/X86Subtarget.cpp b/llvm/lib/Target/X86/X86Subtarget.cpp --- a/llvm/lib/Target/X86/X86Subtarget.cpp +++ b/llvm/lib/Target/X86/X86Subtarget.cpp @@ -143,6 +143,9 @@ return classifyLocalReference(GV); if (isTargetCOFF()) { + // ExternalSymbolSDNode like _tls_index. + if (!GV) + return X86II::MO_NO_FLAG; if (GV->hasDLLImportStorageClass()) return X86II::MO_DLLIMPORT; return X86II::MO_COFFSTUB; @@ -184,10 +187,13 @@ if (TM.shouldAssumeDSOLocal(M, GV)) return X86II::MO_NO_FLAG; - // Functions on COFF can be non-DSO local for two reasons: + // Functions on COFF can be non-DSO local for three reasons: + // - They are intrinsic functions (!GV) // - They are marked dllimport // - They are extern_weak, and a stub is needed if (isTargetCOFF()) { + if (!GV) + return X86II::MO_NO_FLAG; if (GV->hasDLLImportStorageClass()) return X86II::MO_DLLIMPORT; return X86II::MO_COFFSTUB;