diff options
author | Daniel Dunbar <daniel@zuster.org> | 2010-05-15 00:00:30 +0000 |
---|---|---|
committer | Daniel Dunbar <daniel@zuster.org> | 2010-05-15 00:00:30 +0000 |
commit | 7711523d948bbe635f690f5795ef7ea9a3289eb2 (patch) | |
tree | 437ab26aca60009037faa684379754cc697e628a | |
parent | f0229d884da7974f40f558e8cb0b11939017fe43 (diff) |
C++/ABI/i386: Member function pointers should be passed by value.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@103842 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | lib/CodeGen/TargetInfo.cpp | 5 | ||||
-rw-r--r-- | test/CodeGenCXX/x86_32-arguments.cpp | 9 |
2 files changed, 12 insertions, 2 deletions
diff --git a/lib/CodeGen/TargetInfo.cpp b/lib/CodeGen/TargetInfo.cpp index 09baf2e833..176a7432b0 100644 --- a/lib/CodeGen/TargetInfo.cpp +++ b/lib/CodeGen/TargetInfo.cpp @@ -387,10 +387,11 @@ bool X86_32ABIInfo::shouldReturnTypeInRegister(QualType Ty, return true; } - // If this is a builtin, pointer, enum, or complex type, it is ok. + // If this is a builtin, pointer, enum, complex type, member pointer, or + // member function pointer it is ok. if (Ty->getAs<BuiltinType>() || Ty->hasPointerRepresentation() || Ty->isAnyComplexType() || Ty->isEnumeralType() || - Ty->isBlockPointerType()) + Ty->isBlockPointerType() || Ty->isMemberPointerType()) return true; // Arrays are treated like records. diff --git a/test/CodeGenCXX/x86_32-arguments.cpp b/test/CodeGenCXX/x86_32-arguments.cpp index a92ba78b9f..033779d028 100644 --- a/test/CodeGenCXX/x86_32-arguments.cpp +++ b/test/CodeGenCXX/x86_32-arguments.cpp @@ -87,3 +87,12 @@ s4_2 f4() { return s4_2(); } // CHECK: define i32 @_Z2f5v() struct s5 { s5(); int &x; }; s5 f5() { return s5(); } + +// CHECK: define i32 @_Z4f6_0M2s6i(i32 %a) +// CHECK: define i64 @_Z4f6_1M2s6FivE(%{{.*}} byval %a) +// FIXME: It would be nice to avoid byval on the previous case. +struct s6 {}; +typedef int s6::* s6_mdp; +typedef int (s6::*s6_mfp)(); +s6_mdp f6_0(s6_mdp a) { return a; } +s6_mfp f6_1(s6_mfp a) { return a; } |