summaryrefslogtreecommitdiffstats
path: root/clang
diff options
context:
space:
mode:
authorRafael Espindola <rafael.espindola@gmail.com>2012-06-26 19:18:25 +0000
committerRafael Espindola <rafael.espindola@gmail.com>2012-06-26 19:18:25 +0000
commit727a771a5f8492665817729a84a8bc83d21f37c5 (patch)
treea4a26a18838918591d79e3fe0f52f650fefe7102 /clang
parent47e4518117bb2aaf5a442037c8a4f9de962dbfa6 (diff)
downloadbcm5719-llvm-727a771a5f8492665817729a84a8bc83d21f37c5.tar.gz
bcm5719-llvm-727a771a5f8492665817729a84a8bc83d21f37c5.zip
Fix a bug in my previous patch: If we are not doing a virtual call because
the member expression is qualified, call the method specified in the code, not the most derived one we can find. llvm-svn: 159219
Diffstat (limited to 'clang')
-rw-r--r--clang/lib/CodeGen/CGExprCXX.cpp4
-rw-r--r--clang/test/CodeGenCXX/devirtualize-virtual-function-calls.cpp18
2 files changed, 22 insertions, 0 deletions
diff --git a/clang/lib/CodeGen/CGExprCXX.cpp b/clang/lib/CodeGen/CGExprCXX.cpp
index f35287d5406..372eb5407c9 100644
--- a/clang/lib/CodeGen/CGExprCXX.cpp
+++ b/clang/lib/CodeGen/CGExprCXX.cpp
@@ -240,6 +240,8 @@ RValue CodeGenFunction::EmitCXXMemberCallExpr(const CXXMemberCallExpr *CE,
MD->isVirtual() &&
ME->hasQualifier())
Callee = BuildAppleKextVirtualCall(MD, ME->getQualifier(), Ty);
+ else if (ME->hasQualifier())
+ Callee = CGM.GetAddrOfFunction(GlobalDecl(Dtor, Dtor_Complete), Ty);
else {
const CXXMethodDecl *DM =
Dtor->getCorrespondingMethodInClass(MostDerivedClassDecl);
@@ -258,6 +260,8 @@ RValue CodeGenFunction::EmitCXXMemberCallExpr(const CXXMemberCallExpr *CE,
MD->isVirtual() &&
ME->hasQualifier())
Callee = BuildAppleKextVirtualCall(MD, ME->getQualifier(), Ty);
+ else if (ME->hasQualifier())
+ Callee = CGM.GetAddrOfFunction(MD, Ty);
else {
const CXXMethodDecl *DerivedMethod =
MD->getCorrespondingMethodInClass(MostDerivedClassDecl);
diff --git a/clang/test/CodeGenCXX/devirtualize-virtual-function-calls.cpp b/clang/test/CodeGenCXX/devirtualize-virtual-function-calls.cpp
index 5eede66cd7b..a0b6e8c6bda 100644
--- a/clang/test/CodeGenCXX/devirtualize-virtual-function-calls.cpp
+++ b/clang/test/CodeGenCXX/devirtualize-virtual-function-calls.cpp
@@ -53,3 +53,21 @@ void f() {
B().h().f();
}
+namespace test2 {
+ struct foo {
+ virtual void f();
+ virtual ~foo();
+ };
+
+ struct bar : public foo {
+ virtual void f();
+ virtual ~bar();
+ };
+
+ void f(bar *b) {
+ // CHECK: call void @_ZN5test23foo1fEv
+ // CHECK: call void @_ZN5test23fooD1Ev
+ b->foo::f();
+ b->foo::~foo();
+ }
+}
OpenPOWER on IntegriCloud