xref: /llvm-project/llvm/test/Transforms/LoopFlatten/limit-not-invariant.ll (revision 055fb7795aa219a3d274d280ec9129784f169f56)
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