X-Git-Url: http://demsky.eecs.uci.edu/git/?a=blobdiff_plain;f=test%2FTransforms%2FObjCARC%2Fgvn.ll;h=6f828545bc6fa8e5394ff3236fcbb77982587b56;hb=97515eb97bc5a3b075fc4d452c330ac7405cf815;hp=8d9b1bb84b86bd64e058c46a340c6e161abd1c03;hpb=95a1b3484d7daf7830161f1613fc812303641abe;p=oota-llvm.git diff --git a/test/Transforms/ObjCARC/gvn.ll b/test/Transforms/ObjCARC/gvn.ll index 8d9b1bb84b8..6f828545bc6 100644 --- a/test/Transforms/ObjCARC/gvn.ll +++ b/test/Transforms/ObjCARC/gvn.ll @@ -3,20 +3,39 @@ @x = common global i8* null, align 8 declare i8* @objc_retain(i8*) +declare i32 @objc_sync_enter(i8*) +declare i32 @objc_sync_exit(i8*) ; GVN should be able to eliminate this redundant load, with ARC-specific ; alias analysis. ; CHECK: define i8* @test0(i32 %n) ; CHECK-NEXT: entry: -; CHECK-NEXT: %s = load i8** @x +; CHECK-NEXT: %s = load i8*, i8** @x ; CHECK-NOT: load ; CHECK: ret i8* %s ; CHECK-NEXT: } define i8* @test0(i32 %n) nounwind { entry: - %s = load i8** @x + %s = load i8*, i8** @x %0 = tail call i8* @objc_retain(i8* %s) nounwind - %t = load i8** @x + %t = load i8*, i8** @x + ret i8* %t +} + +; GVN should not be able to eliminate this redundant load, with ARC-specific +; alias analysis. + +; CHECK-LABEL: define i8* @test1( +; CHECK: load +; CHECK: load +; CHECK: ret i8* %t +; CHECK: } +define i8* @test1(i32 %n) nounwind { +entry: + %s = load i8*, i8** @x + %0 = call i32 @objc_sync_enter(i8* %s) + %t = load i8*, i8** @x + %1 = call i32 @objc_sync_exit(i8* %s) ret i8* %t }