summaryrefslogtreecommitdiff
path: root/amdgcn/lib/workitem/get_local_id.ll
blob: c54291c0b8f2a561ccffa52bf2671d79a53ee5b9 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
declare i32 @llvm.amdgcn.workitem.id.x() #0
declare i32 @llvm.amdgcn.workitem.id.y() #0
declare i32 @llvm.amdgcn.workitem.id.z() #0

define i32 @get_local_id(i32 %dim) #1 {
  switch i32 %dim, label %default [
    i32 0, label %x_dim
    i32 1, label %y_dim
    i32 2, label %z_dim
  ]

x_dim:
  %x = tail call i32 @llvm.amdgcn.workitem.id.x(), !range !0
  ret i32 %x

y_dim:
  %y = tail call i32 @llvm.amdgcn.workitem.id.y(), !range !0
  ret i32 %y

z_dim:
  %z = tail call i32 @llvm.amdgcn.workitem.id.z(), !range !0
  ret i32 %z

default:
  ret i32 0
}

attributes #0 = { nounwind readnone }
attributes #1 = { alwaysinline norecurse nounwind readnone }

!0 = !{ i32 0, i32 2048 }