/* { 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 /* Input values. */ int16_t input[] = { 1, 10, 48, 100, -1, -10, 7, -7 }; /* Expected results (16-bit hexadecimal representation). */ uint16_t expected_1[] = { 0x3800 /* 0.5. */, 0x4500 /* 5. */, 0x4E00 /* 24. */, 0x5240 /* 50. */, 0xB800 /* -0.5. */, 0xC500 /* -5. */, 0x4300 /* 3.5. */, 0xC300 /* -3.5. */ }; uint16_t expected_2[] = { 0x3400 /* 0.25. */, 0x4100 /* 2.5. */, 0x4A00 /* 12. */, 0x4E40 /* 25. */, 0xB400 /* -0.25. */, 0xC100 /* -2.5. */, 0x3F00 /* 1.75. */, 0xBF00 /* -1.75. */ }; #define TEST_MSG "VCVTH_N_F16_S16" #define INSN_NAME vcvth_n_f16_s16 #define INPUT input #define EXPECTED_1 expected_1 #define EXPECTED_2 expected_2 #define INPUT_TYPE int16_t #define OUTPUT_TYPE float16_t #define OUTPUT_TYPE_SIZE 16 #define SCALAR_OPERANDS #define SCALAR_1 1 #define SCALAR_2 2 /* Include the template for unary scalar operations. */ #include "unary_scalar_op.inc"