//===-- llvm/MC/MCInstBuilder.h - Simplify creation of MCInsts --*- C++ -*-===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// // // This file contains the MCInstBuilder class for convenient creation of // MCInsts. // //===----------------------------------------------------------------------===// #ifndef LLVM_MC_MCINSTBUILDER_H #define LLVM_MC_MCINSTBUILDER_H #include "llvm/MC/MCInst.h" namespace llvm { class MCInstBuilder { MCInst Inst; public: /// Create a new MCInstBuilder for an MCInst with a specific opcode. MCInstBuilder(unsigned Opcode) { Inst.setOpcode(Opcode); } /// Add a new register operand. MCInstBuilder &addReg(unsigned Reg) { Inst.addOperand(MCOperand::createReg(Reg)); return *this; } /// Add a new integer immediate operand. MCInstBuilder &addImm(int64_t Val) { Inst.addOperand(MCOperand::createImm(Val)); return *this; } /// Add a new single floating point immediate operand. MCInstBuilder &addSFPImm(uint32_t Val) { Inst.addOperand(MCOperand::createSFPImm(Val)); return *this; } /// Add a new floating point immediate operand. MCInstBuilder &addDFPImm(uint64_t Val) { Inst.addOperand(MCOperand::createDFPImm(Val)); return *this; } /// Add a new MCExpr operand. MCInstBuilder &addExpr(const MCExpr *Val) { Inst.addOperand(MCOperand::createExpr(Val)); return *this; } /// Add a new MCInst operand. MCInstBuilder &addInst(const MCInst *Val) { Inst.addOperand(MCOperand::createInst(Val)); return *this; } /// Add an operand. MCInstBuilder &addOperand(const MCOperand &Op) { Inst.addOperand(Op); return *this; } operator MCInst&() { return Inst; } }; } // end namespace llvm #endif