blob: 3740d6afa681786762d25bf039bba38f18d0a0f0 [file] [log] [blame]
/* { dg-do run } */
/* { dg-require-effective-target arm_v8_2a_fp16_scalar_hw } */
/* { dg-add-options arm_v8_2a_fp16_scalar } */
/* { dg-skip-if "" { arm*-*-* } } */
#include <arm_fp16.h>
/* Input values. */
#define A 123.4
#define B 567.8
#define C 34.8
#define D 1024
#define E 663.1
#define F 144.0
#define G 4.8
#define H 77
#define RECP_A 0x2028 /* 1/A. */
#define RECP_B 0x1734 /* 1/B. */
#define RECP_C 0x275C /* 1/C. */
#define RECP_D 0x13FC /* 1/D. */
#define RECP_E 0x162C /* 1/E. */
#define RECP_F 0x1F18 /* 1/F. */
#define RECP_G 0x32A8 /* 1/G. */
#define RECP_H 0x22A4 /* 1/H. */
float16_t input[] = { A, B, C, D, E, F, G, H };
uint16_t expected[] = { RECP_A, RECP_B, RECP_C, RECP_D,
RECP_E, RECP_F, RECP_G, RECP_H };
#define TEST_MSG "VRECPEH_F16"
#define INSN_NAME vrecpeh_f16
#define INPUT input
#define EXPECTED expected
#define INPUT_TYPE float16_t
#define OUTPUT_TYPE float16_t
#define OUTPUT_TYPE_SIZE 16
/* Include the template for unary scalar operations. */
#include "unary_scalar_op.inc"