[rtsan] Add fork/execve interceptors (#117198)
[llvm-project.git] / llvm / test / Transforms / ObjCARC / gvn.ll
blobc385f33e63e2cb4f6e16252e44681ee617ce421c
1 ; RUN: opt -S -aa-pipeline=basic-aa,objc-arc-aa -passes=gvn < %s | FileCheck %s
3 @x = common global ptr null, align 8
5 declare ptr @llvm.objc.retain(ptr)
6 declare i32 @llvm.objc.sync.enter(ptr)
7 declare i32 @llvm.objc.sync.exit(ptr)
9 ; GVN should be able to eliminate this redundant load, with ARC-specific
10 ; alias analysis.
12 ; CHECK: define ptr @test0(i32 %n)
13 ; CHECK-NEXT: entry:
14 ; CHECK-NEXT: %s = load ptr, ptr @x
15 ; CHECK-NOT: load
16 ; CHECK: ret ptr %s
17 ; CHECK-NEXT: }
18 define ptr @test0(i32 %n) nounwind {
19 entry:
20   %s = load ptr, ptr @x
21   %0 = tail call ptr @llvm.objc.retain(ptr %s) nounwind
22   %t = load ptr, ptr @x
23   ret ptr %t
26 ; GVN should not be able to eliminate this redundant load, with ARC-specific
27 ; alias analysis.
29 ; CHECK-LABEL: define ptr @test1(
30 ; CHECK: load
31 ; CHECK: load
32 ; CHECK: ret ptr %t
33 ; CHECK: }
34 define ptr @test1(i32 %n) nounwind {
35 entry:
36   %s = load ptr, ptr @x
37   %0 = call i32 @llvm.objc.sync.enter(ptr %s)
38   %t = load ptr, ptr @x
39   %1 = call i32 @llvm.objc.sync.exit(ptr %s)
40   ret ptr %t