summaryrefslogtreecommitdiffstats
path: root/clang/lib/CodeGen/CodeGenModule.cpp
diff options
context:
space:
mode:
authorReid Kleckner <rnk@google.com>2018-03-16 22:20:57 +0000
committerReid Kleckner <rnk@google.com>2018-03-16 22:20:57 +0000
commit281032584d3ca52a97cee0344c0218dd25727d55 (patch)
tree65eba5f62772c3f387eba95d20038d704bff0675 /clang/lib/CodeGen/CodeGenModule.cpp
parentb6073eb6e1f781a61d6d3af17dfc845d4c8b6ac5 (diff)
downloadbcm5719-llvm-281032584d3ca52a97cee0344c0218dd25727d55.tar.gz
bcm5719-llvm-281032584d3ca52a97cee0344c0218dd25727d55.zip
[MS] Fix bug in r327732 with devirtualized complete destructor calls
llvm-svn: 327754
Diffstat (limited to 'clang/lib/CodeGen/CodeGenModule.cpp')
-rw-r--r--clang/lib/CodeGen/CodeGenModule.cpp10
1 files changed, 10 insertions, 0 deletions
diff --git a/clang/lib/CodeGen/CodeGenModule.cpp b/clang/lib/CodeGen/CodeGenModule.cpp
index e221b64d2ec..a47c1c649da 100644
--- a/clang/lib/CodeGen/CodeGenModule.cpp
+++ b/clang/lib/CodeGen/CodeGenModule.cpp
@@ -2550,6 +2550,16 @@ llvm::Constant *CodeGenModule::GetAddrOfFunction(GlobalDecl GD,
Ty = getTypes().ConvertFunctionType(CanonTy, FD);
}
+ // Devirtualized destructor calls may come through here instead of via
+ // getAddrOfCXXStructor. Make sure we use the MS ABI base destructor instead
+ // of the complete destructor when necessary.
+ if (const auto *DD = dyn_cast<CXXDestructorDecl>(GD.getDecl())) {
+ if (getTarget().getCXXABI().isMicrosoft() &&
+ GD.getDtorType() == Dtor_Complete &&
+ DD->getParent()->getNumVBases() == 0)
+ GD = GlobalDecl(DD, Dtor_Base);
+ }
+
StringRef MangledName = getMangledName(GD);
return GetOrCreateLLVMFunction(MangledName, Ty, GD, ForVTable, DontDefer,
/*IsThunk=*/false, llvm::AttributeList(),
OpenPOWER on IntegriCloud