[x86] fix assert with horizontal math + broadcast of vector (PR43402)
[llvm-core.git] / lib / Target / AMDGPU / Utils / AMDGPUAsmUtils.cpp
blob075e08986c0c0608be3c90d71b6c8000e228b4bd
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"
10 namespace llvm {
11 namespace AMDGPU {
12 namespace SendMsg {
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"
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"
43 const char* const OpGsSymbolic[] = {
44 "GS_OP_NOP",
45 "GS_OP_CUT",
46 "GS_OP_EMIT",
47 "GS_OP_EMIT_CUT"
50 } // namespace SendMsg
52 namespace Hwreg {
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"
84 } // namespace Hwreg
86 namespace Swizzle {
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",
97 } // namespace Swizzle
99 namespace VGPRIndexMode {
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",
109 } // namespace VGPRIndexMode
111 } // namespace AMDGPU
112 } // namespace llvm