1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2025-01-31 20:51:52 +01:00
llvm-mirror/test/CodeGen/AMDGPU/llvm.amdgcn.s.sethalt.ll
Jay Foad d90cb44457 [AMDGPU] New intrinsic void llvm.amdgcn.s.sethalt(i32)
The expected use case is for frontends to insert this into
shaders that are to be run under a debugger. The shader can
then be resumed or single stepped from the point of the call
under debugger control.

Differential Revision: https://reviews.llvm.org/D97670
2021-03-01 14:30:23 +00:00

29 lines
1016 B
LLVM

; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
; RUN: llc -march=amdgcn -mcpu=gfx900 -verify-machineinstrs < %s | FileCheck -check-prefix=GCN %s
; RUN: llc -global-isel -march=amdgcn -mcpu=gfx900 -verify-machineinstrs < %s | FileCheck -check-prefix=GCN %s
define amdgpu_kernel void @test_s_sethalt() {
; GCN-LABEL: test_s_sethalt:
; GCN: ; %bb.0:
; GCN-NEXT: s_sethalt 0
; GCN-NEXT: s_sethalt 1
; GCN-NEXT: s_sethalt 2
; GCN-NEXT: s_sethalt 3
; GCN-NEXT: s_sethalt 4
; GCN-NEXT: s_sethalt 5
; GCN-NEXT: s_sethalt 6
; GCN-NEXT: s_sethalt 7
; GCN-NEXT: s_endpgm
call void @llvm.amdgcn.s.sethalt(i32 0)
call void @llvm.amdgcn.s.sethalt(i32 1)
call void @llvm.amdgcn.s.sethalt(i32 2)
call void @llvm.amdgcn.s.sethalt(i32 3)
call void @llvm.amdgcn.s.sethalt(i32 4)
call void @llvm.amdgcn.s.sethalt(i32 5)
call void @llvm.amdgcn.s.sethalt(i32 6)
call void @llvm.amdgcn.s.sethalt(i32 7)
ret void
}
declare void @llvm.amdgcn.s.sethalt(i32)