1  #include <arm_neon.h>
       2  #include "arm-neon-ref.h"
       3  #include "compute-ref-data.h"
       4  
       5  #define INSN_NAME vmin
       6  #define TEST_MSG "VMIN/VMINQ"
       7  
       8  #define HAS_FLOAT_VARIANT
       9  
      10  #if defined (__ARM_FEATURE_FP16_VECTOR_ARITHMETIC)
      11  #define HAS_FLOAT16_VARIANT
      12  #endif
      13  
      14  /* Expected results.  */
      15  VECT_VAR_DECL(expected,int,8,8) [] = { 0xf0, 0xf1, 0xf2, 0xf3,
      16  				       0xf3, 0xf3, 0xf3, 0xf3 };
      17  VECT_VAR_DECL(expected,int,16,4) [] = { 0xfff0, 0xfff1, 0xfff2, 0xfff2 };
      18  VECT_VAR_DECL(expected,int,32,2) [] = { 0xfffffff0, 0xfffffff0 };
      19  VECT_VAR_DECL(expected,uint,8,8) [] = { 0xf0, 0xf1, 0xf2, 0xf3,
      20  					0xf3, 0xf3, 0xf3, 0xf3 };
      21  VECT_VAR_DECL(expected,uint,16,4) [] = { 0xfff0, 0xfff1, 0xfff1, 0xfff1 };
      22  VECT_VAR_DECL(expected,uint,32,2) [] = { 0xfffffff0, 0xfffffff0 };
      23  #if defined (__ARM_FEATURE_FP16_VECTOR_ARITHMETIC)
      24  VECT_VAR_DECL(expected, hfloat, 16, 4) [] = { 0xcc00, 0xcbc0, 0xcbc0, 0xcbc0 };
      25  #endif
      26  VECT_VAR_DECL(expected,hfloat,32,2) [] = { 0xc1800000, 0xc1780000 };
      27  VECT_VAR_DECL(expected,int,8,16) [] = { 0xf0, 0xf1, 0xf2, 0xf3,
      28  					0xf4, 0xf4, 0xf4, 0xf4,
      29  					0xf4, 0xf4, 0xf4, 0xf4,
      30  					0xf4, 0xf4, 0xf4, 0xf4 };
      31  VECT_VAR_DECL(expected,int,16,8) [] = { 0xfff0, 0xfff1, 0xfff2, 0xfff3,
      32  					0xfff3, 0xfff3, 0xfff3, 0xfff3 };
      33  VECT_VAR_DECL(expected,int,32,4) [] = { 0xfffffff0, 0xfffffff1,
      34  					0xfffffff1, 0xfffffff1 };
      35  VECT_VAR_DECL(expected,uint,8,16) [] = { 0xf0, 0xf1, 0xf2, 0xf3,
      36  					 0xf4, 0xf5, 0xf6, 0xf7,
      37  					 0xf8, 0xf9, 0xf9, 0xf9,
      38  					 0xf9, 0xf9, 0xf9, 0xf9 };
      39  VECT_VAR_DECL(expected,uint,16,8) [] = { 0xfff0, 0xfff1, 0xfff2, 0xfff2,
      40  					 0xfff2, 0xfff2, 0xfff2, 0xfff2 };
      41  #if defined (__ARM_FEATURE_FP16_VECTOR_ARITHMETIC)
      42  VECT_VAR_DECL(expected, hfloat, 16, 8) [] = { 0xcc00, 0xcb80, 0xcb40, 0xcb40,
      43  					      0xcb40, 0xcb40, 0xcb40, 0xcb40 };
      44  #endif
      45  VECT_VAR_DECL(expected,uint,32,4) [] = { 0xfffffff0, 0xfffffff1,
      46  					 0xfffffff1, 0xfffffff1 };
      47  VECT_VAR_DECL(expected,hfloat,32,4) [] = { 0xc1800000, 0xc1700000,
      48  					   0xc1680000, 0xc1680000 };
      49  /* Expected results with special FP values.  */
      50  #if defined (__ARM_FEATURE_FP16_VECTOR_ARITHMETIC)
      51  VECT_VAR_DECL(expected_nan, hfloat, 16, 8) [] = { 0x7e00, 0x7e00,
      52  						  0x7e00, 0x7e00,
      53  						  0x7e00, 0x7e00,
      54  						  0x7e00, 0x7e00 };
      55  VECT_VAR_DECL(expected_mnan, hfloat, 16, 8) [] = { 0x7e00, 0x7e00,
      56  						   0x7e00, 0x7e00,
      57  						   0x7e00, 0x7e00,
      58  						   0x7e00, 0x7e00 };
      59  VECT_VAR_DECL(expected_inf, hfloat, 16, 8) [] = { 0x3c00, 0x3c00,
      60  						  0x3c00, 0x3c00,
      61  						  0x3c00, 0x3c00,
      62  						  0x3c00, 0x3c00 };
      63  VECT_VAR_DECL(expected_minf, hfloat, 16, 8) [] = { 0xfc00, 0xfc00,
      64  						   0xfc00, 0xfc00,
      65  						   0xfc00, 0xfc00,
      66  						   0xfc00, 0xfc00 };
      67  VECT_VAR_DECL(expected_zero1, hfloat, 16, 8) [] = { 0x8000, 0x8000,
      68  						    0x8000, 0x8000,
      69  						    0x8000, 0x8000,
      70  						    0x8000, 0x8000 };
      71  VECT_VAR_DECL(expected_zero2, hfloat, 16, 8) [] = { 0x8000, 0x8000,
      72  						    0x8000, 0x8000,
      73  						    0x8000, 0x8000,
      74  						    0x8000, 0x8000 };
      75  #endif
      76  VECT_VAR_DECL(expected_nan,hfloat,32,4) [] = { 0x7fc00000, 0x7fc00000,
      77  					       0x7fc00000, 0x7fc00000 };
      78  VECT_VAR_DECL(expected_mnan,hfloat,32,4) [] = { 0x7fc00000, 0x7fc00000,
      79  						0x7fc00000, 0x7fc00000 };
      80  VECT_VAR_DECL(expected_inf,hfloat,32,4) [] = { 0x3f800000, 0x3f800000,
      81  					       0x3f800000, 0x3f800000 };
      82  VECT_VAR_DECL(expected_minf,hfloat,32,4) [] = { 0xff800000, 0xff800000,
      83  						0xff800000, 0xff800000 };
      84  VECT_VAR_DECL(expected_zero1,hfloat,32,4) [] = { 0x80000000, 0x80000000,
      85  						 0x80000000, 0x80000000 };
      86  VECT_VAR_DECL(expected_zero2,hfloat,32,4) [] = { 0x80000000, 0x80000000,
      87  						 0x80000000, 0x80000000 };
      88  
      89  #include "binary_op_no64.inc"