xref: /llvm-project/llvm/test/Analysis/DependenceAnalysis/lcssa.ll (revision 46f9cddfd7e40998422d1e34a3f1193210ee2fb8)
1*46f9cddfSSebastian Pop; NOTE: Assertions have been autogenerated by utils/update_analyze_test_checks.py UTC_ARGS: --version 5
25d5b0876SEli Friedman; RUN: opt < %s -disable-output "-passes=print<da>"                            \
35d5b0876SEli Friedman; RUN: "-aa-pipeline=basic-aa,tbaa" 2>&1 | FileCheck %s
45d5b0876SEli Friedman
525640966SNikita Popovdefine void @f(ptr %a, i32 %n, i64 %n2) {
6*46f9cddfSSebastian Pop; CHECK-LABEL: 'f'
7*46f9cddfSSebastian Pop; CHECK-NEXT:  Src: %v = load i32, ptr %arrayidx1, align 4 --> Dst: %v = load i32, ptr %arrayidx1, align 4
8*46f9cddfSSebastian Pop; CHECK-NEXT:    da analyze - none!
9*46f9cddfSSebastian Pop; CHECK-NEXT:  Src: %v = load i32, ptr %arrayidx1, align 4 --> Dst: store i32 %add, ptr %a.lcssa, align 4
10*46f9cddfSSebastian Pop; CHECK-NEXT:    da analyze - anti [*|<]!
11*46f9cddfSSebastian Pop; CHECK-NEXT:  Src: store i32 %add, ptr %a.lcssa, align 4 --> Dst: store i32 %add, ptr %a.lcssa, align 4
12*46f9cddfSSebastian Pop; CHECK-NEXT:    da analyze - consistent output [S]!
13*46f9cddfSSebastian Pop;
145d5b0876SEli Friedmanentry:
155d5b0876SEli Friedman  br label %while.body
165d5b0876SEli Friedman
175d5b0876SEli Friedmanwhile.body:
185d5b0876SEli Friedman  %n.addr = phi i32 [ %mul, %while.body ], [ %n, %entry ]
195d5b0876SEli Friedman  %inc.phi = phi i32 [ %inc, %while.body ], [ 0, %entry ]
205d5b0876SEli Friedman  %mul = mul i32 %n.addr, 3
215d5b0876SEli Friedman  %div = udiv i32 %mul, 2
225d5b0876SEli Friedman  %inc = add i32 %inc.phi, 1
2325640966SNikita Popov  %incdec.ptr = getelementptr inbounds i32, ptr %a, i32 %inc
245d5b0876SEli Friedman  %cmp.not = icmp eq i32 %div, 1
255d5b0876SEli Friedman  br i1 %cmp.not, label %while.end, label %while.body
265d5b0876SEli Friedman
275d5b0876SEli Friedmanwhile.end:
2825640966SNikita Popov  %a.lcssa = phi ptr [ %incdec.ptr, %while.body ]
295d5b0876SEli Friedman  br label %for.body
305d5b0876SEli Friedman
315d5b0876SEli Friedmanfor.body:
325d5b0876SEli Friedman  %indvars.iv = phi i64 [ 1, %while.end ], [ %indvars.iv.next, %for.body ]
3325640966SNikita Popov  %arrayidx1 = getelementptr inbounds i32, ptr %a, i64 %indvars.iv
3425640966SNikita Popov  %v = load i32, ptr %arrayidx1, align 4
355d5b0876SEli Friedman  %add = add nsw i32 %v, 1
3625640966SNikita Popov  store i32 %add, ptr %a.lcssa, align 4
375d5b0876SEli Friedman  %indvars.iv.next = add nuw nsw i64 %indvars.iv, 1
385d5b0876SEli Friedman  %exitcond.not = icmp eq i64 %indvars.iv.next, %n2
395d5b0876SEli Friedman  br i1 %exitcond.not, label %ret, label %for.body
405d5b0876SEli Friedman
415d5b0876SEli Friedmanret:
425d5b0876SEli Friedman  ret void
435d5b0876SEli Friedman}
44