blob: c9ecb144c9f3677e6a138743279af4c3e9cc45e4 [file] [log] [blame]
Rafael Espindolaff7cea82013-09-04 04:12:25 +00001// RUN: %clang_cc1 -emit-llvm -o - %s | FileCheck %s
Tanya Lattnerbcffcdf2012-07-09 22:06:01 +00002
Joey Goulyaba589c2013-03-08 09:42:32 +00003typedef unsigned int uint4 __attribute__((ext_vector_type(4)));
Tanya Lattnerbcffcdf2012-07-09 22:06:01 +00004
Joey Goulyaba589c2013-03-08 09:42:32 +00005kernel __attribute__((vec_type_hint(int))) __attribute__((reqd_work_group_size(1,2,4))) void kernel1(int a) {}
Rafael Espindola922f2aa2018-02-23 19:30:48 +00006// CHECK: define {{(dso_local )?}}spir_kernel void @kernel1(i32 {{[^%]*}}%a) {{[^{]+}} !vec_type_hint ![[MD1:[0-9]+]] !reqd_work_group_size ![[MD2:[0-9]+]]
Joey Goulyaba589c2013-03-08 09:42:32 +00007
8kernel __attribute__((vec_type_hint(uint4))) __attribute__((work_group_size_hint(8,16,32))) void kernel2(int a) {}
Rafael Espindola922f2aa2018-02-23 19:30:48 +00009// CHECK: define {{(dso_local )?}}spir_kernel void @kernel2(i32 {{[^%]*}}%a) {{[^{]+}} !vec_type_hint ![[MD3:[0-9]+]] !work_group_size_hint ![[MD4:[0-9]+]]
Tanya Lattnerbcffcdf2012-07-09 22:06:01 +000010
Xiuli Panbe6da4b2017-05-04 07:31:20 +000011kernel __attribute__((intel_reqd_sub_group_size(8))) void kernel3(int a) {}
Rafael Espindola922f2aa2018-02-23 19:30:48 +000012// CHECK: define {{(dso_local )?}}spir_kernel void @kernel3(i32 {{[^%]*}}%a) {{[^{]+}} !intel_reqd_sub_group_size ![[MD5:[0-9]+]]
Xiuli Panbe6da4b2017-05-04 07:31:20 +000013
Yaxun Liuba28cba2016-06-22 14:56:35 +000014// CHECK: [[MD1]] = !{i32 undef, i32 1}
15// CHECK: [[MD2]] = !{i32 1, i32 2, i32 4}
16// CHECK: [[MD3]] = !{<4 x i32> undef, i32 0}
17// CHECK: [[MD4]] = !{i32 8, i32 16, i32 32}
Xiuli Panbe6da4b2017-05-04 07:31:20 +000018// CHECK: [[MD5]] = !{i32 8}