mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-06-24 08:24:33 +00:00
Reinstate "Nuke the old JIT."
Approved by Jim Grosbach, Lang Hames, Rafael Espindola. This reinstates commits r215111, 215115, 215116, 215117, 215136. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@216982 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@ -24,14 +24,6 @@
|
||||
#include <vector>
|
||||
using namespace llvm;
|
||||
|
||||
// FIXME: Somewhat hackish to use a command line option for this. There should
|
||||
// be a CodeEmitter class in the Target.td that controls this sort of thing
|
||||
// instead.
|
||||
static cl::opt<bool>
|
||||
MCEmitter("mc-emitter",
|
||||
cl::desc("Generate CodeEmitter for use with the MC library."),
|
||||
cl::init(false));
|
||||
|
||||
namespace {
|
||||
|
||||
class CodeEmitterGen {
|
||||
@ -134,15 +126,13 @@ AddCodeToMergeInOperand(Record *R, BitsInit *BI, const std::string &VarName,
|
||||
if (SO.second == 0) {
|
||||
Case += " // op: " + VarName + "\n" +
|
||||
" op = " + EncoderMethodName + "(MI, " + utostr(OpIdx);
|
||||
if (MCEmitter)
|
||||
Case += ", Fixups, STI";
|
||||
Case += ", Fixups, STI";
|
||||
Case += ");\n";
|
||||
}
|
||||
} else {
|
||||
Case += " // op: " + VarName + "\n" +
|
||||
" op = getMachineOpValue(MI, MI.getOperand(" + utostr(OpIdx) + ")";
|
||||
if (MCEmitter)
|
||||
Case += ", Fixups, STI";
|
||||
Case += ", Fixups, STI";
|
||||
Case += ");\n";
|
||||
}
|
||||
|
||||
@ -223,8 +213,7 @@ std::string CodeEmitterGen::getInstructionCase(Record *R,
|
||||
std::string PostEmitter = R->getValueAsString("PostEncoderMethod");
|
||||
if (!PostEmitter.empty()) {
|
||||
Case += " Value = " + PostEmitter + "(MI, Value";
|
||||
if (MCEmitter)
|
||||
Case += ", STI";
|
||||
Case += ", STI";
|
||||
Case += ");\n";
|
||||
}
|
||||
|
||||
@ -243,12 +232,9 @@ void CodeEmitterGen::run(raw_ostream &o) {
|
||||
|
||||
// Emit function declaration
|
||||
o << "uint64_t " << Target.getName();
|
||||
if (MCEmitter)
|
||||
o << "MCCodeEmitter::getBinaryCodeForInstr(const MCInst &MI,\n"
|
||||
<< " SmallVectorImpl<MCFixup> &Fixups,\n"
|
||||
<< " const MCSubtargetInfo &STI) const {\n";
|
||||
else
|
||||
o << "CodeEmitter::getBinaryCodeForInstr(const MachineInstr &MI) const {\n";
|
||||
o << "MCCodeEmitter::getBinaryCodeForInstr(const MCInst &MI,\n"
|
||||
<< " SmallVectorImpl<MCFixup> &Fixups,\n"
|
||||
<< " const MCSubtargetInfo &STI) const {\n";
|
||||
|
||||
// Emit instruction base values
|
||||
o << " static const uint64_t InstBits[] = {\n";
|
||||
|
Reference in New Issue
Block a user