12663a25fSSam Parker; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
22663a25fSSam Parker; RUN: opt -jump-threading -S %s -o - | FileCheck %s --check-prefix=DEFAULT
32663a25fSSam Parker; RUN: opt -jump-threading -S -jump-threading-threshold=6 %s -o - | FileCheck %s --check-prefix=OVERIDE
42663a25fSSam Parker
52663a25fSSam Parker@.str = private unnamed_addr constant [4 x i8] c"%d\0A\00", align 1
62663a25fSSam Parkerdefine i32 @test_minsize(i32 %argc, i8** nocapture readonly %argv) local_unnamed_addr #0 {
72663a25fSSam Parker; DEFAULT-LABEL: @test_minsize(
82663a25fSSam Parker; DEFAULT-NEXT:  entry:
92663a25fSSam Parker; DEFAULT-NEXT:    [[CMP:%.*]] = icmp eq i32 [[ARGC:%.*]], 2
102663a25fSSam Parker; DEFAULT-NEXT:    br i1 [[CMP]], label [[COND_TRUE:%.*]], label [[COND_END:%.*]]
112663a25fSSam Parker; DEFAULT:       cond.true:
122663a25fSSam Parker; DEFAULT-NEXT:    [[ARRAYIDX:%.*]] = getelementptr inbounds i8*, i8** [[ARGV:%.*]], i32 1
132663a25fSSam Parker; DEFAULT-NEXT:    [[TMP0:%.*]] = load i8*, i8** [[ARRAYIDX]], align 4
142663a25fSSam Parker; DEFAULT-NEXT:    [[CALL:%.*]] = tail call i32 @atoi(i8* [[TMP0]])
152663a25fSSam Parker; DEFAULT-NEXT:    br label [[COND_END]]
162663a25fSSam Parker; DEFAULT:       cond.end:
172663a25fSSam Parker; DEFAULT-NEXT:    [[COND:%.*]] = phi i32 [ [[CALL]], [[COND_TRUE]] ], [ 46, [[ENTRY:%.*]] ]
182663a25fSSam Parker; DEFAULT-NEXT:    [[TMP1:%.*]] = mul i32 [[COND]], [[COND]]
192663a25fSSam Parker; DEFAULT-NEXT:    [[TMP2:%.*]] = mul i32 [[TMP1]], [[TMP1]]
202663a25fSSam Parker; DEFAULT-NEXT:    [[TMP3:%.*]] = mul i32 [[COND]], [[TMP2]]
212663a25fSSam Parker; DEFAULT-NEXT:    [[TMP4:%.*]] = icmp sgt i32 [[COND]], 0
22*6f0ca6fdSNikita Popov; DEFAULT-NEXT:    [[COND_FR:%.*]] = freeze i1 [[TMP4]]
23*6f0ca6fdSNikita Popov; DEFAULT-NEXT:    br i1 [[COND_FR]], label [[TMP5:%.*]], label [[TMP6:%.*]]
242663a25fSSam Parker; DEFAULT:       5:
252663a25fSSam Parker; DEFAULT-NEXT:    br label [[TMP6]]
262663a25fSSam Parker; DEFAULT:       6:
272663a25fSSam Parker; DEFAULT-NEXT:    [[TMP7:%.*]] = phi i32 [ [[COND]], [[TMP5]] ], [ 0, [[COND_END]] ]
282663a25fSSam Parker; DEFAULT-NEXT:    [[TMP8:%.*]] = mul i32 [[TMP3]], [[TMP7]]
292663a25fSSam Parker; DEFAULT-NEXT:    [[CALL33:%.*]] = tail call i32 (i8*, ...) @printf(i8* nonnull dereferenceable(1) getelementptr inbounds ([4 x i8], [4 x i8]* @.str, i32 0, i32 0), i32 [[TMP8]])
302663a25fSSam Parker; DEFAULT-NEXT:    ret i32 0
312663a25fSSam Parker;
322663a25fSSam Parker; OVERIDE-LABEL: @test_minsize(
332663a25fSSam Parker; OVERIDE-NEXT:  entry:
342663a25fSSam Parker; OVERIDE-NEXT:    [[CMP:%.*]] = icmp eq i32 [[ARGC:%.*]], 2
352663a25fSSam Parker; OVERIDE-NEXT:    br i1 [[CMP]], label [[COND_END:%.*]], label [[COND_END_THREAD:%.*]]
362663a25fSSam Parker; OVERIDE:       cond.end:
372663a25fSSam Parker; OVERIDE-NEXT:    [[ARRAYIDX:%.*]] = getelementptr inbounds i8*, i8** [[ARGV:%.*]], i32 1
382663a25fSSam Parker; OVERIDE-NEXT:    [[TMP0:%.*]] = load i8*, i8** [[ARRAYIDX]], align 4
392663a25fSSam Parker; OVERIDE-NEXT:    [[CALL:%.*]] = tail call i32 @atoi(i8* [[TMP0]])
402663a25fSSam Parker; OVERIDE-NEXT:    [[TMP1:%.*]] = mul i32 [[CALL]], [[CALL]]
412663a25fSSam Parker; OVERIDE-NEXT:    [[TMP2:%.*]] = mul i32 [[TMP1]], [[TMP1]]
422663a25fSSam Parker; OVERIDE-NEXT:    [[TMP3:%.*]] = mul i32 [[CALL]], [[TMP2]]
432663a25fSSam Parker; OVERIDE-NEXT:    [[TMP4:%.*]] = icmp sgt i32 [[CALL]], 0
44*6f0ca6fdSNikita Popov; OVERIDE-NEXT:    [[COND_FR:%.*]] = freeze i1 [[TMP4]]
45*6f0ca6fdSNikita Popov; OVERIDE-NEXT:    br i1 [[COND_FR]], label [[COND_END_THREAD]], label [[TMP6:%.*]]
462663a25fSSam Parker; OVERIDE:       cond.end.thread:
472663a25fSSam Parker; OVERIDE-NEXT:    [[TMP5:%.*]] = phi i32 [ [[TMP3]], [[COND_END]] ], [ 205962976, [[ENTRY:%.*]] ]
48*6f0ca6fdSNikita Popov; OVERIDE-NEXT:    [[COND3:%.*]] = phi i32 [ [[CALL]], [[COND_END]] ], [ 46, [[ENTRY]] ]
492663a25fSSam Parker; OVERIDE-NEXT:    br label [[TMP6]]
502663a25fSSam Parker; OVERIDE:       6:
512663a25fSSam Parker; OVERIDE-NEXT:    [[TMP7:%.*]] = phi i32 [ [[TMP5]], [[COND_END_THREAD]] ], [ [[TMP3]], [[COND_END]] ]
52*6f0ca6fdSNikita Popov; OVERIDE-NEXT:    [[TMP8:%.*]] = phi i32 [ [[COND3]], [[COND_END_THREAD]] ], [ 0, [[COND_END]] ]
532663a25fSSam Parker; OVERIDE-NEXT:    [[TMP9:%.*]] = mul i32 [[TMP7]], [[TMP8]]
542663a25fSSam Parker; OVERIDE-NEXT:    [[CALL33:%.*]] = tail call i32 (i8*, ...) @printf(i8* nonnull dereferenceable(1) getelementptr inbounds ([4 x i8], [4 x i8]* @.str, i32 0, i32 0), i32 [[TMP9]])
552663a25fSSam Parker; OVERIDE-NEXT:    ret i32 0
562663a25fSSam Parker;
572663a25fSSam Parkerentry:
582663a25fSSam Parker  %cmp = icmp eq i32 %argc, 2
592663a25fSSam Parker  br i1 %cmp, label %cond.true, label %cond.end
602663a25fSSam Parker
612663a25fSSam Parkercond.true:                                        ; preds = %entry
622663a25fSSam Parker  %arrayidx = getelementptr inbounds i8*, i8** %argv, i32 1
632663a25fSSam Parker  %0 = load i8*, i8** %arrayidx, align 4
642663a25fSSam Parker  %call = tail call i32 @atoi(i8* %0)
652663a25fSSam Parker  br label %cond.end
662663a25fSSam Parker
672663a25fSSam Parkercond.end:                                         ; preds = %entry, %cond.true
682663a25fSSam Parker  %cond = phi i32 [ %call, %cond.true ], [ 46, %entry ]
692663a25fSSam Parker  %1 = mul i32 %cond, %cond
702663a25fSSam Parker  %2 = mul i32 %1, %1
712663a25fSSam Parker  %3 = mul i32 %cond, %2
722663a25fSSam Parker  %4 = icmp sgt i32 %cond, 0
732663a25fSSam Parker  %spec.select = select i1 %4, i32 %cond, i32 0
742663a25fSSam Parker  %5 = mul i32 %3, %spec.select
752663a25fSSam Parker  %call33 = tail call i32 (i8*, ...) @printf(i8* nonnull dereferenceable(1) getelementptr inbounds ([4 x i8], [4 x i8]* @.str, i32 0, i32 0), i32 %5) #4
762663a25fSSam Parker  ret i32 0
772663a25fSSam Parker}
782663a25fSSam Parker
792663a25fSSam Parkerdefine i32 @test_optsize(i32 %argc, i8** nocapture readonly %argv) local_unnamed_addr #1 {
802663a25fSSam Parker; DEFAULT-LABEL: @test_optsize(
812663a25fSSam Parker; DEFAULT-NEXT:  entry:
822663a25fSSam Parker; DEFAULT-NEXT:    [[CMP:%.*]] = icmp eq i32 [[ARGC:%.*]], 2
832663a25fSSam Parker; DEFAULT-NEXT:    br i1 [[CMP]], label [[COND_END:%.*]], label [[COND_END_THREAD:%.*]]
842663a25fSSam Parker; DEFAULT:       cond.end:
852663a25fSSam Parker; DEFAULT-NEXT:    [[ARRAYIDX:%.*]] = getelementptr inbounds i8*, i8** [[ARGV:%.*]], i32 1
862663a25fSSam Parker; DEFAULT-NEXT:    [[TMP0:%.*]] = load i8*, i8** [[ARRAYIDX]], align 4
872663a25fSSam Parker; DEFAULT-NEXT:    [[CALL:%.*]] = tail call i32 @atoi(i8* [[TMP0]])
882663a25fSSam Parker; DEFAULT-NEXT:    [[TMP1:%.*]] = mul i32 [[CALL]], [[CALL]]
892663a25fSSam Parker; DEFAULT-NEXT:    [[TMP2:%.*]] = mul i32 [[TMP1]], [[TMP1]]
902663a25fSSam Parker; DEFAULT-NEXT:    [[TMP3:%.*]] = mul i32 [[CALL]], [[TMP2]]
912663a25fSSam Parker; DEFAULT-NEXT:    [[TMP4:%.*]] = icmp sgt i32 [[CALL]], 0
92*6f0ca6fdSNikita Popov; DEFAULT-NEXT:    [[COND_FR:%.*]] = freeze i1 [[TMP4]]
93*6f0ca6fdSNikita Popov; DEFAULT-NEXT:    br i1 [[COND_FR]], label [[COND_END_THREAD]], label [[TMP6:%.*]]
942663a25fSSam Parker; DEFAULT:       cond.end.thread:
952663a25fSSam Parker; DEFAULT-NEXT:    [[TMP5:%.*]] = phi i32 [ [[TMP3]], [[COND_END]] ], [ 205962976, [[ENTRY:%.*]] ]
96*6f0ca6fdSNikita Popov; DEFAULT-NEXT:    [[COND3:%.*]] = phi i32 [ [[CALL]], [[COND_END]] ], [ 46, [[ENTRY]] ]
972663a25fSSam Parker; DEFAULT-NEXT:    br label [[TMP6]]
982663a25fSSam Parker; DEFAULT:       6:
992663a25fSSam Parker; DEFAULT-NEXT:    [[TMP7:%.*]] = phi i32 [ [[TMP5]], [[COND_END_THREAD]] ], [ [[TMP3]], [[COND_END]] ]
100*6f0ca6fdSNikita Popov; DEFAULT-NEXT:    [[TMP8:%.*]] = phi i32 [ [[COND3]], [[COND_END_THREAD]] ], [ 0, [[COND_END]] ]
1012663a25fSSam Parker; DEFAULT-NEXT:    [[TMP9:%.*]] = mul i32 [[TMP7]], [[TMP8]]
1022663a25fSSam Parker; DEFAULT-NEXT:    [[CALL33:%.*]] = tail call i32 (i8*, ...) @printf(i8* nonnull dereferenceable(1) getelementptr inbounds ([4 x i8], [4 x i8]* @.str, i32 0, i32 0), i32 [[TMP9]])
1032663a25fSSam Parker; DEFAULT-NEXT:    ret i32 0
1042663a25fSSam Parker;
1052663a25fSSam Parker; OVERIDE-LABEL: @test_optsize(
1062663a25fSSam Parker; OVERIDE-NEXT:  entry:
1072663a25fSSam Parker; OVERIDE-NEXT:    [[CMP:%.*]] = icmp eq i32 [[ARGC:%.*]], 2
1082663a25fSSam Parker; OVERIDE-NEXT:    br i1 [[CMP]], label [[COND_END:%.*]], label [[COND_END_THREAD:%.*]]
1092663a25fSSam Parker; OVERIDE:       cond.end:
1102663a25fSSam Parker; OVERIDE-NEXT:    [[ARRAYIDX:%.*]] = getelementptr inbounds i8*, i8** [[ARGV:%.*]], i32 1
1112663a25fSSam Parker; OVERIDE-NEXT:    [[TMP0:%.*]] = load i8*, i8** [[ARRAYIDX]], align 4
1122663a25fSSam Parker; OVERIDE-NEXT:    [[CALL:%.*]] = tail call i32 @atoi(i8* [[TMP0]])
1132663a25fSSam Parker; OVERIDE-NEXT:    [[TMP1:%.*]] = mul i32 [[CALL]], [[CALL]]
1142663a25fSSam Parker; OVERIDE-NEXT:    [[TMP2:%.*]] = mul i32 [[TMP1]], [[TMP1]]
1152663a25fSSam Parker; OVERIDE-NEXT:    [[TMP3:%.*]] = mul i32 [[CALL]], [[TMP2]]
1162663a25fSSam Parker; OVERIDE-NEXT:    [[TMP4:%.*]] = icmp sgt i32 [[CALL]], 0
117*6f0ca6fdSNikita Popov; OVERIDE-NEXT:    [[COND_FR:%.*]] = freeze i1 [[TMP4]]
118*6f0ca6fdSNikita Popov; OVERIDE-NEXT:    br i1 [[COND_FR]], label [[COND_END_THREAD]], label [[TMP6:%.*]]
1192663a25fSSam Parker; OVERIDE:       cond.end.thread:
1202663a25fSSam Parker; OVERIDE-NEXT:    [[TMP5:%.*]] = phi i32 [ [[TMP3]], [[COND_END]] ], [ 205962976, [[ENTRY:%.*]] ]
121*6f0ca6fdSNikita Popov; OVERIDE-NEXT:    [[COND3:%.*]] = phi i32 [ [[CALL]], [[COND_END]] ], [ 46, [[ENTRY]] ]
1222663a25fSSam Parker; OVERIDE-NEXT:    br label [[TMP6]]
1232663a25fSSam Parker; OVERIDE:       6:
1242663a25fSSam Parker; OVERIDE-NEXT:    [[TMP7:%.*]] = phi i32 [ [[TMP5]], [[COND_END_THREAD]] ], [ [[TMP3]], [[COND_END]] ]
125*6f0ca6fdSNikita Popov; OVERIDE-NEXT:    [[TMP8:%.*]] = phi i32 [ [[COND3]], [[COND_END_THREAD]] ], [ 0, [[COND_END]] ]
1262663a25fSSam Parker; OVERIDE-NEXT:    [[TMP9:%.*]] = mul i32 [[TMP7]], [[TMP8]]
1272663a25fSSam Parker; OVERIDE-NEXT:    [[CALL33:%.*]] = tail call i32 (i8*, ...) @printf(i8* nonnull dereferenceable(1) getelementptr inbounds ([4 x i8], [4 x i8]* @.str, i32 0, i32 0), i32 [[TMP9]])
1282663a25fSSam Parker; OVERIDE-NEXT:    ret i32 0
1292663a25fSSam Parker;
1302663a25fSSam Parkerentry:
1312663a25fSSam Parker  %cmp = icmp eq i32 %argc, 2
1322663a25fSSam Parker  br i1 %cmp, label %cond.true, label %cond.end
1332663a25fSSam Parker
1342663a25fSSam Parkercond.true:                                        ; preds = %entry
1352663a25fSSam Parker  %arrayidx = getelementptr inbounds i8*, i8** %argv, i32 1
1362663a25fSSam Parker  %0 = load i8*, i8** %arrayidx, align 4
1372663a25fSSam Parker  %call = tail call i32 @atoi(i8* %0)
1382663a25fSSam Parker  br label %cond.end
1392663a25fSSam Parker
1402663a25fSSam Parkercond.end:                                         ; preds = %entry, %cond.true
1412663a25fSSam Parker  %cond = phi i32 [ %call, %cond.true ], [ 46, %entry ]
1422663a25fSSam Parker  %1 = mul i32 %cond, %cond
1432663a25fSSam Parker  %2 = mul i32 %1, %1
1442663a25fSSam Parker  %3 = mul i32 %cond, %2
1452663a25fSSam Parker  %4 = icmp sgt i32 %cond, 0
1462663a25fSSam Parker  %spec.select = select i1 %4, i32 %cond, i32 0
1472663a25fSSam Parker  %5 = mul i32 %3, %spec.select
1482663a25fSSam Parker  %call33 = tail call i32 (i8*, ...) @printf(i8* nonnull dereferenceable(1) getelementptr inbounds ([4 x i8], [4 x i8]* @.str, i32 0, i32 0), i32 %5) #4
1492663a25fSSam Parker  ret i32 0
1502663a25fSSam Parker}
1512663a25fSSam Parkerdeclare i32 @atoi(i8* nocapture) local_unnamed_addr
1522663a25fSSam Parkerdeclare i32 @printf(i8* nocapture readonly, ...) local_unnamed_addr
1532663a25fSSam Parker
1542663a25fSSam Parkerattributes #0 = { minsize optsize }
1552663a25fSSam Parkerattributes #1 = { optsize }
1562663a25fSSam Parker
157