//===- llvm/MC/MCCodeEmitter.h - Instruction Encoding -----------*- 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 // //===----------------------------------------------------------------------===// #ifndef LLVM_MC_MCCODEEMITTER_H #define LLVM_MC_MCCODEEMITTER_H namespace llvm { class MCFixup; class MCInst; class MCSubtargetInfo; class raw_ostream; template class SmallVectorImpl; /// MCCodeEmitter - Generic instruction encoding interface. class MCCodeEmitter { protected: // Can only create subclasses. MCCodeEmitter(); public: MCCodeEmitter(const MCCodeEmitter &) = delete; MCCodeEmitter &operator=(const MCCodeEmitter &) = delete; virtual ~MCCodeEmitter(); /// Lifetime management virtual void reset() {} /// Emit the prefixes of given instruction on the output stream. /// /// \param Inst a single low-level machine instruction. /// \param OS output stream. virtual void emitPrefix(const MCInst &Inst, raw_ostream &OS, const MCSubtargetInfo &STI) const {} /// EncodeInstruction - Encode the given \p Inst to bytes on the output /// stream \p OS. virtual void encodeInstruction(const MCInst &Inst, raw_ostream &OS, SmallVectorImpl &Fixups, const MCSubtargetInfo &STI) const = 0; }; } // end namespace llvm #endif // LLVM_MC_MCCODEEMITTER_H