mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-03-02 17:29:03 +00:00
[objc-arc] Check that objc-arc-expand properly handles all strictly forwarding calls and does not touch calls which are not strictly forwarding (i.e. objc_retainBlock).
llvm-svn: 179972
This commit is contained in:
parent
03f1fec178
commit
3af6adbc8d
@ -4,25 +4,91 @@ target datalayout = "e-p:64:64:64"
|
||||
|
||||
declare i8* @objc_retain(i8*)
|
||||
declare i8* @objc_autorelease(i8*)
|
||||
declare i8* @objc_retainAutoreleasedReturnValue(i8*)
|
||||
declare i8* @objc_autoreleaseReturnValue(i8*)
|
||||
declare i8* @objc_retainAutorelease(i8*)
|
||||
declare i8* @objc_retainAutoreleaseReturnValue(i8*)
|
||||
declare i8* @objc_retainBlock(i8*)
|
||||
|
||||
declare void @use_pointer(i8*)
|
||||
|
||||
; CHECK: define void @test0
|
||||
; CHECK: define void @test_retain(i8* %x) [[NUW:#[0-9]+]] {
|
||||
; CHECK: call i8* @objc_retain(i8* %x)
|
||||
; CHECK: call void @use_pointer(i8* %x)
|
||||
; CHECK: }
|
||||
define void @test0(i8* %x) nounwind {
|
||||
define void @test_retain(i8* %x) nounwind {
|
||||
entry:
|
||||
%0 = call i8* @objc_retain(i8* %x) nounwind
|
||||
call void @use_pointer(i8* %0)
|
||||
ret void
|
||||
}
|
||||
|
||||
; CHECK: define void @test1
|
||||
; CHECK: define void @test_retainAutoreleasedReturnValue(i8* %x) [[NUW]] {
|
||||
; CHECK: call i8* @objc_retainAutoreleasedReturnValue(i8* %x)
|
||||
; CHECK: call void @use_pointer(i8* %x)
|
||||
; CHECK: }
|
||||
define void @test1(i8* %x) nounwind {
|
||||
define void @test_retainAutoreleasedReturnValue(i8* %x) nounwind {
|
||||
entry:
|
||||
%0 = call i8* @objc_autorelease(i8* %x) nounwind
|
||||
call void @use_pointer(i8* %x)
|
||||
%0 = call i8* @objc_retainAutoreleasedReturnValue(i8* %x) nounwind
|
||||
call void @use_pointer(i8* %0)
|
||||
ret void
|
||||
}
|
||||
|
||||
; CHECK: define void @test_retainAutorelease(i8* %x) [[NUW]] {
|
||||
; CHECK: call i8* @objc_retainAutorelease(i8* %x)
|
||||
; CHECK: call void @use_pointer(i8* %x)
|
||||
; CHECK: }
|
||||
define void @test_retainAutorelease(i8* %x) nounwind {
|
||||
entry:
|
||||
%0 = call i8* @objc_retainAutorelease(i8* %x) nounwind
|
||||
call void @use_pointer(i8* %0)
|
||||
ret void
|
||||
}
|
||||
|
||||
; CHECK: define void @test_retainAutoreleaseReturnValue(i8* %x) [[NUW]] {
|
||||
; CHECK: call i8* @objc_retainAutoreleaseReturnValue(i8* %x)
|
||||
; CHECK: call void @use_pointer(i8* %x)
|
||||
; CHECK: }
|
||||
define void @test_retainAutoreleaseReturnValue(i8* %x) nounwind {
|
||||
entry:
|
||||
%0 = call i8* @objc_retainAutoreleaseReturnValue(i8* %x) nounwind
|
||||
call void @use_pointer(i8* %0)
|
||||
ret void
|
||||
}
|
||||
|
||||
; CHECK: define void @test_autorelease(i8* %x) [[NUW]] {
|
||||
; CHECK: call i8* @objc_autorelease(i8* %x)
|
||||
; CHECK: call void @use_pointer(i8* %x)
|
||||
; CHECK: }
|
||||
define void @test_autorelease(i8* %x) nounwind {
|
||||
entry:
|
||||
%0 = call i8* @objc_autorelease(i8* %x) nounwind
|
||||
call void @use_pointer(i8* %0)
|
||||
ret void
|
||||
}
|
||||
|
||||
; CHECK: define void @test_autoreleaseReturnValue(i8* %x) [[NUW]] {
|
||||
; CHECK: call i8* @objc_autoreleaseReturnValue(i8* %x)
|
||||
; CHECK: call void @use_pointer(i8* %x)
|
||||
; CHECK: }
|
||||
define void @test_autoreleaseReturnValue(i8* %x) nounwind {
|
||||
entry:
|
||||
%0 = call i8* @objc_autoreleaseReturnValue(i8* %x) nounwind
|
||||
call void @use_pointer(i8* %0)
|
||||
ret void
|
||||
}
|
||||
|
||||
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
||||
; RetainBlock is not strictly forwarding. Do not touch it. ;
|
||||
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
||||
|
||||
; CHECK: define void @test_retainBlock(i8* %x) [[NUW]] {
|
||||
; CHECK: call i8* @objc_retainBlock(i8* %x)
|
||||
; CHECK: call void @use_pointer(i8* %0)
|
||||
; CHECK: }
|
||||
define void @test_retainBlock(i8* %x) nounwind {
|
||||
entry:
|
||||
%0 = call i8* @objc_retainBlock(i8* %x) nounwind
|
||||
call void @use_pointer(i8* %0)
|
||||
ret void
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user