aarch64.md (mov<mode>cc): New for GPF.
2014-04-29 Zhenqiang Chen <zhenqiang.chen@linaro.org> * config/aarch64/aarch64.md (mov<mode>cc): New for GPF. 2014-04-29 Zhenqiang Chen <zhenqiang.chen@linaro.org> * gcc.target/aarch64/fcsel_1.c: New test case. From-SVN: r209889
This commit is contained in:
parent
32a360864e
commit
d3a3182b5d
4 changed files with 49 additions and 0 deletions
|
@ -1,3 +1,7 @@
|
|||
2014-04-29 Zhenqiang Chen <zhenqiang.chen@linaro.org>
|
||||
|
||||
* config/aarch64/aarch64.md (mov<mode>cc): New for GPF.
|
||||
|
||||
2014-04-28 James Greenhalgh <james.greenhalgh@arm.com>
|
||||
|
||||
* config/aarch64/aarch64-builtins.c
|
||||
|
|
|
@ -2429,6 +2429,25 @@
|
|||
}
|
||||
)
|
||||
|
||||
(define_expand "mov<mode>cc"
|
||||
[(set (match_operand:GPF 0 "register_operand" "")
|
||||
(if_then_else:GPF (match_operand 1 "aarch64_comparison_operator" "")
|
||||
(match_operand:GPF 2 "register_operand" "")
|
||||
(match_operand:GPF 3 "register_operand" "")))]
|
||||
""
|
||||
{
|
||||
rtx ccreg;
|
||||
enum rtx_code code = GET_CODE (operands[1]);
|
||||
|
||||
if (code == UNEQ || code == LTGT)
|
||||
FAIL;
|
||||
|
||||
ccreg = aarch64_gen_compare_reg (code, XEXP (operands[1], 0),
|
||||
XEXP (operands[1], 1));
|
||||
operands[1] = gen_rtx_fmt_ee (code, VOIDmode, ccreg, const0_rtx);
|
||||
}
|
||||
)
|
||||
|
||||
(define_insn "*csinc2<mode>_insn"
|
||||
[(set (match_operand:GPI 0 "register_operand" "=r")
|
||||
(plus:GPI (match_operator:GPI 2 "aarch64_comparison_operator"
|
||||
|
|
|
@ -1,3 +1,7 @@
|
|||
2014-04-29 Zhenqiang Chen <zhenqiang.chen@linaro.org>
|
||||
|
||||
* gcc.target/aarch64/fcsel_1.c: New test case.
|
||||
|
||||
2014-04-28 Jerry DeLisle <jvdelisle@gcc.gnu>
|
||||
|
||||
PR libfortran/60810
|
||||
|
|
22
gcc/testsuite/gcc.target/aarch64/fcsel_1.c
Normal file
22
gcc/testsuite/gcc.target/aarch64/fcsel_1.c
Normal file
|
@ -0,0 +1,22 @@
|
|||
/* { dg-do compile } */
|
||||
/* { dg-options " -O2 " } */
|
||||
|
||||
float
|
||||
f_1 (float a, float b, float c, float d)
|
||||
{
|
||||
if (a > 0.0)
|
||||
return c;
|
||||
else
|
||||
return 2.0;
|
||||
}
|
||||
|
||||
double
|
||||
f_2 (double a, double b, double c, double d)
|
||||
{
|
||||
if (a > b)
|
||||
return c;
|
||||
else
|
||||
return d;
|
||||
}
|
||||
|
||||
/* { dg-final { scan-assembler-times "\tfcsel" 2 } } */
|
Loading…
Add table
Reference in a new issue