| // RUN: %clang_cc1 -triple aarch64-linux-gnu -target-feature +neon -target-feature +bf16 -ffreestanding -fsyntax-only -verify %s |
| |
| #include <arm_neon.h> |
| #include <arm_bf16.h> |
| // REQUIRES: aarch64-registered-target |
| |
| |
| void test_set_all_lanes_to_the_same_value_bf16(bfloat16x8_t arg_b16x8, bfloat16x4_t arg_b16x4) { |
| vdup_lane_bf16(arg_b16x4, 0); |
| vdup_lane_bf16(arg_b16x4, 3); |
| vdup_lane_bf16(arg_b16x4, -1); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vdup_lane_bf16(arg_b16x4, 4); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| |
| vdupq_lane_bf16(arg_b16x4, 0); |
| vdupq_lane_bf16(arg_b16x4, 3); |
| vdupq_lane_bf16(arg_b16x4, -1); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vdupq_lane_bf16(arg_b16x4, 4); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| |
| vdup_laneq_bf16(arg_b16x8, 0); |
| vdup_laneq_bf16(arg_b16x8, 7); |
| vdup_laneq_bf16(arg_b16x8, -1); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vdup_laneq_bf16(arg_b16x8, 8); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| |
| vdupq_laneq_bf16(arg_b16x8, 0); |
| vdupq_laneq_bf16(arg_b16x8, 7); |
| vdupq_laneq_bf16(arg_b16x8, -1); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vdupq_laneq_bf16(arg_b16x8, 8); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| |
| vduph_lane_bf16(arg_b16x4, 0); |
| vduph_lane_bf16(arg_b16x4, 3); |
| vduph_lane_bf16(arg_b16x4, -1); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vduph_lane_bf16(arg_b16x4, 4); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| |
| vduph_laneq_bf16(arg_b16x8, 0); |
| vduph_laneq_bf16(arg_b16x8, 7); |
| vduph_laneq_bf16(arg_b16x8, -1); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vduph_laneq_bf16(arg_b16x8, 8); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| |
| } |
| |
| void test_split_vectors_bf16(bfloat16x8_t arg_b16x8, bfloat16x4_t arg_b16x4) { |
| vget_lane_bf16(arg_b16x4, 0); |
| vget_lane_bf16(arg_b16x4, 3); |
| vget_lane_bf16(arg_b16x4, -1); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vget_lane_bf16(arg_b16x4, 4); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| |
| vgetq_lane_bf16(arg_b16x8, 0); |
| vgetq_lane_bf16(arg_b16x8, 7); |
| vgetq_lane_bf16(arg_b16x8, -1); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vgetq_lane_bf16(arg_b16x8, 8); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| |
| } |
| |
| void test_set_vector_lane_bf16(bfloat16x8_t arg_b16x8, bfloat16x4_t arg_b16x4, bfloat16_t arg_b16) { |
| vset_lane_bf16(arg_b16, arg_b16x4, 0); |
| vset_lane_bf16(arg_b16, arg_b16x4, 3); |
| vset_lane_bf16(arg_b16, arg_b16x4, -1); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vset_lane_bf16(arg_b16, arg_b16x4, 4); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| |
| vsetq_lane_bf16(arg_b16, arg_b16x8, 0); |
| vsetq_lane_bf16(arg_b16, arg_b16x8, 7); |
| vsetq_lane_bf16(arg_b16, arg_b16x8, -1); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vsetq_lane_bf16(arg_b16, arg_b16x8, 8); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| |
| } |
| |
| void test_copy_vector_lane_bf16(bfloat16x8_t arg_b16x8, bfloat16x4_t arg_b16x4) { |
| vcopy_lane_bf16(arg_b16x4, 0, arg_b16x4, 0); |
| vcopy_lane_bf16(arg_b16x4, 3, arg_b16x4, 0); |
| vcopy_lane_bf16(arg_b16x4, -1, arg_b16x4, 0); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vcopy_lane_bf16(arg_b16x4, 4, arg_b16x4, 0); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vcopy_lane_bf16(arg_b16x4, 0, arg_b16x4, 3); |
| vcopy_lane_bf16(arg_b16x4, 0, arg_b16x4, -1); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vcopy_lane_bf16(arg_b16x4, 0, arg_b16x4, 4); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| |
| vcopyq_lane_bf16(arg_b16x8, 0, arg_b16x4, 0); |
| vcopyq_lane_bf16(arg_b16x8, 7, arg_b16x4, 0); |
| vcopyq_lane_bf16(arg_b16x8, -1, arg_b16x4, 0); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vcopyq_lane_bf16(arg_b16x8, 8, arg_b16x4, 0); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vcopyq_lane_bf16(arg_b16x8, 0, arg_b16x4, 3); |
| vcopyq_lane_bf16(arg_b16x8, 0, arg_b16x4, -1); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vcopyq_lane_bf16(arg_b16x8, 0, arg_b16x4, 4); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| |
| vcopy_laneq_bf16(arg_b16x4, 0, arg_b16x8, 0); |
| vcopy_laneq_bf16(arg_b16x4, 3, arg_b16x8, 0); |
| vcopy_laneq_bf16(arg_b16x4, -1, arg_b16x8, 0); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vcopy_laneq_bf16(arg_b16x4, 4, arg_b16x8, 0); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vcopy_laneq_bf16(arg_b16x4, 0, arg_b16x8, 7); |
| vcopy_laneq_bf16(arg_b16x4, 0, arg_b16x8, -1); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vcopy_laneq_bf16(arg_b16x4, 0, arg_b16x8, 8); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| |
| vcopyq_laneq_bf16(arg_b16x8, 0, arg_b16x8, 0); |
| vcopyq_laneq_bf16(arg_b16x8, 7, arg_b16x8, 0); |
| vcopyq_laneq_bf16(arg_b16x8, -1, arg_b16x8, 0); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vcopyq_laneq_bf16(arg_b16x8, 8, arg_b16x8, 0); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vcopyq_laneq_bf16(arg_b16x8, 0, arg_b16x8, 7); |
| vcopyq_laneq_bf16(arg_b16x8, 0, arg_b16x8, -1); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vcopyq_laneq_bf16(arg_b16x8, 0, arg_b16x8, 8); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| |
| } |
| |
| void test_load_bf16(bfloat16x4_t arg_b16x4, bfloat16x4x4_t arg_b16x4x4, bfloat16x8x4_t arg_b16x8x4, |
| bfloat16x4x3_t arg_b16x4x3, bfloat16x8_t arg_b16x8, bfloat16_t* arg_b16_ptr, |
| bfloat16x8x3_t arg_b16x8x3, bfloat16x4x2_t arg_b16x4x2, bfloat16x8x2_t arg_b16x8x2) { |
| vld1_lane_bf16(arg_b16_ptr, arg_b16x4, 0); |
| vld1_lane_bf16(arg_b16_ptr, arg_b16x4, 3); |
| vld1_lane_bf16(arg_b16_ptr, arg_b16x4, -1); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vld1_lane_bf16(arg_b16_ptr, arg_b16x4, 4); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| |
| vld1q_lane_bf16(arg_b16_ptr, arg_b16x8, 0); |
| vld1q_lane_bf16(arg_b16_ptr, arg_b16x8, 7); |
| vld1q_lane_bf16(arg_b16_ptr, arg_b16x8, -1); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vld1q_lane_bf16(arg_b16_ptr, arg_b16x8, 8); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| |
| vld2_lane_bf16(arg_b16_ptr, arg_b16x4x2, 0); |
| vld2_lane_bf16(arg_b16_ptr, arg_b16x4x2, 3); |
| vld2_lane_bf16(arg_b16_ptr, arg_b16x4x2, -1); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vld2_lane_bf16(arg_b16_ptr, arg_b16x4x2, 4); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| |
| vld2q_lane_bf16(arg_b16_ptr, arg_b16x8x2, 0); |
| vld2q_lane_bf16(arg_b16_ptr, arg_b16x8x2, 7); |
| vld2q_lane_bf16(arg_b16_ptr, arg_b16x8x2, -1); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vld2q_lane_bf16(arg_b16_ptr, arg_b16x8x2, 8); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| |
| vld3_lane_bf16(arg_b16_ptr, arg_b16x4x3, 0); |
| vld3_lane_bf16(arg_b16_ptr, arg_b16x4x3, 3); |
| vld3_lane_bf16(arg_b16_ptr, arg_b16x4x3, -1); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vld3_lane_bf16(arg_b16_ptr, arg_b16x4x3, 4); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| |
| vld3q_lane_bf16(arg_b16_ptr, arg_b16x8x3, 0); |
| vld3q_lane_bf16(arg_b16_ptr, arg_b16x8x3, 7); |
| vld3q_lane_bf16(arg_b16_ptr, arg_b16x8x3, -1); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vld3q_lane_bf16(arg_b16_ptr, arg_b16x8x3, 8); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| |
| vld4_lane_bf16(arg_b16_ptr, arg_b16x4x4, 0); |
| vld4_lane_bf16(arg_b16_ptr, arg_b16x4x4, 3); |
| vld4_lane_bf16(arg_b16_ptr, arg_b16x4x4, -1); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vld4_lane_bf16(arg_b16_ptr, arg_b16x4x4, 4); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| |
| vld4q_lane_bf16(arg_b16_ptr, arg_b16x8x4, 0); |
| vld4q_lane_bf16(arg_b16_ptr, arg_b16x8x4, 7); |
| vld4q_lane_bf16(arg_b16_ptr, arg_b16x8x4, -1); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vld4q_lane_bf16(arg_b16_ptr, arg_b16x8x4, 8); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| |
| } |
| |
| void test_store_bf16(bfloat16x4_t arg_b16x4, bfloat16x4x4_t arg_b16x4x4, bfloat16x8x4_t arg_b16x8x4, |
| bfloat16x4x3_t arg_b16x4x3, bfloat16x8_t arg_b16x8, bfloat16_t* arg_b16_ptr, |
| bfloat16x8x3_t arg_b16x8x3, bfloat16x4x2_t arg_b16x4x2, bfloat16x8x2_t arg_b16x8x2) { |
| vst1_lane_bf16(arg_b16_ptr, arg_b16x4, 0); |
| vst1_lane_bf16(arg_b16_ptr, arg_b16x4, 3); |
| vst1_lane_bf16(arg_b16_ptr, arg_b16x4, -1); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vst1_lane_bf16(arg_b16_ptr, arg_b16x4, 4); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| |
| vst1q_lane_bf16(arg_b16_ptr, arg_b16x8, 0); |
| vst1q_lane_bf16(arg_b16_ptr, arg_b16x8, 7); |
| vst1q_lane_bf16(arg_b16_ptr, arg_b16x8, -1); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vst1q_lane_bf16(arg_b16_ptr, arg_b16x8, 8); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| |
| vst2_lane_bf16(arg_b16_ptr, arg_b16x4x2, 0); |
| vst2_lane_bf16(arg_b16_ptr, arg_b16x4x2, 3); |
| vst2_lane_bf16(arg_b16_ptr, arg_b16x4x2, -1); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vst2_lane_bf16(arg_b16_ptr, arg_b16x4x2, 4); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| |
| vst2q_lane_bf16(arg_b16_ptr, arg_b16x8x2, 0); |
| vst2q_lane_bf16(arg_b16_ptr, arg_b16x8x2, 7); |
| vst2q_lane_bf16(arg_b16_ptr, arg_b16x8x2, -1); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vst2q_lane_bf16(arg_b16_ptr, arg_b16x8x2, 8); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| |
| vst3_lane_bf16(arg_b16_ptr, arg_b16x4x3, 0); |
| vst3_lane_bf16(arg_b16_ptr, arg_b16x4x3, 3); |
| vst3_lane_bf16(arg_b16_ptr, arg_b16x4x3, -1); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vst3_lane_bf16(arg_b16_ptr, arg_b16x4x3, 4); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| |
| vst3q_lane_bf16(arg_b16_ptr, arg_b16x8x3, 0); |
| vst3q_lane_bf16(arg_b16_ptr, arg_b16x8x3, 7); |
| vst3q_lane_bf16(arg_b16_ptr, arg_b16x8x3, -1); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vst3q_lane_bf16(arg_b16_ptr, arg_b16x8x3, 8); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| |
| vst4_lane_bf16(arg_b16_ptr, arg_b16x4x4, 0); |
| vst4_lane_bf16(arg_b16_ptr, arg_b16x4x4, 3); |
| vst4_lane_bf16(arg_b16_ptr, arg_b16x4x4, -1); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vst4_lane_bf16(arg_b16_ptr, arg_b16x4x4, 4); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| |
| vst4q_lane_bf16(arg_b16_ptr, arg_b16x8x4, 0); |
| vst4q_lane_bf16(arg_b16_ptr, arg_b16x8x4, 7); |
| vst4q_lane_bf16(arg_b16_ptr, arg_b16x8x4, -1); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vst4q_lane_bf16(arg_b16_ptr, arg_b16x8x4, 8); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| |
| } |
| |
| void test_dot_product_f32(bfloat16x8_t arg_b16x8, bfloat16x4_t arg_b16x4, float32x2_t arg_f32x2, float32x4_t arg_f32x4) { |
| vbfdot_lane_f32(arg_f32x2, arg_b16x4, arg_b16x4, 0); |
| vbfdot_lane_f32(arg_f32x2, arg_b16x4, arg_b16x4, 1); |
| vbfdot_lane_f32(arg_f32x2, arg_b16x4, arg_b16x4, -1); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vbfdot_lane_f32(arg_f32x2, arg_b16x4, arg_b16x4, 2); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| |
| vbfdotq_laneq_f32(arg_f32x4, arg_b16x8, arg_b16x8, 0); |
| vbfdotq_laneq_f32(arg_f32x4, arg_b16x8, arg_b16x8, 3); |
| vbfdotq_laneq_f32(arg_f32x4, arg_b16x8, arg_b16x8, -1); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vbfdotq_laneq_f32(arg_f32x4, arg_b16x8, arg_b16x8, 4); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| |
| vbfdot_laneq_f32(arg_f32x2, arg_b16x4, arg_b16x8, 0); |
| vbfdot_laneq_f32(arg_f32x2, arg_b16x4, arg_b16x8, 3); |
| vbfdot_laneq_f32(arg_f32x2, arg_b16x4, arg_b16x8, -1); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vbfdot_laneq_f32(arg_f32x2, arg_b16x4, arg_b16x8, 4); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| |
| vbfdotq_lane_f32(arg_f32x4, arg_b16x8, arg_b16x4, 0); |
| vbfdotq_lane_f32(arg_f32x4, arg_b16x8, arg_b16x4, 1); |
| vbfdotq_lane_f32(arg_f32x4, arg_b16x8, arg_b16x4, -1); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| vbfdotq_lane_f32(arg_f32x4, arg_b16x8, arg_b16x4, 2); // expected-error-re {{argument value {{.*}} is outside the valid range}} |
| |
| } |
| |
| void test_vector_multiply_accumulate_by_scalar_f32(bfloat16x8_t arg_b16x8, bfloat16x4_t arg_b16x4, float32x4_t arg_f32x4) { |
| vbfmlalbq_lane_f32(arg_f32x4, arg_b16x8, arg_b16x4, 0); |
| vbfmlalbq_lane_f32(arg_f32x4, arg_b16x8, arg_b16x4, 3); |
| vbfmlalbq_lane_f32(arg_f32x4, arg_b16x8, arg_b16x4, -1); // expected-error-re +{{argument value {{.*}} is outside the valid range}} |
| vbfmlalbq_lane_f32(arg_f32x4, arg_b16x8, arg_b16x4, 4); // expected-error-re +{{argument value {{.*}} is outside the valid range}} |
| |
| vbfmlalbq_laneq_f32(arg_f32x4, arg_b16x8, arg_b16x8, 0); |
| vbfmlalbq_laneq_f32(arg_f32x4, arg_b16x8, arg_b16x8, 7); |
| vbfmlalbq_laneq_f32(arg_f32x4, arg_b16x8, arg_b16x8, -1); // expected-error-re +{{argument value {{.*}} is outside the valid range}} |
| vbfmlalbq_laneq_f32(arg_f32x4, arg_b16x8, arg_b16x8, 8); // expected-error-re +{{argument value {{.*}} is outside the valid range}} |
| |
| vbfmlaltq_lane_f32(arg_f32x4, arg_b16x8, arg_b16x4, 0); |
| vbfmlaltq_lane_f32(arg_f32x4, arg_b16x8, arg_b16x4, 3); |
| vbfmlaltq_lane_f32(arg_f32x4, arg_b16x8, arg_b16x4, -1); // expected-error-re +{{argument value {{.*}} is outside the valid range}} |
| vbfmlaltq_lane_f32(arg_f32x4, arg_b16x8, arg_b16x4, 4); // expected-error-re +{{argument value {{.*}} is outside the valid range}} |
| |
| vbfmlaltq_laneq_f32(arg_f32x4, arg_b16x8, arg_b16x8, 0); |
| vbfmlaltq_laneq_f32(arg_f32x4, arg_b16x8, arg_b16x8, 7); |
| vbfmlaltq_laneq_f32(arg_f32x4, arg_b16x8, arg_b16x8, -1); // expected-error-re +{{argument value {{.*}} is outside the valid range}} |
| vbfmlaltq_laneq_f32(arg_f32x4, arg_b16x8, arg_b16x8, 8); // expected-error-re +{{argument value {{.*}} is outside the valid range}} |
| |
| } |
| |