blob: b9b9a4b779b8ae27581c023ca27aaf21bd050957 [file] [log] [blame] [edit]
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5
; RUN: llc < %s -verify-machineinstrs -mtriple=s390x-linux-gnu -O2 | FileCheck %s
; Test implementation of combining select_ccmask for flag output operand and
; optimizing ipm sequence using conditional branches.
; Test-1(f2_0_*): Both TrueVal and FalseVal non-const(14-valid CCMask).
; Check (cc == 0).
define i64 @f2_0_eq_0(i64 %x, i64 %y, ptr %a) {
; CHECK-LABEL: f2_0_eq_0:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r4), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: ber %r14
; CHECK-NEXT: .LBB0_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%cmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %cmp)
%cond = icmp eq i32 %cc, 0
%res = select i1 %cond, i64 %x, i64 %y
ret i64 %res
}
; Check (cc != 0).
define i64 @f2_0_ne_0(i64 %x, i64 %y, ptr %a) {
; CHECK-LABEL: f2_0_ne_0:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r4), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: bner %r14
; CHECK-NEXT: .LBB1_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%cmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %cmp)
%cond = icmp ugt i32 %cc, 0
%res = select i1 %cond, i64 %x, i64 %y
ret i64 %res
}
; Check (cc == 1).
define i64 @f2_0_eq_1(i64 %x, i64 %y, ptr %a) {
; CHECK-LABEL: f2_0_eq_1:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r4), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: blr %r14
; CHECK-NEXT: .LBB2_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%cmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %cmp)
%cond = icmp eq i32 %cc, 1
%res = select i1 %cond, i64 %x, i64 %y
ret i64 %res
}
; Check (cc != 1).
define i64 @f2_0_ne_1(i64 %x, i64 %y, ptr %a) {
; CHECK-LABEL: f2_0_ne_1:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r4), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: bnlr %r14
; CHECK-NEXT: .LBB3_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%cmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %cmp)
%cond = icmp ne i32 %cc, 1
%res = select i1 %cond, i64 %x, i64 %y
ret i64 %res
}
; Check (cc == 2).
define i64 @f2_0_eq_2(i64 %x, i64 %y, ptr %a) {
; CHECK-LABEL: f2_0_eq_2:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r4), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: bhr %r14
; CHECK-NEXT: .LBB4_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%cmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %cmp)
%cond = icmp eq i32 %cc, 2
%res = select i1 %cond, i64 %x, i64 %y
ret i64 %res
}
; Check (cc != 2).
define i64 @f2_0_ne_2(i64 %x, i64 %y, ptr %a) {
; CHECK-LABEL: f2_0_ne_2:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r4), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: bnhr %r14
; CHECK-NEXT: .LBB5_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%cmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %cmp)
%cond = icmp ne i32 %cc, 2
%res = select i1 %cond, i64 %x, i64 %y
ret i64 %res
}
; Check (cc == 3).
define i64 @f2_0_eq_3(i64 %x, i64 %y, ptr %a) {
; CHECK-LABEL: f2_0_eq_3:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r4), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: bor %r14
; CHECK-NEXT: .LBB6_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%cmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %cmp)
%cond = icmp eq i32 %cc, 3
%res = select i1 %cond, i64 %x, i64 %y
ret i64 %res
}
; Check (cc != 3).
define i64 @f2_0_ne_3(i64 %x, i64 %y, ptr %a) {
; CHECK-LABEL: f2_0_ne_3:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r4), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: bnor %r14
; CHECK-NEXT: .LBB7_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%cmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %cmp)
%cond = icmp ult i32 %cc, 3
%res = select i1 %cond, i64 %x, i64 %y
ret i64 %res
}
; Check (cc == 0|1).
define i64 @f2_0_01(i64 %x, i64 %y, ptr %a) {
; CHECK-LABEL: f2_0_01:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r4), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: bler %r14
; CHECK-NEXT: .LBB8_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%cmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %cmp)
%cond = icmp ult i32 %cc, 2
%res = select i1 %cond, i64 %x, i64 %y
ret i64 %res
}
; Check (cc == 0|2).
define i64 @f2_0_02(i64 %x, i64 %y, ptr %a) {
; CHECK-LABEL: f2_0_02:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r4), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: bher %r14
; CHECK-NEXT: .LBB9_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%cmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %cmp)
%and = and i32 %cc, 1
%cond = icmp eq i32 %and, 0
%res = select i1 %cond, i64 %x, i64 %y
ret i64 %res
}
; Check (cc == 0|3).
define i64 @f2_0_03(i64 %y, i64 %x, ptr %a) {
; CHECK-LABEL: f2_0_03:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r4), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: blhr %r14
; CHECK-NEXT: .LBB10_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%cmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %cmp)
%cmp0 = icmp ne i32 %cc, 0
%cmp3 = icmp ne i32 %cc, 3
%cond.inv = and i1 %cmp0, %cmp3
%res = select i1 %cond.inv, i64 %y, i64 %x
ret i64 %res
}
; Check (cc == 1|2).
define i64 @f2_0_12(i64 %y, i64 %x, ptr %a) {
; CHECK-LABEL: f2_0_12:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r4), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: bnlhr %r14
; CHECK-NEXT: .LBB11_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%cmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %cmp)
%add = add nsw i32 %cc, -3
%cond.inv = icmp ult i32 %add, -2
%res = select i1 %cond.inv, i64 %y, i64 %x
ret i64 %res
}
; Check (cc == 1|3).
define i64 @f2_0_13(i64 %y, i64 %x, ptr %a) {
; CHECK-LABEL: f2_0_13:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r4), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: bher %r14
; CHECK-NEXT: .LBB12_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%cmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %cmp)
%and = and i32 %cc, 1
%cond.inv = icmp eq i32 %and, 0
%res = select i1 %cond.inv, i64 %y, i64 %x
ret i64 %res
}
; Check (cc == 2|3).
define i64 @f2_0_23(i64 %x, i64 %y, ptr %a) {
; CHECK-LABEL: f2_0_23:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r4), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: bnler %r14
; CHECK-NEXT: .LBB13_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%cmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %cmp)
%cond = icmp ugt i32 %cc, 1
%res = select i1 %cond, i64 %x, i64 %y
ret i64 %res
}
; Test-2(f2_1_*/f2_2_*/f2_3_*/f2_4_*).
; Both TrueVal and FalseVal are non-const with mixed patterns involving
; Binary Ops.
; Check 'add' for (cc != 0).
define i64 @f2_1_1(i64 %x, i64 %y, ptr %a) {
; CHECK-LABEL: f2_1_1:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r4), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: bner %r14
; CHECK-NEXT: .LBB14_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%add = add nsw i32 %cc, -1
%cond = icmp ult i32 %add, 3
%res = select i1 %cond, i64 %x, i64 %y
ret i64 %res
}
; Check 'add' for (cc == 1|2).
define i64 @f2_1_2(i64 %x, i64 %y, ptr %a) {
; CHECK-LABEL: f2_1_2:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r4), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: blhr %r14
; CHECK-NEXT: .LBB15_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%add = add nsw i32 %cc, -1
%cond = icmp ult i32 %add, 2
%res = select i1 %cond, i64 %x, i64 %y
ret i64 %res
}
; Check 'add' for (cc == 1|2).
define i64 @f2_1_3(i64 %y, i64 %x, ptr %a) {
; CHECK-LABEL: f2_1_3:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r4), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: bnlhr %r14
; CHECK-NEXT: .LBB16_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%add = add nsw i32 %cc, -3
%cond.inv = icmp ult i32 %add, -2
%res = select i1 %cond.inv, i64 %y, i64 %x
ret i64 %res
}
; Check 'and' with one operand cc and other select_ccmask(cc !=1).
define i64 @f2_2_1(i64 %y, i64 %x, ptr %a) {
; CHECK-LABEL: f2_2_1:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r4), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: blr %r14
; CHECK-NEXT: .LBB17_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%andcc = and i32 %cc, 1
%cmpne0 = icmp ne i32 %andcc, 0
%cmpne3 = icmp ne i32 %cc, 3
%cond.inv = and i1 %cmpne3, %cmpne0
%res = select i1 %cond.inv, i64 %y, i64 %x
ret i64 %res
}
; Check 'and' with both operands select_ccmask(cc != 2).
define i64 @f2_2_2(i64 %y, i64 %x, ptr %a) {
; CHECK-LABEL: f2_2_2:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r4), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: bhr %r14
; CHECK-NEXT: .LBB18_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%ugt1 = icmp samesign ugt i32 %cc, 1
%cmpne3 = icmp ne i32 %cc, 3
%cond.inv = and i1 %ugt1, %cmpne3
%res = select i1 %cond.inv, i64 %y, i64 %x
ret i64 %res
}
; Check 'and/tm' for (cc == 0|2).
define i64 @f2_2_3(i64 %x, i64 %y, ptr %a) {
; CHECK-LABEL: f2_2_3:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r4), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: bher %r14
; CHECK-NEXT: .LBB19_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%and = and i32 %cc, 1
%cond = icmp eq i32 %and, 0
%res = select i1 %cond, i64 %x, i64 %y
ret i64 %res
}
; Check 'and/tm' for (cc == 1|3).
define i64 @f2_2_4(i64 %y, i64 %x, ptr %a) {
; CHECK-LABEL: f2_2_4:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r4), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: bher %r14
; CHECK-NEXT: .LBB20_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%and = and i32 %cc, 1
%cond.inv = icmp eq i32 %and, 0
%res = select i1 %cond.inv, i64 %y, i64 %x
ret i64 %res
}
; Check 'icmp' with one operand 'and' and other 'select_ccmask'(cc != 1).
define i64 @f2_2_5(i64 %x, i64 %y, ptr %a) {
; CHECK-LABEL: f2_2_5:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r4), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: bnlr %r14
; CHECK-NEXT: .LBB21_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%trunc = trunc i32 %cc to i1
%cmpne3 = icmp ne i32 %cc, 3
%cond = xor i1 %cmpne3, %trunc
%res = select i1 %cond, i64 %x, i64 %y
ret i64 %res
}
; Check nested 'xor' cc with select_ccmask(cc != 1).
define i64 @f2_3_1(i64 %y, i64 %x, ptr %a) {
; CHECK-LABEL: f2_3_1:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r4), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: blr %r14
; CHECK-NEXT: .LBB22_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%cmpeq0 = icmp eq i32 %cc, 0
%cmpeq2 = icmp eq i32 %cc, 2
%xor = xor i1 %cmpeq0, %cmpeq2
%cmpne3 = icmp ne i32 %cc, 3
%cond.inv = xor i1 %cmpne3, %xor
%res = select i1 %cond.inv, i64 %y, i64 %x
ret i64 %res
}
; Check branching on 'tm' and 'xor' with one operand cc and the other
; select_ccmask(cc !=1).
define i64 @f2_3_2(i64 %y, i64 %x, ptr %a) {
; CHECK-LABEL: f2_3_2:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r4), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: blr %r14
; CHECK-NEXT: .LBB23_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%trunc = trunc i32 %cc to i1
%cmpeq3 = icmp eq i32 %cc, 3
%cond.inv = xor i1 %cmpeq3, %trunc
%res = select i1 %cond.inv, i64 %y, i64 %x
ret i64 %res
}
; Check branching on 'tm' and 'xor' with one operand cc and the other
; select_ccmask(cc !=2).
define i64 @f2_3_3(i64 %y, i64 %x, ptr %a) {
; CHECK-LABEL: f2_3_3:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r4), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: bhr %r14
; CHECK-NEXT: .LBB24_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%trunc = trunc i32 %cc to i1
%cmpne0 = icmp ne i32 %cc, 0
%cond.inv = xor i1 %cmpne0, %trunc
%res = select i1 %cond.inv, i64 %y, i64 %x
ret i64 %res
}
; Check 'or' with both operands select_ccmask with TM and ICMP(cc == 1).
define i64 @f2_4_1(i64 %y, i64 %x, ptr %a) {
; CHECK-LABEL: f2_4_1:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r4), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: bnlr %r14
; CHECK-NEXT: .LBB25_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%andcc = and i32 %cc, 1
%cmpeq0 = icmp eq i32 %andcc, 0
%cmpeq3 = icmp eq i32 %cc, 3
%cond.inv = or i1 %cmpeq3, %cmpeq0
%res = select i1 %cond.inv, i64 %y, i64 %x
ret i64 %res
}
; Check 'or' for (cc == 0|1).
define i64 @f2_4_2(i64 %y, i64 %x, ptr %a) {
; CHECK-LABEL: f2_4_2:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r4), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: bnler %r14
; CHECK-NEXT: .LBB26_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%or = or disjoint i32 %cc, -4
%cond.inv = icmp samesign ugt i32 %or, -3
%res = select i1 %cond.inv, i64 %y, i64 %x
ret i64 %res
}
; Check 'or' for (cc == 0|1).
define i64 @f2_4_3(i64 %x, i64 %y, ptr %a) {
; CHECK-LABEL: f2_4_3:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r4), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: bler %r14
; CHECK-NEXT: .LBB27_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%or = or disjoint i32 %cc, -4
%cond = icmp samesign ult i32 %or, -2
%res = select i1 %cond, i64 %x, i64 %y
ret i64 %res
}
; Test-3(f3_1_*/f3_2_*/f3_3_*/f3_4_*).
; TrueVal is non-const and FalseVal is const with mixed patterns involving
; Binary Ops.
; Check 'add' for (cc != 0).
define i64 @f3_1_1(i64 %x, ptr %a) {
; CHECK-LABEL: f3_1_1:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r3), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: bner %r14
; CHECK-NEXT: .LBB28_1: # %entry
; CHECK-NEXT: lghi %r2, 5
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%add = add nsw i32 %cc, -1
%cond = icmp ult i32 %add, 3
%res = select i1 %cond, i64 %x, i64 5
ret i64 %res
}
; Check 'add' for (cc == 1|2).
define i64 @f3_1_2(i64 %x, ptr %a) {
; CHECK-LABEL: f3_1_2:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r3), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: blhr %r14
; CHECK-NEXT: .LBB29_1: # %entry
; CHECK-NEXT: lghi %r2, 5
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%add = add nsw i32 %cc, -1
%cond = icmp ult i32 %add, 2
%res = select i1 %cond, i64 %x, i64 5
ret i64 %res
}
; Check 'add' for (cc == 1|2).
define i64 @f3_1_3(ptr %a, i64 %x) {
; CHECK-LABEL: f3_1_3:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r2), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: lghi %r2, 5
; CHECK-NEXT: bnlhr %r14
; CHECK-NEXT: .LBB30_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%add = add nsw i32 %cc, -3
%cond.inv = icmp ult i32 %add, -2
%res = select i1 %cond.inv, i64 5, i64 %x
ret i64 %res
}
; Check 'and' with one operand cc and other select_ccmask(cc !=1).
define i64 @f3_2_1(ptr %a, i64 %x) {
; CHECK-LABEL: f3_2_1:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r2), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: lghi %r2, 5
; CHECK-NEXT: blr %r14
; CHECK-NEXT: .LBB31_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%andcc = and i32 %cc, 1
%cmpne0 = icmp ne i32 %andcc, 0
%cmpne3 = icmp ne i32 %cc, 3
%cond.inv = and i1 %cmpne3, %cmpne0
%res = select i1 %cond.inv, i64 5, i64 %x
ret i64 %res
}
; Check 'and' with both operands select_ccmask(cc != 2).
define i64 @f3_2_2(ptr %a, i64 %x) {
; CHECK-LABEL: f3_2_2:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r2), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: lghi %r2, 5
; CHECK-NEXT: bhr %r14
; CHECK-NEXT: .LBB32_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%ugt1 = icmp samesign ugt i32 %cc, 1
%cmpne3 = icmp ne i32 %cc, 3
%cond.inv = and i1 %ugt1, %cmpne3
%res = select i1 %cond.inv, i64 5, i64 %x
ret i64 %res
}
; Check 'and/tm' for (cc == 0|2).
define i64 @f3_2_3(i64 %x, ptr %a) {
; CHECK-LABEL: f3_2_3:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r3), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: bher %r14
; CHECK-NEXT: .LBB33_1: # %entry
; CHECK-NEXT: lghi %r2, 5
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%and = and i32 %cc, 1
%cond = icmp eq i32 %and, 0
%res = select i1 %cond, i64 %x, i64 5
ret i64 %res
}
; Check 'and/tm' for (cc == 1|3).
define i64 @f3_2_4(ptr %a, i64 %x) {
; CHECK-LABEL: f3_2_4:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r2), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: lghi %r2, 5
; CHECK-NEXT: bher %r14
; CHECK-NEXT: .LBB34_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%and = and i32 %cc, 1
%cond.inv = icmp eq i32 %and, 0
%res = select i1 %cond.inv, i64 5, i64 %x
ret i64 %res
}
; Check 'icmp' with one operand 'and' and other 'select_ccmask'(cc != 1).
define i64 @f3_2_5(i64 %x, ptr %a) {
; CHECK-LABEL: f3_2_5:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r3), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: bnlr %r14
; CHECK-NEXT: .LBB35_1: # %entry
; CHECK-NEXT: lghi %r2, 5
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%trunc = trunc i32 %cc to i1
%cmpne3 = icmp ne i32 %cc, 3
%cond = xor i1 %cmpne3, %trunc
%res = select i1 %cond, i64 %x, i64 5
ret i64 %res
}
; Check nested 'xor' cc with select_ccmask(cc != 1).
define i64 @f3_3_1(ptr %a, i64 %x) {
; CHECK-LABEL: f3_3_1:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r2), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: lghi %r2, 5
; CHECK-NEXT: blr %r14
; CHECK-NEXT: .LBB36_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%cmpeq0 = icmp eq i32 %cc, 0
%cmpeq2 = icmp eq i32 %cc, 2
%xor = xor i1 %cmpeq0, %cmpeq2
%cmpne3 = icmp ne i32 %cc, 3
%cond.inv = xor i1 %cmpne3, %xor
%res = select i1 %cond.inv, i64 5, i64 %x
ret i64 %res
}
; Check branching on 'tm' and 'xor' with one operand cc and the other
; select_ccmask(cc !=1).
define i64 @f3_3_2(ptr %a, i64 %x) {
; CHECK-LABEL: f3_3_2:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r2), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: lghi %r2, 5
; CHECK-NEXT: blr %r14
; CHECK-NEXT: .LBB37_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%trunc = trunc i32 %cc to i1
%cmpeq3 = icmp eq i32 %cc, 3
%cond.inv = xor i1 %cmpeq3, %trunc
%res = select i1 %cond.inv, i64 5, i64 %x
ret i64 %res
}
; Check branching on 'tm' and 'xor' with one operand cc and the other
; select_ccmask(cc !=2).
define i64 @f3_3_3(ptr %a, i64 %x) {
; CHECK-LABEL: f3_3_3:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r2), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: lghi %r2, 5
; CHECK-NEXT: bhr %r14
; CHECK-NEXT: .LBB38_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%trunc = trunc i32 %cc to i1
%cmpne0 = icmp ne i32 %cc, 0
%cond.inv = xor i1 %cmpne0, %trunc
%res = select i1 %cond.inv, i64 5, i64 %x
ret i64 %res
}
; Check 'or' with both operands select_ccmask with TM and ICMP(cc == 1).
define i64 @f3_4_1(ptr %a, i64 %x) {
; CHECK-LABEL: f3_4_1:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r2), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: lghi %r2, 5
; CHECK-NEXT: bnlr %r14
; CHECK-NEXT: .LBB39_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%andcc = and i32 %cc, 1
%cmpeq0 = icmp eq i32 %andcc, 0
%cmpeq3 = icmp eq i32 %cc, 3
%cond.inv = or i1 %cmpeq3, %cmpeq0
%res = select i1 %cond.inv, i64 5, i64 %x
ret i64 %res
}
; Check 'or' for (cc == 0|1).
define i64 @f3_4_2(ptr %a, i64 %x) {
; CHECK-LABEL: f3_4_2:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r2), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: lghi %r2, 5
; CHECK-NEXT: bnler %r14
; CHECK-NEXT: .LBB40_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%or = or disjoint i32 %cc, -4
%cond.inv = icmp samesign ugt i32 %or, -3
%res = select i1 %cond.inv, i64 5, i64 %x
ret i64 %res
}
; Check 'or' for (cc == 0|1).
define i64 @f3_4_3(i64 %x, ptr %a) {
; CHECK-LABEL: f3_4_3:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r3), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: bler %r14
; CHECK-NEXT: .LBB41_1: # %entry
; CHECK-NEXT: lghi %r2, 5
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%or = or disjoint i32 %cc, -4
%cond = icmp samesign ult i32 %or, -2
%res = select i1 %cond, i64 %x, i64 5
ret i64 %res
}
; Test-4(f4_1_*/f4_2_*/f4_3_*/f4_4_*).
; TrueVal is const and FalseVal is non-const with mixed patterns involving
; Binary Ops.
; Check 'add' for (cc != 0).
define i64 @f4_1_1(ptr %a, i64 %y) {
; CHECK-LABEL: f4_1_1:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r2), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: lghi %r2, 15
; CHECK-NEXT: bner %r14
; CHECK-NEXT: .LBB42_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%add = add nsw i32 %cc, -1
%cond = icmp ult i32 %add, 3
%res = select i1 %cond, i64 15, i64 %y
ret i64 %res
}
; Check 'add' for (cc == 1|2).
define i64 @f4_1_2(ptr %a, i64 %y) {
; CHECK-LABEL: f4_1_2:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r2), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: lghi %r2, 15
; CHECK-NEXT: blhr %r14
; CHECK-NEXT: .LBB43_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%add = add nsw i32 %cc, -1
%cond = icmp ult i32 %add, 2
%res = select i1 %cond, i64 15, i64 %y
ret i64 %res
}
; Check 'add' for (cc == 1|2).
define i64 @f4_1_3(i64 %y, ptr %a) {
; CHECK-LABEL: f4_1_3:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r3), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: bnlhr %r14
; CHECK-NEXT: .LBB44_1: # %entry
; CHECK-NEXT: lghi %r2, 15
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%add = add nsw i32 %cc, -3
%cond.inv = icmp ult i32 %add, -2
%res = select i1 %cond.inv, i64 %y, i64 15
ret i64 %res
}
; Check 'and' with one operand cc and other select_ccmask(cc !=1).
define i64 @f4_2_1(i64 %y, ptr %a) {
; CHECK-LABEL: f4_2_1:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r3), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: blr %r14
; CHECK-NEXT: .LBB45_1: # %entry
; CHECK-NEXT: lghi %r2, 15
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%andcc = and i32 %cc, 1
%cmpne0 = icmp ne i32 %andcc, 0
%cmpne3 = icmp ne i32 %cc, 3
%cond.inv = and i1 %cmpne3, %cmpne0
%res = select i1 %cond.inv, i64 %y, i64 15
ret i64 %res
}
; Check 'and' with both operands select_ccmask(cc != 2).
define i64 @f4_2_2(i64 %y, ptr %a) {
; CHECK-LABEL: f4_2_2:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r3), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: bhr %r14
; CHECK-NEXT: .LBB46_1: # %entry
; CHECK-NEXT: lghi %r2, 15
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%ugt1 = icmp samesign ugt i32 %cc, 1
%cmpne3 = icmp ne i32 %cc, 3
%cond.inv = and i1 %ugt1, %cmpne3
%res = select i1 %cond.inv, i64 %y, i64 15
ret i64 %res
}
; Check 'and/tm' for (cc == 0|2).
define i64 @f4_2_3(ptr %a, i64 %y) {
; CHECK-LABEL: f4_2_3:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r2), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: lghi %r2, 15
; CHECK-NEXT: bher %r14
; CHECK-NEXT: .LBB47_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%and = and i32 %cc, 1
%cond = icmp eq i32 %and, 0
%res = select i1 %cond, i64 15, i64 %y
ret i64 %res
}
; Check 'and/tm' for (cc == 1|3).
define i64 @f4_2_4(i64 %y, ptr %a) {
; CHECK-LABEL: f4_2_4:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r3), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: bher %r14
; CHECK-NEXT: .LBB48_1: # %entry
; CHECK-NEXT: lghi %r2, 15
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%and = and i32 %cc, 1
%cond.inv = icmp eq i32 %and, 0
%res = select i1 %cond.inv, i64 %y, i64 15
ret i64 %res
}
; Check 'icmp' with one operand 'and' and other 'select_ccmask'(cc != 1).
define i64 @f4_2_5(ptr %a, i64 %y) {
; CHECK-LABEL: f4_2_5:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r2), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: lghi %r2, 15
; CHECK-NEXT: bnlr %r14
; CHECK-NEXT: .LBB49_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%trunc = trunc i32 %cc to i1
%cmpne3 = icmp ne i32 %cc, 3
%cond = xor i1 %cmpne3, %trunc
%res = select i1 %cond, i64 15, i64 %y
ret i64 %res
}
; Check nested 'xor' cc with select_ccmask(cc != 1).
define i64 @f4_3_1(i64 %y, ptr %a) {
; CHECK-LABEL: f4_3_1:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r3), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: blr %r14
; CHECK-NEXT: .LBB50_1: # %entry
; CHECK-NEXT: lghi %r2, 15
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%cmpeq0 = icmp eq i32 %cc, 0
%cmpeq2 = icmp eq i32 %cc, 2
%xor = xor i1 %cmpeq0, %cmpeq2
%cmpne3 = icmp ne i32 %cc, 3
%cond.inv = xor i1 %cmpne3, %xor
%res = select i1 %cond.inv, i64 %y, i64 15
ret i64 %res
}
; Check branching on 'tm' and 'xor' with one operand cc and the other
; select_ccmask(cc !=1).
define i64 @f4_3_2(i64 %y, ptr %a) {
; CHECK-LABEL: f4_3_2:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r3), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: blr %r14
; CHECK-NEXT: .LBB51_1: # %entry
; CHECK-NEXT: lghi %r2, 15
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%trunc = trunc i32 %cc to i1
%cmpeq3 = icmp eq i32 %cc, 3
%cond.inv = xor i1 %cmpeq3, %trunc
%res = select i1 %cond.inv, i64 %y, i64 15
ret i64 %res
}
; Check branching on 'tm' and 'xor' with one operand cc and the other
; select_ccmask(cc !=2).
define i64 @f4_3_3(i64 %y, ptr %a) {
; CHECK-LABEL: f4_3_3:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r3), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: bhr %r14
; CHECK-NEXT: .LBB52_1: # %entry
; CHECK-NEXT: lghi %r2, 15
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%trunc = trunc i32 %cc to i1
%cmpne0 = icmp ne i32 %cc, 0
%cond.inv = xor i1 %cmpne0, %trunc
%res = select i1 %cond.inv, i64 %y, i64 15
ret i64 %res
}
; Check 'or' with both operands select_ccmask with TM and ICMP(cc == 1).
define i64 @f4_4_1(i64 %y,ptr %a) {
; CHECK-LABEL: f4_4_1:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r3), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: bnlr %r14
; CHECK-NEXT: .LBB53_1: # %entry
; CHECK-NEXT: lghi %r2, 15
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%andcc = and i32 %cc, 1
%cmpeq0 = icmp eq i32 %andcc, 0
%cmpeq3 = icmp eq i32 %cc, 3
%cond.inv = or i1 %cmpeq3, %cmpeq0
%res = select i1 %cond.inv, i64 %y, i64 15
ret i64 %res
}
; Check 'or' for (cc == 0|1).
define i64 @f4_4_2(i64 %y, ptr %a) {
; CHECK-LABEL: f4_4_2:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r3), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: bnler %r14
; CHECK-NEXT: .LBB54_1: # %entry
; CHECK-NEXT: lghi %r2, 15
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%or = or disjoint i32 %cc, -4
%cond.inv = icmp samesign ugt i32 %or, -3
%res = select i1 %cond.inv, i64 %y, i64 15
ret i64 %res
}
; Check 'or' for (cc == 0|1).
define i64 @f4_4_3(ptr %a, i64 %y) {
; CHECK-LABEL: f4_4_3:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r2), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: lghi %r2, 15
; CHECK-NEXT: bler %r14
; CHECK-NEXT: .LBB55_1: # %entry
; CHECK-NEXT: lgr %r2, %r3
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%or = or disjoint i32 %cc, -4
%cond = icmp samesign ult i32 %or, -2
%res = select i1 %cond, i64 15, i64 %y
ret i64 %res
}
; Test-5(f5_1_*/f5_2_*/f5_3_*/f5_4_*).
; Both TrueVal and FalseVal are const with mixed patterns involving
; Binary Ops.
; Check 'add' for (cc != 0).
define i64 @f5_1_1(ptr %a) {
; CHECK-LABEL: f5_1_1:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r2), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: lghi %r2, 15
; CHECK-NEXT: bner %r14
; CHECK-NEXT: .LBB56_1: # %entry
; CHECK-NEXT: lghi %r2, 5
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%add = add nsw i32 %cc, -1
%cond = icmp ult i32 %add, 3
%res = select i1 %cond, i64 15, i64 5
ret i64 %res
}
; Check 'add' for (cc == 1|2).
define i64 @f5_1_2(ptr %a) {
; CHECK-LABEL: f5_1_2:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r2), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: lghi %r2, 15
; CHECK-NEXT: blhr %r14
; CHECK-NEXT: .LBB57_1: # %entry
; CHECK-NEXT: lghi %r2, 5
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%add = add nsw i32 %cc, -1
%cond = icmp ult i32 %add, 2
%res = select i1 %cond, i64 15, i64 5
ret i64 %res
}
; Check 'add' for (cc == 1|2).
define i64 @f5_1_3(ptr %a) {
; CHECK-LABEL: f5_1_3:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r2), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: lghi %r2, 5
; CHECK-NEXT: bnlhr %r14
; CHECK-NEXT: .LBB58_1: # %entry
; CHECK-NEXT: lghi %r2, 15
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%add = add nsw i32 %cc, -3
%cond.inv = icmp ult i32 %add, -2
%res = select i1 %cond.inv, i64 5, i64 15
ret i64 %res
}
; Check 'and' with one operand cc and other select_ccmask(cc !=1).
define i64 @f5_2_1(ptr %a) {
; CHECK-LABEL: f5_2_1:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r2), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: lghi %r2, 5
; CHECK-NEXT: blr %r14
; CHECK-NEXT: .LBB59_1: # %entry
; CHECK-NEXT: lghi %r2, 15
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%andcc = and i32 %cc, 1
%cmpne0 = icmp ne i32 %andcc, 0
%cmpne3 = icmp ne i32 %cc, 3
%cond.inv = and i1 %cmpne3, %cmpne0
%res = select i1 %cond.inv, i64 5, i64 15
ret i64 %res
}
; Check 'and' with both operands select_ccmask(cc != 2).
define i64 @f5_2_2(ptr %a) {
; CHECK-LABEL: f5_2_2:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r2), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: lghi %r2, 5
; CHECK-NEXT: bhr %r14
; CHECK-NEXT: .LBB60_1: # %entry
; CHECK-NEXT: lghi %r2, 15
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%ugt1 = icmp samesign ugt i32 %cc, 1
%cmpne3 = icmp ne i32 %cc, 3
%cond.inv = and i1 %ugt1, %cmpne3
%res = select i1 %cond.inv, i64 5, i64 15
ret i64 %res
}
; Check 'and/tm' for (cc == 0|2).
define i64 @f5_2_3(ptr %a) {
; CHECK-LABEL: f5_2_3:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r2), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: lghi %r2, 15
; CHECK-NEXT: bher %r14
; CHECK-NEXT: .LBB61_1: # %entry
; CHECK-NEXT: lghi %r2, 5
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%and = and i32 %cc, 1
%cond = icmp eq i32 %and, 0
%res = select i1 %cond, i64 15, i64 5
ret i64 %res
}
; Check 'and/tm' for (cc == 1|3).
define i64 @f5_2_4(ptr %a) {
; CHECK-LABEL: f5_2_4:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r2), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: lghi %r2, 5
; CHECK-NEXT: bher %r14
; CHECK-NEXT: .LBB62_1: # %entry
; CHECK-NEXT: lghi %r2, 15
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%and = and i32 %cc, 1
%cond.inv = icmp eq i32 %and, 0
%res = select i1 %cond.inv, i64 5, i64 15
ret i64 %res
}
; Check 'icmp' with one operand 'and' and other 'select_ccmask'(cc != 1).
define i64 @f5_2_5(ptr %a) {
; CHECK-LABEL: f5_2_5:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r2), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: lghi %r2, 15
; CHECK-NEXT: bnlr %r14
; CHECK-NEXT: .LBB63_1: # %entry
; CHECK-NEXT: lghi %r2, 5
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%trunc = trunc i32 %cc to i1
%cmpne3 = icmp ne i32 %cc, 3
%cond = xor i1 %cmpne3, %trunc
%res = select i1 %cond, i64 15, i64 5
ret i64 %res
}
; Check nested 'xor' cc with select_ccmask(cc != 1).
define i64 @f5_3_1(ptr %a) {
; CHECK-LABEL: f5_3_1:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r2), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: lghi %r2, 5
; CHECK-NEXT: blr %r14
; CHECK-NEXT: .LBB64_1: # %entry
; CHECK-NEXT: lghi %r2, 15
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%cmpeq0 = icmp eq i32 %cc, 0
%cmpeq2 = icmp eq i32 %cc, 2
%xor = xor i1 %cmpeq0, %cmpeq2
%cmpne3 = icmp ne i32 %cc, 3
%cond.inv = xor i1 %cmpne3, %xor
%res = select i1 %cond.inv, i64 5, i64 15
ret i64 %res
}
; Check branching on 'tm' and 'xor' with one operand cc and the other
; select_ccmask(cc !=1).
define i64 @f5_3_2(ptr %a) {
; CHECK-LABEL: f5_3_2:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r2), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: lghi %r2, 5
; CHECK-NEXT: blr %r14
; CHECK-NEXT: .LBB65_1: # %entry
; CHECK-NEXT: lghi %r2, 15
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%trunc = trunc i32 %cc to i1
%cmpeq3 = icmp eq i32 %cc, 3
%cond.inv = xor i1 %cmpeq3, %trunc
%res = select i1 %cond.inv, i64 5, i64 15
ret i64 %res
}
; Check branching on 'tm' and 'xor' with one operand cc and the other
; select_ccmask(cc !=2).
define i64 @f5_3_3(ptr %a) {
; CHECK-LABEL: f5_3_3:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r2), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: lghi %r2, 5
; CHECK-NEXT: bhr %r14
; CHECK-NEXT: .LBB66_1: # %entry
; CHECK-NEXT: lghi %r2, 15
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%trunc = trunc i32 %cc to i1
%cmpne0 = icmp ne i32 %cc, 0
%cond.inv = xor i1 %cmpne0, %trunc
%res = select i1 %cond.inv, i64 5, i64 15
ret i64 %res
}
; Check 'or' with both operands select_ccmask with TM and ICMP(cc == 1).
define i64 @f5_4_1(ptr %a) {
; CHECK-LABEL: f5_4_1:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r2), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: lghi %r2, 5
; CHECK-NEXT: bnlr %r14
; CHECK-NEXT: .LBB67_1: # %entry
; CHECK-NEXT: lghi %r2, 15
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%andcc = and i32 %cc, 1
%cmpeq0 = icmp eq i32 %andcc, 0
%cmpeq3 = icmp eq i32 %cc, 3
%cond.inv = or i1 %cmpeq3, %cmpeq0
%res = select i1 %cond.inv, i64 5, i64 15
ret i64 %res
}
; Check 'or' for (cc == 0|1).
define i64 @f5_4_2(ptr %a) {
; CHECK-LABEL: f5_4_2:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r2), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: lghi %r2, 5
; CHECK-NEXT: bnler %r14
; CHECK-NEXT: .LBB68_1: # %entry
; CHECK-NEXT: lghi %r2, 15
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%or = or disjoint i32 %cc, -4
%cond.inv = icmp samesign ugt i32 %or, -3
%res = select i1 %cond.inv, i64 5, i64 15
ret i64 %res
}
; Check 'or' for (cc == 0|1).
define i64 @f5_4_3(ptr %a) {
; CHECK-LABEL: f5_4_3:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r2), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: lghi %r2, 15
; CHECK-NEXT: bler %r14
; CHECK-NEXT: .LBB69_1: # %entry
; CHECK-NEXT: lghi %r2, 5
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%tmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %tmp)
%or = or disjoint i32 %cc, -4
%cond = icmp samesign ult i32 %or, -2
%res = select i1 %cond, i64 15, i64 5
ret i64 %res
}
; Nested select_ccmask with TrueVal and FalseVal swapped with each other.
define i64 @f6_1(ptr %a) {
; CHECK-LABEL: f6_1:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: #APP
; CHECK-NEXT: alsi 0(%r2), -1
; CHECK-EMPTY:
; CHECK-NEXT: #NO_APP
; CHECK-NEXT: lghi %r2, 15
; CHECK-NEXT: bher %r14
; CHECK-NEXT: .LBB70_1: # %entry
; CHECK-NEXT: lghi %r2, 5
; CHECK-NEXT: br %r14
entry:
%cc = tail call i32 asm sideeffect "alsi $1,-1\0A", "={@cc},=*QS,*QS,~{memory}"(ptr elementtype(i32) %a, ptr elementtype(i32) %a)
%cmp = icmp ult i32 %cc, 4
tail call void @llvm.assume(i1 %cmp)
%andcc = and i32 %cc, 1
%cmpeq0 = icmp eq i32 %andcc, 0
%cmpeq3 = icmp eq i32 %cc, 3
%select = select i1 %cmpeq3, i64 5, i64 15
%res = select i1 %cmpeq0, i64 %select, i64 5
ret i64 %res
}