[llvm] [llvm] Remove `br i1 undef` from regression tests (PR #118419)
Lee Wei via llvm-commits
llvm-commits at lists.llvm.org
Tue Dec 3 10:28:07 PST 2024
https://github.com/leewei05 updated https://github.com/llvm/llvm-project/pull/118419
>From 9aade4839f0996668dbbb00ed227e906bb038e18 Mon Sep 17 00:00:00 2001
From: Lee <lee10202013 at gmail.com>
Date: Mon, 2 Dec 2024 19:18:04 -0700
Subject: [PATCH 01/10] Remove br i1 undef in ObjCARC directory
---
llvm/test/Transforms/ObjCARC/allocas.ll | 12 +-
llvm/test/Transforms/ObjCARC/basic.ll | 16 +-
llvm/test/Transforms/ObjCARC/cfg-hazards.ll | 98 ++--
.../Transforms/ObjCARC/contract-testcases.ll | 10 +-
llvm/test/Transforms/ObjCARC/empty-block.ll | 8 +-
llvm/test/Transforms/ObjCARC/path-overflow.ll | 446 +++++++++---------
6 files changed, 295 insertions(+), 295 deletions(-)
diff --git a/llvm/test/Transforms/ObjCARC/allocas.ll b/llvm/test/Transforms/ObjCARC/allocas.ll
index be829882ae3749..6fe2edf3e2dd48 100644
--- a/llvm/test/Transforms/ObjCARC/allocas.ll
+++ b/llvm/test/Transforms/ObjCARC/allocas.ll
@@ -109,16 +109,16 @@ entry:
}
-; CHECK: define void @test1d(ptr %x)
+; CHECK: define void @test1d(ptr %x, i1 %arg)
; CHECK: @llvm.objc.retain(ptr %x)
; CHECK: @llvm.objc.retain(ptr %x)
; CHECK: @llvm.objc.release(ptr %y)
; CHECK: @llvm.objc.release(ptr %x)
; CHECK: ret void
; CHECK: }
-define void @test1d(ptr %x) {
+define void @test1d(ptr %x, i1 %arg) {
entry:
- br i1 undef, label %use_allocaA, label %use_allocaB
+ br i1 %arg, label %use_allocaA, label %use_allocaB
use_allocaA:
%allocaA = alloca ptr
@@ -141,16 +141,16 @@ exit:
ret void
}
-; CHECK: define void @test1e(ptr %x)
+; CHECK: define void @test1e(ptr %x, i1 %arg)
; CHECK: @llvm.objc.retain(ptr %x)
; CHECK: @llvm.objc.retain(ptr %x)
; CHECK: @llvm.objc.release(ptr %y)
; CHECK: @llvm.objc.release(ptr %x)
; CHECK: ret void
; CHECK: }
-define void @test1e(ptr %x) {
+define void @test1e(ptr %x, i1 %arg) {
entry:
- br i1 undef, label %use_allocaA, label %use_allocaB
+ br i1 %arg, label %use_allocaA, label %use_allocaB
use_allocaA:
%allocaA = alloca ptr, i32 4
diff --git a/llvm/test/Transforms/ObjCARC/basic.ll b/llvm/test/Transforms/ObjCARC/basic.ll
index 0ee59dc8ba6ab7..d461bc0af680d4 100644
--- a/llvm/test/Transforms/ObjCARC/basic.ll
+++ b/llvm/test/Transforms/ObjCARC/basic.ll
@@ -1761,13 +1761,13 @@ g:
; CHECK-LABEL: define void @test39(
; CHECK-NOT: @llvm.objc.
; CHECK: {{^}}}
-define void @test39(ptr %p) {
+define void @test39(ptr %p, i1 %arg) {
entry:
%0 = call ptr @llvm.objc.retain(ptr %p)
br label %loop
loop: ; preds = %loop, %entry
- br i1 undef, label %loop, label %exit
+ br i1 %arg, label %loop, label %exit
exit: ; preds = %loop
call void @llvm.objc.release(ptr %0), !clang.imprecise_release !0
@@ -1779,14 +1779,14 @@ exit: ; preds = %loop
; CHECK-LABEL: define void @test39b(
; CHECK-NOT: @llvm.objc.
; CHECK: {{^}}}
-define void @test39b(ptr %p) {
+define void @test39b(ptr %p, i1 %arg) {
entry:
%0 = call ptr @llvm.objc.retain(ptr %p)
br label %loop
loop: ; preds = %loop, %entry
store i8 0, ptr %0
- br i1 undef, label %loop, label %exit
+ br i1 %arg, label %loop, label %exit
exit: ; preds = %loop
call void @llvm.objc.release(ptr %0), !clang.imprecise_release !0
@@ -1798,14 +1798,14 @@ exit: ; preds = %loop
; CHECK-LABEL: define void @test39c(
; CHECK-NOT: @llvm.objc.
; CHECK: {{^}}}
-define void @test39c(ptr %p) {
+define void @test39c(ptr %p, i1 %arg) {
entry:
%0 = call ptr @llvm.objc.retain(ptr %p)
br label %loop
loop: ; preds = %loop, %entry
call void @use_pointer(ptr %0)
- br i1 undef, label %loop, label %exit
+ br i1 %arg, label %loop, label %exit
exit: ; preds = %loop
call void @llvm.objc.release(ptr %0), !clang.imprecise_release !0
@@ -1818,14 +1818,14 @@ exit: ; preds = %loop
; CHECK-LABEL: define void @test40(
; CHECK-NOT: @llvm.objc.
; CHECK: {{^}}}
-define void @test40(ptr %p) {
+define void @test40(ptr %p, i1 %arg) {
entry:
%0 = call ptr @llvm.objc.retain(ptr %p)
br label %loop
loop: ; preds = %loop, %entry
call void @use_pointer(ptr %0)
- br i1 undef, label %exit, label %loop
+ br i1 %arg, label %exit, label %loop
exit: ; preds = %loop
call void @llvm.objc.release(ptr %0), !clang.imprecise_release !0
diff --git a/llvm/test/Transforms/ObjCARC/cfg-hazards.ll b/llvm/test/Transforms/ObjCARC/cfg-hazards.ll
index 3e762de689d1f4..d43f713d925e09 100644
--- a/llvm/test/Transforms/ObjCARC/cfg-hazards.ll
+++ b/llvm/test/Transforms/ObjCARC/cfg-hazards.ll
@@ -111,7 +111,7 @@ for.end: ; preds = %for.body
}
; Delete nested retain+release pairs around loops.
-define void @test3(ptr %a) nounwind {
+define void @test3(ptr %a, i1 %arg) nounwind {
; CHECK-LABEL: @test3(
; CHECK-NEXT: entry:
; CHECK-NEXT: [[OUTER:%.*]] = tail call ptr @llvm.objc.retain(ptr [[A:%.*]]) #[[ATTR0]]
@@ -119,7 +119,7 @@ define void @test3(ptr %a) nounwind {
; CHECK: loop:
; CHECK-NEXT: call void @callee()
; CHECK-NEXT: store i8 0, ptr [[A]], align 1
-; CHECK-NEXT: br i1 undef, label [[LOOP]], label [[EXIT:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[LOOP]], label [[EXIT:%.*]]
; CHECK: exit:
; CHECK-NEXT: call void @llvm.objc.release(ptr [[A]]) #[[ATTR0]], !clang.imprecise_release !0
; CHECK-NEXT: ret void
@@ -132,7 +132,7 @@ entry:
loop:
call void @callee()
store i8 0, ptr %a
- br i1 undef, label %loop, label %exit
+ br i1 %arg, label %loop, label %exit
exit:
call void @llvm.objc.release(ptr %a) nounwind
@@ -140,7 +140,7 @@ exit:
ret void
}
-define void @test4(ptr %a) nounwind {
+define void @test4(ptr %a, i1 %arg) nounwind {
; CHECK-LABEL: @test4(
; CHECK-NEXT: entry:
; CHECK-NEXT: [[OUTER:%.*]] = tail call ptr @llvm.objc.retain(ptr [[A:%.*]]) #[[ATTR0]]
@@ -151,7 +151,7 @@ define void @test4(ptr %a) nounwind {
; CHECK-NEXT: call void @callee()
; CHECK-NEXT: call void @callee()
; CHECK-NEXT: store i8 0, ptr [[A]], align 1
-; CHECK-NEXT: br i1 undef, label [[LOOP]], label [[EXIT:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[LOOP]], label [[EXIT:%.*]]
; CHECK: exit:
; CHECK-NEXT: call void @llvm.objc.release(ptr [[A]]) #[[ATTR0]], !clang.imprecise_release !0
; CHECK-NEXT: ret void
@@ -168,7 +168,7 @@ more:
call void @callee()
call void @callee()
store i8 0, ptr %a
- br i1 undef, label %loop, label %exit
+ br i1 %arg, label %loop, label %exit
exit:
call void @llvm.objc.release(ptr %a) nounwind
@@ -176,18 +176,18 @@ exit:
ret void
}
-define void @test5(ptr %a) nounwind {
+define void @test5(ptr %a, i1 %arg) nounwind {
; CHECK-LABEL: @test5(
; CHECK-NEXT: entry:
; CHECK-NEXT: [[OUTER:%.*]] = tail call ptr @llvm.objc.retain(ptr [[A:%.*]]) #[[ATTR0]]
; CHECK-NEXT: call void @callee()
; CHECK-NEXT: br label [[LOOP:%.*]]
; CHECK: loop:
-; CHECK-NEXT: br i1 undef, label [[TRUE:%.*]], label [[MORE:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[TRUE:%.*]], label [[MORE:%.*]]
; CHECK: true:
; CHECK-NEXT: br label [[MORE]]
; CHECK: more:
-; CHECK-NEXT: br i1 undef, label [[EXIT:%.*]], label [[LOOP]]
+; CHECK-NEXT: br i1 %arg, label [[EXIT:%.*]], label [[LOOP]]
; CHECK: exit:
; CHECK-NEXT: call void @use_pointer(ptr [[A]])
; CHECK-NEXT: call void @llvm.objc.release(ptr [[A]]) #[[ATTR0]], !clang.imprecise_release !0
@@ -200,13 +200,13 @@ entry:
br label %loop
loop:
- br i1 undef, label %true, label %more
+ br i1 %arg, label %true, label %more
true:
br label %more
more:
- br i1 undef, label %exit, label %loop
+ br i1 %arg, label %exit, label %loop
exit:
call void @use_pointer(ptr %a)
@@ -215,18 +215,18 @@ exit:
ret void
}
-define void @test6(ptr %a) nounwind {
+define void @test6(ptr %a, i1 %arg) nounwind {
; CHECK-LABEL: @test6(
; CHECK-NEXT: entry:
; CHECK-NEXT: [[OUTER:%.*]] = tail call ptr @llvm.objc.retain(ptr [[A:%.*]]) #[[ATTR0]]
; CHECK-NEXT: br label [[LOOP:%.*]]
; CHECK: loop:
-; CHECK-NEXT: br i1 undef, label [[TRUE:%.*]], label [[MORE:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[TRUE:%.*]], label [[MORE:%.*]]
; CHECK: true:
; CHECK-NEXT: call void @callee()
; CHECK-NEXT: br label [[MORE]]
; CHECK: more:
-; CHECK-NEXT: br i1 undef, label [[EXIT:%.*]], label [[LOOP]]
+; CHECK-NEXT: br i1 %arg, label [[EXIT:%.*]], label [[LOOP]]
; CHECK: exit:
; CHECK-NEXT: call void @use_pointer(ptr [[A]])
; CHECK-NEXT: call void @llvm.objc.release(ptr [[A]]) #[[ATTR0]], !clang.imprecise_release !0
@@ -238,14 +238,14 @@ entry:
br label %loop
loop:
- br i1 undef, label %true, label %more
+ br i1 %arg, label %true, label %more
true:
call void @callee()
br label %more
more:
- br i1 undef, label %exit, label %loop
+ br i1 %arg, label %exit, label %loop
exit:
call void @use_pointer(ptr %a)
@@ -254,19 +254,19 @@ exit:
ret void
}
-define void @test7(ptr %a) nounwind {
+define void @test7(ptr %a, i1 %arg) nounwind {
; CHECK-LABEL: @test7(
; CHECK-NEXT: entry:
; CHECK-NEXT: [[OUTER:%.*]] = tail call ptr @llvm.objc.retain(ptr [[A:%.*]]) #[[ATTR0]]
; CHECK-NEXT: call void @callee()
; CHECK-NEXT: br label [[LOOP:%.*]]
; CHECK: loop:
-; CHECK-NEXT: br i1 undef, label [[TRUE:%.*]], label [[MORE:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[TRUE:%.*]], label [[MORE:%.*]]
; CHECK: true:
; CHECK-NEXT: call void @use_pointer(ptr [[A]])
; CHECK-NEXT: br label [[MORE]]
; CHECK: more:
-; CHECK-NEXT: br i1 undef, label [[EXIT:%.*]], label [[LOOP]]
+; CHECK-NEXT: br i1 %arg, label [[EXIT:%.*]], label [[LOOP]]
; CHECK: exit:
; CHECK-NEXT: call void @llvm.objc.release(ptr [[A]]) #[[ATTR0]], !clang.imprecise_release !0
; CHECK-NEXT: ret void
@@ -278,14 +278,14 @@ entry:
br label %loop
loop:
- br i1 undef, label %true, label %more
+ br i1 %arg, label %true, label %more
true:
call void @use_pointer(ptr %a)
br label %more
more:
- br i1 undef, label %exit, label %loop
+ br i1 %arg, label %exit, label %loop
exit:
call void @llvm.objc.release(ptr %a) nounwind
@@ -293,19 +293,19 @@ exit:
ret void
}
-define void @test8(ptr %a) nounwind {
+define void @test8(ptr %a, i1 %arg) nounwind {
; CHECK-LABEL: @test8(
; CHECK-NEXT: entry:
; CHECK-NEXT: [[OUTER:%.*]] = tail call ptr @llvm.objc.retain(ptr [[A:%.*]]) #[[ATTR0]]
; CHECK-NEXT: br label [[LOOP:%.*]]
; CHECK: loop:
-; CHECK-NEXT: br i1 undef, label [[TRUE:%.*]], label [[MORE:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[TRUE:%.*]], label [[MORE:%.*]]
; CHECK: true:
; CHECK-NEXT: call void @callee()
; CHECK-NEXT: call void @use_pointer(ptr [[A]])
; CHECK-NEXT: br label [[MORE]]
; CHECK: more:
-; CHECK-NEXT: br i1 undef, label [[EXIT:%.*]], label [[LOOP]]
+; CHECK-NEXT: br i1 %arg, label [[EXIT:%.*]], label [[LOOP]]
; CHECK: exit:
; CHECK-NEXT: call void @llvm.objc.release(ptr [[A]]) #[[ATTR0]], !clang.imprecise_release !0
; CHECK-NEXT: ret void
@@ -316,7 +316,7 @@ entry:
br label %loop
loop:
- br i1 undef, label %true, label %more
+ br i1 %arg, label %true, label %more
true:
call void @callee()
@@ -324,7 +324,7 @@ true:
br label %more
more:
- br i1 undef, label %exit, label %loop
+ br i1 %arg, label %exit, label %loop
exit:
call void @llvm.objc.release(ptr %a) nounwind
@@ -332,17 +332,17 @@ exit:
ret void
}
-define void @test9(ptr %a) nounwind {
+define void @test9(ptr %a, i1 %arg) nounwind {
; CHECK-LABEL: @test9(
; CHECK-NEXT: entry:
; CHECK-NEXT: br label [[LOOP:%.*]]
; CHECK: loop:
-; CHECK-NEXT: br i1 undef, label [[TRUE:%.*]], label [[MORE:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[TRUE:%.*]], label [[MORE:%.*]]
; CHECK: true:
; CHECK-NEXT: call void @use_pointer(ptr [[A:%.*]])
; CHECK-NEXT: br label [[MORE]]
; CHECK: more:
-; CHECK-NEXT: br i1 undef, label [[EXIT:%.*]], label [[LOOP]]
+; CHECK-NEXT: br i1 %arg, label [[EXIT:%.*]], label [[LOOP]]
; CHECK: exit:
; CHECK-NEXT: ret void
;
@@ -352,14 +352,14 @@ entry:
br label %loop
loop:
- br i1 undef, label %true, label %more
+ br i1 %arg, label %true, label %more
true:
call void @use_pointer(ptr %a)
br label %more
more:
- br i1 undef, label %exit, label %loop
+ br i1 %arg, label %exit, label %loop
exit:
call void @llvm.objc.release(ptr %a) nounwind
@@ -367,17 +367,17 @@ exit:
ret void
}
-define void @test10(ptr %a) nounwind {
+define void @test10(ptr %a, i1 %arg) nounwind {
; CHECK-LABEL: @test10(
; CHECK-NEXT: entry:
; CHECK-NEXT: br label [[LOOP:%.*]]
; CHECK: loop:
-; CHECK-NEXT: br i1 undef, label [[TRUE:%.*]], label [[MORE:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[TRUE:%.*]], label [[MORE:%.*]]
; CHECK: true:
; CHECK-NEXT: call void @callee()
; CHECK-NEXT: br label [[MORE]]
; CHECK: more:
-; CHECK-NEXT: br i1 undef, label [[EXIT:%.*]], label [[LOOP]]
+; CHECK-NEXT: br i1 %arg, label [[EXIT:%.*]], label [[LOOP]]
; CHECK: exit:
; CHECK-NEXT: ret void
;
@@ -387,14 +387,14 @@ entry:
br label %loop
loop:
- br i1 undef, label %true, label %more
+ br i1 %arg, label %true, label %more
true:
call void @callee()
br label %more
more:
- br i1 undef, label %exit, label %loop
+ br i1 %arg, label %exit, label %loop
exit:
call void @llvm.objc.release(ptr %a) nounwind
@@ -402,16 +402,16 @@ exit:
ret void
}
-define void @test11(ptr %a) nounwind {
+define void @test11(ptr %a, i1 %arg) nounwind {
; CHECK-LABEL: @test11(
; CHECK-NEXT: entry:
; CHECK-NEXT: br label [[LOOP:%.*]]
; CHECK: loop:
-; CHECK-NEXT: br i1 undef, label [[TRUE:%.*]], label [[MORE:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[TRUE:%.*]], label [[MORE:%.*]]
; CHECK: true:
; CHECK-NEXT: br label [[MORE]]
; CHECK: more:
-; CHECK-NEXT: br i1 undef, label [[EXIT:%.*]], label [[LOOP]]
+; CHECK-NEXT: br i1 %arg, label [[EXIT:%.*]], label [[LOOP]]
; CHECK: exit:
; CHECK-NEXT: ret void
;
@@ -421,13 +421,13 @@ entry:
br label %loop
loop:
- br i1 undef, label %true, label %more
+ br i1 %arg, label %true, label %more
true:
br label %more
more:
- br i1 undef, label %exit, label %loop
+ br i1 %arg, label %exit, label %loop
exit:
call void @llvm.objc.release(ptr %a) nounwind
@@ -437,18 +437,18 @@ exit:
; Don't delete anything if they're not balanced.
-define void @test12(ptr %a) nounwind {
+define void @test12(ptr %a, i1 %arg) nounwind {
; CHECK-LABEL: @test12(
; CHECK-NEXT: entry:
; CHECK-NEXT: [[OUTER:%.*]] = tail call ptr @llvm.objc.retain(ptr [[A:%.*]]) #[[ATTR0]]
; CHECK-NEXT: [[INNER:%.*]] = tail call ptr @llvm.objc.retain(ptr [[A]]) #[[ATTR0]]
; CHECK-NEXT: br label [[LOOP:%.*]]
; CHECK: loop:
-; CHECK-NEXT: br i1 undef, label [[TRUE:%.*]], label [[MORE:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[TRUE:%.*]], label [[MORE:%.*]]
; CHECK: true:
; CHECK-NEXT: ret void
; CHECK: more:
-; CHECK-NEXT: br i1 undef, label [[EXIT:%.*]], label [[LOOP]]
+; CHECK-NEXT: br i1 %arg, label [[EXIT:%.*]], label [[LOOP]]
; CHECK: exit:
; CHECK-NEXT: call void @llvm.objc.release(ptr [[A]]) #[[ATTR0]]
; CHECK-NEXT: call void @llvm.objc.release(ptr [[A]]) #[[ATTR0]], !clang.imprecise_release !0
@@ -460,13 +460,13 @@ entry:
br label %loop
loop:
- br i1 undef, label %true, label %more
+ br i1 %arg, label %true, label %more
true:
ret void
more:
- br i1 undef, label %exit, label %loop
+ br i1 %arg, label %exit, label %loop
exit:
call void @llvm.objc.release(ptr %a) nounwind
@@ -479,7 +479,7 @@ exit:
; by an alloca.
; rdar://12969722
-define void @test13(ptr %a) nounwind {
+define void @test13(ptr %a, i1 %arg) nounwind {
; CHECK-LABEL: @test13(
; CHECK-NEXT: entry:
; CHECK-NEXT: [[BLOCK:%.*]] = alloca ptr, align 8
@@ -491,7 +491,7 @@ define void @test13(ptr %a) nounwind {
; CHECK-NEXT: call void @block_callee(ptr [[BLOCK]])
; CHECK-NEXT: [[RELOADED_A:%.*]] = load ptr, ptr [[BLOCK]], align 8
; CHECK-NEXT: call void @llvm.objc.release(ptr [[RELOADED_A]]) #[[ATTR0]], !clang.imprecise_release !0
-; CHECK-NEXT: br i1 undef, label [[LOOP]], label [[EXIT:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[LOOP]], label [[EXIT:%.*]]
; CHECK: exit:
; CHECK-NEXT: call void @llvm.objc.release(ptr [[A]]) #[[ATTR0]], !clang.imprecise_release !0
; CHECK-NEXT: ret void
@@ -507,7 +507,7 @@ loop:
call void @block_callee(ptr %block)
%reloaded_a = load ptr, ptr %block, align 8
call void @llvm.objc.release(ptr %reloaded_a) nounwind, !clang.imprecise_release !0
- br i1 undef, label %loop, label %exit
+ br i1 %arg, label %loop, label %exit
exit:
call void @llvm.objc.release(ptr %a) nounwind, !clang.imprecise_release !0
diff --git a/llvm/test/Transforms/ObjCARC/contract-testcases.ll b/llvm/test/Transforms/ObjCARC/contract-testcases.ll
index 36fe49382e4136..4c842823b54e07 100644
--- a/llvm/test/Transforms/ObjCARC/contract-testcases.ll
+++ b/llvm/test/Transforms/ObjCARC/contract-testcases.ll
@@ -19,13 +19,13 @@ declare i32 @__gxx_personality_sj0(...)
; Don't get in trouble on bugpointed code.
; CHECK-LABEL: define void @test0(
-define void @test0() {
+define void @test0(i1 %arg) {
bb:
%tmp1 = tail call ptr @llvm.objc.retainAutoreleasedReturnValue(ptr undef) nounwind
br label %bb3
bb3: ; preds = %bb2
- br i1 undef, label %bb6, label %bb4
+ br i1 %arg, label %bb6, label %bb4
bb4: ; preds = %bb3
switch i64 undef, label %bb5 [
@@ -45,15 +45,15 @@ bb6: ; preds = %bb5, %bb4, %bb4, %b
; for the same block, use the exactly same value in each block.
; CHECK-LABEL: define void @test1(
-; CHECK: br i1 undef, label %bb7, label %bb7
+; CHECK: br i1 %arg, label %bb7, label %bb7
; CHECK: bb7:
; CHECK: %tmp8 = phi ptr [ %tmp3, %bb ], [ %tmp3, %bb ]
; CHECK: }
-define void @test1() {
+define void @test1(i1 %arg) {
bb:
%tmp = tail call ptr @objc_msgSend()
%tmp3 = tail call ptr @llvm.objc.retainAutoreleasedReturnValue(ptr %tmp) nounwind
- br i1 undef, label %bb7, label %bb7
+ br i1 %arg, label %bb7, label %bb7
bb7: ; preds = %bb6, %bb6, %bb5
%tmp8 = phi ptr [ %tmp, %bb ], [ %tmp, %bb ]
diff --git a/llvm/test/Transforms/ObjCARC/empty-block.ll b/llvm/test/Transforms/ObjCARC/empty-block.ll
index 80930812fc7e97..be70beeeb731da 100644
--- a/llvm/test/Transforms/ObjCARC/empty-block.ll
+++ b/llvm/test/Transforms/ObjCARC/empty-block.ll
@@ -18,9 +18,9 @@ declare ptr @llvm.objc.autoreleaseReturnValue(ptr)
; CHECK: @llvm.objc.autoreleaseReturnValue
; CHECK-NOT: @llvm.objc.
; CHECK: }
-define ptr @test0(ptr %buffer) nounwind {
+define ptr @test0(ptr %buffer, i1 %arg) nounwind {
%1 = tail call ptr @llvm.objc.retain(ptr %buffer) nounwind
- br i1 undef, label %.lr.ph, label %._crit_edge
+ br i1 %arg, label %.lr.ph, label %._crit_edge
.lr.ph: ; preds = %.lr.ph, %0
br i1 false, label %.lr.ph, label %._crit_edge
@@ -37,10 +37,10 @@ define ptr @test0(ptr %buffer) nounwind {
; CHECK-LABEL: define ptr @test1(
; CHECK-NOT: @objc
; CHECK: }
-define ptr @test1() nounwind {
+define ptr @test1(i1 %arg) nounwind {
%buffer = call ptr @foo()
%1 = tail call ptr @llvm.objc.retain(ptr %buffer) nounwind
- br i1 undef, label %.lr.ph, label %._crit_edge
+ br i1 %arg, label %.lr.ph, label %._crit_edge
.lr.ph: ; preds = %.lr.ph, %0
br i1 false, label %.lr.ph, label %._crit_edge
diff --git a/llvm/test/Transforms/ObjCARC/path-overflow.ll b/llvm/test/Transforms/ObjCARC/path-overflow.ll
index eeef70554d1148..431b3774812629 100644
--- a/llvm/test/Transforms/ObjCARC/path-overflow.ll
+++ b/llvm/test/Transforms/ObjCARC/path-overflow.ll
@@ -29,9 +29,9 @@ declare i32 @__gxx_personality_sj0(...)
declare i32 @__objc_personality_v0(...)
-define hidden void @test1() personality ptr @__gxx_personality_sj0 {
+define hidden void @test1(i1 %arg) personality ptr @__gxx_personality_sj0 {
entry:
- br i1 undef, label %msgSend.nullinit, label %msgSend.call
+ br i1 %arg, label %msgSend.nullinit, label %msgSend.call
msgSend.call: ; preds = %entry
br label %msgSend.cont
@@ -41,7 +41,7 @@ msgSend.nullinit: ; preds = %entry
msgSend.cont: ; preds = %msgSend.nullinit, %msgSend.call
%0 = call ptr @llvm.objc.retain(ptr @_unnamed_cfstring) nounwind
- br i1 undef, label %msgSend.nullinit33, label %msgSend.call32
+ br i1 %arg, label %msgSend.nullinit33, label %msgSend.call32
msgSend.call32: ; preds = %if.end10
br label %msgSend.cont34
@@ -50,7 +50,7 @@ msgSend.nullinit33: ; preds = %if.end10
br label %msgSend.cont34
msgSend.cont34: ; preds = %msgSend.nullinit33, %msgSend.call32
- br i1 undef, label %msgSend.nullinit38, label %msgSend.call37
+ br i1 %arg, label %msgSend.nullinit38, label %msgSend.call37
msgSend.call37: ; preds = %msgSend.cont34
br label %msgSend.cont39
@@ -59,7 +59,7 @@ msgSend.nullinit38: ; preds = %msgSend.cont34
br label %msgSend.cont39
msgSend.cont39: ; preds = %msgSend.nullinit38, %msgSend.call37
- br i1 undef, label %msgSend.nullinit49, label %msgSend.call48
+ br i1 %arg, label %msgSend.nullinit49, label %msgSend.call48
msgSend.call48: ; preds = %msgSend.cont39
br label %msgSend.cont50
@@ -68,7 +68,7 @@ msgSend.nullinit49: ; preds = %msgSend.cont39
br label %msgSend.cont50
msgSend.cont50: ; preds = %msgSend.nullinit49, %msgSend.call48
- br i1 undef, label %msgSend.nullinit61, label %msgSend.call60
+ br i1 %arg, label %msgSend.nullinit61, label %msgSend.call60
msgSend.call60: ; preds = %msgSend.cont50
br label %msgSend.cont62
@@ -77,7 +77,7 @@ msgSend.nullinit61: ; preds = %msgSend.cont50
br label %msgSend.cont62
msgSend.cont62: ; preds = %msgSend.nullinit61, %msgSend.call60
- br i1 undef, label %msgSend.nullinit67, label %msgSend.call66
+ br i1 %arg, label %msgSend.nullinit67, label %msgSend.call66
msgSend.call66: ; preds = %msgSend.cont62
br label %msgSend.cont68
@@ -86,7 +86,7 @@ msgSend.nullinit67: ; preds = %msgSend.cont62
br label %msgSend.cont68
msgSend.cont68: ; preds = %msgSend.nullinit67, %msgSend.call66
- br i1 undef, label %msgSend.nullinit84, label %msgSend.call83
+ br i1 %arg, label %msgSend.nullinit84, label %msgSend.call83
msgSend.call83: ; preds = %msgSend.cont68
br label %msgSend.cont85
@@ -95,7 +95,7 @@ msgSend.nullinit84: ; preds = %msgSend.cont68
br label %msgSend.cont85
msgSend.cont85: ; preds = %msgSend.nullinit84, %msgSend.call83
- br i1 undef, label %msgSend.nullinit90, label %msgSend.call89
+ br i1 %arg, label %msgSend.nullinit90, label %msgSend.call89
msgSend.call89: ; preds = %msgSend.cont85
br label %msgSend.cont91
@@ -104,7 +104,7 @@ msgSend.nullinit90: ; preds = %msgSend.cont85
br label %msgSend.cont91
msgSend.cont91: ; preds = %msgSend.nullinit90, %msgSend.call89
- br i1 undef, label %msgSend.nullinit104, label %msgSend.call103
+ br i1 %arg, label %msgSend.nullinit104, label %msgSend.call103
msgSend.call103: ; preds = %msgSend.cont91
br label %msgSend.cont105
@@ -113,16 +113,16 @@ msgSend.nullinit104: ; preds = %msgSend.cont91
br label %msgSend.cont105
msgSend.cont105: ; preds = %msgSend.nullinit104, %msgSend.call103
- br i1 undef, label %land.lhs.true, label %if.end123
+ br i1 %arg, label %land.lhs.true, label %if.end123
land.lhs.true: ; preds = %msgSend.cont105
- br i1 undef, label %if.then117, label %if.end123
+ br i1 %arg, label %if.then117, label %if.end123
if.then117: ; preds = %land.lhs.true
br label %if.end123
if.end123: ; preds = %if.then117, %land.lhs.true, %msgSend.cont105
- br i1 undef, label %msgSend.nullinit132, label %msgSend.call131
+ br i1 %arg, label %msgSend.nullinit132, label %msgSend.call131
msgSend.call131: ; preds = %if.end123
br label %msgSend.cont133
@@ -131,7 +131,7 @@ msgSend.nullinit132: ; preds = %if.end123
br label %msgSend.cont133
msgSend.cont133: ; preds = %msgSend.nullinit132, %msgSend.call131
- br i1 undef, label %msgSend.nullinit139, label %msgSend.call138
+ br i1 %arg, label %msgSend.nullinit139, label %msgSend.call138
msgSend.call138: ; preds = %msgSend.cont133
br label %msgSend.cont140
@@ -140,13 +140,13 @@ msgSend.nullinit139: ; preds = %msgSend.cont133
br label %msgSend.cont140
msgSend.cont140: ; preds = %msgSend.nullinit139, %msgSend.call138
- br i1 undef, label %if.then151, label %if.end157
+ br i1 %arg, label %if.then151, label %if.end157
if.then151: ; preds = %msgSend.cont140
br label %if.end157
if.end157: ; preds = %if.then151, %msgSend.cont140
- br i1 undef, label %msgSend.nullinit164, label %msgSend.call163
+ br i1 %arg, label %msgSend.nullinit164, label %msgSend.call163
msgSend.call163: ; preds = %if.end157
br label %msgSend.cont165
@@ -155,7 +155,7 @@ msgSend.nullinit164: ; preds = %if.end157
br label %msgSend.cont165
msgSend.cont165: ; preds = %msgSend.nullinit164, %msgSend.call163
- br i1 undef, label %msgSend.nullinit176, label %msgSend.call175
+ br i1 %arg, label %msgSend.nullinit176, label %msgSend.call175
msgSend.call175: ; preds = %msgSend.cont165
br label %msgSend.cont177
@@ -164,13 +164,13 @@ msgSend.nullinit176: ; preds = %msgSend.cont165
br label %msgSend.cont177
msgSend.cont177: ; preds = %msgSend.nullinit176, %msgSend.call175
- br i1 undef, label %land.lhs.true181, label %if.end202
+ br i1 %arg, label %land.lhs.true181, label %if.end202
land.lhs.true181: ; preds = %msgSend.cont177
- br i1 undef, label %if.then187, label %if.end202
+ br i1 %arg, label %if.then187, label %if.end202
if.then187: ; preds = %land.lhs.true181
- br i1 undef, label %msgSend.nullinit199, label %msgSend.call198
+ br i1 %arg, label %msgSend.nullinit199, label %msgSend.call198
msgSend.call198: ; preds = %if.then187
br label %msgSend.cont200
@@ -182,7 +182,7 @@ msgSend.cont200: ; preds = %msgSend.nullinit199
br label %if.end202
if.end202: ; preds = %msgSend.cont200, %land.lhs.true181, %msgSend.cont177
- br i1 undef, label %msgSend.nullinit236, label %msgSend.call235
+ br i1 %arg, label %msgSend.nullinit236, label %msgSend.call235
msgSend.call235: ; preds = %if.end202
br label %msgSend.cont237
@@ -191,7 +191,7 @@ msgSend.nullinit236: ; preds = %if.end202
br label %msgSend.cont237
msgSend.cont237: ; preds = %msgSend.nullinit236, %msgSend.call235
- br i1 undef, label %msgSend.nullinit254, label %msgSend.call253
+ br i1 %arg, label %msgSend.nullinit254, label %msgSend.call253
msgSend.call253: ; preds = %msgSend.cont237
br label %msgSend.cont255
@@ -200,7 +200,7 @@ msgSend.nullinit254: ; preds = %msgSend.cont237
br label %msgSend.cont255
msgSend.cont255: ; preds = %msgSend.nullinit254, %msgSend.call253
- br i1 undef, label %msgSend.nullinit269, label %msgSend.call268
+ br i1 %arg, label %msgSend.nullinit269, label %msgSend.call268
msgSend.call268: ; preds = %msgSend.cont255
br label %msgSend.cont270
@@ -209,7 +209,7 @@ msgSend.nullinit269: ; preds = %msgSend.cont255
br label %msgSend.cont270
msgSend.cont270: ; preds = %msgSend.nullinit269, %msgSend.call268
- br i1 undef, label %msgSend.nullinit281, label %msgSend.call280
+ br i1 %arg, label %msgSend.nullinit281, label %msgSend.call280
msgSend.call280: ; preds = %msgSend.cont270
br label %msgSend.cont282
@@ -218,7 +218,7 @@ msgSend.nullinit281: ; preds = %msgSend.cont270
br label %msgSend.cont282
msgSend.cont282: ; preds = %msgSend.nullinit281, %msgSend.call280
- br i1 undef, label %msgSend.nullinit287, label %msgSend.call286
+ br i1 %arg, label %msgSend.nullinit287, label %msgSend.call286
msgSend.call286: ; preds = %msgSend.cont282
br label %msgSend.cont288
@@ -227,7 +227,7 @@ msgSend.nullinit287: ; preds = %msgSend.cont282
br label %msgSend.cont288
msgSend.cont288: ; preds = %msgSend.nullinit287, %msgSend.call286
- br i1 undef, label %msgSend.nullinit303, label %msgSend.call302
+ br i1 %arg, label %msgSend.nullinit303, label %msgSend.call302
msgSend.call302: ; preds = %msgSend.cont288
br label %msgSend.cont304
@@ -236,7 +236,7 @@ msgSend.nullinit303: ; preds = %msgSend.cont288
br label %msgSend.cont304
msgSend.cont304: ; preds = %msgSend.nullinit303, %msgSend.call302
- br i1 undef, label %msgSend.nullinit344, label %msgSend.call343
+ br i1 %arg, label %msgSend.nullinit344, label %msgSend.call343
msgSend.call343: ; preds = %msgSend.cont304
br label %msgSend.cont345
@@ -245,7 +245,7 @@ msgSend.nullinit344: ; preds = %msgSend.cont304
br label %msgSend.cont345
msgSend.cont345: ; preds = %msgSend.nullinit344, %msgSend.call343
- br i1 undef, label %msgSend.nullinit350, label %msgSend.call349
+ br i1 %arg, label %msgSend.nullinit350, label %msgSend.call349
msgSend.call349: ; preds = %msgSend.cont345
br label %msgSend.cont351
@@ -254,7 +254,7 @@ msgSend.nullinit350: ; preds = %msgSend.cont345
br label %msgSend.cont351
msgSend.cont351: ; preds = %msgSend.nullinit350, %msgSend.call349
- br i1 undef, label %msgSend.nullinit366, label %msgSend.call365
+ br i1 %arg, label %msgSend.nullinit366, label %msgSend.call365
msgSend.call365: ; preds = %msgSend.cont351
br label %msgSend.cont367
@@ -263,7 +263,7 @@ msgSend.nullinit366: ; preds = %msgSend.cont351
br label %msgSend.cont367
msgSend.cont367: ; preds = %msgSend.nullinit366, %msgSend.call365
- br i1 undef, label %msgSend.nullinit376, label %msgSend.call375
+ br i1 %arg, label %msgSend.nullinit376, label %msgSend.call375
msgSend.call375: ; preds = %msgSend.cont367
br label %msgSend.cont377
@@ -272,10 +272,10 @@ msgSend.nullinit376: ; preds = %msgSend.cont367
br label %msgSend.cont377
msgSend.cont377: ; preds = %msgSend.nullinit376, %msgSend.call375
- br i1 undef, label %if.then384, label %if.else401
+ br i1 %arg, label %if.then384, label %if.else401
if.then384: ; preds = %msgSend.cont377
- br i1 undef, label %msgSend.nullinit392, label %msgSend.call391
+ br i1 %arg, label %msgSend.nullinit392, label %msgSend.call391
msgSend.call391: ; preds = %if.then384
br label %msgSend.cont393
@@ -287,7 +287,7 @@ msgSend.cont393: ; preds = %msgSend.nullinit392
br label %if.end418
if.else401: ; preds = %msgSend.cont377
- br i1 undef, label %msgSend.nullinit409, label %msgSend.call408
+ br i1 %arg, label %msgSend.nullinit409, label %msgSend.call408
msgSend.call408: ; preds = %if.else401
br label %msgSend.cont410
@@ -299,7 +299,7 @@ msgSend.cont410: ; preds = %msgSend.nullinit409
br label %if.end418
if.end418: ; preds = %msgSend.cont410, %msgSend.cont393
- br i1 undef, label %msgSend.nullinit470, label %msgSend.call469
+ br i1 %arg, label %msgSend.nullinit470, label %msgSend.call469
msgSend.call469: ; preds = %if.end418
br label %msgSend.cont471
@@ -308,7 +308,7 @@ msgSend.nullinit470: ; preds = %if.end418
br label %msgSend.cont471
msgSend.cont471: ; preds = %msgSend.nullinit470, %msgSend.call469
- br i1 undef, label %msgSend.nullinit484, label %msgSend.call483
+ br i1 %arg, label %msgSend.nullinit484, label %msgSend.call483
msgSend.call483: ; preds = %msgSend.cont471
br label %msgSend.cont485
@@ -317,7 +317,7 @@ msgSend.nullinit484: ; preds = %msgSend.cont471
br label %msgSend.cont485
msgSend.cont485: ; preds = %msgSend.nullinit484, %msgSend.call483
- br i1 undef, label %msgSend.nullinit500, label %msgSend.call499
+ br i1 %arg, label %msgSend.nullinit500, label %msgSend.call499
msgSend.call499: ; preds = %msgSend.cont485
br label %msgSend.cont501
@@ -326,7 +326,7 @@ msgSend.nullinit500: ; preds = %msgSend.cont485
br label %msgSend.cont501
msgSend.cont501: ; preds = %msgSend.nullinit500, %msgSend.call499
- br i1 undef, label %msgSend.nullinit506, label %msgSend.call505
+ br i1 %arg, label %msgSend.nullinit506, label %msgSend.call505
msgSend.call505: ; preds = %msgSend.cont501
br label %msgSend.cont507
@@ -340,78 +340,78 @@ msgSend.cont507: ; preds = %msgSend.nullinit506
}
; Function Attrs: optsize ssp uwtable
-define void @test2() unnamed_addr align 2 personality ptr @__gxx_personality_sj0 {
+define void @test2(i1 %arg) unnamed_addr align 2 personality ptr @__gxx_personality_sj0 {
bb:
- br i1 undef, label %bb3, label %bb2
+ br i1 %arg, label %bb3, label %bb2
bb2: ; preds = %bb
br label %bb3
bb3: ; preds = %bb2, %bb
- br i1 undef, label %bb5, label %bb4
+ br i1 %arg, label %bb5, label %bb4
bb4: ; preds = %bb3
br label %bb5
bb5: ; preds = %bb4, %bb3
- br i1 undef, label %bb7, label %bb6
+ br i1 %arg, label %bb7, label %bb6
bb6: ; preds = %bb5
br label %bb7
bb7: ; preds = %bb6, %bb5
- br i1 undef, label %bb9, label %bb8
+ br i1 %arg, label %bb9, label %bb8
bb8: ; preds = %bb7
unreachable
bb9: ; preds = %bb7
- br i1 undef, label %bb11, label %bb10
+ br i1 %arg, label %bb11, label %bb10
bb10: ; preds = %bb9
br label %bb11
bb11: ; preds = %bb10, %bb9
- br i1 undef, label %bb13, label %bb12
+ br i1 %arg, label %bb13, label %bb12
bb12: ; preds = %bb11
br label %bb13
bb13: ; preds = %bb12, %bb11
- br i1 undef, label %bb15, label %bb14
+ br i1 %arg, label %bb15, label %bb14
bb14: ; preds = %bb13
br label %bb15
bb15: ; preds = %bb14, %bb13
- br i1 undef, label %bb17, label %bb16
+ br i1 %arg, label %bb17, label %bb16
bb16: ; preds = %bb15
br label %bb17
bb17: ; preds = %bb16, %bb15
- br i1 undef, label %bb19, label %bb18
+ br i1 %arg, label %bb19, label %bb18
bb18: ; preds = %bb17
br label %bb19
bb19: ; preds = %bb18, %bb17
- br i1 undef, label %bb222, label %bb20
+ br i1 %arg, label %bb222, label %bb20
bb20: ; preds = %bb19
- br i1 undef, label %bb222, label %bb21
+ br i1 %arg, label %bb222, label %bb21
bb21: ; preds = %bb20
- br i1 undef, label %bb22, label %bb30
+ br i1 %arg, label %bb22, label %bb30
bb22: ; preds = %bb21
- br i1 undef, label %bb23, label %bb32
+ br i1 %arg, label %bb23, label %bb32
bb23: ; preds = %bb22
- br i1 undef, label %bb24, label %bb34
+ br i1 %arg, label %bb24, label %bb34
bb24: ; preds = %bb23
- br i1 undef, label %bb26, label %bb25
+ br i1 %arg, label %bb26, label %bb25
bb25: ; preds = %bb24
br label %bb27
@@ -420,10 +420,10 @@ bb26: ; preds = %bb24
br label %bb27
bb27: ; preds = %bb26, %bb25
- br i1 undef, label %bb28, label %bb42
+ br i1 %arg, label %bb28, label %bb42
bb28: ; preds = %bb27
- br i1 undef, label %bb36, label %bb29
+ br i1 %arg, label %bb36, label %bb29
bb29: ; preds = %bb28
br label %bb36
@@ -438,7 +438,7 @@ bb34: ; preds = %bb23
unreachable
bb36: ; preds = %bb29, %bb28
- br i1 undef, label %bb38, label %bb37
+ br i1 %arg, label %bb38, label %bb37
bb37: ; preds = %bb36
br label %bb39
@@ -447,7 +447,7 @@ bb38: ; preds = %bb36
br label %bb39
bb39: ; preds = %bb38, %bb37
- br i1 undef, label %bb41, label %bb40
+ br i1 %arg, label %bb41, label %bb40
bb40: ; preds = %bb39
unreachable
@@ -456,19 +456,19 @@ bb41: ; preds = %bb39
br label %bb42
bb42: ; preds = %bb41, %bb27
- br i1 undef, label %bb43, label %bb214
+ br i1 %arg, label %bb43, label %bb214
bb43: ; preds = %bb42
- br i1 undef, label %bb47, label %bb45
+ br i1 %arg, label %bb47, label %bb45
bb45: ; preds = %bb130, %bb128, %bb126, %bb124, %bb122, %bb120, %bb118, %bb116, %bb114, %bb112, %bb110, %bb108, %bb105, %bb102, %bb100, %bb96, %bb94, %bb90, %bb88, %bb84, %bb82, %bb78, %bb76, %bb72, %bb70, %bb66, %bb64, %bb60, %bb58, %bb54, %bb51, %bb43
unreachable
bb47: ; preds = %bb43
- br i1 undef, label %bb48, label %bb106
+ br i1 %arg, label %bb48, label %bb106
bb48: ; preds = %bb47
- br i1 undef, label %bb50, label %bb49
+ br i1 %arg, label %bb50, label %bb49
bb49: ; preds = %bb48
br label %bb51
@@ -477,16 +477,16 @@ bb50: ; preds = %bb48
br label %bb51
bb51: ; preds = %bb50, %bb49
- br i1 undef, label %bb53, label %bb45
+ br i1 %arg, label %bb53, label %bb45
bb53: ; preds = %bb51
- br i1 undef, label %bb54, label %bb134
+ br i1 %arg, label %bb54, label %bb134
bb54: ; preds = %bb53
- br i1 undef, label %bb55, label %bb45
+ br i1 %arg, label %bb55, label %bb45
bb55: ; preds = %bb54
- br i1 undef, label %bb57, label %bb56
+ br i1 %arg, label %bb57, label %bb56
bb56: ; preds = %bb55
br label %bb58
@@ -495,13 +495,13 @@ bb57: ; preds = %bb55
br label %bb58
bb58: ; preds = %bb57, %bb56
- br i1 undef, label %bb60, label %bb45
+ br i1 %arg, label %bb60, label %bb45
bb60: ; preds = %bb58
- br i1 undef, label %bb61, label %bb45
+ br i1 %arg, label %bb61, label %bb45
bb61: ; preds = %bb60
- br i1 undef, label %bb63, label %bb62
+ br i1 %arg, label %bb63, label %bb62
bb62: ; preds = %bb61
br label %bb64
@@ -510,13 +510,13 @@ bb63: ; preds = %bb61
br label %bb64
bb64: ; preds = %bb63, %bb62
- br i1 undef, label %bb66, label %bb45
+ br i1 %arg, label %bb66, label %bb45
bb66: ; preds = %bb64
- br i1 undef, label %bb67, label %bb45
+ br i1 %arg, label %bb67, label %bb45
bb67: ; preds = %bb66
- br i1 undef, label %bb69, label %bb68
+ br i1 %arg, label %bb69, label %bb68
bb68: ; preds = %bb67
br label %bb70
@@ -525,13 +525,13 @@ bb69: ; preds = %bb67
br label %bb70
bb70: ; preds = %bb69, %bb68
- br i1 undef, label %bb72, label %bb45
+ br i1 %arg, label %bb72, label %bb45
bb72: ; preds = %bb70
- br i1 undef, label %bb73, label %bb45
+ br i1 %arg, label %bb73, label %bb45
bb73: ; preds = %bb72
- br i1 undef, label %bb75, label %bb74
+ br i1 %arg, label %bb75, label %bb74
bb74: ; preds = %bb73
br label %bb76
@@ -540,13 +540,13 @@ bb75: ; preds = %bb73
br label %bb76
bb76: ; preds = %bb75, %bb74
- br i1 undef, label %bb78, label %bb45
+ br i1 %arg, label %bb78, label %bb45
bb78: ; preds = %bb76
- br i1 undef, label %bb79, label %bb45
+ br i1 %arg, label %bb79, label %bb45
bb79: ; preds = %bb78
- br i1 undef, label %bb81, label %bb80
+ br i1 %arg, label %bb81, label %bb80
bb80: ; preds = %bb79
br label %bb82
@@ -555,13 +555,13 @@ bb81: ; preds = %bb79
br label %bb82
bb82: ; preds = %bb81, %bb80
- br i1 undef, label %bb84, label %bb45
+ br i1 %arg, label %bb84, label %bb45
bb84: ; preds = %bb82
- br i1 undef, label %bb85, label %bb45
+ br i1 %arg, label %bb85, label %bb45
bb85: ; preds = %bb84
- br i1 undef, label %bb87, label %bb86
+ br i1 %arg, label %bb87, label %bb86
bb86: ; preds = %bb85
br label %bb88
@@ -570,13 +570,13 @@ bb87: ; preds = %bb85
br label %bb88
bb88: ; preds = %bb87, %bb86
- br i1 undef, label %bb90, label %bb45
+ br i1 %arg, label %bb90, label %bb45
bb90: ; preds = %bb88
- br i1 undef, label %bb91, label %bb45
+ br i1 %arg, label %bb91, label %bb45
bb91: ; preds = %bb90
- br i1 undef, label %bb93, label %bb92
+ br i1 %arg, label %bb93, label %bb92
bb92: ; preds = %bb91
br label %bb94
@@ -585,13 +585,13 @@ bb93: ; preds = %bb91
br label %bb94
bb94: ; preds = %bb93, %bb92
- br i1 undef, label %bb96, label %bb45
+ br i1 %arg, label %bb96, label %bb45
bb96: ; preds = %bb94
- br i1 undef, label %bb97, label %bb45
+ br i1 %arg, label %bb97, label %bb45
bb97: ; preds = %bb96
- br i1 undef, label %bb99, label %bb98
+ br i1 %arg, label %bb99, label %bb98
bb98: ; preds = %bb97
br label %bb100
@@ -600,82 +600,82 @@ bb99: ; preds = %bb97
br label %bb100
bb100: ; preds = %bb99, %bb98
- br i1 undef, label %bb102, label %bb45
+ br i1 %arg, label %bb102, label %bb45
bb102: ; preds = %bb100
- br i1 undef, label %bb104, label %bb45
+ br i1 %arg, label %bb104, label %bb45
bb104: ; preds = %bb102
- br i1 undef, label %bb108, label %bb105
+ br i1 %arg, label %bb108, label %bb105
bb105: ; preds = %bb104
- br i1 undef, label %bb108, label %bb45
+ br i1 %arg, label %bb108, label %bb45
bb106: ; preds = %bb47
unreachable
bb108: ; preds = %bb105, %bb104
- br i1 undef, label %bb110, label %bb45
+ br i1 %arg, label %bb110, label %bb45
bb110: ; preds = %bb108
- br i1 undef, label %bb112, label %bb45
+ br i1 %arg, label %bb112, label %bb45
bb112: ; preds = %bb110
- br i1 undef, label %bb114, label %bb45
+ br i1 %arg, label %bb114, label %bb45
bb114: ; preds = %bb112
- br i1 undef, label %bb116, label %bb45
+ br i1 %arg, label %bb116, label %bb45
bb116: ; preds = %bb114
- br i1 undef, label %bb118, label %bb45
+ br i1 %arg, label %bb118, label %bb45
bb118: ; preds = %bb116
- br i1 undef, label %bb120, label %bb45
+ br i1 %arg, label %bb120, label %bb45
bb120: ; preds = %bb118
- br i1 undef, label %bb122, label %bb45
+ br i1 %arg, label %bb122, label %bb45
bb122: ; preds = %bb120
- br i1 undef, label %bb124, label %bb45
+ br i1 %arg, label %bb124, label %bb45
bb124: ; preds = %bb122
- br i1 undef, label %bb126, label %bb45
+ br i1 %arg, label %bb126, label %bb45
bb126: ; preds = %bb124
- br i1 undef, label %bb128, label %bb45
+ br i1 %arg, label %bb128, label %bb45
bb128: ; preds = %bb126
- br i1 undef, label %bb130, label %bb45
+ br i1 %arg, label %bb130, label %bb45
bb130: ; preds = %bb128
- br i1 undef, label %bb132, label %bb45
+ br i1 %arg, label %bb132, label %bb45
bb132: ; preds = %bb130
- br i1 undef, label %bb135, label %bb30
+ br i1 %arg, label %bb135, label %bb30
bb134: ; preds = %bb53
unreachable
bb135: ; preds = %bb132
- br i1 undef, label %bb139, label %bb136
+ br i1 %arg, label %bb139, label %bb136
bb136: ; preds = %bb135
- br i1 undef, label %bb138, label %bb30
+ br i1 %arg, label %bb138, label %bb30
bb138: ; preds = %bb136
br label %bb139
bb139: ; preds = %bb138, %bb135
- br i1 undef, label %bb140, label %bb141
+ br i1 %arg, label %bb140, label %bb141
bb140: ; preds = %bb139
unreachable
bb141: ; preds = %bb139
- br i1 undef, label %bb142, label %bb215
+ br i1 %arg, label %bb142, label %bb215
bb142: ; preds = %bb141
- br i1 undef, label %bb144, label %bb143
+ br i1 %arg, label %bb144, label %bb143
bb143: ; preds = %bb142
br label %bb145
@@ -684,16 +684,16 @@ bb144: ; preds = %bb142
br label %bb145
bb145: ; preds = %bb144, %bb143
- br i1 undef, label %bb146, label %bb151
+ br i1 %arg, label %bb146, label %bb151
bb146: ; preds = %bb145
- br i1 undef, label %bb148, label %bb153
+ br i1 %arg, label %bb148, label %bb153
bb148: ; preds = %bb146
- br i1 undef, label %bb155, label %bb149
+ br i1 %arg, label %bb155, label %bb149
bb149: ; preds = %bb148
- br i1 undef, label %bb150, label %bb153
+ br i1 %arg, label %bb150, label %bb153
bb150: ; preds = %bb149
br label %bb155
@@ -705,7 +705,7 @@ bb153: ; preds = %bb158, %bb149, %bb1
unreachable
bb155: ; preds = %bb150, %bb148
- br i1 undef, label %bb157, label %bb156
+ br i1 %arg, label %bb157, label %bb156
bb156: ; preds = %bb155
br label %bb158
@@ -714,10 +714,10 @@ bb157: ; preds = %bb155
br label %bb158
bb158: ; preds = %bb157, %bb156
- br i1 undef, label %bb160, label %bb153
+ br i1 %arg, label %bb160, label %bb153
bb160: ; preds = %bb158
- br i1 undef, label %bb162, label %bb161
+ br i1 %arg, label %bb162, label %bb161
bb161: ; preds = %bb160
br label %bb163
@@ -726,16 +726,16 @@ bb162: ; preds = %bb160
br label %bb163
bb163: ; preds = %bb162, %bb161
- br i1 undef, label %bb165, label %bb164
+ br i1 %arg, label %bb165, label %bb164
bb164: ; preds = %bb163
br label %bb165
bb165: ; preds = %bb164, %bb163
- br i1 undef, label %bb170, label %bb166
+ br i1 %arg, label %bb170, label %bb166
bb166: ; preds = %bb165
- br i1 undef, label %bb167, label %bb168
+ br i1 %arg, label %bb167, label %bb168
bb167: ; preds = %bb166
unreachable
@@ -744,25 +744,25 @@ bb168: ; preds = %bb166
unreachable
bb170: ; preds = %bb165
- br i1 undef, label %bb215, label %bb171
+ br i1 %arg, label %bb215, label %bb171
bb171: ; preds = %bb170
- br i1 undef, label %bb173, label %bb30
+ br i1 %arg, label %bb173, label %bb30
bb173: ; preds = %bb171
- br i1 undef, label %bb174, label %bb215
+ br i1 %arg, label %bb174, label %bb215
bb174: ; preds = %bb173
- br i1 undef, label %bb176, label %bb30
+ br i1 %arg, label %bb176, label %bb30
bb176: ; preds = %bb174
- br i1 undef, label %bb178, label %bb30
+ br i1 %arg, label %bb178, label %bb30
bb178: ; preds = %bb176
- br i1 undef, label %bb179, label %bb193
+ br i1 %arg, label %bb179, label %bb193
bb179: ; preds = %bb178
- br i1 undef, label %bb181, label %bb180
+ br i1 %arg, label %bb181, label %bb180
bb180: ; preds = %bb179
br label %bb182
@@ -771,23 +771,23 @@ bb181: ; preds = %bb179
br label %bb182
bb182: ; preds = %bb181, %bb180
- br i1 undef, label %bb184, label %bb30
+ br i1 %arg, label %bb184, label %bb30
bb184: ; preds = %bb182
%tmp185 = call ptr @returner()
- br i1 undef, label %bb186, label %bb195
+ br i1 %arg, label %bb186, label %bb195
bb186: ; preds = %bb184
%tmp188 = call ptr @llvm.objc.retainAutoreleasedReturnValue(ptr %tmp185)
%tmp189 = call ptr @llvm.objc.retain(ptr %tmp188)
call void @llvm.objc.release(ptr %tmp189), !clang.imprecise_release !0
- br i1 undef, label %bb197, label %bb190
+ br i1 %arg, label %bb197, label %bb190
bb190: ; preds = %bb186
- br i1 undef, label %bb192, label %bb195
+ br i1 %arg, label %bb192, label %bb195
bb192: ; preds = %bb190
- br i1 undef, label %bb197, label %bb195
+ br i1 %arg, label %bb197, label %bb195
bb193: ; preds = %bb178
br label %bb213
@@ -796,37 +796,37 @@ bb195: ; preds = %bb192, %bb190, %bb1
unreachable
bb197: ; preds = %bb192, %bb186
- br i1 undef, label %bb198, label %bb215
+ br i1 %arg, label %bb198, label %bb215
bb198: ; preds = %bb197
- br i1 undef, label %bb202, label %bb199
+ br i1 %arg, label %bb202, label %bb199
bb199: ; preds = %bb198
- br i1 undef, label %bb201, label %bb30
+ br i1 %arg, label %bb201, label %bb30
bb201: ; preds = %bb199
br label %bb202
bb202: ; preds = %bb201, %bb198
- br i1 undef, label %bb206, label %bb203
+ br i1 %arg, label %bb206, label %bb203
bb203: ; preds = %bb202
- br i1 undef, label %bb205, label %bb30
+ br i1 %arg, label %bb205, label %bb30
bb205: ; preds = %bb203
br label %bb206
bb206: ; preds = %bb205, %bb202
- br i1 undef, label %bb210, label %bb207
+ br i1 %arg, label %bb210, label %bb207
bb207: ; preds = %bb206
- br i1 undef, label %bb209, label %bb30
+ br i1 %arg, label %bb209, label %bb30
bb209: ; preds = %bb207
br label %bb210
bb210: ; preds = %bb209, %bb206
- br i1 undef, label %bb212, label %bb30
+ br i1 %arg, label %bb212, label %bb30
bb212: ; preds = %bb210
unreachable
@@ -838,19 +838,19 @@ bb214: ; preds = %bb42
br label %bb219
bb215: ; preds = %bb197, %bb173, %bb170, %bb141
- br i1 undef, label %bb217, label %bb216
+ br i1 %arg, label %bb217, label %bb216
bb216: ; preds = %bb215
br label %bb217
bb217: ; preds = %bb216, %bb215
- br i1 undef, label %bb219, label %bb218
+ br i1 %arg, label %bb219, label %bb218
bb218: ; preds = %bb217
br label %bb219
bb219: ; preds = %bb218, %bb217, %bb214
- br i1 undef, label %bb221, label %bb220
+ br i1 %arg, label %bb221, label %bb220
bb220: ; preds = %bb219
unreachable
@@ -863,7 +863,7 @@ bb222: ; preds = %bb20, %bb19
}
; Function Attrs: ssp
-define void @test3() #1 personality ptr @__gxx_personality_sj0 {
+define void @test3(i1 %arg) #1 personality ptr @__gxx_personality_sj0 {
entry:
%call2 = invoke ptr @objc_msgSend(ptr undef, ptr undef, ptr @_unnamed_cfstring)
to label %invoke.cont unwind label %lpad
@@ -873,7 +873,7 @@ invoke.cont: ; preds = %entry
to label %invoke.cont4 unwind label %lpad3
invoke.cont4: ; preds = %invoke.cont
- br i1 undef, label %land.end, label %land.rhs
+ br i1 %arg, label %land.end, label %land.rhs
land.rhs: ; preds = %invoke.cont4
%call7 = invoke i32 @objc_msgSend(ptr undef, ptr undef)
@@ -884,7 +884,7 @@ land.end: ; preds = %land.rhs, %invoke.c
to label %invoke.cont.i unwind label %lpad.i
invoke.cont.i: ; preds = %land.end
- br i1 undef, label %invoke.cont8, label %if.then.i
+ br i1 %arg, label %invoke.cont8, label %if.then.i
if.then.i: ; preds = %invoke.cont.i
br label %invoke.cont8
@@ -907,7 +907,7 @@ invoke.cont21: ; preds = %invoke.cont17
to label %invoke.cont.i1980 unwind label %lpad.i1982
invoke.cont.i1980: ; preds = %invoke.cont21
- br i1 undef, label %invoke.cont24, label %if.then.i1981
+ br i1 %arg, label %invoke.cont24, label %if.then.i1981
if.then.i1981: ; preds = %invoke.cont.i1980
br label %invoke.cont24
@@ -922,7 +922,7 @@ invoke.cont24: ; preds = %if.then.i1981, %inv
to label %invoke.cont36 unwind label %lpad35
invoke.cont36: ; preds = %invoke.cont24
- br i1 undef, label %land.end43, label %land.rhs39
+ br i1 %arg, label %land.end43, label %land.rhs39
land.rhs39: ; preds = %invoke.cont36
%call41 = invoke signext i8 @objc_msgSend(ptr undef, ptr undef, ptr @_unnamed_cfstring)
@@ -933,7 +933,7 @@ land.end43: ; preds = %land.rhs39, %invoke
to label %invoke.cont.i1986 unwind label %lpad.i1988
invoke.cont.i1986: ; preds = %land.end43
- br i1 undef, label %invoke.cont44, label %if.then.i1987
+ br i1 %arg, label %invoke.cont44, label %if.then.i1987
if.then.i1987: ; preds = %invoke.cont.i1986
br label %invoke.cont44
@@ -948,7 +948,7 @@ invoke.cont44: ; preds = %if.then.i1987, %inv
to label %invoke.cont52 unwind label %lpad51
invoke.cont52: ; preds = %invoke.cont44
- br i1 undef, label %land.end70, label %land.rhs58
+ br i1 %arg, label %land.end70, label %land.rhs58
land.rhs58: ; preds = %invoke.cont52
%call63 = invoke ptr @objc_msgSend(ptr undef, ptr undef, i32 42)
@@ -963,7 +963,7 @@ land.end70: ; preds = %invoke.cont62, %inv
to label %invoke.cont.i1992 unwind label %lpad66.body
invoke.cont.i1992: ; preds = %land.end70
- br i1 undef, label %invoke.cont71, label %if.then.i1993
+ br i1 %arg, label %invoke.cont71, label %if.then.i1993
if.then.i1993: ; preds = %invoke.cont.i1992
br label %invoke.cont71
@@ -973,7 +973,7 @@ invoke.cont71: ; preds = %if.then.i1993, %inv
to label %invoke.cont.i1998 unwind label %lpad.i2000
invoke.cont.i1998: ; preds = %invoke.cont71
- br i1 undef, label %invoke.cont91, label %if.then.i1999
+ br i1 %arg, label %invoke.cont91, label %if.then.i1999
if.then.i1999: ; preds = %invoke.cont.i1998
br label %invoke.cont91
@@ -996,7 +996,7 @@ invoke.cont97: ; preds = %invoke.cont95
to label %invoke.cont.i2004 unwind label %lpad.i2006
invoke.cont.i2004: ; preds = %invoke.cont97
- br i1 undef, label %invoke.cont100, label %if.then.i2005
+ br i1 %arg, label %invoke.cont100, label %if.then.i2005
if.then.i2005: ; preds = %invoke.cont.i2004
br label %invoke.cont100
@@ -1015,7 +1015,7 @@ invoke.cont110: ; preds = %invoke.cont100
to label %invoke.cont.i2010 unwind label %lpad.i2012
invoke.cont.i2010: ; preds = %invoke.cont110
- br i1 undef, label %invoke.cont117, label %if.then.i2011
+ br i1 %arg, label %invoke.cont117, label %if.then.i2011
if.then.i2011: ; preds = %invoke.cont.i2010
br label %invoke.cont117
@@ -1094,7 +1094,7 @@ lpad109: ; preds = %invoke.cont100
unreachable
invoke.cont.i2022: ; preds = %invoke.cont117
- br i1 undef, label %invoke.cont157, label %if.then.i2023
+ br i1 %arg, label %invoke.cont157, label %if.then.i2023
if.then.i2023: ; preds = %invoke.cont.i2022
br label %invoke.cont157
@@ -1104,7 +1104,7 @@ invoke.cont157: ; preds = %if.then.i2023, %inv
to label %invoke.cont.i2028 unwind label %lpad164.body
invoke.cont.i2028: ; preds = %invoke.cont157
- br i1 undef, label %invoke.cont165, label %if.then.i2029
+ br i1 %arg, label %invoke.cont165, label %if.then.i2029
if.then.i2029: ; preds = %invoke.cont.i2028
br label %invoke.cont165
@@ -1122,7 +1122,7 @@ invoke.cont185: ; preds = %invoke.cont184
to label %invoke.cont.i2034 unwind label %lpad.i2036
invoke.cont.i2034: ; preds = %invoke.cont185
- br i1 undef, label %invoke.cont190, label %if.then.i2035
+ br i1 %arg, label %invoke.cont190, label %if.then.i2035
if.then.i2035: ; preds = %invoke.cont.i2034
br label %invoke.cont190
@@ -1149,7 +1149,7 @@ invoke.cont204: ; preds = %invoke.cont201
to label %invoke.cont.i2040 unwind label %lpad.i2042
invoke.cont.i2040: ; preds = %invoke.cont204
- br i1 undef, label %invoke.cont207, label %if.then.i2041
+ br i1 %arg, label %invoke.cont207, label %if.then.i2041
if.then.i2041: ; preds = %invoke.cont.i2040
br label %invoke.cont207
@@ -1168,7 +1168,7 @@ invoke.cont208: ; preds = %invoke.cont207
to label %invoke.cont.i2046 unwind label %lpad212.body
invoke.cont.i2046: ; preds = %invoke.cont208
- br i1 undef, label %invoke.cont213, label %if.then.i2047
+ br i1 %arg, label %invoke.cont213, label %if.then.i2047
if.then.i2047: ; preds = %invoke.cont.i2046
br label %invoke.cont213
@@ -1186,7 +1186,7 @@ invoke.cont228: ; preds = %invoke.cont221
to label %invoke.cont.i2052 unwind label %lpad.i2054
invoke.cont.i2052: ; preds = %invoke.cont228
- br i1 undef, label %invoke.cont231, label %if.then.i2053
+ br i1 %arg, label %invoke.cont231, label %if.then.i2053
if.then.i2053: ; preds = %invoke.cont.i2052
br label %invoke.cont231
@@ -1205,7 +1205,7 @@ invoke.cont232: ; preds = %invoke.cont231
to label %invoke.cont.i2058 unwind label %lpad236.body
invoke.cont.i2058: ; preds = %invoke.cont232
- br i1 undef, label %invoke.cont237, label %if.then.i2059
+ br i1 %arg, label %invoke.cont237, label %if.then.i2059
if.then.i2059: ; preds = %invoke.cont.i2058
br label %invoke.cont237
@@ -1251,7 +1251,7 @@ invoke.cont278: ; preds = %invoke.cont274
to label %invoke.cont.i2064 unwind label %lpad.i2066
invoke.cont.i2064: ; preds = %invoke.cont278
- br i1 undef, label %invoke.cont281, label %if.then.i2065
+ br i1 %arg, label %invoke.cont281, label %if.then.i2065
if.then.i2065: ; preds = %invoke.cont.i2064
br label %invoke.cont281
@@ -1286,7 +1286,7 @@ invoke.cont315: ; preds = %invoke.cont312
to label %invoke.cont321 unwind label %lpad320
invoke.cont321: ; preds = %invoke.cont315
- br i1 undef, label %land.end344, label %land.rhs335
+ br i1 %arg, label %land.end344, label %land.rhs335
land.rhs335: ; preds = %invoke.cont321
%call342 = invoke signext i8 @objc_msgSend(ptr undef, ptr undef, ptr @_unnamed_cfstring)
@@ -1297,7 +1297,7 @@ land.end344: ; preds = %land.rhs335, %invok
to label %invoke.cont.i2070 unwind label %lpad340.body
invoke.cont.i2070: ; preds = %land.end344
- br i1 undef, label %invoke.cont345, label %if.then.i2071
+ br i1 %arg, label %invoke.cont345, label %if.then.i2071
if.then.i2071: ; preds = %invoke.cont.i2070
br label %invoke.cont345
@@ -1319,7 +1319,7 @@ invoke.cont370: ; preds = %invoke.cont364
to label %invoke.cont.i2076 unwind label %lpad.i2078
invoke.cont.i2076: ; preds = %invoke.cont370
- br i1 undef, label %invoke.cont373, label %if.then.i2077
+ br i1 %arg, label %invoke.cont373, label %if.then.i2077
if.then.i2077: ; preds = %invoke.cont.i2076
br label %invoke.cont373
@@ -1346,7 +1346,7 @@ invoke.cont383: ; preds = %invoke.cont382
to label %invoke.cont.i2082 unwind label %lpad.i2084
invoke.cont.i2082: ; preds = %invoke.cont383
- br i1 undef, label %invoke.cont392, label %if.then.i2083
+ br i1 %arg, label %invoke.cont392, label %if.then.i2083
if.then.i2083: ; preds = %invoke.cont.i2082
br label %invoke.cont392
@@ -1377,7 +1377,7 @@ invoke.cont402: ; preds = %invoke.cont399
to label %invoke.cont.i2088 unwind label %lpad.i2090
invoke.cont.i2088: ; preds = %invoke.cont402
- br i1 undef, label %invoke.cont405, label %if.then.i2089
+ br i1 %arg, label %invoke.cont405, label %if.then.i2089
if.then.i2089: ; preds = %invoke.cont.i2088
br label %invoke.cont405
@@ -1404,7 +1404,7 @@ invoke.cont412: ; preds = %invoke.cont409
to label %invoke.cont.i2094 unwind label %lpad.i2096
invoke.cont.i2094: ; preds = %invoke.cont412
- br i1 undef, label %invoke.cont418, label %if.then.i2095
+ br i1 %arg, label %invoke.cont418, label %if.then.i2095
if.then.i2095: ; preds = %invoke.cont.i2094
br label %invoke.cont418
@@ -1435,7 +1435,7 @@ invoke.cont429: ; preds = %invoke.cont426
to label %invoke.cont.i2100 unwind label %lpad.i2102
invoke.cont.i2100: ; preds = %invoke.cont429
- br i1 undef, label %invoke.cont432, label %if.then.i2101
+ br i1 %arg, label %invoke.cont432, label %if.then.i2101
if.then.i2101: ; preds = %invoke.cont.i2100
br label %invoke.cont432
@@ -1467,7 +1467,7 @@ invoke.cont443: ; preds = %invoke.cont.i2106
to label %invoke.cont.i2112 unwind label %lpad.i2114
invoke.cont.i2112: ; preds = %invoke.cont443
- br i1 undef, label %invoke.cont449, label %if.then.i2113
+ br i1 %arg, label %invoke.cont449, label %if.then.i2113
if.then.i2113: ; preds = %invoke.cont.i2112
br label %invoke.cont449
@@ -1490,7 +1490,7 @@ invoke.cont455: ; preds = %invoke.cont452
to label %invoke.cont.i2118 unwind label %lpad.i2120
invoke.cont.i2118: ; preds = %invoke.cont455
- br i1 undef, label %invoke.cont458, label %if.then.i2119
+ br i1 %arg, label %invoke.cont458, label %if.then.i2119
if.then.i2119: ; preds = %invoke.cont.i2118
br label %invoke.cont458
@@ -1509,7 +1509,7 @@ invoke.cont460: ; preds = %invoke.cont458
to label %invoke.cont.i2124 unwind label %lpad.i2126
invoke.cont.i2124: ; preds = %invoke.cont460
- br i1 undef, label %invoke.cont466, label %if.then.i2125
+ br i1 %arg, label %invoke.cont466, label %if.then.i2125
if.then.i2125: ; preds = %invoke.cont.i2124
br label %invoke.cont466
@@ -1528,7 +1528,7 @@ invoke.cont469: ; preds = %invoke.cont466
to label %invoke.cont.i2130 unwind label %lpad.i2132
invoke.cont.i2130: ; preds = %invoke.cont469
- br i1 undef, label %invoke.cont475, label %if.then.i2131
+ br i1 %arg, label %invoke.cont475, label %if.then.i2131
if.then.i2131: ; preds = %invoke.cont.i2130
br label %invoke.cont475
@@ -1563,7 +1563,7 @@ invoke.cont509: ; preds = %invoke.cont506
to label %invoke.cont512 unwind label %lpad489
invoke.cont512: ; preds = %invoke.cont509
- br i1 undef, label %msgSend.null-receiver, label %msgSend.call
+ br i1 %arg, label %msgSend.null-receiver, label %msgSend.call
msgSend.call: ; preds = %invoke.cont512
invoke void @objc_msgSend_stret(ptr sret(%struct.CGPoint) undef, ptr undef, ptr undef)
@@ -1577,7 +1577,7 @@ msgSend.cont: ; preds = %msgSend.null-receiv
to label %invoke.cont.i2136 unwind label %lpad.i2138
invoke.cont.i2136: ; preds = %msgSend.cont
- br i1 undef, label %invoke.cont521, label %if.then.i2137
+ br i1 %arg, label %invoke.cont521, label %if.then.i2137
if.then.i2137: ; preds = %invoke.cont.i2136
br label %invoke.cont521
@@ -1604,7 +1604,7 @@ invoke.cont534: ; preds = %invoke.cont531
to label %invoke.cont.i2142 unwind label %lpad.i2144
invoke.cont.i2142: ; preds = %invoke.cont534
- br i1 undef, label %invoke.cont540, label %if.then.i2143
+ br i1 %arg, label %invoke.cont540, label %if.then.i2143
if.then.i2143: ; preds = %invoke.cont.i2142
br label %invoke.cont540
@@ -1918,31 +1918,31 @@ eh.resume: ; preds = %lpad580, %ehcleanup
@"OBJC_EHTYPE_$_NSException" = external global i8
-define void @test4() personality ptr @__objc_personality_v0 {
+define void @test4(i1 %arg) personality ptr @__objc_personality_v0 {
entry:
- br i1 undef, label %if.end13, label %if.then10
+ br i1 %arg, label %if.end13, label %if.then10
if.then10: ; preds = %entry
br label %if.end13
if.end13: ; preds = %if.then10, %entry
%0 = call ptr @objc_msgSend(ptr undef, ptr undef, ptr @_unnamed_cfstring, i64 2, ptr @_unnamed_cfstring_2, i8 signext 0), !clang.arc.no_objc_arc_exceptions !0
- br i1 undef, label %if.then17, label %if.end18
+ br i1 %arg, label %if.then17, label %if.end18
if.then17: ; preds = %if.end13
br label %if.end18
if.end18: ; preds = %if.then17, %if.end13
- br i1 undef, label %if.then64, label %if.end73
+ br i1 %arg, label %if.then64, label %if.end73
if.then64: ; preds = %if.end18
- br i1 undef, label %cond.end71, label %cond.true68
+ br i1 %arg, label %cond.end71, label %cond.true68
cond.true68: ; preds = %if.then64
br label %cond.end71
cond.end71: ; preds = %cond.true68, %if.then64
- br i1 undef, label %cleanup.action, label %cleanup.done
+ br i1 %arg, label %cleanup.action, label %cleanup.done
cleanup.action: ; preds = %cond.end71
br label %cleanup.done
@@ -1951,7 +1951,7 @@ cleanup.done: ; preds = %cleanup.action, %co
br label %if.end73
if.end73: ; preds = %cleanup.done, %if.end18
- br i1 undef, label %forcoll.empty, label %forcoll.loopinit
+ br i1 %arg, label %forcoll.empty, label %forcoll.loopinit
forcoll.loopinit: ; preds = %if.end73
br label %forcoll.loopbody.outer
@@ -1960,34 +1960,34 @@ forcoll.loopbody.outer: ; preds = %forcoll.refetch, %f
br label %forcoll.loopbody
forcoll.loopbody: ; preds = %forcoll.notmutated, %forcoll.loopbody.outer
- br i1 undef, label %forcoll.notmutated, label %forcoll.mutated
+ br i1 %arg, label %forcoll.notmutated, label %forcoll.mutated
forcoll.mutated: ; preds = %forcoll.loopbody
br label %forcoll.notmutated
forcoll.notmutated: ; preds = %forcoll.mutated, %forcoll.loopbody
- br i1 undef, label %forcoll.loopbody, label %forcoll.refetch
+ br i1 %arg, label %forcoll.loopbody, label %forcoll.refetch
forcoll.refetch: ; preds = %forcoll.notmutated
- br i1 undef, label %forcoll.empty, label %forcoll.loopbody.outer
+ br i1 %arg, label %forcoll.empty, label %forcoll.loopbody.outer
forcoll.empty: ; preds = %forcoll.refetch, %if.end73
- br i1 undef, label %if.end85, label %if.then82
+ br i1 %arg, label %if.end85, label %if.then82
if.then82: ; preds = %forcoll.empty
br label %if.end85
if.end85: ; preds = %if.then82, %forcoll.empty
- br i1 undef, label %if.then87, label %if.end102
+ br i1 %arg, label %if.then87, label %if.end102
if.then87: ; preds = %if.end85
- br i1 undef, label %if.end94, label %if.then91
+ br i1 %arg, label %if.end94, label %if.then91
if.then91: ; preds = %if.then87
br label %if.end94
if.end94: ; preds = %if.then91, %if.then87
- br i1 undef, label %if.end101, label %if.then98
+ br i1 %arg, label %if.end101, label %if.then98
if.then98: ; preds = %if.end94
br label %if.end101
@@ -1996,139 +1996,139 @@ if.end101: ; preds = %if.then98, %if.end9
br label %if.end102
if.end102: ; preds = %if.end101, %if.end85
- br i1 undef, label %do.body113, label %if.then107
+ br i1 %arg, label %do.body113, label %if.then107
if.then107: ; preds = %if.end102
br label %do.body113
do.body113: ; preds = %if.then107, %if.end102
- br i1 undef, label %if.then116, label %if.end117
+ br i1 %arg, label %if.then116, label %if.end117
if.then116: ; preds = %do.body113
br label %if.end117
if.end117: ; preds = %if.then116, %do.body113
- br i1 undef, label %if.then125, label %if.end126
+ br i1 %arg, label %if.then125, label %if.end126
if.then125: ; preds = %if.end117
br label %if.end126
if.end126: ; preds = %if.then125, %if.end117
- br i1 undef, label %do.end166, label %cond.true132
+ br i1 %arg, label %do.end166, label %cond.true132
cond.true132: ; preds = %if.end126
- br i1 undef, label %do.body148, label %cond.true151
+ br i1 %arg, label %do.body148, label %cond.true151
do.body148: ; preds = %cond.true132
- br i1 undef, label %do.end166, label %cond.true151
+ br i1 %arg, label %do.end166, label %cond.true151
cond.true151: ; preds = %do.body148, %cond.true132
- br i1 undef, label %if.then162, label %do.end166
+ br i1 %arg, label %if.then162, label %do.end166
if.then162: ; preds = %cond.true151
br label %do.end166
do.end166: ; preds = %if.then162, %cond.true151, %do.body148, %if.end126
- br i1 undef, label %if.then304, label %if.then170
+ br i1 %arg, label %if.then304, label %if.then170
if.then170: ; preds = %do.end166
- br i1 undef, label %do.end193, label %cond.true179
+ br i1 %arg, label %do.end193, label %cond.true179
cond.true179: ; preds = %if.then170
- br i1 undef, label %if.then190, label %do.end193
+ br i1 %arg, label %if.then190, label %do.end193
if.then190: ; preds = %cond.true179
br label %do.end193
do.end193: ; preds = %if.then190, %cond.true179, %if.then170
- br i1 undef, label %do.body200, label %do.body283
+ br i1 %arg, label %do.body200, label %do.body283
do.body200: ; preds = %do.end193
- br i1 undef, label %do.end254, label %cond.true203
+ br i1 %arg, label %do.end254, label %cond.true203
cond.true203: ; preds = %do.body200
- br i1 undef, label %do.body218, label %cond.true221
+ br i1 %arg, label %do.body218, label %cond.true221
do.body218: ; preds = %cond.true203
- br i1 undef, label %do.end254, label %cond.true221
+ br i1 %arg, label %do.end254, label %cond.true221
cond.true221: ; preds = %do.body218, %cond.true203
- br i1 undef, label %if.then232, label %do.body236
+ br i1 %arg, label %if.then232, label %do.body236
if.then232: ; preds = %cond.true221
br label %do.body236
do.body236: ; preds = %if.then232, %cond.true221
- br i1 undef, label %do.end254, label %cond.true239
+ br i1 %arg, label %do.end254, label %cond.true239
cond.true239: ; preds = %do.body236
- br i1 undef, label %if.then250, label %do.end254
+ br i1 %arg, label %if.then250, label %do.end254
if.then250: ; preds = %cond.true239
br label %do.end254
do.end254: ; preds = %if.then250, %cond.true239, %do.body236, %do.body218, %do.body200
- br i1 undef, label %do.end277, label %cond.true263
+ br i1 %arg, label %do.end277, label %cond.true263
cond.true263: ; preds = %do.end254
- br i1 undef, label %if.then274, label %do.end277
+ br i1 %arg, label %if.then274, label %do.end277
if.then274: ; preds = %cond.true263
unreachable
do.end277: ; preds = %cond.true263, %do.end254
- br i1 undef, label %if.then280, label %do.body283
+ br i1 %arg, label %if.then280, label %do.body283
if.then280: ; preds = %do.end277
br label %do.body283
do.body283: ; preds = %if.then280, %do.end277, %do.end193
- br i1 undef, label %if.end301, label %cond.true286
+ br i1 %arg, label %if.end301, label %cond.true286
cond.true286: ; preds = %do.body283
- br i1 undef, label %if.then297, label %if.end301
+ br i1 %arg, label %if.then297, label %if.end301
if.then297: ; preds = %cond.true286
br label %if.end301
if.end301: ; preds = %if.then297, %cond.true286, %do.body283
- br i1 undef, label %if.then304, label %do.body351
+ br i1 %arg, label %if.then304, label %do.body351
if.then304: ; preds = %if.end301, %do.end166
- br i1 undef, label %do.body309.lr.ph, label %do.body351
+ br i1 %arg, label %do.body309.lr.ph, label %do.body351
do.body309.lr.ph: ; preds = %if.then304
br label %do.body309
do.body309: ; preds = %for.cond.backedge, %do.body309.lr.ph
- br i1 undef, label %do.end328, label %cond.true312
+ br i1 %arg, label %do.end328, label %cond.true312
cond.true312: ; preds = %do.body309
- br i1 undef, label %if.then323, label %do.end328
+ br i1 %arg, label %if.then323, label %do.end328
if.then323: ; preds = %cond.true312
br label %do.end328
do.end328: ; preds = %if.then323, %cond.true312, %do.body309
- br i1 undef, label %for.cond.backedge, label %cond.true335
+ br i1 %arg, label %for.cond.backedge, label %cond.true335
for.cond.backedge: ; preds = %if.then346, %cond.true335, %do.end328
- br i1 undef, label %do.body309, label %do.body351
+ br i1 %arg, label %do.body309, label %do.body351
cond.true335: ; preds = %do.end328
- br i1 undef, label %if.then346, label %for.cond.backedge
+ br i1 %arg, label %if.then346, label %for.cond.backedge
if.then346: ; preds = %cond.true335
br label %for.cond.backedge
do.body351: ; preds = %for.cond.backedge, %if.then304, %if.end301
- br i1 undef, label %if.then354, label %if.end355
+ br i1 %arg, label %if.then354, label %if.end355
if.then354: ; preds = %do.body351
br label %if.end355
if.end355: ; preds = %if.then354, %do.body351
- br i1 undef, label %if.else, label %if.then364
+ br i1 %arg, label %if.else, label %if.then364
if.then364: ; preds = %if.end355
br label %do.body366
@@ -2137,7 +2137,7 @@ if.else: ; preds = %if.end355
br label %do.body366
do.body366: ; preds = %if.else, %if.then364
- br i1 undef, label %if.then369, label %if.end377.critedge
+ br i1 %arg, label %if.then369, label %if.end377.critedge
if.then369: ; preds = %do.body366
br label %if.end377
@@ -2146,7 +2146,7 @@ if.end377.critedge: ; preds = %do.body366
br label %if.end377
if.end377: ; preds = %if.end377.critedge, %if.then369
- br i1 undef, label %if.then383, label %if.end392.critedge
+ br i1 %arg, label %if.then383, label %if.end392.critedge
if.then383: ; preds = %if.end377
br label %if.end392
@@ -2155,7 +2155,7 @@ if.end392.critedge: ; preds = %if.end377
br label %if.end392
if.end392: ; preds = %if.end392.critedge, %if.then383
- br i1 undef, label %if.then398, label %if.end399
+ br i1 %arg, label %if.then398, label %if.end399
if.then398: ; preds = %if.end392
br label %if.end399
@@ -2165,7 +2165,7 @@ if.end399: ; preds = %if.then398, %if.end
to label %eh.cont unwind label %lpad, !clang.arc.no_objc_arc_exceptions !0
eh.cont: ; preds = %if.end399
- br i1 undef, label %if.then430, label %if.end439.critedge
+ br i1 %arg, label %if.then430, label %if.end439.critedge
if.then430: ; preds = %eh.cont
%1 = call ptr @llvm.objc.retain(ptr %0)
>From 9e2a747e45c780ca3740534e5913dbde3c91385d Mon Sep 17 00:00:00 2001
From: Lee <lee10202013 at gmail.com>
Date: Mon, 2 Dec 2024 19:21:29 -0700
Subject: [PATCH 02/10] Remove br i1 undef in Reassociate directory
---
llvm/test/Transforms/Reassociate/2011-01-26-UseAfterFree.ll | 6 +++---
llvm/test/Transforms/Reassociate/2012-06-08-InfiniteLoop.ll | 4 ++--
llvm/test/Transforms/Reassociate/add_across_block_crash.ll | 6 +++---
llvm/test/Transforms/Reassociate/infloop-deadphi.ll | 6 +++---
llvm/test/Transforms/Reassociate/reassociate-landingpad.ll | 4 ++--
5 files changed, 13 insertions(+), 13 deletions(-)
diff --git a/llvm/test/Transforms/Reassociate/2011-01-26-UseAfterFree.ll b/llvm/test/Transforms/Reassociate/2011-01-26-UseAfterFree.ll
index 4cde69bb0c7ddf..80a9e77030e643 100644
--- a/llvm/test/Transforms/Reassociate/2011-01-26-UseAfterFree.ll
+++ b/llvm/test/Transforms/Reassociate/2011-01-26-UseAfterFree.ll
@@ -3,7 +3,7 @@
target datalayout = "e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:64-f32:32:32-f64:32:64-v64:64:64-v128:128:128-a0:0:64-f80:32:32-n8:16:32"
target triple = "i386-gnu-linux"
-define void @exp_averages_intraday__deviation() {
+define void @exp_averages_intraday__deviation(i1 %arg) {
entry:
%0 = load i32, ptr undef, align 4
%1 = shl i32 %0, 2
@@ -16,14 +16,14 @@ entry:
br i1 false, label %"4", label %"12"
"4": ; preds = %entry
- br i1 undef, label %"5", label %"8"
+ br i1 %arg, label %"5", label %"8"
"5": ; preds = %"4"
unreachable
"8": ; preds = %"4"
%8 = getelementptr inbounds i8, ptr undef, i32 %6
- br i1 undef, label %"13", label %"12"
+ br i1 %arg, label %"13", label %"12"
"12": ; preds = %"8", %entry
ret void
diff --git a/llvm/test/Transforms/Reassociate/2012-06-08-InfiniteLoop.ll b/llvm/test/Transforms/Reassociate/2012-06-08-InfiniteLoop.ll
index 650aa82c1af2f1..ba730758a1f26f 100644
--- a/llvm/test/Transforms/Reassociate/2012-06-08-InfiniteLoop.ll
+++ b/llvm/test/Transforms/Reassociate/2012-06-08-InfiniteLoop.ll
@@ -1,14 +1,14 @@
; RUN: opt < %s -passes=reassociate -disable-output
; PR13041
-define void @foo() {
+define void @foo(i1 %arg) {
entry:
br label %while.cond
while.cond: ; preds = %while.body, %entry
%b.0 = phi i32 [ undef, %entry ], [ %sub2, %while.body ]
%c.0 = phi i32 [ undef, %entry ], [ %sub3, %while.body ]
- br i1 undef, label %while.end, label %while.body
+ br i1 %arg, label %while.end, label %while.body
while.body: ; preds = %while.cond
%sub = sub nsw i32 0, %b.0
diff --git a/llvm/test/Transforms/Reassociate/add_across_block_crash.ll b/llvm/test/Transforms/Reassociate/add_across_block_crash.ll
index 26e971266d3443..a89f81154f3eb5 100644
--- a/llvm/test/Transforms/Reassociate/add_across_block_crash.ll
+++ b/llvm/test/Transforms/Reassociate/add_across_block_crash.ll
@@ -3,10 +3,10 @@
; This test is to make sure while processing a block, uses of instructions
; from a different basic block don't get added to be re-optimized
-define void @main() {
+define void @main(i1 %arg) {
; CHECK-LABEL: @main(
; CHECK-NEXT: entry:
-; CHECK-NEXT: br i1 undef, label %bb1, label %bb2
+; CHECK-NEXT: br i1 %arg, label %bb1, label %bb2
; CHECK: bb1:
; CHECK-NEXT: ret void
; CHECK: bb2:
@@ -14,7 +14,7 @@ define void @main() {
;
entry:
%0 = fadd fast float undef, undef
- br i1 undef, label %bb1, label %bb2
+ br i1 %arg, label %bb1, label %bb2
bb1:
%1 = fmul fast float undef, -2.000000e+00
diff --git a/llvm/test/Transforms/Reassociate/infloop-deadphi.ll b/llvm/test/Transforms/Reassociate/infloop-deadphi.ll
index 5b19f8d384f4da..3202f450b7566f 100644
--- a/llvm/test/Transforms/Reassociate/infloop-deadphi.ll
+++ b/llvm/test/Transforms/Reassociate/infloop-deadphi.ll
@@ -3,14 +3,14 @@
target triple = "x86_64-unknown-linux-gnu"
-define void @f() {
+define void @f(i1 %arg) {
; CHECK-LABEL: @f(
; CHECK-NEXT: entry:
; CHECK-NEXT: br label [[DONE:%.*]]
; CHECK: dead:
; CHECK-NEXT: [[XOR0:%.*]] = xor i16 [[XOR1:%.*]], undef
; CHECK-NEXT: [[XOR1]] = xor i16 [[XOR0]], undef
-; CHECK-NEXT: br i1 undef, label [[DEAD:%.*]], label [[DONE]]
+; CHECK-NEXT: br i1 %arg, label [[DEAD:%.*]], label [[DONE]]
; CHECK: done:
; CHECK-NEXT: ret void
;
@@ -20,7 +20,7 @@ entry:
dead:
%xor0 = xor i16 %xor1, undef
%xor1 = xor i16 %xor0, undef
- br i1 undef, label %dead, label %done
+ br i1 %arg, label %dead, label %done
done:
%e = phi i16 [ %xor1, %dead ], [ 0, %entry ]
diff --git a/llvm/test/Transforms/Reassociate/reassociate-landingpad.ll b/llvm/test/Transforms/Reassociate/reassociate-landingpad.ll
index eb6a5cabb7be84..c5bd62e2763b67 100644
--- a/llvm/test/Transforms/Reassociate/reassociate-landingpad.ll
+++ b/llvm/test/Transforms/Reassociate/reassociate-landingpad.ll
@@ -14,7 +14,7 @@ declare i32 @__gxx_personality_v0(...)
declare void @b() #0
-define void @a() #0 personality ptr @__gxx_personality_v0 {
+define void @a(i1 %arg) #0 personality ptr @__gxx_personality_v0 {
", bb1":
invoke void @b()
to label %invoke.cont unwind label %"bb22"
@@ -39,7 +39,7 @@ define void @a() #0 personality ptr @__gxx_personality_v0 {
unreachable
invoke.cont: ; preds = %", bb1"
- br i1 undef, label %", bb15", label %", bb8"
+ br i1 %arg, label %", bb15", label %", bb8"
invoke.cont25: ; preds = %", bb8"
unreachable
>From 8dae2d78d8b08399d8e1fac7d125a0a4617121c4 Mon Sep 17 00:00:00 2001
From: Lee <lee10202013 at gmail.com>
Date: Mon, 2 Dec 2024 19:42:54 -0700
Subject: [PATCH 03/10] Remove br i1 undef in SCCP directory
---
.../SCCP/2004-12-10-UndefBranchBug.ll | 11 ++-
.../SCCP/2006-10-23-IPSCCP-Crash.ll | 4 +-
.../SCCP/2008-01-27-UndefCorrelate.ll | 22 +++++-
llvm/test/Transforms/SCCP/PR26044.ll | 23 +++---
llvm/test/Transforms/SCCP/crash.ll | 4 +-
llvm/test/Transforms/SCCP/domtree-update.ll | 6 +-
.../Transforms/SCCP/fp-bc-icmp-const-fold.ll | 10 +--
.../Transforms/SCCP/ipsccp-preserve-pdt.ll | 11 +--
.../SCCP/pr49582-iterator-invalidation.ll | 8 +--
llvm/test/Transforms/SCCP/return-zapped.ll | 32 +++++----
...fter-each-resolving-undefs-for-function.ll | 34 +++++----
.../SCCP/switch-constantfold-crash.ll | 72 +++++++++++--------
12 files changed, 138 insertions(+), 99 deletions(-)
diff --git a/llvm/test/Transforms/SCCP/2004-12-10-UndefBranchBug.ll b/llvm/test/Transforms/SCCP/2004-12-10-UndefBranchBug.ll
index 2098b0390b64a2..e84ac516b9f50c 100644
--- a/llvm/test/Transforms/SCCP/2004-12-10-UndefBranchBug.ll
+++ b/llvm/test/Transforms/SCCP/2004-12-10-UndefBranchBug.ll
@@ -1,14 +1,13 @@
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
; RUN: opt < %s -passes=sccp -S | FileCheck %s
-; Branch on undef is UB, so the T block is never executed, and we can return
-; undef (IPSCCP would replace the block with unreachable).
-
-define i32 @foo() {
+define i32 @foo(i1 %arg) {
; CHECK-LABEL: @foo(
-; CHECK-NEXT: unreachable
+; CHECK-NEXT: br i1 [[ARG:%.*]], label [[T:%.*]], label [[T]]
+; CHECK: T:
+; CHECK-NEXT: ret i32 1
;
- br i1 undef, label %T, label %T
+ br i1 %arg, label %T, label %T
T:
%X = add i32 0, 1
ret i32 %X
diff --git a/llvm/test/Transforms/SCCP/2006-10-23-IPSCCP-Crash.ll b/llvm/test/Transforms/SCCP/2006-10-23-IPSCCP-Crash.ll
index 3e2cfe1ce25fbe..8c1687a3eb7847 100644
--- a/llvm/test/Transforms/SCCP/2006-10-23-IPSCCP-Crash.ll
+++ b/llvm/test/Transforms/SCCP/2006-10-23-IPSCCP-Crash.ll
@@ -6,7 +6,7 @@ target triple = "powerpc-unknown-linux-gnu"
@JUMP = external global i32 ; <ptr> [#uses=1]
@old_D_pat = external global [16 x i8] ; <ptr> [#uses=0]
-define void @asearch1(i32 %D) {
+define void @asearch1(i32 %D, i1 %arg) {
entry:
%tmp80 = icmp ult i32 0, %D ; <i1> [#uses=1]
br i1 %tmp80, label %bb647.preheader, label %cond_true81.preheader
@@ -22,7 +22,7 @@ cond_true612: ; preds = %cond_true654
cond_next624: ; preds = %cond_true654
ret void
cond_true654: ; preds = %bb647.preheader
- br i1 undef, label %cond_true612, label %cond_next624
+ br i1 %arg, label %cond_true612, label %cond_next624
UnifiedReturnBlock: ; preds = %bb647.preheader
ret void
}
diff --git a/llvm/test/Transforms/SCCP/2008-01-27-UndefCorrelate.ll b/llvm/test/Transforms/SCCP/2008-01-27-UndefCorrelate.ll
index 6f499f27a65a91..895b1393dadaef 100644
--- a/llvm/test/Transforms/SCCP/2008-01-27-UndefCorrelate.ll
+++ b/llvm/test/Transforms/SCCP/2008-01-27-UndefCorrelate.ll
@@ -2,12 +2,30 @@
; RUN: opt < %s -passes=sccp -S | FileCheck %s
; PR1938
-define i32 @main() {
+define i32 @main(i1 %arg) {
; CHECK-LABEL: @main(
; CHECK-NEXT: entry:
; CHECK-NEXT: br label [[BB:%.*]]
; CHECK: bb:
+; CHECK-NEXT: [[INDVAR:%.*]] = phi i32 [ 0, [[ENTRY:%.*]] ], [ [[K:%.*]], [[BB_BACKEDGE:%.*]] ]
+; CHECK-NEXT: [[K]] = add i32 [[INDVAR]], 1
+; CHECK-NEXT: br i1 [[ARG:%.*]], label [[COND_TRUE:%.*]], label [[COND_FALSE:%.*]]
+; CHECK: cond_true:
+; CHECK-NEXT: [[TMP97:%.*]] = icmp slt i32 [[K]], 10
+; CHECK-NEXT: br i1 [[TMP97]], label [[BB_BACKEDGE]], label [[BB12:%.*]]
+; CHECK: bb.backedge:
+; CHECK-NEXT: br label [[BB]]
+; CHECK: cond_false:
+; CHECK-NEXT: [[TMP9:%.*]] = icmp slt i32 [[K]], 10
+; CHECK-NEXT: br i1 [[TMP9]], label [[BB_BACKEDGE]], label [[BB12]]
+; CHECK: bb12:
+; CHECK-NEXT: [[TMP14:%.*]] = icmp eq i32 [[K]], 10
+; CHECK-NEXT: br i1 [[TMP14]], label [[COND_NEXT18:%.*]], label [[COND_TRUE17:%.*]]
+; CHECK: cond_true17:
+; CHECK-NEXT: tail call void @abort()
; CHECK-NEXT: unreachable
+; CHECK: cond_next18:
+; CHECK-NEXT: ret i32 0
;
entry:
br label %bb
@@ -15,7 +33,7 @@ entry:
bb:
%indvar = phi i32 [ 0, %entry ], [ %k, %bb.backedge ]
%k = add i32 %indvar, 1
- br i1 undef, label %cond_true, label %cond_false
+ br i1 %arg, label %cond_true, label %cond_false
cond_true:
%tmp97 = icmp slt i32 %k, 10
diff --git a/llvm/test/Transforms/SCCP/PR26044.ll b/llvm/test/Transforms/SCCP/PR26044.ll
index 90ac3101d0c23f..f786629f47d0e3 100644
--- a/llvm/test/Transforms/SCCP/PR26044.ll
+++ b/llvm/test/Transforms/SCCP/PR26044.ll
@@ -3,13 +3,13 @@
target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
target triple = "x86_64-unknown-linux-gnu"
-define void @fn2(ptr %P) {
+define void @fn2(ptr %P, i1 %arg) {
; CHECK-LABEL: define {{[^@]+}}@fn2
-; CHECK-SAME: (ptr [[P:%.*]]) {
+; CHECK-SAME: (ptr [[P:%.*]], i1 [[ARG:%.*]]) {
; CHECK-NEXT: entry:
; CHECK-NEXT: br label [[IF_END:%.*]]
; CHECK: for.cond1:
-; CHECK-NEXT: unreachable
+; CHECK-NEXT: br i1 [[ARG]], label [[IF_END]], label [[IF_END]]
; CHECK: if.end:
; CHECK-NEXT: [[CALL:%.*]] = call i32 @fn1(i32 undef)
; CHECK-NEXT: store i32 [[CALL]], ptr [[P]], align 4
@@ -19,7 +19,7 @@ entry:
br label %if.end
for.cond1: ; preds = %if.end, %for.end
- br i1 undef, label %if.end, label %if.end
+ br i1 %arg, label %if.end, label %if.end
if.end: ; preds = %lbl, %for.cond1
%e.2 = phi ptr [ undef, %entry ], [ null, %for.cond1 ], [ null, %for.cond1 ]
@@ -43,15 +43,16 @@ entry:
ret i32 %cond
}
-define void @fn_no_null_opt(ptr %P) #0 {
+define void @fn_no_null_opt(ptr %P, i1 %arg) #0 {
; CHECK-LABEL: define {{[^@]+}}@fn_no_null_opt
-; CHECK-SAME: (ptr [[P:%.*]]) #[[ATTR0:[0-9]+]] {
+; CHECK-SAME: (ptr [[P:%.*]], i1 [[ARG:%.*]]) #[[ATTR0:[0-9]+]] {
; CHECK-NEXT: entry:
; CHECK-NEXT: br label [[IF_END:%.*]]
; CHECK: for.cond1:
-; CHECK-NEXT: unreachable
+; CHECK-NEXT: br i1 [[ARG]], label [[IF_END]], label [[IF_END]]
; CHECK: if.end:
-; CHECK-NEXT: [[CALL:%.*]] = call i32 @fn0(i32 undef)
+; CHECK-NEXT: [[TMP0:%.*]] = load i32, ptr null, align 4
+; CHECK-NEXT: [[CALL:%.*]] = call i32 @fn0(i32 [[TMP0]])
; CHECK-NEXT: store i32 [[CALL]], ptr [[P]], align 4
; CHECK-NEXT: br label [[FOR_COND1:%.*]]
;
@@ -59,7 +60,7 @@ entry:
br label %if.end
for.cond1: ; preds = %if.end, %for.end
- br i1 undef, label %if.end, label %if.end
+ br i1 %arg, label %if.end, label %if.end
if.end: ; preds = %lbl, %for.cond1
%e.2 = phi ptr [ undef, %entry ], [ null, %for.cond1 ], [ null, %for.cond1 ]
@@ -73,8 +74,8 @@ define internal i32 @fn0(i32 %p1) {
; CHECK-LABEL: define {{[^@]+}}@fn0
; CHECK-SAME: (i32 [[P1:%.*]]) {
; CHECK-NEXT: entry:
-; CHECK-NEXT: [[TOBOOL:%.*]] = icmp ne i32 undef, 0
-; CHECK-NEXT: [[COND:%.*]] = select i1 [[TOBOOL]], i32 undef, i32 undef
+; CHECK-NEXT: [[TOBOOL:%.*]] = icmp ne i32 [[P1]], 0
+; CHECK-NEXT: [[COND:%.*]] = select i1 [[TOBOOL]], i32 [[P1]], i32 [[P1]]
; CHECK-NEXT: ret i32 [[COND]]
;
entry:
diff --git a/llvm/test/Transforms/SCCP/crash.ll b/llvm/test/Transforms/SCCP/crash.ll
index 47d9329f6f03da..9001b42850c25e 100644
--- a/llvm/test/Transforms/SCCP/crash.ll
+++ b/llvm/test/Transforms/SCCP/crash.ll
@@ -2,9 +2,9 @@
target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128"
target triple = "x86_64-apple-darwin10.0"
-define void @test1(i8 %arg) {
+define void @test1(i8 %arg, i1 %arg1) {
entry:
- br i1 undef, label %return, label %bb
+ br i1 %arg1, label %return, label %bb
bb:
br label %bb34
diff --git a/llvm/test/Transforms/SCCP/domtree-update.ll b/llvm/test/Transforms/SCCP/domtree-update.ll
index 76f575c4e9c6d4..270da0e2f2bfe7 100644
--- a/llvm/test/Transforms/SCCP/domtree-update.ll
+++ b/llvm/test/Transforms/SCCP/domtree-update.ll
@@ -4,7 +4,7 @@
; DTU should not crash.
-define i32 @test() {
+define i32 @test(i1 %arg) {
; CHECK-LABEL: @test(
; CHECK-NEXT: entry:
; CHECK-NEXT: br label [[FOR_BODY:%.*]]
@@ -25,10 +25,10 @@ if.then2: ; preds = %for.body
br label %for.inc
if.else: ; preds = %for.body
- br i1 undef, label %lor.rhs, label %if.then19.critedge
+ br i1 %arg, label %lor.rhs, label %if.then19.critedge
lor.rhs: ; preds = %if.else
- br i1 undef, label %if.then19, label %for.inc
+ br i1 %arg, label %if.then19, label %for.inc
if.then19.critedge: ; preds = %if.else
br label %if.then19
diff --git a/llvm/test/Transforms/SCCP/fp-bc-icmp-const-fold.ll b/llvm/test/Transforms/SCCP/fp-bc-icmp-const-fold.ll
index 8061a0396ee4c8..6a8b52d0ac4814 100644
--- a/llvm/test/Transforms/SCCP/fp-bc-icmp-const-fold.ll
+++ b/llvm/test/Transforms/SCCP/fp-bc-icmp-const-fold.ll
@@ -2,18 +2,18 @@
target datalayout = "E-m:e-i64:64-n32:64"
target triple = "powerpc64le-unknown-linux"
-define void @test(i32 signext %n) {
+define void @test(i32 signext %n, i1 %arg) {
; CHECK-LABEL: @test
entry:
- br i1 undef, label %if.then, label %if.end
+ br i1 %arg, label %if.then, label %if.end
if.then: ; preds = %entry
ret void
if.end: ; preds = %entry
- br i1 undef, label %if.then2, label %if.end4
+ br i1 %arg, label %if.then2, label %if.end4
if.then2: ; preds = %if.end
unreachable
@@ -36,10 +36,10 @@ if.else14: ; preds = %if.end4
do.body: ; preds = %do.body, %if.else14
%scale.0 = phi ppc_fp128 [ 0xM3FF00000000000000000000000000000, %if.else14 ], [ %scale.0, %do.body ]
- br i1 undef, label %do.body, label %if.then33
+ br i1 %arg, label %do.body, label %if.then33
if.then33: ; preds = %do.body
- br i1 undef, label %_ZN5boost4math4signIgEEiRKT_.exit30, label %cond.false.i28
+ br i1 %arg, label %_ZN5boost4math4signIgEEiRKT_.exit30, label %cond.false.i28
cond.false.i28: ; preds = %if.then33
%0 = bitcast ppc_fp128 %scale.0 to i128
diff --git a/llvm/test/Transforms/SCCP/ipsccp-preserve-pdt.ll b/llvm/test/Transforms/SCCP/ipsccp-preserve-pdt.ll
index f8c8e33dfc2335..be05d96f085741 100644
--- a/llvm/test/Transforms/SCCP/ipsccp-preserve-pdt.ll
+++ b/llvm/test/Transforms/SCCP/ipsccp-preserve-pdt.ll
@@ -20,16 +20,17 @@
; CHECK-NEXT: [2] %for.body {4294967295,4294967295} [1]
; CHECK-NEXT: [2] %if.end4 {4294967295,4294967295} [1]
; CHECK-NEXT: [3] %entry {4294967295,4294967295} [2]
-; CHECK-NEXT: [2] %for.cond34 {4294967295,4294967295} [1]
-; CHECK-NEXT: [3] %for.cond16 {4294967295,4294967295} [2]
-; CHECK-NEXT: Roots: %for.body %for.cond34
+; CHECK-NEXT: [2] %for.body37 {4294967295,4294967295} [1]
+; CHECK-NEXT: [3] %for.cond34 {4294967295,4294967295} [2]
+; CHECK-NEXT: [4] %for.cond16 {4294967295,4294967295} [3]
+; CHECK-NEXT: Roots: %for.body %for.body37
; CHECK-NEXT: PostDominatorTree for function: bar
; CHECK-NOT: <badref>
declare hidden i1 @compare(ptr) align 2
declare hidden { i8, ptr } @getType(ptr) align 2
-define internal void @foo(ptr %TLI, ptr %DL, ptr %Ty, ptr %ValueVTs, ptr %Offsets, i64 %StartingOffset) {
+define internal void @foo(ptr %TLI, ptr %DL, ptr %Ty, ptr %ValueVTs, ptr %Offsets, i64 %StartingOffset, i1 %arg) {
entry:
%VT = alloca i64, align 8
br i1 false, label %if.then, label %if.end4
@@ -51,7 +52,7 @@ for.cond16: ; preds = %for.cond34, %if.end
br label %for.cond34
for.cond34: ; preds = %for.body37, %for.cond16
- br i1 undef, label %for.body37, label %for.cond16
+ br i1 %arg, label %for.body37, label %for.cond16
for.body37: ; preds = %for.cond34
%tobool39 = icmp ne ptr %Offsets, null
diff --git a/llvm/test/Transforms/SCCP/pr49582-iterator-invalidation.ll b/llvm/test/Transforms/SCCP/pr49582-iterator-invalidation.ll
index ed5703da35e6f6..1ba6e9734e642c 100644
--- a/llvm/test/Transforms/SCCP/pr49582-iterator-invalidation.ll
+++ b/llvm/test/Transforms/SCCP/pr49582-iterator-invalidation.ll
@@ -5,7 +5,7 @@
@c = external dso_local global ptr, align 8
@d = external dso_local global i32, align 4
-define void @f(i32 %i) {
+define void @f(i32 %i, i1 %arg) {
entry:
br label %for.cond
@@ -474,7 +474,7 @@ if.then312: ; preds = %if.then309
br label %if.end628
if.else316: ; preds = %if.then309
- br i1 undef, label %if.then318, label %if.end628
+ br i1 %arg, label %if.then318, label %if.end628
if.then318: ; preds = %if.else316
%idxprom320 = sext i32 %add310 to i64
@@ -726,7 +726,7 @@ if.then499: ; preds = %if.else496
br label %if.end628
if.else501: ; preds = %if.else496
- br i1 undef, label %if.then503, label %if.end628
+ br i1 %arg, label %if.then503, label %if.end628
if.then503: ; preds = %if.else501
br label %if.end628
@@ -834,7 +834,7 @@ if.then596: ; preds = %if.then593
br label %if.end628
if.else600: ; preds = %if.then593
- br i1 undef, label %if.then602, label %if.end628
+ br i1 %arg, label %if.then602, label %if.end628
if.then602: ; preds = %if.else600
%idxprom604 = sext i32 %add594 to i64
diff --git a/llvm/test/Transforms/SCCP/return-zapped.ll b/llvm/test/Transforms/SCCP/return-zapped.ll
index 6d705001250930..2b0a7942943c8f 100644
--- a/llvm/test/Transforms/SCCP/return-zapped.ll
+++ b/llvm/test/Transforms/SCCP/return-zapped.ll
@@ -1,37 +1,41 @@
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --function-signature
; RUN: opt < %s -S -passes=ipsccp | FileCheck %s
-; testf() performs an unconditional branch on undef, as such the testf() return
-; value used in test1() will remain "unknown" and the following branch on it
-; replaced by unreachable. This is fine, as the call to testf() will already
-; trigger undefined behavior.
-define void @test1() {
-; CHECK-LABEL: define {{[^@]+}}@test1() {
+define void @test1(i1 %arg) {
+; CHECK-LABEL: define {{[^@]+}}@test1
+; CHECK-SAME: (i1 [[ARG:%.*]]) {
; CHECK-NEXT: entry:
; CHECK-NEXT: br label [[IF_THEN:%.*]]
; CHECK: if.then:
-; CHECK-NEXT: [[CALL:%.*]] = call i1 @testf()
-; CHECK-NEXT: unreachable
+; CHECK-NEXT: [[CALL:%.*]] = call i1 @testf(i1 [[ARG]])
+; CHECK-NEXT: br label [[IF_END:%.*]]
+; CHECK: if.end:
+; CHECK-NEXT: ret void
;
entry:
br label %if.then
if.then: ; preds = %entry, %if.then
%foo = phi i32 [ 0, %entry], [ %next, %if.then]
%next = add i32 %foo, 1
- %call = call i1 @testf()
+ %call = call i1 @testf(i1 %arg)
br i1 %call, label %if.end, label %if.then
if.end: ; preds = %if.then, %entry
ret void
}
-define internal i1 @testf() {
-; CHECK-LABEL: define {{[^@]+}}@testf() {
+define internal i1 @testf(i1 %arg) {
+; CHECK-LABEL: define {{[^@]+}}@testf
+; CHECK-SAME: (i1 [[ARG:%.*]]) {
; CHECK-NEXT: entry:
-; CHECK-NEXT: unreachable
+; CHECK-NEXT: br i1 [[ARG]], label [[IF_THEN1:%.*]], label [[IF_END3:%.*]]
+; CHECK: if.then1:
+; CHECK-NEXT: br label [[IF_END3]]
+; CHECK: if.end3:
+; CHECK-NEXT: ret i1 true
;
entry:
- br i1 undef, label %if.then1, label %if.end3
+ br i1 %arg, label %if.then1, label %if.end3
if.then1: ; preds = %if.end
br label %if.end3
@@ -47,7 +51,7 @@ define i1 @test2() {
; CHECK-NEXT: br label [[IF_END:%.*]]
; CHECK: if.end:
; CHECK-NEXT: [[CALL2:%.*]] = call i1 @testf()
-; CHECK-NEXT: ret i1 undef
+; CHECK-NEXT: ret i1 [[CALL2]]
;
entry:
br label %if.end
diff --git a/llvm/test/Transforms/SCCP/solve-after-each-resolving-undefs-for-function.ll b/llvm/test/Transforms/SCCP/solve-after-each-resolving-undefs-for-function.ll
index 05f3358045c3c4..e3048b2a6ac7f0 100644
--- a/llvm/test/Transforms/SCCP/solve-after-each-resolving-undefs-for-function.ll
+++ b/llvm/test/Transforms/SCCP/solve-after-each-resolving-undefs-for-function.ll
@@ -1,22 +1,23 @@
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 5
; RUN: opt < %s -passes=ipsccp -S | FileCheck %s
-;
-define internal i32 @testf(i1 %c) {
-; CHECK-LABEL: define internal i32 @testf(
-; CHECK-SAME: i1 [[C:%.*]]) {
+define internal i32 @testf(i1 %c, i1 %arg) {
+; CHECK-LABEL: define internal range(i32 10, 12) i32 @testf(
+; CHECK-SAME: i1 [[C:%.*]], i1 [[ARG:%.*]]) {
; CHECK-NEXT: [[ENTRY:.*:]]
; CHECK-NEXT: br i1 [[C]], label %[[IF_COND:.*]], label %[[IF_END:.*]]
; CHECK: [[IF_COND]]:
-; CHECK-NEXT: unreachable
+; CHECK-NEXT: br i1 [[ARG]], label %[[IF_THEN:.*]], label %[[IF_END]]
+; CHECK: [[IF_THEN]]:
+; CHECK-NEXT: ret i32 11
; CHECK: [[IF_END]]:
-; CHECK-NEXT: ret i32 poison
+; CHECK-NEXT: ret i32 10
;
entry:
br i1 %c, label %if.cond, label %if.end
if.cond:
- br i1 undef, label %if.then, label %if.end
+ br i1 %arg, label %if.then, label %if.end
if.then: ; preds = %entry, %if.then
ret i32 11
@@ -26,22 +27,25 @@ if.end: ; preds = %if.then1, %entry
}
;
-define internal i32 @test1(i1 %c) {
-; CHECK-LABEL: define internal i32 @test1(
-; CHECK-SAME: i1 [[C:%.*]]) {
+define internal i32 @test1(i1 %c, i1 %arg) {
+; CHECK-LABEL: define internal range(i32 0, 100) i32 @test1(
+; CHECK-SAME: i1 [[C:%.*]], i1 [[ARG:%.*]]) {
; CHECK-NEXT: [[ENTRY:.*:]]
; CHECK-NEXT: br label %[[IF_THEN:.*]]
; CHECK: [[IF_THEN]]:
-; CHECK-NEXT: [[CALL:%.*]] = call i32 @testf(i1 [[C]])
-; CHECK-NEXT: br label %[[RET1:.*]]
+; CHECK-NEXT: [[CALL:%.*]] = call i32 @testf(i1 [[C]], i1 [[ARG]])
+; CHECK-NEXT: [[RES:%.*]] = icmp eq i32 [[CALL]], 10
+; CHECK-NEXT: br i1 [[RES]], label %[[RET1:.*]], label %[[RET2:.*]]
; CHECK: [[RET1]]:
-; CHECK-NEXT: ret i32 poison
+; CHECK-NEXT: ret i32 99
+; CHECK: [[RET2]]:
+; CHECK-NEXT: ret i32 0
;
entry:
br label %if.then
if.then: ; preds = %entry, %if.then
- %call = call i32 @testf(i1 %c)
+ %call = call i32 @testf(i1 %c, i1 %arg)
%res = icmp eq i32 %call, 10
br i1 %res, label %ret1, label %ret2
@@ -57,7 +61,7 @@ define i32 @main(i1 %c) {
; CHECK-LABEL: define i32 @main(
; CHECK-SAME: i1 [[C:%.*]]) {
; CHECK-NEXT: [[RES:%.*]] = call i32 @test1(i1 [[C]])
-; CHECK-NEXT: ret i32 99
+; CHECK-NEXT: ret i32 [[RES]]
;
%res = call i32 @test1(i1 %c)
ret i32 %res
diff --git a/llvm/test/Transforms/SCCP/switch-constantfold-crash.ll b/llvm/test/Transforms/SCCP/switch-constantfold-crash.ll
index 2336c9186636e4..b163d2c078ef69 100644
--- a/llvm/test/Transforms/SCCP/switch-constantfold-crash.ll
+++ b/llvm/test/Transforms/SCCP/switch-constantfold-crash.ll
@@ -2,8 +2,9 @@
; RUN: opt -passes=ipsccp < %s -S | FileCheck %s
; RUN: opt -passes='ipsccp,ipsccp' < %s -S | FileCheck %s
-define void @barney() {
-; CHECK-LABEL: define {{[^@]+}}@barney() {
+define void @barney(i1 %arg) {
+; CHECK-LABEL: define {{[^@]+}}@barney
+; CHECK-SAME: (i1 [[ARG:%.*]]) {
; CHECK-NEXT: bb:
; CHECK-NEXT: br label [[BB9:%.*]]
; CHECK: bb6:
@@ -26,8 +27,9 @@ bb9: ; preds = %bb
]
}
-define void @blam() {
-; CHECK-LABEL: define {{[^@]+}}@blam() {
+define void @blam(i1 %arg) {
+; CHECK-LABEL: define {{[^@]+}}@blam
+; CHECK-SAME: (i1 [[ARG:%.*]]) {
; CHECK-NEXT: bb:
; CHECK-NEXT: br label [[BB16:%.*]]
; CHECK: bb16:
@@ -59,13 +61,23 @@ bb38: ; preds = %bb16
}
-define void @hoge() {
-; CHECK-LABEL: define {{[^@]+}}@hoge() {
+define void @hoge(i1 %arg, i16 %arg2) {
+; CHECK-LABEL: define {{[^@]+}}@hoge
+; CHECK-SAME: (i1 [[ARG:%.*]], i16 [[ARG2:%.*]]) {
; CHECK-NEXT: bb:
+; CHECK-NEXT: switch i16 [[ARG2]], label [[BB1:%.*]] [
+; CHECK-NEXT: i16 135, label [[BB2:%.*]]
+; CHECK-NEXT: i16 66, label [[BB2]]
+; CHECK-NEXT: ]
+; CHECK: bb1:
+; CHECK-NEXT: ret void
+; CHECK: bb2:
+; CHECK-NEXT: br label [[BB3:%.*]]
+; CHECK: bb3:
; CHECK-NEXT: unreachable
;
bb:
- switch i16 undef, label %bb1 [
+ switch i16 %arg2, label %bb1 [
i16 135, label %bb2
i16 66, label %bb2
]
@@ -89,14 +101,9 @@ bb4: ; preds = %bb2, %bb2, %bb2
; Test case from PR49573. %default.bb is unfeasible. Make sure it gets replaced
; by an unreachable block.
-define void @pr49573_main() {
-; CHECK-LABEL: define {{[^@]+}}@pr49573_main() {
-; CHECK-NEXT: entry:
-; CHECK-NEXT: [[TGT:%.*]] = call i16 @pr49573_fn()
-; CHECK-NEXT: unreachable
-;
+define void @pr49573_main(i1 %arg) {
entry:
- %tgt = call i16 @pr49573_fn()
+ %tgt = call i16 @pr49573_fn(i1 %arg)
switch i16 %tgt, label %default.bb [
i16 0, label %case.0
i16 1, label %case.1
@@ -116,7 +123,7 @@ case.2:
br label %next
next:
- %tgt.2 = call i16 @pr49573_fn_2()
+ %tgt.2 = call i16 @pr49573_fn_2(i1 %arg)
switch i16 %tgt.2, label %default.bb [
i16 0, label %case.0
i16 2, label %case.2
@@ -124,14 +131,9 @@ next:
}
; Make sure a new unreachable BB is created.
-define void @pr49573_main_2() {
-; CHECK-LABEL: define {{[^@]+}}@pr49573_main_2() {
-; CHECK-NEXT: entry:
-; CHECK-NEXT: [[TGT:%.*]] = call i16 @pr49573_fn()
-; CHECK-NEXT: unreachable
-;
+define void @pr49573_main_2(i1 %arg) {
entry:
- %tgt = call i16 @pr49573_fn()
+ %tgt = call i16 @pr49573_fn(i1 %arg)
switch i16 %tgt, label %default.bb [
i16 0, label %case.0
i16 1, label %case.1
@@ -151,13 +153,18 @@ case.2:
ret void
}
-define internal i16 @pr49573_fn() {
-; CHECK-LABEL: define {{[^@]+}}@pr49573_fn() {
+define internal i16 @pr49573_fn(i1 %arg) {
+; CHECK-LABEL: define {{[^@]+}}@pr49573_fn
+; CHECK-SAME: (i1 [[ARG:%.*]]) {
; CHECK-NEXT: entry:
-; CHECK-NEXT: unreachable
+; CHECK-NEXT: br i1 [[ARG]], label [[THEN:%.*]], label [[ELSE:%.*]]
+; CHECK: then:
+; CHECK-NEXT: ret i16 0
+; CHECK: else:
+; CHECK-NEXT: ret i16 2
;
entry:
- br i1 undef, label %then, label %else
+ br i1 %arg, label %then, label %else
then:
ret i16 0
@@ -166,13 +173,18 @@ else:
ret i16 2
}
-define internal i16 @pr49573_fn_2() {
-; CHECK-LABEL: define {{[^@]+}}@pr49573_fn_2() {
+define internal i16 @pr49573_fn_2(i1 %arg) {
+; CHECK-LABEL: define {{[^@]+}}@pr49573_fn_2
+; CHECK-SAME: (i1 [[ARG:%.*]]) {
; CHECK-NEXT: entry:
-; CHECK-NEXT: unreachable
+; CHECK-NEXT: br i1 [[ARG]], label [[THEN:%.*]], label [[ELSE:%.*]]
+; CHECK: then:
+; CHECK-NEXT: ret i16 0
+; CHECK: else:
+; CHECK-NEXT: ret i16 2
;
entry:
- br i1 undef, label %then, label %else
+ br i1 %arg, label %then, label %else
then:
ret i16 0
>From b9e635636a5ae340436bfb62e9fc96d466b9c96d Mon Sep 17 00:00:00 2001
From: Lee <lee10202013 at gmail.com>
Date: Mon, 2 Dec 2024 19:56:45 -0700
Subject: [PATCH 04/10] Remove br i1 undef in SLPVectorizer directory
---
.../SLPVectorizer/AArch64/minimum-sizes.ll | 12 +--
.../AArch64/reorder-fmuladd-crash.ll | 10 +--
.../SLPVectorizer/AArch64/trunc-insertion.ll | 10 +--
.../SLPVectorizer/X86/crash_7zip.ll | 10 +--
.../SLPVectorizer/X86/crash_bullet.ll | 74 +++++++++----------
.../SLPVectorizer/X86/crash_bullet3.ll | 46 ++++++------
.../SLPVectorizer/X86/crash_dequeue.ll | 18 ++---
.../SLPVectorizer/X86/crash_flop7.ll | 18 ++---
.../X86/crash_lencod-inseltpoison.ll | 38 +++++-----
.../SLPVectorizer/X86/crash_lencod.ll | 38 +++++-----
.../SLPVectorizer/X86/crash_mandeltext.ll | 38 +++++-----
.../SLPVectorizer/X86/crash_sim4b1.ll | 62 ++++++++--------
.../SLPVectorizer/X86/crash_smallpt.ll | 28 +++----
.../SLPVectorizer/X86/crash_vectorizeTree.ll | 18 ++---
llvm/test/Transforms/SLPVectorizer/X86/cse.ll | 10 +--
.../X86/memory-runtime-checks.ll | 18 ++---
.../X86/no-scheduled-instructions.ll | 8 +-
.../Transforms/SLPVectorizer/X86/ordering.ll | 10 +--
.../Transforms/SLPVectorizer/X86/partail.ll | 6 +-
llvm/test/Transforms/SLPVectorizer/X86/phi.ll | 6 +-
.../SLPVectorizer/X86/phi_overalignedtype.ll | 6 +-
.../Transforms/SLPVectorizer/X86/pr16571.ll | 8 +-
.../SLPVectorizer/X86/remark_unsupported.ll | 6 +-
.../SLPVectorizer/X86/reorder_repeated_ops.ll | 6 +-
.../X86/reorder_with_reordered_users.ll | 10 +--
.../Transforms/SLPVectorizer/X86/resched.ll | 6 +-
.../X86/reuse-extracts-in-wider-vect.ll | 6 +-
.../X86/revectorized_rdx_crash.ll | 6 +-
.../X86/value-bug-inseltpoison.ll | 10 +--
.../Transforms/SLPVectorizer/X86/value-bug.ll | 10 +--
.../X86/vectorize-widest-phis.ll | 6 +-
.../slp-umax-rdx-matcher-crash.ll | 6 +-
32 files changed, 282 insertions(+), 282 deletions(-)
diff --git a/llvm/test/Transforms/SLPVectorizer/AArch64/minimum-sizes.ll b/llvm/test/Transforms/SLPVectorizer/AArch64/minimum-sizes.ll
index 920e1e64e3958f..356102ce817801 100644
--- a/llvm/test/Transforms/SLPVectorizer/AArch64/minimum-sizes.ll
+++ b/llvm/test/Transforms/SLPVectorizer/AArch64/minimum-sizes.ll
@@ -8,10 +8,10 @@ target triple = "aarch64--linux-gnu"
; should not compute a smaller size for %k.13 since it is in a use-def cycle
; and cannot be demoted.
;
-define fastcc void @PR26364() {
+define fastcc void @PR26364(i1 %arg) {
; CHECK-LABEL: @PR26364(
; CHECK-NEXT: entry:
-; CHECK-NEXT: br i1 undef, label [[FOR_END11:%.*]], label [[FOR_COND4:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[FOR_END11:%.*]], label [[FOR_COND4:%.*]]
; CHECK: for.cond4:
; CHECK-NEXT: [[K_13:%.*]] = phi i32 [ undef, [[ENTRY:%.*]] ], [ [[K_3:%.*]], [[FOR_COND4]] ]
; CHECK-NEXT: [[E_02:%.*]] = phi i32 [ 1, [[ENTRY]] ], [ 0, [[FOR_COND4]] ]
@@ -22,7 +22,7 @@ define fastcc void @PR26364() {
; CHECK-NEXT: ret void
;
entry:
- br i1 undef, label %for.end11, label %for.cond4
+ br i1 %arg, label %for.end11, label %for.cond4
for.cond4:
%k.13 = phi i32 [ undef, %entry ], [ %k.3, %for.cond4 ]
@@ -39,10 +39,10 @@ for.end11:
; every root in the vectorizable tree when computing minimum sizes since one
; root may require fewer bits than another.
;
-define void @PR26629(ptr %c) {
+define void @PR26629(ptr %c, i1 %arg) {
; CHECK-LABEL: @PR26629(
; CHECK-NEXT: entry:
-; CHECK-NEXT: br i1 undef, label [[FOR_PH:%.*]], label [[FOR_END:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[FOR_PH:%.*]], label [[FOR_END:%.*]]
; CHECK: for.ph:
; CHECK-NEXT: [[TMP0:%.*]] = load i32, ptr [[C:%.*]], align 4
; CHECK-NEXT: br label [[FOR_BODY:%.*]]
@@ -59,7 +59,7 @@ define void @PR26629(ptr %c) {
; CHECK-NEXT: ret void
;
entry:
- br i1 undef, label %for.ph, label %for.end
+ br i1 %arg, label %for.ph, label %for.end
for.ph:
%0 = load i32, ptr %c, align 4
diff --git a/llvm/test/Transforms/SLPVectorizer/AArch64/reorder-fmuladd-crash.ll b/llvm/test/Transforms/SLPVectorizer/AArch64/reorder-fmuladd-crash.ll
index dc05967af15295..f5e904467baa7f 100644
--- a/llvm/test/Transforms/SLPVectorizer/AArch64/reorder-fmuladd-crash.ll
+++ b/llvm/test/Transforms/SLPVectorizer/AArch64/reorder-fmuladd-crash.ll
@@ -1,7 +1,7 @@
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
; RUN: opt < %s -passes=slp-vectorizer -S -mtriple=aarch64-w32-windows-gnu | FileCheck %s
-define i32 @foo(i32 %v1, double %v2) {
+define i32 @foo(i32 %v1, double %v2, i1 %arg, i32 %arg2) {
; CHECK-LABEL: @foo(
; CHECK-NEXT: entry:
; CHECK-NEXT: [[TMP0:%.*]] = insertelement <2 x i32> <i32 poison, i32 undef>, i32 [[V1:%.*]], i32 0
@@ -15,7 +15,7 @@ define i32 @foo(i32 %v1, double %v2) {
; CHECK: if.end:
; CHECK-NEXT: br label [[FOR_COND15:%.*]]
; CHECK: for.end39:
-; CHECK-NEXT: switch i32 undef, label [[DO_BODY:%.*]] [
+; CHECK-NEXT: switch i32 %arg2, label [[DO_BODY:%.*]] [
; CHECK-NEXT: i32 0, label [[SW_BB:%.*]]
; CHECK-NEXT: i32 1, label [[SW_BB195:%.*]]
; CHECK-NEXT: ]
@@ -39,7 +39,7 @@ define i32 @foo(i32 %v1, double %v2) {
; CHECK: if.end.1:
; CHECK-NEXT: br label [[FOR_COND15_1:%.*]]
; CHECK: for.cond15.1:
-; CHECK-NEXT: br i1 undef, label [[FOR_END39:%.*]], label [[FOR_COND15_PREHEADER]]
+; CHECK-NEXT: br i1 %arg, label [[FOR_END39:%.*]], label [[FOR_COND15_PREHEADER]]
;
entry:
%conv = sitofp i32 undef to double
@@ -56,7 +56,7 @@ if.end: ; preds = %for.cond15.preheade
br label %for.cond15
for.end39: ; preds = %for.cond15.1
- switch i32 undef, label %do.body [
+ switch i32 %arg2, label %do.body [
i32 0, label %sw.bb
i32 1, label %sw.bb195
]
@@ -99,7 +99,7 @@ if.end.1: ; preds = %for.cond15
br label %for.cond15.1
for.cond15.1: ; preds = %if.end.1
- br i1 undef, label %for.end39, label %for.cond15.preheader
+ br i1 %arg, label %for.end39, label %for.cond15.preheader
}
declare double @llvm.fmuladd.f64(double, double, double)
diff --git a/llvm/test/Transforms/SLPVectorizer/AArch64/trunc-insertion.ll b/llvm/test/Transforms/SLPVectorizer/AArch64/trunc-insertion.ll
index 9910090d43eae9..82761b458efcfc 100644
--- a/llvm/test/Transforms/SLPVectorizer/AArch64/trunc-insertion.ll
+++ b/llvm/test/Transforms/SLPVectorizer/AArch64/trunc-insertion.ll
@@ -3,13 +3,13 @@
target triple = "aarch64-unknown-linux-gnu"
@d = internal unnamed_addr global i32 5, align 4
-define dso_local void @l() local_unnamed_addr {
+define dso_local void @l(i1 %arg) local_unnamed_addr {
; CHECK-LABEL: @l(
; CHECK-NEXT: bb:
; CHECK-NEXT: br label [[BB1:%.*]]
; CHECK: bb1:
; CHECK-NEXT: [[TMP0:%.*]] = phi <2 x i16> [ undef, [[BB:%.*]] ], [ [[TMP9:%.*]], [[BB25:%.*]] ]
-; CHECK-NEXT: br i1 undef, label [[BB3:%.*]], label [[BB11:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[BB3:%.*]], label [[BB11:%.*]]
; CHECK: bb3:
; CHECK-NEXT: [[I4:%.*]] = zext i1 undef to i32
; CHECK-NEXT: [[TMP1:%.*]] = xor <2 x i16> [[TMP0]], undef
@@ -34,7 +34,7 @@ define dso_local void @l() local_unnamed_addr {
; CHECK-NEXT: [[TMP13:%.*]] = zext i1 [[TMP12]] to i32
; CHECK-NEXT: [[I32:%.*]] = and i32 [[I31]], [[TMP13]]
; CHECK-NEXT: [[I33:%.*]] = and i32 [[I32]], [[I28]]
-; CHECK-NEXT: br i1 undef, label [[BB34:%.*]], label [[BB1]]
+; CHECK-NEXT: br i1 %arg, label [[BB34:%.*]], label [[BB1]]
; CHECK: bb34:
; CHECK-NEXT: [[I35:%.*]] = phi i32 [ [[I33]], [[BB25]] ]
; CHECK-NEXT: br label [[BB36:%.*]]
@@ -48,7 +48,7 @@ bb:
bb1: ; preds = %bb25, %bb
%i = phi i16 [ undef, %bb ], [ %i29, %bb25 ]
%i2 = phi i16 [ undef, %bb ], [ %i30, %bb25 ]
- br i1 undef, label %bb3, label %bb11
+ br i1 %arg, label %bb3, label %bb11
bb3: ; preds = %bb1
%i4 = zext i1 undef to i32
@@ -85,7 +85,7 @@ bb25: ; preds = %bb11, %bb3
%i31 = and i32 undef, %i26
%i32 = and i32 %i31, %i27
%i33 = and i32 %i32, %i28
- br i1 undef, label %bb34, label %bb1
+ br i1 %arg, label %bb34, label %bb1
bb34: ; preds = %bb25
%i35 = phi i32 [ %i33, %bb25 ]
diff --git a/llvm/test/Transforms/SLPVectorizer/X86/crash_7zip.ll b/llvm/test/Transforms/SLPVectorizer/X86/crash_7zip.ll
index 607d7f78887842..c029781142af33 100644
--- a/llvm/test/Transforms/SLPVectorizer/X86/crash_7zip.ll
+++ b/llvm/test/Transforms/SLPVectorizer/X86/crash_7zip.ll
@@ -7,7 +7,7 @@ target triple = "x86_64-apple-macosx10.8.0"
%struct.CLzmaDec.1.28.55.82.103.124.145.166.181.196.229.259.334 = type { %struct._CLzmaProps.0.27.54.81.102.123.144.165.180.195.228.258.333, ptr, ptr, ptr, i32, i32, i64, i64, i32, i32, i32, [4 x i32], i32, i32, i32, i32, i32, [20 x i8] }
%struct._CLzmaProps.0.27.54.81.102.123.144.165.180.195.228.258.333 = type { i32, i32, i32, i32 }
-define fastcc void @LzmaDec_DecodeReal2(ptr %p) {
+define fastcc void @LzmaDec_DecodeReal2(ptr %p, i1 %arg) {
; CHECK-LABEL: @LzmaDec_DecodeReal2(
; CHECK-NEXT: entry:
; CHECK-NEXT: [[RANGE20_I:%.*]] = getelementptr inbounds [[STRUCT_CLZMADEC_1_28_55_82_103_124_145_166_181_196_229_259_334:%.*]], ptr [[P:%.*]], i64 0, i32 4
@@ -15,13 +15,13 @@ define fastcc void @LzmaDec_DecodeReal2(ptr %p) {
; CHECK: do.body66.i:
; CHECK-NEXT: [[TMP0:%.*]] = phi <2 x i32> [ [[TMP3:%.*]], [[DO_COND_I:%.*]] ], [ undef, [[ENTRY:%.*]] ]
; CHECK-NEXT: [[TMP1:%.*]] = select <2 x i1> undef, <2 x i32> undef, <2 x i32> [[TMP0]]
-; CHECK-NEXT: br i1 undef, label [[DO_COND_I]], label [[IF_ELSE_I:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[DO_COND_I]], label [[IF_ELSE_I:%.*]]
; CHECK: if.else.i:
; CHECK-NEXT: [[TMP2:%.*]] = sub <2 x i32> [[TMP1]], undef
; CHECK-NEXT: br label [[DO_COND_I]]
; CHECK: do.cond.i:
; CHECK-NEXT: [[TMP3]] = phi <2 x i32> [ [[TMP2]], [[IF_ELSE_I]] ], [ [[TMP1]], [[DO_BODY66_I]] ]
-; CHECK-NEXT: br i1 undef, label [[DO_BODY66_I]], label [[DO_END1006_I:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[DO_BODY66_I]], label [[DO_END1006_I:%.*]]
; CHECK: do.end1006.i:
; CHECK-NEXT: [[TMP4:%.*]] = select <2 x i1> undef, <2 x i32> undef, <2 x i32> [[TMP3]]
; CHECK-NEXT: store <2 x i32> [[TMP4]], ptr [[RANGE20_I]], align 4
@@ -37,7 +37,7 @@ do.body66.i: ; preds = %do.cond.i, %entry
%code.2.i = phi i32 [ %code.4.i, %do.cond.i ], [ undef, %entry ]
%.range.2.i = select i1 undef, i32 undef, i32 %range.2.i
%.code.2.i = select i1 undef, i32 undef, i32 %code.2.i
- br i1 undef, label %do.cond.i, label %if.else.i
+ br i1 %arg, label %do.cond.i, label %if.else.i
if.else.i: ; preds = %do.body66.i
%sub91.i = sub i32 %.range.2.i, undef
@@ -47,7 +47,7 @@ if.else.i: ; preds = %do.body66.i
do.cond.i: ; preds = %if.else.i, %do.body66.i
%range.4.i = phi i32 [ %sub91.i, %if.else.i ], [ undef, %do.body66.i ]
%code.4.i = phi i32 [ %sub92.i, %if.else.i ], [ %.code.2.i, %do.body66.i ]
- br i1 undef, label %do.body66.i, label %do.end1006.i
+ br i1 %arg, label %do.body66.i, label %do.end1006.i
do.end1006.i: ; preds = %do.cond.i
%.range.4.i = select i1 undef, i32 undef, i32 %range.4.i
diff --git a/llvm/test/Transforms/SLPVectorizer/X86/crash_bullet.ll b/llvm/test/Transforms/SLPVectorizer/X86/crash_bullet.ll
index f1f83c0663099a..291edbbc925bdb 100644
--- a/llvm/test/Transforms/SLPVectorizer/X86/crash_bullet.ll
+++ b/llvm/test/Transforms/SLPVectorizer/X86/crash_bullet.ll
@@ -6,17 +6,17 @@ target triple = "x86_64-apple-macosx10.8.0"
%"struct.btTypedConstraint::btConstraintInfo1.17.157.357.417.477.960" = type { i32, i32 }
-define void @_ZN23btGeneric6DofConstraint8getInfo1EPN17btTypedConstraint17btConstraintInfo1E(ptr nocapture %info) {
+define void @_ZN23btGeneric6DofConstraint8getInfo1EPN17btTypedConstraint17btConstraintInfo1E(ptr nocapture %info, i1 %arg) {
; CHECK-LABEL: @_ZN23btGeneric6DofConstraint8getInfo1EPN17btTypedConstraint17btConstraintInfo1E(
; CHECK-NEXT: entry:
-; CHECK-NEXT: br i1 undef, label [[IF_ELSE:%.*]], label [[IF_THEN:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[IF_ELSE:%.*]], label [[IF_THEN:%.*]]
; CHECK: if.then:
; CHECK-NEXT: ret void
; CHECK: if.else:
; CHECK-NEXT: [[NUB5:%.*]] = getelementptr inbounds %"struct.btTypedConstraint::btConstraintInfo1.17.157.357.417.477.960", ptr [[INFO:%.*]], i64 0, i32 1
-; CHECK-NEXT: br i1 undef, label [[LAND_LHS_TRUE_I_1:%.*]], label [[IF_THEN7_1:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[LAND_LHS_TRUE_I_1:%.*]], label [[IF_THEN7_1:%.*]]
; CHECK: land.lhs.true.i.1:
-; CHECK-NEXT: br i1 undef, label [[FOR_INC_1:%.*]], label [[IF_THEN7_1]]
+; CHECK-NEXT: br i1 %arg, label [[FOR_INC_1:%.*]], label [[IF_THEN7_1]]
; CHECK: if.then7.1:
; CHECK-NEXT: store <2 x i32> <i32 1, i32 5>, ptr [[INFO]], align 4
; CHECK-NEXT: br label [[FOR_INC_1]]
@@ -30,17 +30,17 @@ define void @_ZN23btGeneric6DofConstraint8getInfo1EPN17btTypedConstraint17btCons
; CHECK-NEXT: unreachable
;
entry:
- br i1 undef, label %if.else, label %if.then
+ br i1 %arg, label %if.else, label %if.then
if.then: ; preds = %entry
ret void
if.else: ; preds = %entry
%nub5 = getelementptr inbounds %"struct.btTypedConstraint::btConstraintInfo1.17.157.357.417.477.960", ptr %info, i64 0, i32 1
- br i1 undef, label %land.lhs.true.i.1, label %if.then7.1
+ br i1 %arg, label %land.lhs.true.i.1, label %if.then7.1
land.lhs.true.i.1: ; preds = %if.else
- br i1 undef, label %for.inc.1, label %if.then7.1
+ br i1 %arg, label %for.inc.1, label %if.then7.1
if.then7.1: ; preds = %land.lhs.true.i.1, %if.else
%inc.1 = add nsw i32 0, 1
@@ -63,7 +63,7 @@ for.inc.1: ; preds = %if.then7.1, %land.l
%class.btVector3.5.30.65.90.115.140.175.185.260.280.330 = type { [4 x float] }
%class.btVector4.7.32.67.92.117.142.177.187.262.282.331 = type { %class.btVector3.5.30.65.90.115.140.175.185.260.280.330 }
-define void @_ZN30GIM_TRIANGLE_CALCULATION_CACHE18triangle_collisionERK9btVector3S2_S2_fS2_S2_S2_fR25GIM_TRIANGLE_CONTACT_DATA(ptr %this) {
+define void @_ZN30GIM_TRIANGLE_CALCULATION_CACHE18triangle_collisionERK9btVector3S2_S2_fS2_S2_S2_fR25GIM_TRIANGLE_CONTACT_DATA(ptr %this, i1 %arg) {
; CHECK-LABEL: @_ZN30GIM_TRIANGLE_CALCULATION_CACHE18triangle_collisionERK9btVector3S2_S2_fS2_S2_S2_fR25GIM_TRIANGLE_CONTACT_DATA(
; CHECK-NEXT: entry:
; CHECK-NEXT: [[ARRAYIDX26:%.*]] = getelementptr inbounds [[CLASS_GIM_TRIANGLE_CALCULATION_CACHE_9_34_69_94_119_144_179_189_264_284_332:%.*]], ptr [[THIS:%.*]], i64 0, i32 2, i64 0, i32 0, i64 1
@@ -76,9 +76,9 @@ define void @_ZN30GIM_TRIANGLE_CALCULATION_CACHE18triangle_collisionERK9btVector
; CHECK-NEXT: store float [[TMP4]], ptr undef, align 4
; CHECK-NEXT: [[TMP5:%.*]] = fsub <2 x float> [[TMP2]], [[TMP3]]
; CHECK-NEXT: store <2 x float> [[TMP5]], ptr [[ARRAYIDX26]], align 4
-; CHECK-NEXT: br i1 undef, label [[IF_ELSE1609:%.*]], label [[IF_THEN1595:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[IF_ELSE1609:%.*]], label [[IF_THEN1595:%.*]]
; CHECK: if.then1595:
-; CHECK-NEXT: br i1 undef, label [[RETURN:%.*]], label [[FOR_BODY_LR_PH_I_I1702:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[RETURN:%.*]], label [[FOR_BODY_LR_PH_I_I1702:%.*]]
; CHECK: for.body.lr.ph.i.i1702:
; CHECK-NEXT: unreachable
; CHECK: if.else1609:
@@ -99,10 +99,10 @@ entry:
%sub639 = fsub float %add626, undef
%sub652 = fsub float %add626, %sub639
store float %sub652, ptr %arrayidx36, align 4
- br i1 undef, label %if.else1609, label %if.then1595
+ br i1 %arg, label %if.else1609, label %if.then1595
if.then1595: ; preds = %entry
- br i1 undef, label %return, label %for.body.lr.ph.i.i1702
+ br i1 %arg, label %return, label %for.body.lr.ph.i.i1702
for.body.lr.ph.i.i1702: ; preds = %if.then1595
unreachable
@@ -114,34 +114,34 @@ return: ; preds = %if.then1595
ret void
}
-define void @_Z8dBoxBox2RK9btVector3PKfS1_S1_S3_S1_RS_PfPiiP12dContactGeomiRN36btDiscreteCollisionDetectorInterface6ResultE() {
+define void @_Z8dBoxBox2RK9btVector3PKfS1_S1_S3_S1_RS_PfPiiP12dContactGeomiRN36btDiscreteCollisionDetectorInterface6ResultE(i1 %arg) {
; CHECK-LABEL: @_Z8dBoxBox2RK9btVector3PKfS1_S1_S3_S1_RS_PfPiiP12dContactGeomiRN36btDiscreteCollisionDetectorInterface6ResultE(
; CHECK-NEXT: entry:
-; CHECK-NEXT: br i1 undef, label [[RETURN:%.*]], label [[IF_END:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[RETURN:%.*]], label [[IF_END:%.*]]
; CHECK: if.end:
-; CHECK-NEXT: br i1 undef, label [[RETURN]], label [[IF_END111:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[RETURN]], label [[IF_END111:%.*]]
; CHECK: if.end111:
-; CHECK-NEXT: br i1 undef, label [[RETURN]], label [[IF_END136:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[RETURN]], label [[IF_END136:%.*]]
; CHECK: if.end136:
-; CHECK-NEXT: br i1 undef, label [[RETURN]], label [[IF_END162:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[RETURN]], label [[IF_END162:%.*]]
; CHECK: if.end162:
-; CHECK-NEXT: br i1 undef, label [[RETURN]], label [[IF_END189:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[RETURN]], label [[IF_END189:%.*]]
; CHECK: if.end189:
-; CHECK-NEXT: br i1 undef, label [[RETURN]], label [[IF_END216:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[RETURN]], label [[IF_END216:%.*]]
; CHECK: if.end216:
-; CHECK-NEXT: br i1 undef, label [[IF_THEN218:%.*]], label [[IF_END225:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[IF_THEN218:%.*]], label [[IF_END225:%.*]]
; CHECK: if.then218:
; CHECK-NEXT: br label [[IF_END225]]
; CHECK: if.end225:
-; CHECK-NEXT: br i1 undef, label [[RETURN]], label [[IF_END248:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[RETURN]], label [[IF_END248:%.*]]
; CHECK: if.end248:
-; CHECK-NEXT: br i1 undef, label [[RETURN]], label [[IF_END304:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[RETURN]], label [[IF_END304:%.*]]
; CHECK: if.end304:
-; CHECK-NEXT: br i1 undef, label [[RETURN]], label [[IF_END361:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[RETURN]], label [[IF_END361:%.*]]
; CHECK: if.end361:
-; CHECK-NEXT: br i1 undef, label [[IF_THEN370:%.*]], label [[IF_END395:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[IF_THEN370:%.*]], label [[IF_END395:%.*]]
; CHECK: if.then370:
-; CHECK-NEXT: br i1 undef, label [[IF_THEN374:%.*]], label [[IF_END395]]
+; CHECK-NEXT: br i1 %arg, label [[IF_THEN374:%.*]], label [[IF_END395]]
; CHECK: if.then374:
; CHECK-NEXT: br label [[IF_END395]]
; CHECK: if.end395:
@@ -152,47 +152,47 @@ define void @_Z8dBoxBox2RK9btVector3PKfS1_S1_S3_S1_RS_PfPiiP12dContactGeomiRN36b
entry:
%add8.i2343 = fadd float undef, undef
%add8.i2381 = fadd float undef, undef
- br i1 undef, label %return, label %if.end
+ br i1 %arg, label %return, label %if.end
if.end: ; preds = %entry
- br i1 undef, label %return, label %if.end111
+ br i1 %arg, label %return, label %if.end111
if.end111: ; preds = %if.end
- br i1 undef, label %return, label %if.end136
+ br i1 %arg, label %return, label %if.end136
if.end136: ; preds = %if.end111
- br i1 undef, label %return, label %if.end162
+ br i1 %arg, label %return, label %if.end162
if.end162: ; preds = %if.end136
- br i1 undef, label %return, label %if.end189
+ br i1 %arg, label %return, label %if.end189
if.end189: ; preds = %if.end162
- br i1 undef, label %return, label %if.end216
+ br i1 %arg, label %return, label %if.end216
if.end216: ; preds = %if.end189
- br i1 undef, label %if.then218, label %if.end225
+ br i1 %arg, label %if.then218, label %if.end225
if.then218: ; preds = %if.end216
br label %if.end225
if.end225: ; preds = %if.then218, %if.end216
- br i1 undef, label %return, label %if.end248
+ br i1 %arg, label %return, label %if.end248
if.end248: ; preds = %if.end225
- br i1 undef, label %return, label %if.end304
+ br i1 %arg, label %return, label %if.end304
if.end304: ; preds = %if.end248
%mul341 = fmul float undef, %add8.i2343
%mul344 = fmul float undef, %add8.i2381
%sub345 = fsub float %mul341, %mul344
- br i1 undef, label %return, label %if.end361
+ br i1 %arg, label %return, label %if.end361
if.end361: ; preds = %if.end304
%mul364 = fmul float %add8.i2381, %add8.i2381
- br i1 undef, label %if.then370, label %if.end395
+ br i1 %arg, label %if.then370, label %if.end395
if.then370: ; preds = %if.end361
- br i1 undef, label %if.then374, label %if.end395
+ br i1 %arg, label %if.then374, label %if.end395
if.then374: ; preds = %if.then370
%cmp392 = fcmp olt float %sub345, 0.000000e+00
diff --git a/llvm/test/Transforms/SLPVectorizer/X86/crash_bullet3.ll b/llvm/test/Transforms/SLPVectorizer/X86/crash_bullet3.ll
index 925b348cdeec1f..55e691b39d78c7 100644
--- a/llvm/test/Transforms/SLPVectorizer/X86/crash_bullet3.ll
+++ b/llvm/test/Transforms/SLPVectorizer/X86/crash_bullet3.ll
@@ -7,36 +7,36 @@ target triple = "x86_64-apple-macosx10.8.0"
%class.btVector3.23.221.463.485.507.573.595.683.727.749.815.837.991.1585.1607.1629.1651.1849.2047.2069.2091.2113 = type { [4 x float] }
; Function Attrs: ssp uwtable
-define void @_ZN11HullLibrary15CleanupVerticesEjPK9btVector3jRjPS0_fRS0_(ptr %vertices) #0 align 2 {
+define void @_ZN11HullLibrary15CleanupVerticesEjPK9btVector3jRjPS0_fRS0_(ptr %vertices, i1 %arg) #0 align 2 {
; CHECK-LABEL: @_ZN11HullLibrary15CleanupVerticesEjPK9btVector3jRjPS0_fRS0_(
; CHECK-NEXT: entry:
-; CHECK-NEXT: br i1 undef, label [[RETURN:%.*]], label [[IF_END:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[RETURN:%.*]], label [[IF_END:%.*]]
; CHECK: if.end:
; CHECK-NEXT: br label [[FOR_BODY:%.*]]
; CHECK: for.body:
-; CHECK-NEXT: br i1 undef, label [[IF_THEN17_1:%.*]], label [[IF_END22_1:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[IF_THEN17_1:%.*]], label [[IF_END22_1:%.*]]
; CHECK: for.end36:
; CHECK-NEXT: br label [[FOR_BODY144:%.*]]
; CHECK: for.body144:
-; CHECK-NEXT: br i1 undef, label [[FOR_END227:%.*]], label [[FOR_BODY144]]
+; CHECK-NEXT: br i1 %arg, label [[FOR_END227:%.*]], label [[FOR_BODY144]]
; CHECK: for.end227:
-; CHECK-NEXT: br i1 undef, label [[FOR_END271:%.*]], label [[FOR_BODY233:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[FOR_END271:%.*]], label [[FOR_BODY233:%.*]]
; CHECK: for.body233:
-; CHECK-NEXT: br i1 undef, label [[FOR_BODY233]], label [[FOR_END271]]
+; CHECK-NEXT: br i1 %arg, label [[FOR_BODY233]], label [[FOR_END271]]
; CHECK: for.end271:
; CHECK-NEXT: [[TMP0:%.*]] = phi <2 x float> [ splat (float 0x47EFFFFFE0000000), [[FOR_END227]] ], [ undef, [[FOR_BODY233]] ]
; CHECK-NEXT: [[TMP1:%.*]] = fsub <2 x float> undef, [[TMP0]]
-; CHECK-NEXT: br i1 undef, label [[IF_THEN291:%.*]], label [[RETURN]]
+; CHECK-NEXT: br i1 %arg, label [[IF_THEN291:%.*]], label [[RETURN]]
; CHECK: if.then291:
; CHECK-NEXT: [[TMP2:%.*]] = fmul <2 x float> [[TMP1]], splat (float 5.000000e-01)
; CHECK-NEXT: [[TMP3:%.*]] = fadd <2 x float> [[TMP0]], [[TMP2]]
-; CHECK-NEXT: br i1 undef, label [[IF_END332:%.*]], label [[IF_ELSE319:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[IF_END332:%.*]], label [[IF_ELSE319:%.*]]
; CHECK: if.else319:
-; CHECK-NEXT: br i1 undef, label [[IF_THEN325:%.*]], label [[IF_END327:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[IF_THEN325:%.*]], label [[IF_END327:%.*]]
; CHECK: if.then325:
; CHECK-NEXT: br label [[IF_END327]]
; CHECK: if.end327:
-; CHECK-NEXT: br i1 undef, label [[IF_THEN329:%.*]], label [[IF_END332]]
+; CHECK-NEXT: br i1 %arg, label [[IF_THEN329:%.*]], label [[IF_END332]]
; CHECK: if.then329:
; CHECK-NEXT: br label [[IF_END332]]
; CHECK: if.end332:
@@ -49,55 +49,55 @@ define void @_ZN11HullLibrary15CleanupVerticesEjPK9btVector3jRjPS0_fRS0_(ptr %ve
; CHECK: if.then17.1:
; CHECK-NEXT: br label [[IF_END22_1]]
; CHECK: if.end22.1:
-; CHECK-NEXT: br i1 undef, label [[IF_THEN17_2:%.*]], label [[IF_END22_2:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[IF_THEN17_2:%.*]], label [[IF_END22_2:%.*]]
; CHECK: if.then17.2:
; CHECK-NEXT: br label [[IF_END22_2]]
; CHECK: if.end22.2:
-; CHECK-NEXT: br i1 undef, label [[FOR_END36:%.*]], label [[FOR_BODY]]
+; CHECK-NEXT: br i1 %arg, label [[FOR_END36:%.*]], label [[FOR_BODY]]
;
entry:
- br i1 undef, label %return, label %if.end
+ br i1 %arg, label %return, label %if.end
if.end: ; preds = %entry
br label %for.body
for.body: ; preds = %if.end22.2, %if.end
- br i1 undef, label %if.then17.1, label %if.end22.1
+ br i1 %arg, label %if.then17.1, label %if.end22.1
for.end36: ; preds = %if.end22.2
br label %for.body144
for.body144: ; preds = %for.body144, %for.end36
- br i1 undef, label %for.end227, label %for.body144
+ br i1 %arg, label %for.end227, label %for.body144
for.end227: ; preds = %for.body144
- br i1 undef, label %for.end271, label %for.body233
+ br i1 %arg, label %for.end271, label %for.body233
for.body233: ; preds = %for.body233, %for.end227
- br i1 undef, label %for.body233, label %for.end271
+ br i1 %arg, label %for.body233, label %for.end271
for.end271: ; preds = %for.body233, %for.end227
%0 = phi float [ 0x47EFFFFFE0000000, %for.end227 ], [ undef, %for.body233 ]
%1 = phi float [ 0x47EFFFFFE0000000, %for.end227 ], [ undef, %for.body233 ]
%sub275 = fsub float undef, %1
%sub279 = fsub float undef, %0
- br i1 undef, label %if.then291, label %return
+ br i1 %arg, label %if.then291, label %return
if.then291: ; preds = %for.end271
%mul292 = fmul float %sub275, 5.000000e-01
%add294 = fadd float %1, %mul292
%mul295 = fmul float %sub279, 5.000000e-01
%add297 = fadd float %0, %mul295
- br i1 undef, label %if.end332, label %if.else319
+ br i1 %arg, label %if.end332, label %if.else319
if.else319: ; preds = %if.then291
- br i1 undef, label %if.then325, label %if.end327
+ br i1 %arg, label %if.then325, label %if.end327
if.then325: ; preds = %if.else319
br label %if.end327
if.end327: ; preds = %if.then325, %if.else319
- br i1 undef, label %if.then329, label %if.end332
+ br i1 %arg, label %if.then329, label %if.end332
if.then329: ; preds = %if.end327
br label %if.end332
@@ -119,13 +119,13 @@ if.then17.1: ; preds = %for.body
br label %if.end22.1
if.end22.1: ; preds = %if.then17.1, %for.body
- br i1 undef, label %if.then17.2, label %if.end22.2
+ br i1 %arg, label %if.then17.2, label %if.end22.2
if.then17.2: ; preds = %if.end22.1
br label %if.end22.2
if.end22.2: ; preds = %if.then17.2, %if.end22.1
- br i1 undef, label %for.end36, label %for.body
+ br i1 %arg, label %for.end36, label %for.body
}
attributes #0 = { ssp uwtable "less-precise-fpmad"="false" "frame-pointer"="none" "no-infs-fp-math"="false" "no-nans-fp-math"="false" "unsafe-fp-math"="false" "use-soft-float"="false" }
diff --git a/llvm/test/Transforms/SLPVectorizer/X86/crash_dequeue.ll b/llvm/test/Transforms/SLPVectorizer/X86/crash_dequeue.ll
index 4de16a5d57793d..faf4496ce27225 100644
--- a/llvm/test/Transforms/SLPVectorizer/X86/crash_dequeue.ll
+++ b/llvm/test/Transforms/SLPVectorizer/X86/crash_dequeue.ll
@@ -6,23 +6,23 @@ target triple = "x86_64-apple-macosx10.8.0"
%"struct.std::_Deque_iterator.4.157.174.208.259.276.344.731" = type { ptr, ptr, ptr, ptr }
; Function Attrs: nounwind ssp uwtable
-define void @_ZSt6uniqueISt15_Deque_iteratorIdRdPdEET_S4_S4_(ptr %__first, ptr nocapture %__last) {
+define void @_ZSt6uniqueISt15_Deque_iteratorIdRdPdEET_S4_S4_(ptr %__first, ptr nocapture %__last, i1 %arg) {
; CHECK-LABEL: @_ZSt6uniqueISt15_Deque_iteratorIdRdPdEET_S4_S4_(
; CHECK-NEXT: entry:
; CHECK-NEXT: [[TMP0:%.*]] = load ptr, ptr [[__FIRST:%.*]], align 8
; CHECK-NEXT: [[TMP1:%.*]] = load <2 x ptr>, ptr [[__LAST:%.*]], align 8
; CHECK-NEXT: [[TMP2:%.*]] = insertelement <2 x ptr> [[TMP1]], ptr [[TMP0]], i32 0
-; CHECK-NEXT: br i1 undef, label [[_ZST13ADJACENT_FINDIST15_DEQUE_ITERATORIDRDPDEET_S4_S4__EXIT:%.*]], label [[WHILE_COND_I_PREHEADER:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[_ZST13ADJACENT_FINDIST15_DEQUE_ITERATORIDRDPDEET_S4_S4__EXIT:%.*]], label [[WHILE_COND_I_PREHEADER:%.*]]
; CHECK: while.cond.i.preheader:
; CHECK-NEXT: br label [[WHILE_COND_I:%.*]]
; CHECK: while.cond.i:
-; CHECK-NEXT: br i1 undef, label [[_ZST13ADJACENT_FINDIST15_DEQUE_ITERATORIDRDPDEET_S4_S4__EXIT]], label [[WHILE_BODY_I:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[_ZST13ADJACENT_FINDIST15_DEQUE_ITERATORIDRDPDEET_S4_S4__EXIT]], label [[WHILE_BODY_I:%.*]]
; CHECK: while.body.i:
-; CHECK-NEXT: br i1 undef, label [[_ZST13ADJACENT_FINDIST15_DEQUE_ITERATORIDRDPDEET_S4_S4__EXIT]], label [[WHILE_COND_I]]
+; CHECK-NEXT: br i1 %arg, label [[_ZST13ADJACENT_FINDIST15_DEQUE_ITERATORIDRDPDEET_S4_S4__EXIT]], label [[WHILE_COND_I]]
; CHECK: _ZSt13adjacent_findISt15_Deque_iteratorIdRdPdEET_S4_S4_.exit:
; CHECK-NEXT: [[TMP3:%.*]] = phi <2 x ptr> [ [[TMP2]], [[ENTRY:%.*]] ], [ [[TMP1]], [[WHILE_COND_I]] ], [ undef, [[WHILE_BODY_I]] ]
; CHECK-NEXT: store <2 x ptr> [[TMP3]], ptr [[__FIRST]], align 8
-; CHECK-NEXT: br i1 undef, label [[IF_THEN_I55:%.*]], label [[WHILE_COND:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[IF_THEN_I55:%.*]], label [[WHILE_COND:%.*]]
; CHECK: if.then.i55:
; CHECK-NEXT: br label [[WHILE_COND]]
; CHECK: while.cond:
@@ -34,23 +34,23 @@ entry:
%1 = load ptr, ptr %__last, align 8
%_M_first3.i.i83 = getelementptr inbounds %"struct.std::_Deque_iterator.4.157.174.208.259.276.344.731", ptr %__last, i64 0, i32 1
%2 = load ptr, ptr %_M_first3.i.i83, align 8
- br i1 undef, label %_ZSt13adjacent_findISt15_Deque_iteratorIdRdPdEET_S4_S4_.exit, label %while.cond.i.preheader
+ br i1 %arg, label %_ZSt13adjacent_findISt15_Deque_iteratorIdRdPdEET_S4_S4_.exit, label %while.cond.i.preheader
while.cond.i.preheader: ; preds = %entry
br label %while.cond.i
while.cond.i: ; preds = %while.body.i, %while.cond.i.preheader
- br i1 undef, label %_ZSt13adjacent_findISt15_Deque_iteratorIdRdPdEET_S4_S4_.exit, label %while.body.i
+ br i1 %arg, label %_ZSt13adjacent_findISt15_Deque_iteratorIdRdPdEET_S4_S4_.exit, label %while.body.i
while.body.i: ; preds = %while.cond.i
- br i1 undef, label %_ZSt13adjacent_findISt15_Deque_iteratorIdRdPdEET_S4_S4_.exit, label %while.cond.i
+ br i1 %arg, label %_ZSt13adjacent_findISt15_Deque_iteratorIdRdPdEET_S4_S4_.exit, label %while.cond.i
_ZSt13adjacent_findISt15_Deque_iteratorIdRdPdEET_S4_S4_.exit: ; preds = %while.body.i, %while.cond.i, %entry
%3 = phi ptr [ %2, %entry ], [ %2, %while.cond.i ], [ undef, %while.body.i ]
%4 = phi ptr [ %0, %entry ], [ %1, %while.cond.i ], [ undef, %while.body.i ]
store ptr %4, ptr %__first, align 8
store ptr %3, ptr %_M_first3.i.i, align 8
- br i1 undef, label %if.then.i55, label %while.cond
+ br i1 %arg, label %if.then.i55, label %while.cond
if.then.i55: ; preds = %_ZSt13adjacent_findISt15_Deque_iteratorIdRdPdEET_S4_S4_.exit
br label %while.cond
diff --git a/llvm/test/Transforms/SLPVectorizer/X86/crash_flop7.ll b/llvm/test/Transforms/SLPVectorizer/X86/crash_flop7.ll
index 371b06869841b2..fc1bd856da9c3f 100644
--- a/llvm/test/Transforms/SLPVectorizer/X86/crash_flop7.ll
+++ b/llvm/test/Transforms/SLPVectorizer/X86/crash_flop7.ll
@@ -5,20 +5,20 @@ target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f3
target triple = "x86_64-apple-macosx10.8.0"
; Function Attrs: nounwind ssp uwtable
-define void @main() #0 {
+define void @main(i1 %arg) #0 {
; CHECK-LABEL: @main(
; CHECK-NEXT: entry:
-; CHECK-NEXT: br i1 undef, label [[WHILE_BODY:%.*]], label [[WHILE_END:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[WHILE_BODY:%.*]], label [[WHILE_END:%.*]]
; CHECK: while.body:
; CHECK-NEXT: unreachable
; CHECK: while.end:
-; CHECK-NEXT: br i1 undef, label [[FOR_END80:%.*]], label [[FOR_BODY75_LR_PH:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[FOR_END80:%.*]], label [[FOR_BODY75_LR_PH:%.*]]
; CHECK: for.body75.lr.ph:
; CHECK-NEXT: br label [[FOR_BODY75:%.*]]
; CHECK: for.body75:
; CHECK-NEXT: br label [[FOR_BODY75]]
; CHECK: for.end80:
-; CHECK-NEXT: br i1 undef, label [[FOR_END300:%.*]], label [[FOR_BODY267_LR_PH:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[FOR_END300:%.*]], label [[FOR_BODY267_LR_PH:%.*]]
; CHECK: for.body267.lr.ph:
; CHECK-NEXT: br label [[FOR_BODY267:%.*]]
; CHECK: for.body267:
@@ -32,18 +32,18 @@ define void @main() #0 {
; CHECK-NEXT: [[ADD295:%.*]] = fadd double undef, [[MUL294]]
; CHECK-NEXT: [[DIV296:%.*]] = fdiv double [[MUL283]], [[ADD295]]
; CHECK-NEXT: [[ADD297]] = fadd double [[S_71010]], [[DIV296]]
-; CHECK-NEXT: br i1 undef, label [[FOR_BODY267]], label [[FOR_END300]]
+; CHECK-NEXT: br i1 %arg, label [[FOR_BODY267]], label [[FOR_END300]]
; CHECK: for.end300:
; CHECK-NEXT: unreachable
;
entry:
- br i1 undef, label %while.body, label %while.end
+ br i1 %arg, label %while.body, label %while.end
while.body: ; preds = %entry
unreachable
while.end: ; preds = %entry
- br i1 undef, label %for.end80, label %for.body75.lr.ph
+ br i1 %arg, label %for.end80, label %for.body75.lr.ph
for.body75.lr.ph: ; preds = %while.end
br label %for.body75
@@ -52,7 +52,7 @@ for.body75: ; preds = %for.body75, %for.bo
br label %for.body75
for.end80: ; preds = %while.end
- br i1 undef, label %for.end300, label %for.body267.lr.ph
+ br i1 %arg, label %for.end300, label %for.body267.lr.ph
for.body267.lr.ph: ; preds = %for.end80
br label %for.body267
@@ -68,7 +68,7 @@ for.body267: ; preds = %for.body267, %for.b
%add295 = fadd double undef, %mul294
%div296 = fdiv double %mul283, %add295
%add297 = fadd double %s.71010, %div296
- br i1 undef, label %for.body267, label %for.end300
+ br i1 %arg, label %for.body267, label %for.end300
for.end300: ; preds = %for.body267, %for.end80
unreachable
diff --git a/llvm/test/Transforms/SLPVectorizer/X86/crash_lencod-inseltpoison.ll b/llvm/test/Transforms/SLPVectorizer/X86/crash_lencod-inseltpoison.ll
index 6ac588524f8452..d516126d8412d9 100644
--- a/llvm/test/Transforms/SLPVectorizer/X86/crash_lencod-inseltpoison.ll
+++ b/llvm/test/Transforms/SLPVectorizer/X86/crash_lencod-inseltpoison.ll
@@ -5,34 +5,34 @@ target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f3
target triple = "x86_64-apple-macosx10.8.0"
; Function Attrs: nounwind ssp uwtable
-define void @RCModelEstimator() {
+define void @RCModelEstimator(i1 %arg) {
; CHECK-LABEL: @RCModelEstimator(
; CHECK-NEXT: entry:
-; CHECK-NEXT: br i1 undef, label [[FOR_BODY_LR_PH:%.*]], label [[FOR_END_THREAD:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[FOR_BODY_LR_PH:%.*]], label [[FOR_END_THREAD:%.*]]
; CHECK: for.end.thread:
; CHECK-NEXT: unreachable
; CHECK: for.body.lr.ph:
-; CHECK-NEXT: br i1 undef, label [[FOR_END:%.*]], label [[FOR_BODY:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[FOR_END:%.*]], label [[FOR_BODY:%.*]]
; CHECK: for.body:
-; CHECK-NEXT: br i1 undef, label [[FOR_END]], label [[FOR_BODY]]
+; CHECK-NEXT: br i1 %arg, label [[FOR_END]], label [[FOR_BODY]]
; CHECK: for.end:
-; CHECK-NEXT: br i1 undef, label [[FOR_BODY3:%.*]], label [[IF_END103:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[FOR_BODY3:%.*]], label [[IF_END103:%.*]]
; CHECK: for.cond14.preheader:
-; CHECK-NEXT: br i1 undef, label [[FOR_BODY16_LR_PH:%.*]], label [[IF_END103]]
+; CHECK-NEXT: br i1 %arg, label [[FOR_BODY16_LR_PH:%.*]], label [[IF_END103]]
; CHECK: for.body16.lr.ph:
; CHECK-NEXT: br label [[FOR_BODY16:%.*]]
; CHECK: for.body3:
-; CHECK-NEXT: br i1 undef, label [[IF_THEN7:%.*]], label [[FOR_INC11:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[IF_THEN7:%.*]], label [[FOR_INC11:%.*]]
; CHECK: if.then7:
; CHECK-NEXT: br label [[FOR_INC11]]
; CHECK: for.inc11:
; CHECK-NEXT: br i1 false, label [[FOR_COND14_PREHEADER:%.*]], label [[FOR_BODY3]]
; CHECK: for.body16:
-; CHECK-NEXT: br i1 undef, label [[FOR_END39:%.*]], label [[FOR_BODY16]]
+; CHECK-NEXT: br i1 %arg, label [[FOR_END39:%.*]], label [[FOR_BODY16]]
; CHECK: for.end39:
-; CHECK-NEXT: br i1 undef, label [[IF_END103]], label [[FOR_COND45_PREHEADER:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[IF_END103]], label [[FOR_COND45_PREHEADER:%.*]]
; CHECK: for.cond45.preheader:
-; CHECK-NEXT: br i1 undef, label [[IF_THEN88:%.*]], label [[IF_ELSE:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[IF_THEN88:%.*]], label [[IF_ELSE:%.*]]
; CHECK: if.then88:
; CHECK-NEXT: br label [[IF_END103]]
; CHECK: if.else:
@@ -41,28 +41,28 @@ define void @RCModelEstimator() {
; CHECK-NEXT: ret void
;
entry:
- br i1 undef, label %for.body.lr.ph, label %for.end.thread
+ br i1 %arg, label %for.body.lr.ph, label %for.end.thread
for.end.thread: ; preds = %entry
unreachable
for.body.lr.ph: ; preds = %entry
- br i1 undef, label %for.end, label %for.body
+ br i1 %arg, label %for.end, label %for.body
for.body: ; preds = %for.body, %for.body.lr.ph
- br i1 undef, label %for.end, label %for.body
+ br i1 %arg, label %for.end, label %for.body
for.end: ; preds = %for.body, %for.body.lr.ph
- br i1 undef, label %for.body3, label %if.end103
+ br i1 %arg, label %for.body3, label %if.end103
for.cond14.preheader: ; preds = %for.inc11
- br i1 undef, label %for.body16.lr.ph, label %if.end103
+ br i1 %arg, label %for.body16.lr.ph, label %if.end103
for.body16.lr.ph: ; preds = %for.cond14.preheader
br label %for.body16
for.body3: ; preds = %for.inc11, %for.end
- br i1 undef, label %if.then7, label %for.inc11
+ br i1 %arg, label %if.then7, label %for.inc11
if.then7: ; preds = %for.body3
br label %for.inc11
@@ -71,13 +71,13 @@ for.inc11: ; preds = %if.then7, %for.body
br i1 false, label %for.cond14.preheader, label %for.body3
for.body16: ; preds = %for.body16, %for.body16.lr.ph
- br i1 undef, label %for.end39, label %for.body16
+ br i1 %arg, label %for.end39, label %for.body16
for.end39: ; preds = %for.body16
- br i1 undef, label %if.end103, label %for.cond45.preheader
+ br i1 %arg, label %if.end103, label %for.cond45.preheader
for.cond45.preheader: ; preds = %for.end39
- br i1 undef, label %if.then88, label %if.else
+ br i1 %arg, label %if.then88, label %if.else
if.then88: ; preds = %for.cond45.preheader
%mul89 = fmul double 0.000000e+00, 0.000000e+00
diff --git a/llvm/test/Transforms/SLPVectorizer/X86/crash_lencod.ll b/llvm/test/Transforms/SLPVectorizer/X86/crash_lencod.ll
index f0d38e1bf269c4..3ad0473c847665 100644
--- a/llvm/test/Transforms/SLPVectorizer/X86/crash_lencod.ll
+++ b/llvm/test/Transforms/SLPVectorizer/X86/crash_lencod.ll
@@ -5,34 +5,34 @@ target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f3
target triple = "x86_64-apple-macosx10.8.0"
; Function Attrs: nounwind ssp uwtable
-define void @RCModelEstimator() {
+define void @RCModelEstimator(i1 %arg) {
; CHECK-LABEL: @RCModelEstimator(
; CHECK-NEXT: entry:
-; CHECK-NEXT: br i1 undef, label [[FOR_BODY_LR_PH:%.*]], label [[FOR_END_THREAD:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[FOR_BODY_LR_PH:%.*]], label [[FOR_END_THREAD:%.*]]
; CHECK: for.end.thread:
; CHECK-NEXT: unreachable
; CHECK: for.body.lr.ph:
-; CHECK-NEXT: br i1 undef, label [[FOR_END:%.*]], label [[FOR_BODY:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[FOR_END:%.*]], label [[FOR_BODY:%.*]]
; CHECK: for.body:
-; CHECK-NEXT: br i1 undef, label [[FOR_END]], label [[FOR_BODY]]
+; CHECK-NEXT: br i1 %arg, label [[FOR_END]], label [[FOR_BODY]]
; CHECK: for.end:
-; CHECK-NEXT: br i1 undef, label [[FOR_BODY3:%.*]], label [[IF_END103:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[FOR_BODY3:%.*]], label [[IF_END103:%.*]]
; CHECK: for.cond14.preheader:
-; CHECK-NEXT: br i1 undef, label [[FOR_BODY16_LR_PH:%.*]], label [[IF_END103]]
+; CHECK-NEXT: br i1 %arg, label [[FOR_BODY16_LR_PH:%.*]], label [[IF_END103]]
; CHECK: for.body16.lr.ph:
; CHECK-NEXT: br label [[FOR_BODY16:%.*]]
; CHECK: for.body3:
-; CHECK-NEXT: br i1 undef, label [[IF_THEN7:%.*]], label [[FOR_INC11:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[IF_THEN7:%.*]], label [[FOR_INC11:%.*]]
; CHECK: if.then7:
; CHECK-NEXT: br label [[FOR_INC11]]
; CHECK: for.inc11:
; CHECK-NEXT: br i1 false, label [[FOR_COND14_PREHEADER:%.*]], label [[FOR_BODY3]]
; CHECK: for.body16:
-; CHECK-NEXT: br i1 undef, label [[FOR_END39:%.*]], label [[FOR_BODY16]]
+; CHECK-NEXT: br i1 %arg, label [[FOR_END39:%.*]], label [[FOR_BODY16]]
; CHECK: for.end39:
-; CHECK-NEXT: br i1 undef, label [[IF_END103]], label [[FOR_COND45_PREHEADER:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[IF_END103]], label [[FOR_COND45_PREHEADER:%.*]]
; CHECK: for.cond45.preheader:
-; CHECK-NEXT: br i1 undef, label [[IF_THEN88:%.*]], label [[IF_ELSE:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[IF_THEN88:%.*]], label [[IF_ELSE:%.*]]
; CHECK: if.then88:
; CHECK-NEXT: br label [[IF_END103]]
; CHECK: if.else:
@@ -41,28 +41,28 @@ define void @RCModelEstimator() {
; CHECK-NEXT: ret void
;
entry:
- br i1 undef, label %for.body.lr.ph, label %for.end.thread
+ br i1 %arg, label %for.body.lr.ph, label %for.end.thread
for.end.thread: ; preds = %entry
unreachable
for.body.lr.ph: ; preds = %entry
- br i1 undef, label %for.end, label %for.body
+ br i1 %arg, label %for.end, label %for.body
for.body: ; preds = %for.body, %for.body.lr.ph
- br i1 undef, label %for.end, label %for.body
+ br i1 %arg, label %for.end, label %for.body
for.end: ; preds = %for.body, %for.body.lr.ph
- br i1 undef, label %for.body3, label %if.end103
+ br i1 %arg, label %for.body3, label %if.end103
for.cond14.preheader: ; preds = %for.inc11
- br i1 undef, label %for.body16.lr.ph, label %if.end103
+ br i1 %arg, label %for.body16.lr.ph, label %if.end103
for.body16.lr.ph: ; preds = %for.cond14.preheader
br label %for.body16
for.body3: ; preds = %for.inc11, %for.end
- br i1 undef, label %if.then7, label %for.inc11
+ br i1 %arg, label %if.then7, label %for.inc11
if.then7: ; preds = %for.body3
br label %for.inc11
@@ -71,13 +71,13 @@ for.inc11: ; preds = %if.then7, %for.body
br i1 false, label %for.cond14.preheader, label %for.body3
for.body16: ; preds = %for.body16, %for.body16.lr.ph
- br i1 undef, label %for.end39, label %for.body16
+ br i1 %arg, label %for.end39, label %for.body16
for.end39: ; preds = %for.body16
- br i1 undef, label %if.end103, label %for.cond45.preheader
+ br i1 %arg, label %if.end103, label %for.cond45.preheader
for.cond45.preheader: ; preds = %for.end39
- br i1 undef, label %if.then88, label %if.else
+ br i1 %arg, label %if.then88, label %if.else
if.then88: ; preds = %for.cond45.preheader
%mul89 = fmul double 0.000000e+00, 0.000000e+00
diff --git a/llvm/test/Transforms/SLPVectorizer/X86/crash_mandeltext.ll b/llvm/test/Transforms/SLPVectorizer/X86/crash_mandeltext.ll
index e6c46e1847daca..403a610da8d554 100644
--- a/llvm/test/Transforms/SLPVectorizer/X86/crash_mandeltext.ll
+++ b/llvm/test/Transforms/SLPVectorizer/X86/crash_mandeltext.ll
@@ -4,7 +4,7 @@
target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64-S128"
target triple = "x86_64-apple-macosx10.8.0"
-define void @main() {
+define void @main(i1 %arg) {
; CHECK-LABEL: @main(
; CHECK-NEXT: entry:
; CHECK-NEXT: br label [[FOR_BODY:%.*]]
@@ -27,17 +27,17 @@ define void @main() {
; CHECK-NEXT: [[ADD19]] = fadd double undef, [[MUL18]]
; CHECK-NEXT: [[SUB:%.*]] = fsub double [[MUL13]], [[MUL14]]
; CHECK-NEXT: [[ADD20]] = fadd double undef, [[SUB]]
-; CHECK-NEXT: br i1 undef, label [[FOR_BODY12]], label [[FOR_INC21]]
+; CHECK-NEXT: br i1 %arg, label [[FOR_BODY12]], label [[FOR_INC21]]
; CHECK: for.inc21:
-; CHECK-NEXT: br i1 undef, label [[FOR_END23:%.*]], label [[FOR_BODY6]]
+; CHECK-NEXT: br i1 %arg, label [[FOR_END23:%.*]], label [[FOR_BODY6]]
; CHECK: for.end23:
-; CHECK-NEXT: br i1 undef, label [[IF_THEN25:%.*]], label [[IF_THEN26:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[IF_THEN25:%.*]], label [[IF_THEN26:%.*]]
; CHECK: if.then25:
-; CHECK-NEXT: br i1 undef, label [[FOR_END44:%.*]], label [[FOR_COND4_PREHEADER]]
+; CHECK-NEXT: br i1 %arg, label [[FOR_END44:%.*]], label [[FOR_COND4_PREHEADER]]
; CHECK: if.then26:
; CHECK-NEXT: unreachable
; CHECK: for.end44:
-; CHECK-NEXT: br i1 undef, label [[FOR_END48:%.*]], label [[FOR_BODY]]
+; CHECK-NEXT: br i1 %arg, label [[FOR_END48:%.*]], label [[FOR_BODY]]
; CHECK: for.end48:
; CHECK-NEXT: ret void
;
@@ -67,22 +67,22 @@ if.end: ; preds = %for.body12
%add19 = fadd double undef, %mul18
%sub = fsub double %mul13, %mul14
%add20 = fadd double undef, %sub
- br i1 undef, label %for.body12, label %for.inc21
+ br i1 %arg, label %for.body12, label %for.inc21
for.inc21: ; preds = %if.end, %for.body12
- br i1 undef, label %for.end23, label %for.body6
+ br i1 %arg, label %for.end23, label %for.body6
for.end23: ; preds = %for.inc21
- br i1 undef, label %if.then25, label %if.then26
+ br i1 %arg, label %if.then25, label %if.then26
if.then25: ; preds = %for.end23
- br i1 undef, label %for.end44, label %for.cond4.preheader
+ br i1 %arg, label %for.end44, label %for.cond4.preheader
if.then26: ; preds = %for.end23
unreachable
for.end44: ; preds = %if.then25
- br i1 undef, label %for.end48, label %for.body
+ br i1 %arg, label %for.end48, label %for.body
for.end48: ; preds = %for.end44
ret void
@@ -90,7 +90,7 @@ for.end48: ; preds = %for.end44
%struct.hoge = type { double, double, double}
-define void @zot(ptr %arg) {
+define void @zot(ptr %arg, i1 %arg2) {
; CHECK-LABEL: @zot(
; CHECK-NEXT: bb:
; CHECK-NEXT: [[TMP:%.*]] = load double, ptr undef, align 8
@@ -102,7 +102,7 @@ define void @zot(ptr %arg) {
; CHECK-NEXT: [[TMP3:%.*]] = fmul <2 x double> [[TMP2]], undef
; CHECK-NEXT: [[TMP4:%.*]] = fsub <2 x double> [[TMP3]], undef
; CHECK-NEXT: store <2 x double> [[TMP4]], ptr [[TMP7]], align 8
-; CHECK-NEXT: br i1 undef, label [[BB11:%.*]], label [[BB12:%.*]]
+; CHECK-NEXT: br i1 %arg2, label [[BB11:%.*]], label [[BB12:%.*]]
; CHECK: bb11:
; CHECK-NEXT: br label [[BB14:%.*]]
; CHECK: bb12:
@@ -124,7 +124,7 @@ bb:
%tmp9 = fsub double %tmp8, undef
%tmp10 = getelementptr inbounds %struct.hoge, ptr %arg, i64 0, i32 2
store double %tmp9, ptr %tmp10, align 8
- br i1 undef, label %bb11, label %bb12
+ br i1 %arg2, label %bb11, label %bb12
bb11: ; preds = %bb
br label %bb14
@@ -140,15 +140,15 @@ bb14: ; preds = %bb12, %bb11
%struct.rc4_state.0.24 = type { i32, i32, [256 x i32] }
-define void @rc4_crypt(ptr nocapture %s) {
+define void @rc4_crypt(ptr nocapture %s, i1 %arg) {
; CHECK-LABEL: @rc4_crypt(
; CHECK-NEXT: entry:
; CHECK-NEXT: [[Y2:%.*]] = getelementptr inbounds [[STRUCT_RC4_STATE_0_24:%.*]], ptr [[S:%.*]], i64 0, i32 1
-; CHECK-NEXT: br i1 undef, label [[FOR_BODY:%.*]], label [[FOR_END:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[FOR_BODY:%.*]], label [[FOR_END:%.*]]
; CHECK: for.body:
; CHECK-NEXT: [[CONV4:%.*]] = and i32 undef, 255
; CHECK-NEXT: [[CONV7:%.*]] = and i32 undef, 255
-; CHECK-NEXT: br i1 undef, label [[FOR_END]], label [[FOR_BODY]]
+; CHECK-NEXT: br i1 %arg, label [[FOR_END]], label [[FOR_BODY]]
; CHECK: for.end:
; CHECK-NEXT: [[X_0_LCSSA:%.*]] = phi i32 [ undef, [[ENTRY:%.*]] ], [ [[CONV4]], [[FOR_BODY]] ]
; CHECK-NEXT: [[Y_0_LCSSA:%.*]] = phi i32 [ undef, [[ENTRY]] ], [ [[CONV7]], [[FOR_BODY]] ]
@@ -158,14 +158,14 @@ define void @rc4_crypt(ptr nocapture %s) {
;
entry:
%y2 = getelementptr inbounds %struct.rc4_state.0.24, ptr %s, i64 0, i32 1
- br i1 undef, label %for.body, label %for.end
+ br i1 %arg, label %for.body, label %for.end
for.body: ; preds = %for.body, %entry
%x.045 = phi i32 [ %conv4, %for.body ], [ undef, %entry ]
%conv4 = and i32 undef, 255
%conv7 = and i32 undef, 255
%idxprom842 = zext i32 %conv7 to i64
- br i1 undef, label %for.end, label %for.body
+ br i1 %arg, label %for.end, label %for.body
for.end: ; preds = %for.body, %entry
%x.0.lcssa = phi i32 [ undef, %entry ], [ %conv4, %for.body ]
diff --git a/llvm/test/Transforms/SLPVectorizer/X86/crash_sim4b1.ll b/llvm/test/Transforms/SLPVectorizer/X86/crash_sim4b1.ll
index a9f92f324d6f54..d434035051f5e0 100644
--- a/llvm/test/Transforms/SLPVectorizer/X86/crash_sim4b1.ll
+++ b/llvm/test/Transforms/SLPVectorizer/X86/crash_sim4b1.ll
@@ -6,28 +6,28 @@ target triple = "x86_64-apple-macosx10.8.0"
%struct._exon_t.12.103.220.363.480.649.740.857.1039.1065.1078.1091.1117.1130.1156.1169.1195.1221.1234.1286.1299.1312.1338.1429.1455.1468.1494.1520.1884.1897.1975.2066.2105.2170.2171 = type { i32, i32, i32, i32, i32, i32, [8 x i8] }
-define void @SIM4() {
+define void @SIM4(i1 %arg) {
; CHECK-LABEL: @SIM4(
; CHECK-NEXT: entry:
-; CHECK-NEXT: br i1 undef, label [[RETURN:%.*]], label [[LOR_LHS_FALSE:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[RETURN:%.*]], label [[LOR_LHS_FALSE:%.*]]
; CHECK: lor.lhs.false:
-; CHECK-NEXT: br i1 undef, label [[RETURN]], label [[IF_END:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[RETURN]], label [[IF_END:%.*]]
; CHECK: if.end:
-; CHECK-NEXT: br i1 undef, label [[FOR_END605:%.*]], label [[FOR_BODY_LR_PH:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[FOR_END605:%.*]], label [[FOR_BODY_LR_PH:%.*]]
; CHECK: for.body.lr.ph:
; CHECK-NEXT: br label [[FOR_BODY:%.*]]
; CHECK: for.body:
-; CHECK-NEXT: br i1 undef, label [[FOR_INC603:%.*]], label [[IF_END12:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[FOR_INC603:%.*]], label [[IF_END12:%.*]]
; CHECK: if.end12:
-; CHECK-NEXT: br i1 undef, label [[LAND_LHS_TRUE:%.*]], label [[LAND_LHS_TRUE167:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[LAND_LHS_TRUE:%.*]], label [[LAND_LHS_TRUE167:%.*]]
; CHECK: land.lhs.true:
-; CHECK-NEXT: br i1 undef, label [[IF_THEN17:%.*]], label [[LAND_LHS_TRUE167]]
+; CHECK-NEXT: br i1 %arg, label [[IF_THEN17:%.*]], label [[LAND_LHS_TRUE167]]
; CHECK: if.then17:
-; CHECK-NEXT: br i1 undef, label [[IF_END98:%.*]], label [[LAND_RHS_LR_PH:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[IF_END98:%.*]], label [[LAND_RHS_LR_PH:%.*]]
; CHECK: land.rhs.lr.ph:
; CHECK-NEXT: unreachable
; CHECK: if.end98:
-; CHECK-NEXT: br i1 undef, label [[LAND_LHS_TRUE167]], label [[IF_THEN103:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[LAND_LHS_TRUE167]], label [[IF_THEN103:%.*]]
; CHECK: if.then103:
; CHECK-NEXT: [[DOTSUB100:%.*]] = select i1 undef, i32 250, i32 undef
; CHECK-NEXT: [[MUL114:%.*]] = shl nsw i32 [[DOTSUB100]], 2
@@ -37,11 +37,11 @@ define void @SIM4() {
; CHECK-NEXT: br label [[FOR_COND_I:%.*]]
; CHECK: for.cond.i:
; CHECK-NEXT: [[TMP2:%.*]] = phi <2 x i32> [ undef, [[LAND_RHS_I874:%.*]] ], [ [[TMP1]], [[IF_THEN103]] ]
-; CHECK-NEXT: br i1 undef, label [[LAND_RHS_I874]], label [[FOR_END_I:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[LAND_RHS_I874]], label [[FOR_END_I:%.*]]
; CHECK: land.rhs.i874:
-; CHECK-NEXT: br i1 undef, label [[FOR_COND_I]], label [[FOR_END_I]]
+; CHECK-NEXT: br i1 %arg, label [[FOR_COND_I]], label [[FOR_END_I]]
; CHECK: for.end.i:
-; CHECK-NEXT: br i1 undef, label [[IF_THEN_I:%.*]], label [[IF_END_I:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[IF_THEN_I:%.*]], label [[IF_END_I:%.*]]
; CHECK: if.then.i:
; CHECK-NEXT: [[TMP3:%.*]] = add nsw <2 x i32> [[TMP2]], undef
; CHECK-NEXT: br label [[EXTEND_BW_EXIT:%.*]]
@@ -52,15 +52,15 @@ define void @SIM4() {
; CHECK: for.body28.lr.ph.i:
; CHECK-NEXT: br label [[FOR_END33_I]]
; CHECK: for.end33.i:
-; CHECK-NEXT: br i1 undef, label [[FOR_END58_I:%.*]], label [[FOR_BODY52_LR_PH_I:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[FOR_END58_I:%.*]], label [[FOR_BODY52_LR_PH_I:%.*]]
; CHECK: for.body52.lr.ph.i:
; CHECK-NEXT: br label [[FOR_END58_I]]
; CHECK: for.end58.i:
; CHECK-NEXT: br label [[WHILE_COND260_I:%.*]]
; CHECK: while.cond260.i:
-; CHECK-NEXT: br i1 undef, label [[LAND_RHS263_I:%.*]], label [[WHILE_END275_I:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[LAND_RHS263_I:%.*]], label [[WHILE_END275_I:%.*]]
; CHECK: land.rhs263.i:
-; CHECK-NEXT: br i1 undef, label [[WHILE_COND260_I]], label [[WHILE_END275_I]]
+; CHECK-NEXT: br i1 %arg, label [[WHILE_COND260_I]], label [[WHILE_END275_I]]
; CHECK: while.end275.i:
; CHECK-NEXT: br label [[EXTEND_BW_EXIT]]
; CHECK: extend_bw.exit:
@@ -73,42 +73,42 @@ define void @SIM4() {
; CHECK: land.lhs.true167:
; CHECK-NEXT: unreachable
; CHECK: for.inc603:
-; CHECK-NEXT: br i1 undef, label [[FOR_BODY]], label [[FOR_END605]]
+; CHECK-NEXT: br i1 %arg, label [[FOR_BODY]], label [[FOR_END605]]
; CHECK: for.end605:
; CHECK-NEXT: unreachable
; CHECK: return:
; CHECK-NEXT: ret void
;
entry:
- br i1 undef, label %return, label %lor.lhs.false
+ br i1 %arg, label %return, label %lor.lhs.false
lor.lhs.false: ; preds = %entry
- br i1 undef, label %return, label %if.end
+ br i1 %arg, label %return, label %if.end
if.end: ; preds = %lor.lhs.false
- br i1 undef, label %for.end605, label %for.body.lr.ph
+ br i1 %arg, label %for.end605, label %for.body.lr.ph
for.body.lr.ph: ; preds = %if.end
br label %for.body
for.body: ; preds = %for.inc603, %for.body.lr.ph
- br i1 undef, label %for.inc603, label %if.end12
+ br i1 %arg, label %for.inc603, label %if.end12
if.end12: ; preds = %for.body
- br i1 undef, label %land.lhs.true, label %land.lhs.true167
+ br i1 %arg, label %land.lhs.true, label %land.lhs.true167
land.lhs.true: ; preds = %if.end12
- br i1 undef, label %if.then17, label %land.lhs.true167
+ br i1 %arg, label %if.then17, label %land.lhs.true167
if.then17: ; preds = %land.lhs.true
- br i1 undef, label %if.end98, label %land.rhs.lr.ph
+ br i1 %arg, label %if.end98, label %land.rhs.lr.ph
land.rhs.lr.ph: ; preds = %if.then17
unreachable
if.end98: ; preds = %if.then17
%from299 = getelementptr inbounds %struct._exon_t.12.103.220.363.480.649.740.857.1039.1065.1078.1091.1117.1130.1156.1169.1195.1221.1234.1286.1299.1312.1338.1429.1455.1468.1494.1520.1884.1897.1975.2066.2105.2170.2171, ptr undef, i64 0, i32 1
- br i1 undef, label %land.lhs.true167, label %if.then103
+ br i1 %arg, label %land.lhs.true167, label %if.then103
if.then103: ; preds = %if.end98
%.sub100 = select i1 undef, i32 250, i32 undef
@@ -119,13 +119,13 @@ if.then103: ; preds = %if.end98
for.cond.i: ; preds = %land.rhs.i874, %if.then103
%row.0.i = phi i32 [ undef, %land.rhs.i874 ], [ %.sub100, %if.then103 ]
%col.0.i = phi i32 [ undef, %land.rhs.i874 ], [ %cond125, %if.then103 ]
- br i1 undef, label %land.rhs.i874, label %for.end.i
+ br i1 %arg, label %land.rhs.i874, label %for.end.i
land.rhs.i874: ; preds = %for.cond.i
- br i1 undef, label %for.cond.i, label %for.end.i
+ br i1 %arg, label %for.cond.i, label %for.end.i
for.end.i: ; preds = %land.rhs.i874, %for.cond.i
- br i1 undef, label %if.then.i, label %if.end.i
+ br i1 %arg, label %if.then.i, label %if.end.i
if.then.i: ; preds = %for.end.i
%add14.i = add nsw i32 %row.0.i, undef
@@ -141,7 +141,7 @@ for.body28.lr.ph.i: ; preds = %if.end.i
br label %for.end33.i
for.end33.i: ; preds = %for.body28.lr.ph.i, %if.end.i
- br i1 undef, label %for.end58.i, label %for.body52.lr.ph.i
+ br i1 %arg, label %for.end58.i, label %for.body52.lr.ph.i
for.body52.lr.ph.i: ; preds = %for.end33.i
br label %for.end58.i
@@ -150,10 +150,10 @@ for.end58.i: ; preds = %for.body52.lr.ph.i,
br label %while.cond260.i
while.cond260.i: ; preds = %land.rhs263.i, %for.end58.i
- br i1 undef, label %land.rhs263.i, label %while.end275.i
+ br i1 %arg, label %land.rhs263.i, label %while.end275.i
land.rhs263.i: ; preds = %while.cond260.i
- br i1 undef, label %while.cond260.i, label %while.end275.i
+ br i1 %arg, label %while.cond260.i, label %while.end275.i
while.end275.i: ; preds = %land.rhs263.i, %while.cond260.i
br label %extend_bw.exit
@@ -174,7 +174,7 @@ land.lhs.true167: ; preds = %if.then157, %extend
unreachable
for.inc603: ; preds = %for.body
- br i1 undef, label %for.body, label %for.end605
+ br i1 %arg, label %for.body, label %for.end605
for.end605: ; preds = %for.inc603, %if.end
unreachable
diff --git a/llvm/test/Transforms/SLPVectorizer/X86/crash_smallpt.ll b/llvm/test/Transforms/SLPVectorizer/X86/crash_smallpt.ll
index 42ad20ff578c10..d13a8578d1e00a 100644
--- a/llvm/test/Transforms/SLPVectorizer/X86/crash_smallpt.ll
+++ b/llvm/test/Transforms/SLPVectorizer/X86/crash_smallpt.ll
@@ -4,25 +4,25 @@
%struct.Ray = type { %struct.Vec, %struct.Vec }
%struct.Vec = type { double, double, double }
-define void @main() {
+define void @main(i1 %arg) {
; CHECK-LABEL: @main(
; CHECK-NEXT: entry:
-; CHECK-NEXT: br i1 undef, label [[COND_TRUE:%.*]], label [[COND_END:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[COND_TRUE:%.*]], label [[COND_END:%.*]]
; CHECK: cond.true:
; CHECK-NEXT: unreachable
; CHECK: cond.end:
; CHECK-NEXT: br label [[INVOKE_CONT:%.*]]
; CHECK: invoke.cont:
-; CHECK-NEXT: br i1 undef, label [[ARRAYCTOR_CONT:%.*]], label [[INVOKE_CONT]]
+; CHECK-NEXT: br i1 %arg, label [[ARRAYCTOR_CONT:%.*]], label [[INVOKE_CONT]]
; CHECK: arrayctor.cont:
; CHECK-NEXT: [[AGG_TMP101211_SROA_0_0_IDX:%.*]] = getelementptr inbounds [[STRUCT_RAY:%.*]], ptr undef, i64 0, i32 1, i32 0
; CHECK-NEXT: br label [[FOR_COND36_PREHEADER:%.*]]
; CHECK: for.cond36.preheader:
-; CHECK-NEXT: br i1 undef, label [[FOR_BODY42_LR_PH_US:%.*]], label [[_Z5CLAMPD_EXIT_1:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[FOR_BODY42_LR_PH_US:%.*]], label [[_Z5CLAMPD_EXIT_1:%.*]]
; CHECK: cond.false51.us:
; CHECK-NEXT: unreachable
; CHECK: cond.true48.us:
-; CHECK-NEXT: br i1 undef, label [[COND_TRUE63_US:%.*]], label [[COND_FALSE66_US:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[COND_TRUE63_US:%.*]], label [[COND_FALSE66_US:%.*]]
; CHECK: cond.false66.us:
; CHECK-NEXT: [[ADD_I276_US:%.*]] = fadd double 0.000000e+00, 0x3EB0C6F7A0B5ED8D
; CHECK-NEXT: [[TMP0:%.*]] = insertelement <2 x double> <double poison, double 0xBFA5CC2D1960285F>, double [[ADD_I276_US]], i32 0
@@ -36,12 +36,12 @@ define void @main() {
; CHECK: cond.true63.us:
; CHECK-NEXT: unreachable
; CHECK: for.body42.lr.ph.us:
-; CHECK-NEXT: br i1 undef, label [[COND_TRUE48_US:%.*]], label [[COND_FALSE51_US:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[COND_TRUE48_US:%.*]], label [[COND_FALSE51_US:%.*]]
; CHECK: _Z5clampd.exit.1:
; CHECK-NEXT: br label [[FOR_COND36_PREHEADER]]
;
entry:
- br i1 undef, label %cond.true, label %cond.end
+ br i1 %arg, label %cond.true, label %cond.end
cond.true:
unreachable
@@ -50,7 +50,7 @@ cond.end:
br label %invoke.cont
invoke.cont:
- br i1 undef, label %arrayctor.cont, label %invoke.cont
+ br i1 %arg, label %arrayctor.cont, label %invoke.cont
arrayctor.cont:
%agg.tmp99208.sroa.1.8.idx388 = getelementptr inbounds %struct.Ray, ptr undef, i64 0, i32 0, i32 1
@@ -59,13 +59,13 @@ arrayctor.cont:
br label %for.cond36.preheader
for.cond36.preheader:
- br i1 undef, label %for.body42.lr.ph.us, label %_Z5clampd.exit.1
+ br i1 %arg, label %for.body42.lr.ph.us, label %_Z5clampd.exit.1
cond.false51.us:
unreachable
cond.true48.us:
- br i1 undef, label %cond.true63.us, label %cond.false66.us
+ br i1 %arg, label %cond.true63.us, label %cond.false66.us
cond.false66.us:
%add.i276.us = fadd double 0.000000e+00, 0.000001e+00
@@ -87,16 +87,16 @@ cond.true63.us:
unreachable
for.body42.lr.ph.us:
- br i1 undef, label %cond.true48.us, label %cond.false51.us
+ br i1 %arg, label %cond.true48.us, label %cond.false51.us
_Z5clampd.exit.1:
br label %for.cond36.preheader
}
-define void @test() {
+define void @test(i1 %arg) {
; CHECK-LABEL: @test(
; CHECK-NEXT: entry:
-; CHECK-NEXT: br i1 undef, label [[IF_THEN78:%.*]], label [[IF_THEN38:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[IF_THEN78:%.*]], label [[IF_THEN38:%.*]]
; CHECK: if.then38:
; CHECK-NEXT: [[AGG_TMP74663_SROA_0_0_IDX:%.*]] = getelementptr inbounds [[STRUCT_RAY:%.*]], ptr undef, i64 0, i32 1, i32 0
; CHECK-NEXT: store <2 x double> <double 0x3FFA356C1D8A7F76, double 0x3FFDC4F38B38BEF4>, ptr [[AGG_TMP74663_SROA_0_0_IDX]], align 8
@@ -105,7 +105,7 @@ define void @test() {
; CHECK-NEXT: ret void
;
entry:
- br i1 undef, label %if.then78, label %if.then38
+ br i1 %arg, label %if.then78, label %if.then38
if.then38:
%mul.i.i790 = fmul double 0.0, 0.1
diff --git a/llvm/test/Transforms/SLPVectorizer/X86/crash_vectorizeTree.ll b/llvm/test/Transforms/SLPVectorizer/X86/crash_vectorizeTree.ll
index e3a860a4c6f062..c7c4b06be2d193 100644
--- a/llvm/test/Transforms/SLPVectorizer/X86/crash_vectorizeTree.ll
+++ b/llvm/test/Transforms/SLPVectorizer/X86/crash_vectorizeTree.ll
@@ -16,7 +16,7 @@ target triple = "x86_64-apple-macosx10.9.0"
;define fastcc void @bar() {
-define void @bar() {
+define void @bar(i1 %arg) {
; CHECK-LABEL: @bar(
; CHECK-NEXT: bb:
; CHECK-NEXT: [[I:%.*]] = getelementptr inbounds [[TMP0:%.*]], ptr undef, i64 0, i32 1, i32 0
@@ -32,16 +32,16 @@ define void @bar() {
; CHECK-NEXT: store double [[I7]], ptr [[I1]], align 8
; CHECK-NEXT: [[I10]] = load double, ptr [[I3]], align 8
; CHECK-NEXT: [[TMP0]] = load <2 x double>, ptr [[I2]], align 8
-; CHECK-NEXT: br i1 undef, label [[BB11:%.*]], label [[BB12:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[BB11:%.*]], label [[BB12:%.*]]
; CHECK: bb11:
; CHECK-NEXT: ret void
; CHECK: bb12:
; CHECK-NEXT: store <2 x double> [[TMP0]], ptr [[I4]], align 8
-; CHECK-NEXT: br i1 undef, label [[BB13:%.*]], label [[BB14:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[BB13:%.*]], label [[BB14:%.*]]
; CHECK: bb13:
; CHECK-NEXT: br label [[BB14]]
; CHECK: bb14:
-; CHECK-NEXT: br i1 undef, label [[BB15:%.*]], label [[BB16]]
+; CHECK-NEXT: br i1 %arg, label [[BB15:%.*]], label [[BB16]]
; CHECK: bb15:
; CHECK-NEXT: unreachable
; CHECK: bb16:
@@ -51,7 +51,7 @@ define void @bar() {
; CHECK-NEXT: i32 103, label [[BB6]]
; CHECK-NEXT: ]
; CHECK: bb17:
-; CHECK-NEXT: br i1 undef, label [[BB6]], label [[BB18:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[BB6]], label [[BB18:%.*]]
; CHECK: bb18:
; CHECK-NEXT: unreachable
;
@@ -71,7 +71,7 @@ bb6: ; preds = %bb17, %bb16, %bb16,
store double %i7, ptr %i1, align 8
%i9 = load double, ptr %i2, align 8
%i10 = load double, ptr %i3, align 8
- br i1 undef, label %bb11, label %bb12
+ br i1 %arg, label %bb11, label %bb12
bb11: ; preds = %bb6
ret void
@@ -79,13 +79,13 @@ bb11: ; preds = %bb6
bb12: ; preds = %bb6
store double %i9, ptr %i4, align 8
store double %i10, ptr %i5, align 8
- br i1 undef, label %bb13, label %bb14
+ br i1 %arg, label %bb13, label %bb14
bb13: ; preds = %bb12
br label %bb14
bb14: ; preds = %bb13, %bb12
- br i1 undef, label %bb15, label %bb16
+ br i1 %arg, label %bb15, label %bb16
bb15: ; preds = %bb14
unreachable
@@ -97,7 +97,7 @@ bb16: ; preds = %bb14
]
bb17: ; preds = %bb16
- br i1 undef, label %bb6, label %bb18
+ br i1 %arg, label %bb6, label %bb18
bb18: ; preds = %bb17
unreachable
diff --git a/llvm/test/Transforms/SLPVectorizer/X86/cse.ll b/llvm/test/Transforms/SLPVectorizer/X86/cse.ll
index 739e3964c2685f..7510b8fb83e34b 100644
--- a/llvm/test/Transforms/SLPVectorizer/X86/cse.ll
+++ b/llvm/test/Transforms/SLPVectorizer/X86/cse.ll
@@ -280,10 +280,10 @@ return: ; preds = %entry, %if.end
@a = external global double, align 8
-define void @PR19646(ptr %this) {
+define void @PR19646(ptr %this, i1 %arg) {
; CHECK-LABEL: @PR19646(
; CHECK-NEXT: entry:
-; CHECK-NEXT: br i1 undef, label [[IF_END13:%.*]], label [[IF_END13]]
+; CHECK-NEXT: br i1 %arg, label [[IF_END13:%.*]], label [[IF_END13]]
; CHECK: sw.epilog7:
; CHECK-NEXT: [[DOTIN:%.*]] = getelementptr inbounds [[CLASS_B_53_55:%.*]], ptr [[THIS:%.*]], i64 0, i32 0, i32 1
; CHECK-NEXT: [[TMP0:%.*]] = load double, ptr [[DOTIN]], align 8
@@ -294,7 +294,7 @@ define void @PR19646(ptr %this) {
; CHECK-NEXT: [[_DY:%.*]] = getelementptr inbounds [[CLASS_B_53_55]], ptr [[THIS]], i64 0, i32 0, i32 2
; CHECK-NEXT: [[TMP2:%.*]] = load double, ptr [[_DY]], align 8
; CHECK-NEXT: [[ADD10:%.*]] = fadd double [[ADD8]], [[TMP2]]
-; CHECK-NEXT: br i1 undef, label [[IF_THEN12:%.*]], label [[IF_END13]]
+; CHECK-NEXT: br i1 %arg, label [[IF_THEN12:%.*]], label [[IF_END13]]
; CHECK: if.then12:
; CHECK-NEXT: [[TMP3:%.*]] = load double, ptr undef, align 8
; CHECK-NEXT: br label [[IF_END13]]
@@ -304,7 +304,7 @@ define void @PR19646(ptr %this) {
; CHECK-NEXT: unreachable
;
entry:
- br i1 undef, label %if.end13, label %if.end13
+ br i1 %arg, label %if.end13, label %if.end13
sw.epilog7: ; No predecessors!
%.in = getelementptr inbounds %class.B.53.55, ptr %this, i64 0, i32 0, i32 1
@@ -316,7 +316,7 @@ sw.epilog7: ; No predecessors!
%_dy = getelementptr inbounds %class.B.53.55, ptr %this, i64 0, i32 0, i32 2
%2 = load double, ptr %_dy, align 8
%add10 = fadd double %add8, %2
- br i1 undef, label %if.then12, label %if.end13
+ br i1 %arg, label %if.then12, label %if.end13
if.then12: ; preds = %sw.epilog7
%3 = load double, ptr undef, align 8
diff --git a/llvm/test/Transforms/SLPVectorizer/X86/memory-runtime-checks.ll b/llvm/test/Transforms/SLPVectorizer/X86/memory-runtime-checks.ll
index f614796916baa1..d474218e84cca5 100644
--- a/llvm/test/Transforms/SLPVectorizer/X86/memory-runtime-checks.ll
+++ b/llvm/test/Transforms/SLPVectorizer/X86/memory-runtime-checks.ll
@@ -116,7 +116,7 @@ then:
%struct.wombat.0 = type { %struct.bar }
%struct.bar = type { [3 x double], [3 x double], double, double, i16, ptr, i32, [3 x double] }
-define double @preserve_loop_info(ptr %arg) {
+define double @preserve_loop_info(ptr %arg, i1 %arg2) {
; CHECK-LABEL: @preserve_loop_info(
; CHECK-NEXT: entry:
; CHECK-NEXT: [[TMP:%.*]] = alloca [3 x double], align 16
@@ -124,15 +124,15 @@ define double @preserve_loop_info(ptr %arg) {
; CHECK: outer.header:
; CHECK-NEXT: br label [[INNER:%.*]]
; CHECK: inner:
-; CHECK-NEXT: br i1 undef, label [[OUTER_LATCH:%.*]], label [[INNER]]
+; CHECK-NEXT: br i1 %arg2, label [[OUTER_LATCH:%.*]], label [[INNER]]
; CHECK: outer.latch:
-; CHECK-NEXT: br i1 undef, label [[BB:%.*]], label [[OUTER_HEADER]]
+; CHECK-NEXT: br i1 %arg2, label [[BB:%.*]], label [[OUTER_HEADER]]
; CHECK: bb:
; CHECK-NEXT: [[TMP5:%.*]] = load ptr, ptr undef, align 8
; CHECK-NEXT: [[TMP7:%.*]] = getelementptr inbounds [3 x double], ptr [[TMP]], i64 0, i64 1
; CHECK-NEXT: br label [[LOOP_3HEADER:%.*]]
; CHECK: loop.3header:
-; CHECK-NEXT: br i1 undef, label [[LOOP_3LATCH:%.*]], label [[BB9:%.*]]
+; CHECK-NEXT: br i1 %arg2, label [[LOOP_3LATCH:%.*]], label [[BB9:%.*]]
; CHECK: bb9:
; CHECK-NEXT: [[TMP10:%.*]] = getelementptr inbounds [3 x double], ptr [[TMP5]], i64 undef, i64 1
; CHECK-NEXT: store double undef, ptr [[TMP]], align 16
@@ -140,7 +140,7 @@ define double @preserve_loop_info(ptr %arg) {
; CHECK-NEXT: store double [[TMP12]], ptr [[TMP7]], align 8
; CHECK-NEXT: br label [[LOOP_3LATCH]]
; CHECK: loop.3latch:
-; CHECK-NEXT: br i1 undef, label [[BB14:%.*]], label [[LOOP_3HEADER]]
+; CHECK-NEXT: br i1 %arg2, label [[BB14:%.*]], label [[LOOP_3HEADER]]
; CHECK: bb14:
; CHECK-NEXT: [[TMP15:%.*]] = call double undef(ptr [[TMP]], ptr [[ARG:%.*]])
; CHECK-NEXT: ret double undef
@@ -153,10 +153,10 @@ outer.header: ; preds = %bb3, %bb
br label %inner
inner:
- br i1 undef, label %outer.latch, label %inner
+ br i1 %arg2, label %outer.latch, label %inner
outer.latch: ; preds = %bb16
- br i1 undef, label %bb, label %outer.header
+ br i1 %arg2, label %bb, label %outer.header
bb: ; preds = %bb3
%tmp5 = load ptr, ptr undef, align 8
@@ -164,7 +164,7 @@ bb: ; preds = %bb3
br label %loop.3header
loop.3header: ; preds = %bb13, %bb4
- br i1 undef, label %loop.3latch, label %bb9
+ br i1 %arg2, label %loop.3latch, label %bb9
bb9: ; preds = %bb8
%tmp10 = getelementptr inbounds [3 x double], ptr %tmp5, i64 undef, i64 1
@@ -174,7 +174,7 @@ bb9: ; preds = %bb8
br label %loop.3latch
loop.3latch: ; preds = %bb11, %bb8
- br i1 undef, label %bb14, label %loop.3header
+ br i1 %arg2, label %bb14, label %loop.3header
bb14: ; preds = %bb13
%tmp15 = call double undef(ptr %tmp, ptr %arg)
diff --git a/llvm/test/Transforms/SLPVectorizer/X86/no-scheduled-instructions.ll b/llvm/test/Transforms/SLPVectorizer/X86/no-scheduled-instructions.ll
index 43d8c1342cbbc0..eea22c1861b44e 100644
--- a/llvm/test/Transforms/SLPVectorizer/X86/no-scheduled-instructions.ll
+++ b/llvm/test/Transforms/SLPVectorizer/X86/no-scheduled-instructions.ll
@@ -1,10 +1,10 @@
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 2
; RUN: opt -S -passes=slp-vectorizer -mattr=+avx -mtriple=x86_64 < %s | FileCheck %s
-define void @test() {
+define void @test(i1 %arg) {
; CHECK-LABEL: define void @test
-; CHECK-SAME: () #[[ATTR0:[0-9]+]] {
-; CHECK-NEXT: br i1 undef, label [[BB1:%.*]], label [[BB2:%.*]]
+; CHECK-SAME: (i1 %arg) #[[ATTR0:[0-9]+]] {
+; CHECK-NEXT: br i1 %arg, label [[BB1:%.*]], label [[BB2:%.*]]
; CHECK: bb1:
; CHECK-NEXT: [[TMP1:%.*]] = call i32 @llvm.vector.reduce.mul.v8i32(<8 x i32> <i32 0, i32 0, i32 0, i32 0, i32 undef, i32 undef, i32 undef, i32 undef>)
; CHECK-NEXT: call void @f(i32 noundef [[TMP1]])
@@ -20,7 +20,7 @@ define void @test() {
%i32 = extractelement <4 x i32> zeroinitializer, i64 1
%i33 = extractelement <4 x i32> zeroinitializer, i64 2
%i34 = extractelement <4 x i32> zeroinitializer, i64 3
- br i1 undef, label %bb1, label %bb2
+ br i1 %arg, label %bb1, label %bb2
bb1:
%i11 = mul nsw i32 %i28, %i27
diff --git a/llvm/test/Transforms/SLPVectorizer/X86/ordering.ll b/llvm/test/Transforms/SLPVectorizer/X86/ordering.ll
index ad3ebf57ab7a48..f9d6c3eab350f0 100644
--- a/llvm/test/Transforms/SLPVectorizer/X86/ordering.ll
+++ b/llvm/test/Transforms/SLPVectorizer/X86/ordering.ll
@@ -26,10 +26,10 @@ entry:
declare ptr @objc_msgSend(ptr, ptr, ...)
declare i32 @personality_v0(...)
-define void @invoketest() personality ptr @personality_v0 {
+define void @invoketest(i1 %arg) personality ptr @personality_v0 {
; CHECK-LABEL: @invoketest(
; CHECK-NEXT: entry:
-; CHECK-NEXT: br i1 undef, label [[COND_TRUE:%.*]], label [[COND_FALSE:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[COND_TRUE:%.*]], label [[COND_FALSE:%.*]]
; CHECK: cond.true:
; CHECK-NEXT: [[CALL49:%.*]] = invoke double @objc_msgSend(ptr undef, ptr undef)
; CHECK-NEXT: to label [[COND_TRUE54:%.*]] unwind label [[LPAD:%.*]]
@@ -43,7 +43,7 @@ define void @invoketest() personality ptr @personality_v0 {
; CHECK-NEXT: [[CALL59:%.*]] = invoke double @objc_msgSend(ptr undef, ptr undef)
; CHECK-NEXT: to label [[COND_END60]] unwind label [[LPAD]]
; CHECK: cond.end60:
-; CHECK-NEXT: br i1 undef, label [[IF_END98:%.*]], label [[IF_THEN63:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[IF_END98:%.*]], label [[IF_THEN63:%.*]]
; CHECK: if.then63:
; CHECK-NEXT: br label [[IF_END98]]
; CHECK: lpad:
@@ -56,7 +56,7 @@ define void @invoketest() personality ptr @personality_v0 {
; CHECK-NEXT: ret void
;
entry:
- br i1 undef, label %cond.true, label %cond.false
+ br i1 %arg, label %cond.true, label %cond.false
cond.true:
%call49 = invoke double @objc_msgSend(ptr undef, ptr undef)
@@ -77,7 +77,7 @@ cond.false57:
cond.end60:
%cond126 = phi double [ %call49, %cond.true54 ], [ %call51, %cond.false57 ]
%cond61 = phi double [ %call56, %cond.true54 ], [ %call59, %cond.false57 ]
- br i1 undef, label %if.end98, label %if.then63
+ br i1 %arg, label %if.end98, label %if.then63
if.then63:
%conv69 = fptrunc double undef to float
diff --git a/llvm/test/Transforms/SLPVectorizer/X86/partail.ll b/llvm/test/Transforms/SLPVectorizer/X86/partail.ll
index 20ad09a6328268..4cdf9670394f1e 100644
--- a/llvm/test/Transforms/SLPVectorizer/X86/partail.ll
+++ b/llvm/test/Transforms/SLPVectorizer/X86/partail.ll
@@ -2,12 +2,12 @@
; RUN: opt -passes=slp-vectorizer -S -mtriple=x86_64-unknown-linux-gnu -mcpu=bdver2 < %s | FileCheck %s
; Function Attrs: nounwind uwtable
-define void @get_block(i32 %y_pos) local_unnamed_addr #0 {
+define void @get_block(i32 %y_pos, i1 %arg) local_unnamed_addr #0 {
; CHECK-LABEL: @get_block(
; CHECK-NEXT: entry:
; CHECK-NEXT: br label [[LAND_LHS_TRUE:%.*]]
; CHECK: land.lhs.true:
-; CHECK-NEXT: br i1 undef, label [[IF_THEN:%.*]], label [[IF_END:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[IF_THEN:%.*]], label [[IF_END:%.*]]
; CHECK: if.then:
; CHECK-NEXT: unreachable
; CHECK: if.end:
@@ -43,7 +43,7 @@ entry:
br label %land.lhs.true
land.lhs.true: ; preds = %entry
- br i1 undef, label %if.then, label %if.end
+ br i1 %arg, label %if.then, label %if.end
if.then: ; preds = %land.lhs.true
unreachable
diff --git a/llvm/test/Transforms/SLPVectorizer/X86/phi.ll b/llvm/test/Transforms/SLPVectorizer/X86/phi.ll
index 78bfb8df51aebb..df85656800aac2 100644
--- a/llvm/test/Transforms/SLPVectorizer/X86/phi.ll
+++ b/llvm/test/Transforms/SLPVectorizer/X86/phi.ll
@@ -277,13 +277,13 @@ for.end: ; preds = %for.body
ret float %add31
}
-define void @test(ptr %i1, ptr %i2, ptr %o) {
+define void @test(ptr %i1, ptr %i2, ptr %o, i1 %arg) {
; CHECK-LABEL: @test(
; CHECK-NEXT: entry:
; CHECK-NEXT: [[I1_0:%.*]] = load x86_fp80, ptr [[I1:%.*]], align 16
; CHECK-NEXT: [[I1_GEP1:%.*]] = getelementptr x86_fp80, ptr [[I1]], i64 1
; CHECK-NEXT: [[I1_1:%.*]] = load x86_fp80, ptr [[I1_GEP1]], align 16
-; CHECK-NEXT: br i1 undef, label [[THEN:%.*]], label [[END:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[THEN:%.*]], label [[END:%.*]]
; CHECK: then:
; CHECK-NEXT: [[I2_0:%.*]] = load x86_fp80, ptr [[I2:%.*]], align 16
; CHECK-NEXT: [[I2_GEP1:%.*]] = getelementptr inbounds x86_fp80, ptr [[I2]], i64 1
@@ -305,7 +305,7 @@ entry:
%i1.0 = load x86_fp80, ptr %i1, align 16
%i1.gep1 = getelementptr x86_fp80, ptr %i1, i64 1
%i1.1 = load x86_fp80, ptr %i1.gep1, align 16
- br i1 undef, label %then, label %end
+ br i1 %arg, label %then, label %end
then:
%i2.0 = load x86_fp80, ptr %i2, align 16
diff --git a/llvm/test/Transforms/SLPVectorizer/X86/phi_overalignedtype.ll b/llvm/test/Transforms/SLPVectorizer/X86/phi_overalignedtype.ll
index 88ac2d9dc42d12..ddbe943e324466 100644
--- a/llvm/test/Transforms/SLPVectorizer/X86/phi_overalignedtype.ll
+++ b/llvm/test/Transforms/SLPVectorizer/X86/phi_overalignedtype.ll
@@ -6,7 +6,7 @@ target datalayout = "e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:64-f3
target triple = "i386-apple-macosx10.9.0"
-define void @test(ptr %i1, ptr %i2, ptr %o) {
+define void @test(ptr %i1, ptr %i2, ptr %o, i1 %arg) {
; CHECK-LABEL: @test(
; CHECK-NEXT: entry:
; CHECK-NEXT: [[I1_0:%.*]] = load double, ptr [[I1:%.*]], align 16
@@ -14,7 +14,7 @@ define void @test(ptr %i1, ptr %i2, ptr %o) {
; CHECK-NEXT: [[I1_1:%.*]] = load double, ptr [[I1_GEP1]], align 16
; CHECK-NEXT: [[TMP0:%.*]] = insertelement <2 x double> poison, double [[I1_0]], i32 0
; CHECK-NEXT: [[TMP1:%.*]] = insertelement <2 x double> [[TMP0]], double [[I1_1]], i32 1
-; CHECK-NEXT: br i1 undef, label [[THEN:%.*]], label [[END:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[THEN:%.*]], label [[END:%.*]]
; CHECK: then:
; CHECK-NEXT: [[I2_0:%.*]] = load double, ptr [[I2:%.*]], align 16
; CHECK-NEXT: [[I2_GEP1:%.*]] = getelementptr inbounds double, ptr [[I2]], i64 1
@@ -38,7 +38,7 @@ entry:
%i1.0 = load double, ptr %i1, align 16
%i1.gep1 = getelementptr double, ptr %i1, i64 1
%i1.1 = load double, ptr %i1.gep1, align 16
- br i1 undef, label %then, label %end
+ br i1 %arg, label %then, label %end
then:
%i2.0 = load double, ptr %i2, align 16
diff --git a/llvm/test/Transforms/SLPVectorizer/X86/pr16571.ll b/llvm/test/Transforms/SLPVectorizer/X86/pr16571.ll
index b61b004797959a..733033efa3bfe4 100644
--- a/llvm/test/Transforms/SLPVectorizer/X86/pr16571.ll
+++ b/llvm/test/Transforms/SLPVectorizer/X86/pr16571.ll
@@ -3,9 +3,9 @@
target datalayout = "e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-f80:32:32-n8:16:32-S32"
target triple = "i686-pc-win32"
-define hidden fastcc void @"System.PrimitiveTypesParser.TryParseIEEE754<char>(char*,uint,double&)"() unnamed_addr {
+define hidden fastcc void @"System.PrimitiveTypesParser.TryParseIEEE754<char>(char*,uint,double&)"(i1 %arg) unnamed_addr {
"@0":
- br i1 undef, label %"@38.lr.ph", label %"@37"
+ br i1 %arg, label %"@38.lr.ph", label %"@37"
"@37": ; preds = %"@38.lr.ph", %"@44", %"@0"
ret void
@@ -13,10 +13,10 @@ define hidden fastcc void @"System.PrimitiveTypesParser.TryParseIEEE754<char>(ch
"@44": ; preds = %"@38.lr.ph"
%0 = add i64 undef, undef
%1 = add i32 %mainPartDigits.loc.0.ph45, 1
- br i1 undef, label %"@38.lr.ph", label %"@37"
+ br i1 %arg, label %"@38.lr.ph", label %"@37"
"@38.lr.ph": ; preds = %"@44", %"@0"
%mainDoublePart.loc.0.ph46 = phi i64 [ %0, %"@44" ], [ 0, %"@0" ]
%mainPartDigits.loc.0.ph45 = phi i32 [ %1, %"@44" ], [ 0, %"@0" ]
- br i1 undef, label %"@44", label %"@37"
+ br i1 %arg, label %"@44", label %"@37"
}
diff --git a/llvm/test/Transforms/SLPVectorizer/X86/remark_unsupported.ll b/llvm/test/Transforms/SLPVectorizer/X86/remark_unsupported.ll
index 540ea4eb659fe3..ac8b2428a3deab 100644
--- a/llvm/test/Transforms/SLPVectorizer/X86/remark_unsupported.ll
+++ b/llvm/test/Transforms/SLPVectorizer/X86/remark_unsupported.ll
@@ -3,13 +3,13 @@
; RUN: FileCheck --input-file=%t --check-prefix=YAML %s
; This type is not supported by SLP
-define i1 @test(ptr %i1, ptr %i2) {
+define i1 @test(ptr %i1, ptr %i2, i1 %arg) {
; CHECK-LABEL: @test(
; CHECK-NEXT: entry:
; CHECK-NEXT: [[I1_0:%.*]] = load x86_fp80, ptr [[I1:%.*]], align 16
; CHECK-NEXT: [[I1_GEP1:%.*]] = getelementptr x86_fp80, ptr [[I1]], i64 1
; CHECK-NEXT: [[I1_1:%.*]] = load x86_fp80, ptr [[I1_GEP1]], align 16
-; CHECK-NEXT: br i1 undef, label [[THEN:%.*]], label [[END:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[THEN:%.*]], label [[END:%.*]]
; CHECK: then:
; CHECK-NEXT: [[I2_0:%.*]] = load x86_fp80, ptr [[I2:%.*]], align 16
; CHECK-NEXT: [[I2_GEP1:%.*]] = getelementptr inbounds x86_fp80, ptr [[I2]], i64 1
@@ -25,7 +25,7 @@ entry:
%i1.0 = load x86_fp80, ptr %i1, align 16
%i1.gep1 = getelementptr x86_fp80, ptr %i1, i64 1
%i1.1 = load x86_fp80, ptr %i1.gep1, align 16
- br i1 undef, label %then, label %end
+ br i1 %arg, label %then, label %end
then:
%i2.0 = load x86_fp80, ptr %i2, align 16
%i2.gep1 = getelementptr inbounds x86_fp80, ptr %i2, i64 1
diff --git a/llvm/test/Transforms/SLPVectorizer/X86/reorder_repeated_ops.ll b/llvm/test/Transforms/SLPVectorizer/X86/reorder_repeated_ops.ll
index f9815529a23759..5f2199aef17ee4 100644
--- a/llvm/test/Transforms/SLPVectorizer/X86/reorder_repeated_ops.ll
+++ b/llvm/test/Transforms/SLPVectorizer/X86/reorder_repeated_ops.ll
@@ -3,10 +3,10 @@
target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
-define void @hoge() {
+define void @hoge(i1 %arg) {
; CHECK-LABEL: @hoge(
; CHECK-NEXT: bb:
-; CHECK-NEXT: br i1 undef, label [[BB1:%.*]], label [[BB2:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[BB1:%.*]], label [[BB2:%.*]]
; CHECK: bb1:
; CHECK-NEXT: ret void
; CHECK: bb2:
@@ -57,7 +57,7 @@ define void @hoge() {
; CHECK-NEXT: unreachable
;
bb:
- br i1 undef, label %bb1, label %bb2
+ br i1 %arg, label %bb1, label %bb2
bb1: ; preds = %bb
ret void
diff --git a/llvm/test/Transforms/SLPVectorizer/X86/reorder_with_reordered_users.ll b/llvm/test/Transforms/SLPVectorizer/X86/reorder_with_reordered_users.ll
index 69b4639d9c1318..2e6df0007e08b0 100644
--- a/llvm/test/Transforms/SLPVectorizer/X86/reorder_with_reordered_users.ll
+++ b/llvm/test/Transforms/SLPVectorizer/X86/reorder_with_reordered_users.ll
@@ -42,16 +42,16 @@
; comment out reorderTopToBottom() and remove the stores.
-define void @reorder_crash(ptr %ptr) {
+define void @reorder_crash(ptr %ptr, i1 %arg) {
; CHECK-LABEL: @reorder_crash(
; CHECK-NEXT: entry:
-; CHECK-NEXT: br i1 undef, label [[BB0:%.*]], label [[BB12:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[BB0:%.*]], label [[BB12:%.*]]
; CHECK: bb0:
; CHECK-NEXT: [[TMP0:%.*]] = load <4 x float>, ptr [[PTR:%.*]], align 4
; CHECK-NEXT: store <4 x float> [[TMP0]], ptr [[PTR]], align 4
; CHECK-NEXT: br label [[BB3:%.*]]
; CHECK: bb12:
-; CHECK-NEXT: br i1 undef, label [[BB1:%.*]], label [[BB2:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[BB1:%.*]], label [[BB2:%.*]]
; CHECK: bb1:
; CHECK-NEXT: [[TMP1:%.*]] = load <4 x float>, ptr [[PTR]], align 4
; CHECK-NEXT: store <4 x float> [[TMP1]], ptr [[PTR]], align 4
@@ -69,7 +69,7 @@ entry:
%gep1 = getelementptr inbounds float, ptr %ptr, i64 1
%gep2 = getelementptr inbounds float, ptr %ptr, i64 2
%gep3 = getelementptr inbounds float, ptr %ptr, i64 3
- br i1 undef, label %bb0, label %bb12
+ br i1 %arg, label %bb0, label %bb12
bb0:
; Used by phi in this order: 1, 0, 2, 3
@@ -86,7 +86,7 @@ bb0:
br label %bb3
bb12:
- br i1 undef, label %bb1, label %bb2
+ br i1 %arg, label %bb1, label %bb2
bb1:
; Used by phi in this order: 1, 0, 2, 3
diff --git a/llvm/test/Transforms/SLPVectorizer/X86/resched.ll b/llvm/test/Transforms/SLPVectorizer/X86/resched.ll
index cb955ff91ed810..ef1149a108e291 100644
--- a/llvm/test/Transforms/SLPVectorizer/X86/resched.ll
+++ b/llvm/test/Transforms/SLPVectorizer/X86/resched.ll
@@ -4,10 +4,10 @@
%"struct.std::array" = type { [32 x i8] }
; Function Attrs: nounwind uwtable
-define fastcc void @_ZN12_GLOBAL__N_127PolynomialMultiplyRecognize9recognizeEv() unnamed_addr #0 align 2 {
+define fastcc void @_ZN12_GLOBAL__N_127PolynomialMultiplyRecognize9recognizeEv(i1 %arg) unnamed_addr #0 align 2 {
; CHECK-LABEL: @_ZN12_GLOBAL__N_127PolynomialMultiplyRecognize9recognizeEv(
; CHECK-NEXT: entry:
-; CHECK-NEXT: br i1 undef, label [[IF_END50_I:%.*]], label [[IF_THEN22_I:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[IF_END50_I:%.*]], label [[IF_THEN22_I:%.*]]
; CHECK: if.then22.i:
; CHECK-NEXT: [[SUB_I:%.*]] = add nsw i32 undef, -1
; CHECK-NEXT: [[CONV31_I:%.*]] = and i32 undef, [[SUB_I]]
@@ -36,7 +36,7 @@ define fastcc void @_ZN12_GLOBAL__N_127PolynomialMultiplyRecognize9recognizeEv()
; CHECK-NEXT: ret void
;
entry:
- br i1 undef, label %if.end50.i, label %if.then22.i
+ br i1 %arg, label %if.end50.i, label %if.then22.i
if.then22.i: ; preds = %entry
%sub.i = add nsw i32 undef, -1
diff --git a/llvm/test/Transforms/SLPVectorizer/X86/reuse-extracts-in-wider-vect.ll b/llvm/test/Transforms/SLPVectorizer/X86/reuse-extracts-in-wider-vect.ll
index 79ce74bd21dbcf..b900bd3a8c3318 100644
--- a/llvm/test/Transforms/SLPVectorizer/X86/reuse-extracts-in-wider-vect.ll
+++ b/llvm/test/Transforms/SLPVectorizer/X86/reuse-extracts-in-wider-vect.ll
@@ -4,7 +4,7 @@ target datalayout = "e-m:e-p270:32:32-p271:32:32-p272:64:64-i64:64-f80:128-n8:16
%struct.S = type { [3 x float], [3 x float], [4 x float] }
-define i32 @foo(i32 %0, ptr %1, ptr %2) {
+define i32 @foo(i32 %0, ptr %1, ptr %2, i1 %arg) {
; CHECK-LABEL: @foo(
; CHECK-NEXT: [[T4:%.*]] = alloca [[STRUCT_S:%.*]], align 8
; CHECK-NEXT: [[T8:%.*]] = getelementptr inbounds [[STRUCT_S]], ptr [[T4]], i64 0, i32 1
@@ -19,7 +19,7 @@ define i32 @foo(i32 %0, ptr %1, ptr %2) {
; CHECK-NEXT: [[T21:%.*]] = getelementptr inbounds [[STRUCT_S]], ptr [[T4]], i64 0, i32 2, i64 0
; CHECK-NEXT: store <4 x float> [[SHUFFLE]], ptr [[T21]], align 4
; CHECK-NEXT: [[T89]] = load <2 x float>, ptr [[T9]], align 4
-; CHECK-NEXT: br i1 undef, label [[T37]], label [[T55:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[T37]], label [[T55:%.*]]
; CHECK: t55:
; CHECK-NEXT: ret i32 0
;
@@ -49,7 +49,7 @@ t37:
%t89 = load <2 x float>, ptr %t9, align 4
%x23 = extractelement <2 x float> %t89, i32 0
%x24 = extractelement <2 x float> %t89, i32 1
- br i1 undef, label %t37, label %t55
+ br i1 %arg, label %t37, label %t55
t55:
diff --git a/llvm/test/Transforms/SLPVectorizer/X86/revectorized_rdx_crash.ll b/llvm/test/Transforms/SLPVectorizer/X86/revectorized_rdx_crash.ll
index edd1a2a3a2fff8..364b0f4c1a3a7a 100644
--- a/llvm/test/Transforms/SLPVectorizer/X86/revectorized_rdx_crash.ll
+++ b/llvm/test/Transforms/SLPVectorizer/X86/revectorized_rdx_crash.ll
@@ -12,10 +12,10 @@
; iteration (it was matched and vectorized, which added a use of a deleted
; instruction)
-define void @test() {
+define void @test(i1 %arg) {
; CHECK-LABEL: @test(
; CHECK-NEXT: entry:
-; CHECK-NEXT: br i1 undef, label [[IF_END:%.*]], label [[FOR_COND_PREHEADER:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[IF_END:%.*]], label [[FOR_COND_PREHEADER:%.*]]
; CHECK: for.cond.preheader:
; CHECK-NEXT: [[I:%.*]] = getelementptr inbounds [100 x i32], ptr undef, i64 0, i64 2
; CHECK-NEXT: [[I1:%.*]] = getelementptr inbounds [100 x i32], ptr undef, i64 0, i64 3
@@ -35,7 +35,7 @@ define void @test() {
; CHECK-NEXT: ret void
;
entry:
- br i1 undef, label %if.end, label %for.cond.preheader
+ br i1 %arg, label %if.end, label %for.cond.preheader
for.cond.preheader: ; preds = %entry
%i = getelementptr inbounds [100 x i32], ptr undef, i64 0, i64 2
diff --git a/llvm/test/Transforms/SLPVectorizer/X86/value-bug-inseltpoison.ll b/llvm/test/Transforms/SLPVectorizer/X86/value-bug-inseltpoison.ll
index eb5e218f057ce0..ac9454967719e4 100644
--- a/llvm/test/Transforms/SLPVectorizer/X86/value-bug-inseltpoison.ll
+++ b/llvm/test/Transforms/SLPVectorizer/X86/value-bug-inseltpoison.ll
@@ -8,7 +8,7 @@ target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
; as elements of the vectorized tree.
; PR19621
-define void @test() {
+define void @test(i1 %arg) {
; CHECK-LABEL: @test(
; CHECK-NEXT: bb279:
; CHECK-NEXT: br label [[BB283:%.*]]
@@ -22,13 +22,13 @@ define void @test() {
; CHECK-NEXT: [[TMP4:%.*]] = fsub <2 x double> [[TMP3]], undef
; CHECK-NEXT: br label [[BB21_I:%.*]]
; CHECK: bb21.i:
-; CHECK-NEXT: br i1 undef, label [[BB22_I:%.*]], label [[EXIT]]
+; CHECK-NEXT: br i1 %arg, label [[BB22_I:%.*]], label [[EXIT]]
; CHECK: bb22.i:
; CHECK-NEXT: [[TMP5:%.*]] = fadd <2 x double> undef, [[TMP4]]
; CHECK-NEXT: br label [[BB32_I:%.*]]
; CHECK: bb32.i:
; CHECK-NEXT: [[TMP6:%.*]] = phi <2 x double> [ [[TMP5]], [[BB22_I]] ], [ zeroinitializer, [[BB32_I]] ]
-; CHECK-NEXT: br i1 undef, label [[BB32_I]], label [[BB21_I]]
+; CHECK-NEXT: br i1 %arg, label [[BB32_I]], label [[BB21_I]]
; CHECK: exit:
; CHECK-NEXT: [[TMP7:%.*]] = fpext <2 x float> [[TMP1]] to <2 x double>
; CHECK-NEXT: [[TMP8:%.*]] = fmul <2 x double> [[TMP7]], <double undef, double 0.000000e+00>
@@ -57,7 +57,7 @@ bb284:
br label %bb21.i
bb21.i:
- br i1 undef, label %bb22.i, label %exit
+ br i1 %arg, label %bb22.i, label %exit
bb22.i:
%tmp24.i = fadd double undef, %tmp9.i
@@ -67,7 +67,7 @@ bb22.i:
bb32.i:
%xs.0.i = phi double [ %tmp24.i, %bb22.i ], [ 0.000000e+00, %bb32.i ]
%ys.0.i = phi double [ %tmp26.i, %bb22.i ], [ 0.000000e+00, %bb32.i ]
- br i1 undef, label %bb32.i, label %bb21.i
+ br i1 %arg, label %bb32.i, label %bb21.i
exit:
%tmp303 = fpext float %Av.sroa.0.0 to double
diff --git a/llvm/test/Transforms/SLPVectorizer/X86/value-bug.ll b/llvm/test/Transforms/SLPVectorizer/X86/value-bug.ll
index f870cb44f4e5f6..c5cdcdc1eb1a59 100644
--- a/llvm/test/Transforms/SLPVectorizer/X86/value-bug.ll
+++ b/llvm/test/Transforms/SLPVectorizer/X86/value-bug.ll
@@ -8,7 +8,7 @@ target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
; as elements of the vectorized tree.
; PR19621
-define void @test() {
+define void @test(i1 %arg) {
; CHECK-LABEL: @test(
; CHECK-NEXT: bb279:
; CHECK-NEXT: br label [[BB283:%.*]]
@@ -22,13 +22,13 @@ define void @test() {
; CHECK-NEXT: [[TMP4:%.*]] = fsub <2 x double> [[TMP3]], undef
; CHECK-NEXT: br label [[BB21_I:%.*]]
; CHECK: bb21.i:
-; CHECK-NEXT: br i1 undef, label [[BB22_I:%.*]], label [[EXIT]]
+; CHECK-NEXT: br i1 %arg, label [[BB22_I:%.*]], label [[EXIT]]
; CHECK: bb22.i:
; CHECK-NEXT: [[TMP5:%.*]] = fadd <2 x double> undef, [[TMP4]]
; CHECK-NEXT: br label [[BB32_I:%.*]]
; CHECK: bb32.i:
; CHECK-NEXT: [[TMP6:%.*]] = phi <2 x double> [ [[TMP5]], [[BB22_I]] ], [ zeroinitializer, [[BB32_I]] ]
-; CHECK-NEXT: br i1 undef, label [[BB32_I]], label [[BB21_I]]
+; CHECK-NEXT: br i1 %arg, label [[BB32_I]], label [[BB21_I]]
; CHECK: exit:
; CHECK-NEXT: [[TMP7:%.*]] = fpext <2 x float> [[TMP1]] to <2 x double>
; CHECK-NEXT: [[TMP8:%.*]] = fmul <2 x double> [[TMP7]], <double undef, double 0.000000e+00>
@@ -57,7 +57,7 @@ bb284:
br label %bb21.i
bb21.i:
- br i1 undef, label %bb22.i, label %exit
+ br i1 %arg, label %bb22.i, label %exit
bb22.i:
%tmp24.i = fadd double undef, %tmp9.i
@@ -67,7 +67,7 @@ bb22.i:
bb32.i:
%xs.0.i = phi double [ %tmp24.i, %bb22.i ], [ 0.000000e+00, %bb32.i ]
%ys.0.i = phi double [ %tmp26.i, %bb22.i ], [ 0.000000e+00, %bb32.i ]
- br i1 undef, label %bb32.i, label %bb21.i
+ br i1 %arg, label %bb32.i, label %bb21.i
exit:
%tmp303 = fpext float %Av.sroa.0.0 to double
diff --git a/llvm/test/Transforms/SLPVectorizer/X86/vectorize-widest-phis.ll b/llvm/test/Transforms/SLPVectorizer/X86/vectorize-widest-phis.ll
index 17f9f371ff6ef9..a69849fabcef6a 100644
--- a/llvm/test/Transforms/SLPVectorizer/X86/vectorize-widest-phis.ll
+++ b/llvm/test/Transforms/SLPVectorizer/X86/vectorize-widest-phis.ll
@@ -1,7 +1,7 @@
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
; RUN: opt -passes=slp-vectorizer -S -mcpu=cascadelake -mtriple=x86_64-unknown-linux-gnu < %s | FileCheck %s
-define void @foo() {
+define void @foo(i1 %arg) {
; CHECK-LABEL: @foo(
; CHECK-NEXT: entry:
; CHECK-NEXT: [[CONV:%.*]] = uitofp i16 undef to float
@@ -14,7 +14,7 @@ define void @foo() {
; CHECK: bb2:
; CHECK-NEXT: [[TMP2:%.*]] = phi <4 x float> [ [[TMP1]], [[BB1]] ], [ [[TMP14:%.*]], [[BB3:%.*]] ]
; CHECK-NEXT: [[TMP3:%.*]] = load double, ptr undef, align 8
-; CHECK-NEXT: br i1 undef, label [[BB3]], label [[BB4:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[BB3]], label [[BB4:%.*]]
; CHECK: bb4:
; CHECK-NEXT: [[TMP4:%.*]] = fpext <4 x float> [[TMP2]] to <4 x double>
; CHECK-NEXT: [[CONV2:%.*]] = uitofp i16 undef to double
@@ -46,7 +46,7 @@ bb2:
%2 = phi float [ undef, %bb1 ], [ %11, %bb3 ]
%3 = phi float [ undef, %bb1 ], [ %12, %bb3 ]
%4 = load double, ptr undef, align 8
- br i1 undef, label %bb3, label %bb4
+ br i1 %arg, label %bb3, label %bb4
bb4:
%ext = fpext float %3 to double
diff --git a/llvm/test/Transforms/SLPVectorizer/slp-umax-rdx-matcher-crash.ll b/llvm/test/Transforms/SLPVectorizer/slp-umax-rdx-matcher-crash.ll
index 9d6371b13e08a4..a728515f0fdc33 100644
--- a/llvm/test/Transforms/SLPVectorizer/slp-umax-rdx-matcher-crash.ll
+++ b/llvm/test/Transforms/SLPVectorizer/slp-umax-rdx-matcher-crash.ll
@@ -7,10 +7,10 @@
; to UMax and thus same reduction kind is returned.
; The routine's later code merely assumes the instruction to be a select.
-define dso_local void @test() {
+define dso_local void @test(i1 %arg) {
; CHECK-LABEL: @test(
; CHECK-NEXT: entry:
-; CHECK-NEXT: br i1 undef, label [[NEXT:%.*]], label [[THEN:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[NEXT:%.*]], label [[THEN:%.*]]
; CHECK: then:
; CHECK-NEXT: [[UM:%.*]] = call i8 @llvm.umax.i8(i8 0, i8 undef)
; CHECK-NEXT: [[SELCMP:%.*]] = icmp ult i8 [[UM]], undef
@@ -21,7 +21,7 @@ define dso_local void @test() {
; CHECK-NEXT: ret void
;
entry:
- br i1 undef, label %next, label %then
+ br i1 %arg, label %next, label %then
then:
%um = call i8 @llvm.umax.i8(i8 0, i8 undef)
>From 4537b6e791f6e777836f456cd3b7e86448942487 Mon Sep 17 00:00:00 2001
From: Lee <lee10202013 at gmail.com>
Date: Mon, 2 Dec 2024 19:59:46 -0700
Subject: [PATCH 05/10] Remove br i1 undef in Scalarizer directory
---
llvm/test/Transforms/Scalarizer/crash-bug.ll | 8 ++++----
.../Scalarizer/dbgloc-bug-inseltpoison.ll | 4 ++--
llvm/test/Transforms/Scalarizer/dbgloc-bug.ll | 4 ++--
.../Scalarizer/phi-unreachable-pred.ll | 20 +++++++++----------
4 files changed, 18 insertions(+), 18 deletions(-)
diff --git a/llvm/test/Transforms/Scalarizer/crash-bug.ll b/llvm/test/Transforms/Scalarizer/crash-bug.ll
index 2195a37564c6a1..692fc07e3ea5c1 100644
--- a/llvm/test/Transforms/Scalarizer/crash-bug.ll
+++ b/llvm/test/Transforms/Scalarizer/crash-bug.ll
@@ -3,14 +3,14 @@
; Don't crash
-define void @foo() {
-; CHECK-LABEL: define void @foo() {
+define void @foo(i1 %arg) {
+; CHECK-LABEL: define void @foo(i1 %arg) {
; CHECK-NEXT: br label [[BB1:%.*]]
; CHECK: bb2:
; CHECK-NEXT: br label [[BB1]]
; CHECK: bb1:
; CHECK-NEXT: [[BB2_VEC_I1:%.*]] = phi i16 [ 200, [[TMP0:%.*]] ], [ [[BB2_VEC_I1]], [[BB2:%.*]] ]
-; CHECK-NEXT: br i1 undef, label [[BB3:%.*]], label [[BB2]]
+; CHECK-NEXT: br i1 %arg, label [[BB3:%.*]], label [[BB2]]
; CHECK: bb3:
; CHECK-NEXT: ret void
;
@@ -22,7 +22,7 @@ bb2: ; preds = %bb1
bb1: ; preds = %bb2, %0
%bb1_vec = phi <2 x i16> [ <i16 100, i16 200>, %0 ], [ %bb2_vec, %bb2 ]
- br i1 undef, label %bb3, label %bb2
+ br i1 %arg, label %bb3, label %bb2
bb3:
ret void
diff --git a/llvm/test/Transforms/Scalarizer/dbgloc-bug-inseltpoison.ll b/llvm/test/Transforms/Scalarizer/dbgloc-bug-inseltpoison.ll
index e5ba35ca2c4ee2..4f4dff84e12942 100644
--- a/llvm/test/Transforms/Scalarizer/dbgloc-bug-inseltpoison.ll
+++ b/llvm/test/Transforms/Scalarizer/dbgloc-bug-inseltpoison.ll
@@ -7,7 +7,7 @@ define i16 @f1() !dbg !5 {
ret i16 undef, !dbg !9
}
-define void @f2() !dbg !10 {
+define void @f2(i1 %arg) !dbg !10 {
bb1:
%_tmp7 = tail call i16 @f1(), !dbg !13
; CHECK: call i16 @f1(), !dbg !13
@@ -16,7 +16,7 @@ bb1:
br label %vector.body
vector.body:
- br i1 undef, label %middle.block, label %vector.body
+ br i1 %arg, label %middle.block, label %vector.body
middle.block:
ret void, !dbg !15
diff --git a/llvm/test/Transforms/Scalarizer/dbgloc-bug.ll b/llvm/test/Transforms/Scalarizer/dbgloc-bug.ll
index 639fd3d7c0957b..3dd768e593eb4c 100644
--- a/llvm/test/Transforms/Scalarizer/dbgloc-bug.ll
+++ b/llvm/test/Transforms/Scalarizer/dbgloc-bug.ll
@@ -7,7 +7,7 @@ define i16 @f1() !dbg !5 {
ret i16 undef, !dbg !9
}
-define void @f2() !dbg !10 {
+define void @f2(i1 %arg) !dbg !10 {
bb1:
%_tmp7 = tail call i16 @f1(), !dbg !13
; CHECK: call i16 @f1(), !dbg !13
@@ -16,7 +16,7 @@ bb1:
br label %vector.body
vector.body:
- br i1 undef, label %middle.block, label %vector.body
+ br i1 %arg, label %middle.block, label %vector.body
middle.block:
ret void, !dbg !15
diff --git a/llvm/test/Transforms/Scalarizer/phi-unreachable-pred.ll b/llvm/test/Transforms/Scalarizer/phi-unreachable-pred.ll
index 3b6f5ccf3d3ea0..8ce912ff55d6e5 100644
--- a/llvm/test/Transforms/Scalarizer/phi-unreachable-pred.ll
+++ b/llvm/test/Transforms/Scalarizer/phi-unreachable-pred.ll
@@ -1,7 +1,7 @@
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
; RUN: opt < %s -passes='function(scalarizer)' -S -o - | FileCheck %s
-define i16 @f1() {
+define i16 @f1(i1 %arg) {
; CHECK-LABEL: @f1(
; CHECK-NEXT: entry:
; CHECK-NEXT: br label [[FOR_END:%.*]]
@@ -9,7 +9,7 @@ define i16 @f1() {
; CHECK-NEXT: [[INSERT:%.*]] = insertelement <4 x i16> [[INSERT]], i16 ptrtoint (ptr @f1 to i16), i32 0
; CHECK-NEXT: br label [[FOR_COND:%.*]]
; CHECK: for.cond:
-; CHECK-NEXT: br i1 undef, label [[FOR_BODY:%.*]], label [[FOR_END]]
+; CHECK-NEXT: br i1 %arg, label [[FOR_BODY:%.*]], label [[FOR_END]]
; CHECK: for.end:
; CHECK-NEXT: [[PHI_I0:%.*]] = phi i16 [ 1, [[ENTRY:%.*]] ], [ poison, [[FOR_COND]] ]
; CHECK-NEXT: ret i16 [[PHI_I0]]
@@ -22,7 +22,7 @@ for.body:
br label %for.cond
for.cond:
- br i1 undef, label %for.body, label %for.end
+ br i1 %arg, label %for.body, label %for.end
for.end:
; opt used to hang when scalarizing this code. When scattering %insert we
@@ -34,22 +34,22 @@ for.end:
ret i16 %extract
}
-define void @f2() {
+define void @f2(i1 %arg) {
; CHECK-LABEL: @f2(
; CHECK-NEXT: entry:
; CHECK-NEXT: br label [[FOR_BODY:%.*]]
; CHECK: for.body:
-; CHECK-NEXT: br i1 undef, label [[IF_THEN:%.*]], label [[IF_END8:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[IF_THEN:%.*]], label [[IF_END8:%.*]]
; CHECK: if.then:
; CHECK-NEXT: br label [[IF_END8]]
; CHECK: for.body2:
-; CHECK-NEXT: br i1 undef, label [[FOR_END:%.*]], label [[FOR_INC:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[FOR_END:%.*]], label [[FOR_INC:%.*]]
; CHECK: for.end:
; CHECK-NEXT: br label [[FOR_INC]]
; CHECK: for.inc:
; CHECK-NEXT: [[E_SROA_3_2:%.*]] = phi <2 x i64> [ splat (i64 1), [[FOR_END]] ], [ [[E_SROA_3_2]], [[FOR_BODY2:%.*]] ]
; CHECK-NEXT: [[TMP0:%.*]] = phi i32 [ 6, [[FOR_END]] ], [ [[TMP0]], [[FOR_BODY2]] ]
-; CHECK-NEXT: br i1 undef, label [[FOR_BODY2]], label [[FOR_COND1_FOR_END7_CRIT_EDGE:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[FOR_BODY2]], label [[FOR_COND1_FOR_END7_CRIT_EDGE:%.*]]
; CHECK: for.cond1.for.end7_crit_edge:
; CHECK-NEXT: br label [[IF_END8]]
; CHECK: if.end8:
@@ -61,13 +61,13 @@ entry:
br label %for.body
for.body: ; preds = %if.end8, %entry
- br i1 undef, label %if.then, label %if.end8
+ br i1 %arg, label %if.then, label %if.end8
if.then: ; preds = %for.body
br label %if.end8
for.body2: ; preds = %for.inc
- br i1 undef, label %for.end, label %for.inc
+ br i1 %arg, label %for.end, label %for.inc
for.end: ; preds = %for.body2
br label %for.inc
@@ -75,7 +75,7 @@ for.end: ; preds = %for.body2
for.inc: ; preds = %for.end, %for.body2
%e.sroa.3.2 = phi <2 x i64> [ <i64 1, i64 1>, %for.end ], [ %e.sroa.3.2, %for.body2 ]
%0 = phi i32 [ 6, %for.end ], [ %0, %for.body2 ]
- br i1 undef, label %for.body2, label %for.cond1.for.end7_crit_edge
+ br i1 %arg, label %for.body2, label %for.cond1.for.end7_crit_edge
for.cond1.for.end7_crit_edge: ; preds = %for.inc
br label %if.end8
>From ab7ec90e00140a8343c4b57814c2a61afe0b95b5 Mon Sep 17 00:00:00 2001
From: Lee <lee10202013 at gmail.com>
Date: Mon, 2 Dec 2024 20:14:43 -0700
Subject: [PATCH 06/10] Remove br i1 undef in SimpleLoopUnswitch directory
---
.../2011-06-02-CritSwitch.ll | 6 +--
.../2012-04-30-LoopUnswitch-LPad-Crash.ll | 4 +-
.../2015-09-18-Addrspace.ll | 4 +-
.../SimpleLoopUnswitch/delete-dead-blocks.ll | 12 ++---
.../formDedicatedAfterTrivial1.ll | 4 +-
.../Transforms/SimpleLoopUnswitch/guards.ll | 54 ++++++++++++++-----
.../Transforms/SimpleLoopUnswitch/pr37888.ll | 2 +-
.../SimpleLoopUnswitch/preserve-analyses.ll | 12 ++---
8 files changed, 62 insertions(+), 36 deletions(-)
diff --git a/llvm/test/Transforms/SimpleLoopUnswitch/2011-06-02-CritSwitch.ll b/llvm/test/Transforms/SimpleLoopUnswitch/2011-06-02-CritSwitch.ll
index 55c9d677ee529a..62e451f8f5ca85 100644
--- a/llvm/test/Transforms/SimpleLoopUnswitch/2011-06-02-CritSwitch.ll
+++ b/llvm/test/Transforms/SimpleLoopUnswitch/2011-06-02-CritSwitch.ll
@@ -1,12 +1,12 @@
; RUN: opt -passes=simple-loop-unswitch -verify-memoryssa -disable-output < %s
; PR10031
-define i32 @test(i32 %command) {
+define i32 @test(i32 %command, i1 %arg) {
entry:
br label %tailrecurse
tailrecurse: ; preds = %if.then14, %tailrecurse, %entry
- br i1 undef, label %if.then, label %tailrecurse
+ br i1 %arg, label %if.then, label %tailrecurse
if.then: ; preds = %tailrecurse
switch i32 %command, label %sw.bb [
@@ -15,7 +15,7 @@ if.then: ; preds = %tailrecurse
]
land.lhs.true: ; preds = %if.then, %if.then
- br i1 undef, label %sw.bb, label %if.then14
+ br i1 %arg, label %sw.bb, label %if.then14
if.then14: ; preds = %land.lhs.true
switch i32 %command, label %tailrecurse [
diff --git a/llvm/test/Transforms/SimpleLoopUnswitch/2012-04-30-LoopUnswitch-LPad-Crash.ll b/llvm/test/Transforms/SimpleLoopUnswitch/2012-04-30-LoopUnswitch-LPad-Crash.ll
index 8ad869015f44e8..229bbb2f3929f1 100644
--- a/llvm/test/Transforms/SimpleLoopUnswitch/2012-04-30-LoopUnswitch-LPad-Crash.ll
+++ b/llvm/test/Transforms/SimpleLoopUnswitch/2012-04-30-LoopUnswitch-LPad-Crash.ll
@@ -8,7 +8,7 @@ target triple = "x86_64-apple-macosx10.7.0"
%class.B.21.41.65.101.137.157.177.197.237.241.245.249.261.293.301.337.345.378 = type { ptr }
%class.A.20.40.64.100.136.156.176.196.236.240.244.248.260.292.300.336.344.377 = type { i8 }
-define void @_Z23get_reconstruction_pathv() uwtable ssp personality ptr @__gxx_personality_v0 {
+define void @_Z23get_reconstruction_pathv(i1 %arg) uwtable ssp personality ptr @__gxx_personality_v0 {
entry:
%c = alloca %class.D.22.42.66.102.138.158.178.198.238.242.246.250.262.294.302.338.346.379, align 8
br label %for.cond
@@ -30,7 +30,7 @@ invoke.cont4: ; preds = %for.cond3
to label %invoke.cont6 unwind label %lpad
invoke.cont6: ; preds = %invoke.cont4
- br i1 undef, label %for.cond3, label %for.end
+ br i1 %arg, label %for.cond3, label %for.end
lpad: ; preds = %for.end, %invoke.cont4, %for.cond3, %invoke.cont, %for.cond
%0 = landingpad { ptr, i32 }
diff --git a/llvm/test/Transforms/SimpleLoopUnswitch/2015-09-18-Addrspace.ll b/llvm/test/Transforms/SimpleLoopUnswitch/2015-09-18-Addrspace.ll
index ce767f14cf073d..8d5c0306306d8b 100644
--- a/llvm/test/Transforms/SimpleLoopUnswitch/2015-09-18-Addrspace.ll
+++ b/llvm/test/Transforms/SimpleLoopUnswitch/2015-09-18-Addrspace.ll
@@ -6,12 +6,12 @@
target datalayout = "e-m:e-p:16:16-p1:32:16-i32:16-i64:16-n8:16"
-define void @foo() {
+define void @foo(i1 %arg) {
; CHECK-LABEL: @foo
entry:
%arrayidx.i1 = getelementptr inbounds i16, ptr undef, i16 undef
%arrayidx.i = addrspacecast ptr %arrayidx.i1 to ptr addrspace(1)
- br i1 undef, label %for.body.i, label %bar.exit
+ br i1 %arg, label %for.body.i, label %bar.exit
for.body.i: ; preds = %for.body.i, %entry
; When we call makeLoopInvariant (i.e. trivial LICM) on this load, it
diff --git a/llvm/test/Transforms/SimpleLoopUnswitch/delete-dead-blocks.ll b/llvm/test/Transforms/SimpleLoopUnswitch/delete-dead-blocks.ll
index 9ca554023a8cf3..e66c7ace18fc05 100644
--- a/llvm/test/Transforms/SimpleLoopUnswitch/delete-dead-blocks.ll
+++ b/llvm/test/Transforms/SimpleLoopUnswitch/delete-dead-blocks.ll
@@ -6,7 +6,7 @@
declare void @foo()
; CHECK-LABEL: @Test
-define void @Test(i32) {
+define void @Test(i32, i1 %arg) {
entry:
br label %outer
outer:
@@ -47,7 +47,7 @@ get_out2:
;
; This comes from PR38778
; CHECK-LABEL: @Test2
-define void @Test2(i32) {
+define void @Test2(i32, i1 %arg) {
header:
br label %loop
loop:
@@ -58,12 +58,12 @@ loop:
]
; CHECK-NOT: {{^}}guarded1:
guarded1:
- br i1 undef, label %continue, label %leave
+ br i1 %arg, label %continue, label %leave
guarded2:
br label %continue
check:
%val = add i32 0, 1
- br i1 undef, label %continue, label %leave
+ br i1 %arg, label %continue, label %leave
continue:
br label %loop
leave:
@@ -75,7 +75,7 @@ leave:
; Yet another test from PR38778
;
; CHECK-LABEL: @Test3
-define void @Test3(i32) {
+define void @Test3(i32, i1 %arg) {
header:
br label %outer
outer:
@@ -95,7 +95,7 @@ case2:
br label %continue
continue:
%local_11_92 = phi i32 [ 0, %switchme ], [ 18, %case2 ], [ 0, %overflow ]
- br i1 undef, label %outer, label %inner
+ br i1 %arg, label %outer, label %inner
go_out:
unreachable
}
diff --git a/llvm/test/Transforms/SimpleLoopUnswitch/formDedicatedAfterTrivial1.ll b/llvm/test/Transforms/SimpleLoopUnswitch/formDedicatedAfterTrivial1.ll
index 19a2bc3ad04498..45da85299051f9 100644
--- a/llvm/test/Transforms/SimpleLoopUnswitch/formDedicatedAfterTrivial1.ll
+++ b/llvm/test/Transforms/SimpleLoopUnswitch/formDedicatedAfterTrivial1.ll
@@ -2,7 +2,7 @@
; PR38283
; PR38737
-define void @f1() {
+define void @f1(i1 %arg) {
for.cond1thread-pre-split.lr.ph.lr.ph:
%tobool4 = icmp eq i16 undef, 0
br label %for.cond1thread-pre-split
@@ -18,7 +18,7 @@ if.end: ; preds = %for.body2
br i1 %tobool4, label %if.end6, label %for.cond1thread-pre-split
if.end6: ; preds = %if.end
- br i1 undef, label %for.body2, label %for.end
+ br i1 %arg, label %for.body2, label %for.end
for.end: ; preds = %if.end6, %for.body2
ret void
diff --git a/llvm/test/Transforms/SimpleLoopUnswitch/guards.ll b/llvm/test/Transforms/SimpleLoopUnswitch/guards.ll
index 07668616ff86d0..533b1f691f5adb 100644
--- a/llvm/test/Transforms/SimpleLoopUnswitch/guards.ll
+++ b/llvm/test/Transforms/SimpleLoopUnswitch/guards.ll
@@ -1,3 +1,4 @@
+; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: -p --version 5
; RUN: opt -passes='loop(simple-loop-unswitch<nontrivial>),verify<loops>' -simple-loop-unswitch-guards -S < %s | FileCheck %s
; RUN: opt -passes='simple-loop-unswitch<nontrivial>' -simple-loop-unswitch-guards -S < %s | FileCheck %s
; RUN: opt -passes='loop-mssa(simple-loop-unswitch<nontrivial>),verify<loops>' -simple-loop-unswitch-guards -verify-memoryssa -verify-loop-info -S < %s | FileCheck %s
@@ -131,30 +132,55 @@ exit:
ret void
}
-define void @test_nested_loop(i1 %cond, i32 %N) {
-; CHECK-LABEL: @test_nested_loop(
+define void @test_nested_loop(i1 %cond, i32 %N, i1 %arg) {
+; CHECK-LABEL: define void @test_nested_loop(i1 %cond, i32 %N, i1 %arg) {
; CHECK-NEXT: entry:
-; CHECK-NEXT: br i1 [[COND:%.*]], label [[ENTRY_SPLIT:%.*]], label [[OUTER_LOOP_SPLIT:%.*]]
+; CHECK-NEXT: br i1 %cond, label %entry.split, label %outer_loop.split
; CHECK: entry.split:
-; CHECK-NEXT: br label [[OUTER_LOOP:%.*]]
+; CHECK-NEXT: br i1 %arg, label %entry.split.split.us, label %entry.split.split
+; CHECK: entry.split.split.us:
+; CHECK-NEXT: br label %outer_loop.us
+; CHECK: outer_loop.us:
+; CHECK-NEXT: br label %outer_loop.split.us.us
+; CHECK: outer_backedge.us:
+; CHECK-NEXT: br label %outer_loop.us
+; CHECK: outer_loop.split.us.us:
+; CHECK-NEXT: br label %loop.us.us
+; CHECK: loop.us.us:
+; CHECK-NEXT: %iv.us.us = phi i32 [ 0, %outer_loop.split.us.us ], [ %iv.next.us.us, %guarded.us.us ]
+; CHECK-NEXT: br label %guarded.us.us
+; CHECK: guarded.us.us:
+; CHECK-NEXT: %iv.next.us.us = add i32 %iv.us.us, 1
+; CHECK-NEXT: %loop.cond.us.us = icmp slt i32 %iv.next.us.us, %N
+; CHECK-NEXT: br i1 %loop.cond.us.us, label %loop.us.us, label %outer_backedge.split.us.us
+; CHECK: outer_backedge.split.us.us:
+; CHECK-NEXT: br label %outer_backedge.us
+; CHECK: entry.split.split:
+; CHECK-NEXT: br label %outer_loop
; CHECK: outer_loop:
-; CHECK-NEXT: br label [[OUTER_LOOP_SPLIT_US:%.*]]
+; CHECK-NEXT: br label %outer_loop.split.us
; CHECK: outer_loop.split.us:
-; CHECK-NEXT: br label [[LOOP_US:%.*]]
+; CHECK-NEXT: br label %loop.us
; CHECK: loop.us:
-; CHECK-NEXT: [[IV_US:%.*]] = phi i32 [ 0, [[OUTER_LOOP_SPLIT_US]] ], [ [[IV_NEXT_US:%.*]], [[GUARDED_US:%.*]] ]
-; CHECK-NEXT: br label [[GUARDED_US]]
+; CHECK-NEXT: %iv.us = phi i32 [ 0, %outer_loop.split.us ], [ %iv.next.us, %guarded.us ]
+; CHECK-NEXT: br label %guarded.us
; CHECK: guarded.us:
-; CHECK-NEXT: [[IV_NEXT_US]] = add i32 [[IV_US]], 1
-; CHECK-NEXT: [[LOOP_COND_US:%.*]] = icmp slt i32 [[IV_NEXT_US]], [[N:%.*]]
-; CHECK-NEXT: br i1 [[LOOP_COND_US]], label [[LOOP_US]], label [[OUTER_BACKEDGE_SPLIT_US:%.*]]
+; CHECK-NEXT: %iv.next.us = add i32 %iv.us, 1
+; CHECK-NEXT: %loop.cond.us = icmp slt i32 %iv.next.us, %N
+; CHECK-NEXT: br i1 %loop.cond.us, label %loop.us, label %outer_backedge.split.us
; CHECK: outer_backedge.split.us:
-; CHECK-NEXT: br label [[OUTER_BACKEDGE:%.*]]
+; CHECK-NEXT: br label %outer_backedge
+; CHECK: outer_loop.split:
+; CHECK-NEXT: br label %loop
+; CHECK: loop:
+; CHECK-NEXT: br label %deopt
; CHECK: deopt:
; CHECK-NEXT: call void (i1, ...) @llvm.experimental.guard(i1 false) [ "deopt"() ]
; CHECK-NEXT: unreachable
; CHECK: outer_backedge:
-; CHECK-NEXT: br i1 false, label [[OUTER_LOOP]], label [[EXIT:%.*]]
+; CHECK-NEXT: br label %exit
+; CHECK: exit:
+; CHECK-NEXT: ret void
;
entry:
@@ -171,7 +197,7 @@ loop:
br i1 %loop.cond, label %loop, label %outer_backedge
outer_backedge:
- br i1 undef, label %outer_loop, label %exit
+ br i1 %arg, label %outer_loop, label %exit
exit:
ret void
diff --git a/llvm/test/Transforms/SimpleLoopUnswitch/pr37888.ll b/llvm/test/Transforms/SimpleLoopUnswitch/pr37888.ll
index 099d6a5456e8ea..7c9bb1b8520d63 100644
--- a/llvm/test/Transforms/SimpleLoopUnswitch/pr37888.ll
+++ b/llvm/test/Transforms/SimpleLoopUnswitch/pr37888.ll
@@ -29,7 +29,7 @@ if.end:
br label %for.inc
for.inc:
- br i1 undef, label %for.body, label %for.end
+ br i1 false, label %for.body, label %for.end
for.end:
ret void
diff --git a/llvm/test/Transforms/SimpleLoopUnswitch/preserve-analyses.ll b/llvm/test/Transforms/SimpleLoopUnswitch/preserve-analyses.ll
index d4544ba6f4a29a..7230bc75b012fb 100644
--- a/llvm/test/Transforms/SimpleLoopUnswitch/preserve-analyses.ll
+++ b/llvm/test/Transforms/SimpleLoopUnswitch/preserve-analyses.ll
@@ -74,13 +74,13 @@ bb10: ; preds = %bb8, %bb
; This is a simplified form of ineqn from above. It triggers some
; different cases in the loop-unswitch code.
-define void @simplified_ineqn() nounwind readonly {
+define void @simplified_ineqn(i1 %arg) nounwind readonly {
entry:
br label %bb8.outer
bb8.outer: ; preds = %bb6, %bb2, %entry
%x = phi i32 [ 0, %entry ], [ 0, %bb6 ], [ 1, %bb2 ] ; <i32> [#uses=1]
- br i1 undef, label %return, label %bb2
+ br i1 %arg, label %return, label %bb2
bb2: ; preds = %bb
switch i32 %x, label %bb6 [
@@ -88,7 +88,7 @@ bb2: ; preds = %bb
]
bb6: ; preds = %bb2
- br i1 undef, label %bb8.outer, label %bb2
+ br i1 %arg, label %bb8.outer, label %bb2
return: ; preds = %bb8, %bb
ret void
@@ -97,17 +97,17 @@ return: ; preds = %bb8, %bb
; This function requires special handling to preserve LCSSA form.
; PR4934
-define void @pnp_check_irq() nounwind noredzone {
+define void @pnp_check_irq(i1 %arg) nounwind noredzone {
entry:
%conv56 = trunc i64 undef to i32 ; <i32> [#uses=1]
br label %while.cond.i
while.cond.i: ; preds = %while.cond.i.backedge, %entry
%call.i25 = call ptr @pci_get_device() nounwind noredzone ; <ptr> [#uses=2]
- br i1 undef, label %if.then65, label %while.body.i
+ br i1 %arg, label %if.then65, label %while.body.i
while.body.i: ; preds = %while.cond.i
- br i1 undef, label %if.then31.i.i, label %while.cond.i.backedge
+ br i1 %arg, label %if.then31.i.i, label %while.cond.i.backedge
while.cond.i.backedge: ; preds = %if.then31.i.i, %while.body.i
br label %while.cond.i
>From 5cd1e1e5a192ae67cf003855829545986df2324f Mon Sep 17 00:00:00 2001
From: Lee <lee10202013 at gmail.com>
Date: Mon, 2 Dec 2024 20:18:53 -0700
Subject: [PATCH 07/10] Remove br i1 undef in SimplifyCFG directory
---
.../2004-12-10-SimplifyCFGCrash.ll | 20 ++++++------
.../SimplifyCFG/2006-06-12-InfLoop.ll | 32 +++++++++----------
.../Transforms/SimplifyCFG/branch-on-undef.ll | 6 ++--
.../SimplifyCFG/fold-branch-to-common-dest.ll | 4 +--
llvm/test/Transforms/SimplifyCFG/pr34131.ll | 22 ++++++-------
5 files changed, 42 insertions(+), 42 deletions(-)
diff --git a/llvm/test/Transforms/SimplifyCFG/2004-12-10-SimplifyCFGCrash.ll b/llvm/test/Transforms/SimplifyCFG/2004-12-10-SimplifyCFGCrash.ll
index dbd8f7ab862d0d..0656811b39a9ea 100644
--- a/llvm/test/Transforms/SimplifyCFG/2004-12-10-SimplifyCFGCrash.ll
+++ b/llvm/test/Transforms/SimplifyCFG/2004-12-10-SimplifyCFGCrash.ll
@@ -1,36 +1,36 @@
; RUN: opt < %s -passes=simplifycfg -simplifycfg-require-and-preserve-domtree=1 -disable-output
-define void @symhash_add() {
+define void @symhash_add(i1 %arg) {
entry:
- br i1 undef, label %then.0, label %UnifiedReturnBlock
+ br i1 %arg, label %then.0, label %UnifiedReturnBlock
then.0: ; preds = %entry
- br i1 undef, label %loopentry.2, label %loopentry.1.preheader
+ br i1 %arg, label %loopentry.2, label %loopentry.1.preheader
loopentry.1.preheader: ; preds = %then.0
br label %loopentry.1.outer
loopentry.1.outer: ; preds = %loopexit.1, %loopentry.1.preheader
br label %loopentry.1
loopentry.1: ; preds = %endif.1, %then.4, %then.3, %then.1, %loopentry.1.outer
- br i1 undef, label %loopexit.1, label %no_exit.1
+ br i1 %arg, label %loopexit.1, label %no_exit.1
no_exit.1: ; preds = %loopentry.1
- br i1 undef, label %then.1, label %else.0
+ br i1 %arg, label %then.1, label %else.0
then.1: ; preds = %no_exit.1
br label %loopentry.1
else.0: ; preds = %no_exit.1
- br i1 undef, label %then.2, label %else.1
+ br i1 %arg, label %then.2, label %else.1
then.2: ; preds = %else.0
- br i1 undef, label %then.3, label %endif.1
+ br i1 %arg, label %then.3, label %endif.1
then.3: ; preds = %then.2
br label %loopentry.1
else.1: ; preds = %else.0
- br i1 undef, label %endif.1, label %then.4
+ br i1 %arg, label %endif.1, label %then.4
then.4: ; preds = %else.1
br label %loopentry.1
endif.1: ; preds = %else.1, %then.2
br label %loopentry.1
loopexit.1: ; preds = %loopentry.1
- br i1 undef, label %loopentry.1.outer, label %loopentry.2
+ br i1 %arg, label %loopentry.1.outer, label %loopentry.2
loopentry.2: ; preds = %no_exit.2, %loopexit.1, %then.0
- br i1 undef, label %loopexit.2, label %no_exit.2
+ br i1 %arg, label %loopexit.2, label %no_exit.2
no_exit.2: ; preds = %loopentry.2
br label %loopentry.2
loopexit.2: ; preds = %loopentry.2
diff --git a/llvm/test/Transforms/SimplifyCFG/2006-06-12-InfLoop.ll b/llvm/test/Transforms/SimplifyCFG/2006-06-12-InfLoop.ll
index 0ec88ed071fc2f..20c03e05ba0b97 100644
--- a/llvm/test/Transforms/SimplifyCFG/2006-06-12-InfLoop.ll
+++ b/llvm/test/Transforms/SimplifyCFG/2006-06-12-InfLoop.ll
@@ -1,7 +1,7 @@
; RUN: opt < %s -passes=simplifycfg -simplifycfg-require-and-preserve-domtree=1 -disable-output
; END.
-define void @main(i32 %c) {
+define void @main(i32 %c, i1 %arg) {
entry:
%tmp.9 = icmp eq i32 %c, 2 ; <i1> [#uses=1]
br i1 %tmp.9, label %endif.0, label %then.0
@@ -186,7 +186,7 @@ no_exit.0.i31.preheader: ; preds = %loopentry.1.i30
no_exit.0.i31: ; preds = %loopexit.3.i, %no_exit.0.i31.preheader
br i1 false, label %then.1.i, label %else.0.i
then.1.i: ; preds = %no_exit.0.i31
- br i1 undef, label %then.0.i29, label %loopentry.0.i31
+ br i1 %arg, label %then.0.i29, label %loopentry.0.i31
then.0.i29: ; preds = %then.1.i
unreachable
loopentry.0.i31: ; preds = %then.1.i
@@ -194,13 +194,13 @@ loopentry.0.i31: ; preds = %then.1.i
no_exit.0.i38.preheader: ; preds = %loopentry.0.i31
br label %no_exit.0.i38
no_exit.0.i38: ; preds = %no_exit.0.i38, %no_exit.0.i38.preheader
- br i1 undef, label %no_exit.0.i38, label %loopentry.1.i.preheader.loopexit
+ br i1 %arg, label %no_exit.0.i38, label %loopentry.1.i.preheader.loopexit
loopentry.1.i.preheader.loopexit: ; preds = %no_exit.0.i38
br label %loopentry.1.i.preheader
loopentry.1.i.preheader: ; preds = %loopentry.1.i.preheader.loopexit, %loopentry.0.i31
br label %loopentry.1.i
loopentry.1.i: ; preds = %endif.2.i, %loopentry.1.i.preheader
- br i1 undef, label %loopentry.2.i39.preheader, label %loopexit.1.i79.loopexit2
+ br i1 %arg, label %loopentry.2.i39.preheader, label %loopexit.1.i79.loopexit2
loopentry.2.i39.preheader: ; preds = %loopentry.1.i
br label %loopentry.2.i39
loopentry.2.i39: ; preds = %loopexit.5.i77, %loopentry.2.i39.preheader
@@ -212,45 +212,45 @@ loopentry.3.i40: ; preds = %loopexit.3.i51, %loopentry.3.i40.preheader
no_exit.3.preheader.i42: ; preds = %loopentry.3.i40
br label %no_exit.3.i49
no_exit.3.i49: ; preds = %no_exit.3.i49, %no_exit.3.preheader.i42
- br i1 undef, label %no_exit.3.i49, label %loopexit.3.i51.loopexit
+ br i1 %arg, label %no_exit.3.i49, label %loopexit.3.i51.loopexit
loopexit.3.i51.loopexit: ; preds = %no_exit.3.i49
br label %loopexit.3.i51
loopexit.3.i51: ; preds = %loopexit.3.i51.loopexit, %loopentry.3.i40
- br i1 undef, label %loopentry.3.i40, label %loopentry.4.i52
+ br i1 %arg, label %loopentry.3.i40, label %loopentry.4.i52
loopentry.4.i52: ; preds = %loopexit.3.i51
br i1 false, label %no_exit.4.i54.preheader, label %hamming.exit.i71
no_exit.4.i54.preheader: ; preds = %loopentry.4.i52
br label %no_exit.4.i54
no_exit.4.i54: ; preds = %no_exit.4.backedge.i, %no_exit.4.i54.preheader
- br i1 undef, label %then.1.i55, label %endif.1.i56
+ br i1 %arg, label %then.1.i55, label %endif.1.i56
then.1.i55: ; preds = %no_exit.4.i54
- br i1 undef, label %no_exit.4.backedge.i, label %loopexit.4.i57
+ br i1 %arg, label %no_exit.4.backedge.i, label %loopexit.4.i57
no_exit.4.backedge.i: ; preds = %endif.1.i56, %then.1.i55
br label %no_exit.4.i54
endif.1.i56: ; preds = %no_exit.4.i54
- br i1 undef, label %no_exit.4.backedge.i, label %loopexit.4.i57
+ br i1 %arg, label %no_exit.4.backedge.i, label %loopexit.4.i57
loopexit.4.i57: ; preds = %endif.1.i56, %then.1.i55
br i1 false, label %no_exit.i.i69.preheader, label %hamming.exit.i71
no_exit.i.i69.preheader: ; preds = %loopexit.4.i57
br label %no_exit.i.i69
no_exit.i.i69: ; preds = %no_exit.i.i69, %no_exit.i.i69.preheader
- br i1 undef, label %no_exit.i.i69, label %hamming.exit.i71.loopexit
+ br i1 %arg, label %no_exit.i.i69, label %hamming.exit.i71.loopexit
hamming.exit.i71.loopexit: ; preds = %no_exit.i.i69
br label %hamming.exit.i71
hamming.exit.i71: ; preds = %hamming.exit.i71.loopexit, %loopexit.4.i57, %loopentry.4.i52, %loopentry.2.i39
- br i1 undef, label %endif.2.i, label %loopentry.5.i72
+ br i1 %arg, label %endif.2.i, label %loopentry.5.i72
loopentry.5.i72: ; preds = %hamming.exit.i71
br i1 false, label %shortcirc_next.i74.preheader, label %loopexit.5.i77
shortcirc_next.i74.preheader: ; preds = %loopentry.5.i72
br label %shortcirc_next.i74
shortcirc_next.i74: ; preds = %no_exit.5.i76, %shortcirc_next.i74.preheader
- br i1 undef, label %no_exit.5.i76, label %loopexit.5.i77.loopexit
+ br i1 %arg, label %no_exit.5.i76, label %loopexit.5.i77.loopexit
no_exit.5.i76: ; preds = %shortcirc_next.i74
- br i1 undef, label %shortcirc_next.i74, label %loopexit.5.i77.loopexit
+ br i1 %arg, label %shortcirc_next.i74, label %loopexit.5.i77.loopexit
loopexit.5.i77.loopexit: ; preds = %no_exit.5.i76, %shortcirc_next.i74
br label %loopexit.5.i77
loopexit.5.i77: ; preds = %loopexit.5.i77.loopexit, %loopentry.5.i72
- br i1 undef, label %loopentry.2.i39, label %loopexit.1.i79.loopexit
+ br i1 %arg, label %loopentry.2.i39, label %loopexit.1.i79.loopexit
endif.2.i: ; preds = %hamming.exit.i71
br label %loopentry.1.i
loopexit.1.i79.loopexit: ; preds = %loopexit.5.i77
@@ -258,7 +258,7 @@ loopexit.1.i79.loopexit: ; preds = %loopexit.5.i77
loopexit.1.i79.loopexit2: ; preds = %loopentry.1.i
br label %loopexit.1.i79
loopexit.1.i79: ; preds = %loopexit.1.i79.loopexit2, %loopexit.1.i79.loopexit
- br i1 undef, label %then.3.i, label %loopentry.6.i80
+ br i1 %arg, label %then.3.i, label %loopentry.6.i80
then.3.i: ; preds = %loopexit.1.i79
br i1 false, label %no_exit.6.i82.preheader, label %run.exit
loopentry.6.i80: ; preds = %loopexit.1.i79
@@ -266,7 +266,7 @@ loopentry.6.i80: ; preds = %loopexit.1.i79
no_exit.6.i82.preheader: ; preds = %loopentry.6.i80, %then.3.i
br label %no_exit.6.i82
no_exit.6.i82: ; preds = %no_exit.6.i82, %no_exit.6.i82.preheader
- br i1 undef, label %no_exit.6.i82, label %run.exit.loopexit
+ br i1 %arg, label %no_exit.6.i82, label %run.exit.loopexit
run.exit.loopexit: ; preds = %no_exit.6.i82
br label %run.exit
run.exit: ; preds = %run.exit.loopexit, %loopentry.6.i80, %then.3.i
diff --git a/llvm/test/Transforms/SimplifyCFG/branch-on-undef.ll b/llvm/test/Transforms/SimplifyCFG/branch-on-undef.ll
index bc42ae60730a7a..582a38f4af12fb 100644
--- a/llvm/test/Transforms/SimplifyCFG/branch-on-undef.ll
+++ b/llvm/test/Transforms/SimplifyCFG/branch-on-undef.ll
@@ -3,10 +3,10 @@
declare void @foo(i32)
-define void @br_undef_simple() {
+define void @br_undef_simple(i1 %arg) {
; CHECK-LABEL: @br_undef_simple(
; CHECK-NEXT: call void @foo(i32 0)
-; CHECK-NEXT: br i1 undef, label [[IF:%.*]], label [[ELSE:%.*]]
+; CHECK-NEXT: br i1 %arg, label [[IF:%.*]], label [[ELSE:%.*]]
; CHECK: common.ret:
; CHECK-NEXT: ret void
; CHECK: if:
@@ -17,7 +17,7 @@ define void @br_undef_simple() {
; CHECK-NEXT: br label [[COMMON_RET]]
;
call void @foo(i32 0)
- br i1 undef, label %if, label %else
+ br i1 %arg, label %if, label %else
if:
call void @foo(i32 1)
diff --git a/llvm/test/Transforms/SimplifyCFG/fold-branch-to-common-dest.ll b/llvm/test/Transforms/SimplifyCFG/fold-branch-to-common-dest.ll
index bd63e6658c9a61..9fb5164d44d459 100644
--- a/llvm/test/Transforms/SimplifyCFG/fold-branch-to-common-dest.ll
+++ b/llvm/test/Transforms/SimplifyCFG/fold-branch-to-common-dest.ll
@@ -939,7 +939,7 @@ if.end.loopexit:
}
@f.b = external global i8, align 1
-define void @pr48450_3() {
+define void @pr48450_3(i1 %arg) {
; CHECK-LABEL: @pr48450_3(
; CHECK-NEXT: entry:
; CHECK-NEXT: br label [[FOR_COND1:%.*]]
@@ -979,7 +979,7 @@ for.cond.cleanup:
br label %cleanup
for.body4:
- br i1 undef, label %if.then6, label %if.end7
+ br i1 %arg, label %if.then6, label %if.end7
if.then6:
br label %cleanup
diff --git a/llvm/test/Transforms/SimplifyCFG/pr34131.ll b/llvm/test/Transforms/SimplifyCFG/pr34131.ll
index 89415cc88aeb1c..ed37a969aa47fa 100644
--- a/llvm/test/Transforms/SimplifyCFG/pr34131.ll
+++ b/llvm/test/Transforms/SimplifyCFG/pr34131.ll
@@ -4,7 +4,7 @@
; Earlier version using auto-generated checks from utils/update_test_checks.py
; had bot problems though...
-define void @patatino() {
+define void @patatino(i1 %arg) {
; CHECK-LABEL: @patatino
@@ -12,16 +12,16 @@ define void @patatino() {
bb1: ; preds = %bb36, %0
br label %bb2
bb2: ; preds = %bb3, %bb1
- br i1 undef, label %bb4, label %bb3
+ br i1 %arg, label %bb4, label %bb3
bb3: ; preds = %bb4, %bb2
- br i1 undef, label %bb2, label %bb5
+ br i1 %arg, label %bb2, label %bb5
bb4: ; preds = %bb2
switch i32 undef, label %bb3 [
]
bb5: ; preds = %bb3
br label %bb6
bb6: ; preds = %bb5
- br i1 undef, label %bb7, label %bb9
+ br i1 %arg, label %bb7, label %bb9
bb7: ; preds = %bb6
%tmp = or i64 undef, 1
%tmp8 = icmp ult i64 %tmp, 0
@@ -58,17 +58,17 @@ bb27: ; preds = %bb24
%tmp29 = icmp ult i64 %tmp28, 0
br i1 %tmp29, label %bb30, label %bb9
bb30: ; preds = %bb27
- br i1 undef, label %bb31, label %bb9
+ br i1 %arg, label %bb31, label %bb9
bb31: ; preds = %bb30
- br i1 undef, label %bb32, label %bb9
+ br i1 %arg, label %bb32, label %bb9
bb32: ; preds = %bb31
- br i1 undef, label %bb33, label %bb9
+ br i1 %arg, label %bb33, label %bb9
bb33: ; preds = %bb32
- br i1 undef, label %bb34, label %bb9
+ br i1 %arg, label %bb34, label %bb9
bb34: ; preds = %bb33
- br i1 undef, label %bb35, label %bb9
+ br i1 %arg, label %bb35, label %bb9
bb35: ; preds = %bb34
- br i1 undef, label %bb36, label %bb9
+ br i1 %arg, label %bb36, label %bb9
bb36: ; preds = %bb35
- br i1 undef, label %bb1, label %bb10
+ br i1 %arg, label %bb1, label %bb10
}
>From 71ffa902b66e56d6277e03d3de2f0107351251fe Mon Sep 17 00:00:00 2001
From: Lee <lee10202013 at gmail.com>
Date: Mon, 2 Dec 2024 20:28:54 -0700
Subject: [PATCH 08/10] Remove br i1 undef in remaining Transforms directory
---
llvm/test/Transforms/Sink/dead-user.ll | 27 +++++++++--------
.../SpeculativeExecution/PR46267.ll | 4 +--
.../StructurizeCFG/loop-continue-phi.ll | 29 ++++++++++---------
3 files changed, 30 insertions(+), 30 deletions(-)
diff --git a/llvm/test/Transforms/Sink/dead-user.ll b/llvm/test/Transforms/Sink/dead-user.ll
index 91e61b43ca3912..23e1b266adaf14 100644
--- a/llvm/test/Transforms/Sink/dead-user.ll
+++ b/llvm/test/Transforms/Sink/dead-user.ll
@@ -1,28 +1,27 @@
-; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 3
+; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: -p --version 3
; Compiler should not be broken with a dead user.
; RUN: opt -passes=sink -S < %s | FileCheck %s
-define void @test(i16 %p1) {
-; CHECK-LABEL: define void @test(
-; CHECK-SAME: i16 [[P1:%.*]]) {
+define void @test(i16 %p1, i1 %arg) {
+; CHECK-LABEL: define void @test(i16 %p1, i1 %arg) {
; CHECK-NEXT: bb.0:
-; CHECK-NEXT: [[CONV:%.*]] = sext i16 [[P1]] to i32
-; CHECK-NEXT: br i1 undef, label [[BB_1:%.*]], label [[BB_3:%.*]]
+; CHECK-NEXT: %conv = sext i16 %p1 to i32
+; CHECK-NEXT: br i1 %arg, label %bb.1, label %bb.3
; CHECK: bb.1:
-; CHECK-NEXT: br label [[BB_2:%.*]]
+; CHECK-NEXT: br label %bb.2
; CHECK: bb.2:
-; CHECK-NEXT: [[AND_2:%.*]] = and i32 undef, [[CONV]]
-; CHECK-NEXT: br label [[BB_2]]
+; CHECK-NEXT: %and.2 = and i32 undef, %conv
+; CHECK-NEXT: br label %bb.2
; CHECK: bb.3:
-; CHECK-NEXT: [[AND_3:%.*]] = and i32 undef, [[CONV]]
-; CHECK-NEXT: br label [[BB_3]]
+; CHECK-NEXT: %and.3 = and i32 undef, %conv
+; CHECK-NEXT: br label %bb.3
; CHECK: dead:
-; CHECK-NEXT: [[AND_DEAD:%.*]] = and i32 undef, [[CONV]]
-; CHECK-NEXT: br label [[DEAD:%.*]]
+; CHECK-NEXT: %and.dead = and i32 undef, %conv
+; CHECK-NEXT: br label %dead
;
bb.0:
%conv = sext i16 %p1 to i32
- br i1 undef, label %bb.1, label %bb.3
+ br i1 %arg, label %bb.1, label %bb.3
bb.1: ; preds = %bb.0
br label %bb.2
diff --git a/llvm/test/Transforms/SpeculativeExecution/PR46267.ll b/llvm/test/Transforms/SpeculativeExecution/PR46267.ll
index 8f82a16639744d..5ee9fda470d1e7 100644
--- a/llvm/test/Transforms/SpeculativeExecution/PR46267.ll
+++ b/llvm/test/Transforms/SpeculativeExecution/PR46267.ll
@@ -27,11 +27,11 @@ end: ; preds = %notnull, %entry
ret ptr %i6
}
-define void @f(i32 %i) {
+define void @f(i32 %i, i1 %arg) {
entry:
; CHECK-LABEL: @f(
; CHECK: %a2 = add i32 %i, 0
- br i1 undef, label %land.rhs, label %land.end
+ br i1 %arg, label %land.rhs, label %land.end
land.rhs: ; preds = %entry
; CHECK: land.rhs:
diff --git a/llvm/test/Transforms/StructurizeCFG/loop-continue-phi.ll b/llvm/test/Transforms/StructurizeCFG/loop-continue-phi.ll
index 364eb161e298aa..a151d509be019f 100644
--- a/llvm/test/Transforms/StructurizeCFG/loop-continue-phi.ll
+++ b/llvm/test/Transforms/StructurizeCFG/loop-continue-phi.ll
@@ -1,24 +1,25 @@
-; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
+; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: -p
; RUN: opt -S -o - -structurizecfg < %s | FileCheck %s
-define void @test1() {
+define void @test1(i1 %arg) {
; CHECK-LABEL: @test1(
; CHECK-NEXT: entry:
-; CHECK-NEXT: br label [[LOOP:%.*]]
+; CHECK-NEXT: %arg.inv = xor i1 %arg, true
+; CHECK-NEXT: br label %loop
; CHECK: Flow:
-; CHECK-NEXT: br label [[FLOW1:%.*]]
+; CHECK-NEXT: br label %Flow1
; CHECK: loop:
-; CHECK-NEXT: [[CTR:%.*]] = phi i32 [ 0, [[ENTRY:%.*]] ], [ [[TMP0:%.*]], [[FLOW1]] ]
-; CHECK-NEXT: [[CTR_NEXT:%.*]] = add i32 [[CTR]], 1
-; CHECK-NEXT: br i1 undef, label [[LOOP_A:%.*]], label [[FLOW1]]
+; CHECK-NEXT: %ctr = phi i32 [ 0, %entry ], [ %0, %Flow1 ]
+; CHECK-NEXT: %ctr.next = add i32 %ctr, 1
+; CHECK-NEXT: br i1 %arg.inv, label %loop.a, label %Flow1
; CHECK: loop.a:
-; CHECK-NEXT: br i1 undef, label [[LOOP_B:%.*]], label [[FLOW:%.*]]
+; CHECK-NEXT: br i1 %arg.inv, label %loop.b, label %Flow
; CHECK: loop.b:
-; CHECK-NEXT: br label [[FLOW]]
+; CHECK-NEXT: br label %Flow
; CHECK: Flow1:
-; CHECK-NEXT: [[TMP0]] = phi i32 [ [[CTR_NEXT]], [[FLOW]] ], [ undef, [[LOOP]] ]
-; CHECK-NEXT: [[TMP1:%.*]] = phi i1 [ false, [[FLOW]] ], [ true, [[LOOP]] ]
-; CHECK-NEXT: br i1 [[TMP1]], label [[EXIT:%.*]], label [[LOOP]]
+; CHECK-NEXT: %0 = phi i32 [ %ctr.next, %Flow ], [ undef, %loop ]
+; CHECK-NEXT: %1 = phi i1 [ false, %Flow ], [ true, %loop ]
+; CHECK-NEXT: br i1 %1, label %exit, label %loop
; CHECK: exit:
; CHECK-NEXT: ret void
;
@@ -28,10 +29,10 @@ entry:
loop:
%ctr = phi i32 [ 0, %entry ], [ %ctr.next, %loop.a ], [ %ctr.next, %loop.b ]
%ctr.next = add i32 %ctr, 1
- br i1 undef, label %exit, label %loop.a
+ br i1 %arg, label %exit, label %loop.a
loop.a:
- br i1 undef, label %loop, label %loop.b
+ br i1 %arg, label %loop, label %loop.b
loop.b:
br label %loop
>From fff79ffacebbaa9a8ecd3cd3200b699eb1c8513c Mon Sep 17 00:00:00 2001
From: Lee <lee10202013 at gmail.com>
Date: Mon, 2 Dec 2024 20:48:05 -0700
Subject: [PATCH 09/10] Remove unused arguments
---
llvm/test/Transforms/SCCP/switch-constantfold-crash.ll | 10 ++++------
.../SimpleLoopUnswitch/delete-dead-blocks.ll | 2 +-
llvm/test/Transforms/Sink/dead-user.ll | 2 +-
.../Transforms/StructurizeCFG/loop-continue-phi.ll | 2 +-
4 files changed, 7 insertions(+), 9 deletions(-)
diff --git a/llvm/test/Transforms/SCCP/switch-constantfold-crash.ll b/llvm/test/Transforms/SCCP/switch-constantfold-crash.ll
index b163d2c078ef69..73eef205adae75 100644
--- a/llvm/test/Transforms/SCCP/switch-constantfold-crash.ll
+++ b/llvm/test/Transforms/SCCP/switch-constantfold-crash.ll
@@ -2,9 +2,8 @@
; RUN: opt -passes=ipsccp < %s -S | FileCheck %s
; RUN: opt -passes='ipsccp,ipsccp' < %s -S | FileCheck %s
-define void @barney(i1 %arg) {
-; CHECK-LABEL: define {{[^@]+}}@barney
-; CHECK-SAME: (i1 [[ARG:%.*]]) {
+define void @barney() {
+; CHECK-LABEL: define {{[^@]+}}@barney() {
; CHECK-NEXT: bb:
; CHECK-NEXT: br label [[BB9:%.*]]
; CHECK: bb6:
@@ -27,9 +26,8 @@ bb9: ; preds = %bb
]
}
-define void @blam(i1 %arg) {
-; CHECK-LABEL: define {{[^@]+}}@blam
-; CHECK-SAME: (i1 [[ARG:%.*]]) {
+define void @blam() {
+; CHECK-LABEL: define {{[^@]+}}@blam() {
; CHECK-NEXT: bb:
; CHECK-NEXT: br label [[BB16:%.*]]
; CHECK: bb16:
diff --git a/llvm/test/Transforms/SimpleLoopUnswitch/delete-dead-blocks.ll b/llvm/test/Transforms/SimpleLoopUnswitch/delete-dead-blocks.ll
index e66c7ace18fc05..c120eeb440d193 100644
--- a/llvm/test/Transforms/SimpleLoopUnswitch/delete-dead-blocks.ll
+++ b/llvm/test/Transforms/SimpleLoopUnswitch/delete-dead-blocks.ll
@@ -6,7 +6,7 @@
declare void @foo()
; CHECK-LABEL: @Test
-define void @Test(i32, i1 %arg) {
+define void @Test(i32) {
entry:
br label %outer
outer:
diff --git a/llvm/test/Transforms/Sink/dead-user.ll b/llvm/test/Transforms/Sink/dead-user.ll
index 23e1b266adaf14..e63aa027a2db81 100644
--- a/llvm/test/Transforms/Sink/dead-user.ll
+++ b/llvm/test/Transforms/Sink/dead-user.ll
@@ -1,4 +1,4 @@
-; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: -p --version 3
+; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 3
; Compiler should not be broken with a dead user.
; RUN: opt -passes=sink -S < %s | FileCheck %s
diff --git a/llvm/test/Transforms/StructurizeCFG/loop-continue-phi.ll b/llvm/test/Transforms/StructurizeCFG/loop-continue-phi.ll
index a151d509be019f..eec67e67b540dc 100644
--- a/llvm/test/Transforms/StructurizeCFG/loop-continue-phi.ll
+++ b/llvm/test/Transforms/StructurizeCFG/loop-continue-phi.ll
@@ -1,4 +1,4 @@
-; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: -p
+; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
; RUN: opt -S -o - -structurizecfg < %s | FileCheck %s
define void @test1(i1 %arg) {
>From 6eec7f5bb25b34becfd75429b81171efb6958586 Mon Sep 17 00:00:00 2001
From: Lee <lee10202013 at gmail.com>
Date: Tue, 3 Dec 2024 11:27:15 -0700
Subject: [PATCH 10/10] Revert changes and replace undef with poison
---
.../SCCP/2004-12-10-UndefBranchBug.ll | 11 +++---
llvm/test/Transforms/SCCP/return-zapped.ll | 32 ++++++++---------
...fter-each-resolving-undefs-for-function.ll | 34 ++++++++-----------
3 files changed, 35 insertions(+), 42 deletions(-)
diff --git a/llvm/test/Transforms/SCCP/2004-12-10-UndefBranchBug.ll b/llvm/test/Transforms/SCCP/2004-12-10-UndefBranchBug.ll
index e84ac516b9f50c..974c2dac78ebf6 100644
--- a/llvm/test/Transforms/SCCP/2004-12-10-UndefBranchBug.ll
+++ b/llvm/test/Transforms/SCCP/2004-12-10-UndefBranchBug.ll
@@ -1,13 +1,14 @@
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
; RUN: opt < %s -passes=sccp -S | FileCheck %s
-define i32 @foo(i1 %arg) {
+; Branch on poison is UB, so the T block is never executed, and we can return
+; undef (IPSCCP would replace the block with unreachable).
+
+define i32 @foo() {
; CHECK-LABEL: @foo(
-; CHECK-NEXT: br i1 [[ARG:%.*]], label [[T:%.*]], label [[T]]
-; CHECK: T:
-; CHECK-NEXT: ret i32 1
+; CHECK-NEXT: unreachable
;
- br i1 %arg, label %T, label %T
+ br i1 poison, label %T, label %T
T:
%X = add i32 0, 1
ret i32 %X
diff --git a/llvm/test/Transforms/SCCP/return-zapped.ll b/llvm/test/Transforms/SCCP/return-zapped.ll
index 2b0a7942943c8f..cafc8aa69e8684 100644
--- a/llvm/test/Transforms/SCCP/return-zapped.ll
+++ b/llvm/test/Transforms/SCCP/return-zapped.ll
@@ -1,41 +1,37 @@
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --function-signature
; RUN: opt < %s -S -passes=ipsccp | FileCheck %s
-define void @test1(i1 %arg) {
-; CHECK-LABEL: define {{[^@]+}}@test1
-; CHECK-SAME: (i1 [[ARG:%.*]]) {
+; testf() performs an unconditional branch on poison, as such the testf() return
+; value used in test1() will remain "unknown" and the following branch on it
+; replaced by unreachable. This is fine, as the call to testf() will already
+; trigger undefined behavior.
+define void @test1() {
+; CHECK-LABEL: define {{[^@]+}}@test1() {
; CHECK-NEXT: entry:
; CHECK-NEXT: br label [[IF_THEN:%.*]]
; CHECK: if.then:
-; CHECK-NEXT: [[CALL:%.*]] = call i1 @testf(i1 [[ARG]])
-; CHECK-NEXT: br label [[IF_END:%.*]]
-; CHECK: if.end:
-; CHECK-NEXT: ret void
+; CHECK-NEXT: [[CALL:%.*]] = call i1 @testf()
+; CHECK-NEXT: unreachable
;
entry:
br label %if.then
if.then: ; preds = %entry, %if.then
%foo = phi i32 [ 0, %entry], [ %next, %if.then]
%next = add i32 %foo, 1
- %call = call i1 @testf(i1 %arg)
+ %call = call i1 @testf()
br i1 %call, label %if.end, label %if.then
if.end: ; preds = %if.then, %entry
ret void
}
-define internal i1 @testf(i1 %arg) {
-; CHECK-LABEL: define {{[^@]+}}@testf
-; CHECK-SAME: (i1 [[ARG:%.*]]) {
+define internal i1 @testf() {
+; CHECK-LABEL: define {{[^@]+}}@testf() {
; CHECK-NEXT: entry:
-; CHECK-NEXT: br i1 [[ARG]], label [[IF_THEN1:%.*]], label [[IF_END3:%.*]]
-; CHECK: if.then1:
-; CHECK-NEXT: br label [[IF_END3]]
-; CHECK: if.end3:
-; CHECK-NEXT: ret i1 true
+; CHECK-NEXT: unreachable
;
entry:
- br i1 %arg, label %if.then1, label %if.end3
+ br i1 poison, label %if.then1, label %if.end3
if.then1: ; preds = %if.end
br label %if.end3
@@ -51,7 +47,7 @@ define i1 @test2() {
; CHECK-NEXT: br label [[IF_END:%.*]]
; CHECK: if.end:
; CHECK-NEXT: [[CALL2:%.*]] = call i1 @testf()
-; CHECK-NEXT: ret i1 [[CALL2]]
+; CHECK-NEXT: ret i1 undef
;
entry:
br label %if.end
diff --git a/llvm/test/Transforms/SCCP/solve-after-each-resolving-undefs-for-function.ll b/llvm/test/Transforms/SCCP/solve-after-each-resolving-undefs-for-function.ll
index e3048b2a6ac7f0..a4b1ba8a0c8dd0 100644
--- a/llvm/test/Transforms/SCCP/solve-after-each-resolving-undefs-for-function.ll
+++ b/llvm/test/Transforms/SCCP/solve-after-each-resolving-undefs-for-function.ll
@@ -1,23 +1,22 @@
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 5
; RUN: opt < %s -passes=ipsccp -S | FileCheck %s
-define internal i32 @testf(i1 %c, i1 %arg) {
-; CHECK-LABEL: define internal range(i32 10, 12) i32 @testf(
-; CHECK-SAME: i1 [[C:%.*]], i1 [[ARG:%.*]]) {
+;
+define internal i32 @testf(i1 %c) {
+; CHECK-LABEL: define internal i32 @testf(
+; CHECK-SAME: i1 [[C:%.*]]) {
; CHECK-NEXT: [[ENTRY:.*:]]
; CHECK-NEXT: br i1 [[C]], label %[[IF_COND:.*]], label %[[IF_END:.*]]
; CHECK: [[IF_COND]]:
-; CHECK-NEXT: br i1 [[ARG]], label %[[IF_THEN:.*]], label %[[IF_END]]
-; CHECK: [[IF_THEN]]:
-; CHECK-NEXT: ret i32 11
+; CHECK-NEXT: unreachable
; CHECK: [[IF_END]]:
-; CHECK-NEXT: ret i32 10
+; CHECK-NEXT: ret i32 poison
;
entry:
br i1 %c, label %if.cond, label %if.end
if.cond:
- br i1 %arg, label %if.then, label %if.end
+ br i1 poison, label %if.then, label %if.end
if.then: ; preds = %entry, %if.then
ret i32 11
@@ -27,25 +26,22 @@ if.end: ; preds = %if.then1, %entry
}
;
-define internal i32 @test1(i1 %c, i1 %arg) {
-; CHECK-LABEL: define internal range(i32 0, 100) i32 @test1(
-; CHECK-SAME: i1 [[C:%.*]], i1 [[ARG:%.*]]) {
+define internal i32 @test1(i1 %c) {
+; CHECK-LABEL: define internal i32 @test1(
+; CHECK-SAME: i1 [[C:%.*]]) {
; CHECK-NEXT: [[ENTRY:.*:]]
; CHECK-NEXT: br label %[[IF_THEN:.*]]
; CHECK: [[IF_THEN]]:
-; CHECK-NEXT: [[CALL:%.*]] = call i32 @testf(i1 [[C]], i1 [[ARG]])
-; CHECK-NEXT: [[RES:%.*]] = icmp eq i32 [[CALL]], 10
-; CHECK-NEXT: br i1 [[RES]], label %[[RET1:.*]], label %[[RET2:.*]]
+; CHECK-NEXT: [[CALL:%.*]] = call i32 @testf(i1 [[C]])
+; CHECK-NEXT: br label %[[RET1:.*]]
; CHECK: [[RET1]]:
-; CHECK-NEXT: ret i32 99
-; CHECK: [[RET2]]:
-; CHECK-NEXT: ret i32 0
+; CHECK-NEXT: ret i32 poison
;
entry:
br label %if.then
if.then: ; preds = %entry, %if.then
- %call = call i32 @testf(i1 %c, i1 %arg)
+ %call = call i32 @testf(i1 %c)
%res = icmp eq i32 %call, 10
br i1 %res, label %ret1, label %ret2
@@ -61,7 +57,7 @@ define i32 @main(i1 %c) {
; CHECK-LABEL: define i32 @main(
; CHECK-SAME: i1 [[C:%.*]]) {
; CHECK-NEXT: [[RES:%.*]] = call i32 @test1(i1 [[C]])
-; CHECK-NEXT: ret i32 [[RES]]
+; CHECK-NEXT: ret i32 99
;
%res = call i32 @test1(i1 %c)
ret i32 %res
More information about the llvm-commits
mailing list