diff options
author | John McCall <rjmccall@apple.com> | 2010-11-14 09:40:28 +0000 |
---|---|---|
committer | John McCall <rjmccall@apple.com> | 2010-11-14 09:40:28 +0000 |
commit | 83fe49d1e197ee2ac3ab62d10b9eae65b7f5d9cc (patch) | |
tree | 63a34c57b72077270e445732476fd5d4e4b383a7 /clang/lib/CodeGen/CGExprComplex.cpp | |
parent | d764625448caf3b885b37be6bfa88f93f16cbb3c (diff) | |
download | bcm5719-llvm-83fe49d1e197ee2ac3ab62d10b9eae65b7f5d9cc.tar.gz bcm5719-llvm-83fe49d1e197ee2ac3ab62d10b9eae65b7f5d9cc.zip |
Always emit full loads from volatile complex l-values.
Return the result of a complex assignment with the original values,
not by performing a load from the l-value; this is the correct
semantics in C, although not in C++.
llvm-svn: 119037
Diffstat (limited to 'clang/lib/CodeGen/CGExprComplex.cpp')
-rw-r--r-- | clang/lib/CodeGen/CGExprComplex.cpp | 13 |
1 files changed, 3 insertions, 10 deletions
diff --git a/clang/lib/CodeGen/CGExprComplex.cpp b/clang/lib/CodeGen/CGExprComplex.cpp index ad0786fd9b0..25824260aa4 100644 --- a/clang/lib/CodeGen/CGExprComplex.cpp +++ b/clang/lib/CodeGen/CGExprComplex.cpp @@ -274,15 +274,13 @@ ComplexPairTy ComplexExprEmitter::EmitLoadOfComplex(llvm::Value *SrcPtr, bool isVolatile) { llvm::Value *Real=0, *Imag=0; - // FIXME: we should really not be suppressing volatile loads. - - if (!IgnoreReal) { + if (!IgnoreReal || isVolatile) { llvm::Value *RealP = Builder.CreateStructGEP(SrcPtr, 0, SrcPtr->getName() + ".realp"); Real = Builder.CreateLoad(RealP, isVolatile, SrcPtr->getName() + ".real"); } - if (!IgnoreImag) { + if (!IgnoreImag || isVolatile) { llvm::Value *ImagP = Builder.CreateStructGEP(SrcPtr, 1, SrcPtr->getName() + ".imagp"); Imag = Builder.CreateLoad(ImagP, isVolatile, SrcPtr->getName() + ".imag"); @@ -619,12 +617,7 @@ ComplexPairTy ComplexExprEmitter::VisitBinAssign(const BinaryOperator *E) { IgnoreRealAssign = ignreal; IgnoreImagAssign = ignimag; - // Objective-C property assignment never reloads the value following a store. - if (LHS.isPropertyRef() || LHS.isKVCRef()) - return Val; - - // Otherwise, reload the value. - return EmitLoadOfComplex(LHS.getAddress(), LHS.isVolatileQualified()); + return Val; } ComplexPairTy ComplexExprEmitter::VisitBinComma(const BinaryOperator *E) { |