1*9a0e4156SSadaf Ebrahimi //===-- SystemZInstPrinter.cpp - Convert SystemZ MCInst to assembly syntax --------===//
2*9a0e4156SSadaf Ebrahimi //
3*9a0e4156SSadaf Ebrahimi // The LLVM Compiler Infrastructure
4*9a0e4156SSadaf Ebrahimi //
5*9a0e4156SSadaf Ebrahimi // This file is distributed under the University of Illinois Open Source
6*9a0e4156SSadaf Ebrahimi // License. See LICENSE.TXT for details.
7*9a0e4156SSadaf Ebrahimi //
8*9a0e4156SSadaf Ebrahimi //===----------------------------------------------------------------------===//
9*9a0e4156SSadaf Ebrahimi //
10*9a0e4156SSadaf Ebrahimi // This class prints an SystemZ MCInst to a .s file.
11*9a0e4156SSadaf Ebrahimi //
12*9a0e4156SSadaf Ebrahimi //===----------------------------------------------------------------------===//
13*9a0e4156SSadaf Ebrahimi
14*9a0e4156SSadaf Ebrahimi /* Capstone Disassembly Engine */
15*9a0e4156SSadaf Ebrahimi /* By Nguyen Anh Quynh <[email protected]>, 2013-2015 */
16*9a0e4156SSadaf Ebrahimi
17*9a0e4156SSadaf Ebrahimi #ifdef CAPSTONE_HAS_SYSZ
18*9a0e4156SSadaf Ebrahimi
19*9a0e4156SSadaf Ebrahimi #include <stdio.h>
20*9a0e4156SSadaf Ebrahimi #include <stdlib.h>
21*9a0e4156SSadaf Ebrahimi #include <string.h>
22*9a0e4156SSadaf Ebrahimi #include <capstone/platform.h>
23*9a0e4156SSadaf Ebrahimi
24*9a0e4156SSadaf Ebrahimi #include "SystemZInstPrinter.h"
25*9a0e4156SSadaf Ebrahimi #include "../../MCInst.h"
26*9a0e4156SSadaf Ebrahimi #include "../../utils.h"
27*9a0e4156SSadaf Ebrahimi #include "../../SStream.h"
28*9a0e4156SSadaf Ebrahimi #include "../../MCRegisterInfo.h"
29*9a0e4156SSadaf Ebrahimi #include "../../MathExtras.h"
30*9a0e4156SSadaf Ebrahimi #include "SystemZMapping.h"
31*9a0e4156SSadaf Ebrahimi
32*9a0e4156SSadaf Ebrahimi static const char *getRegisterName(unsigned RegNo);
33*9a0e4156SSadaf Ebrahimi
SystemZ_post_printer(csh ud,cs_insn * insn,char * insn_asm,MCInst * mci)34*9a0e4156SSadaf Ebrahimi void SystemZ_post_printer(csh ud, cs_insn *insn, char *insn_asm, MCInst *mci)
35*9a0e4156SSadaf Ebrahimi {
36*9a0e4156SSadaf Ebrahimi /*
37*9a0e4156SSadaf Ebrahimi if (((cs_struct *)ud)->detail != CS_OPT_ON)
38*9a0e4156SSadaf Ebrahimi return;
39*9a0e4156SSadaf Ebrahimi */
40*9a0e4156SSadaf Ebrahimi }
41*9a0e4156SSadaf Ebrahimi
printAddress(MCInst * MI,unsigned Base,int64_t Disp,unsigned Index,SStream * O)42*9a0e4156SSadaf Ebrahimi static void printAddress(MCInst *MI, unsigned Base, int64_t Disp, unsigned Index, SStream *O)
43*9a0e4156SSadaf Ebrahimi {
44*9a0e4156SSadaf Ebrahimi printInt64(O, Disp);
45*9a0e4156SSadaf Ebrahimi
46*9a0e4156SSadaf Ebrahimi if (Base) {
47*9a0e4156SSadaf Ebrahimi SStream_concat0(O, "(");
48*9a0e4156SSadaf Ebrahimi if (Index)
49*9a0e4156SSadaf Ebrahimi SStream_concat(O, "%%%s, ", getRegisterName(Index));
50*9a0e4156SSadaf Ebrahimi SStream_concat(O, "%%%s)", getRegisterName(Base));
51*9a0e4156SSadaf Ebrahimi
52*9a0e4156SSadaf Ebrahimi if (MI->csh->detail) {
53*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].type = SYSZ_OP_MEM;
54*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].mem.base = (uint8_t)SystemZ_map_register(Base);
55*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].mem.index = (uint8_t)SystemZ_map_register(Index);
56*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].mem.disp = Disp;
57*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.op_count++;
58*9a0e4156SSadaf Ebrahimi }
59*9a0e4156SSadaf Ebrahimi } else if (!Index) {
60*9a0e4156SSadaf Ebrahimi if (MI->csh->detail) {
61*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].type = SYSZ_OP_IMM;
62*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].imm = Disp;
63*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.op_count++;
64*9a0e4156SSadaf Ebrahimi }
65*9a0e4156SSadaf Ebrahimi } else {
66*9a0e4156SSadaf Ebrahimi SStream_concat(O, "(%%%s)", getRegisterName(Index));
67*9a0e4156SSadaf Ebrahimi if (MI->csh->detail) {
68*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].type = SYSZ_OP_MEM;
69*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].mem.base = (uint8_t)SystemZ_map_register(Base);
70*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].mem.index = (uint8_t)SystemZ_map_register(Index);
71*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].mem.disp = Disp;
72*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.op_count++;
73*9a0e4156SSadaf Ebrahimi }
74*9a0e4156SSadaf Ebrahimi }
75*9a0e4156SSadaf Ebrahimi }
76*9a0e4156SSadaf Ebrahimi
_printOperand(MCInst * MI,MCOperand * MO,SStream * O)77*9a0e4156SSadaf Ebrahimi static void _printOperand(MCInst *MI, MCOperand *MO, SStream *O)
78*9a0e4156SSadaf Ebrahimi {
79*9a0e4156SSadaf Ebrahimi if (MCOperand_isReg(MO)) {
80*9a0e4156SSadaf Ebrahimi unsigned reg;
81*9a0e4156SSadaf Ebrahimi
82*9a0e4156SSadaf Ebrahimi reg = MCOperand_getReg(MO);
83*9a0e4156SSadaf Ebrahimi SStream_concat(O, "%%%s", getRegisterName(reg));
84*9a0e4156SSadaf Ebrahimi reg = SystemZ_map_register(reg);
85*9a0e4156SSadaf Ebrahimi
86*9a0e4156SSadaf Ebrahimi if (MI->csh->detail) {
87*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].type = SYSZ_OP_REG;
88*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].reg = reg;
89*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.op_count++;
90*9a0e4156SSadaf Ebrahimi }
91*9a0e4156SSadaf Ebrahimi } else if (MCOperand_isImm(MO)) {
92*9a0e4156SSadaf Ebrahimi int64_t Imm = MCOperand_getImm(MO);
93*9a0e4156SSadaf Ebrahimi
94*9a0e4156SSadaf Ebrahimi printInt64(O, Imm);
95*9a0e4156SSadaf Ebrahimi
96*9a0e4156SSadaf Ebrahimi if (MI->csh->detail) {
97*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].type = SYSZ_OP_IMM;
98*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].imm = Imm;
99*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.op_count++;
100*9a0e4156SSadaf Ebrahimi }
101*9a0e4156SSadaf Ebrahimi }
102*9a0e4156SSadaf Ebrahimi }
103*9a0e4156SSadaf Ebrahimi
printU1ImmOperand(MCInst * MI,int OpNum,SStream * O)104*9a0e4156SSadaf Ebrahimi static void printU1ImmOperand(MCInst *MI, int OpNum, SStream *O)
105*9a0e4156SSadaf Ebrahimi {
106*9a0e4156SSadaf Ebrahimi int64_t Value = MCOperand_getImm(MCInst_getOperand(MI, OpNum));
107*9a0e4156SSadaf Ebrahimi // assert(isUInt<1>(Value) && "Invalid u1imm argument");
108*9a0e4156SSadaf Ebrahimi printInt64(O, Value);
109*9a0e4156SSadaf Ebrahimi
110*9a0e4156SSadaf Ebrahimi if (MI->csh->detail) {
111*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].type = SYSZ_OP_IMM;
112*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].imm = Value;
113*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.op_count++;
114*9a0e4156SSadaf Ebrahimi }
115*9a0e4156SSadaf Ebrahimi }
116*9a0e4156SSadaf Ebrahimi
printU2ImmOperand(MCInst * MI,int OpNum,SStream * O)117*9a0e4156SSadaf Ebrahimi static void printU2ImmOperand(MCInst *MI, int OpNum, SStream *O)
118*9a0e4156SSadaf Ebrahimi {
119*9a0e4156SSadaf Ebrahimi int64_t Value = MCOperand_getImm(MCInst_getOperand(MI, OpNum));
120*9a0e4156SSadaf Ebrahimi // assert(isUInt<2>(Value) && "Invalid u2imm argument");
121*9a0e4156SSadaf Ebrahimi printInt64(O, Value);
122*9a0e4156SSadaf Ebrahimi
123*9a0e4156SSadaf Ebrahimi if (MI->csh->detail) {
124*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].type = SYSZ_OP_IMM;
125*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].imm = Value;
126*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.op_count++;
127*9a0e4156SSadaf Ebrahimi }
128*9a0e4156SSadaf Ebrahimi }
129*9a0e4156SSadaf Ebrahimi
printU3ImmOperand(MCInst * MI,int OpNum,SStream * O)130*9a0e4156SSadaf Ebrahimi static void printU3ImmOperand(MCInst *MI, int OpNum, SStream *O)
131*9a0e4156SSadaf Ebrahimi {
132*9a0e4156SSadaf Ebrahimi int64_t Value = MCOperand_getImm(MCInst_getOperand(MI, OpNum));
133*9a0e4156SSadaf Ebrahimi // assert(isUInt<3>(Value) && "Invalid u4imm argument");
134*9a0e4156SSadaf Ebrahimi printInt64(O, Value);
135*9a0e4156SSadaf Ebrahimi
136*9a0e4156SSadaf Ebrahimi if (MI->csh->detail) {
137*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].type = SYSZ_OP_IMM;
138*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].imm = Value;
139*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.op_count++;
140*9a0e4156SSadaf Ebrahimi }
141*9a0e4156SSadaf Ebrahimi }
142*9a0e4156SSadaf Ebrahimi
printU4ImmOperand(MCInst * MI,int OpNum,SStream * O)143*9a0e4156SSadaf Ebrahimi static void printU4ImmOperand(MCInst *MI, int OpNum, SStream *O)
144*9a0e4156SSadaf Ebrahimi {
145*9a0e4156SSadaf Ebrahimi int64_t Value = MCOperand_getImm(MCInst_getOperand(MI, OpNum));
146*9a0e4156SSadaf Ebrahimi // assert(isUInt<4>(Value) && "Invalid u4imm argument");
147*9a0e4156SSadaf Ebrahimi printInt64(O, Value);
148*9a0e4156SSadaf Ebrahimi
149*9a0e4156SSadaf Ebrahimi if (MI->csh->detail) {
150*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].type = SYSZ_OP_IMM;
151*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].imm = Value;
152*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.op_count++;
153*9a0e4156SSadaf Ebrahimi }
154*9a0e4156SSadaf Ebrahimi }
155*9a0e4156SSadaf Ebrahimi
printU6ImmOperand(MCInst * MI,int OpNum,SStream * O)156*9a0e4156SSadaf Ebrahimi static void printU6ImmOperand(MCInst *MI, int OpNum, SStream *O)
157*9a0e4156SSadaf Ebrahimi {
158*9a0e4156SSadaf Ebrahimi uint32_t Value = (uint32_t)MCOperand_getImm(MCInst_getOperand(MI, OpNum));
159*9a0e4156SSadaf Ebrahimi // assert(isUInt<6>(Value) && "Invalid u6imm argument");
160*9a0e4156SSadaf Ebrahimi
161*9a0e4156SSadaf Ebrahimi printUInt32(O, Value);
162*9a0e4156SSadaf Ebrahimi
163*9a0e4156SSadaf Ebrahimi if (MI->csh->detail) {
164*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].type = SYSZ_OP_IMM;
165*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].imm = (int64_t)Value;
166*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.op_count++;
167*9a0e4156SSadaf Ebrahimi }
168*9a0e4156SSadaf Ebrahimi }
169*9a0e4156SSadaf Ebrahimi
printS8ImmOperand(MCInst * MI,int OpNum,SStream * O)170*9a0e4156SSadaf Ebrahimi static void printS8ImmOperand(MCInst *MI, int OpNum, SStream *O)
171*9a0e4156SSadaf Ebrahimi {
172*9a0e4156SSadaf Ebrahimi int8_t Value = (int8_t)MCOperand_getImm(MCInst_getOperand(MI, OpNum));
173*9a0e4156SSadaf Ebrahimi // assert(isInt<8>(Value) && "Invalid s8imm argument");
174*9a0e4156SSadaf Ebrahimi
175*9a0e4156SSadaf Ebrahimi if (Value >= 0) {
176*9a0e4156SSadaf Ebrahimi if (Value > HEX_THRESHOLD)
177*9a0e4156SSadaf Ebrahimi SStream_concat(O, "0x%x", Value);
178*9a0e4156SSadaf Ebrahimi else
179*9a0e4156SSadaf Ebrahimi SStream_concat(O, "%u", Value);
180*9a0e4156SSadaf Ebrahimi } else {
181*9a0e4156SSadaf Ebrahimi if (Value < -HEX_THRESHOLD)
182*9a0e4156SSadaf Ebrahimi SStream_concat(O, "-0x%x", -Value);
183*9a0e4156SSadaf Ebrahimi else
184*9a0e4156SSadaf Ebrahimi SStream_concat(O, "-%u", -Value);
185*9a0e4156SSadaf Ebrahimi }
186*9a0e4156SSadaf Ebrahimi
187*9a0e4156SSadaf Ebrahimi if (MI->csh->detail) {
188*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].type = SYSZ_OP_IMM;
189*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].imm = (int64_t)Value;
190*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.op_count++;
191*9a0e4156SSadaf Ebrahimi }
192*9a0e4156SSadaf Ebrahimi }
193*9a0e4156SSadaf Ebrahimi
printU8ImmOperand(MCInst * MI,int OpNum,SStream * O)194*9a0e4156SSadaf Ebrahimi static void printU8ImmOperand(MCInst *MI, int OpNum, SStream *O)
195*9a0e4156SSadaf Ebrahimi {
196*9a0e4156SSadaf Ebrahimi uint8_t Value = (uint8_t)MCOperand_getImm(MCInst_getOperand(MI, OpNum));
197*9a0e4156SSadaf Ebrahimi // assert(isUInt<8>(Value) && "Invalid u8imm argument");
198*9a0e4156SSadaf Ebrahimi
199*9a0e4156SSadaf Ebrahimi if (Value > HEX_THRESHOLD)
200*9a0e4156SSadaf Ebrahimi SStream_concat(O, "0x%x", Value);
201*9a0e4156SSadaf Ebrahimi else
202*9a0e4156SSadaf Ebrahimi SStream_concat(O, "%u", Value);
203*9a0e4156SSadaf Ebrahimi
204*9a0e4156SSadaf Ebrahimi if (MI->csh->detail) {
205*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].type = SYSZ_OP_IMM;
206*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].imm = (int64_t)Value;
207*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.op_count++;
208*9a0e4156SSadaf Ebrahimi }
209*9a0e4156SSadaf Ebrahimi }
210*9a0e4156SSadaf Ebrahimi
printU12ImmOperand(MCInst * MI,int OpNum,SStream * O)211*9a0e4156SSadaf Ebrahimi static void printU12ImmOperand(MCInst *MI, int OpNum, SStream *O)
212*9a0e4156SSadaf Ebrahimi {
213*9a0e4156SSadaf Ebrahimi int64_t Value = MCOperand_getImm(MCInst_getOperand(MI, OpNum));
214*9a0e4156SSadaf Ebrahimi // assert(isUInt<12>(Value) && "Invalid u12imm argument");
215*9a0e4156SSadaf Ebrahimi printInt64(O, Value);
216*9a0e4156SSadaf Ebrahimi
217*9a0e4156SSadaf Ebrahimi if (MI->csh->detail) {
218*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].type = SYSZ_OP_IMM;
219*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].imm = Value;
220*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.op_count++;
221*9a0e4156SSadaf Ebrahimi }
222*9a0e4156SSadaf Ebrahimi }
223*9a0e4156SSadaf Ebrahimi
printS16ImmOperand(MCInst * MI,int OpNum,SStream * O)224*9a0e4156SSadaf Ebrahimi static void printS16ImmOperand(MCInst *MI, int OpNum, SStream *O)
225*9a0e4156SSadaf Ebrahimi {
226*9a0e4156SSadaf Ebrahimi int16_t Value = (int16_t)MCOperand_getImm(MCInst_getOperand(MI, OpNum));
227*9a0e4156SSadaf Ebrahimi // assert(isInt<16>(Value) && "Invalid s16imm argument");
228*9a0e4156SSadaf Ebrahimi
229*9a0e4156SSadaf Ebrahimi if (Value >= 0) {
230*9a0e4156SSadaf Ebrahimi if (Value > HEX_THRESHOLD)
231*9a0e4156SSadaf Ebrahimi SStream_concat(O, "0x%x", Value);
232*9a0e4156SSadaf Ebrahimi else
233*9a0e4156SSadaf Ebrahimi SStream_concat(O, "%u", Value);
234*9a0e4156SSadaf Ebrahimi } else {
235*9a0e4156SSadaf Ebrahimi if (Value < -HEX_THRESHOLD)
236*9a0e4156SSadaf Ebrahimi SStream_concat(O, "-0x%x", -Value);
237*9a0e4156SSadaf Ebrahimi else
238*9a0e4156SSadaf Ebrahimi SStream_concat(O, "-%u", -Value);
239*9a0e4156SSadaf Ebrahimi }
240*9a0e4156SSadaf Ebrahimi
241*9a0e4156SSadaf Ebrahimi if (MI->csh->detail) {
242*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].type = SYSZ_OP_IMM;
243*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].imm = (int64_t)Value;
244*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.op_count++;
245*9a0e4156SSadaf Ebrahimi }
246*9a0e4156SSadaf Ebrahimi }
247*9a0e4156SSadaf Ebrahimi
printU16ImmOperand(MCInst * MI,int OpNum,SStream * O)248*9a0e4156SSadaf Ebrahimi static void printU16ImmOperand(MCInst *MI, int OpNum, SStream *O)
249*9a0e4156SSadaf Ebrahimi {
250*9a0e4156SSadaf Ebrahimi uint16_t Value = (uint16_t)MCOperand_getImm(MCInst_getOperand(MI, OpNum));
251*9a0e4156SSadaf Ebrahimi // assert(isUInt<16>(Value) && "Invalid u16imm argument");
252*9a0e4156SSadaf Ebrahimi
253*9a0e4156SSadaf Ebrahimi if (Value > HEX_THRESHOLD)
254*9a0e4156SSadaf Ebrahimi SStream_concat(O, "0x%x", Value);
255*9a0e4156SSadaf Ebrahimi else
256*9a0e4156SSadaf Ebrahimi SStream_concat(O, "%u", Value);
257*9a0e4156SSadaf Ebrahimi
258*9a0e4156SSadaf Ebrahimi if (MI->csh->detail) {
259*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].type = SYSZ_OP_IMM;
260*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].imm = (int64_t)Value;
261*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.op_count++;
262*9a0e4156SSadaf Ebrahimi }
263*9a0e4156SSadaf Ebrahimi }
264*9a0e4156SSadaf Ebrahimi
printS32ImmOperand(MCInst * MI,int OpNum,SStream * O)265*9a0e4156SSadaf Ebrahimi static void printS32ImmOperand(MCInst *MI, int OpNum, SStream *O)
266*9a0e4156SSadaf Ebrahimi {
267*9a0e4156SSadaf Ebrahimi int32_t Value = (int32_t)MCOperand_getImm(MCInst_getOperand(MI, OpNum));
268*9a0e4156SSadaf Ebrahimi // assert(isInt<32>(Value) && "Invalid s32imm argument");
269*9a0e4156SSadaf Ebrahimi
270*9a0e4156SSadaf Ebrahimi printInt32(O, Value);
271*9a0e4156SSadaf Ebrahimi
272*9a0e4156SSadaf Ebrahimi if (MI->csh->detail) {
273*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].type = SYSZ_OP_IMM;
274*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].imm = (int64_t)Value;
275*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.op_count++;
276*9a0e4156SSadaf Ebrahimi }
277*9a0e4156SSadaf Ebrahimi }
278*9a0e4156SSadaf Ebrahimi
printU32ImmOperand(MCInst * MI,int OpNum,SStream * O)279*9a0e4156SSadaf Ebrahimi static void printU32ImmOperand(MCInst *MI, int OpNum, SStream *O)
280*9a0e4156SSadaf Ebrahimi {
281*9a0e4156SSadaf Ebrahimi uint32_t Value = (uint32_t)MCOperand_getImm(MCInst_getOperand(MI, OpNum));
282*9a0e4156SSadaf Ebrahimi // assert(isUInt<32>(Value) && "Invalid u32imm argument");
283*9a0e4156SSadaf Ebrahimi
284*9a0e4156SSadaf Ebrahimi printUInt32(O, Value);
285*9a0e4156SSadaf Ebrahimi
286*9a0e4156SSadaf Ebrahimi if (MI->csh->detail) {
287*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].type = SYSZ_OP_IMM;
288*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].imm = (int64_t)Value;
289*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.op_count++;
290*9a0e4156SSadaf Ebrahimi }
291*9a0e4156SSadaf Ebrahimi }
292*9a0e4156SSadaf Ebrahimi
printU48ImmOperand(MCInst * MI,int OpNum,SStream * O)293*9a0e4156SSadaf Ebrahimi static void printU48ImmOperand(MCInst *MI, int OpNum, SStream *O)
294*9a0e4156SSadaf Ebrahimi {
295*9a0e4156SSadaf Ebrahimi int64_t Value = MCOperand_getImm(MCInst_getOperand(MI, OpNum));
296*9a0e4156SSadaf Ebrahimi // assert(isUInt<48>(Value) && "Invalid u48imm argument");
297*9a0e4156SSadaf Ebrahimi printInt64(O, Value);
298*9a0e4156SSadaf Ebrahimi
299*9a0e4156SSadaf Ebrahimi if (MI->csh->detail) {
300*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].type = SYSZ_OP_IMM;
301*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].imm = Value;
302*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.op_count++;
303*9a0e4156SSadaf Ebrahimi }
304*9a0e4156SSadaf Ebrahimi }
305*9a0e4156SSadaf Ebrahimi
printPCRelOperand(MCInst * MI,int OpNum,SStream * O)306*9a0e4156SSadaf Ebrahimi static void printPCRelOperand(MCInst *MI, int OpNum, SStream *O)
307*9a0e4156SSadaf Ebrahimi {
308*9a0e4156SSadaf Ebrahimi MCOperand *MO = MCInst_getOperand(MI, OpNum);
309*9a0e4156SSadaf Ebrahimi int32_t imm;
310*9a0e4156SSadaf Ebrahimi
311*9a0e4156SSadaf Ebrahimi if (MCOperand_isImm(MO)) {
312*9a0e4156SSadaf Ebrahimi imm = (int32_t)MCOperand_getImm(MO);
313*9a0e4156SSadaf Ebrahimi
314*9a0e4156SSadaf Ebrahimi printInt32(O, imm);
315*9a0e4156SSadaf Ebrahimi
316*9a0e4156SSadaf Ebrahimi if (MI->csh->detail) {
317*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].type = SYSZ_OP_IMM;
318*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].imm = (int64_t)imm;
319*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.op_count++;
320*9a0e4156SSadaf Ebrahimi }
321*9a0e4156SSadaf Ebrahimi }
322*9a0e4156SSadaf Ebrahimi }
323*9a0e4156SSadaf Ebrahimi
printPCRelTLSOperand(MCInst * MI,int OpNum,SStream * O)324*9a0e4156SSadaf Ebrahimi static void printPCRelTLSOperand(MCInst *MI, int OpNum, SStream *O)
325*9a0e4156SSadaf Ebrahimi {
326*9a0e4156SSadaf Ebrahimi // Output the PC-relative operand.
327*9a0e4156SSadaf Ebrahimi printPCRelOperand(MI, OpNum, O);
328*9a0e4156SSadaf Ebrahimi }
329*9a0e4156SSadaf Ebrahimi
printOperand(MCInst * MI,int OpNum,SStream * O)330*9a0e4156SSadaf Ebrahimi static void printOperand(MCInst *MI, int OpNum, SStream *O)
331*9a0e4156SSadaf Ebrahimi {
332*9a0e4156SSadaf Ebrahimi _printOperand(MI, MCInst_getOperand(MI, OpNum), O);
333*9a0e4156SSadaf Ebrahimi }
334*9a0e4156SSadaf Ebrahimi
printBDAddrOperand(MCInst * MI,int OpNum,SStream * O)335*9a0e4156SSadaf Ebrahimi static void printBDAddrOperand(MCInst *MI, int OpNum, SStream *O)
336*9a0e4156SSadaf Ebrahimi {
337*9a0e4156SSadaf Ebrahimi printAddress(MI, MCOperand_getReg(MCInst_getOperand(MI, OpNum)),
338*9a0e4156SSadaf Ebrahimi MCOperand_getImm(MCInst_getOperand(MI, OpNum + 1)), 0, O);
339*9a0e4156SSadaf Ebrahimi }
340*9a0e4156SSadaf Ebrahimi
printBDXAddrOperand(MCInst * MI,int OpNum,SStream * O)341*9a0e4156SSadaf Ebrahimi static void printBDXAddrOperand(MCInst *MI, int OpNum, SStream *O)
342*9a0e4156SSadaf Ebrahimi {
343*9a0e4156SSadaf Ebrahimi printAddress(MI, MCOperand_getReg(MCInst_getOperand(MI, OpNum)),
344*9a0e4156SSadaf Ebrahimi MCOperand_getImm(MCInst_getOperand(MI, OpNum + 1)),
345*9a0e4156SSadaf Ebrahimi MCOperand_getReg(MCInst_getOperand(MI, OpNum + 2)), O);
346*9a0e4156SSadaf Ebrahimi }
347*9a0e4156SSadaf Ebrahimi
printBDLAddrOperand(MCInst * MI,int OpNum,SStream * O)348*9a0e4156SSadaf Ebrahimi static void printBDLAddrOperand(MCInst *MI, int OpNum, SStream *O)
349*9a0e4156SSadaf Ebrahimi {
350*9a0e4156SSadaf Ebrahimi unsigned Base = MCOperand_getReg(MCInst_getOperand(MI, OpNum));
351*9a0e4156SSadaf Ebrahimi uint64_t Disp = (uint64_t)MCOperand_getImm(MCInst_getOperand(MI, OpNum + 1));
352*9a0e4156SSadaf Ebrahimi uint64_t Length = (uint64_t)MCOperand_getImm(MCInst_getOperand(MI, OpNum + 2));
353*9a0e4156SSadaf Ebrahimi
354*9a0e4156SSadaf Ebrahimi if (Disp > HEX_THRESHOLD)
355*9a0e4156SSadaf Ebrahimi SStream_concat(O, "0x%"PRIx64, Disp);
356*9a0e4156SSadaf Ebrahimi else
357*9a0e4156SSadaf Ebrahimi SStream_concat(O, "%"PRIu64, Disp);
358*9a0e4156SSadaf Ebrahimi
359*9a0e4156SSadaf Ebrahimi if (Length > HEX_THRESHOLD)
360*9a0e4156SSadaf Ebrahimi SStream_concat(O, "(0x%"PRIx64, Length);
361*9a0e4156SSadaf Ebrahimi else
362*9a0e4156SSadaf Ebrahimi SStream_concat(O, "(%"PRIu64, Length);
363*9a0e4156SSadaf Ebrahimi
364*9a0e4156SSadaf Ebrahimi if (Base)
365*9a0e4156SSadaf Ebrahimi SStream_concat(O, ", %%%s", getRegisterName(Base));
366*9a0e4156SSadaf Ebrahimi SStream_concat0(O, ")");
367*9a0e4156SSadaf Ebrahimi
368*9a0e4156SSadaf Ebrahimi if (MI->csh->detail) {
369*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].type = SYSZ_OP_MEM;
370*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].mem.base = (uint8_t)SystemZ_map_register(Base);
371*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].mem.length = Length;
372*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].mem.disp = (int64_t)Disp;
373*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.op_count++;
374*9a0e4156SSadaf Ebrahimi }
375*9a0e4156SSadaf Ebrahimi }
376*9a0e4156SSadaf Ebrahimi
printBDRAddrOperand(MCInst * MI,int OpNum,SStream * O)377*9a0e4156SSadaf Ebrahimi static void printBDRAddrOperand(MCInst *MI, int OpNum, SStream *O)
378*9a0e4156SSadaf Ebrahimi {
379*9a0e4156SSadaf Ebrahimi unsigned Base = MCOperand_getReg(MCInst_getOperand(MI, OpNum));
380*9a0e4156SSadaf Ebrahimi uint64_t Disp = (uint64_t)MCOperand_getImm(MCInst_getOperand(MI, OpNum + 1));
381*9a0e4156SSadaf Ebrahimi uint64_t Length = MCOperand_getReg(MCInst_getOperand(MI, OpNum + 2));
382*9a0e4156SSadaf Ebrahimi
383*9a0e4156SSadaf Ebrahimi if (Disp > HEX_THRESHOLD)
384*9a0e4156SSadaf Ebrahimi SStream_concat(O, "0x%"PRIx64, Disp);
385*9a0e4156SSadaf Ebrahimi else
386*9a0e4156SSadaf Ebrahimi SStream_concat(O, "%"PRIu64, Disp);
387*9a0e4156SSadaf Ebrahimi
388*9a0e4156SSadaf Ebrahimi SStream_concat0(O, "(");
389*9a0e4156SSadaf Ebrahimi SStream_concat(O, "%%%s", getRegisterName((unsigned int)Length));
390*9a0e4156SSadaf Ebrahimi
391*9a0e4156SSadaf Ebrahimi if (Base)
392*9a0e4156SSadaf Ebrahimi SStream_concat(O, ", %%%s", getRegisterName(Base));
393*9a0e4156SSadaf Ebrahimi SStream_concat0(O, ")");
394*9a0e4156SSadaf Ebrahimi
395*9a0e4156SSadaf Ebrahimi if (MI->csh->detail) {
396*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].type = SYSZ_OP_MEM;
397*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].mem.base = (uint8_t)SystemZ_map_register((unsigned int)Base);
398*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].mem.length = (uint8_t)SystemZ_map_register((unsigned int)Length);
399*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.operands[MI->flat_insn->detail->sysz.op_count].mem.disp = (int64_t)Disp;
400*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.op_count++;
401*9a0e4156SSadaf Ebrahimi }
402*9a0e4156SSadaf Ebrahimi }
403*9a0e4156SSadaf Ebrahimi
printBDVAddrOperand(MCInst * MI,int OpNum,SStream * O)404*9a0e4156SSadaf Ebrahimi static void printBDVAddrOperand(MCInst *MI, int OpNum, SStream *O)
405*9a0e4156SSadaf Ebrahimi {
406*9a0e4156SSadaf Ebrahimi printAddress(MI, MCOperand_getReg(MCInst_getOperand(MI, OpNum)),
407*9a0e4156SSadaf Ebrahimi MCOperand_getImm(MCInst_getOperand(MI, OpNum + 1)),
408*9a0e4156SSadaf Ebrahimi MCOperand_getReg(MCInst_getOperand(MI, OpNum + 2)), O);
409*9a0e4156SSadaf Ebrahimi }
410*9a0e4156SSadaf Ebrahimi
printCond4Operand(MCInst * MI,int OpNum,SStream * O)411*9a0e4156SSadaf Ebrahimi static void printCond4Operand(MCInst *MI, int OpNum, SStream *O)
412*9a0e4156SSadaf Ebrahimi {
413*9a0e4156SSadaf Ebrahimi static const char *const CondNames[] = {
414*9a0e4156SSadaf Ebrahimi "o", "h", "nle", "l", "nhe", "lh", "ne",
415*9a0e4156SSadaf Ebrahimi "e", "nlh", "he", "nl", "le", "nh", "no"
416*9a0e4156SSadaf Ebrahimi };
417*9a0e4156SSadaf Ebrahimi
418*9a0e4156SSadaf Ebrahimi uint64_t Imm = MCOperand_getImm(MCInst_getOperand(MI, OpNum));
419*9a0e4156SSadaf Ebrahimi // assert(Imm > 0 && Imm < 15 && "Invalid condition");
420*9a0e4156SSadaf Ebrahimi SStream_concat0(O, CondNames[Imm - 1]);
421*9a0e4156SSadaf Ebrahimi
422*9a0e4156SSadaf Ebrahimi if (MI->csh->detail)
423*9a0e4156SSadaf Ebrahimi MI->flat_insn->detail->sysz.cc = (sysz_cc)Imm;
424*9a0e4156SSadaf Ebrahimi }
425*9a0e4156SSadaf Ebrahimi
426*9a0e4156SSadaf Ebrahimi #define PRINT_ALIAS_INSTR
427*9a0e4156SSadaf Ebrahimi #include "SystemZGenAsmWriter.inc"
428*9a0e4156SSadaf Ebrahimi
SystemZ_printInst(MCInst * MI,SStream * O,void * Info)429*9a0e4156SSadaf Ebrahimi void SystemZ_printInst(MCInst *MI, SStream *O, void *Info)
430*9a0e4156SSadaf Ebrahimi {
431*9a0e4156SSadaf Ebrahimi printInstruction(MI, O, Info);
432*9a0e4156SSadaf Ebrahimi }
433*9a0e4156SSadaf Ebrahimi
434*9a0e4156SSadaf Ebrahimi #endif
435