summaryrefslogtreecommitdiffstats
path: root/llvm/test/CodeGen/Mips/Fast-ISel/sel1.ll
diff options
context:
space:
mode:
Diffstat (limited to 'llvm/test/CodeGen/Mips/Fast-ISel/sel1.ll')
-rw-r--r--llvm/test/CodeGen/Mips/Fast-ISel/sel1.ll29
1 files changed, 29 insertions, 0 deletions
diff --git a/llvm/test/CodeGen/Mips/Fast-ISel/sel1.ll b/llvm/test/CodeGen/Mips/Fast-ISel/sel1.ll
index 8f762b0ed08..b3fc58f293a 100644
--- a/llvm/test/CodeGen/Mips/Fast-ISel/sel1.ll
+++ b/llvm/test/CodeGen/Mips/Fast-ISel/sel1.ll
@@ -80,6 +80,20 @@ entry:
ret float %res
}
+define float @sel_float2(float %k, float %l, i32 %j) {
+entry:
+ ; CHECK-LABEL: sel_float2:
+
+ ; CHECK-DAG: xor $[[T0:[0-9]+]], $6, $zero
+ ; CHECK: sltu $[[T1:[0-9]+]], $zero, $[[T0]]
+ ; CHECK-NEXT: andi $[[T2:[0-9]+]], $[[T1]], 1
+ ; CHECK: movn.s $f14, $f12, $[[T2]]
+ ; CHECK: mov.s $f0, $f14
+ %cond = icmp ne i32 %j, 0
+ %res = select i1 %cond, float %k, float %l
+ ret float %res
+}
+
define double @sel_double(i32 %j, double %k, double %l) {
entry:
; CHECK-LABEL: sel_double:
@@ -95,3 +109,18 @@ entry:
%res = select i1 %cond, double %k, double %l
ret double %res
}
+
+define double @sel_double2(double %k, double %l, i32 %j) {
+entry:
+ ; CHECK-LABEL: sel_double2:
+
+ ; CHECK-DAG: lw $[[SEL:[0-9]+]], 16($sp)
+ ; CHECK-DAG: xor $[[T0:[0-9]+]], $[[SEL]], $zero
+ ; CHECK: sltu $[[T1:[0-9]+]], $zero, $[[T0]]
+ ; CHECK-NEXT: andi $[[T2:[0-9]+]], $[[T1]], 1
+ ; CHECK: movn.d $f14, $f12, $[[T2]]
+ ; CHECK: mov.d $f0, $f14
+ %cond = icmp ne i32 %j, 0
+ %res = select i1 %cond, double %k, double %l
+ ret double %res
+}
OpenPOWER on IntegriCloud