[ARM] Adjust how NEON shifts are lowered
[llvm-core.git] / test / Transforms / GVN / PRE / rle-semidominated.ll
blobf9704d3efbffa7937fad1da9554e0c4c02f0cfdd
1 ; RUN: opt < %s -basicaa -gvn -S | FileCheck %s
3 define i32 @main(i32* %p, i32 %x, i32 %y) {
4 block1:
5   %z = load i32, i32* %p
6   %cmp = icmp eq i32 %x, %y
7         br i1 %cmp, label %block2, label %block3
9 block2:
10  br label %block4
12 block3:
13   %b = bitcast i32 0 to i32
14   store i32 %b, i32* %p
15   br label %block4
17 block4:
18   %DEAD = load i32, i32* %p
19   ret i32 %DEAD
22 ; CHECK: define i32 @main(i32* %p, i32 %x, i32 %y) {
23 ; CHECK-NEXT: block1:
24 ; CHECK-NOT:    %z = load i32, i32* %p
25 ; CHECK-NEXT:   %cmp = icmp eq i32 %x, %y
26 ; CHECK-NEXT:   br i1 %cmp, label %block2, label %block3
27 ; CHECK: block2:
28 ; CHECK-NEXT:   %DEAD.pre = load i32, i32* %p
29 ; CHECK-NEXT:   br label %block4
30 ; CHECK: block3:
31 ; CHECK-NEXT:   store i32 0, i32* %p
32 ; CHECK-NEXT:   br label %block4
33 ; CHECK: block4:
34 ; CHECK-NEXT:   %DEAD = phi i32 [ 0, %block3 ], [ %DEAD.pre, %block2 ]
35 ; CHECK-NEXT:   ret i32 %DEAD
36 ; CHECK-NEXT: }