From 553f3a9b300fa709379ee77e0ae698b26350a964 Mon Sep 17 00:00:00 2001 From: Douglas Gregor Date: Mon, 12 Jul 2010 21:08:32 +0000 Subject: Speculatively revert r108156; it appears to be breaking self-host. llvm-svn: 108194 --- clang/lib/CodeGen/CodeGenModule.cpp | 18 +++++------------- 1 file changed, 5 insertions(+), 13 deletions(-) (limited to 'clang/lib/CodeGen/CodeGenModule.cpp') diff --git a/clang/lib/CodeGen/CodeGenModule.cpp b/clang/lib/CodeGen/CodeGenModule.cpp index d544d4c..cb83ffd 100644 --- a/clang/lib/CodeGen/CodeGenModule.cpp +++ b/clang/lib/CodeGen/CodeGenModule.cpp @@ -817,22 +817,14 @@ void CodeGenModule::EmitGlobalDefinition(GlobalDecl GD) { if (Method->isVirtual()) getVTables().EmitThunks(GD); - if (const FunctionDecl *Function = dyn_cast(D)) { - // At -O0, don't generate IR for functions with available_externally - // linkage. - if (CodeGenOpts.OptimizationLevel == 0 && - getFunctionLinkage(Function) - == llvm::Function::AvailableExternallyLinkage) - return; - - if (const CXXConstructorDecl *CD = dyn_cast(Function)) - return EmitCXXConstructor(CD, GD.getCtorType()); + if (const CXXConstructorDecl *CD = dyn_cast(D)) + return EmitCXXConstructor(CD, GD.getCtorType()); - if (const CXXDestructorDecl *DD = dyn_cast(Function)) - return EmitCXXDestructor(DD, GD.getDtorType()); + if (const CXXDestructorDecl *DD = dyn_cast(D)) + return EmitCXXDestructor(DD, GD.getDtorType()); + if (isa(D)) return EmitGlobalFunctionDefinition(GD); - } if (const VarDecl *VD = dyn_cast(D)) return EmitGlobalVarDefinition(VD); -- cgit v1.1