From: Eric Christopher Date: Fri, 13 Nov 2009 23:00:14 +0000 (+0000) Subject: Print out something, even if it's non-parseable later when we've X-Git-Url: http://plrg.eecs.uci.edu/git/?a=commitdiff_plain;h=04458e404fe418c2ce4dac31ad57018374bc6c00;p=oota-llvm.git Print out something, even if it's non-parseable later when we've got ghost linkage. It's better than aborting. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@88715 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/VMCore/AsmWriter.cpp b/lib/VMCore/AsmWriter.cpp index 9a803a16628..4954522691e 100644 --- a/lib/VMCore/AsmWriter.cpp +++ b/lib/VMCore/AsmWriter.cpp @@ -1497,8 +1497,8 @@ static void PrintLinkage(GlobalValue::LinkageTypes LT, case GlobalValue::AvailableExternallyLinkage: Out << "available_externally "; break; - case GlobalValue::GhostLinkage: - llvm_unreachable("GhostLinkage not allowed in AsmWriter!"); + // This is invalid syntax and just a debugging aid. + case GlobalValue::GhostLinkage: Out << "ghost "; break; } } @@ -1514,6 +1514,11 @@ static void PrintVisibility(GlobalValue::VisibilityTypes Vis, } void AssemblyWriter::printGlobal(const GlobalVariable *GV) { + // If we're going to print a global that has GhostLinkage + // materialize it now. + if (GV->getLinkage() == GlobalValue::GhostLinkage) { + } + WriteAsOperandInternal(Out, GV, &TypePrinter, &Machine); Out << " = ";