// RUN: mlir-translate -no-implicit-module -test-spirv-roundtrip -split-input-file %s | FileCheck %s // CHECK: spirv.GlobalVariable @var0 bind(1, 0) : !spirv.ptr // CHECK-NEXT: spirv.GlobalVariable @var1 bind(0, 1) : !spirv.ptr // CHECK-NEXT: spirv.GlobalVariable @var2 built_in("GlobalInvocationId") : !spirv.ptr, Input> // CHECK-NEXT: spirv.GlobalVariable @var3 built_in("GlobalInvocationId") : !spirv.ptr, Input> spirv.module Logical GLSL450 requires #spirv.vce { spirv.GlobalVariable @var0 bind(1, 0) : !spirv.ptr spirv.GlobalVariable @var1 bind(0, 1) : !spirv.ptr spirv.GlobalVariable @var2 {built_in = "GlobalInvocationId"} : !spirv.ptr, Input> spirv.GlobalVariable @var3 built_in("GlobalInvocationId") : !spirv.ptr, Input> } // ----- spirv.module Logical GLSL450 requires #spirv.vce { // CHECK: spirv.GlobalVariable @var1 : !spirv.ptr // CHECK-NEXT: spirv.GlobalVariable @var2 initializer(@var1) bind(1, 0) : !spirv.ptr spirv.GlobalVariable @var1 : !spirv.ptr spirv.GlobalVariable @var2 initializer(@var1) bind(1, 0) : !spirv.ptr } // ----- spirv.module Logical GLSL450 requires #spirv.vce { // CHECK: spirv.SpecConstant @sc = 1 : i8 // CHECK-NEXT: spirv.GlobalVariable @var initializer(@sc) : !spirv.ptr spirv.SpecConstant @sc = 1 : i8 spirv.GlobalVariable @var initializer(@sc) : !spirv.ptr } // ----- spirv.module Logical GLSL450 requires #spirv.vce { // CHECK: spirv.SpecConstantComposite @scc (@sc0, @sc1, @sc2) : !spirv.array<3 x i8> // CHECK-NEXT: spirv.GlobalVariable @var initializer(@scc) : !spirv.ptr, Uniform> spirv.SpecConstant @sc0 = 1 : i8 spirv.SpecConstant @sc1 = 2 : i8 spirv.SpecConstant @sc2 = 3 : i8 spirv.SpecConstantComposite @scc (@sc0, @sc1, @sc2) : !spirv.array<3 x i8> spirv.GlobalVariable @var initializer(@scc) : !spirv.ptr, Uniform> } // ----- spirv.module Logical GLSL450 requires #spirv.vce { spirv.GlobalVariable @globalInvocationID built_in("GlobalInvocationId") : !spirv.ptr, Input> spirv.func @foo() "None" { // CHECK: %[[ADDR:.*]] = spirv.mlir.addressof @globalInvocationID : !spirv.ptr, Input> %0 = spirv.mlir.addressof @globalInvocationID : !spirv.ptr, Input> %1 = spirv.Constant 0: i32 // CHECK: spirv.AccessChain %[[ADDR]] %2 = spirv.AccessChain %0[%1] : !spirv.ptr, Input>, i32 spirv.Return } } // ----- spirv.module Logical GLSL450 requires #spirv.vce { // CHECK: linkage_attributes = #spirv.linkage_attributes> spirv.GlobalVariable @var1 { linkage_attributes=#spirv.linkage_attributes< linkage_name="outSideGlobalVar1", linkage_type= > } : !spirv.ptr }