From: Anders Carlsson Date: Mon, 12 Oct 2009 19:51:33 +0000 (+0000) Subject: More devirtualization improvements. X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=cf5deecd7885b544f1197846897513858863e3af;p=clang More devirtualization improvements. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@83883 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/CodeGen/CGCXX.cpp b/lib/CodeGen/CGCXX.cpp index ed7ee4298c..f19067941e 100644 --- a/lib/CodeGen/CGCXX.cpp +++ b/lib/CodeGen/CGCXX.cpp @@ -214,6 +214,10 @@ static bool canDevirtualizeMemberFunctionCalls(const Expr *Base) { if (isa(Base)) return true; + // Check if this is a call expr that returns a record type. + if (const CallExpr *CE = dyn_cast(Base)) + return CE->getCallReturnType()->isRecordType(); + // We can't devirtualize the call. return false; } diff --git a/test/CodeGenCXX/devirtualize-virtual-function-calls.cpp b/test/CodeGenCXX/devirtualize-virtual-function-calls.cpp index 3dd2551bbc..76f9520bfd 100644 --- a/test/CodeGenCXX/devirtualize-virtual-function-calls.cpp +++ b/test/CodeGenCXX/devirtualize-virtual-function-calls.cpp @@ -2,8 +2,12 @@ struct A { virtual void f(); + + A h(); }; +A g(); + void f(A a, A *ap, A& ar) { // This should not be a virtual function call. @@ -18,4 +22,10 @@ void f(A a, A *ap, A& ar) { // CHECK: call void @_ZN1A1fEv A().f(); + + // CHECK: call void @_ZN1A1fEv + g().f(); + + // CHECK: call void @_ZN1A1fEv + a.h().f(); }