summaryrefslogtreecommitdiff
path: root/llvm/test/CodeGen/AMDGPU/kernarg-size.ll
blob: 0353e7ee49ab953508d119ec325318660260f35e (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
32
; RUN: sed 's/CODE_OBJECT_VERSION/400/g' %s | llc -mtriple=amdgcn-amd-amdhsa -mcpu=gfx900 | FileCheck --check-prefix=DOORBELL %s
; RUN: sed 's/CODE_OBJECT_VERSION/400/g' %s | llc -mtriple=amdgcn-amd-amdhsa -mcpu=gfx900 | FileCheck --check-prefix=DOORBELL %s
; RUN: sed 's/CODE_OBJECT_VERSION/300/g' %s | llc -mtriple=amdgcn-amd-amdhsa -mcpu=gfx900 | FileCheck --check-prefix=HSA %s

declare void @llvm.trap() #0

; HSA:      .amdhsa_kernel trap
; HSA-NEXT:     .amdhsa_group_segment_fixed_size 0
; HSA-NEXT:     .amdhsa_private_segment_fixed_size 0
; HSA-NEXT:     .amdhsa_kernarg_size 8
; HSA-NEXT:     .amdhsa_user_sgpr_count 8
; HSA-NEXT:     .amdhsa_user_sgpr_private_segment_buffer 1
; HSA:      .end_amdhsa_kernel

; DOORBELL:      .amdhsa_kernel trap
; DOORBELL-NEXT:     .amdhsa_group_segment_fixed_size 0
; DOORBELL-NEXT:     .amdhsa_private_segment_fixed_size 0
; DOORBELL-NEXT:     .amdhsa_kernarg_size 8
; DOORBELL-NEXT:     .amdhsa_user_sgpr_count 6
; DOORBELL-NEXT:     .amdhsa_user_sgpr_private_segment_buffer 1
; DOORBELL:      .end_amdhsa_kernel

define amdgpu_kernel void @trap(ptr addrspace(1) nocapture readonly %arg0) {
  store volatile i32 1, ptr addrspace(1) %arg0
  call void @llvm.trap()
  unreachable
  store volatile i32 2, ptr addrspace(1) %arg0
  ret void
}

!llvm.module.flags = !{!0}
!0 = !{i32 1, !"amdgpu_code_object_version", i32 CODE_OBJECT_VERSION}