Add file comment

Add register info emitter
Simplify code by using "high-level" methods.

llvm-svn: 7466
This commit is contained in:
Chris Lattner 2003-08-01 04:39:05 +00:00
parent 8d99a76d55
commit 1f2f5c8392
1 changed files with 52 additions and 40 deletions

View File

@ -1,13 +1,25 @@
//===- TableGen.cpp - Top-Level TableGen implementation -------------------===//
//
// TableGen is a tool which can be used to build up a description of something,
// then invoke one or more "tablegen backends" to emit information about the
// description in some predefined format. In practice, this is used by the LLVM
// code generators to automate generation of a code generator through a
// high-level description of the target.
//
//===----------------------------------------------------------------------===//
#include "Record.h" #include "Record.h"
#include "Support/CommandLine.h" #include "Support/CommandLine.h"
#include "Support/Signals.h" #include "Support/Signals.h"
#include "CodeEmitterGen.h" #include "CodeEmitterGen.h"
#include "RegisterInfoEmitter.h"
#include <algorithm> #include <algorithm>
#include <fstream> #include <fstream>
enum ActionType { enum ActionType {
PrintRecords, PrintRecords,
GenEmitter, GenEmitter,
GenRegister, GenRegisterHeader,
PrintEnums, PrintEnums,
Parse, Parse,
}; };
@ -19,6 +31,10 @@ namespace {
"Print all records to stdout (default)"), "Print all records to stdout (default)"),
clEnumValN(GenEmitter, "gen-emitter", clEnumValN(GenEmitter, "gen-emitter",
"Generate machine code emitter"), "Generate machine code emitter"),
clEnumValN(GenRegister, "gen-register-desc",
"Generate a register info description"),
clEnumValN(GenRegisterHeader, "gen-register-desc-header",
"Generate a register info description header"),
clEnumValN(PrintEnums, "print-enums", clEnumValN(PrintEnums, "print-enums",
"Print enum values for a class"), "Print enum values for a class"),
clEnumValN(Parse, "parse", clEnumValN(Parse, "parse",
@ -174,7 +190,7 @@ static Record *ParseMachineCode(std::vector<Record*>::iterator InstsB,
for (unsigned i = 0, e = getNumBits(Inst); i != e; ++i) for (unsigned i = 0, e = getNumBits(Inst); i != e; ++i)
if (BitInit *BI = dynamic_cast<BitInit*>(getBit(Inst, i))) if (BitInit *BI = dynamic_cast<BitInit*>(getBit(Inst, i)))
if (getMemoryBit(M, i) != BI->getValue()) if (getMemoryBit(M, i) != BI->getValue())
return 0; throw std::string("Parse failed!\n");
return Inst; return Inst;
} }
@ -353,24 +369,11 @@ static void ParseMachineCode() {
}; };
#endif #endif
std::vector<Record*> Insts; std::vector<Record*> Insts = Records.getAllDerivedDefinitions("Instruction");
const std::map<std::string, Record*> &Defs = Records.getDefs();
Record *Inst = Records.getClass("Instruction");
assert(Inst && "Couldn't find Instruction class!");
for (std::map<std::string, Record*>::const_iterator I = Defs.begin(),
E = Defs.end(); I != E; ++I)
if (I->second->isSubClassOf(Inst))
Insts.push_back(I->second);
unsigned char *BuffPtr = Buffer; unsigned char *BuffPtr = Buffer;
while (1) { while (1) {
Record *R = ParseMachineCode(Insts.begin(), Insts.end(), BuffPtr); Record *R = ParseMachineCode(Insts.begin(), Insts.end(), BuffPtr);
if (R == 0) {
std::cout << "Parse failed!\n";
return;
}
PrintInstruction(R, BuffPtr); PrintInstruction(R, BuffPtr);
unsigned Bits = getNumBits(R); unsigned Bits = getNumBits(R);
@ -397,12 +400,19 @@ int main(int argc, char **argv) {
RemoveFileOnSignal(OutputFilename); RemoveFileOnSignal(OutputFilename);
} }
int ErrorCode = 0; try {
switch (Action) { switch (Action) {
case Parse: ParseMachineCode(); break; case Parse:
ParseMachineCode();
break;
case GenEmitter: case GenEmitter:
ErrorCode = CodeEmitterGen(Records).run(*Out); CodeEmitterGen(Records).run(*Out);
break;
case GenRegister:
RegisterInfoEmitter(Records).run(*Out);
break;
case GenRegisterHeader:
RegisterInfoEmitter(Records).runHeader(*Out);
break; break;
case PrintRecords: case PrintRecords:
*Out << Records; // No argument, dump all contents *Out << Records; // No argument, dump all contents
@ -414,17 +424,19 @@ int main(int argc, char **argv) {
abort(); abort();
} }
const std::map<std::string, Record*> &Defs = Records.getDefs(); std::vector<Record*> Recs = Records.getAllDerivedDefinitions(Class);
for (std::map<std::string, Record*>::const_iterator I = Defs.begin(),
E = Defs.end(); I != E; ++I) { for (unsigned i = 0, e = Recs.size(); i != e; ++i)
if (I->second->isSubClassOf(R)) { *Out << Recs[i] << ", ";
*Out << I->first << ", ";
}
}
*Out << "\n"; *Out << "\n";
break; break;
} }
} catch (const std::string &Error) {
std::cerr << Error << "\n";
if (Out != &std::cout) delete Out;
return 1;
}
if (Out != &std::cout) delete Out; if (Out != &std::cout) delete Out;
return ErrorCode; return 0;
} }