1 ; RUN: opt < %s -passes=indvars -S -scalar-evolution-use-expensive-range-sharpening | FileCheck %s
3 target datalayout = "e-m:e-p270:32:32-p271:32:32-p272:64:64-i64:64-f80:128-n8:16:32:64-S128-ni:1-p2:32:8:8:32-ni:2"
4 target triple = "x86_64-unknown-linux-gnu"
12 bb1: ; preds = %bb10, %bb
13 %tmp = phi i32 [ undef, %bb ], [ %tmp11, %bb10 ]
14 %tmp2 = phi i32 [ 0, %bb ], [ 1, %bb10 ]
15 br i1 false, label %bb3, label %bb4
24 %tmp6 = phi i64 [ %tmp21, %bb16 ]
25 %tmp7 = phi i64 [ undef, %bb16 ]
28 bb8: ; preds = %bb5, %bb3
29 %tmp9 = phi i64 [ undef, %bb3 ], [ %tmp6, %bb5 ]
33 %tmp11 = phi i32 [ %tmp15, %bb13 ]
34 br i1 undef, label %bb12, label %bb1
39 bb13: ; preds = %bb13, %bb8
40 %tmp14 = phi i32 [ %tmp, %bb8 ], [ %tmp15, %bb13 ]
41 %tmp15 = add i32 %tmp14, undef
42 br i1 undef, label %bb10, label %bb13
44 bb16: ; preds = %bb16, %bb4
45 %tmp17 = phi i32 [ %tmp27, %bb16 ], [ %tmp2, %bb4 ]
46 %tmp18 = phi i64 [ %tmp21, %bb16 ], [ undef, %bb4 ]
47 %tmp19 = sext i32 %tmp17 to i64
48 %tmp20 = mul i64 undef, %tmp19
49 %tmp21 = add i64 %tmp18, 1
50 %tmp22 = add i32 %tmp17, %tmp
51 %tmp23 = add i32 %tmp22, undef
52 %tmp24 = add i32 %tmp23, undef
53 %tmp25 = and i32 %tmp24, 31
54 %tmp26 = lshr i32 undef, %tmp25
55 %tmp27 = add nsw i32 %tmp17, 1
56 %tmp28 = icmp sgt i32 %tmp17, 111
57 br i1 %tmp28, label %bb5, label %bb16