Remove compares after replacing all uses. Cleaning dead compares can enable additional simplifications when adjusting the position of the pass slightly. In particular, it seems like the additional dead instructions may prevent SimplifyCFG performing some folds. Reviewed By: nikic Differential Revision: https://reviews.llvm.org/D158760
46 lines
1.3 KiB
LLVM
46 lines
1.3 KiB
LLVM
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
|
|
; RUN: opt -passes=constraint-elimination -S %s | FileCheck %s
|
|
|
|
declare void @may_unwind()
|
|
|
|
define i1 @test_switch_in_block_with_assume(i32 %x) {
|
|
; CHECK-LABEL: @test_switch_in_block_with_assume(
|
|
; CHECK-NEXT: entry:
|
|
; CHECK-NEXT: call void @may_unwind()
|
|
; CHECK-NEXT: [[C_1:%.*]] = icmp ult i32 [[X:%.*]], 10
|
|
; CHECK-NEXT: call void @llvm.assume(i1 [[C_1]])
|
|
; CHECK-NEXT: switch i32 0, label [[EXIT_1:%.*]] [
|
|
; CHECK-NEXT: i32 1, label [[EXIT_2:%.*]]
|
|
; CHECK-NEXT: ]
|
|
; CHECK: exit.1:
|
|
; CHECK-NEXT: [[C_2:%.*]] = icmp ult i32 [[X]], 9
|
|
; CHECK-NEXT: [[RES_1:%.*]] = xor i1 true, [[C_2]]
|
|
; CHECK-NEXT: ret i1 [[RES_1]]
|
|
; CHECK: exit.2:
|
|
; CHECK-NEXT: [[C_3:%.*]] = icmp ult i32 [[X]], 9
|
|
; CHECK-NEXT: [[RES_2:%.*]] = xor i1 true, [[C_3]]
|
|
; CHECK-NEXT: ret i1 [[RES_2]]
|
|
;
|
|
entry:
|
|
call void @may_unwind()
|
|
%c.1 = icmp ult i32 %x, 10
|
|
call void @llvm.assume(i1 %c.1)
|
|
switch i32 0, label %exit.1 [
|
|
i32 1, label %exit.2
|
|
]
|
|
|
|
exit.1:
|
|
%t.1 = icmp ult i32 %x, 10
|
|
%c.2 = icmp ult i32 %x, 9
|
|
%res.1 = xor i1 %t.1, %c.2
|
|
ret i1 %res.1
|
|
|
|
exit.2:
|
|
%t.2 = icmp ult i32 %x, 10
|
|
%c.3 = icmp ult i32 %x, 9
|
|
%res.2 = xor i1 %t.2, %c.3
|
|
ret i1 %res.2
|
|
}
|
|
|
|
declare void @llvm.assume(i1)
|