зеркало из https://github.com/microsoft/clang.git
Fixup codegen for __block int i; i += rhs();. Should also slightly
improve codegen in some cases. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@72273 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Родитель
e027a4b239
Коммит
cc0442fa28
|
@ -803,15 +803,16 @@ Value *ScalarExprEmitter::EmitCompoundAssign(const CompoundAssignOperator *E,
|
|||
return llvm::UndefValue::get(CGF.ConvertType(E->getType()));
|
||||
}
|
||||
|
||||
// Emit the RHS first. __block variables need to have the rhs evaluated
|
||||
// first, plus this should improve codegen a little.
|
||||
OpInfo.RHS = Visit(E->getRHS());
|
||||
OpInfo.Ty = E->getComputationResultType();
|
||||
OpInfo.E = E;
|
||||
// Load/convert the LHS.
|
||||
LValue LHSLV = EmitLValue(E->getLHS());
|
||||
OpInfo.LHS = EmitLoadOfLValue(LHSLV, LHSTy);
|
||||
OpInfo.LHS = EmitScalarConversion(OpInfo.LHS, LHSTy,
|
||||
E->getComputationLHSType());
|
||||
// Emit the RHS.
|
||||
OpInfo.RHS = Visit(E->getRHS());
|
||||
OpInfo.Ty = E->getComputationResultType();
|
||||
OpInfo.E = E;
|
||||
|
||||
// Expand the binary operator.
|
||||
Value *Result = (this->*Func)(OpInfo);
|
||||
|
|
|
@ -1,13 +1,18 @@
|
|||
// RUN: clang-cc -fblocks -triple x86_64-apple-darwin10 -emit-llvm -o %t %s &&
|
||||
// RUN: grep '%call = call i32 (...)\* @rhs()' %t | count 1 &&
|
||||
// If this fails, see about sliding %4 and %5...
|
||||
// If this fails, see about sliding %4, %5, %6 and %7...
|
||||
// RUN: grep '%forwarding1 = getelementptr %0\* %i, i32 0, i32 1' %t | count 1 &&
|
||||
// RUN: grep '%4 = bitcast i8\*\* %forwarding1 to %0\*\*' %t | count 1 &&
|
||||
// RUN: grep '%5 = load %0\*\* %4' %t | count 1
|
||||
// RUN: grep '%5 = load %0\*\* %4' %t | count 1 &&
|
||||
// RUN: grep '%call2 = call i32 (...)\* @rhs()' %t | count 1 &&
|
||||
// RUN: grep '%forwarding3 = getelementptr %0\* %i, i32 0, i32 1' %t | count 1 &&
|
||||
// RUN: grep '%6 = bitcast i8\*\* %forwarding3 to %0\*\*' %t | count 1 &&
|
||||
// RUN: grep '%7 = load %0\*\* %6' %t | count 1
|
||||
|
||||
int rhs();
|
||||
|
||||
void foo() {
|
||||
__block int i;
|
||||
i = rhs();
|
||||
i += rhs();
|
||||
}
|
||||
|
|
Загрузка…
Ссылка в новой задаче