diff options
| author | Fariborz Jahanian <fjahanian@apple.com> | 2010-03-25 21:56:43 +0000 |
|---|---|---|
| committer | Fariborz Jahanian <fjahanian@apple.com> | 2010-03-25 21:56:43 +0000 |
| commit | f9c4585c807d6f988d9a604d46c1f0967b60cea6 (patch) | |
| tree | 33ddc43393adfb0e9c5077ae7b1477ea29fb571c /clang | |
| parent | 91d27744161ac6cde44020f43a00bcc0ce36c27a (diff) | |
| download | bcm5719-llvm-f9c4585c807d6f988d9a604d46c1f0967b60cea6.tar.gz bcm5719-llvm-f9c4585c807d6f988d9a604d46c1f0967b60cea6.zip | |
Fix a code gen. bug involving generation of getter method
from properties of _Complex type. (radar 7351147).
llvm-svn: 99558
Diffstat (limited to 'clang')
| -rw-r--r-- | clang/lib/CodeGen/CGObjC.cpp | 7 | ||||
| -rw-r--r-- | clang/test/CodeGenObjC/complex-property.m | 17 |
2 files changed, 22 insertions, 2 deletions
diff --git a/clang/lib/CodeGen/CGObjC.cpp b/clang/lib/CodeGen/CGObjC.cpp index 3ff77f0170c..f40b3d705d2 100644 --- a/clang/lib/CodeGen/CGObjC.cpp +++ b/clang/lib/CodeGen/CGObjC.cpp @@ -201,7 +201,12 @@ void CodeGenFunction::GenerateObjCGetter(ObjCImplementationDecl *IMP, EmitReturnOfRValue(RV, PD->getType()); } else { LValue LV = EmitLValueForIvar(TypeOfSelfObject(), LoadObjCSelf(), Ivar, 0); - if (hasAggregateLLVMType(Ivar->getType())) { + if (Ivar->getType()->isAnyComplexType()) { + ComplexPairTy Pair = LoadComplexFromAddr(LV.getAddress(), + LV.isVolatileQualified()); + StoreComplexToAddr(Pair, ReturnValue, LV.isVolatileQualified()); + } + else if (hasAggregateLLVMType(Ivar->getType())) { EmitAggregateCopy(ReturnValue, LV.getAddress(), Ivar->getType()); } else { CodeGenTypes &Types = CGM.getTypes(); diff --git a/clang/test/CodeGenObjC/complex-property.m b/clang/test/CodeGenObjC/complex-property.m index bd3bfea94b5..5a2b78b5977 100644 --- a/clang/test/CodeGenObjC/complex-property.m +++ b/clang/test/CodeGenObjC/complex-property.m @@ -1,4 +1,4 @@ -// RUN: %clang_cc1 -triple x86_64-apple-darwin10 -emit-llvm -o - %s | FileCheck -check-prefix LP64 %s +// RUN: %clang_cc1 -triple x86_64-apple-darwin10 -fobjc-nonfragile-abi -emit-llvm -o - %s | FileCheck -check-prefix LP64 %s // rdar: // 7351147 @interface A @@ -15,3 +15,18 @@ void f0(A *a) { // CHECK-LP64: internal global [13 x i8] c"COMPLEX_PROP // CHECK-LP64: internal global [17 x i8] c"setCOMPLEX_PROP + +// rdar: // 7351147 +@interface B +@property (assign) _Complex float f_complex_ivar; +@end + +@implementation B + +@synthesize f_complex_ivar = _f_complex_ivar; +-(void) unary_f_complex: (_Complex float) a0 { + self.f_complex_ivar = a0; +} + +@end + |

