Coverage Report

Created: 2025-10-28 07:02

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/capstonenext/arch/SystemZ/SystemZDisassembler.c
Line
Count
Source
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
//===-- SystemZDisassembler.cpp - Disassembler for SystemZ ------*- C++ -*-===//
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 <stdio.h>
24
#include <string.h>
25
#include <stdlib.h>
26
#include <capstone/platform.h>
27
28
#include "../../MCInst.h"
29
#include "../../MathExtras.h"
30
#include "../../MCInstPrinter.h"
31
#include "../../MCDisassembler.h"
32
#include "../../MCFixedLenDisassembler.h"
33
#include "../../cs_priv.h"
34
#include "../../utils.h"
35
36
#include "SystemZMCTargetDesc.h"
37
#include "SystemZDisassemblerExtension.h"
38
39
222k
#define CONCAT(a, b) CONCAT_(a, b)
40
222k
#define CONCAT_(a, b) a##_##b
41
42
#define DEBUG_TYPE "systemz-disassembler"
43
44
static DecodeStatus getInstruction(MCInst *Instr, uint16_t *Size,
45
           const uint8_t *Bytes, size_t BytesLen,
46
           uint64_t Address, SStream *CStream);
47
48
/// tryAddingSymbolicOperand - trys to add a symbolic operand in place of the
49
/// immediate Value in the MCInst.
50
///
51
/// @param Value      - The immediate Value, has had any PC adjustment made by
52
///                     the caller.
53
/// @param isBranch   - If the instruction is a branch instruction
54
/// @param Address    - The starting address of the instruction
55
/// @param Offset     - The byte offset to this immediate in the instruction
56
/// @param Width      - The byte width of this immediate in the instruction
57
///
58
/// If the getOpInfo() function was set when setupForSymbolicDisassembly() was
59
/// called then that function is called to get any symbolic information for the
60
/// immediate in the instruction using the Address, Offset and Width.  If that
61
/// returns non-zero then the symbolic information it returns is used to create
62
/// an MCExpr and that is added as an operand to the MCInst.  If getOpInfo()
63
/// returns zero and isBranch is true then a symbol look up for immediate Value
64
/// is done and if a symbol is found an MCExpr is created with that, else
65
/// an MCExpr with the immediate Value is created.  This function returns true
66
/// if it adds an operand to the MCInst and false otherwise.
67
static bool tryAddingSymbolicOperand(int64_t Value, bool IsBranch,
68
             uint64_t Address, uint64_t Offset,
69
             uint64_t Width, MCInst *MI,
70
             const void *Decoder)
71
5.13k
{
72
  // return Decoder->tryAddingSymbolicOperand(MI, Value, Address, IsBranch,
73
  //           Offset, Width, /*InstSize=*/0);
74
5.13k
  return false;
75
5.13k
}
76
77
static DecodeStatus decodeRegisterClass(MCInst *Inst, uint64_t RegNo,
78
          const unsigned *Regs, unsigned Size,
79
          bool IsAddr)
80
438k
{
81
438k
  CS_ASSERT((RegNo < Size && "Invalid register"));
82
438k
  if (IsAddr && RegNo == 0) {
83
53.4k
    RegNo = SystemZ_NoRegister;
84
384k
  } else {
85
384k
    RegNo = Regs[RegNo];
86
384k
    if (RegNo == 0)
87
160
      return MCDisassembler_Fail;
88
384k
  }
89
438k
  MCOperand_CreateReg0(Inst, (RegNo));
90
438k
  return MCDisassembler_Success;
91
438k
}
92
93
static DecodeStatus DecodeGR32BitRegisterClass(MCInst *Inst, uint64_t RegNo,
94
                 uint64_t Address,
95
                 const void *Decoder)
96
111k
{
97
111k
  return decodeRegisterClass(Inst, RegNo, SystemZMC_GR32Regs, 16, false);
98
111k
}
99
100
static DecodeStatus DecodeGRH32BitRegisterClass(MCInst *Inst, uint64_t RegNo,
101
            uint64_t Address,
102
            const void *Decoder)
103
16.5k
{
104
16.5k
  return decodeRegisterClass(Inst, RegNo, SystemZMC_GRH32Regs, 16, false);
105
16.5k
}
106
107
static DecodeStatus DecodeGR64BitRegisterClass(MCInst *Inst, uint64_t RegNo,
108
                 uint64_t Address,
109
                 const void *Decoder)
110
80.6k
{
111
80.6k
  return decodeRegisterClass(Inst, RegNo, SystemZMC_GR64Regs, 16, false);
112
80.6k
}
113
114
static DecodeStatus DecodeGR128BitRegisterClass(MCInst *Inst, uint64_t RegNo,
115
            uint64_t Address,
116
            const void *Decoder)
117
33.0k
{
118
33.0k
  return decodeRegisterClass(Inst, RegNo, SystemZMC_GR128Regs, 16, false);
119
33.0k
}
120
121
static DecodeStatus DecodeADDR32BitRegisterClass(MCInst *Inst, uint64_t RegNo,
122
             uint64_t Address,
123
             const void *Decoder)
124
7.20k
{
125
7.20k
  return decodeRegisterClass(Inst, RegNo, SystemZMC_GR32Regs, 16, true);
126
7.20k
}
127
128
static DecodeStatus DecodeADDR64BitRegisterClass(MCInst *Inst, uint64_t RegNo,
129
             uint64_t Address,
130
             const void *Decoder)
131
148k
{
132
148k
  return decodeRegisterClass(Inst, RegNo, SystemZMC_GR64Regs, 16, true);
133
148k
}
134
135
static DecodeStatus DecodeFP32BitRegisterClass(MCInst *Inst, uint64_t RegNo,
136
                 uint64_t Address,
137
                 const void *Decoder)
138
52.7k
{
139
52.7k
  return decodeRegisterClass(Inst, RegNo, SystemZMC_FP32Regs, 16, false);
140
52.7k
}
141
142
static DecodeStatus DecodeFP64BitRegisterClass(MCInst *Inst, uint64_t RegNo,
143
                 uint64_t Address,
144
                 const void *Decoder)
145
73.1k
{
146
73.1k
  return decodeRegisterClass(Inst, RegNo, SystemZMC_FP64Regs, 16, false);
147
73.1k
}
148
149
static DecodeStatus DecodeFP128BitRegisterClass(MCInst *Inst, uint64_t RegNo,
150
            uint64_t Address,
151
            const void *Decoder)
152
18.0k
{
153
18.0k
  return decodeRegisterClass(Inst, RegNo, SystemZMC_FP128Regs, 16, false);
154
18.0k
}
155
156
static DecodeStatus DecodeVR32BitRegisterClass(MCInst *Inst, uint64_t RegNo,
157
                 uint64_t Address,
158
                 const void *Decoder)
159
5.33k
{
160
5.33k
  return decodeRegisterClass(Inst, RegNo, SystemZMC_VR32Regs, 32, false);
161
5.33k
}
162
163
static DecodeStatus DecodeVR64BitRegisterClass(MCInst *Inst, uint64_t RegNo,
164
                 uint64_t Address,
165
                 const void *Decoder)
166
7.10k
{
167
7.10k
  return decodeRegisterClass(Inst, RegNo, SystemZMC_VR64Regs, 32, false);
168
7.10k
}
169
170
static DecodeStatus DecodeVR128BitRegisterClass(MCInst *Inst, uint64_t RegNo,
171
            uint64_t Address,
172
            const void *Decoder)
173
59.0k
{
174
59.0k
  return decodeRegisterClass(Inst, RegNo, SystemZMC_VR128Regs, 32, false);
175
59.0k
}
176
177
static DecodeStatus DecodeAR32BitRegisterClass(MCInst *Inst, uint64_t RegNo,
178
                 uint64_t Address,
179
                 const void *Decoder)
180
4.76k
{
181
4.76k
  return decodeRegisterClass(Inst, RegNo, SystemZMC_AR32Regs, 16, false);
182
4.76k
}
183
184
static DecodeStatus DecodeCR64BitRegisterClass(MCInst *Inst, uint64_t RegNo,
185
                 uint64_t Address,
186
                 const void *Decoder)
187
3.25k
{
188
3.25k
  return decodeRegisterClass(Inst, RegNo, SystemZMC_CR64Regs, 16, false);
189
3.25k
}
190
191
#define DEFINE_decodeUImmOperand(N) \
192
  static DecodeStatus CONCAT(decodeUImmOperand, N)(MCInst * Inst, \
193
               uint64_t Imm) \
194
136k
  { \
195
136k
    if (!isUIntN(N, Imm)) \
196
136k
      return MCDisassembler_Fail; \
197
136k
    MCOperand_CreateImm0(Inst, (Imm)); \
198
136k
    return MCDisassembler_Success; \
199
136k
  }
SystemZDisassembler.c:decodeUImmOperand_4
Line
Count
Source
194
31.4k
  { \
195
31.4k
    if (!isUIntN(N, Imm)) \
196
31.4k
      return MCDisassembler_Fail; \
197
31.4k
    MCOperand_CreateImm0(Inst, (Imm)); \
198
31.4k
    return MCDisassembler_Success; \
199
31.4k
  }
SystemZDisassembler.c:decodeUImmOperand_8
Line
Count
Source
194
9.13k
  { \
195
9.13k
    if (!isUIntN(N, Imm)) \
196
9.13k
      return MCDisassembler_Fail; \
197
9.13k
    MCOperand_CreateImm0(Inst, (Imm)); \
198
9.13k
    return MCDisassembler_Success; \
199
9.13k
  }
SystemZDisassembler.c:decodeUImmOperand_12
Line
Count
Source
194
86.5k
  { \
195
86.5k
    if (!isUIntN(N, Imm)) \
196
86.5k
      return MCDisassembler_Fail; \
197
86.5k
    MCOperand_CreateImm0(Inst, (Imm)); \
198
86.5k
    return MCDisassembler_Success; \
199
86.5k
  }
SystemZDisassembler.c:decodeUImmOperand_16
Line
Count
Source
194
1.83k
  { \
195
1.83k
    if (!isUIntN(N, Imm)) \
196
1.83k
      return MCDisassembler_Fail; \
197
1.83k
    MCOperand_CreateImm0(Inst, (Imm)); \
198
1.83k
    return MCDisassembler_Success; \
199
1.83k
  }
SystemZDisassembler.c:decodeUImmOperand_32
Line
Count
Source
194
1.37k
  { \
195
1.37k
    if (!isUIntN(N, Imm)) \
196
1.37k
      return MCDisassembler_Fail; \
197
1.37k
    MCOperand_CreateImm0(Inst, (Imm)); \
198
1.37k
    return MCDisassembler_Success; \
199
1.37k
  }
SystemZDisassembler.c:decodeUImmOperand_3
Line
Count
Source
194
1.72k
  { \
195
1.72k
    if (!isUIntN(N, Imm)) \
196
1.72k
      return MCDisassembler_Fail; \
197
1.72k
    MCOperand_CreateImm0(Inst, (Imm)); \
198
1.72k
    return MCDisassembler_Success; \
199
1.72k
  }
SystemZDisassembler.c:decodeUImmOperand_1
Line
Count
Source
194
2.38k
  { \
195
2.38k
    if (!isUIntN(N, Imm)) \
196
2.38k
      return MCDisassembler_Fail; \
197
2.38k
    MCOperand_CreateImm0(Inst, (Imm)); \
198
2.37k
    return MCDisassembler_Success; \
199
2.38k
  }
SystemZDisassembler.c:decodeUImmOperand_2
Line
Count
Source
194
1.82k
  { \
195
1.82k
    if (!isUIntN(N, Imm)) \
196
1.82k
      return MCDisassembler_Fail; \
197
1.82k
    MCOperand_CreateImm0(Inst, (Imm)); \
198
1.81k
    return MCDisassembler_Success; \
199
1.82k
  }
200
DEFINE_decodeUImmOperand(1);
201
DEFINE_decodeUImmOperand(2);
202
DEFINE_decodeUImmOperand(3);
203
DEFINE_decodeUImmOperand(4);
204
DEFINE_decodeUImmOperand(8);
205
DEFINE_decodeUImmOperand(12);
206
DEFINE_decodeUImmOperand(16);
207
DEFINE_decodeUImmOperand(32);
208
209
#define DEFINE_decodeSImmOperand(N) \
210
  static DecodeStatus CONCAT(decodeSImmOperand, N)(MCInst * Inst, \
211
               uint64_t Imm) \
212
26.7k
  { \
213
26.7k
    if (!isUIntN(N, Imm)) \
214
26.7k
      return MCDisassembler_Fail; \
215
26.7k
    MCOperand_CreateImm0(Inst, (SignExtend64((Imm), N))); \
216
26.7k
    return MCDisassembler_Success; \
217
26.7k
  }
SystemZDisassembler.c:decodeSImmOperand_16
Line
Count
Source
212
3.88k
  { \
213
3.88k
    if (!isUIntN(N, Imm)) \
214
3.88k
      return MCDisassembler_Fail; \
215
3.88k
    MCOperand_CreateImm0(Inst, (SignExtend64((Imm), N))); \
216
3.88k
    return MCDisassembler_Success; \
217
3.88k
  }
SystemZDisassembler.c:decodeSImmOperand_32
Line
Count
Source
212
1.80k
  { \
213
1.80k
    if (!isUIntN(N, Imm)) \
214
1.80k
      return MCDisassembler_Fail; \
215
1.80k
    MCOperand_CreateImm0(Inst, (SignExtend64((Imm), N))); \
216
1.80k
    return MCDisassembler_Success; \
217
1.80k
  }
SystemZDisassembler.c:decodeSImmOperand_20
Line
Count
Source
212
18.2k
  { \
213
18.2k
    if (!isUIntN(N, Imm)) \
214
18.2k
      return MCDisassembler_Fail; \
215
18.2k
    MCOperand_CreateImm0(Inst, (SignExtend64((Imm), N))); \
216
18.2k
    return MCDisassembler_Success; \
217
18.2k
  }
SystemZDisassembler.c:decodeSImmOperand_8
Line
Count
Source
212
2.79k
  { \
213
2.79k
    if (!isUIntN(N, Imm)) \
214
2.79k
      return MCDisassembler_Fail; \
215
2.79k
    MCOperand_CreateImm0(Inst, (SignExtend64((Imm), N))); \
216
2.79k
    return MCDisassembler_Success; \
217
2.79k
  }
218
DEFINE_decodeSImmOperand(8);
219
DEFINE_decodeSImmOperand(16);
220
DEFINE_decodeSImmOperand(20);
221
DEFINE_decodeSImmOperand(32);
222
223
static DecodeStatus decodeU1ImmOperand(MCInst *Inst, uint64_t Imm,
224
               uint64_t Address, const void *Decoder)
225
2.95k
{
226
2.95k
  return CONCAT(decodeUImmOperand, 1)(Inst, Imm);
227
2.95k
}
228
229
static DecodeStatus decodeU2ImmOperand(MCInst *Inst, uint64_t Imm,
230
               uint64_t Address, const void *Decoder)
231
2.81k
{
232
2.81k
  return CONCAT(decodeUImmOperand, 2)(Inst, Imm);
233
2.81k
}
234
235
static DecodeStatus decodeU3ImmOperand(MCInst *Inst, uint64_t Imm,
236
               uint64_t Address, const void *Decoder)
237
1.89k
{
238
1.89k
  return CONCAT(decodeUImmOperand, 3)(Inst, Imm);
239
1.89k
}
240
241
static DecodeStatus decodeU4ImmOperand(MCInst *Inst, uint64_t Imm,
242
               uint64_t Address, const void *Decoder)
243
59.7k
{
244
59.7k
  return CONCAT(decodeUImmOperand, 4)(Inst, Imm);
245
59.7k
}
246
247
static DecodeStatus decodeU8ImmOperand(MCInst *Inst, uint64_t Imm,
248
               uint64_t Address, const void *Decoder)
249
14.8k
{
250
14.8k
  return CONCAT(decodeUImmOperand, 8)(Inst, Imm);
251
14.8k
}
252
253
static DecodeStatus decodeU12ImmOperand(MCInst *Inst, uint64_t Imm,
254
          uint64_t Address, const void *Decoder)
255
86.9k
{
256
86.9k
  return CONCAT(decodeUImmOperand, 12)(Inst, Imm);
257
86.9k
}
258
259
static DecodeStatus decodeU16ImmOperand(MCInst *Inst, uint64_t Imm,
260
          uint64_t Address, const void *Decoder)
261
4.50k
{
262
4.50k
  return CONCAT(decodeUImmOperand, 16)(Inst, Imm);
263
4.50k
}
264
265
static DecodeStatus decodeU32ImmOperand(MCInst *Inst, uint64_t Imm,
266
          uint64_t Address, const void *Decoder)
267
2.41k
{
268
2.41k
  return CONCAT(decodeUImmOperand, 32)(Inst, Imm);
269
2.41k
}
270
271
static DecodeStatus decodeS8ImmOperand(MCInst *Inst, uint64_t Imm,
272
               uint64_t Address, const void *Decoder)
273
4.75k
{
274
4.75k
  return CONCAT(decodeSImmOperand, 8)(Inst, Imm);
275
4.75k
}
276
277
static DecodeStatus decodeS16ImmOperand(MCInst *Inst, uint64_t Imm,
278
          uint64_t Address, const void *Decoder)
279
7.38k
{
280
7.38k
  return CONCAT(decodeSImmOperand, 16)(Inst, Imm);
281
7.38k
}
282
283
static DecodeStatus decodeS20ImmOperand(MCInst *Inst, uint64_t Imm,
284
          uint64_t Address, const void *Decoder)
285
18.2k
{
286
18.2k
  return CONCAT(decodeSImmOperand, 20)(Inst, Imm);
287
18.2k
}
288
289
static DecodeStatus decodeS32ImmOperand(MCInst *Inst, uint64_t Imm,
290
          uint64_t Address, const void *Decoder)
291
3.04k
{
292
3.04k
  return CONCAT(decodeSImmOperand, 32)(Inst, Imm);
293
3.04k
}
294
295
#define DEFINE_decodeLenOperand(N) \
296
  static DecodeStatus CONCAT(decodeLenOperand, \
297
           N)(MCInst * Inst, uint64_t Imm, \
298
              uint64_t Address, const void *Decoder) \
299
12.6k
  { \
300
12.6k
    if (!isUIntN(N, Imm)) \
301
12.6k
      return MCDisassembler_Fail; \
302
12.6k
    MCOperand_CreateImm0(Inst, (Imm + 1)); \
303
12.6k
    return MCDisassembler_Success; \
304
12.6k
  }
SystemZDisassembler.c:decodeLenOperand_8
Line
Count
Source
299
4.33k
  { \
300
4.33k
    if (!isUIntN(N, Imm)) \
301
4.33k
      return MCDisassembler_Fail; \
302
4.33k
    MCOperand_CreateImm0(Inst, (Imm + 1)); \
303
4.33k
    return MCDisassembler_Success; \
304
4.33k
  }
SystemZDisassembler.c:decodeLenOperand_4
Line
Count
Source
299
8.33k
  { \
300
8.33k
    if (!isUIntN(N, Imm)) \
301
8.33k
      return MCDisassembler_Fail; \
302
8.33k
    MCOperand_CreateImm0(Inst, (Imm + 1)); \
303
8.33k
    return MCDisassembler_Success; \
304
8.33k
  }
305
DEFINE_decodeLenOperand(8);
306
DEFINE_decodeLenOperand(4);
307
308
#define DEFINE_decodePCDBLOperand(N) \
309
  static DecodeStatus CONCAT(decodePCDBLOperand, N)( \
310
    MCInst * Inst, uint64_t Imm, uint64_t Address, bool isBranch, \
311
    const void *Decoder) \
312
5.13k
  { \
313
5.13k
    CS_ASSERT((isUIntN(N, Imm) && "Invalid PC-relative offset")); \
314
5.13k
    uint64_t Value = SignExtend64((Imm), N) * 2 + Address; \
315
5.13k
\
316
5.13k
    if (!tryAddingSymbolicOperand(Value, isBranch, Address, 2, \
317
5.13k
                N / 8, Inst, Decoder)) \
318
5.13k
      MCOperand_CreateImm0(Inst, (Value)); \
319
5.13k
\
320
5.13k
    return MCDisassembler_Success; \
321
5.13k
  }
SystemZDisassembler.c:decodePCDBLOperand_16
Line
Count
Source
312
2.46k
  { \
313
2.46k
    CS_ASSERT((isUIntN(N, Imm) && "Invalid PC-relative offset")); \
314
2.46k
    uint64_t Value = SignExtend64((Imm), N) * 2 + Address; \
315
2.46k
\
316
2.46k
    if (!tryAddingSymbolicOperand(Value, isBranch, Address, 2, \
317
2.46k
                N / 8, Inst, Decoder)) \
318
2.46k
      MCOperand_CreateImm0(Inst, (Value)); \
319
2.46k
\
320
2.46k
    return MCDisassembler_Success; \
321
2.46k
  }
SystemZDisassembler.c:decodePCDBLOperand_32
Line
Count
Source
312
1.36k
  { \
313
1.36k
    CS_ASSERT((isUIntN(N, Imm) && "Invalid PC-relative offset")); \
314
1.36k
    uint64_t Value = SignExtend64((Imm), N) * 2 + Address; \
315
1.36k
\
316
1.36k
    if (!tryAddingSymbolicOperand(Value, isBranch, Address, 2, \
317
1.36k
                N / 8, Inst, Decoder)) \
318
1.36k
      MCOperand_CreateImm0(Inst, (Value)); \
319
1.36k
\
320
1.36k
    return MCDisassembler_Success; \
321
1.36k
  }
SystemZDisassembler.c:decodePCDBLOperand_12
Line
Count
Source
312
654
  { \
313
654
    CS_ASSERT((isUIntN(N, Imm) && "Invalid PC-relative offset")); \
314
654
    uint64_t Value = SignExtend64((Imm), N) * 2 + Address; \
315
654
\
316
654
    if (!tryAddingSymbolicOperand(Value, isBranch, Address, 2, \
317
654
                N / 8, Inst, Decoder)) \
318
654
      MCOperand_CreateImm0(Inst, (Value)); \
319
654
\
320
654
    return MCDisassembler_Success; \
321
654
  }
SystemZDisassembler.c:decodePCDBLOperand_24
Line
Count
Source
312
654
  { \
313
654
    CS_ASSERT((isUIntN(N, Imm) && "Invalid PC-relative offset")); \
314
654
    uint64_t Value = SignExtend64((Imm), N) * 2 + Address; \
315
654
\
316
654
    if (!tryAddingSymbolicOperand(Value, isBranch, Address, 2, \
317
654
                N / 8, Inst, Decoder)) \
318
654
      MCOperand_CreateImm0(Inst, (Value)); \
319
654
\
320
654
    return MCDisassembler_Success; \
321
654
  }
322
DEFINE_decodePCDBLOperand(12);
323
DEFINE_decodePCDBLOperand(16);
324
DEFINE_decodePCDBLOperand(24);
325
DEFINE_decodePCDBLOperand(32);
326
327
static DecodeStatus decodePC12DBLBranchOperand(MCInst *Inst, uint64_t Imm,
328
                 uint64_t Address,
329
                 const void *Decoder)
330
967
{
331
967
  return CONCAT(decodePCDBLOperand, 12)(Inst, Imm, Address, true,
332
967
                Decoder);
333
967
}
334
335
static DecodeStatus decodePC16DBLBranchOperand(MCInst *Inst, uint64_t Imm,
336
                 uint64_t Address,
337
                 const void *Decoder)
338
7.34k
{
339
7.34k
  return CONCAT(decodePCDBLOperand, 16)(Inst, Imm, Address, true,
340
7.34k
                Decoder);
341
7.34k
}
342
343
static DecodeStatus decodePC24DBLBranchOperand(MCInst *Inst, uint64_t Imm,
344
                 uint64_t Address,
345
                 const void *Decoder)
346
967
{
347
967
  return CONCAT(decodePCDBLOperand, 24)(Inst, Imm, Address, true,
348
967
                Decoder);
349
967
}
350
351
static DecodeStatus decodePC32DBLBranchOperand(MCInst *Inst, uint64_t Imm,
352
                 uint64_t Address,
353
                 const void *Decoder)
354
1.20k
{
355
1.20k
  return CONCAT(decodePCDBLOperand, 32)(Inst, Imm, Address, true,
356
1.20k
                Decoder);
357
1.20k
}
358
359
static DecodeStatus decodePC32DBLOperand(MCInst *Inst, uint64_t Imm,
360
           uint64_t Address, const void *Decoder)
361
2.22k
{
362
2.22k
  return CONCAT(decodePCDBLOperand, 32)(Inst, Imm, Address, false,
363
2.22k
                Decoder);
364
2.22k
}
365
366
#include "SystemZGenDisassemblerTables.inc"
367
368
static DecodeStatus getInstruction(MCInst *MI, uint16_t *Size,
369
           const uint8_t *Bytes, size_t BytesLen,
370
           uint64_t Address, SStream *CS)
371
169k
{
372
  // Get the first two bytes of the instruction.
373
169k
  *Size = 0;
374
169k
  if (BytesLen < 2)
375
730
    return MCDisassembler_Fail;
376
377
  // The top 2 bits of the first byte specify the size.
378
168k
  const uint8_t *Table;
379
168k
  uint64_t Inst = 0;
380
168k
  if (Bytes[0] < 0x40) {
381
45.5k
    *Size = 2;
382
45.5k
    Table = DecoderTable16;
383
45.5k
    Inst = readBytes16(MI, Bytes);
384
122k
  } else if (Bytes[0] < 0xc0) {
385
47.9k
    if (BytesLen < 4) {
386
253
      return MCDisassembler_Fail;
387
253
    }
388
47.7k
    *Size = 4;
389
47.7k
    Table = DecoderTable32;
390
47.7k
    Inst = readBytes32(MI, Bytes);
391
74.8k
  } else {
392
74.8k
    if (BytesLen < 6) {
393
379
      return MCDisassembler_Fail;
394
379
    }
395
74.4k
    *Size = 6;
396
74.4k
    Table = DecoderTable48;
397
74.4k
    Inst = readBytes48(MI, Bytes);
398
74.4k
  }
399
400
  // Read any remaining bytes.
401
167k
  if (BytesLen < *Size) {
402
0
    *Size = BytesLen;
403
0
    return MCDisassembler_Fail;
404
0
  }
405
406
167k
  return decodeInstruction_8(Table, MI, Inst, Address, NULL);
407
167k
}
408
409
DecodeStatus SystemZ_LLVM_getInstruction(csh handle, const uint8_t *Bytes,
410
           size_t BytesLen, MCInst *MI,
411
           uint16_t *Size, uint64_t Address,
412
           void *Info)
413
169k
{
414
  return getInstruction(MI, Size, Bytes, BytesLen, MI->address, NULL);
415
169k
}