Coverage Report

Created: 2019-05-09 23:04

/Users/buildslave/jenkins/workspace/clang-stage2-coverage-R/llvm/lib/Target/AMDGPU/InstPrinter/AMDGPUInstPrinter.h
Line
Count
Source
1
//===-- AMDGPUInstPrinter.h - AMDGPU MC Inst -> ASM interface ---*- C++ -*-===//
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
//
9
/// \file
10
//===----------------------------------------------------------------------===//
11
12
#ifndef LLVM_LIB_TARGET_AMDGPU_INSTPRINTER_AMDGPUINSTPRINTER_H
13
#define LLVM_LIB_TARGET_AMDGPU_INSTPRINTER_AMDGPUINSTPRINTER_H
14
15
#include "llvm/MC/MCInstPrinter.h"
16
17
namespace llvm {
18
19
class AMDGPUInstPrinter : public MCInstPrinter {
20
public:
21
  AMDGPUInstPrinter(const MCAsmInfo &MAI,
22
                    const MCInstrInfo &MII, const MCRegisterInfo &MRI)
23
2.56k
    : MCInstPrinter(MAI, MII, MRI) {}
24
25
  //Autogenerated by tblgen
26
  void printInstruction(const MCInst *MI, const MCSubtargetInfo &STI,
27
                        raw_ostream &O);
28
  static const char *getRegisterName(unsigned RegNo);
29
30
  void printInst(const MCInst *MI, raw_ostream &O, StringRef Annot,
31
                 const MCSubtargetInfo &STI) override;
32
  static void printRegOperand(unsigned RegNo, raw_ostream &O,
33
                              const MCRegisterInfo &MRI);
34
35
private:
36
  void printU4ImmOperand(const MCInst *MI, unsigned OpNo,
37
                         const MCSubtargetInfo &STI, raw_ostream &O);
38
  void printU8ImmOperand(const MCInst *MI, unsigned OpNo, raw_ostream &O);
39
  void printU16ImmOperand(const MCInst *MI, unsigned OpNo,
40
                          const MCSubtargetInfo &STI, raw_ostream &O);
41
  void printU4ImmDecOperand(const MCInst *MI, unsigned OpNo, raw_ostream &O);
42
  void printU8ImmDecOperand(const MCInst *MI, unsigned OpNo, raw_ostream &O);
43
  void printU16ImmDecOperand(const MCInst *MI, unsigned OpNo, raw_ostream &O);
44
  void printS13ImmDecOperand(const MCInst *MI, unsigned OpNo,
45
                             const MCSubtargetInfo &STI, raw_ostream &O);
46
  void printU32ImmOperand(const MCInst *MI, unsigned OpNo,
47
                          const MCSubtargetInfo &STI, raw_ostream &O);
48
  void printNamedBit(const MCInst *MI, unsigned OpNo, raw_ostream &O,
49
                     StringRef BitName);
50
  void printOffen(const MCInst *MI, unsigned OpNo, raw_ostream &O);
51
  void printIdxen(const MCInst *MI, unsigned OpNo, raw_ostream &O);
52
  void printAddr64(const MCInst *MI, unsigned OpNo, raw_ostream &O);
53
  void printMBUFOffset(const MCInst *MI, unsigned OpNo, raw_ostream &O);
54
  void printOffset(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
55
                   raw_ostream &O);
56
  void printOffsetS13(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
57
                      raw_ostream &O);
58
59
  void printOffset0(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
60
                    raw_ostream &O);
61
  void printOffset1(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
62
                    raw_ostream &O);
63
  void printSMRDOffset8(const MCInst *MI, unsigned OpNo,
64
                       const MCSubtargetInfo &STI, raw_ostream &O);
65
  void printSMRDOffset20(const MCInst *MI, unsigned OpNo,
66
                       const MCSubtargetInfo &STI, raw_ostream &O);
67
  void printSMRDLiteralOffset(const MCInst *MI, unsigned OpNo,
68
                              const MCSubtargetInfo &STI, raw_ostream &O);
69
  void printGDS(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
70
                raw_ostream &O);
71
  void printDLC(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
72
                raw_ostream &O);
73
  void printGLC(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
74
                raw_ostream &O);
75
  void printSLC(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
76
                raw_ostream &O);
77
  void printTFE(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
78
                raw_ostream &O);
79
  void printDMask(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
80
                  raw_ostream &O);
81
  void printDim(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
82
                raw_ostream &O);
83
  void printUNorm(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
84
                  raw_ostream &O);
85
  void printDA(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
86
               raw_ostream &O);
87
  void printR128A16(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
88
                 raw_ostream &O);
89
  void printLWE(const MCInst *MI, unsigned OpNo,
90
                const MCSubtargetInfo &STI, raw_ostream &O);
91
  void printD16(const MCInst *MI, unsigned OpNo,
92
                const MCSubtargetInfo &STI, raw_ostream &O);
93
  void printExpCompr(const MCInst *MI, unsigned OpNo,
94
                     const MCSubtargetInfo &STI, raw_ostream &O);
95
  void printExpVM(const MCInst *MI, unsigned OpNo,
96
                  const MCSubtargetInfo &STI, raw_ostream &O);
97
  void printFORMAT(const MCInst *MI, unsigned OpNo,
98
                   const MCSubtargetInfo &STI, raw_ostream &O);
99
100
  void printRegOperand(unsigned RegNo, raw_ostream &O);
101
  void printVOPDst(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
102
                   raw_ostream &O);
103
  void printVINTRPDst(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
104
                      raw_ostream &O);
105
  void printImmediate16(uint32_t Imm, const MCSubtargetInfo &STI,
106
                        raw_ostream &O);
107
  void printImmediateV216(uint32_t Imm, const MCSubtargetInfo &STI,
108
                          raw_ostream &O);
109
  void printImmediate32(uint32_t Imm, const MCSubtargetInfo &STI,
110
                        raw_ostream &O);
111
  void printImmediate64(uint64_t Imm, const MCSubtargetInfo &STI,
112
                        raw_ostream &O);
113
  void printOperand(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
114
                    raw_ostream &O);
115
  void printOperandAndFPInputMods(const MCInst *MI, unsigned OpNo,
116
                                  const MCSubtargetInfo &STI, raw_ostream &O);
117
  void printOperandAndIntInputMods(const MCInst *MI, unsigned OpNo,
118
                                   const MCSubtargetInfo &STI, raw_ostream &O);
119
  void printDPPCtrl(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
120
                    raw_ostream &O);
121
  void printRowMask(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
122
                    raw_ostream &O);
123
  void printBankMask(const MCInst *MI, unsigned OpNo,
124
                     const MCSubtargetInfo &STI, raw_ostream &O);
125
  void printBoundCtrl(const MCInst *MI, unsigned OpNo,
126
                      const MCSubtargetInfo &STI, raw_ostream &O);
127
  void printSDWASel(const MCInst *MI, unsigned OpNo, raw_ostream &O);
128
  void printSDWADstSel(const MCInst *MI, unsigned OpNo,
129
                       const MCSubtargetInfo &STI, raw_ostream &O);
130
  void printSDWASrc0Sel(const MCInst *MI, unsigned OpNo,
131
                        const MCSubtargetInfo &STI, raw_ostream &O);
132
  void printSDWASrc1Sel(const MCInst *MI, unsigned OpNo,
133
                        const MCSubtargetInfo &STI, raw_ostream &O);
134
  void printSDWADstUnused(const MCInst *MI, unsigned OpNo,
135
                          const MCSubtargetInfo &STI, raw_ostream &O);
136
  void printPackedModifier(const MCInst *MI, StringRef Name, unsigned Mod,
137
                           raw_ostream &O);
138
  void printOpSel(const MCInst *MI, unsigned OpNo,
139
                  const MCSubtargetInfo &STI, raw_ostream &O);
140
  void printOpSelHi(const MCInst *MI, unsigned OpNo,
141
                  const MCSubtargetInfo &STI, raw_ostream &O);
142
  void printNegLo(const MCInst *MI, unsigned OpNo,
143
                  const MCSubtargetInfo &STI, raw_ostream &O);
144
  void printNegHi(const MCInst *MI, unsigned OpNo,
145
                  const MCSubtargetInfo &STI, raw_ostream &O);
146
  void printInterpSlot(const MCInst *MI, unsigned OpNo,
147
                       const MCSubtargetInfo &STI, raw_ostream &O);
148
  void printInterpAttr(const MCInst *MI, unsigned OpNo,
149
                       const MCSubtargetInfo &STI, raw_ostream &O);
150
  void printInterpAttrChan(const MCInst *MI, unsigned OpNo,
151
                           const MCSubtargetInfo &STI, raw_ostream &O);
152
153
  void printVGPRIndexMode(const MCInst *MI, unsigned OpNo,
154
                          const MCSubtargetInfo &STI, raw_ostream &O);
155
  void printMemOperand(const MCInst *MI, unsigned OpNo,
156
                       const MCSubtargetInfo &STI, raw_ostream &O);
157
  void printDefaultVccOperand(unsigned OpNo, const MCSubtargetInfo &STI,
158
                              raw_ostream &O);
159
160
161
  template <unsigned N>
162
  void printExpSrcN(const MCInst *MI, unsigned OpNo,
163
                    const MCSubtargetInfo &STI, raw_ostream &O);
164
  void printExpSrc0(const MCInst *MI, unsigned OpNo,
165
                    const MCSubtargetInfo &STI, raw_ostream &O);
166
  void printExpSrc1(const MCInst *MI, unsigned OpNo,
167
                    const MCSubtargetInfo &STI, raw_ostream &O);
168
  void printExpSrc2(const MCInst *MI, unsigned OpNo,
169
                    const MCSubtargetInfo &STI, raw_ostream &O);
170
  void printExpSrc3(const MCInst *MI, unsigned OpNo,
171
                    const MCSubtargetInfo &STI, raw_ostream &O);
172
  void printExpTgt(const MCInst *MI, unsigned OpNo,
173
                   const MCSubtargetInfo &STI, raw_ostream &O);
174
175
public:
176
  static void printIfSet(const MCInst *MI, unsigned OpNo, raw_ostream &O,
177
                         StringRef Asm, StringRef Default = "");
178
  static void printIfSet(const MCInst *MI, unsigned OpNo, raw_ostream &O,
179
                         char Asm);
180
protected:
181
  void printAbs(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
182
                raw_ostream &O);
183
  void printHigh(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
184
                 raw_ostream &O);
185
  void printClamp(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
186
                  raw_ostream &O);
187
  void printClampSI(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
188
                    raw_ostream &O);
189
  void printOModSI(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
190
                   raw_ostream &O);
191
  void printLiteral(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
192
                    raw_ostream &O);
193
  void printLast(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
194
                 raw_ostream &O);
195
  void printNeg(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
196
                raw_ostream &O);
197
  void printOMOD(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
198
                 raw_ostream &O);
199
  void printRel(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
200
                raw_ostream &O);
201
  void printUpdateExecMask(const MCInst *MI, unsigned OpNo,
202
                           const MCSubtargetInfo &STI, raw_ostream &O);
203
  void printUpdatePred(const MCInst *MI, unsigned OpNo,
204
                       const MCSubtargetInfo &STI, raw_ostream &O);
205
  void printWrite(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
206
                  raw_ostream &O);
207
  void printBankSwizzle(const MCInst *MI, unsigned OpNo,
208
                        const MCSubtargetInfo &STI, raw_ostream &O);
209
  void printRSel(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
210
                 raw_ostream &O);
211
  void printCT(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
212
               raw_ostream &O);
213
  void printKCache(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
214
                   raw_ostream &O);
215
  void printSendMsg(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
216
                    raw_ostream &O);
217
  void printSwizzle(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
218
                    raw_ostream &O);
219
  void printWaitFlag(const MCInst *MI, unsigned OpNo,
220
                     const MCSubtargetInfo &STI, raw_ostream &O);
221
  void printHwreg(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
222
                  raw_ostream &O);
223
  void printEndpgm(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
224
                   raw_ostream &O);
225
};
226
227
class R600InstPrinter : public MCInstPrinter {
228
public:
229
  R600InstPrinter(const MCAsmInfo &MAI, const MCInstrInfo &MII,
230
                  const MCRegisterInfo &MRI)
231
261
    : MCInstPrinter(MAI, MII, MRI) {}
232
233
  void printInst(const MCInst *MI, raw_ostream &O, StringRef Annot,
234
                 const MCSubtargetInfo &STI) override;
235
  void printInstruction(const MCInst *MI, raw_ostream &O);
236
  static const char *getRegisterName(unsigned RegNo);
237
238
  void printAbs(const MCInst *MI, unsigned OpNo, raw_ostream &O);
239
  void printBankSwizzle(const MCInst *MI, unsigned OpNo, raw_ostream &O);
240
  void printClamp(const MCInst *MI, unsigned OpNo, raw_ostream &O);
241
  void printCT(const MCInst *MI, unsigned OpNo, raw_ostream &O);
242
  void printKCache(const MCInst *MI, unsigned OpNo, raw_ostream &O);
243
  void printLast(const MCInst *MI, unsigned OpNo, raw_ostream &O);
244
  void printLiteral(const MCInst *MI, unsigned OpNo, raw_ostream &O);
245
  void printMemOperand(const MCInst *MI, unsigned OpNo, raw_ostream &O);
246
  void printNeg(const MCInst *MI, unsigned OpNo, raw_ostream &O);
247
  void printOMOD(const MCInst *MI, unsigned OpNo, raw_ostream &O);
248
  void printOperand(const MCInst *MI, unsigned OpNo, raw_ostream &O);
249
  void printRel(const MCInst *MI, unsigned OpNo, raw_ostream &O);
250
  void printRSel(const MCInst *MI, unsigned OpNo, raw_ostream &O);
251
  void printUpdateExecMask(const MCInst *MI, unsigned OpNo, raw_ostream &O);
252
  void printUpdatePred(const MCInst *MI, unsigned OpNo, raw_ostream &O);
253
  void printWrite(const MCInst *MI, unsigned OpNo, raw_ostream &O);
254
};
255
256
} // End namespace llvm
257
258
#endif