blob: e65a453d0f327c977db0049dfea7153b358b30db [file] [log] [blame]
Dan Gohmanf17a25c2007-07-18 16:29:46 +00001; Test that LICM uses basicaa to do alias analysis, which is capable of
2; disambiguating some obvious cases. If LICM is able to disambiguate the
3; two pointers, then the load should be hoisted, and the store sunk. Thus
4; the loop becomes empty and can be deleted by ADCE.
5
Tanya Lattnera695f012008-02-14 06:56:27 +00006; RUN: llvm-as < %s | opt -basicaa -licm --adce | llvm-dis | not grep Loop
Dan Gohmanf17a25c2007-07-18 16:29:46 +00007
Tanya Lattnera695f012008-02-14 06:56:27 +00008@A = global i32 7 ; <i32*> [#uses=3]
9@B = global i32 8 ; <i32*> [#uses=2]
10@C = global [2 x i32] [ i32 4, i32 8 ] ; <[2 x i32]*> [#uses=2]
Dan Gohmanf17a25c2007-07-18 16:29:46 +000011
Tanya Lattnera695f012008-02-14 06:56:27 +000012define i32 @test(i1 %c) {
13 %Atmp = load i32* @A ; <i32> [#uses=2]
14 br label %Loop
Dan Gohmanf17a25c2007-07-18 16:29:46 +000015
Tanya Lattnera695f012008-02-14 06:56:27 +000016Loop: ; preds = %Loop, %0
17 %ToRemove = load i32* @A ; <i32> [#uses=1]
18 store i32 %Atmp, i32* @B
19 br i1 %c, label %Out, label %Loop
20
21Out: ; preds = %Loop
22 %X = sub i32 %ToRemove, %Atmp ; <i32> [#uses=1]
23 ret i32 %X
Dan Gohmanf17a25c2007-07-18 16:29:46 +000024}
25
Tanya Lattnera695f012008-02-14 06:56:27 +000026define i32 @test2(i1 %c) {
27 br label %Loop
Dan Gohmanf17a25c2007-07-18 16:29:46 +000028
Tanya Lattnera695f012008-02-14 06:56:27 +000029Loop: ; preds = %Loop, %0
30 %AVal = load i32* @A ; <i32> [#uses=2]
31 %C0 = getelementptr [2 x i32]* @C, i64 0, i64 0 ; <i32*> [#uses=1]
32 store i32 %AVal, i32* %C0
33 %BVal = load i32* @B ; <i32> [#uses=2]
34 %C1 = getelementptr [2 x i32]* @C, i64 0, i64 1 ; <i32*> [#uses=1]
35 store i32 %BVal, i32* %C1
36 br i1 %c, label %Out, label %Loop
Dan Gohmanf17a25c2007-07-18 16:29:46 +000037
Tanya Lattnera695f012008-02-14 06:56:27 +000038Out: ; preds = %Loop
39 %X = sub i32 %AVal, %BVal ; <i32> [#uses=1]
40 ret i32 %X
Dan Gohmanf17a25c2007-07-18 16:29:46 +000041}
42