1//===-- AMDGPUAsmUtils.cpp - AsmParser/InstPrinter common -----------------===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8#include "AMDGPUAsmUtils.h"
9
10namespace llvm {
11namespace AMDGPU {
12namespace SendMsg {
13
14// This must be in sync with llvm::AMDGPU::SendMsg::Id enum members, see SIDefines.h.
15const char* const IdSymbolic[] = {
16  nullptr,
17  "MSG_INTERRUPT",
18  "MSG_GS",
19  "MSG_GS_DONE",
20  nullptr,
21  nullptr,
22  nullptr,
23  nullptr,
24  nullptr,
25  "MSG_GS_ALLOC_REQ",
26  "MSG_GET_DOORBELL",
27  nullptr,
28  nullptr,
29  nullptr,
30  nullptr,
31  "MSG_SYSMSG"
32};
33
34// These two must be in sync with llvm::AMDGPU::SendMsg::Op enum members, see SIDefines.h.
35const char* const OpSysSymbolic[] = {
36  nullptr,
37  "SYSMSG_OP_ECC_ERR_INTERRUPT",
38  "SYSMSG_OP_REG_RD",
39  "SYSMSG_OP_HOST_TRAP_ACK",
40  "SYSMSG_OP_TTRACE_PC"
41};
42
43const char* const OpGsSymbolic[] = {
44  "GS_OP_NOP",
45  "GS_OP_CUT",
46  "GS_OP_EMIT",
47  "GS_OP_EMIT_CUT"
48};
49
50} // namespace SendMsg
51
52namespace Hwreg {
53
54// This must be in sync with llvm::AMDGPU::Hwreg::ID_SYMBOLIC_FIRST_/LAST_, see SIDefines.h.
55const char* const IdSymbolic[] = {
56  nullptr,
57  "HW_REG_MODE",
58  "HW_REG_STATUS",
59  "HW_REG_TRAPSTS",
60  "HW_REG_HW_ID",
61  "HW_REG_GPR_ALLOC",
62  "HW_REG_LDS_ALLOC",
63  "HW_REG_IB_STS",
64  nullptr,
65  nullptr,
66  nullptr,
67  nullptr,
68  nullptr,
69  nullptr,
70  nullptr,
71  "HW_REG_SH_MEM_BASES",
72  "HW_REG_TBA_LO",
73  "HW_REG_TBA_HI",
74  "HW_REG_TMA_LO",
75  "HW_REG_TMA_HI",
76  "HW_REG_FLAT_SCR_LO",
77  "HW_REG_FLAT_SCR_HI",
78  "HW_REG_XNACK_MASK",
79  nullptr, // HW_ID1, no predictable values
80  nullptr, // HW_ID2, no predictable values
81  "HW_REG_POPS_PACKER"
82};
83
84} // namespace Hwreg
85
86namespace Swizzle {
87
88// This must be in sync with llvm::AMDGPU::Swizzle::Id enum members, see SIDefines.h.
89const char* const IdSymbolic[] = {
90  "QUAD_PERM",
91  "BITMASK_PERM",
92  "SWAP",
93  "REVERSE",
94  "BROADCAST",
95};
96
97} // namespace Swizzle
98
99namespace VGPRIndexMode {
100
101// This must be in sync with llvm::AMDGPU::VGPRIndexMode::Id enum members, see SIDefines.h.
102const char* const IdSymbolic[] = {
103  "SRC0",
104  "SRC1",
105  "SRC2",
106  "DST",
107};
108
109} // namespace VGPRIndexMode
110
111} // namespace AMDGPU
112} // namespace llvm
113