2009-10-10 01:20:46 +08:00
|
|
|
; RUN: llc < %s -march=arm | FileCheck %s
|
|
|
|
; RUN: llc < %s -march=arm -mattr=+vfp2 | FileCheck %s --check-prefix=CHECK-VFP
|
2006-08-22 14:43:24 +08:00
|
|
|
|
2007-01-26 16:25:06 +08:00
|
|
|
define i32 @f1(i32 %a.s) {
|
2009-10-10 01:20:46 +08:00
|
|
|
;CHECK: f1:
|
|
|
|
;CHECK: moveq
|
2006-08-22 06:00:32 +08:00
|
|
|
entry:
|
2007-01-19 17:20:23 +08:00
|
|
|
%tmp = icmp eq i32 %a.s, 4
|
|
|
|
%tmp1.s = select i1 %tmp, i32 2, i32 3
|
|
|
|
ret i32 %tmp1.s
|
2006-08-22 06:00:32 +08:00
|
|
|
}
|
2006-09-21 21:06:26 +08:00
|
|
|
|
2007-01-26 16:25:06 +08:00
|
|
|
define i32 @f2(i32 %a.s) {
|
2009-10-10 01:20:46 +08:00
|
|
|
;CHECK: f2:
|
|
|
|
;CHECK: movgt
|
2006-09-21 21:06:26 +08:00
|
|
|
entry:
|
2007-01-19 17:20:23 +08:00
|
|
|
%tmp = icmp sgt i32 %a.s, 4
|
|
|
|
%tmp1.s = select i1 %tmp, i32 2, i32 3
|
|
|
|
ret i32 %tmp1.s
|
2006-09-21 21:06:26 +08:00
|
|
|
}
|
|
|
|
|
2007-01-26 16:25:06 +08:00
|
|
|
define i32 @f3(i32 %a.s, i32 %b.s) {
|
2009-10-10 01:20:46 +08:00
|
|
|
;CHECK: f3:
|
|
|
|
;CHECK: movlt
|
2006-09-21 21:06:26 +08:00
|
|
|
entry:
|
2007-01-19 17:20:23 +08:00
|
|
|
%tmp = icmp slt i32 %a.s, %b.s
|
|
|
|
%tmp1.s = select i1 %tmp, i32 2, i32 3
|
|
|
|
ret i32 %tmp1.s
|
2006-09-21 21:06:26 +08:00
|
|
|
}
|
|
|
|
|
2007-01-26 16:25:06 +08:00
|
|
|
define i32 @f4(i32 %a.s, i32 %b.s) {
|
2009-10-10 01:20:46 +08:00
|
|
|
;CHECK: f4:
|
|
|
|
;CHECK: movle
|
2006-09-21 21:06:26 +08:00
|
|
|
entry:
|
2007-01-19 17:20:23 +08:00
|
|
|
%tmp = icmp sle i32 %a.s, %b.s
|
|
|
|
%tmp1.s = select i1 %tmp, i32 2, i32 3
|
|
|
|
ret i32 %tmp1.s
|
2006-09-21 21:06:26 +08:00
|
|
|
}
|
|
|
|
|
2007-01-26 16:25:06 +08:00
|
|
|
define i32 @f5(i32 %a.u, i32 %b.u) {
|
2009-10-10 01:20:46 +08:00
|
|
|
;CHECK: f5:
|
|
|
|
;CHECK: movls
|
2006-09-21 21:06:26 +08:00
|
|
|
entry:
|
2007-01-19 17:20:23 +08:00
|
|
|
%tmp = icmp ule i32 %a.u, %b.u
|
|
|
|
%tmp1.s = select i1 %tmp, i32 2, i32 3
|
|
|
|
ret i32 %tmp1.s
|
2006-09-21 21:06:26 +08:00
|
|
|
}
|
|
|
|
|
2007-01-26 16:25:06 +08:00
|
|
|
define i32 @f6(i32 %a.u, i32 %b.u) {
|
2009-10-10 01:20:46 +08:00
|
|
|
;CHECK: f6:
|
|
|
|
;CHECK: movhi
|
2006-09-21 21:06:26 +08:00
|
|
|
entry:
|
2007-01-19 17:20:23 +08:00
|
|
|
%tmp = icmp ugt i32 %a.u, %b.u
|
|
|
|
%tmp1.s = select i1 %tmp, i32 2, i32 3
|
|
|
|
ret i32 %tmp1.s
|
|
|
|
}
|
|
|
|
|
2007-01-26 16:25:06 +08:00
|
|
|
define double @f7(double %a, double %b) {
|
2009-10-10 01:20:46 +08:00
|
|
|
;CHECK: f7:
|
|
|
|
;CHECK: movlt
|
|
|
|
;CHECK: movlt
|
|
|
|
;CHECK-VFP: f7:
|
|
|
|
;CHECK-VFP: fcpydmi
|
2007-01-19 17:20:23 +08:00
|
|
|
%tmp = fcmp olt double %a, 1.234e+00
|
|
|
|
%tmp1 = select i1 %tmp, double -1.000e+00, double %b
|
|
|
|
ret double %tmp1
|
2006-09-21 21:06:26 +08:00
|
|
|
}
|