Disable the available_externally optimization for inline virtual
methods for which the key function is guaranteed to be in another translation unit. Unfortunately, this guarantee isn't the case when dealing with shared libraries that fail to export these virtual method definitions. I'm reopening PR6747 so we can consider this again at a later point in time. llvm-svn: 103741
This commit is contained in:
@@ -316,17 +316,6 @@ GetLinkageForFunction(ASTContext &Context, const FunctionDecl *FD,
|
||||
== TSK_ExplicitInstantiationDeclaration)
|
||||
return CodeGenModule::GVA_C99Inline;
|
||||
|
||||
// If this is a virtual method and its class has a key method in another
|
||||
// translation unit, we know that this method will be present in that
|
||||
// translation unit. In this translation unit we will use this method
|
||||
// only for inlining and analysis. This is the semantics of c99 inline.
|
||||
if (const CXXMethodDecl *MD = dyn_cast<CXXMethodDecl>(FD)) {
|
||||
const CXXRecordDecl *RD = MD->getParent();
|
||||
if (MD->isVirtual() && !MD->isImplicit() &&
|
||||
CodeGenVTables::isKeyFunctionInAnotherTU(Context, RD))
|
||||
return CodeGenModule::GVA_C99Inline;
|
||||
}
|
||||
|
||||
return CodeGenModule::GVA_CXXInline;
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user