//===--------------------- CodeEmitter.cpp ----------------------*- 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 implements the CodeEmitter API. // //===----------------------------------------------------------------------===// #include "llvm/MCA/CodeEmitter.h" namespace llvm { namespace mca { CodeEmitter::EncodingInfo CodeEmitter::getOrCreateEncodingInfo(unsigned MCID) { EncodingInfo &EI = Encodings[MCID]; if (EI.second) return EI; SmallVector Fixups; const MCInst &Inst = Sequence[MCID]; MCInst Relaxed(Sequence[MCID]); if (MAB.mayNeedRelaxation(Inst, STI)) MAB.relaxInstruction(Relaxed, STI); EI.first = Code.size(); MCE.encodeInstruction(Relaxed, VecOS, Fixups, STI); EI.second = Code.size() - EI.first; return EI; } } // namespace mca } // namespace llvm