; RUN: llc -O0 -mtriple=spirv-unknown-linux %s -o - | FileCheck %s
; RUN: %if spirv-tools %{ llc -O0 -mtriple=spirv-vulkan-unknown %s -o - -filetype=obj | spirv-val %}
target datalayout = "e-i64:64-v16:16-v24:32-v32:32-v48:64-v96:128-v192:256-v256:256-v512:512-v1024:1024"
target triple = "spirv-unknown-vulkan-compute"
; CHECK-DAG: %[[#uint:]] = OpTypeInt 32 0
; CHECK-DAG: %[[#uint_3:]] = OpConstant %[[#uint]] 3
; CHECK-DAG: %[[#bool:]] = OpTypeBool
define spir_func void @main() #0 {
entry:
%0 = call token @llvm.experimental.convergence.entry()
; CHECK: %[[#]] = OpGroupNonUniformElect %[[#bool]] %[[#uint_3]]
%1 = call i1 @llvm.spv.wave.is.first.lane() [ "convergencectrl"(token %0) ]
ret void
}
declare i32 @__hlsl_wave_get_lane_index() #1
attributes #0 = { convergent norecurse "hlsl.numthreads"="1,1,1" "hlsl.shader"="compute" "no-trapping-math"="true" "stack-protector-buffer-size"="8" }
attributes #1 = { convergent }
!llvm.module.flags = !{!0, !1}
!0 = !{i32 1, !"wchar_size", i32 4}
!1 = !{i32 4, !"dx.disable_optimizations", i32 1}