aboutsummaryrefslogtreecommitdiff
path: root/lib/CodeGen/CGExpr.cpp
diff options
context:
space:
mode:
authorAnton Korobeynikov <asl@math.spbu.ru>2012-04-13 11:22:00 +0000
committerAnton Korobeynikov <asl@math.spbu.ru>2012-04-13 11:22:00 +0000
commiteaf856db5d1a272dc7188937206ef4572836f82a (patch)
treeea360d29807f197c529a7105dad5ece443fca2ae /lib/CodeGen/CGExpr.cpp
parent51b92401c9f95023a2ef27064fd5a60fd99175f5 (diff)
Step forward with supporting of ARM homogenous aggregates:
- Handle unions - Handle C++ classes git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@154664 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/CGExpr.cpp')
-rw-r--r--lib/CodeGen/CGExpr.cpp13
1 files changed, 13 insertions, 0 deletions
diff --git a/lib/CodeGen/CGExpr.cpp b/lib/CodeGen/CGExpr.cpp
index 08970fd738..a7f5c47bbc 100644
--- a/lib/CodeGen/CGExpr.cpp
+++ b/lib/CodeGen/CGExpr.cpp
@@ -2378,6 +2378,19 @@ LValue CodeGenFunction::EmitMaterializeTemporaryExpr(
return MakeAddrLValue(RV.getScalarVal(), E->getType());
}
+RValue CodeGenFunction::EmitRValueForField(llvm::Value *Addr,
+ const FieldDecl *FD) {
+ QualType FT = FD->getType();
+ // FIXME: What are the right qualifiers here?
+ LValue LV = EmitLValueForField(Addr, FD, 0);
+ if (FT->isAnyComplexType())
+ // FIXME: Volatile?
+ return RValue::getComplex(LoadComplexFromAddr(LV.getAddress(), false));
+ else if (CodeGenFunction::hasAggregateLLVMType(FT))
+ return LV.asAggregateRValue();
+
+ return EmitLoadOfLValue(LV);
+}
//===--------------------------------------------------------------------===//
// Expression Emission