diff options
author | Daniel Dunbar <daniel@zuster.org> | 2010-09-23 01:54:32 +0000 |
---|---|---|
committer | Daniel Dunbar <daniel@zuster.org> | 2010-09-23 01:54:32 +0000 |
commit | f554b1cc3083d9ed1fb9b52a305025f744e90d08 (patch) | |
tree | 9176d77515de0a4448bf447a5bedcb9a98308e46 /lib/CodeGen/TargetInfo.cpp | |
parent | 8aa87c71d9bfec14e135c683b0d7b9de999dbcb0 (diff) |
IRgen/ABI/ARM: Return large vectors in memory.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@114619 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/TargetInfo.cpp')
-rw-r--r-- | lib/CodeGen/TargetInfo.cpp | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/lib/CodeGen/TargetInfo.cpp b/lib/CodeGen/TargetInfo.cpp index f1da3c3903..e8e25ca6d4 100644 --- a/lib/CodeGen/TargetInfo.cpp +++ b/lib/CodeGen/TargetInfo.cpp @@ -2391,6 +2391,10 @@ ABIArgInfo ARMABIInfo::classifyReturnType(QualType RetTy) const { if (RetTy->isVoidType()) return ABIArgInfo::getIgnore(); + // Large vector types should be returned via memory. + if (RetTy->isVectorType() && getContext().getTypeSize(RetTy) > 128) + return ABIArgInfo::getIndirect(0); + if (!isAggregateTypeForABI(RetTy)) { // Treat an enum type as its underlying type. if (const EnumType *EnumTy = RetTy->getAs<EnumType>()) |