; 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 with each their own dependencies should go into 3
; distinct partitions. The most expensive kernel should be
; seen first and go into the last partition.
; CHECK0: define amdgpu_kernel void @C
; CHECK0: define internal void @HelperC
; CHECK0-NOT: define
; CHECK1: define amdgpu_kernel void @A
; CHECK1: define internal void @HelperA
; CHECK2: define amdgpu_kernel void @B
; CHECK2: define internal void @HelperB
define amdgpu_kernel void @A() {
call void @HelperA()
ret void
}
define internal void @HelperA() {
ret void
}
define amdgpu_kernel void @B(ptr %x) {
store i64 42, ptr %x
store i64 43, ptr %x
store i64 44, ptr %x
call void @HelperB()
ret void
}
define internal void @HelperB() {
ret void
}
define amdgpu_kernel void @C() {
call void @HelperC()
ret void
}
define internal void @HelperC() {
ret void
}