This change removes code that switches the operands in bigendian mode erroneously. This fixes the related test also.
gcc/ChangeLog: PR target/114890 * config/aarch64/aarch64-simd.md: Remove bigendian operand swap. gcc/testsuite/ChangeLog: PR target/114890 * gcc.target/aarch64/vector_intrinsics_asm.c: Remove xfail. --- gcc/config/aarch64/aarch64-simd.md | 2 -- gcc/testsuite/gcc.target/aarch64/vector_intrinsics_asm.c | 2 +- 2 files changed, 1 insertion(+), 3 deletions(-)
diff --git a/gcc/config/aarch64/aarch64-simd.md b/gcc/config/aarch64/aarch64-simd.md index 868f4486218..095ef3228cc 100644 --- a/gcc/config/aarch64/aarch64-simd.md +++ b/gcc/config/aarch64/aarch64-simd.md @@ -7341,8 +7341,6 @@ (define_expand "aarch64_addp<mode>" nunits /= 2; rtx par_even = aarch64_gen_stepped_int_parallel (nunits, 0, 2); rtx par_odd = aarch64_gen_stepped_int_parallel (nunits, 1, 2); - if (BYTES_BIG_ENDIAN) - std::swap (operands[1], operands[2]); emit_insn (gen_aarch64_addp<mode>_insn (operands[0], operands[1], operands[2], par_even, par_odd)); DONE; diff --git a/gcc/testsuite/gcc.target/aarch64/vector_intrinsics_asm.c b/gcc/testsuite/gcc.target/aarch64/vector_intrinsics_asm.c index b7d5620abab..e3dcd0830c8 100644 --- a/gcc/testsuite/gcc.target/aarch64/vector_intrinsics_asm.c +++ b/gcc/testsuite/gcc.target/aarch64/vector_intrinsics_asm.c @@ -1,6 +1,6 @@ /* { dg-do compile } */ /* { dg-options "-O2" } */ -/* { dg-final { check-function-bodies "**" "" "" { xfail be } } } */ +/* { dg-final { check-function-bodies "**" "" "" } } */ #include "arm_neon.h"