From d3a3182b5d2ca6551e241ec22f171299b2495c4e Mon Sep 17 00:00:00 2001 From: Zhenqiang Chen Date: Tue, 29 Apr 2014 05:10:11 +0000 Subject: [PATCH] aarch64.md (movcc): New for GPF. 2014-04-29 Zhenqiang Chen * config/aarch64/aarch64.md (movcc): New for GPF. 2014-04-29 Zhenqiang Chen * gcc.target/aarch64/fcsel_1.c: New test case. From-SVN: r209889 --- gcc/ChangeLog | 4 ++++ gcc/config/aarch64/aarch64.md | 19 +++++++++++++++++++ gcc/testsuite/ChangeLog | 4 ++++ gcc/testsuite/gcc.target/aarch64/fcsel_1.c | 22 ++++++++++++++++++++++ 4 files changed, 49 insertions(+) create mode 100644 gcc/testsuite/gcc.target/aarch64/fcsel_1.c diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 1799a435274..9bc2ce05d38 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,7 @@ +2014-04-29 Zhenqiang Chen + + * config/aarch64/aarch64.md (movcc): New for GPF. + 2014-04-28 James Greenhalgh * config/aarch64/aarch64-builtins.c diff --git a/gcc/config/aarch64/aarch64.md b/gcc/config/aarch64/aarch64.md index a004f9da1c8..266d7873a5a 100644 --- a/gcc/config/aarch64/aarch64.md +++ b/gcc/config/aarch64/aarch64.md @@ -2429,6 +2429,25 @@ } ) +(define_expand "movcc" + [(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_insn" [(set (match_operand:GPI 0 "register_operand" "=r") (plus:GPI (match_operator:GPI 2 "aarch64_comparison_operator" diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index b5a66cec7e9..5fbd76f0b67 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,7 @@ +2014-04-29 Zhenqiang Chen + + * gcc.target/aarch64/fcsel_1.c: New test case. + 2014-04-28 Jerry DeLisle PR libfortran/60810 diff --git a/gcc/testsuite/gcc.target/aarch64/fcsel_1.c b/gcc/testsuite/gcc.target/aarch64/fcsel_1.c new file mode 100644 index 00000000000..2704ee0ede7 --- /dev/null +++ b/gcc/testsuite/gcc.target/aarch64/fcsel_1.c @@ -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 } } */ -- 2.30.2