1//===-- XCoreMCInstLower.h - Lower MachineInstr to MCInst ------*- C++ -*--===// 2// 3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 4// See https://llvm.org/LICENSE.txt for license information. 5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 6// 7//===----------------------------------------------------------------------===// 8 9#ifndef LLVM_LIB_TARGET_XCORE_XCOREMCINSTLOWER_H 10#define LLVM_LIB_TARGET_XCORE_XCOREMCINSTLOWER_H 11#include "llvm/CodeGen/MachineOperand.h" 12#include "llvm/Support/Compiler.h" 13 14namespace llvm { 15 class MCContext; 16 class MCInst; 17 class MCOperand; 18 class MachineInstr; 19 class MachineFunction; 20 class Mangler; 21 class AsmPrinter; 22 23/// This class is used to lower an MachineInstr into an MCInst. 24class LLVM_LIBRARY_VISIBILITY XCoreMCInstLower { 25 typedef MachineOperand::MachineOperandType MachineOperandType; 26 MCContext *Ctx; 27 AsmPrinter &Printer; 28public: 29 XCoreMCInstLower(class AsmPrinter &asmprinter); 30 void Initialize(MCContext *C); 31 void Lower(const MachineInstr *MI, MCInst &OutMI) const; 32 MCOperand LowerOperand(const MachineOperand& MO, unsigned offset = 0) const; 33 34private: 35 MCOperand LowerSymbolOperand(const MachineOperand &MO, 36 MachineOperandType MOTy, unsigned Offset) const; 37}; 38} 39 40#endif 41