| // RUN: %clang_cc1 -triple spir-unknown-unknown -cl-std=CL3.0 -fdeclare-opencl-builtins -verify -fsyntax-only %s |
| |
| // Keep this test header-free so it exercises OpenCLBuiltins.td instead of |
| // declarations from opencl-c.h. |
| |
| typedef unsigned int uint; |
| typedef unsigned char uchar; |
| typedef int int2 __attribute__((ext_vector_type(2))); |
| typedef char char3 __attribute__((ext_vector_type(3))); |
| typedef char char8 __attribute__((ext_vector_type(8))); |
| typedef char char16 __attribute__((ext_vector_type(16))); |
| typedef uchar uchar2 __attribute__((ext_vector_type(2))); |
| typedef uchar uchar4 __attribute__((ext_vector_type(4))); |
| typedef uchar uchar8 __attribute__((ext_vector_type(8))); |
| typedef uchar uchar16 __attribute__((ext_vector_type(16))); |
| |
| char3 test_broadcast_char3(char3 value) { |
| return intel_sub_group_broadcast(value, 1u); |
| } |
| |
| uchar8 test_broadcast_uchar8(uchar8 value) { |
| return intel_sub_group_broadcast(value, 1u); |
| } |
| |
| char16 test_shuffle_char16(char16 value) { |
| return intel_sub_group_shuffle(value, 1u); |
| } |
| |
| uchar16 test_shuffle_xor_uchar16(uchar16 value) { |
| return intel_sub_group_shuffle_xor(value, 1u); |
| } |
| |
| char16 test_shuffle_down_char16(char16 current, char16 next) { |
| return intel_sub_group_shuffle_down(current, next, 1u); |
| } |
| |
| uchar16 test_shuffle_up_uchar16(uchar16 previous, uchar16 current) { |
| return intel_sub_group_shuffle_up(previous, current, 1u); |
| } |
| |
| char test_collectives_char(char value) { |
| value = intel_sub_group_reduce_add(value); |
| value = intel_sub_group_reduce_min(value); |
| value = intel_sub_group_reduce_max(value); |
| value = intel_sub_group_scan_exclusive_add(value); |
| value = intel_sub_group_scan_exclusive_min(value); |
| value = intel_sub_group_scan_exclusive_max(value); |
| value = intel_sub_group_scan_inclusive_add(value); |
| value = intel_sub_group_scan_inclusive_min(value); |
| value = intel_sub_group_scan_inclusive_max(value); |
| return value; |
| } |
| |
| uchar test_collectives_uchar(uchar value) { |
| value = intel_sub_group_reduce_add(value); |
| value = intel_sub_group_reduce_min(value); |
| value = intel_sub_group_reduce_max(value); |
| value = intel_sub_group_scan_exclusive_add(value); |
| value = intel_sub_group_scan_exclusive_min(value); |
| value = intel_sub_group_scan_exclusive_max(value); |
| value = intel_sub_group_scan_inclusive_add(value); |
| value = intel_sub_group_scan_inclusive_min(value); |
| value = intel_sub_group_scan_inclusive_max(value); |
| return value; |
| } |
| |
| uchar test_block_read_uc_global(const __global uchar *in) { |
| return intel_sub_group_block_read_uc(in); |
| } |
| |
| uchar2 test_block_read_uc2_global(const __global uchar *in) { |
| return intel_sub_group_block_read_uc2(in); |
| } |
| |
| uchar4 test_block_read_uc4_image(read_only image2d_t image, int2 coord) { |
| return intel_sub_group_block_read_uc4(image, coord); |
| } |
| |
| uchar8 test_block_read_uc8_rw_image(read_write image2d_t image, int2 coord) { |
| return intel_sub_group_block_read_uc8(image, coord); |
| } |
| |
| uchar16 test_block_read_uc16_rw_image(read_write image2d_t image, int2 coord) { |
| return intel_sub_group_block_read_uc16(image, coord); |
| } |
| |
| void test_block_write_uc(__global uchar *out, write_only image2d_t image, |
| read_write image2d_t rw, int2 coord, uchar value, |
| uchar2 value2, uchar4 value4, uchar8 value8, |
| uchar16 value16) { |
| intel_sub_group_block_write_uc(out, value); |
| intel_sub_group_block_write_uc2(out, value2); |
| intel_sub_group_block_write_uc4(out, value4); |
| intel_sub_group_block_write_uc8(out, value8); |
| intel_sub_group_block_write_uc16(out, value16); |
| intel_sub_group_block_write_uc(image, coord, value); |
| intel_sub_group_block_write_uc2(image, coord, value2); |
| intel_sub_group_block_write_uc4(image, coord, value4); |
| intel_sub_group_block_write_uc8(rw, coord, value8); |
| intel_sub_group_block_write_uc16(rw, coord, value16); |
| } |
| |
| void test_broadcast_char16_rejected(char16 value) { |
| (void)intel_sub_group_broadcast(value, 0u); // expected-error{{no matching function for call to 'intel_sub_group_broadcast'}} |
| // expected-note@-1 0+{{candidate function not viable}} |
| } |