xref: /aosp_15_r20/external/llvm/test/CodeGen/AMDGPU/private-memory-broken.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: not llc -verify-machineinstrs -march=amdgcn %s -o /dev/null 2>&1 | FileCheck %s
2*9880d681SAndroid Build Coastguard Worker; RUN: not llc -verify-machineinstrs -march=amdgcn -mcpu=tonga %s -o /dev/null 2>&1 | FileCheck %s
3*9880d681SAndroid Build Coastguard Worker
4*9880d681SAndroid Build Coastguard Worker; Make sure promote alloca pass doesn't crash
5*9880d681SAndroid Build Coastguard Worker
6*9880d681SAndroid Build Coastguard Worker; CHECK: unsupported call
7*9880d681SAndroid Build Coastguard Worker
8*9880d681SAndroid Build Coastguard Workerdeclare i32 @foo(i32*) nounwind
9*9880d681SAndroid Build Coastguard Worker
10*9880d681SAndroid Build Coastguard Workerdefine void @call_private(i32 addrspace(1)* %out, i32 %in) nounwind {
11*9880d681SAndroid Build Coastguard Workerentry:
12*9880d681SAndroid Build Coastguard Worker  %tmp = alloca [2 x i32]
13*9880d681SAndroid Build Coastguard Worker  %tmp1 = getelementptr [2 x i32], [2 x i32]* %tmp, i32 0, i32 0
14*9880d681SAndroid Build Coastguard Worker  %tmp2 = getelementptr [2 x i32], [2 x i32]* %tmp, i32 0, i32 1
15*9880d681SAndroid Build Coastguard Worker  store i32 0, i32* %tmp1
16*9880d681SAndroid Build Coastguard Worker  store i32 1, i32* %tmp2
17*9880d681SAndroid Build Coastguard Worker  %tmp3 = getelementptr [2 x i32], [2 x i32]* %tmp, i32 0, i32 %in
18*9880d681SAndroid Build Coastguard Worker  %val = call i32 @foo(i32* %tmp3) nounwind
19*9880d681SAndroid Build Coastguard Worker  store i32 %val, i32 addrspace(1)* %out
20*9880d681SAndroid Build Coastguard Worker  ret void
21*9880d681SAndroid Build Coastguard Worker}
22