(root)/
gcc-13.2.0/
gcc/
testsuite/
gcc.target/
aarch64/
advsimd-intrinsics/
vqrdmlsh.c
       1  /* { dg-require-effective-target arm_v8_1a_neon_hw } */
       2  /* { dg-add-options arm_v8_1a_neon } */
       3  
       4  #include <arm_neon.h>
       5  #include "arm-neon-ref.h"
       6  #include "compute-ref-data.h"
       7  
       8  /* Expected results.  */
       9  VECT_VAR_DECL (expected, int, 16, 4) [] = { 0xc70d, 0xc70e, 0xc70f, 0xc710 };
      10  VECT_VAR_DECL (expected, int, 32, 2) [] = { 0xfffffff0, 0xfffffff1 };
      11  VECT_VAR_DECL (expected, int, 16, 8) [] = { 0xfff0, 0xfff1, 0xfff2, 0xfff3,
      12  					    0xfff4, 0xfff5, 0xfff6, 0xfff7 };
      13  VECT_VAR_DECL (expected, int, 32, 4) [] = { 0xfffffff0, 0xfffffff1,
      14  					    0xfffffff2, 0xfffffff3 };
      15  
      16  /* Expected results when multiplication saturates.  */
      17  VECT_VAR_DECL (expected_mul, int, 16, 4) [] = { 0x8000, 0x8000,
      18  						0x8000, 0x8000 };
      19  VECT_VAR_DECL (expected_mul, int, 32, 2) [] = { 0x80000000, 0x80000000 };
      20  VECT_VAR_DECL (expected_mul, int, 16, 8) [] = { 0x8000, 0x8000,
      21  						0x8000, 0x8000,
      22  						0x8000, 0x8000,
      23  						0x8000, 0x8000 };
      24  VECT_VAR_DECL (expected_mul, int, 32, 4) [] = { 0x80000000, 0x80000000,
      25  						0x80000000, 0x80000000 };
      26  
      27  /* Expected results when rounding should not cause saturation.  */
      28  VECT_VAR_DECL (expected_round, int, 16, 4) [] = { 0x8000, 0x8000,
      29  						  0x8000, 0x8000 };
      30  VECT_VAR_DECL (expected_round, int, 32, 2) [] = { 0x80000000, 0x80000000 };
      31  VECT_VAR_DECL (expected_round, int, 16, 8) [] = { 0x8000, 0x8000,
      32  						  0x8000, 0x8000,
      33  						  0x8000, 0x8000,
      34  						  0x8000, 0x8000 };
      35  VECT_VAR_DECL (expected_round, int, 32, 4) [] = { 0x80000000, 0x80000000,
      36  						  0x80000000, 0x80000000 };
      37  
      38  #define INSN vqrdmlsh
      39  #define TEST_MSG "VQRDMLSH"
      40  
      41  #include "vqrdmlXh.inc"