xref: /llvm-project/llvm/test/CodeGen/SPIRV/ExecutionMode.ll (revision 6cce67a8f9bbab7ebaafa6f33e0efbb22dee3ea1)
11268cf64SAndrey Tretyakov; RUN: llc -O0 -mtriple=spirv32-unknown-unknown %s -o - | FileCheck %s
2*6cce67a8SVyacheslav Levytskyy; RUN: %if spirv-tools %{ llc -O0 -mtriple=spirv32-unknown-unknown %s -o - -filetype=obj | spirv-val %}
31268cf64SAndrey Tretyakov
41268cf64SAndrey Tretyakov; CHECK-DAG: %[[#VOID:]] = OpTypeVoid
51268cf64SAndrey Tretyakov
61268cf64SAndrey Tretyakov; CHECK-DAG: OpEntryPoint Kernel %[[#WORKER:]] "worker"
71268cf64SAndrey Tretyakov; CHECK-DAG: OpEntryPoint Kernel %[[#INIT:]] "_SPIRV_GLOBAL__I_45b04794_Test_attr.cl"
81268cf64SAndrey Tretyakov; CHECK-DAG: OpEntryPoint Kernel %[[#FIN:]] "_SPIRV_GLOBAL__D_45b04794_Test_attr.cl"
91268cf64SAndrey Tretyakov
101268cf64SAndrey Tretyakov; CHECK-DAG: OpExecutionMode %[[#WORKER]] LocalSize 10 10 10
111268cf64SAndrey Tretyakov; CHECK-DAG: OpExecutionMode %[[#WORKER]] LocalSizeHint 12 10 1
121268cf64SAndrey Tretyakov; CHECK-DAG: OpExecutionMode %[[#WORKER]] VecTypeHint 262149
131268cf64SAndrey Tretyakov; CHECK-DAG: OpExecutionMode %[[#WORKER]] SubgroupsPerWorkgroup 4
141268cf64SAndrey Tretyakov; CHECK-DAG: OpExecutionMode %[[#INIT]] LocalSize 1 1 1
151268cf64SAndrey Tretyakov; CHECK-DAG: OpExecutionMode %[[#INIT]] Initializer
161268cf64SAndrey Tretyakov; CHECK-DAG: OpExecutionMode %[[#FIN]] LocalSize 1 1 1
171268cf64SAndrey Tretyakov; CHECK-DAG: OpExecutionMode %[[#FIN]] Finalizer
181268cf64SAndrey Tretyakov
191268cf64SAndrey Tretyakov%struct.global_ctor_dtor = type { i32 }
201268cf64SAndrey Tretyakov
211268cf64SAndrey Tretyakov@g = addrspace(1) global %struct.global_ctor_dtor zeroinitializer, align 4
221268cf64SAndrey Tretyakov
231268cf64SAndrey Tretyakovdefine internal spir_func void @__cxx_global_var_init() {
241268cf64SAndrey Tretyakoventry:
251268cf64SAndrey Tretyakov  call spir_func void @_ZNU3AS416global_ctor_dtorC1Ei(%struct.global_ctor_dtor addrspace(4)* addrspacecast (%struct.global_ctor_dtor addrspace(1)* @g to %struct.global_ctor_dtor addrspace(4)*), i32 12)
261268cf64SAndrey Tretyakov  ret void
271268cf64SAndrey Tretyakov}
281268cf64SAndrey Tretyakov
291268cf64SAndrey Tretyakovdefine linkonce_odr spir_func void @_ZNU3AS416global_ctor_dtorC1Ei(%struct.global_ctor_dtor addrspace(4)* %this, i32 %i) unnamed_addr align 2 {
301268cf64SAndrey Tretyakoventry:
311268cf64SAndrey Tretyakov  %this.addr = alloca %struct.global_ctor_dtor addrspace(4)*, align 4
321268cf64SAndrey Tretyakov  %i.addr = alloca i32, align 4
331268cf64SAndrey Tretyakov  store %struct.global_ctor_dtor addrspace(4)* %this, %struct.global_ctor_dtor addrspace(4)** %this.addr, align 4
341268cf64SAndrey Tretyakov  store i32 %i, i32* %i.addr, align 4
351268cf64SAndrey Tretyakov  %this1 = load %struct.global_ctor_dtor addrspace(4)*, %struct.global_ctor_dtor addrspace(4)** %this.addr
361268cf64SAndrey Tretyakov  %0 = load i32, i32* %i.addr, align 4
371268cf64SAndrey Tretyakov  call spir_func void @_ZNU3AS416global_ctor_dtorC2Ei(%struct.global_ctor_dtor addrspace(4)* %this1, i32 %0)
381268cf64SAndrey Tretyakov  ret void
391268cf64SAndrey Tretyakov}
401268cf64SAndrey Tretyakov
411268cf64SAndrey Tretyakovdefine linkonce_odr spir_func void @_ZNU3AS416global_ctor_dtorD1Ev(%struct.global_ctor_dtor addrspace(4)* %this) unnamed_addr align 2 {
421268cf64SAndrey Tretyakoventry:
431268cf64SAndrey Tretyakov  %this.addr = alloca %struct.global_ctor_dtor addrspace(4)*, align 4
441268cf64SAndrey Tretyakov  store %struct.global_ctor_dtor addrspace(4)* %this, %struct.global_ctor_dtor addrspace(4)** %this.addr, align 4
451268cf64SAndrey Tretyakov  %this1 = load %struct.global_ctor_dtor addrspace(4)*, %struct.global_ctor_dtor addrspace(4)** %this.addr
461268cf64SAndrey Tretyakov  call spir_func void @_ZNU3AS416global_ctor_dtorD2Ev(%struct.global_ctor_dtor addrspace(4)* %this1)
471268cf64SAndrey Tretyakov  ret void
481268cf64SAndrey Tretyakov}
491268cf64SAndrey Tretyakov
501268cf64SAndrey Tretyakovdefine internal spir_func void @__dtor_g() {
511268cf64SAndrey Tretyakoventry:
521268cf64SAndrey Tretyakov  call spir_func void @_ZNU3AS416global_ctor_dtorD1Ev(%struct.global_ctor_dtor addrspace(4)* addrspacecast (%struct.global_ctor_dtor addrspace(1)* @g to %struct.global_ctor_dtor addrspace(4)*))
531268cf64SAndrey Tretyakov  ret void
541268cf64SAndrey Tretyakov}
551268cf64SAndrey Tretyakov
561268cf64SAndrey Tretyakov; CHECK: %[[#WORKER]] = OpFunction %[[#VOID]]
571268cf64SAndrey Tretyakov
581268cf64SAndrey Tretyakovdefine spir_kernel void @worker() {
591268cf64SAndrey Tretyakoventry:
601268cf64SAndrey Tretyakov  ret void
611268cf64SAndrey Tretyakov}
621268cf64SAndrey Tretyakov
631268cf64SAndrey Tretyakovdefine linkonce_odr spir_func void @_ZNU3AS416global_ctor_dtorD2Ev(%struct.global_ctor_dtor addrspace(4)* %this) unnamed_addr align 2 {
641268cf64SAndrey Tretyakoventry:
651268cf64SAndrey Tretyakov  %this.addr = alloca %struct.global_ctor_dtor addrspace(4)*, align 4
661268cf64SAndrey Tretyakov  store %struct.global_ctor_dtor addrspace(4)* %this, %struct.global_ctor_dtor addrspace(4)** %this.addr, align 4
671268cf64SAndrey Tretyakov  %this1 = load %struct.global_ctor_dtor addrspace(4)*, %struct.global_ctor_dtor addrspace(4)** %this.addr
681268cf64SAndrey Tretyakov  %a = getelementptr inbounds %struct.global_ctor_dtor, %struct.global_ctor_dtor addrspace(4)* %this1, i32 0, i32 0
691268cf64SAndrey Tretyakov  store i32 0, i32 addrspace(4)* %a, align 4
701268cf64SAndrey Tretyakov  ret void
711268cf64SAndrey Tretyakov}
721268cf64SAndrey Tretyakov
731268cf64SAndrey Tretyakovdefine linkonce_odr spir_func void @_ZNU3AS416global_ctor_dtorC2Ei(%struct.global_ctor_dtor addrspace(4)* %this, i32 %i) unnamed_addr align 2 {
741268cf64SAndrey Tretyakoventry:
751268cf64SAndrey Tretyakov  %this.addr = alloca %struct.global_ctor_dtor addrspace(4)*, align 4
761268cf64SAndrey Tretyakov  %i.addr = alloca i32, align 4
771268cf64SAndrey Tretyakov  store %struct.global_ctor_dtor addrspace(4)* %this, %struct.global_ctor_dtor addrspace(4)** %this.addr, align 4
781268cf64SAndrey Tretyakov  store i32 %i, i32* %i.addr, align 4
791268cf64SAndrey Tretyakov  %this1 = load %struct.global_ctor_dtor addrspace(4)*, %struct.global_ctor_dtor addrspace(4)** %this.addr
801268cf64SAndrey Tretyakov  %0 = load i32, i32* %i.addr, align 4
811268cf64SAndrey Tretyakov  %a = getelementptr inbounds %struct.global_ctor_dtor, %struct.global_ctor_dtor addrspace(4)* %this1, i32 0, i32 0
821268cf64SAndrey Tretyakov  store i32 %0, i32 addrspace(4)* %a, align 4
831268cf64SAndrey Tretyakov  ret void
841268cf64SAndrey Tretyakov}
851268cf64SAndrey Tretyakov
861268cf64SAndrey Tretyakovdefine internal spir_func void @_GLOBAL__sub_I_Test_attr.cl() {
871268cf64SAndrey Tretyakoventry:
881268cf64SAndrey Tretyakov  call spir_func void @__cxx_global_var_init()
891268cf64SAndrey Tretyakov  ret void
901268cf64SAndrey Tretyakov}
911268cf64SAndrey Tretyakov
921268cf64SAndrey Tretyakov; CHECK: %[[#INIT]] = OpFunction %[[#VOID]]
931268cf64SAndrey Tretyakov
941268cf64SAndrey Tretyakovdefine spir_kernel void @_SPIRV_GLOBAL__I_45b04794_Test_attr.cl() {
951268cf64SAndrey Tretyakoventry:
961268cf64SAndrey Tretyakov  call spir_func void @_GLOBAL__sub_I_Test_attr.cl()
971268cf64SAndrey Tretyakov  ret void
981268cf64SAndrey Tretyakov}
991268cf64SAndrey Tretyakov
1001268cf64SAndrey Tretyakov; CHECK: %[[#FIN]] = OpFunction %[[#VOID]]
1011268cf64SAndrey Tretyakov
1021268cf64SAndrey Tretyakovdefine spir_kernel void @_SPIRV_GLOBAL__D_45b04794_Test_attr.cl() {
1031268cf64SAndrey Tretyakoventry:
1041268cf64SAndrey Tretyakov  call spir_func void @__dtor_g()
1051268cf64SAndrey Tretyakov  ret void
1061268cf64SAndrey Tretyakov}
1071268cf64SAndrey Tretyakov
1081268cf64SAndrey Tretyakov!spirv.ExecutionMode = !{!0, !1, !2, !3, !4, !5, !6, !7}
1091268cf64SAndrey Tretyakov
1101268cf64SAndrey Tretyakov!0 = !{void ()* @worker, i32 30, i32 262149}
1111268cf64SAndrey Tretyakov!1 = !{void ()* @worker, i32 18, i32 12, i32 10, i32 1}
1121268cf64SAndrey Tretyakov!2 = !{void ()* @worker, i32 17, i32 10, i32 10, i32 10}
1131268cf64SAndrey Tretyakov!3 = !{void ()* @worker, i32 36, i32 4}
1141268cf64SAndrey Tretyakov!4 = !{void ()* @_SPIRV_GLOBAL__I_45b04794_Test_attr.cl, i32 33}
1151268cf64SAndrey Tretyakov!5 = !{void ()* @_SPIRV_GLOBAL__I_45b04794_Test_attr.cl, i32 17, i32 1, i32 1, i32 1}
1161268cf64SAndrey Tretyakov!6 = !{void ()* @_SPIRV_GLOBAL__D_45b04794_Test_attr.cl, i32 34}
1171268cf64SAndrey Tretyakov!7 = !{void ()* @_SPIRV_GLOBAL__D_45b04794_Test_attr.cl, i32 17, i32 1, i32 1, i32 1}
118