1*9880d681SAndroid Build Coastguard Worker; REQUIRES: asserts 2*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -march=x86-64 | FileCheck %s --check-prefix=ASM 3*9880d681SAndroid Build Coastguard Worker; RUN: llc -debug -o /dev/null < %s -march=x86-64 2>&1 | FileCheck %s --check-prefix=DBG 4*9880d681SAndroid Build Coastguard Worker; rdar://8168938 5*9880d681SAndroid Build Coastguard Worker 6*9880d681SAndroid Build Coastguard Worker; This testcase involves SCEV normalization with the exit value from 7*9880d681SAndroid Build Coastguard Worker; one loop involved with the increment value for an addrec on another 8*9880d681SAndroid Build Coastguard Worker; loop. The expression should be properly normalized and simplified, 9*9880d681SAndroid Build Coastguard Worker; and require only a single division. 10*9880d681SAndroid Build Coastguard Worker 11*9880d681SAndroid Build Coastguard Worker; DBG-NOT: DISCARDING (NORMALIZATION ISN'T INVERTIBLE) 12*9880d681SAndroid Build Coastguard Worker; ASM: div 13*9880d681SAndroid Build Coastguard Worker; ASM-NOT: div 14*9880d681SAndroid Build Coastguard Worker 15*9880d681SAndroid Build Coastguard Worker%0 = type { %0*, %0* } 16*9880d681SAndroid Build Coastguard Worker 17*9880d681SAndroid Build Coastguard Worker@0 = private constant [13 x i8] c"Result: %lu\0A\00" ; <[13 x i8]*> [#uses=1] 18*9880d681SAndroid Build Coastguard Worker@1 = internal constant [5 x i8] c"Huh?\00" ; <[5 x i8]*> [#uses=1] 19*9880d681SAndroid Build Coastguard Worker 20*9880d681SAndroid Build Coastguard Workerdefine i32 @main(i32 %arg, i8** nocapture %arg1) nounwind { 21*9880d681SAndroid Build Coastguard Workerbb: 22*9880d681SAndroid Build Coastguard Worker %tmp = alloca %0, align 8 ; <%0*> [#uses=11] 23*9880d681SAndroid Build Coastguard Worker %tmp2 = bitcast %0* %tmp to i8* ; <i8*> [#uses=1] 24*9880d681SAndroid Build Coastguard Worker call void @llvm.memset.p0i8.i64(i8* %tmp2, i8 0, i64 16, i32 8, i1 false) nounwind 25*9880d681SAndroid Build Coastguard Worker %tmp3 = getelementptr inbounds %0, %0* %tmp, i64 0, i32 0 ; <%0**> [#uses=3] 26*9880d681SAndroid Build Coastguard Worker store %0* %tmp, %0** %tmp3 27*9880d681SAndroid Build Coastguard Worker %tmp4 = getelementptr inbounds %0, %0* %tmp, i64 0, i32 1 ; <%0**> [#uses=1] 28*9880d681SAndroid Build Coastguard Worker store %0* %tmp, %0** %tmp4 29*9880d681SAndroid Build Coastguard Worker %tmp5 = call noalias i8* @_Znwm(i64 24) nounwind ; <i8*> [#uses=2] 30*9880d681SAndroid Build Coastguard Worker %tmp6 = getelementptr inbounds i8, i8* %tmp5, i64 16 ; <i8*> [#uses=2] 31*9880d681SAndroid Build Coastguard Worker %tmp7 = icmp eq i8* %tmp6, null ; <i1> [#uses=1] 32*9880d681SAndroid Build Coastguard Worker br i1 %tmp7, label %bb10, label %bb8 33*9880d681SAndroid Build Coastguard Worker 34*9880d681SAndroid Build Coastguard Workerbb8: ; preds = %bb 35*9880d681SAndroid Build Coastguard Worker %tmp9 = bitcast i8* %tmp6 to i32* ; <i32*> [#uses=1] 36*9880d681SAndroid Build Coastguard Worker store i32 1, i32* %tmp9 37*9880d681SAndroid Build Coastguard Worker br label %bb10 38*9880d681SAndroid Build Coastguard Worker 39*9880d681SAndroid Build Coastguard Workerbb10: ; preds = %bb8, %bb 40*9880d681SAndroid Build Coastguard Worker %tmp11 = bitcast i8* %tmp5 to %0* ; <%0*> [#uses=1] 41*9880d681SAndroid Build Coastguard Worker call void @_ZNSt15_List_node_base4hookEPS_(%0* %tmp11, %0* %tmp) nounwind 42*9880d681SAndroid Build Coastguard Worker %tmp12 = load %0*, %0** %tmp3 ; <%0*> [#uses=3] 43*9880d681SAndroid Build Coastguard Worker %tmp13 = icmp eq %0* %tmp12, %tmp ; <i1> [#uses=1] 44*9880d681SAndroid Build Coastguard Worker br i1 %tmp13, label %bb14, label %bb16 45*9880d681SAndroid Build Coastguard Worker 46*9880d681SAndroid Build Coastguard Workerbb14: ; preds = %bb10 47*9880d681SAndroid Build Coastguard Worker %tmp15 = call i32 @puts(i8* getelementptr inbounds ([5 x i8], [5 x i8]* @1, i64 0, i64 0)) 48*9880d681SAndroid Build Coastguard Worker br label %bb35 49*9880d681SAndroid Build Coastguard Worker 50*9880d681SAndroid Build Coastguard Workerbb16: ; preds = %bb16, %bb10 51*9880d681SAndroid Build Coastguard Worker %tmp17 = phi i64 [ %tmp22, %bb16 ], [ 0, %bb10 ] ; <i64> [#uses=1] 52*9880d681SAndroid Build Coastguard Worker %tmp18 = phi %0* [ %tmp20, %bb16 ], [ %tmp12, %bb10 ] ; <%0*> [#uses=1] 53*9880d681SAndroid Build Coastguard Worker %tmp19 = getelementptr inbounds %0, %0* %tmp18, i64 0, i32 0 ; <%0**> [#uses=1] 54*9880d681SAndroid Build Coastguard Worker %tmp20 = load %0*, %0** %tmp19 ; <%0*> [#uses=2] 55*9880d681SAndroid Build Coastguard Worker %tmp21 = icmp eq %0* %tmp20, %tmp ; <i1> [#uses=1] 56*9880d681SAndroid Build Coastguard Worker %tmp22 = add i64 %tmp17, 1 ; <i64> [#uses=2] 57*9880d681SAndroid Build Coastguard Worker br i1 %tmp21, label %bb23, label %bb16 58*9880d681SAndroid Build Coastguard Worker 59*9880d681SAndroid Build Coastguard Workerbb23: ; preds = %bb16 60*9880d681SAndroid Build Coastguard Worker %tmp24 = udiv i64 100, %tmp22 ; <i64> [#uses=1] 61*9880d681SAndroid Build Coastguard Worker br label %bb25 62*9880d681SAndroid Build Coastguard Worker 63*9880d681SAndroid Build Coastguard Workerbb25: ; preds = %bb25, %bb23 64*9880d681SAndroid Build Coastguard Worker %tmp26 = phi i64 [ %tmp31, %bb25 ], [ 0, %bb23 ] ; <i64> [#uses=1] 65*9880d681SAndroid Build Coastguard Worker %tmp27 = phi %0* [ %tmp29, %bb25 ], [ %tmp12, %bb23 ] ; <%0*> [#uses=1] 66*9880d681SAndroid Build Coastguard Worker %tmp28 = getelementptr inbounds %0, %0* %tmp27, i64 0, i32 0 ; <%0**> [#uses=1] 67*9880d681SAndroid Build Coastguard Worker %tmp29 = load %0*, %0** %tmp28 ; <%0*> [#uses=2] 68*9880d681SAndroid Build Coastguard Worker %tmp30 = icmp eq %0* %tmp29, %tmp ; <i1> [#uses=1] 69*9880d681SAndroid Build Coastguard Worker %tmp31 = add i64 %tmp26, 1 ; <i64> [#uses=2] 70*9880d681SAndroid Build Coastguard Worker br i1 %tmp30, label %bb32, label %bb25 71*9880d681SAndroid Build Coastguard Worker 72*9880d681SAndroid Build Coastguard Workerbb32: ; preds = %bb25 73*9880d681SAndroid Build Coastguard Worker %tmp33 = mul i64 %tmp31, %tmp24 ; <i64> [#uses=1] 74*9880d681SAndroid Build Coastguard Worker %tmp34 = call i32 (i8*, ...) @printf(i8* getelementptr inbounds ([13 x i8], [13 x i8]* @0, i64 0, i64 0), i64 %tmp33) nounwind 75*9880d681SAndroid Build Coastguard Worker br label %bb35 76*9880d681SAndroid Build Coastguard Worker 77*9880d681SAndroid Build Coastguard Workerbb35: ; preds = %bb32, %bb14 78*9880d681SAndroid Build Coastguard Worker %tmp36 = load %0*, %0** %tmp3 ; <%0*> [#uses=2] 79*9880d681SAndroid Build Coastguard Worker %tmp37 = icmp eq %0* %tmp36, %tmp ; <i1> [#uses=1] 80*9880d681SAndroid Build Coastguard Worker br i1 %tmp37, label %bb44, label %bb38 81*9880d681SAndroid Build Coastguard Worker 82*9880d681SAndroid Build Coastguard Workerbb38: ; preds = %bb38, %bb35 83*9880d681SAndroid Build Coastguard Worker %tmp39 = phi %0* [ %tmp41, %bb38 ], [ %tmp36, %bb35 ] ; <%0*> [#uses=2] 84*9880d681SAndroid Build Coastguard Worker %tmp40 = getelementptr inbounds %0, %0* %tmp39, i64 0, i32 0 ; <%0**> [#uses=1] 85*9880d681SAndroid Build Coastguard Worker %tmp41 = load %0*, %0** %tmp40 ; <%0*> [#uses=2] 86*9880d681SAndroid Build Coastguard Worker %tmp42 = bitcast %0* %tmp39 to i8* ; <i8*> [#uses=1] 87*9880d681SAndroid Build Coastguard Worker call void @_ZdlPv(i8* %tmp42) nounwind 88*9880d681SAndroid Build Coastguard Worker %tmp43 = icmp eq %0* %tmp41, %tmp ; <i1> [#uses=1] 89*9880d681SAndroid Build Coastguard Worker br i1 %tmp43, label %bb44, label %bb38 90*9880d681SAndroid Build Coastguard Worker 91*9880d681SAndroid Build Coastguard Workerbb44: ; preds = %bb38, %bb35 92*9880d681SAndroid Build Coastguard Worker ret i32 0 93*9880d681SAndroid Build Coastguard Worker} 94*9880d681SAndroid Build Coastguard Worker 95*9880d681SAndroid Build Coastguard Workerdeclare i32 @printf(i8* nocapture, ...) nounwind 96*9880d681SAndroid Build Coastguard Worker 97*9880d681SAndroid Build Coastguard Workerdeclare void @_ZNSt15_List_node_base4hookEPS_(%0*, %0*) 98*9880d681SAndroid Build Coastguard Worker 99*9880d681SAndroid Build Coastguard Workerdeclare noalias i8* @_Znwm(i64) 100*9880d681SAndroid Build Coastguard Worker 101*9880d681SAndroid Build Coastguard Workerdeclare void @llvm.memset.p0i8.i64(i8* nocapture, i8, i64, i32, i1) nounwind 102*9880d681SAndroid Build Coastguard Worker 103*9880d681SAndroid Build Coastguard Workerdeclare void @_ZdlPv(i8*) nounwind 104*9880d681SAndroid Build Coastguard Worker 105*9880d681SAndroid Build Coastguard Workerdeclare i32 @puts(i8* nocapture) nounwind 106