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