John Brawn | cd73fe8 | 2018-07-30 11:52:08 +0000 | [diff] [blame] | 1 | ; RUN: opt < %s -phi-values -basicaa -aa-eval -print-all-alias-modref-info -disable-output 2>&1 | FileCheck %s |
| 2 | ; RUN: opt < %s -aa-pipeline=basic-aa -passes='require<phi-values>,aa-eval' -print-all-alias-modref-info -disable-output 2>&1 | FileCheck %s |
Arnold Schwaighofer | 0d10a9d | 2014-01-02 03:31:36 +0000 | [diff] [blame] | 3 | target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64-S128" |
| 4 | target triple = "x86_64-unknown-linux-gnu" |
| 5 | |
Evan Cheng | c10e88d | 2009-10-13 22:02:20 +0000 | [diff] [blame] | 6 | ; rdar://7282591 |
| 7 | |
Evan Cheng | c745bf2 | 2009-10-14 01:45:10 +0000 | [diff] [blame] | 8 | @X = common global i32 0 |
| 9 | @Y = common global i32 0 |
| 10 | @Z = common global i32 0 |
Evan Cheng | c10e88d | 2009-10-13 22:02:20 +0000 | [diff] [blame] | 11 | |
Arnold Schwaighofer | 0d10a9d | 2014-01-02 03:31:36 +0000 | [diff] [blame] | 12 | ; CHECK-LABEL: foo |
Bill Wendling | cd6df16 | 2012-04-24 09:15:38 +0000 | [diff] [blame] | 13 | ; CHECK: NoAlias: i32* %P, i32* @Z |
| 14 | |
Dan Gohman | 22e0e1c | 2010-11-11 21:08:46 +0000 | [diff] [blame] | 15 | define void @foo(i32 %cond) nounwind { |
Evan Cheng | c10e88d | 2009-10-13 22:02:20 +0000 | [diff] [blame] | 16 | entry: |
Evan Cheng | c745bf2 | 2009-10-14 01:45:10 +0000 | [diff] [blame] | 17 | %"alloca point" = bitcast i32 0 to i32 |
| 18 | %tmp = icmp ne i32 %cond, 0 |
| 19 | br i1 %tmp, label %bb, label %bb1 |
Evan Cheng | c10e88d | 2009-10-13 22:02:20 +0000 | [diff] [blame] | 20 | |
Evan Cheng | c745bf2 | 2009-10-14 01:45:10 +0000 | [diff] [blame] | 21 | bb: |
| 22 | br label %bb2 |
Evan Cheng | c10e88d | 2009-10-13 22:02:20 +0000 | [diff] [blame] | 23 | |
Evan Cheng | c745bf2 | 2009-10-14 01:45:10 +0000 | [diff] [blame] | 24 | bb1: |
| 25 | br label %bb2 |
Evan Cheng | c10e88d | 2009-10-13 22:02:20 +0000 | [diff] [blame] | 26 | |
Evan Cheng | c745bf2 | 2009-10-14 01:45:10 +0000 | [diff] [blame] | 27 | bb2: |
| 28 | %P = phi i32* [ @X, %bb ], [ @Y, %bb1 ] |
David Blaikie | a79ac14 | 2015-02-27 21:17:42 +0000 | [diff] [blame] | 29 | %tmp1 = load i32, i32* @Z, align 4 |
Evan Cheng | c745bf2 | 2009-10-14 01:45:10 +0000 | [diff] [blame] | 30 | store i32 123, i32* %P, align 4 |
David Blaikie | a79ac14 | 2015-02-27 21:17:42 +0000 | [diff] [blame] | 31 | %tmp2 = load i32, i32* @Z, align 4 |
Evan Cheng | c745bf2 | 2009-10-14 01:45:10 +0000 | [diff] [blame] | 32 | br label %return |
Evan Cheng | c10e88d | 2009-10-13 22:02:20 +0000 | [diff] [blame] | 33 | |
Evan Cheng | c745bf2 | 2009-10-14 01:45:10 +0000 | [diff] [blame] | 34 | return: |
Evan Cheng | c10e88d | 2009-10-13 22:02:20 +0000 | [diff] [blame] | 35 | ret void |
| 36 | } |
Arnold Schwaighofer | 0d10a9d | 2014-01-02 03:31:36 +0000 | [diff] [blame] | 37 | |
| 38 | ; Pointers can vary in between iterations of loops. |
| 39 | ; PR18068 |
| 40 | |
| 41 | ; CHECK-LABEL: pr18068 |
| 42 | ; CHECK: MayAlias: i32* %0, i32* %arrayidx5 |
Quentin Colombet | 5989bc6 | 2015-08-31 22:32:47 +0000 | [diff] [blame] | 43 | ; CHECK: NoAlias: i32* %arrayidx13, i32* %arrayidx5 |
Arnold Schwaighofer | 0d10a9d | 2014-01-02 03:31:36 +0000 | [diff] [blame] | 44 | |
Arnold Schwaighofer | 0d10a9d | 2014-01-02 03:31:36 +0000 | [diff] [blame] | 45 | define i32 @pr18068(i32* %jj7, i32* %j) { |
| 46 | entry: |
| 47 | %oa5 = alloca [100 x i32], align 16 |
| 48 | br label %codeRepl |
| 49 | |
| 50 | codeRepl: |
| 51 | %0 = phi i32* [ %arrayidx13, %for.body ], [ %j, %entry ] |
| 52 | %targetBlock = call i1 @cond(i32* %jj7) |
| 53 | br i1 %targetBlock, label %for.body, label %bye |
| 54 | |
| 55 | for.body: |
David Blaikie | a79ac14 | 2015-02-27 21:17:42 +0000 | [diff] [blame] | 56 | %1 = load i32, i32* %jj7, align 4 |
Arnold Schwaighofer | 0d10a9d | 2014-01-02 03:31:36 +0000 | [diff] [blame] | 57 | %idxprom4 = zext i32 %1 to i64 |
David Blaikie | 79e6c74 | 2015-02-27 19:29:02 +0000 | [diff] [blame] | 58 | %arrayidx5 = getelementptr inbounds [100 x i32], [100 x i32]* %oa5, i64 0, i64 %idxprom4 |
David Blaikie | a79ac14 | 2015-02-27 21:17:42 +0000 | [diff] [blame] | 59 | %2 = load i32, i32* %arrayidx5, align 4 |
Arnold Schwaighofer | 0d10a9d | 2014-01-02 03:31:36 +0000 | [diff] [blame] | 60 | %sub6 = sub i32 %2, 6 |
| 61 | store i32 %sub6, i32* %arrayidx5, align 4 |
| 62 | ; %0 and %arrayidx5 can alias! It is not safe to DSE the above store. |
David Blaikie | a79ac14 | 2015-02-27 21:17:42 +0000 | [diff] [blame] | 63 | %3 = load i32, i32* %0, align 4 |
Arnold Schwaighofer | 0d10a9d | 2014-01-02 03:31:36 +0000 | [diff] [blame] | 64 | store i32 %3, i32* %arrayidx5, align 4 |
| 65 | %sub11 = add i32 %1, -1 |
| 66 | %idxprom12 = zext i32 %sub11 to i64 |
David Blaikie | 79e6c74 | 2015-02-27 19:29:02 +0000 | [diff] [blame] | 67 | %arrayidx13 = getelementptr inbounds [100 x i32], [100 x i32]* %oa5, i64 0, i64 %idxprom12 |
Arnold Schwaighofer | 0d10a9d | 2014-01-02 03:31:36 +0000 | [diff] [blame] | 68 | call void @inc(i32* %jj7) |
| 69 | br label %codeRepl |
| 70 | |
| 71 | bye: |
David Blaikie | a79ac14 | 2015-02-27 21:17:42 +0000 | [diff] [blame] | 72 | %.reload = load i32, i32* %jj7, align 4 |
Arnold Schwaighofer | 0d10a9d | 2014-01-02 03:31:36 +0000 | [diff] [blame] | 73 | ret i32 %.reload |
| 74 | } |
| 75 | |
| 76 | declare i1 @cond(i32*) |
| 77 | |
| 78 | declare void @inc(i32*) |
| 79 | |
| 80 | |
John Brawn | cd73fe8 | 2018-07-30 11:52:08 +0000 | [diff] [blame] | 81 | ; When we have a chain of phis in nested loops we should recognise if there's |
| 82 | ; actually only one underlying value. |
| 83 | ; CHECK-LABEL: loop_phi_chain |
| 84 | ; CHECK: NoAlias: i32* %val1, i32* @Y |
| 85 | ; CHECK: NoAlias: i32* %val2, i32* @Y |
| 86 | ; CHECK: NoAlias: i32* %val3, i32* @Y |
| 87 | define void @loop_phi_chain(i32 %a, i32 %b, i32 %c) { |
| 88 | entry: |
| 89 | br label %loop1 |
| 90 | |
| 91 | loop1: |
| 92 | %n1 = phi i32 [ 0, %entry ], [ %add1, %loop2 ] |
| 93 | %val1 = phi i32* [ @X, %entry ], [ %val2, %loop2 ] |
| 94 | %add1 = add i32 %n1, 1 |
| 95 | %cmp1 = icmp ne i32 %n1, 32 |
| 96 | br i1 %cmp1, label %loop2, label %end |
| 97 | |
| 98 | loop2: |
| 99 | %n2 = phi i32 [ 0, %loop1 ], [ %add2, %loop3 ] |
| 100 | %val2 = phi i32* [ %val1, %loop1 ], [ %val3, %loop3 ] |
| 101 | %add2 = add i32 %n2, 1 |
| 102 | %cmp2 = icmp ne i32 %n2, 32 |
| 103 | br i1 %cmp2, label %loop3, label %loop1 |
| 104 | |
| 105 | loop3: |
| 106 | %n3 = phi i32 [ 0, %loop2 ], [ %add3, %loop3 ] |
| 107 | %val3 = phi i32* [ %val2, %loop2 ], [ %val3, %loop3 ] |
| 108 | store i32 0, i32* %val3, align 4 |
| 109 | store i32 0, i32* @Y, align 4 |
| 110 | %add3 = add i32 %n3, 1 |
| 111 | %cmp3 = icmp ne i32 %n3, 32 |
| 112 | br i1 %cmp3, label %loop3, label %loop2 |
| 113 | |
| 114 | end: |
| 115 | ret void |
| 116 | } |