[ARM] Adjust how NEON shifts are lowered
[llvm-core.git] / test / Transforms / IndVarSimplify / signed-trip-count.ll
blob41968ac0518646d07b750e8d8b2421e036fbae6d
1 ; RUN: opt < %s -indvars -S | FileCheck %s
3 ; Provide legal integer types.
4 target datalayout = "n8:16:32:64"
7 define void @foo(i64* nocapture %x, i32 %n) nounwind {
8 ; CHECK-LABEL: @foo(
9 ; CHECK-NOT: sext
10 ; CHECK: phi
11 ; CHECK-NOT: phi
12 entry:
13         %tmp102 = icmp sgt i32 %n, 0            ; <i1> [#uses=1]
14         br i1 %tmp102, label %bb.nph, label %return
16 bb.nph:         ; preds = %entry
17         br label %bb
19 bb:             ; preds = %bb7, %bb.nph
20         %i.01 = phi i32 [ %tmp6, %bb7 ], [ 0, %bb.nph ]         ; <i32> [#uses=3]
21         %tmp1 = sext i32 %i.01 to i64           ; <i64> [#uses=1]
22         %tmp4 = getelementptr i64, i64* %x, i32 %i.01           ; <i64*> [#uses=1]
23         store i64 %tmp1, i64* %tmp4, align 8
24         %tmp6 = add i32 %i.01, 1                ; <i32> [#uses=2]
25         br label %bb7
27 bb7:            ; preds = %bb
28         %tmp10 = icmp slt i32 %tmp6, %n         ; <i1> [#uses=1]
29         br i1 %tmp10, label %bb, label %bb7.return_crit_edge
31 bb7.return_crit_edge:           ; preds = %bb7
32         br label %return
34 return:         ; preds = %bb7.return_crit_edge, %entry
35         ret void