blob: 0f20a73b1928e65d2114b7ddf315d5f16c20a3c0 (
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
|
; RUN: llvm-split -o %t %s -j 3 -mtriple amdgcn-amd-amdhsa -amdgpu-module-splitting-large-threshold=0
; 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
; 3 kernels:
; - A does a direct call to HelperA
; - B is storing @HelperA
; - C does a direct call to HelperA
;
; The helper functions will get externalized, so C/A will end up
; in the same partition.
; CHECK0: define amdgpu_kernel void @B(ptr %dst)
; CHECK1: define hidden void @HelperA()
; CHECK1: define amdgpu_kernel void @A()
; CHECK1: define amdgpu_kernel void @C()
define internal void @HelperA() {
ret void
}
define amdgpu_kernel void @A() {
call void @HelperA()
ret void
}
define amdgpu_kernel void @B(ptr %dst) {
store ptr @HelperA, ptr %dst
ret void
}
define amdgpu_kernel void @C() {
call void @HelperA()
ret void
}
|