diff options
| author | Anders Carlsson <andersca@mac.com> | 2008-11-25 22:21:48 +0000 |
|---|---|---|
| committer | Anders Carlsson <andersca@mac.com> | 2008-11-25 22:21:48 +0000 |
| commit | 32ef8ceaa1d2c71634ca42a7be2499e2088f9758 (patch) | |
| tree | 61866e609cd3d4a2ea57bfa1ae44f23cf199b77c /clang/lib | |
| parent | 511ed555245c79149ebe61a3a6f20d0350c7f9ad (diff) | |
| download | bcm5719-llvm-32ef8ceaa1d2c71634ca42a7be2499e2088f9758.tar.gz bcm5719-llvm-32ef8ceaa1d2c71634ca42a7be2499e2088f9758.zip | |
Handle returning complex types that get coerced. Fixes PR3131
llvm-svn: 60058
Diffstat (limited to 'clang/lib')
| -rw-r--r-- | clang/lib/CodeGen/CGCall.cpp | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/clang/lib/CodeGen/CGCall.cpp b/clang/lib/CodeGen/CGCall.cpp index 1fc4143d60a..220586db589 100644 --- a/clang/lib/CodeGen/CGCall.cpp +++ b/clang/lib/CodeGen/CGCall.cpp @@ -868,7 +868,10 @@ RValue CodeGenFunction::EmitCall(llvm::Value *Callee, llvm::PointerType::getUnqual(RetAI.getCoerceToType()); llvm::Value *V = CreateTempAlloca(ConvertType(RetTy), "tmp"); Builder.CreateStore(CI, Builder.CreateBitCast(V, CoerceToPTy)); - return RValue::getAggregate(V); + if (RetTy->isAnyComplexType()) + return RValue::getComplex(LoadComplexFromAddr(V, false)); + else + return RValue::getAggregate(V); } case ABIArgInfo::ByVal: |

