From: Vidya Praveen Date: Fri, 3 May 2013 10:17:57 +0000 (+0100) Subject: [AArch64] Support scalar FABD X-Git-Tag: upstream/12.2.0~69888 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=1d0c8e5cc36c164c065a1b8655d1b51085a5b6ad;p=platform%2Fupstream%2Fgcc.git [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 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index b94a74b..4c70ab4 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 13384aa..548600d 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 b716353..937d634 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 0000000..7206d5e --- /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 } } */