blob: 4b4b4ef97ab243d79205fa19b4fb1e78b276efaa [file] [log] [blame]
Joey Gouly53160cd2017-07-31 15:50:27 +00001// RUN: %clang_cc1 -emit-llvm -cl-ext=+cl_khr_subgroups -O0 -cl-std=CL2.0 -o - %s | FileCheck %s
Xiuli Panbb4d8d32016-01-26 04:03:48 +00002
3// CHECK: %opencl.pipe_t = type opaque
4// CHECK: %opencl.reserve_id_t = type opaque
5
Joey Gouly84ae3362017-07-31 15:15:59 +00006#pragma OPENCL EXTENSION cl_khr_subgroups : enable
7
Xiuli Panbb4d8d32016-01-26 04:03:48 +00008void test1(read_only pipe int p, global int *ptr) {
Alexey Bader465c1892016-09-23 14:20:00 +00009 // CHECK: call i32 @__read_pipe_2(%opencl.pipe_t* %{{.*}}, i8* %{{.*}}, i32 4, i32 4)
Xiuli Panbb4d8d32016-01-26 04:03:48 +000010 read_pipe(p, ptr);
Alexey Bader465c1892016-09-23 14:20:00 +000011 // CHECK: call %opencl.reserve_id_t* @__reserve_read_pipe(%opencl.pipe_t* %{{.*}}, i32 {{.*}}, i32 4, i32 4)
Xiuli Panbb4d8d32016-01-26 04:03:48 +000012 reserve_id_t rid = reserve_read_pipe(p, 2);
Alexey Bader465c1892016-09-23 14:20:00 +000013 // CHECK: call i32 @__read_pipe_4(%opencl.pipe_t* %{{.*}}, %opencl.reserve_id_t* %{{.*}}, i32 {{.*}}, i8* %{{.*}}, i32 4, i32 4)
Xiuli Panbb4d8d32016-01-26 04:03:48 +000014 read_pipe(p, rid, 2, ptr);
Alexey Bader465c1892016-09-23 14:20:00 +000015 // CHECK: call void @__commit_read_pipe(%opencl.pipe_t* %{{.*}}, %opencl.reserve_id_t* %{{.*}}, i32 4, i32 4)
Xiuli Panbb4d8d32016-01-26 04:03:48 +000016 commit_read_pipe(p, rid);
17}
18
19void test2(write_only pipe int p, global int *ptr) {
Alexey Bader465c1892016-09-23 14:20:00 +000020 // CHECK: call i32 @__write_pipe_2(%opencl.pipe_t* %{{.*}}, i8* %{{.*}}, i32 4, i32 4)
Xiuli Panbb4d8d32016-01-26 04:03:48 +000021 write_pipe(p, ptr);
Alexey Bader465c1892016-09-23 14:20:00 +000022 // CHECK: call %opencl.reserve_id_t* @__reserve_write_pipe(%opencl.pipe_t* %{{.*}}, i32 {{.*}}, i32 4, i32 4)
Xiuli Panbb4d8d32016-01-26 04:03:48 +000023 reserve_id_t rid = reserve_write_pipe(p, 2);
Alexey Bader465c1892016-09-23 14:20:00 +000024 // CHECK: call i32 @__write_pipe_4(%opencl.pipe_t* %{{.*}}, %opencl.reserve_id_t* %{{.*}}, i32 {{.*}}, i8* %{{.*}}, i32 4, i32 4)
Xiuli Panbb4d8d32016-01-26 04:03:48 +000025 write_pipe(p, rid, 2, ptr);
Alexey Bader465c1892016-09-23 14:20:00 +000026 // CHECK: call void @__commit_write_pipe(%opencl.pipe_t* %{{.*}}, %opencl.reserve_id_t* %{{.*}}, i32 4, i32 4)
Xiuli Panbb4d8d32016-01-26 04:03:48 +000027 commit_write_pipe(p, rid);
28}
29
30void test3(read_only pipe int p, global int *ptr) {
Alexey Bader465c1892016-09-23 14:20:00 +000031 // CHECK: call %opencl.reserve_id_t* @__work_group_reserve_read_pipe(%opencl.pipe_t* %{{.*}}, i32 {{.*}}, i32 4, i32 4)
Xiuli Panbb4d8d32016-01-26 04:03:48 +000032 reserve_id_t rid = work_group_reserve_read_pipe(p, 2);
Alexey Bader465c1892016-09-23 14:20:00 +000033 // CHECK: call void @__work_group_commit_read_pipe(%opencl.pipe_t* %{{.*}}, %opencl.reserve_id_t* %{{.*}}, i32 4, i32 4)
Xiuli Panbb4d8d32016-01-26 04:03:48 +000034 work_group_commit_read_pipe(p, rid);
35}
36
37void test4(write_only pipe int p, global int *ptr) {
Alexey Bader465c1892016-09-23 14:20:00 +000038 // CHECK: call %opencl.reserve_id_t* @__work_group_reserve_write_pipe(%opencl.pipe_t* %{{.*}}, i32 {{.*}}, i32 4, i32 4)
Xiuli Panbb4d8d32016-01-26 04:03:48 +000039 reserve_id_t rid = work_group_reserve_write_pipe(p, 2);
Alexey Bader465c1892016-09-23 14:20:00 +000040 // CHECK: call void @__work_group_commit_write_pipe(%opencl.pipe_t* %{{.*}}, %opencl.reserve_id_t* %{{.*}}, i32 4, i32 4)
Xiuli Panbb4d8d32016-01-26 04:03:48 +000041 work_group_commit_write_pipe(p, rid);
42}
43
44void test5(read_only pipe int p, global int *ptr) {
Alexey Bader465c1892016-09-23 14:20:00 +000045 // CHECK: call %opencl.reserve_id_t* @__sub_group_reserve_read_pipe(%opencl.pipe_t* %{{.*}}, i32 {{.*}}, i32 4, i32 4)
Xiuli Panbb4d8d32016-01-26 04:03:48 +000046 reserve_id_t rid = sub_group_reserve_read_pipe(p, 2);
Alexey Bader465c1892016-09-23 14:20:00 +000047 // CHECK: call void @__sub_group_commit_read_pipe(%opencl.pipe_t* %{{.*}}, %opencl.reserve_id_t* %{{.*}}, i32 4, i32 4)
Xiuli Panbb4d8d32016-01-26 04:03:48 +000048 sub_group_commit_read_pipe(p, rid);
49}
50
51void test6(write_only pipe int p, global int *ptr) {
Alexey Bader465c1892016-09-23 14:20:00 +000052 // CHECK: call %opencl.reserve_id_t* @__sub_group_reserve_write_pipe(%opencl.pipe_t* %{{.*}}, i32 {{.*}}, i32 4, i32 4)
Xiuli Panbb4d8d32016-01-26 04:03:48 +000053 reserve_id_t rid = sub_group_reserve_write_pipe(p, 2);
Alexey Bader465c1892016-09-23 14:20:00 +000054 // CHECK: call void @__sub_group_commit_write_pipe(%opencl.pipe_t* %{{.*}}, %opencl.reserve_id_t* %{{.*}}, i32 4, i32 4)
Xiuli Panbb4d8d32016-01-26 04:03:48 +000055 sub_group_commit_write_pipe(p, rid);
56}
57
58void test7(write_only pipe int p, global int *ptr) {
Alexey Bader465c1892016-09-23 14:20:00 +000059 // CHECK: call i32 @__get_pipe_num_packets(%opencl.pipe_t* %{{.*}}, i32 4, i32 4)
Xiuli Panbb4d8d32016-01-26 04:03:48 +000060 *ptr = get_pipe_num_packets(p);
Alexey Bader465c1892016-09-23 14:20:00 +000061 // CHECK: call i32 @__get_pipe_max_packets(%opencl.pipe_t* %{{.*}}, i32 4, i32 4)
Xiuli Panbb4d8d32016-01-26 04:03:48 +000062 *ptr = get_pipe_max_packets(p);
63}
Alexey Baderaf17c792016-09-07 10:32:03 +000064
65void test8(read_only pipe int r, write_only pipe int w, global int *ptr) {
66 // verify that return type is correctly casted to i1 value
67 // CHECK: %[[R:[0-9]+]] = call i32 @__read_pipe_2
68 // CHECK: icmp ne i32 %[[R]], 0
69 if (read_pipe(r, ptr)) *ptr = -1;
70 // CHECK: %[[W:[0-9]+]] = call i32 @__write_pipe_2
71 // CHECK: icmp ne i32 %[[W]], 0
72 if (write_pipe(w, ptr)) *ptr = -1;
73 // CHECK: %[[N:[0-9]+]] = call i32 @__get_pipe_num_packets
74 // CHECK: icmp ne i32 %[[N]], 0
75 if (get_pipe_num_packets(r)) *ptr = -1;
76 // CHECK: %[[M:[0-9]+]] = call i32 @__get_pipe_max_packets
77 // CHECK: icmp ne i32 %[[M]], 0
78 if (get_pipe_max_packets(w)) *ptr = -1;
79}