Coverage Report

Created: 2025-08-28 06:43

/src/capstonenext/arch/SystemZ/SystemZInstPrinter.c
Line
Count
Source (jump to first uncovered line)
1
/* Capstone Disassembly Engine, http://www.capstone-engine.org */
2
/* By Nguyen Anh Quynh <aquynh@gmail.com>, 2013-2022, */
3
/*    Rot127 <unisono@quyllur.org> 2022-2023 */
4
/* Automatically translated source file from LLVM. */
5
6
/* LLVM-commit: <commit> */
7
/* LLVM-tag: <tag> */
8
9
/* Only small edits allowed. */
10
/* For multiple similar edits, please create a Patch for the translator. */
11
12
/* Capstone's C++ file translator: */
13
/* https://github.com/capstone-engine/capstone/tree/next/suite/auto-sync */
14
15
//===- SystemZInstPrinter.cpp - Convert SystemZ MCInst to assembly syntax -===//
16
//
17
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
18
// See https://llvm.org/LICENSE.txt for license information.
19
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
20
//
21
//===----------------------------------------------------------------------===//
22
23
#include <ctype.h>
24
#include <stdint.h>
25
#include <stdio.h>
26
#include <string.h>
27
#include <stdlib.h>
28
#include <capstone/platform.h>
29
30
#include "../../MathExtras.h"
31
#include "../../MCAsmInfo.h"
32
33
#include "SystemZMapping.h"
34
#include "SystemZInstPrinter.h"
35
36
43.6k
#define CONCAT(a, b) CONCAT_(a, b)
37
43.6k
#define CONCAT_(a, b) a##_##b
38
39
static void printAddress(const MCAsmInfo *MAI, MCRegister Base,
40
       const MCOperand *DispMO, MCRegister Index, SStream *O);
41
static void printMCOperandMAI(const MCOperand *MO, const MCAsmInfo *MAI,
42
            SStream *O);
43
static void printRegName(const MCInst *MI, SStream *O, MCRegister Reg);
44
static void printInst(MCInst *MI, uint64_t Address, const char *Annot,
45
          SStream *O);
46
static void printOperand(MCInst *MI, int OpNum, SStream *O);
47
static void printU1ImmOperand(MCInst *MI, int OpNum, SStream *O);
48
static void printU2ImmOperand(MCInst *MI, int OpNum, SStream *O);
49
static void printU3ImmOperand(MCInst *MI, int OpNum, SStream *O);
50
static void printU4ImmOperand(MCInst *MI, int OpNum, SStream *O);
51
static void printS8ImmOperand(MCInst *MI, int OpNum, SStream *O);
52
static void printU8ImmOperand(MCInst *MI, int OpNum, SStream *O);
53
static void printU12ImmOperand(MCInst *MI, int OpNum, SStream *O);
54
static void printS16ImmOperand(MCInst *MI, int OpNum, SStream *O);
55
static void printU16ImmOperand(MCInst *MI, int OpNum, SStream *O);
56
static void printS32ImmOperand(MCInst *MI, int OpNum, SStream *O);
57
static void printU32ImmOperand(MCInst *MI, int OpNum, SStream *O);
58
static void printU48ImmOperand(MCInst *MI, int OpNum, SStream *O);
59
static void printBDAddrOperand(MCInst *MI, int OpNum, SStream *O);
60
static void printBDXAddrOperand(MCInst *MI, int OpNum, SStream *O);
61
static void printBDLAddrOperand(MCInst *MI, int OpNum, SStream *O);
62
static void printBDRAddrOperand(MCInst *MI, int OpNum, SStream *O);
63
static void printBDVAddrOperand(MCInst *MI, int OpNum, SStream *O);
64
static void printPCRelOperand(MCInst *MI, uint64_t Address, int OpNum,
65
            SStream *O);
66
static void printPCRelTLSOperand(MCInst *MI, uint64_t Address, int OpNum,
67
         SStream *O);
68
// This forms part of the instruction name rather than the operand list.
69
// Print the mnemonic for a condition-code mask ("ne", "lh", etc.)
70
static void printCond4Operand(MCInst *MI, int OpNum, SStream *O);
71
72
#include "SystemZGenAsmWriter.inc"
73
74
#define DECLARE_printUImmOperand(N) \
75
  static void CONCAT(printUImmOperand, N)(MCInst * MI, int OpNum, \
76
            SStream *O);
77
DECLARE_printUImmOperand(1);
78
DECLARE_printUImmOperand(2);
79
DECLARE_printUImmOperand(3);
80
DECLARE_printUImmOperand(4);
81
DECLARE_printUImmOperand(8);
82
DECLARE_printUImmOperand(12);
83
DECLARE_printUImmOperand(16);
84
DECLARE_printUImmOperand(32);
85
DECLARE_printUImmOperand(48);
86
87
#define DECLARE_printSImmOperand(N) \
88
  static void CONCAT(printSImmOperand, N)(MCInst * MI, int OpNum, \
89
            SStream *O);
90
DECLARE_printSImmOperand(8);
91
DECLARE_printSImmOperand(16);
92
DECLARE_printSImmOperand(32);
93
94
static void printAddress(const MCAsmInfo *MAI, MCRegister Base,
95
       const MCOperand *DispMO, MCRegister Index, SStream *O)
96
74.9k
{
97
74.9k
  printMCOperandMAI(DispMO, MAI, O);
98
74.9k
  if (Base || Index) {
99
55.0k
    SStream_concat0(O, "(");
100
101
55.0k
    if (Index) {
102
23.0k
      printFormattedRegName(MAI, Index, O);
103
23.0k
      SStream_concat0(O, ",");
104
23.0k
    }
105
55.0k
    if (Base)
106
47.9k
      printFormattedRegName(MAI, Base, O);
107
7.08k
    else
108
7.08k
      SStream_concat0(O, "0");
109
110
55.0k
    SStream_concat0(O, ")");
111
55.0k
  }
112
74.9k
}
113
114
static void printMCOperandMAI(const MCOperand *MO, const MCAsmInfo *MAI,
115
            SStream *O)
116
87.5k
{
117
87.5k
  if (MCOperand_isReg(MO)) {
118
0
    if (!MCOperand_getReg(MO))
119
0
      SStream_concat1(O, '0');
120
0
    else
121
0
      printFormattedRegName(MAI, MCOperand_getReg(MO), O);
122
87.5k
  } else if (MCOperand_isImm(MO))
123
87.5k
    printInt64(markup_OS(O, Markup_Immediate),
124
87.5k
         MCOperand_getImm(MO));
125
0
  else if (MCOperand_isExpr(MO))
126
0
    printExpr(O, MCOperand_getExpr(MO));
127
0
  else
128
0
    CS_ASSERT(0 && "Invalid operand");
129
87.5k
}
130
131
static void printMCOperand(const MCInst *MI, const MCOperand *MO, SStream *O)
132
175k
{
133
175k
  if (MCOperand_isReg(MO)) {
134
175k
    if (!MCOperand_getReg(MO))
135
1.73k
      SStream_concat0(O, "0");
136
137
173k
    else
138
173k
      printFormattedRegName(&MI->MAI, MCOperand_getReg(MO),
139
173k
                O);
140
175k
  } else if (MCOperand_isImm(MO))
141
0
    printInt64(markup_OS(O, Markup_Immediate),
142
0
         MCOperand_getImm(MO));
143
0
  else if (MCOperand_isExpr(MO))
144
0
    printExpr(O, MCOperand_getExpr(MO));
145
0
  else
146
0
    CS_ASSERT_RET(0 && "Invalid operand");
147
175k
}
148
149
void printFormattedRegName(const MCAsmInfo *MAI, MCRegister Reg, SStream *O)
150
255k
{
151
255k
  const char *RegName = getRegisterName(Reg);
152
255k
  if (MAI->assemblerDialect == SYSTEMZASMDIALECT_AD_ATT) {
153
    // Skip register prefix so that only register number is left
154
0
    CS_ASSERT((isalpha(RegName[0]) && isdigit(RegName[1])));
155
0
    SStream_concat0(markup_OS(O, Markup_Register), (RegName + 1));
156
0
  } else
157
255k
    SStream_concat1(markup_OS(O, Markup_Register), '%');
158
255k
  SStream_concat0(markup_OS(O, Markup_Register), RegName);
159
255k
}
160
161
static void printRegName(const MCInst *MI, SStream *O, MCRegister Reg)
162
10.5k
{
163
10.5k
  printFormattedRegName(&MI->MAI, Reg, O);
164
10.5k
}
165
166
static void printInst(MCInst *MI, uint64_t Address, const char *Annot,
167
          SStream *O)
168
131k
{
169
131k
  printInstruction(MI, Address, O);
170
131k
}
171
172
#define DEFINE_printUImmOperand(N) \
173
  void CONCAT(printUImmOperand, N)(MCInst * MI, int OpNum, SStream *O) \
174
38.6k
  { \
175
38.6k
    MCOperand *MO = MCInst_getOperand(MI, (OpNum)); \
176
38.6k
    if (MCOperand_isExpr(MO)) { \
177
0
      printExpr(O, MCOperand_getExpr(MO)); \
178
0
      return; \
179
0
    } \
180
38.6k
    uint64_t Value = (uint64_t)(MCOperand_getImm(MO)); \
181
38.6k
    CS_ASSERT((isUIntN(N, Value) && "Invalid uimm argument")); \
182
38.6k
    printUInt64(markup_OS(O, Markup_Immediate), Value); \
183
38.6k
  }
SystemZInstPrinter.c:printUImmOperand_4
Line
Count
Source
174
21.9k
  { \
175
21.9k
    MCOperand *MO = MCInst_getOperand(MI, (OpNum)); \
176
21.9k
    if (MCOperand_isExpr(MO)) { \
177
0
      printExpr(O, MCOperand_getExpr(MO)); \
178
0
      return; \
179
0
    } \
180
21.9k
    uint64_t Value = (uint64_t)(MCOperand_getImm(MO)); \
181
21.9k
    CS_ASSERT((isUIntN(N, Value) && "Invalid uimm argument")); \
182
21.9k
    printUInt64(markup_OS(O, Markup_Immediate), Value); \
183
21.9k
  }
SystemZInstPrinter.c:printUImmOperand_16
Line
Count
Source
174
2.28k
  { \
175
2.28k
    MCOperand *MO = MCInst_getOperand(MI, (OpNum)); \
176
2.28k
    if (MCOperand_isExpr(MO)) { \
177
0
      printExpr(O, MCOperand_getExpr(MO)); \
178
0
      return; \
179
0
    } \
180
2.28k
    uint64_t Value = (uint64_t)(MCOperand_getImm(MO)); \
181
2.28k
    CS_ASSERT((isUIntN(N, Value) && "Invalid uimm argument")); \
182
2.28k
    printUInt64(markup_OS(O, Markup_Immediate), Value); \
183
2.28k
  }
SystemZInstPrinter.c:printUImmOperand_32
Line
Count
Source
174
1.34k
  { \
175
1.34k
    MCOperand *MO = MCInst_getOperand(MI, (OpNum)); \
176
1.34k
    if (MCOperand_isExpr(MO)) { \
177
0
      printExpr(O, MCOperand_getExpr(MO)); \
178
0
      return; \
179
0
    } \
180
1.34k
    uint64_t Value = (uint64_t)(MCOperand_getImm(MO)); \
181
1.34k
    CS_ASSERT((isUIntN(N, Value) && "Invalid uimm argument")); \
182
1.34k
    printUInt64(markup_OS(O, Markup_Immediate), Value); \
183
1.34k
  }
Unexecuted instantiation: SystemZInstPrinter.c:printUImmOperand_48
SystemZInstPrinter.c:printUImmOperand_8
Line
Count
Source
174
8.48k
  { \
175
8.48k
    MCOperand *MO = MCInst_getOperand(MI, (OpNum)); \
176
8.48k
    if (MCOperand_isExpr(MO)) { \
177
0
      printExpr(O, MCOperand_getExpr(MO)); \
178
0
      return; \
179
0
    } \
180
8.48k
    uint64_t Value = (uint64_t)(MCOperand_getImm(MO)); \
181
8.48k
    CS_ASSERT((isUIntN(N, Value) && "Invalid uimm argument")); \
182
8.48k
    printUInt64(markup_OS(O, Markup_Immediate), Value); \
183
8.48k
  }
SystemZInstPrinter.c:printUImmOperand_2
Line
Count
Source
174
1.92k
  { \
175
1.92k
    MCOperand *MO = MCInst_getOperand(MI, (OpNum)); \
176
1.92k
    if (MCOperand_isExpr(MO)) { \
177
0
      printExpr(O, MCOperand_getExpr(MO)); \
178
0
      return; \
179
0
    } \
180
1.92k
    uint64_t Value = (uint64_t)(MCOperand_getImm(MO)); \
181
1.92k
    CS_ASSERT((isUIntN(N, Value) && "Invalid uimm argument")); \
182
1.92k
    printUInt64(markup_OS(O, Markup_Immediate), Value); \
183
1.92k
  }
SystemZInstPrinter.c:printUImmOperand_1
Line
Count
Source
174
1.46k
  { \
175
1.46k
    MCOperand *MO = MCInst_getOperand(MI, (OpNum)); \
176
1.46k
    if (MCOperand_isExpr(MO)) { \
177
0
      printExpr(O, MCOperand_getExpr(MO)); \
178
0
      return; \
179
0
    } \
180
1.46k
    uint64_t Value = (uint64_t)(MCOperand_getImm(MO)); \
181
1.46k
    CS_ASSERT((isUIntN(N, Value) && "Invalid uimm argument")); \
182
1.46k
    printUInt64(markup_OS(O, Markup_Immediate), Value); \
183
1.46k
  }
SystemZInstPrinter.c:printUImmOperand_12
Line
Count
Source
174
139
  { \
175
139
    MCOperand *MO = MCInst_getOperand(MI, (OpNum)); \
176
139
    if (MCOperand_isExpr(MO)) { \
177
0
      printExpr(O, MCOperand_getExpr(MO)); \
178
0
      return; \
179
0
    } \
180
139
    uint64_t Value = (uint64_t)(MCOperand_getImm(MO)); \
181
139
    CS_ASSERT((isUIntN(N, Value) && "Invalid uimm argument")); \
182
139
    printUInt64(markup_OS(O, Markup_Immediate), Value); \
183
139
  }
SystemZInstPrinter.c:printUImmOperand_3
Line
Count
Source
174
1.01k
  { \
175
1.01k
    MCOperand *MO = MCInst_getOperand(MI, (OpNum)); \
176
1.01k
    if (MCOperand_isExpr(MO)) { \
177
0
      printExpr(O, MCOperand_getExpr(MO)); \
178
0
      return; \
179
0
    } \
180
1.01k
    uint64_t Value = (uint64_t)(MCOperand_getImm(MO)); \
181
1.01k
    CS_ASSERT((isUIntN(N, Value) && "Invalid uimm argument")); \
182
1.01k
    printUInt64(markup_OS(O, Markup_Immediate), Value); \
183
1.01k
  }
184
DEFINE_printUImmOperand(1);
185
DEFINE_printUImmOperand(2);
186
DEFINE_printUImmOperand(3);
187
DEFINE_printUImmOperand(4);
188
DEFINE_printUImmOperand(8);
189
DEFINE_printUImmOperand(12);
190
DEFINE_printUImmOperand(16);
191
DEFINE_printUImmOperand(32);
192
DEFINE_printUImmOperand(48);
193
194
#define DEFINE_printSImmOperand(N) \
195
  void CONCAT(printSImmOperand, N)(MCInst * MI, int OpNum, SStream *O) \
196
5.05k
  { \
197
5.05k
    MCOperand *MO = MCInst_getOperand(MI, (OpNum)); \
198
5.05k
    if (MCOperand_isExpr(MO)) { \
199
0
      printExpr(O, MCOperand_getExpr(MO)); \
200
0
      return; \
201
0
    } \
202
5.05k
    int64_t Value = \
203
5.05k
      MCOperand_getImm(MCInst_getOperand(MI, (OpNum))); \
204
5.05k
    if (N == 8) \
205
5.05k
      printInt8(markup_OS(O, Markup_Immediate), Value); \
206
5.05k
    else if (N == 16) \
207
3.49k
      printInt16(markup_OS(O, Markup_Immediate), Value); \
208
3.49k
    else if (N == 32) \
209
1.23k
      printInt32(markup_OS(O, Markup_Immediate), Value); \
210
1.23k
    else \
211
1.23k
      CS_ASSERT(0 && "Unreachable"); \
212
5.05k
  }
SystemZInstPrinter.c:printSImmOperand_8
Line
Count
Source
196
1.56k
  { \
197
1.56k
    MCOperand *MO = MCInst_getOperand(MI, (OpNum)); \
198
1.56k
    if (MCOperand_isExpr(MO)) { \
199
0
      printExpr(O, MCOperand_getExpr(MO)); \
200
0
      return; \
201
0
    } \
202
1.56k
    int64_t Value = \
203
1.56k
      MCOperand_getImm(MCInst_getOperand(MI, (OpNum))); \
204
1.56k
    if (N == 8) \
205
1.56k
      printInt8(markup_OS(O, Markup_Immediate), Value); \
206
1.56k
    else if (N == 16) \
207
0
      printInt16(markup_OS(O, Markup_Immediate), Value); \
208
0
    else if (N == 32) \
209
0
      printInt32(markup_OS(O, Markup_Immediate), Value); \
210
0
    else \
211
0
      CS_ASSERT(0 && "Unreachable"); \
212
1.56k
  }
SystemZInstPrinter.c:printSImmOperand_16
Line
Count
Source
196
2.26k
  { \
197
2.26k
    MCOperand *MO = MCInst_getOperand(MI, (OpNum)); \
198
2.26k
    if (MCOperand_isExpr(MO)) { \
199
0
      printExpr(O, MCOperand_getExpr(MO)); \
200
0
      return; \
201
0
    } \
202
2.26k
    int64_t Value = \
203
2.26k
      MCOperand_getImm(MCInst_getOperand(MI, (OpNum))); \
204
2.26k
    if (N == 8) \
205
2.26k
      printInt8(markup_OS(O, Markup_Immediate), Value); \
206
2.26k
    else if (N == 16) \
207
2.26k
      printInt16(markup_OS(O, Markup_Immediate), Value); \
208
2.26k
    else if (N == 32) \
209
0
      printInt32(markup_OS(O, Markup_Immediate), Value); \
210
0
    else \
211
0
      CS_ASSERT(0 && "Unreachable"); \
212
2.26k
  }
SystemZInstPrinter.c:printSImmOperand_32
Line
Count
Source
196
1.23k
  { \
197
1.23k
    MCOperand *MO = MCInst_getOperand(MI, (OpNum)); \
198
1.23k
    if (MCOperand_isExpr(MO)) { \
199
0
      printExpr(O, MCOperand_getExpr(MO)); \
200
0
      return; \
201
0
    } \
202
1.23k
    int64_t Value = \
203
1.23k
      MCOperand_getImm(MCInst_getOperand(MI, (OpNum))); \
204
1.23k
    if (N == 8) \
205
1.23k
      printInt8(markup_OS(O, Markup_Immediate), Value); \
206
1.23k
    else if (N == 16) \
207
1.23k
      printInt16(markup_OS(O, Markup_Immediate), Value); \
208
1.23k
    else if (N == 32) \
209
1.23k
      printInt32(markup_OS(O, Markup_Immediate), Value); \
210
1.23k
    else \
211
1.23k
      CS_ASSERT(0 && "Unreachable"); \
212
1.23k
  }
213
DEFINE_printSImmOperand(8);
214
DEFINE_printSImmOperand(16);
215
DEFINE_printSImmOperand(32);
216
217
static void printU1ImmOperand(MCInst *MI, int OpNum, SStream *O)
218
1.46k
{
219
1.46k
  add_cs_detail(MI, SystemZ_OP_GROUP_U1ImmOperand, OpNum);
220
1.46k
  CONCAT(printUImmOperand, 1)(MI, OpNum, O);
221
1.46k
}
222
223
static void printU2ImmOperand(MCInst *MI, int OpNum, SStream *O)
224
1.92k
{
225
1.92k
  add_cs_detail(MI, SystemZ_OP_GROUP_U2ImmOperand, OpNum);
226
1.92k
  CONCAT(printUImmOperand, 2)(MI, OpNum, O);
227
1.92k
}
228
229
static void printU3ImmOperand(MCInst *MI, int OpNum, SStream *O)
230
1.01k
{
231
1.01k
  add_cs_detail(MI, SystemZ_OP_GROUP_U3ImmOperand, OpNum);
232
1.01k
  CONCAT(printUImmOperand, 3)(MI, OpNum, O);
233
1.01k
}
234
235
static void printU4ImmOperand(MCInst *MI, int OpNum, SStream *O)
236
21.9k
{
237
21.9k
  add_cs_detail(MI, SystemZ_OP_GROUP_U4ImmOperand, OpNum);
238
21.9k
  CONCAT(printUImmOperand, 4)(MI, OpNum, O);
239
21.9k
}
240
241
static void printS8ImmOperand(MCInst *MI, int OpNum, SStream *O)
242
1.56k
{
243
1.56k
  add_cs_detail(MI, SystemZ_OP_GROUP_S8ImmOperand, OpNum);
244
1.56k
  CONCAT(printSImmOperand, 8)(MI, OpNum, O);
245
1.56k
}
246
247
static void printU8ImmOperand(MCInst *MI, int OpNum, SStream *O)
248
8.48k
{
249
8.48k
  add_cs_detail(MI, SystemZ_OP_GROUP_U8ImmOperand, OpNum);
250
8.48k
  CONCAT(printUImmOperand, 8)(MI, OpNum, O);
251
8.48k
}
252
253
static void printU12ImmOperand(MCInst *MI, int OpNum, SStream *O)
254
139
{
255
139
  add_cs_detail(MI, SystemZ_OP_GROUP_U12ImmOperand, OpNum);
256
139
  CONCAT(printUImmOperand, 12)(MI, OpNum, O);
257
139
}
258
259
static void printS16ImmOperand(MCInst *MI, int OpNum, SStream *O)
260
2.26k
{
261
2.26k
  add_cs_detail(MI, SystemZ_OP_GROUP_S16ImmOperand, OpNum);
262
2.26k
  CONCAT(printSImmOperand, 16)(MI, OpNum, O);
263
2.26k
}
264
265
static void printU16ImmOperand(MCInst *MI, int OpNum, SStream *O)
266
2.28k
{
267
2.28k
  add_cs_detail(MI, SystemZ_OP_GROUP_U16ImmOperand, OpNum);
268
2.28k
  CONCAT(printUImmOperand, 16)(MI, OpNum, O);
269
2.28k
}
270
271
static void printS32ImmOperand(MCInst *MI, int OpNum, SStream *O)
272
1.23k
{
273
1.23k
  add_cs_detail(MI, SystemZ_OP_GROUP_S32ImmOperand, OpNum);
274
1.23k
  CONCAT(printSImmOperand, 32)(MI, OpNum, O);
275
1.23k
}
276
277
static void printU32ImmOperand(MCInst *MI, int OpNum, SStream *O)
278
1.34k
{
279
1.34k
  add_cs_detail(MI, SystemZ_OP_GROUP_U32ImmOperand, OpNum);
280
1.34k
  CONCAT(printUImmOperand, 32)(MI, OpNum, O);
281
1.34k
}
282
283
static void printU48ImmOperand(MCInst *MI, int OpNum, SStream *O)
284
0
{
285
0
  add_cs_detail(MI, SystemZ_OP_GROUP_U48ImmOperand, OpNum);
286
0
  CONCAT(printUImmOperand, 48)(MI, OpNum, O);
287
0
}
288
289
static void printPCRelOperand(MCInst *MI, uint64_t Address, int OpNum,
290
            SStream *O)
291
5.02k
{
292
5.02k
  add_cs_detail(MI, SystemZ_OP_GROUP_PCRelOperand, OpNum);
293
5.02k
  MCOperand *MO = MCInst_getOperand(MI, (OpNum));
294
5.02k
  if (MCOperand_isImm(MO)) {
295
5.02k
    printInt64(O, MCOperand_getImm(MO));
296
5.02k
  } else
297
0
    printExpr(O, MCOperand_getExpr(MO));
298
5.02k
}
299
300
static void printPCRelTLSOperand(MCInst *MI, uint64_t Address, int OpNum,
301
         SStream *O)
302
145
{
303
  // Output the PC-relative operand.
304
145
  printPCRelOperand(MI, MI->address, OpNum, O);
305
306
  // Output the TLS marker if present.
307
145
  if ((unsigned)OpNum + 1 < MCInst_getNumOperands(MI)) {
308
    // Expressions not supported
309
0
  }
310
145
}
311
312
static void printOperand(MCInst *MI, int OpNum, SStream *O)
313
296k
{
314
296k
  add_cs_detail(MI, SystemZ_OP_GROUP_Operand, OpNum);
315
296k
  printMCOperand(MI, MCInst_getOperand(MI, (OpNum)), O);
316
296k
}
317
318
static void printBDAddrOperand(MCInst *MI, int OpNum, SStream *O)
319
58.7k
{
320
58.7k
  add_cs_detail(MI, SystemZ_OP_GROUP_BDAddrOperand, OpNum);
321
58.7k
  printAddress(&MI->MAI, MCOperand_getReg(MCInst_getOperand(MI, (OpNum))),
322
58.7k
         MCInst_getOperand(MI, (OpNum + 1)), 0, O);
323
58.7k
}
324
325
static void printBDXAddrOperand(MCInst *MI, int OpNum, SStream *O)
326
50.5k
{
327
50.5k
  add_cs_detail(MI, SystemZ_OP_GROUP_BDXAddrOperand, OpNum);
328
50.5k
  printAddress(&MI->MAI, MCOperand_getReg(MCInst_getOperand(MI, (OpNum))),
329
50.5k
         MCInst_getOperand(MI, (OpNum + 1)),
330
50.5k
         MCOperand_getReg(MCInst_getOperand(MI, (OpNum + 2))), O);
331
50.5k
}
332
333
static void printBDLAddrOperand(MCInst *MI, int OpNum, SStream *O)
334
11.9k
{
335
11.9k
  add_cs_detail(MI, SystemZ_OP_GROUP_BDLAddrOperand, OpNum);
336
11.9k
  unsigned Base = MCOperand_getReg(MCInst_getOperand(MI, (OpNum)));
337
11.9k
  MCOperand *DispMO = MCInst_getOperand(MI, (OpNum + 1));
338
11.9k
  uint64_t Length = MCOperand_getImm(MCInst_getOperand(MI, (OpNum + 2)));
339
11.9k
  printMCOperandMAI(DispMO, &MI->MAI, O);
340
11.9k
  SStream_concat1(O, '(');
341
11.9k
  printUInt64(O, Length);
342
11.9k
  if (Base) {
343
9.45k
    SStream_concat0(O, ",");
344
9.45k
    printRegName(MI, O, Base);
345
9.45k
  }
346
11.9k
  SStream_concat0(O, ")");
347
11.9k
}
348
349
static void printBDRAddrOperand(MCInst *MI, int OpNum, SStream *O)
350
595
{
351
595
  add_cs_detail(MI, SystemZ_OP_GROUP_BDRAddrOperand, OpNum);
352
595
  unsigned Base = MCOperand_getReg(MCInst_getOperand(MI, (OpNum)));
353
595
  MCOperand *DispMO = MCInst_getOperand(MI, (OpNum + 1));
354
595
  unsigned Length = MCOperand_getReg(MCInst_getOperand(MI, (OpNum + 2)));
355
595
  printMCOperandMAI(DispMO, &MI->MAI, O);
356
595
  SStream_concat0(O, "(");
357
595
  printRegName(MI, O, Length);
358
595
  if (Base) {
359
491
    SStream_concat0(O, ",");
360
491
    printRegName(MI, O, Base);
361
491
  }
362
595
  SStream_concat0(O, ")");
363
595
}
364
365
static void printBDVAddrOperand(MCInst *MI, int OpNum, SStream *O)
366
2.16k
{
367
2.16k
  add_cs_detail(MI, SystemZ_OP_GROUP_BDVAddrOperand, OpNum);
368
2.16k
  printAddress(&MI->MAI, MCOperand_getReg(MCInst_getOperand(MI, (OpNum))),
369
2.16k
         MCInst_getOperand(MI, (OpNum + 1)),
370
2.16k
         MCOperand_getReg(MCInst_getOperand(MI, (OpNum + 2))), O);
371
2.16k
}
372
373
static void printCond4Operand(MCInst *MI, int OpNum, SStream *O)
374
0
{
375
0
  add_cs_detail(MI, SystemZ_OP_GROUP_Cond4Operand, OpNum);
376
0
  static const char *const CondNames[] = { "o", "h",  "nle", "l",
377
0
             "nhe", "lh", "ne",  "e",
378
0
             "nlh", "he", "nl",  "le",
379
0
             "nh",  "no" };
380
0
  uint64_t Imm = MCOperand_getImm(MCInst_getOperand(MI, (OpNum)));
381
0
  CS_ASSERT((Imm > 0 && Imm < 15 && "Invalid condition"));
382
0
  SStream_concat0(O, CondNames[Imm - 1]);
383
0
}
384
385
const char *SystemZ_LLVM_getRegisterName(unsigned RegNo)
386
80.8k
{
387
80.8k
  return getRegisterName(RegNo);
388
80.8k
}
389
390
void SystemZ_LLVM_printInstruction(MCInst *MI, const char *Annotation,
391
           SStream *O)
392
131k
{
393
131k
  printInst(MI, MI->address, Annotation, O);
394
131k
}