120c7ab87SSjoerd Meijer; NOTE: Assertions have been autogenerated by utils/update_test_checks.py 220c7ab87SSjoerd Meijer 372482c51SRoman Lebedev; RUN: opt < %s -S -passes='loop(loop-flatten),verify' -verify-loop-info -verify-dom-info -verify-scev | FileCheck %s 420c7ab87SSjoerd Meijer 520c7ab87SSjoerd Meijertarget datalayout = "e-m:e-i8:8:32-i16:16:32-i64:64-i128:128-n32:64-S128" 620c7ab87SSjoerd Meijer 7*055fb779SNikita Popovdefine dso_local void @inner_limit_not_invariant(i32 %N, ptr nocapture %C, ptr nocapture readonly %A, i16 %val) { 820c7ab87SSjoerd Meijer; CHECK-LABEL: @inner_limit_not_invariant( 920c7ab87SSjoerd Meijer; CHECK-NEXT: entry: 1020c7ab87SSjoerd Meijer; CHECK-NEXT: [[CMP26_NOT:%.*]] = icmp eq i32 [[N:%.*]], 0 1120c7ab87SSjoerd Meijer; CHECK-NEXT: br i1 [[CMP26_NOT]], label [[FOR_END12:%.*]], label [[FOR_COND1_PREHEADER_LR_PH:%.*]] 1220c7ab87SSjoerd Meijer; CHECK: for.cond1.preheader.lr.ph: 1320c7ab87SSjoerd Meijer; CHECK-NEXT: [[CONV4:%.*]] = sext i16 [[VAL:%.*]] to i32 1420c7ab87SSjoerd Meijer; CHECK-NEXT: br label [[FOR_COND1_PREHEADER_US:%.*]] 1520c7ab87SSjoerd Meijer; CHECK: for.cond1.preheader.us: 1620c7ab87SSjoerd Meijer; CHECK-NEXT: [[I_027_US:%.*]] = phi i32 [ 0, [[FOR_COND1_PREHEADER_LR_PH]] ], [ [[INC11_US:%.*]], [[FOR_COND1_FOR_INC10_CRIT_EDGE_US:%.*]] ] 1720c7ab87SSjoerd Meijer; CHECK-NEXT: [[MUL_US:%.*]] = mul i32 [[I_027_US]], [[N]] 1820c7ab87SSjoerd Meijer; CHECK-NEXT: [[WIDE_TRIP_COUNT:%.*]] = zext i32 [[N]] to i64 1920c7ab87SSjoerd Meijer; CHECK-NEXT: br label [[FOR_BODY3_US:%.*]] 2020c7ab87SSjoerd Meijer; CHECK: for.body3.us: 2120c7ab87SSjoerd Meijer; CHECK-NEXT: [[INDVARS_IV:%.*]] = phi i64 [ 0, [[FOR_COND1_PREHEADER_US]] ], [ [[INDVARS_IV_NEXT:%.*]], [[FOR_BODY3_US]] ] 2220c7ab87SSjoerd Meijer; CHECK-NEXT: [[TMP0:%.*]] = trunc i64 [[INDVARS_IV]] to i32 2320c7ab87SSjoerd Meijer; CHECK-NEXT: [[ADD_US:%.*]] = add i32 [[TMP0]], [[MUL_US]] 2420c7ab87SSjoerd Meijer; CHECK-NEXT: [[IDXPROM_US:%.*]] = zext i32 [[ADD_US]] to i64 25*055fb779SNikita Popov; CHECK-NEXT: [[ARRAYIDX_US:%.*]] = getelementptr inbounds i16, ptr [[A:%.*]], i64 [[IDXPROM_US]] 26*055fb779SNikita Popov; CHECK-NEXT: [[TMP1:%.*]] = load i16, ptr [[ARRAYIDX_US]], align 2 2720c7ab87SSjoerd Meijer; CHECK-NEXT: [[CONV_US:%.*]] = sext i16 [[TMP1]] to i32 2820c7ab87SSjoerd Meijer; CHECK-NEXT: [[MUL5_US:%.*]] = mul nsw i32 [[CONV_US]], [[CONV4]] 29*055fb779SNikita Popov; CHECK-NEXT: [[ARRAYIDX9_US:%.*]] = getelementptr inbounds i32, ptr [[C:%.*]], i64 [[IDXPROM_US]] 30*055fb779SNikita Popov; CHECK-NEXT: store i32 [[MUL5_US]], ptr [[ARRAYIDX9_US]], align 4 3120c7ab87SSjoerd Meijer; CHECK-NEXT: [[INDVARS_IV_NEXT]] = add nuw nsw i64 [[INDVARS_IV]], 1 3220c7ab87SSjoerd Meijer; CHECK-NEXT: [[EXITCOND:%.*]] = icmp ne i64 [[INDVARS_IV_NEXT]], [[WIDE_TRIP_COUNT]] 3320c7ab87SSjoerd Meijer; CHECK-NEXT: br i1 [[EXITCOND]], label [[FOR_BODY3_US]], label [[FOR_COND1_FOR_INC10_CRIT_EDGE_US]] 3420c7ab87SSjoerd Meijer; CHECK: for.cond1.for.inc10_crit_edge.us: 3520c7ab87SSjoerd Meijer; CHECK-NEXT: [[INC11_US]] = add nuw i32 [[I_027_US]], 1 3620c7ab87SSjoerd Meijer; CHECK-NEXT: [[EXITCOND29:%.*]] = icmp ne i32 [[INC11_US]], [[N]] 3720c7ab87SSjoerd Meijer; CHECK-NEXT: br i1 [[EXITCOND29]], label [[FOR_COND1_PREHEADER_US]], label [[FOR_END12_LOOPEXIT:%.*]] 3820c7ab87SSjoerd Meijer; CHECK: for.end12.loopexit: 3920c7ab87SSjoerd Meijer; CHECK-NEXT: br label [[FOR_END12]] 4020c7ab87SSjoerd Meijer; CHECK: for.end12: 4120c7ab87SSjoerd Meijer; CHECK-NEXT: ret void 4220c7ab87SSjoerd Meijer; 4320c7ab87SSjoerd Meijerentry: 4420c7ab87SSjoerd Meijer %cmp26.not = icmp eq i32 %N, 0 4520c7ab87SSjoerd Meijer br i1 %cmp26.not, label %for.end12, label %for.cond1.preheader.lr.ph 4620c7ab87SSjoerd Meijer 4720c7ab87SSjoerd Meijerfor.cond1.preheader.lr.ph: 4820c7ab87SSjoerd Meijer %conv4 = sext i16 %val to i32 4920c7ab87SSjoerd Meijer br label %for.cond1.preheader.us 5020c7ab87SSjoerd Meijer 5120c7ab87SSjoerd Meijerfor.cond1.preheader.us: 5220c7ab87SSjoerd Meijer %i.027.us = phi i32 [ 0, %for.cond1.preheader.lr.ph ], [ %inc11.us, %for.cond1.for.inc10_crit_edge.us ] 5320c7ab87SSjoerd Meijer %mul.us = mul i32 %i.027.us, %N 5420c7ab87SSjoerd Meijer %wide.trip.count = zext i32 %N to i64 5520c7ab87SSjoerd Meijer br label %for.body3.us 5620c7ab87SSjoerd Meijer 5720c7ab87SSjoerd Meijerfor.body3.us: 5820c7ab87SSjoerd Meijer %indvars.iv = phi i64 [ 0, %for.cond1.preheader.us ], [ %indvars.iv.next, %for.body3.us ] 5920c7ab87SSjoerd Meijer %0 = trunc i64 %indvars.iv to i32 6020c7ab87SSjoerd Meijer %add.us = add i32 %0, %mul.us 6120c7ab87SSjoerd Meijer %idxprom.us = zext i32 %add.us to i64 62*055fb779SNikita Popov %arrayidx.us = getelementptr inbounds i16, ptr %A, i64 %idxprom.us 63*055fb779SNikita Popov %1 = load i16, ptr %arrayidx.us, align 2 6420c7ab87SSjoerd Meijer %conv.us = sext i16 %1 to i32 6520c7ab87SSjoerd Meijer %mul5.us = mul nsw i32 %conv.us, %conv4 66*055fb779SNikita Popov %arrayidx9.us = getelementptr inbounds i32, ptr %C, i64 %idxprom.us 67*055fb779SNikita Popov store i32 %mul5.us, ptr %arrayidx9.us, align 4 6820c7ab87SSjoerd Meijer %indvars.iv.next = add nuw nsw i64 %indvars.iv, 1 6920c7ab87SSjoerd Meijer %exitcond = icmp ne i64 %indvars.iv.next, %wide.trip.count 7020c7ab87SSjoerd Meijer br i1 %exitcond, label %for.body3.us, label %for.cond1.for.inc10_crit_edge.us 7120c7ab87SSjoerd Meijer 7220c7ab87SSjoerd Meijerfor.cond1.for.inc10_crit_edge.us: 7320c7ab87SSjoerd Meijer %inc11.us = add nuw i32 %i.027.us, 1 7420c7ab87SSjoerd Meijer %exitcond29 = icmp ne i32 %inc11.us, %N 7520c7ab87SSjoerd Meijer br i1 %exitcond29, label %for.cond1.preheader.us, label %for.end12.loopexit 7620c7ab87SSjoerd Meijer 7720c7ab87SSjoerd Meijerfor.end12.loopexit: 7820c7ab87SSjoerd Meijer br label %for.end12 7920c7ab87SSjoerd Meijer 8020c7ab87SSjoerd Meijerfor.end12: 8120c7ab87SSjoerd Meijer ret void 8220c7ab87SSjoerd Meijer} 8320c7ab87SSjoerd Meijer 84*055fb779SNikita Popovdefine dso_local void @outer_limit_not_invariant(i32 %N, ptr nocapture %C, ptr nocapture readonly %A, i16 %val, i64 %M) { 8520c7ab87SSjoerd Meijer; CHECK-LABEL: @outer_limit_not_invariant( 8620c7ab87SSjoerd Meijer; CHECK-NEXT: entry: 8720c7ab87SSjoerd Meijer; CHECK-NEXT: [[CMP26_NOT:%.*]] = icmp eq i32 [[N:%.*]], 0 8820c7ab87SSjoerd Meijer; CHECK-NEXT: br i1 [[CMP26_NOT]], label [[FOR_END12:%.*]], label [[FOR_COND1_PREHEADER_LR_PH:%.*]] 8920c7ab87SSjoerd Meijer; CHECK: for.cond1.preheader.lr.ph: 9020c7ab87SSjoerd Meijer; CHECK-NEXT: [[CONV4:%.*]] = sext i16 [[VAL:%.*]] to i32 9120c7ab87SSjoerd Meijer; CHECK-NEXT: br label [[FOR_COND1_PREHEADER_US:%.*]] 9220c7ab87SSjoerd Meijer; CHECK: for.cond1.preheader.us: 9320c7ab87SSjoerd Meijer; CHECK-NEXT: [[I_027_US:%.*]] = phi i32 [ 0, [[FOR_COND1_PREHEADER_LR_PH]] ], [ [[INC11_US:%.*]], [[FOR_COND1_FOR_INC10_CRIT_EDGE_US:%.*]] ] 9420c7ab87SSjoerd Meijer; CHECK-NEXT: [[MUL_US:%.*]] = mul i32 [[I_027_US]], [[N]] 9520c7ab87SSjoerd Meijer; CHECK-NEXT: [[TRUNC_TRIP_COUNT:%.*]] = trunc i64 [[M:%.*]] to i32 9620c7ab87SSjoerd Meijer; CHECK-NEXT: br label [[FOR_BODY3_US:%.*]] 9720c7ab87SSjoerd Meijer; CHECK: for.body3.us: 9820c7ab87SSjoerd Meijer; CHECK-NEXT: [[INDVARS_IV:%.*]] = phi i64 [ 0, [[FOR_COND1_PREHEADER_US]] ], [ [[INDVARS_IV_NEXT:%.*]], [[FOR_BODY3_US]] ] 9920c7ab87SSjoerd Meijer; CHECK-NEXT: [[TMP0:%.*]] = trunc i64 [[INDVARS_IV]] to i32 10020c7ab87SSjoerd Meijer; CHECK-NEXT: [[ADD_US:%.*]] = add i32 [[TMP0]], [[MUL_US]] 10120c7ab87SSjoerd Meijer; CHECK-NEXT: [[IDXPROM_US:%.*]] = zext i32 [[ADD_US]] to i64 102*055fb779SNikita Popov; CHECK-NEXT: [[ARRAYIDX_US:%.*]] = getelementptr inbounds i16, ptr [[A:%.*]], i64 [[IDXPROM_US]] 103*055fb779SNikita Popov; CHECK-NEXT: [[TMP1:%.*]] = load i16, ptr [[ARRAYIDX_US]], align 2 10420c7ab87SSjoerd Meijer; CHECK-NEXT: [[CONV_US:%.*]] = sext i16 [[TMP1]] to i32 10520c7ab87SSjoerd Meijer; CHECK-NEXT: [[MUL5_US:%.*]] = mul nsw i32 [[CONV_US]], [[CONV4]] 106*055fb779SNikita Popov; CHECK-NEXT: [[ARRAYIDX9_US:%.*]] = getelementptr inbounds i32, ptr [[C:%.*]], i64 [[IDXPROM_US]] 107*055fb779SNikita Popov; CHECK-NEXT: store i32 [[MUL5_US]], ptr [[ARRAYIDX9_US]], align 4 10820c7ab87SSjoerd Meijer; CHECK-NEXT: [[INDVARS_IV_NEXT]] = add nuw nsw i64 [[INDVARS_IV]], 1 10920c7ab87SSjoerd Meijer; CHECK-NEXT: [[EXITCOND:%.*]] = icmp ne i64 [[INDVARS_IV_NEXT]], [[M]] 11020c7ab87SSjoerd Meijer; CHECK-NEXT: br i1 [[EXITCOND]], label [[FOR_BODY3_US]], label [[FOR_COND1_FOR_INC10_CRIT_EDGE_US]] 11120c7ab87SSjoerd Meijer; CHECK: for.cond1.for.inc10_crit_edge.us: 11220c7ab87SSjoerd Meijer; CHECK-NEXT: [[INC11_US]] = add nuw i32 [[I_027_US]], 1 11320c7ab87SSjoerd Meijer; CHECK-NEXT: [[EXITCOND29:%.*]] = icmp ne i32 [[INC11_US]], [[TRUNC_TRIP_COUNT]] 11420c7ab87SSjoerd Meijer; CHECK-NEXT: br i1 [[EXITCOND29]], label [[FOR_COND1_PREHEADER_US]], label [[FOR_END12_LOOPEXIT:%.*]] 11520c7ab87SSjoerd Meijer; CHECK: for.end12.loopexit: 11620c7ab87SSjoerd Meijer; CHECK-NEXT: br label [[FOR_END12]] 11720c7ab87SSjoerd Meijer; CHECK: for.end12: 11820c7ab87SSjoerd Meijer; CHECK-NEXT: ret void 11920c7ab87SSjoerd Meijer; 12020c7ab87SSjoerd Meijerentry: 12120c7ab87SSjoerd Meijer %cmp26.not = icmp eq i32 %N, 0 12220c7ab87SSjoerd Meijer br i1 %cmp26.not, label %for.end12, label %for.cond1.preheader.lr.ph 12320c7ab87SSjoerd Meijer 12420c7ab87SSjoerd Meijerfor.cond1.preheader.lr.ph: 12520c7ab87SSjoerd Meijer %conv4 = sext i16 %val to i32 12620c7ab87SSjoerd Meijer br label %for.cond1.preheader.us 12720c7ab87SSjoerd Meijer 12820c7ab87SSjoerd Meijerfor.cond1.preheader.us: 12920c7ab87SSjoerd Meijer %i.027.us = phi i32 [ 0, %for.cond1.preheader.lr.ph ], [ %inc11.us, %for.cond1.for.inc10_crit_edge.us ] 13020c7ab87SSjoerd Meijer %mul.us = mul i32 %i.027.us, %N 13120c7ab87SSjoerd Meijer %trunc.trip.count = trunc i64 %M to i32 13220c7ab87SSjoerd Meijer br label %for.body3.us 13320c7ab87SSjoerd Meijer 13420c7ab87SSjoerd Meijerfor.body3.us: 13520c7ab87SSjoerd Meijer %indvars.iv = phi i64 [ 0, %for.cond1.preheader.us ], [ %indvars.iv.next, %for.body3.us ] 13620c7ab87SSjoerd Meijer %0 = trunc i64 %indvars.iv to i32 13720c7ab87SSjoerd Meijer %add.us = add i32 %0, %mul.us 13820c7ab87SSjoerd Meijer %idxprom.us = zext i32 %add.us to i64 139*055fb779SNikita Popov %arrayidx.us = getelementptr inbounds i16, ptr %A, i64 %idxprom.us 140*055fb779SNikita Popov %1 = load i16, ptr %arrayidx.us, align 2 14120c7ab87SSjoerd Meijer %conv.us = sext i16 %1 to i32 14220c7ab87SSjoerd Meijer %mul5.us = mul nsw i32 %conv.us, %conv4 143*055fb779SNikita Popov %arrayidx9.us = getelementptr inbounds i32, ptr %C, i64 %idxprom.us 144*055fb779SNikita Popov store i32 %mul5.us, ptr %arrayidx9.us, align 4 14520c7ab87SSjoerd Meijer %indvars.iv.next = add nuw nsw i64 %indvars.iv, 1 14620c7ab87SSjoerd Meijer %exitcond = icmp ne i64 %indvars.iv.next, %M 14720c7ab87SSjoerd Meijer br i1 %exitcond, label %for.body3.us, label %for.cond1.for.inc10_crit_edge.us 14820c7ab87SSjoerd Meijer 14920c7ab87SSjoerd Meijerfor.cond1.for.inc10_crit_edge.us: 15020c7ab87SSjoerd Meijer %inc11.us = add nuw i32 %i.027.us, 1 15120c7ab87SSjoerd Meijer %exitcond29 = icmp ne i32 %inc11.us, %trunc.trip.count 15220c7ab87SSjoerd Meijer br i1 %exitcond29, label %for.cond1.preheader.us, label %for.end12.loopexit 15320c7ab87SSjoerd Meijer 15420c7ab87SSjoerd Meijerfor.end12.loopexit: 15520c7ab87SSjoerd Meijer br label %for.end12 15620c7ab87SSjoerd Meijer 15720c7ab87SSjoerd Meijerfor.end12: 15820c7ab87SSjoerd Meijer ret void 15920c7ab87SSjoerd Meijer} 160