mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-23 19:23:23 +01:00
111 lines
1.8 KiB
LLVM
111 lines
1.8 KiB
LLVM
|
; RUN: llc < %s -mtriple thumbv6m-eabi | FileCheck %s
|
||
|
|
||
|
define i32 @slt_poweroftwo(i32 %a) {
|
||
|
; CHECK-LABEL: slt_poweroftwo:
|
||
|
; CHECK: .long 4095
|
||
|
%b = icmp slt i32 %a, 4096
|
||
|
br i1 %b, label %true, label %false
|
||
|
|
||
|
true:
|
||
|
ret i32 1
|
||
|
|
||
|
false:
|
||
|
ret i32 2
|
||
|
}
|
||
|
|
||
|
define i32 @sle_poweroftwo(i32 %a) {
|
||
|
; CHECK-LABEL: sle_poweroftwo:
|
||
|
; CHECK: movs r1, #1
|
||
|
; CHECK: lsls r1, r1, #12
|
||
|
%b = icmp sle i32 %a, 4096
|
||
|
br i1 %b, label %true, label %false
|
||
|
|
||
|
true:
|
||
|
ret i32 1
|
||
|
|
||
|
false:
|
||
|
ret i32 2
|
||
|
}
|
||
|
|
||
|
define i32 @sge_poweroftwo(i32 %a) {
|
||
|
; CHECK-LABEL: sge_poweroftwo:
|
||
|
; CHECK: movs r1, #1
|
||
|
; CHECK: lsls r1, r1, #12
|
||
|
%b = icmp sge i32 %a, 4096
|
||
|
br i1 %b, label %true, label %false
|
||
|
|
||
|
true:
|
||
|
ret i32 1
|
||
|
|
||
|
false:
|
||
|
ret i32 2
|
||
|
}
|
||
|
|
||
|
define i32 @sgt_poweroftwo(i32 %a) {
|
||
|
; CHECK-LABEL: sgt_poweroftwo:
|
||
|
; CHECK: .long 4097
|
||
|
%b = icmp sgt i32 %a, 4096
|
||
|
br i1 %b, label %true, label %false
|
||
|
|
||
|
true:
|
||
|
ret i32 1
|
||
|
|
||
|
false:
|
||
|
ret i32 2
|
||
|
}
|
||
|
|
||
|
define i32 @slt_nearpoweroftwo(i32 %a) {
|
||
|
; CHECK-LABEL: slt_nearpoweroftwo:
|
||
|
; CHECK: movs r1, #1
|
||
|
; CHECK: lsls r1, r1, #12
|
||
|
%b = icmp slt i32 %a, 4097
|
||
|
br i1 %b, label %true, label %false
|
||
|
|
||
|
true:
|
||
|
ret i32 1
|
||
|
|
||
|
false:
|
||
|
ret i32 2
|
||
|
}
|
||
|
|
||
|
define i32 @sle_nearpoweroftwo(i32 %a) {
|
||
|
; CHECK-LABEL: sle_nearpoweroftwo:
|
||
|
; CHECK: .long 4095
|
||
|
%b = icmp sle i32 %a, 4095
|
||
|
br i1 %b, label %true, label %false
|
||
|
|
||
|
true:
|
||
|
ret i32 1
|
||
|
|
||
|
false:
|
||
|
ret i32 2
|
||
|
}
|
||
|
|
||
|
|
||
|
define i32 @sge_nearpoweroftwo(i32 %a) {
|
||
|
; CHECK-LABEL: sge_nearpoweroftwo:
|
||
|
; CHECK: .long 4097
|
||
|
%b = icmp sge i32 %a, 4097
|
||
|
br i1 %b, label %true, label %false
|
||
|
|
||
|
true:
|
||
|
ret i32 1
|
||
|
|
||
|
false:
|
||
|
ret i32 2
|
||
|
}
|
||
|
|
||
|
define i32 @sgt_nearpoweroftwo(i32 %a) {
|
||
|
; CHECK-LABEL: sgt_nearpoweroftwo:
|
||
|
; CHECK: movs r1, #1
|
||
|
; CHECK: lsls r1, r1, #12
|
||
|
%b = icmp sgt i32 %a, 4095
|
||
|
br i1 %b, label %true, label %false
|
||
|
|
||
|
true:
|
||
|
ret i32 1
|
||
|
|
||
|
false:
|
||
|
ret i32 2
|
||
|
}
|