blob: 4dba3edfe19965ed0922ed2280e2d048dac42bbb [file] [log] [blame] [edit]
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
; RUN: llc < %s -mtriple=aarch64-none-eabi | FileCheck %s
define i32 @icmp_slt_i256(i256 %a, i256 %b) nounwind {
; CHECK-LABEL: icmp_slt_i256:
; CHECK: // %bb.0:
; CHECK-NEXT: cmp x0, x4
; CHECK-NEXT: sbcs xzr, x1, x5
; CHECK-NEXT: sbcs xzr, x2, x6
; CHECK-NEXT: sbcs xzr, x3, x7
; CHECK-NEXT: cset w0, lt
; CHECK-NEXT: ret
%c = icmp slt i256 %a, %b
%r = zext i1 %c to i32
ret i32 %r
}
define i32 @icmp_sgt_i256(i256 %a, i256 %b) nounwind {
; CHECK-LABEL: icmp_sgt_i256:
; CHECK: // %bb.0:
; CHECK-NEXT: cmp x4, x0
; CHECK-NEXT: sbcs xzr, x5, x1
; CHECK-NEXT: sbcs xzr, x6, x2
; CHECK-NEXT: sbcs xzr, x7, x3
; CHECK-NEXT: cset w0, lt
; CHECK-NEXT: ret
%c = icmp sgt i256 %a, %b
%r = zext i1 %c to i32
ret i32 %r
}
define i32 @icmp_sle_i256(i256 %a, i256 %b) nounwind {
; CHECK-LABEL: icmp_sle_i256:
; CHECK: // %bb.0:
; CHECK-NEXT: cmp x4, x0
; CHECK-NEXT: sbcs xzr, x5, x1
; CHECK-NEXT: sbcs xzr, x6, x2
; CHECK-NEXT: sbcs xzr, x7, x3
; CHECK-NEXT: cset w0, ge
; CHECK-NEXT: ret
%c = icmp sle i256 %a, %b
%r = zext i1 %c to i32
ret i32 %r
}
define i32 @icmp_sge_i256(i256 %a, i256 %b) nounwind {
; CHECK-LABEL: icmp_sge_i256:
; CHECK: // %bb.0:
; CHECK-NEXT: cmp x0, x4
; CHECK-NEXT: sbcs xzr, x1, x5
; CHECK-NEXT: sbcs xzr, x2, x6
; CHECK-NEXT: sbcs xzr, x3, x7
; CHECK-NEXT: cset w0, ge
; CHECK-NEXT: ret
%c = icmp sge i256 %a, %b
%r = zext i1 %c to i32
ret i32 %r
}
define i32 @icmp_ult_i256(i256 %a, i256 %b) nounwind {
; CHECK-LABEL: icmp_ult_i256:
; CHECK: // %bb.0:
; CHECK-NEXT: cmp x0, x4
; CHECK-NEXT: sbcs xzr, x1, x5
; CHECK-NEXT: sbcs xzr, x2, x6
; CHECK-NEXT: sbcs xzr, x3, x7
; CHECK-NEXT: cset w0, lo
; CHECK-NEXT: ret
%c = icmp ult i256 %a, %b
%r = zext i1 %c to i32
ret i32 %r
}
define i32 @icmp_ugt_i256(i256 %a, i256 %b) nounwind {
; CHECK-LABEL: icmp_ugt_i256:
; CHECK: // %bb.0:
; CHECK-NEXT: cmp x4, x0
; CHECK-NEXT: sbcs xzr, x5, x1
; CHECK-NEXT: sbcs xzr, x6, x2
; CHECK-NEXT: sbcs xzr, x7, x3
; CHECK-NEXT: cset w0, lo
; CHECK-NEXT: ret
%c = icmp ugt i256 %a, %b
%r = zext i1 %c to i32
ret i32 %r
}
define i32 @icmp_ule_i256(i256 %a, i256 %b) nounwind {
; CHECK-LABEL: icmp_ule_i256:
; CHECK: // %bb.0:
; CHECK-NEXT: cmp x4, x0
; CHECK-NEXT: sbcs xzr, x5, x1
; CHECK-NEXT: sbcs xzr, x6, x2
; CHECK-NEXT: sbcs xzr, x7, x3
; CHECK-NEXT: cset w0, hs
; CHECK-NEXT: ret
%c = icmp ule i256 %a, %b
%r = zext i1 %c to i32
ret i32 %r
}
define i32 @icmp_uge_i256(i256 %a, i256 %b) nounwind {
; CHECK-LABEL: icmp_uge_i256:
; CHECK: // %bb.0:
; CHECK-NEXT: cmp x0, x4
; CHECK-NEXT: sbcs xzr, x1, x5
; CHECK-NEXT: sbcs xzr, x2, x6
; CHECK-NEXT: sbcs xzr, x3, x7
; CHECK-NEXT: cset w0, hs
; CHECK-NEXT: ret
%c = icmp uge i256 %a, %b
%r = zext i1 %c to i32
ret i32 %r
}
; Select based on i256 comparison
define i256 @select_slt_i256(i256 %a, i256 %b, i256 %x, i256 %y) nounwind {
; CHECK-LABEL: select_slt_i256:
; CHECK: // %bb.0:
; CHECK-NEXT: cmp x0, x4
; CHECK-NEXT: add x8, sp, #32
; CHECK-NEXT: mov x9, sp
; CHECK-NEXT: sbcs xzr, x1, x5
; CHECK-NEXT: sbcs xzr, x2, x6
; CHECK-NEXT: sbcs xzr, x3, x7
; CHECK-NEXT: csel x8, x9, x8, lt
; CHECK-NEXT: ldp x0, x1, [x8]
; CHECK-NEXT: ldp x2, x3, [x8, #16]
; CHECK-NEXT: ret
%c = icmp slt i256 %a, %b
%r = select i1 %c, i256 %x, i256 %y
ret i256 %r
}