mirror of
git://gcc.gnu.org/git/gcc.git
synced 2025-04-23 02:00:32 +08:00
[Patch AArch64] Improve SIMD concatenation with zeroes
gcc/ * config/aarch64/aarch64-simd.md (*aarch64_combinez<mode>): Add alternatives for reads from memory and moves from general-purpose registers. (*aarch64_combinez_be<mode>): Likewise. gcc/testsuite/ * gcc.target/aarch64/vect_combine_zeroes_1.c: New. From-SVN: r228374
This commit is contained in:
parent
547bbe4977
commit
c0233c783d
@ -1,3 +1,10 @@
|
||||
2015-10-02 James Greenhalgh <james.greenhalgh@arm.com>
|
||||
|
||||
* config/aarch64/aarch64-simd.md (*aarch64_combinez<mode>): Add
|
||||
alternatives for reads from memory and moves from general-purpose
|
||||
registers.
|
||||
(*aarch64_combinez_be<mode>): Likewise.
|
||||
|
||||
2015-10-02 Kai Tietz <ktietz70@googlemail.com>
|
||||
|
||||
PR target/51726
|
||||
|
@ -2530,23 +2530,33 @@
|
||||
;; dest vector.
|
||||
|
||||
(define_insn "*aarch64_combinez<mode>"
|
||||
[(set (match_operand:<VDBL> 0 "register_operand" "=&w")
|
||||
[(set (match_operand:<VDBL> 0 "register_operand" "=w,w,w")
|
||||
(vec_concat:<VDBL>
|
||||
(match_operand:VD_BHSI 1 "register_operand" "w")
|
||||
(match_operand:VD_BHSI 2 "aarch64_simd_imm_zero" "Dz")))]
|
||||
(match_operand:VD_BHSI 1 "general_operand" "w,r,m")
|
||||
(match_operand:VD_BHSI 2 "aarch64_simd_imm_zero" "Dz,Dz,Dz")))]
|
||||
"TARGET_SIMD && !BYTES_BIG_ENDIAN"
|
||||
"mov\\t%0.8b, %1.8b"
|
||||
[(set_attr "type" "neon_move<q>")]
|
||||
"@
|
||||
mov\\t%0.8b, %1.8b
|
||||
fmov\t%d0, %1
|
||||
ldr\\t%d0, %1"
|
||||
[(set_attr "type" "neon_move<q>, neon_from_gp, neon_load1_1reg")
|
||||
(set_attr "simd" "yes,*,yes")
|
||||
(set_attr "fp" "*,yes,*")]
|
||||
)
|
||||
|
||||
(define_insn "*aarch64_combinez_be<mode>"
|
||||
[(set (match_operand:<VDBL> 0 "register_operand" "=&w")
|
||||
[(set (match_operand:<VDBL> 0 "register_operand" "=w,w,w")
|
||||
(vec_concat:<VDBL>
|
||||
(match_operand:VD_BHSI 2 "aarch64_simd_imm_zero" "Dz")
|
||||
(match_operand:VD_BHSI 1 "register_operand" "w")))]
|
||||
(match_operand:VD_BHSI 2 "aarch64_simd_imm_zero" "Dz,Dz,Dz")
|
||||
(match_operand:VD_BHSI 1 "general_operand" "w,r,m")))]
|
||||
"TARGET_SIMD && BYTES_BIG_ENDIAN"
|
||||
"mov\\t%0.8b, %1.8b"
|
||||
[(set_attr "type" "neon_move<q>")]
|
||||
"@
|
||||
mov\\t%0.8b, %1.8b
|
||||
fmov\t%d0, %1
|
||||
ldr\\t%d0, %1"
|
||||
[(set_attr "type" "neon_move<q>, neon_from_gp, neon_load1_1reg")
|
||||
(set_attr "simd" "yes,*,yes")
|
||||
(set_attr "fp" "*,yes,*")]
|
||||
)
|
||||
|
||||
(define_expand "aarch64_combine<mode>"
|
||||
|
@ -1,3 +1,7 @@
|
||||
2015-10-02 James Greenhalgh <james.greenhalgh@arm.com>
|
||||
|
||||
* gcc.target/aarch64/vect_combine_zeroes_1.c: New.
|
||||
|
||||
2015-10-02 Kai Tietz <ktietz70@googlemail.com>
|
||||
|
||||
PR target/51726
|
||||
|
24
gcc/testsuite/gcc.target/aarch64/vect_combine_zeroes_1.c
Normal file
24
gcc/testsuite/gcc.target/aarch64/vect_combine_zeroes_1.c
Normal file
@ -0,0 +1,24 @@
|
||||
/* { dg-options "-O2 --save-temps" } */
|
||||
|
||||
#include "arm_neon.h"
|
||||
|
||||
int32x4_t
|
||||
foo (int32x2_t *x)
|
||||
{
|
||||
int32x2_t i = *x;
|
||||
int32x2_t zeroes = vcreate_s32 (0l);
|
||||
int32x4_t ret = vcombine_s32 (i, zeroes);
|
||||
return ret;
|
||||
}
|
||||
|
||||
int32x4_t
|
||||
bar (int64_t x)
|
||||
{
|
||||
int32x2_t i = vcreate_s32 (x);
|
||||
int32x2_t zeroes = vcreate_s32 (0l);
|
||||
int32x4_t ret = vcombine_s32 (i, zeroes);
|
||||
return ret;
|
||||
}
|
||||
|
||||
/* { dg-final { scan-assembler-not "mov\tv\[0-9\]+.8b, v\[0-9\]+.8b" } } */
|
||||
|
Loading…
x
Reference in New Issue
Block a user