[RISCV] Add missing SiFive P400 scheduling model test for divisions. NFC
[llvm-project.git] / llvm / test / Transforms / LoopRotate / basic.ll
blobb3c35f1edd3ea64912f73593c74bb00af815e046
1 ; RUN: opt -S -passes=loop-rotate -verify-memoryssa < %s | FileCheck %s
2 ; RUN: opt -S -passes='require<target-ir>,require<assumptions>,loop(loop-rotate)' < %s | FileCheck %s
3 ; RUN: opt -S -passes='require<target-ir>,require<assumptions>,loop-mssa(loop-rotate)' -verify-memoryssa  < %s | FileCheck %s
5 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"
6 target triple = "x86_64-apple-darwin10.0.0"
8 ; PR5319 - The "arrayidx" gep should be hoisted, not duplicated.  We should
9 ; end up with one phi node.
10 define void @test1() nounwind ssp {
11 ; CHECK-LABEL: @test1(
12 entry:
13   %array = alloca [20 x i32], align 16
14   br label %for.cond
16 for.cond:                                         ; preds = %for.body, %entry
17   %i.0 = phi i32 [ 0, %entry ], [ %inc, %for.body ]
18   %cmp = icmp slt i32 %i.0, 100
19   br i1 %cmp, label %for.body, label %for.end
21 ; CHECK: for.body:
22 ; CHECK-NEXT: phi i32 [ 0
23 ; CHECK-NEXT: store i32 0
25 for.body:                                         ; preds = %for.cond
26   store i32 0, ptr %array, align 16
27   %inc = add nsw i32 %i.0, 1
28   br label %for.cond
30 for.end:                                          ; preds = %for.cond
31   %arrayidx.lcssa = phi ptr [ %array, %for.cond ]
32   call void @g(ptr %arrayidx.lcssa) nounwind
33   ret void
36 declare void @g(ptr)
38 ; CHECK-LABEL: @test2(
39 define void @test2() nounwind ssp {
40 entry:
41   %array = alloca [20 x i32], align 16
42   br label %for.cond
44 for.cond:                                         ; preds = %for.body, %entry
45   %i.0 = phi i32 [ 0, %entry ], [ %inc, %for.body ]
46   %cmp = icmp slt i32 %i.0, 100
47 ; CHECK: call void @f
48 ; CHECK-NOT: call void @f
49   call void @f() noduplicate 
50   br i1 %cmp, label %for.body, label %for.end
52 for.body:                                         ; preds = %for.cond
53   %inc = add nsw i32 %i.0, 1
54   call void @h()
55   br label %for.cond
57 for.end:                                          ; preds = %for.cond
58   ret void
59 ; CHECK: }
62 declare void @f() noduplicate
63 declare void @h()