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 10 namespace llvm { 11 namespace AMDGPU { 12 namespace SendMsg { 13 14 // This must be in sync with llvm::AMDGPU::SendMsg::Id enum members, see SIDefines.h. 15 const 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. 35 const 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 43 const 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 52 namespace Hwreg { 53 54 // This must be in sync with llvm::AMDGPU::Hwreg::ID_SYMBOLIC_FIRST_/LAST_, see SIDefines.h. 55 const 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 86 namespace Swizzle { 87 88 // This must be in sync with llvm::AMDGPU::Swizzle::Id enum members, see SIDefines.h. 89 const char* const IdSymbolic[] = { 90 "QUAD_PERM", 91 "BITMASK_PERM", 92 "SWAP", 93 "REVERSE", 94 "BROADCAST", 95 }; 96 97 } // namespace Swizzle 98 99 namespace VGPRIndexMode { 100 101 // This must be in sync with llvm::AMDGPU::VGPRIndexMode::Id enum members, see SIDefines.h. 102 const char* const IdSymbolic[] = { 103 "SRC0", 104 "SRC1", 105 "SRC2", 106 "DST", 107 }; 108 109 } // namespace VGPRIndexMode 110 111 } // namespace AMDGPU 112 } // namespace llvm 113