diff options
| author | Eli Friedman <eli.friedman@gmail.com> | 2011-12-03 03:08:40 +0000 |
|---|---|---|
| committer | Eli Friedman <eli.friedman@gmail.com> | 2011-12-03 03:08:40 +0000 |
| commit | 2869b5afe3cc962cfe33f17d44b0615deeeb7a38 (patch) | |
| tree | 3fedfbcfdfd0ea3fe5438e74cd17f8248d46c28d /clang/lib/CodeGen/CGCall.cpp | |
| parent | ef3ad87ac649db1f09c1c337bdb8b5cfb1d0c268 (diff) | |
| download | bcm5719-llvm-2869b5afe3cc962cfe33f17d44b0615deeeb7a38.tar.gz bcm5719-llvm-2869b5afe3cc962cfe33f17d44b0615deeeb7a38.zip | |
Add a utility to get a RValue for a given LValue for an aggregate; switch a few places over to it.
llvm-svn: 145747
Diffstat (limited to 'clang/lib/CodeGen/CGCall.cpp')
| -rw-r--r-- | clang/lib/CodeGen/CGCall.cpp | 7 |
1 files changed, 3 insertions, 4 deletions
diff --git a/clang/lib/CodeGen/CGCall.cpp b/clang/lib/CodeGen/CGCall.cpp index 4f2210f10e4..93bc1753ce8 100644 --- a/clang/lib/CodeGen/CGCall.cpp +++ b/clang/lib/CodeGen/CGCall.cpp @@ -1463,8 +1463,7 @@ void CodeGenFunction::EmitCallArg(CallArgList &args, const Expr *E, cast<CastExpr>(E)->getCastKind() == CK_LValueToRValue) { LValue L = EmitLValue(cast<CastExpr>(E)->getSubExpr()); assert(L.isSimple()); - args.add(RValue::getAggregate(L.getAddress(), L.isVolatileQualified()), - type, /*NeedsCopy*/true); + args.add(L.asAggregateRValue(), type, /*NeedsCopy*/true); return; } @@ -1518,7 +1517,7 @@ void CodeGenFunction::ExpandTypeToArgs(QualType Ty, RValue RV, // FIXME: Volatile? EltRV = RValue::getComplex(LoadComplexFromAddr(LV.getAddress(), false)); else if (CodeGenFunction::hasAggregateLLVMType(EltTy)) - EltRV = RValue::getAggregate(LV.getAddress()); + EltRV = LV.asAggregateRValue(); else EltRV = EmitLoadOfLValue(LV); ExpandTypeToArgs(EltTy, EltRV, Args, IRFuncTy); @@ -1539,7 +1538,7 @@ void CodeGenFunction::ExpandTypeToArgs(QualType Ty, RValue RV, // FIXME: Volatile? FldRV = RValue::getComplex(LoadComplexFromAddr(LV.getAddress(), false)); else if (CodeGenFunction::hasAggregateLLVMType(FT)) - FldRV = RValue::getAggregate(LV.getAddress()); + FldRV = LV.asAggregateRValue(); else FldRV = EmitLoadOfLValue(LV); ExpandTypeToArgs(FT, FldRV, Args, IRFuncTy); |

