aboutsummaryrefslogtreecommitdiff
path: root/llvm/test/tools/llvm-split/AMDGPU/kernels-global-variables.ll
blob: be84a0b5916f0d7557a423b54b52067340dbddbc (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
33
34
35
36
37
38
; RUN: llvm-split -o %t %s -j 3 -mtriple amdgcn-amd-amdhsa
; RUN: llvm-dis -o - %t0 | FileCheck --check-prefix=CHECK0 --implicit-check-not=define %s
; RUN: llvm-dis -o - %t1 | FileCheck --check-prefix=CHECK1 --implicit-check-not=define %s
; RUN: llvm-dis -o - %t2 | FileCheck --check-prefix=CHECK2 --implicit-check-not=define %s

; 3 kernels use private/internal global variables.
; The GVs should be copied in each partition as needed.

; CHECK0: @foo = hidden constant ptr poison
; CHECK0: @bar = hidden constant ptr poison
; CHECK0: define amdgpu_kernel void @C

; CHECK1: @foo = external hidden constant ptr{{$}}
; CHECK1: @bar = external hidden constant ptr{{$}}
; CHECK1: define amdgpu_kernel void @A

; CHECK2: @foo = external hidden constant ptr{{$}}
; CHECK2: @bar = external hidden constant ptr{{$}}
; CHECK2: define amdgpu_kernel void @B

@foo = private constant ptr poison
@bar = internal constant ptr poison

define amdgpu_kernel void @A() {
  store i32 42, ptr @foo
  ret void
}

define amdgpu_kernel void @B() {
  store i32 42, ptr @foo
  store i32 42, ptr @bar
  ret void
}

define amdgpu_kernel void @C() {
  store i32 42, ptr @bar
  ret void
}