Path: blob/main/contrib/llvm-project/llvm/lib/Target/SystemZ/SystemZMCInstLower.cpp
35294 views
//===-- SystemZMCInstLower.cpp - Lower MachineInstr to MCInst -------------===//1//2// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.3// See https://llvm.org/LICENSE.txt for license information.4// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception5//6//===----------------------------------------------------------------------===//78#include "SystemZMCInstLower.h"9#include "SystemZAsmPrinter.h"10#include "llvm/IR/Mangler.h"11#include "llvm/MC/MCExpr.h"12#include "llvm/MC/MCInst.h"13#include "llvm/MC/MCStreamer.h"1415using namespace llvm;1617// Return the VK_* enumeration for MachineOperand target flags Flags.18static MCSymbolRefExpr::VariantKind getVariantKind(unsigned Flags) {19switch (Flags & SystemZII::MO_SYMBOL_MODIFIER) {20case 0:21return MCSymbolRefExpr::VK_None;22case SystemZII::MO_GOT:23return MCSymbolRefExpr::VK_GOT;24case SystemZII::MO_INDNTPOFF:25return MCSymbolRefExpr::VK_INDNTPOFF;26}27llvm_unreachable("Unrecognised MO_ACCESS_MODEL");28}2930SystemZMCInstLower::SystemZMCInstLower(MCContext &ctx,31SystemZAsmPrinter &asmprinter)32: Ctx(ctx), AsmPrinter(asmprinter) {}3334const MCExpr *35SystemZMCInstLower::getExpr(const MachineOperand &MO,36MCSymbolRefExpr::VariantKind Kind) const {37const MCSymbol *Symbol;38bool HasOffset = true;39switch (MO.getType()) {40case MachineOperand::MO_MachineBasicBlock:41Symbol = MO.getMBB()->getSymbol();42HasOffset = false;43break;4445case MachineOperand::MO_GlobalAddress:46Symbol = AsmPrinter.getSymbol(MO.getGlobal());47break;4849case MachineOperand::MO_ExternalSymbol:50Symbol = AsmPrinter.GetExternalSymbolSymbol(MO.getSymbolName());51break;5253case MachineOperand::MO_JumpTableIndex:54Symbol = AsmPrinter.GetJTISymbol(MO.getIndex());55HasOffset = false;56break;5758case MachineOperand::MO_ConstantPoolIndex:59Symbol = AsmPrinter.GetCPISymbol(MO.getIndex());60break;6162case MachineOperand::MO_BlockAddress:63Symbol = AsmPrinter.GetBlockAddressSymbol(MO.getBlockAddress());64break;6566default:67llvm_unreachable("unknown operand type");68}69const MCExpr *Expr = MCSymbolRefExpr::create(Symbol, Kind, Ctx);70if (HasOffset)71if (int64_t Offset = MO.getOffset()) {72const MCExpr *OffsetExpr = MCConstantExpr::create(Offset, Ctx);73Expr = MCBinaryExpr::createAdd(Expr, OffsetExpr, Ctx);74}75return Expr;76}7778MCOperand SystemZMCInstLower::lowerOperand(const MachineOperand &MO) const {79switch (MO.getType()) {80case MachineOperand::MO_Register:81return MCOperand::createReg(MO.getReg());8283case MachineOperand::MO_Immediate:84return MCOperand::createImm(MO.getImm());8586default: {87MCSymbolRefExpr::VariantKind Kind = getVariantKind(MO.getTargetFlags());88return MCOperand::createExpr(getExpr(MO, Kind));89}90}91}9293void SystemZMCInstLower::lower(const MachineInstr *MI, MCInst &OutMI) const {94OutMI.setOpcode(MI->getOpcode());95for (const MachineOperand &MO : MI->operands())96// Ignore all implicit register operands.97if (!MO.isReg() || !MO.isImplicit())98OutMI.addOperand(lowerOperand(MO));99}100101102