blob: 196a608c33d454b9b8984ce6a5905e25e172d65b [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
Owen Andersone73dd1b2008-05-16 04:25:09 +00003; two pointers, then the load should be hoisted, and the store sunk.
Dan Gohmanf17a25c2007-07-18 16:29:46 +00004
Dan Gohman1b4c27772009-09-08 16:50:01 +00005; RUN: opt %s -basicaa -licm | llvm-dis | FileCheck %s
Dan Gohmanf17a25c2007-07-18 16:29:46 +00006
Tanya Lattnera695f012008-02-14 06:56:27 +00007@A = global i32 7 ; <i32*> [#uses=3]
8@B = global i32 8 ; <i32*> [#uses=2]
9@C = global [2 x i32] [ i32 4, i32 8 ] ; <[2 x i32]*> [#uses=2]
Dan Gohmanf17a25c2007-07-18 16:29:46 +000010
Chris Lattner16078ca2009-08-30 21:36:06 +000011define i32 @test1(i1 %c) {
Tanya Lattnera695f012008-02-14 06:56:27 +000012 %Atmp = load i32* @A ; <i32> [#uses=2]
13 br label %Loop
Dan Gohmanf17a25c2007-07-18 16:29:46 +000014
Tanya Lattnera695f012008-02-14 06:56:27 +000015Loop: ; preds = %Loop, %0
16 %ToRemove = load i32* @A ; <i32> [#uses=1]
17 store i32 %Atmp, i32* @B
18 br i1 %c, label %Out, label %Loop
19
20Out: ; preds = %Loop
21 %X = sub i32 %ToRemove, %Atmp ; <i32> [#uses=1]
22 ret i32 %X
Chris Lattner16078ca2009-08-30 21:36:06 +000023
24; The Loop block should be empty after the load/store are promoted.
25; CHECK: @test1
26; CHECK: load i32* @B
27; CHECK: Loop:
28; CHECK-NEXT: br i1 %c, label %Out, label %Loop
29; CHECK: Out:
30; CHECK: store i32 %Atmp, i32* @B
Dan Gohmanf17a25c2007-07-18 16:29:46 +000031}
32
Tanya Lattnera695f012008-02-14 06:56:27 +000033define i32 @test2(i1 %c) {
34 br label %Loop
Dan Gohmanf17a25c2007-07-18 16:29:46 +000035
Tanya Lattnera695f012008-02-14 06:56:27 +000036Loop: ; preds = %Loop, %0
37 %AVal = load i32* @A ; <i32> [#uses=2]
38 %C0 = getelementptr [2 x i32]* @C, i64 0, i64 0 ; <i32*> [#uses=1]
39 store i32 %AVal, i32* %C0
40 %BVal = load i32* @B ; <i32> [#uses=2]
41 %C1 = getelementptr [2 x i32]* @C, i64 0, i64 1 ; <i32*> [#uses=1]
42 store i32 %BVal, i32* %C1
43 br i1 %c, label %Out, label %Loop
Dan Gohmanf17a25c2007-07-18 16:29:46 +000044
Tanya Lattnera695f012008-02-14 06:56:27 +000045Out: ; preds = %Loop
46 %X = sub i32 %AVal, %BVal ; <i32> [#uses=1]
47 ret i32 %X
Chris Lattner16078ca2009-08-30 21:36:06 +000048; The Loop block should be empty after the load/store are promoted.
49; CHECK: @test2
50; CHECK: Loop:
51; CHECK-NEXT: br i1 %c, label %Out, label %Loop
Dan Gohmanf17a25c2007-07-18 16:29:46 +000052}
53