Commit d3a3182b by Zhenqiang Chen Committed by Zhenqiang Chen

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
parent 32a36086
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> 2014-04-28 James Greenhalgh <james.greenhalgh@arm.com>
* config/aarch64/aarch64-builtins.c * config/aarch64/aarch64-builtins.c
......
...@@ -2429,6 +2429,25 @@ ...@@ -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" (define_insn "*csinc2<mode>_insn"
[(set (match_operand:GPI 0 "register_operand" "=r") [(set (match_operand:GPI 0 "register_operand" "=r")
(plus:GPI (match_operator:GPI 2 "aarch64_comparison_operator" (plus:GPI (match_operator:GPI 2 "aarch64_comparison_operator"
......
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> 2014-04-28 Jerry DeLisle <jvdelisle@gcc.gnu>
PR libfortran/60810 PR libfortran/60810
......
/* { 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 } } */
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment