[clang][modules] Don't prevent translation of FW_Private includes when explicitly...
[llvm-project.git] / llvm / test / Transforms / NewGVN / deadstore.ll
blobef8bdf38b658fbad0fe7153746d0d27d641e481b
1 ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
2 ; RUN: opt < %s -passes=newgvn -S | FileCheck %s
4 ;; Most of these are borrowed from transforms/DSE/simple.ll
5 ;; NewGVN should be able to eliminate any stores of the same value that are actually redundnat.
7 ;; tmp5 is store of the same value to the same location as the load.
8 define void @test12(ptr %x) nounwind  {
9 ; CHECK-LABEL: @test12(
10 ; CHECK-NEXT:    [[TMP5:%.*]] = load i32, ptr [[X:%.*]], align 4
11 ; CHECK-NEXT:    [[TMP7:%.*]] = getelementptr { i32, i32 }, ptr [[X]], i32 0, i32 1
12 ; CHECK-NEXT:    [[TMP8:%.*]] = load i32, ptr [[TMP7]], align 4
13 ; CHECK-NEXT:    [[TMP17:%.*]] = sub i32 0, [[TMP8]]
14 ; CHECK-NEXT:    store i32 [[TMP17]], ptr [[TMP7]], align 4
15 ; CHECK-NEXT:    ret void
17   %tmp4 = getelementptr { i32, i32 }, ptr %x, i32 0, i32 0
18   %tmp5 = load i32, ptr %tmp4, align 4
19   %tmp7 = getelementptr { i32, i32 }, ptr %x, i32 0, i32 1
20   %tmp8 = load i32, ptr %tmp7, align 4
21   %tmp17 = sub i32 0, %tmp8
22   store i32 %tmp5, ptr %tmp4, align 4
23   store i32 %tmp17, ptr %tmp7, align 4
24   ret void
26 ; Remove redundant store if loaded value is in another block.
27 define i32 @test26(i1 %c, ptr %p) {
28 ; CHECK-LABEL: @test26(
29 ; CHECK-NEXT:  entry:
30 ; CHECK-NEXT:    [[V:%.*]] = load i32, ptr [[P:%.*]], align 4
31 ; CHECK-NEXT:    br i1 [[C:%.*]], label [[BB1:%.*]], label [[BB2:%.*]]
32 ; CHECK:       bb1:
33 ; CHECK-NEXT:    br label [[BB3:%.*]]
34 ; CHECK:       bb2:
35 ; CHECK-NEXT:    br label [[BB3]]
36 ; CHECK:       bb3:
37 ; CHECK-NEXT:    ret i32 0
39 entry:
40   %v = load i32, ptr %p, align 4
41   br i1 %c, label %bb1, label %bb2
42 bb1:
43   br label %bb3
44 bb2:
45   store i32 %v, ptr %p, align 4
46   br label %bb3
47 bb3:
48   ret i32 0
51 declare void @unknown_func()
52 ; Remove redundant store, which is in the same loop as the load.
53 define i32 @test33(i1 %c, ptr %p, i32 %i) {
54 ; CHECK-LABEL: @test33(
55 ; CHECK-NEXT:  entry:
56 ; CHECK-NEXT:    br label [[BB1:%.*]]
57 ; CHECK:       bb1:
58 ; CHECK-NEXT:    [[V:%.*]] = load i32, ptr [[P:%.*]], align 4
59 ; CHECK-NEXT:    br label [[BB2:%.*]]
60 ; CHECK:       bb2:
61 ; CHECK-NEXT:    call void @unknown_func()
62 ; CHECK-NEXT:    br i1 undef, label [[BB1]], label [[BB3:%.*]]
63 ; CHECK:       bb3:
64 ; CHECK-NEXT:    ret i32 0
66 entry:
67   br label %bb1
68 bb1:
69   %v = load i32, ptr %p, align 4
70   br label %bb2
71 bb2:
72   store i32 %v, ptr %p, align 4
73   ; Might read and overwrite value at %p, but doesn't matter.
74   call void @unknown_func()
75   br i1 undef, label %bb1, label %bb3
76 bb3:
77   ret i32 0