From 1d0c8e5cc36c164c065a1b8655d1b51085a5b6ad Mon Sep 17 00:00:00 2001 From: Vidya Praveen Date: Fri, 3 May 2013 11:17:57 +0100 Subject: [PATCH] [AArch64] Support scalar FABD gcc/ChangeLog 2013-05-02 Vidya Praveen * config/aarch64/aarch64-simd.md (*fabd_scalar3): Support scalar form of FABD instruction. gcc/testsuite/ChangeLog 2013-05-02 Vidya Praveen * gcc.target/aarch64/fabd.c: New file. From-SVN: r198574 --- gcc/ChangeLog | 5 ++++ gcc/config/aarch64/aarch64-simd.md | 11 +++++++ gcc/testsuite/ChangeLog | 4 +++ gcc/testsuite/gcc.target/aarch64/fabd.c | 38 +++++++++++++++++++++++++ 4 files changed, 58 insertions(+) create mode 100644 gcc/testsuite/gcc.target/aarch64/fabd.c diff --git a/gcc/ChangeLog b/gcc/ChangeLog index b94a74bd739..4c70ab41189 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2013-05-03 Vidya Praveen + + * config/aarch64/aarch64-simd.md (*fabd_scalar3): Support + scalar form of FABD instruction. + 2013-05-02 Vladimir Makarov * lra-constraints.c (process_alt_operands): Add checking alt diff --git a/gcc/config/aarch64/aarch64-simd.md b/gcc/config/aarch64/aarch64-simd.md index 13384aa85af..548600dfa21 100644 --- a/gcc/config/aarch64/aarch64-simd.md +++ b/gcc/config/aarch64/aarch64-simd.md @@ -556,6 +556,17 @@ (set_attr "simd_mode" "")] ) +(define_insn "*fabd_scalar3" + [(set (match_operand:GPF 0 "register_operand" "=w") + (abs:GPF (minus:GPF + (match_operand:GPF 1 "register_operand" "w") + (match_operand:GPF 2 "register_operand" "w"))))] + "TARGET_SIMD" + "fabd\t%0, %1, %2" + [(set_attr "simd_type" "simd_fabd") + (set_attr "mode" "")] +) + (define_insn "and3" [(set (match_operand:VDQ 0 "register_operand" "=w") (and:VDQ (match_operand:VDQ 1 "register_operand" "w") diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index b7163534e82..937d634ccfd 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,7 @@ +2013-05-03 Vidya Praveen + + * gcc.target/aarch64/fabd.c: New file. + 2013-05-03 Paolo Carlini PR c++/54318 diff --git a/gcc/testsuite/gcc.target/aarch64/fabd.c b/gcc/testsuite/gcc.target/aarch64/fabd.c new file mode 100644 index 00000000000..7206d5e95c7 --- /dev/null +++ b/gcc/testsuite/gcc.target/aarch64/fabd.c @@ -0,0 +1,38 @@ +/* { dg-do run } */ +/* { dg-options "-O1 -fno-inline --save-temps" } */ + +extern double fabs (double); +extern float fabsf (float); +extern void abort (); +extern void exit (int); + +void +fabd_d (double x, double y, double d) +{ + if ((fabs (x - y) - d) > 0.00001) + abort (); +} + +/* { dg-final { scan-assembler "fabd\td\[0-9\]+" } } */ + +void +fabd_f (float x, float y, float d) +{ + if ((fabsf (x - y) - d) > 0.00001) + abort (); +} + +/* { dg-final { scan-assembler "fabd\ts\[0-9\]+" } } */ + +int +main () +{ + fabd_d (10.0, 5.0, 5.0); + fabd_d (5.0, 10.0, 5.0); + fabd_f (10.0, 5.0, 5.0); + fabd_f (5.0, 10.0, 5.0); + + return 0; +} + +/* { dg-final { cleanup-saved-temps } } */