mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-11-02 22:23:10 +00:00
InstCombine: Combine select sequences into a single select
Normalize select(C0, select(C1, a, b), b) -> select((C0 & C1), a, b) select(C0, a, select(C1, a, b)) -> select((C0 | C1), a, b) This normal form may enable further combines on the And/Or and shortens paths for the values. Many targets prefer the other but can go back easily in CodeGen. Differential Revision: http://reviews.llvm.org/D7399 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@228409 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -1492,3 +1492,31 @@ entry:
|
||||
%v = load i128* %p
|
||||
ret i128 %v
|
||||
}
|
||||
|
||||
define i32 @test_select_select0(i32 %a, i32 %r0, i32 %r1, i32 %v1, i32 %v2) {
|
||||
; CHECK-LABEL: @test_select_select0(
|
||||
; CHECK: %[[C0:.*]] = icmp sge i32 %a, %v1
|
||||
; CHECK-NEXT: %[[C1:.*]] = icmp slt i32 %a, %v2
|
||||
; CHECK-NEXT: %[[C:.*]] = and i1 %[[C1]], %[[C0]]
|
||||
; CHECK-NEXT: %[[SEL:.*]] = select i1 %[[C]], i32 %r0, i32 %r1
|
||||
; CHECK-NEXT: ret i32 %[[SEL]]
|
||||
%c0 = icmp sge i32 %a, %v1
|
||||
%s0 = select i1 %c0, i32 %r0, i32 %r1
|
||||
%c1 = icmp slt i32 %a, %v2
|
||||
%s1 = select i1 %c1, i32 %s0, i32 %r1
|
||||
ret i32 %s1
|
||||
}
|
||||
|
||||
define i32 @test_select_select1(i32 %a, i32 %r0, i32 %r1, i32 %v1, i32 %v2) {
|
||||
; CHECK-LABEL: @test_select_select1(
|
||||
; CHECK: %[[C0:.*]] = icmp sge i32 %a, %v1
|
||||
; CHECK-NEXT: %[[C1:.*]] = icmp slt i32 %a, %v2
|
||||
; CHECK-NEXT: %[[C:.*]] = or i1 %[[C1]], %[[C0]]
|
||||
; CHECK-NEXT: %[[SEL:.*]] = select i1 %[[C]], i32 %r0, i32 %r1
|
||||
; CHECK-NEXT: ret i32 %[[SEL]]
|
||||
%c0 = icmp sge i32 %a, %v1
|
||||
%s0 = select i1 %c0, i32 %r0, i32 %r1
|
||||
%c1 = icmp slt i32 %a, %v2
|
||||
%s1 = select i1 %c1, i32 %r0, i32 %s0
|
||||
ret i32 %s1
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user