blob: d2ba9b6f54c35abbacc9d970d46f44cfa7d6a302 [file] [log] [blame]
Ulrich Weigand5f613df2013-05-06 16:15:19 +00001//===-- SystemZInstPrinter.cpp - Convert SystemZ MCInst to assembly syntax ===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9
Ulrich Weigand5f613df2013-05-06 16:15:19 +000010#include "SystemZInstPrinter.h"
11#include "llvm/MC/MCExpr.h"
12#include "llvm/MC/MCInstrInfo.h"
13#include "llvm/Support/raw_ostream.h"
14
15using namespace llvm;
16
Chandler Carruth84e68b22014-04-22 02:41:26 +000017#define DEBUG_TYPE "asm-printer"
18
Ulrich Weigand5f613df2013-05-06 16:15:19 +000019#include "SystemZGenAsmWriter.inc"
20
21void SystemZInstPrinter::printAddress(unsigned Base, int64_t Disp,
22 unsigned Index, raw_ostream &O) {
23 O << Disp;
24 if (Base) {
25 O << '(';
26 if (Index)
27 O << '%' << getRegisterName(Index) << ',';
28 O << '%' << getRegisterName(Base) << ')';
29 } else
30 assert(!Index && "Shouldn't have an index without a base");
31}
32
33void SystemZInstPrinter::printOperand(const MCOperand &MO, raw_ostream &O) {
34 if (MO.isReg())
35 O << '%' << getRegisterName(MO.getReg());
36 else if (MO.isImm())
37 O << MO.getImm();
38 else if (MO.isExpr())
39 O << *MO.getExpr();
40 else
41 llvm_unreachable("Invalid operand");
42}
43
44void SystemZInstPrinter::printInst(const MCInst *MI, raw_ostream &O,
45 StringRef Annot) {
46 printInstruction(MI, O);
47 printAnnotation(O, Annot);
48}
49
50void SystemZInstPrinter::printRegName(raw_ostream &O, unsigned RegNo) const {
51 O << '%' << getRegisterName(RegNo);
52}
53
54void SystemZInstPrinter::printU4ImmOperand(const MCInst *MI, int OpNum,
55 raw_ostream &O) {
56 int64_t Value = MI->getOperand(OpNum).getImm();
57 assert(isUInt<4>(Value) && "Invalid u4imm argument");
58 O << Value;
59}
60
61void SystemZInstPrinter::printU6ImmOperand(const MCInst *MI, int OpNum,
62 raw_ostream &O) {
63 int64_t Value = MI->getOperand(OpNum).getImm();
64 assert(isUInt<6>(Value) && "Invalid u6imm argument");
65 O << Value;
66}
67
68void SystemZInstPrinter::printS8ImmOperand(const MCInst *MI, int OpNum,
69 raw_ostream &O) {
70 int64_t Value = MI->getOperand(OpNum).getImm();
71 assert(isInt<8>(Value) && "Invalid s8imm argument");
72 O << Value;
73}
74
75void SystemZInstPrinter::printU8ImmOperand(const MCInst *MI, int OpNum,
76 raw_ostream &O) {
77 int64_t Value = MI->getOperand(OpNum).getImm();
78 assert(isUInt<8>(Value) && "Invalid u8imm argument");
79 O << Value;
80}
81
82void SystemZInstPrinter::printS16ImmOperand(const MCInst *MI, int OpNum,
83 raw_ostream &O) {
84 int64_t Value = MI->getOperand(OpNum).getImm();
85 assert(isInt<16>(Value) && "Invalid s16imm argument");
86 O << Value;
87}
88
89void SystemZInstPrinter::printU16ImmOperand(const MCInst *MI, int OpNum,
90 raw_ostream &O) {
91 int64_t Value = MI->getOperand(OpNum).getImm();
92 assert(isUInt<16>(Value) && "Invalid u16imm argument");
93 O << Value;
94}
95
96void SystemZInstPrinter::printS32ImmOperand(const MCInst *MI, int OpNum,
97 raw_ostream &O) {
98 int64_t Value = MI->getOperand(OpNum).getImm();
99 assert(isInt<32>(Value) && "Invalid s32imm argument");
100 O << Value;
101}
102
103void SystemZInstPrinter::printU32ImmOperand(const MCInst *MI, int OpNum,
104 raw_ostream &O) {
105 int64_t Value = MI->getOperand(OpNum).getImm();
106 assert(isUInt<32>(Value) && "Invalid u32imm argument");
107 O << Value;
108}
109
110void SystemZInstPrinter::printAccessRegOperand(const MCInst *MI, int OpNum,
111 raw_ostream &O) {
112 uint64_t Value = MI->getOperand(OpNum).getImm();
113 assert(Value < 16 && "Invalid access register number");
114 O << "%a" << (unsigned int)Value;
115}
116
Richard Sandifordeb9af292013-05-14 10:17:52 +0000117void SystemZInstPrinter::printPCRelOperand(const MCInst *MI, int OpNum,
118 raw_ostream &O) {
119 const MCOperand &MO = MI->getOperand(OpNum);
120 if (MO.isImm()) {
121 O << "0x";
122 O.write_hex(MO.getImm());
123 } else
124 O << *MO.getExpr();
125}
126
Ulrich Weigand5f613df2013-05-06 16:15:19 +0000127void SystemZInstPrinter::printOperand(const MCInst *MI, int OpNum,
128 raw_ostream &O) {
129 printOperand(MI->getOperand(OpNum), O);
130}
131
132void SystemZInstPrinter::printBDAddrOperand(const MCInst *MI, int OpNum,
133 raw_ostream &O) {
134 printAddress(MI->getOperand(OpNum).getReg(),
135 MI->getOperand(OpNum + 1).getImm(), 0, O);
136}
137
138void SystemZInstPrinter::printBDXAddrOperand(const MCInst *MI, int OpNum,
139 raw_ostream &O) {
140 printAddress(MI->getOperand(OpNum).getReg(),
141 MI->getOperand(OpNum + 1).getImm(),
142 MI->getOperand(OpNum + 2).getReg(), O);
143}
144
Richard Sandiford1d959002013-07-02 14:56:45 +0000145void SystemZInstPrinter::printBDLAddrOperand(const MCInst *MI, int OpNum,
146 raw_ostream &O) {
147 unsigned Base = MI->getOperand(OpNum).getReg();
148 uint64_t Disp = MI->getOperand(OpNum + 1).getImm();
149 uint64_t Length = MI->getOperand(OpNum + 2).getImm();
150 O << Disp << '(' << Length;
151 if (Base)
152 O << ",%" << getRegisterName(Base);
153 O << ')';
154}
155
Ulrich Weigand5f613df2013-05-06 16:15:19 +0000156void SystemZInstPrinter::printCond4Operand(const MCInst *MI, int OpNum,
157 raw_ostream &O) {
158 static const char *const CondNames[] = {
159 "o", "h", "nle", "l", "nhe", "lh", "ne",
160 "e", "nlh", "he", "nl", "le", "nh", "no"
161 };
162 uint64_t Imm = MI->getOperand(OpNum).getImm();
163 assert(Imm > 0 && Imm < 15 && "Invalid condition");
164 O << CondNames[Imm - 1];
165}