xref: /llvm-project/llvm/test/tools/llvm-split/AMDGPU/indirect-call-inline-asm.ll (revision d656b2063262d59c3565e63095104c01d1f6a5a3)
1; RUN: llvm-split -o %t %s -j 2 -mtriple amdgcn-amd-amdhsa -amdgpu-module-splitting-no-externalize-address-taken
2; RUN: llvm-dis -o - %t0 | FileCheck --check-prefix=CHECK0 --implicit-check-not=define %s
3; RUN: llvm-dis -o - %t1 | FileCheck --check-prefix=CHECK1 --implicit-check-not=define %s
4
5; CHECK0: define internal void @HelperB
6; CHECK0: define amdgpu_kernel void @B
7
8; CHECK1: define internal void @HelperA()
9; CHECK1: define amdgpu_kernel void @A()
10
11@addrthief = global [2 x ptr] [ptr @HelperA, ptr @HelperB]
12
13define internal void @HelperA() {
14  ret void
15}
16
17define internal void @HelperB() {
18  ret void
19}
20
21define amdgpu_kernel void @A() {
22  call void asm sideeffect "v_mov_b32 v0, 7", "~{v0}"()
23  call void @HelperA()
24  ret void
25}
26
27define amdgpu_kernel void @B(ptr %out) {
28  call void @HelperB()
29  ret void
30}
31