diff options
-rw-r--r-- | clang/lib/CodeGen/TargetInfo.cpp | 5 | ||||
-rw-r--r-- | clang/test/CodeGenObjC/arc-i386.m | 43 |
2 files changed, 48 insertions, 0 deletions
diff --git a/clang/lib/CodeGen/TargetInfo.cpp b/clang/lib/CodeGen/TargetInfo.cpp index d4ceb0d3da1..1cfdde38a36 100644 --- a/clang/lib/CodeGen/TargetInfo.cpp +++ b/clang/lib/CodeGen/TargetInfo.cpp @@ -920,6 +920,11 @@ public: ('T' << 24); return llvm::ConstantInt::get(CGM.Int32Ty, Sig); } + + StringRef getARCRetainAutoreleasedReturnValueMarker() const override { + return "movl\t%ebp, %ebp" + "\t\t## marker for objc_retainAutoreleaseReturnValue"; + } }; } diff --git a/clang/test/CodeGenObjC/arc-i386.m b/clang/test/CodeGenObjC/arc-i386.m new file mode 100644 index 00000000000..7693a8f2b6f --- /dev/null +++ b/clang/test/CodeGenObjC/arc-i386.m @@ -0,0 +1,43 @@ +// RUN: %clang_cc1 -triple i386-apple-darwin10 -emit-llvm -fblocks -fobjc-arc -o - %s | FileCheck %s +// RUN: %clang_cc1 -triple i386-apple-iossimulator6.0 -emit-llvm -fblocks -fobjc-arc -o - %s | FileCheck %s + +// <rdar://24531556>: implement objc_retainAutoreleasedReturnValue on i386 + +// CHECK-LABEL: define i8* @test0() +id test0(void) { + extern id test0_helper(void); + // CHECK: [[T0:%.*]] = call i8* @test0_helper() + // CHECK-NEXT: ret i8* [[T0]] + return test0_helper(); +} + +// CHECK-LABEL: define void @test1() +void test1(void) { + extern id test1_helper(void); + // CHECK: [[T0:%.*]] = call i8* @test1_helper() + // CHECK-NEXT: call void asm sideeffect "mov + // CHECK-NEXT: [[T1:%.*]] = call i8* @objc_retainAutoreleasedReturnValue(i8* [[T0]]) + // CHECK-NEXT: store i8* [[T1]], + // CHECK-NEXT: call void @objc_storeStrong( + // CHECK-NEXT: ret void + id x = test1_helper(); +} + +// rdar://problem/12133032 +// CHECK-LABEL: define {{.*}} @test2() +@class A; +A *test2(void) { + extern A *test2_helper(void); + // CHECK: [[T0:%.*]] = call [[A:%.*]]* @test2_helper() + // CHECK-NEXT: ret [[A]]* [[T0]] + return test2_helper(); +} + +// CHECK-LABEL: define i8* @test3() +id test3(void) { + extern A *test3_helper(void); + // CHECK: [[T0:%.*]] = call [[A]]* @test3_helper() + // CHECK-NEXT: [[T1:%.*]] = bitcast [[A]]* [[T0]] to i8* + // CHECK-NEXT: ret i8* [[T1]] + return test3_helper(); +} |