diff options
Diffstat (limited to 'llvm/test/Bitcode')
| -rw-r--r-- | llvm/test/Bitcode/upgrade-arc-runtime-calls.bc | bin | 3040 -> 2896 bytes | |||
| -rw-r--r-- | llvm/test/Bitcode/upgrade-arc-runtime-calls.ll | 60 | ||||
| -rw-r--r-- | llvm/test/Bitcode/upgrade-mrr-runtime-calls.bc | bin | 2880 -> 2720 bytes |
3 files changed, 6 insertions, 54 deletions
diff --git a/llvm/test/Bitcode/upgrade-arc-runtime-calls.bc b/llvm/test/Bitcode/upgrade-arc-runtime-calls.bc Binary files differindex 35c78004a95..5fedabb8904 100644 --- a/llvm/test/Bitcode/upgrade-arc-runtime-calls.bc +++ b/llvm/test/Bitcode/upgrade-arc-runtime-calls.bc diff --git a/llvm/test/Bitcode/upgrade-arc-runtime-calls.ll b/llvm/test/Bitcode/upgrade-arc-runtime-calls.ll index dbccff2a5b0..512443b0411 100644 --- a/llvm/test/Bitcode/upgrade-arc-runtime-calls.ll +++ b/llvm/test/Bitcode/upgrade-arc-runtime-calls.ll @@ -8,62 +8,14 @@ ; RUN: llvm-dis < %S/upgrade-arc-runtime-calls.bc | FileCheck -check-prefixes=ARC %s ; RUN: llvm-dis < %S/upgrade-mrr-runtime-calls.bc | FileCheck -check-prefixes=MRR %s -define void @testRuntimeCalls(i8* %a, i8** %b, i8** %c, i32* %d, i32** %e) personality i32 (...)* @__gxx_personality_v0 { -entry: - %v0 = tail call i8* @objc_autorelease(i8* %a) #0 - tail call void @objc_autoreleasePoolPop(i8* %a) #0 - %v1 = tail call i8* @objc_autoreleasePoolPush() #0 - %v2 = tail call i8* @objc_autoreleaseReturnValue(i8* %a) #0 - tail call void @objc_copyWeak(i8** %b, i8** %c) #0 - tail call void @objc_destroyWeak(i8** %b) #0 - %v3 = tail call i32* @objc_initWeak(i32** %e, i32* %d) #0 - %v4 = tail call i8* @objc_loadWeak(i8** %b) #0 - %v5 = tail call i8* @objc_loadWeakRetained(i8** %b) #0 - tail call void @objc_moveWeak(i8** %b, i8** %c) #0 - tail call void @objc_release(i8* %a) #0 - %v6 = tail call i8* @objc_retain(i8* %a) #0 - %v7 = tail call i8* @objc_retainAutorelease(i8* %a) #0 - %v8 = tail call i8* @objc_retainAutoreleaseReturnValue(i8* %a) #0 - %v9 = tail call i8* @objc_retainAutoreleasedReturnValue(i8* %a) #0 - %v10 = tail call i8* @objc_retainBlock(i8* %a) #0 - tail call void @objc_storeStrong(i8** %b, i8* %a) #0 - %v11 = tail call i8* @objc_storeWeak(i8** %b, i8* %a) #0 - tail call void (...) @clang.arc.use(i8* %a) #0 - %v12 = tail call i8* @objc_unsafeClaimAutoreleasedReturnValue(i8* %a) #0 - %v13 = tail call i8* @objc_retainedObject(i8* %a) #0 - %v14 = tail call i8* @objc_unretainedObject(i8* %a) #0 - %v15 = tail call i8* @objc_unretainedPointer(i8* %a) #0 - %v16 = tail call i8* @objc_retain.autorelease(i8* %a) #0 - %v17 = tail call i32 @objc_sync.enter(i8* %a) #0 - %v18 = tail call i32 @objc_sync.exit(i8* %a) #0 - tail call void @objc_arc_annotation_topdown_bbstart(i8** %b, i8** %c) #0 - tail call void @objc_arc_annotation_topdown_bbend(i8** %b, i8** %c) #0 - tail call void @objc_arc_annotation_bottomup_bbstart(i8** %b, i8** %c) #0 - tail call void @objc_arc_annotation_bottomup_bbend(i8** %b, i8** %c) #0 - invoke void @objc_autoreleasePoolPop(i8* %a) - to label %normalBlock unwind label %unwindBlock -normalBlock: - ret void -unwindBlock: - %ll = landingpad { i8*, i32 } - cleanup - ret void -} - -// Check that auto-upgrader converts function calls to intrinsic calls. Note that -// the auto-upgrader doesn't touch invoke instructions. - -// ARC: define void @testRuntimeCalls(i8* %[[A:.*]], i8** %[[B:.*]], i8** %[[C:.*]], i32* %[[D:.*]], i32** %[[E:.*]]) personality +// ARC: define void @testRuntimeCalls(i8* %[[A:.*]], i8** %[[B:.*]], i8** %[[C:.*]]) { // ARC: %[[V0:.*]] = tail call i8* @llvm.objc.autorelease(i8* %[[A]]) // ARC-NEXT: tail call void @llvm.objc.autoreleasePoolPop(i8* %[[A]]) // ARC-NEXT: %[[V1:.*]] = tail call i8* @llvm.objc.autoreleasePoolPush() // ARC-NEXT: %[[V2:.*]] = tail call i8* @llvm.objc.autoreleaseReturnValue(i8* %[[A]]) // ARC-NEXT: tail call void @llvm.objc.copyWeak(i8** %[[B]], i8** %[[C]]) // ARC-NEXT: tail call void @llvm.objc.destroyWeak(i8** %[[B]]) -// ARC-NEXT: %[[V100:.*]] = bitcast i32** %[[E]] to i8** -// ARC-NEXT: %[[V101:.*]] = bitcast i32* %[[D]] to i8* -// ARC-NEXT: %[[V102:.*]] = tail call i8* @llvm.objc.initWeak(i8** %[[V100]], i8* %[[V101]]) -// ARC-NEXT: %[[V103:.*]] = bitcast i8* %[[V102]] to i32* +// ARC-NEXT: %[[V3:.*]] = tail call i8* @llvm.objc.initWeak(i8** %[[B]], i8* %[[A]]) // ARC-NEXT: %[[V4:.*]] = tail call i8* @llvm.objc.loadWeak(i8** %[[B]]) // ARC-NEXT: %[[V5:.*]] = tail call i8* @llvm.objc.loadWeakRetained(i8** %[[B]]) // ARC-NEXT: tail call void @llvm.objc.moveWeak(i8** %[[B]], i8** %[[C]]) @@ -87,16 +39,16 @@ unwindBlock: // ARC-NEXT: tail call void @llvm.objc.arc.annotation.topdown.bbend(i8** %[[B]], i8** %[[C]]) // ARC-NEXT: tail call void @llvm.objc.arc.annotation.bottomup.bbstart(i8** %[[B]], i8** %[[C]]) // ARC-NEXT: tail call void @llvm.objc.arc.annotation.bottomup.bbend(i8** %[[B]], i8** %[[C]]) -// ARC-NEXT: invoke void @objc_autoreleasePoolPop(i8* %[[A]]) +// ARC-NEXT: ret void -// MRR: define void @testRuntimeCalls(i8* %[[A:.*]], i8** %[[B:.*]], i8** %[[C:.*]], i32* %[[D:.*]], i32** %[[E:.*]]) personality +// MRR: define void @testRuntimeCalls(i8* %[[A:.*]], i8** %[[B:.*]], i8** %[[C:.*]]) { // MRR: %[[V0:.*]] = tail call i8* @objc_autorelease(i8* %[[A]]) // MRR-NEXT: tail call void @objc_autoreleasePoolPop(i8* %[[A]]) // MRR-NEXT: %[[V1:.*]] = tail call i8* @objc_autoreleasePoolPush() // MRR-NEXT: %[[V2:.*]] = tail call i8* @objc_autoreleaseReturnValue(i8* %[[A]]) // MRR-NEXT: tail call void @objc_copyWeak(i8** %[[B]], i8** %[[C]]) // MRR-NEXT: tail call void @objc_destroyWeak(i8** %[[B]]) -// MRR-NEXT: %[[V3:.*]] = tail call i32* @objc_initWeak(i32** %[[E]], i32* %[[D]]) +// MRR-NEXT: %[[V3:.*]] = tail call i8* @objc_initWeak(i8** %[[B]], i8* %[[A]]) // MRR-NEXT: %[[V4:.*]] = tail call i8* @objc_loadWeak(i8** %[[B]]) // MRR-NEXT: %[[V5:.*]] = tail call i8* @objc_loadWeakRetained(i8** %[[B]]) // MRR-NEXT: tail call void @objc_moveWeak(i8** %[[B]], i8** %[[C]]) @@ -120,4 +72,4 @@ unwindBlock: // MRR-NEXT: tail call void @objc_arc_annotation_topdown_bbend(i8** %[[B]], i8** %[[C]]) // MRR-NEXT: tail call void @objc_arc_annotation_bottomup_bbstart(i8** %[[B]], i8** %[[C]]) // MRR-NEXT: tail call void @objc_arc_annotation_bottomup_bbend(i8** %[[B]], i8** %[[C]]) -// MRR-NEXT: invoke void @objc_autoreleasePoolPop(i8* %[[A]]) +// MRR-NEXT: ret void diff --git a/llvm/test/Bitcode/upgrade-mrr-runtime-calls.bc b/llvm/test/Bitcode/upgrade-mrr-runtime-calls.bc Binary files differindex 64c44c8696f..877b2b4eb49 100644 --- a/llvm/test/Bitcode/upgrade-mrr-runtime-calls.bc +++ b/llvm/test/Bitcode/upgrade-mrr-runtime-calls.bc |

