1  /* { dg-do run } */
       2  /* { dg-require-effective-target arm_v8_2a_fp16_scalar_hw } */
       3  /* { dg-add-options arm_v8_2a_fp16_scalar }  */
       4  /* { dg-skip-if "" { arm*-*-* } } */
       5  
       6  #include <arm_fp16.h>
       7  
       8  /* Input values.  */
       9  #define A 123.4
      10  #define B 567.8
      11  #define C 34.8
      12  #define D 1024
      13  #define E 663.1
      14  #define F 144.0
      15  #define G 4.8
      16  #define H 77
      17  
      18  #define RECP_A 0x2028 /* 1/A.  */
      19  #define RECP_B 0x1734 /* 1/B.  */
      20  #define RECP_C 0x275C /* 1/C.  */
      21  #define RECP_D 0x13FC /* 1/D.  */
      22  #define RECP_E 0x162C /* 1/E.  */
      23  #define RECP_F 0x1F18 /* 1/F.  */
      24  #define RECP_G 0x32A8 /* 1/G.  */
      25  #define RECP_H 0x22A4 /* 1/H.  */
      26  
      27  float16_t input[] = { A, B, C, D, E, F, G, H };
      28  uint16_t expected[] = { RECP_A, RECP_B, RECP_C, RECP_D,
      29  		        RECP_E, RECP_F, RECP_G, RECP_H };
      30  
      31  #define TEST_MSG "VRECPEH_F16"
      32  #define INSN_NAME vrecpeh_f16
      33  
      34  #define INPUT input
      35  #define EXPECTED expected
      36  
      37  #define INPUT_TYPE float16_t
      38  #define OUTPUT_TYPE float16_t
      39  #define OUTPUT_TYPE_SIZE 16
      40  
      41  /* Include the template for unary scalar operations.  */
      42  #include "unary_scalar_op.inc"