public inbox for gcc-bugs@sourceware.org
help / color / mirror / Atom feed
From: "alalaw01 at gcc dot gnu.org" <gcc-bugzilla@gcc.gnu.org>
To: gcc-bugs@gcc.gnu.org
Subject: [Bug target/60825] [AArch64] int64x1_t, uint64x1_t and float64x1_t are not treated as vector types
Date: Mon, 23 Jun 2014 12:47:00 -0000	[thread overview]
Message-ID: <bug-60825-4-KjoJAukB4b@http.gcc.gnu.org/bugzilla/> (raw)
In-Reply-To: <bug-60825-4@http.gcc.gnu.org/bugzilla/>

https://gcc.gnu.org/bugzilla/show_bug.cgi?id=60825

--- Comment #3 from alalaw01 at gcc dot gnu.org ---
Author: alalaw01
Date: Mon Jun 23 12:46:52 2014
New Revision: 211892

URL: https://gcc.gnu.org/viewcvs?rev=211892&root=gcc&view=rev
Log:
PR/60825 Make float64x1_t in arm_neon.h a proper vector type

gcc/ChangeLog:
    PR target/60825
    * config/aarch64/aarch64.c (aarch64_simd_mangle_map): Add entry for
    V1DFmode.
    * config/aarch64/aarch64-builtins.c (aarch64_simd_builtin_type_mode):
    add V1DFmode
    (BUILTIN_VD1): New.
    (BUILTIN_VD_RE): Remove.
    (aarch64_init_simd_builtins): Add V1DF to modes/modenames.
    (aarch64_fold_builtin): Update reinterpret patterns, df becomes v1df.
    * config/aarch64/aarch64-simd-builtins.def (create): Make a v1df
    variant but not df.
    (vreinterpretv1df*, vreinterpret*v1df): New.
    (vreinterpretdf*, vreinterpret*df): Remove.
    * config/aarch64/aarch64-simd.md (aarch64_create, aarch64_reinterpret*):
    Generate V1DFmode pattern not DFmode.
    * config/aarch64/iterators.md (VD_RE): Include V1DF, remove DF.
    (VD1): New.
    * config/aarch64/arm_neon.h (float64x1_t): typedef with gcc extensions.
    (vcreate_f64): Remove cast, use v1df builtin.
    (vcombine_f64): Remove cast, get elements with gcc vector extensions.
    (vget_low_f64, vabs_f64, vceq_f64, vceqz_f64, vcge_f64, vgfez_f64,
    vcgt_f64, vcgtz_f64, vcle_f64, vclez_f64, vclt_f64, vcltz_f64,
    vdup_n_f64, vdupq_lane_f64, vld1_f64, vld2_f64, vld3_f64, vld4_f64,
    vmov_n_f64, vst1_f64): Use gcc vector extensions.
    (vget_lane_f64, vdupd_lane_f64, vmulq_lane_f64, ): Use gcc extensions,
    add range check using __builtin_aarch64_im_lane_boundsi.
    (vfma_lane_f64, vfmad_lane_f64, vfma_laneq_f64, vfmaq_lane_f64,
    vfms_lane_f64, vfmsd_lane_f64, vfms_laneq_f64, vfmsq_lane_f64): Fix
    type signature, use gcc vector extensions.
    (vreinterpret_p8_f64, vreinterpret_p16_f64, vreinterpret_f32_f64,
    vreinterpret_f64_f32, vreinterpret_f64_p8, vreinterpret_f64_p16,
    vreinterpret_f64_s8, vreinterpret_f64_s16, vreinterpret_f64_s32,
    vreinterpret_f64_s64, vreinterpret_f64_u8, vreinterpret_f64_u16,
    vreinterpret_f64_u32, vreinterpret_f64_u64, vreinterpret_s8_f64,
    vreinterpret_s16_f64, vreinterpret_s32_f64, vreinterpret_s64_f64,
    vreinterpret_u8_f64, vreinterpret_u16_f64, vreinterpret_u32_f64,
    vreinterpret_u64_f64): Use v1df builtin not df.

gcc/testsuite/ChangeLog:
    * g++.dg/abi/mangle-neon-aarch64.C: Also test mangling of float64x1_t.
    * gcc.target/aarch64/aapcs/test_64x1_1.c: New test.
    * gcc.target/aarch64/aapcs/func-ret-64x1_1.c: New test.
    * gcc.target/aarch64/simd/ext_f64_1.c (main): Compare vector elements.
    * gcc.target/aarch64/vadd_f64.c: Rewrite with macro to use vector types.
    * gcc.target/aarch64/vsub_f64.c: Likewise.
    * gcc.target/aarch64/vdiv_f.c (INDEX*, RUN_TEST): Remove indexing scheme
    as now the same for all variants.
    * gcc.target/aarch64/vrnd_f64_1.c (compare_f64): Return float64_t not
    float64x1_t.

Added:
    trunk/gcc/testsuite/gcc.target/aarch64/aapcs64/func-ret-64x1_1.c
    trunk/gcc/testsuite/gcc.target/aarch64/aapcs64/test_64x1_1.c
Modified:
    trunk/gcc/ChangeLog
    trunk/gcc/config/aarch64/aarch64-builtins.c
    trunk/gcc/config/aarch64/aarch64-simd-builtins.def
    trunk/gcc/config/aarch64/aarch64-simd.md
    trunk/gcc/config/aarch64/aarch64.c
    trunk/gcc/config/aarch64/arm_neon.h
    trunk/gcc/config/aarch64/iterators.md
    trunk/gcc/testsuite/ChangeLog
    trunk/gcc/testsuite/g++.dg/abi/mangle-neon-aarch64.C
    trunk/gcc/testsuite/gcc.target/aarch64/simd/ext_f64_1.c
    trunk/gcc/testsuite/gcc.target/aarch64/vadd_f64.c
    trunk/gcc/testsuite/gcc.target/aarch64/vdiv_f.c
    trunk/gcc/testsuite/gcc.target/aarch64/vrnd_f64_1.c
    trunk/gcc/testsuite/gcc.target/aarch64/vsub_f64.c


  parent reply	other threads:[~2014-06-23 12:47 UTC|newest]

Thread overview: 11+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2014-04-11 14:24 [Bug target/60825] New: " yufeng at gcc dot gnu.org
2014-04-11 14:30 ` [Bug target/60825] " yufeng at gcc dot gnu.org
2014-04-11 14:33 ` yufeng at gcc dot gnu.org
2014-04-11 16:03 ` pinskia at gcc dot gnu.org
2014-06-23 12:47 ` alalaw01 at gcc dot gnu.org [this message]
2014-06-23 14:08 ` alalaw01 at gcc dot gnu.org
2014-07-16 13:31 ` jakub at gcc dot gnu.org
2014-10-30 10:43 ` jakub at gcc dot gnu.org
2015-06-26 20:10 ` jakub at gcc dot gnu.org
2015-06-26 20:36 ` jakub at gcc dot gnu.org
2015-06-26 21:29 ` pinskia at gcc dot gnu.org

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=bug-60825-4-KjoJAukB4b@http.gcc.gnu.org/bugzilla/ \
    --to=gcc-bugzilla@gcc.gnu.org \
    --cc=gcc-bugs@gcc.gnu.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).