Home | History | Annotate | Download | only in SPIRV
      1 ; RUN: llvm-as < %s | llvm-spirv -spirv-text -o %t
      2 ; RUN: FileCheck < %t %s
      3 
      4 ; ModuleID = 'test.cl'
      5 target datalayout = "e-p:32:32-i64:64-v16:16-v24:32-v32:32-v48:64-v96:128-v192:256-v256:256-v512:512-v1024:1024"
      6 target triple = "spir-unknown-unknown"
      7 
      8 ; CHECK: {{[0-9]+}} Name [[WD:[0-9]+]] "__spirv_BuiltInWorkDim"
      9 ; CHECK: {{[0-9]+}} Name [[GS:[0-9]+]] "__spirv_BuiltInGlobalSize"
     10 ; CHECK: {{[0-9]+}} Name [[GII:[0-9]+]] "__spirv_BuiltInGlobalInvocationId"
     11 ; CHECK: {{[0-9]+}} Name [[WS:[0-9]+]] "__spirv_BuiltInWorkgroupSize"
     12 ; CHECK: {{[0-9]+}} Name [[EWS:[0-9]+]] "__spirv_BuiltInEnqueuedWorkgroupSize"
     13 ; CHECK: {{[0-9]+}} Name [[LLI:[0-9]+]] "__spirv_BuiltInLocalInvocationId"
     14 ; CHECK: {{[0-9]+}} Name [[NW:[0-9]+]] "__spirv_BuiltInNumWorkgroups"
     15 ; CHECK: {{[0-9]+}} Name [[WI:[0-9]+]] "__spirv_BuiltInWorkgroupId"
     16 ; CHECK: {{[0-9]+}} Name [[GO:[0-9]+]] "__spirv_BuiltInGlobalOffset"
     17 ; CHECK: {{[0-9]+}} Name [[GLI:[0-9]+]] "__spirv_BuiltInGlobalLinearId"
     18 ; CHECK: {{[0-9]+}} Name [[LLII:[0-9]+]] "__spirv_BuiltInLocalInvocationIndex"
     19 ; CHECK: {{[0-9]+}} Name [[SS:[0-9]+]] "__spirv_BuiltInSubgroupSize"
     20 ; CHECK: {{[0-9]+}} Name [[SMS:[0-9]+]] "__spirv_BuiltInSubgroupMaxSize"
     21 ; CHECK: {{[0-9]+}} Name [[NS:[0-9]+]] "__spirv_BuiltInNumSubgroups"
     22 ; CHECK: {{[0-9]+}} Name [[NES:[0-9]+]] "__spirv_BuiltInNumEnqueuedSubgroups"
     23 ; CHECK: {{[0-9]+}} Name [[SI:[0-9]+]] "__spirv_BuiltInSubgroupId"
     24 ; CHECK: {{[0-9]+}} Name [[SLII:[0-9]+]] "__spirv_BuiltInSubgroupLocalInvocationId"
     25 
     26 ; CHECK: 4 Decorate [[NW]] BuiltIn 24
     27 ; CHECK: 4 Decorate [[WS]] BuiltIn 25
     28 ; CHECK: 4 Decorate [[WI]] BuiltIn 26
     29 ; CHECK: 4 Decorate [[LLI]] BuiltIn 27
     30 ; CHECK: 4 Decorate [[GII]] BuiltIn 28
     31 ; CHECK: 4 Decorate [[LLII]] BuiltIn 29
     32 ; CHECK: 4 Decorate [[WD]] BuiltIn 30
     33 ; CHECK: 4 Decorate [[GS]] BuiltIn 31
     34 ; CHECK: 4 Decorate [[EWS]] BuiltIn 32
     35 ; CHECK: 4 Decorate [[GO]] BuiltIn 33
     36 ; CHECK: 4 Decorate [[GLI]] BuiltIn 34
     37 ; CHECK: 4 Decorate [[SS]] BuiltIn 36
     38 ; CHECK: 4 Decorate [[SMS]] BuiltIn 37
     39 ; CHECK: 4 Decorate [[NS]] BuiltIn 38
     40 ; CHECK: 4 Decorate [[NES]] BuiltIn 39
     41 ; CHECK: 4 Decorate [[SI]] BuiltIn 40
     42 ; CHECK: 4 Decorate [[SLII]] BuiltIn 41
     43 @__spirv_BuiltInWorkDim = external addrspace(1) global i32
     44 @__spirv_BuiltInGlobalSize = external addrspace(1) global <3 x i32>
     45 @__spirv_BuiltInGlobalInvocationId = external addrspace(1) global <3 x i32>
     46 @__spirv_BuiltInWorkgroupSize = external addrspace(1) global <3 x i32>
     47 @__spirv_BuiltInEnqueuedWorkgroupSize = external addrspace(1) global <3 x i32>
     48 @__spirv_BuiltInLocalInvocationId = external addrspace(1) global <3 x i32>
     49 @__spirv_BuiltInNumWorkgroups = external addrspace(1) global <3 x i32>
     50 @__spirv_BuiltInWorkgroupId = external addrspace(1) global <3 x i32>
     51 @__spirv_BuiltInGlobalOffset = external addrspace(1) global <3 x i32>
     52 @__spirv_BuiltInGlobalLinearId = external addrspace(1) global i32
     53 @__spirv_BuiltInLocalInvocationIndex = external addrspace(1) global i32
     54 @__spirv_BuiltInSubgroupSize = external addrspace(1) global i32
     55 @__spirv_BuiltInSubgroupMaxSize = external addrspace(1) global i32
     56 @__spirv_BuiltInNumSubgroups = external addrspace(1) global i32
     57 @__spirv_BuiltInNumEnqueuedSubgroups = external addrspace(1) global i32
     58 @__spirv_BuiltInSubgroupId = external addrspace(1) global i32
     59 @__spirv_BuiltInSubgroupLocalInvocationId = external addrspace(1) global i32
     60 
     61 ; Function Attrs: nounwind readnone
     62 define spir_kernel void @_Z1wv() #1 {
     63 entry:
     64   ret void
     65 }
     66 
     67 attributes #0 = { alwaysinline nounwind readonly "less-precise-fpmad"="false" "no-frame-pointer-elim"="false" "no-infs-fp-math"="false" "no-nans-fp-math"="false" "no-realign-stack" "stack-protector-buffer-size"="8" "unsafe-fp-math"="false" "use-soft-float"="false" }
     68 attributes #1 = { nounwind readnone "less-precise-fpmad"="false" "no-frame-pointer-elim"="false" "no-infs-fp-math"="false" "no-nans-fp-math"="false" "no-realign-stack" "stack-protector-buffer-size"="8" "unsafe-fp-math"="false" "use-soft-float"="false" }
     69 
     70 !opencl.kernels = !{!0}
     71 !opencl.enable.FP_CONTRACT = !{}
     72 !opencl.spir.version = !{!6}
     73 !opencl.ocl.version = !{!7}
     74 !opencl.used.extensions = !{!8}
     75 !opencl.used.optional.core.features = !{!8}
     76 !opencl.compiler.options = !{!8}
     77 !llvm.ident = !{!9}
     78 !spirv.Source = !{!10}
     79 !spirv.String = !{!11}
     80 
     81 !0 = !{void ()* @_Z1wv, !1, !2, !3, !4, !5}
     82 !1 = !{!"kernel_arg_addr_space"}
     83 !2 = !{!"kernel_arg_access_qual"}
     84 !3 = !{!"kernel_arg_type"}
     85 !4 = !{!"kernel_arg_base_type"}
     86 !5 = !{!"kernel_arg_type_qual"}
     87 !6 = !{i32 1, i32 2}
     88 !7 = !{i32 2, i32 1}
     89 !8 = !{}
     90 !9 = !{!"clang version 3.6.1 "}
     91 !10 = !{i32 3, i32 200000, !11}
     92 !11 = !{!"test.cl"}
     93 !12 = !{!13, !13, i64 0}
     94 !13 = !{!"int", !14, i64 0}
     95 !14 = !{!"omnipotent char", !15, i64 0}
     96 !15 = !{!"Simple C/C++ TBAA"}
     97