summaryrefslogtreecommitdiff
path: root/utils
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2006-07-18 17:56:07 +0000
committerChris Lattner <sabre@nondot.org>2006-07-18 17:56:07 +0000
commitb84628679ad7240a63d267fc6388efbc1e91f588 (patch)
tree91f7898730846c80611b798df325ac2c9f6cbe35 /utils
parent191dd1f1860661f2e0bb99432d10da9b2aff1fc7 (diff)
downloadllvm-b84628679ad7240a63d267fc6388efbc1e91f588.tar.gz
llvm-b84628679ad7240a63d267fc6388efbc1e91f588.tar.bz2
llvm-b84628679ad7240a63d267fc6388efbc1e91f588.tar.xz
Change generator to remove operands as it processes them. No change in
generated file. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@29183 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'utils')
-rw-r--r--utils/TableGen/AsmWriterEmitter.cpp36
-rw-r--r--utils/TableGen/AsmWriterEmitter.h3
2 files changed, 22 insertions, 17 deletions
diff --git a/utils/TableGen/AsmWriterEmitter.cpp b/utils/TableGen/AsmWriterEmitter.cpp
index 7162590cc1..016bac5c76 100644
--- a/utils/TableGen/AsmWriterEmitter.cpp
+++ b/utils/TableGen/AsmWriterEmitter.cpp
@@ -330,7 +330,7 @@ static void EmitInstructions(std::vector<AsmWriterInst> &Insts,
void AsmWriterEmitter::
FindUniqueOperandCommands(std::vector<std::string> &UniqueOperandCommands,
- std::vector<unsigned> &InstIdxs, unsigned Op) const {
+ std::vector<unsigned> &InstIdxs) const {
InstIdxs.clear();
InstIdxs.resize(NumberedInstructions.size());
@@ -345,13 +345,13 @@ FindUniqueOperandCommands(std::vector<std::string> &UniqueOperandCommands,
if (Inst == 0) continue; // PHI, INLINEASM, etc.
std::string Command;
- if (Op >= Inst->Operands.size())
+ if (Inst->Operands.empty())
continue; // Instruction already done.
- Command = " " + Inst->Operands[Op].getCode() + "\n";
+ Command = " " + Inst->Operands[0].getCode() + "\n";
// If this is the last operand, emit a return.
- if (Op == Inst->Operands.size()-1)
+ if (Inst->Operands.size() == 1)
Command += " return true;\n";
// Check to see if we already have 'Command' in UniqueOperandCommands.
@@ -463,16 +463,19 @@ void AsmWriterEmitter::run(std::ostream &O) {
std::vector<std::vector<std::string> > TableDrivenOperandPrinters;
- for (unsigned i = 0; ; ++i) {
+ bool isFirst = true;
+ while (1) {
std::vector<std::string> UniqueOperandCommands;
// For the first operand check, add a default value that unhandled
// instructions will use.
- if (i == 0)
+ if (isFirst) {
UniqueOperandCommands.push_back(" return false;\n");
+ isFirst = false;
+ }
std::vector<unsigned> InstIdxs;
- FindUniqueOperandCommands(UniqueOperandCommands, InstIdxs, i);
+ FindUniqueOperandCommands(UniqueOperandCommands, InstIdxs);
// If we ran out of operands to print, we're done.
if (UniqueOperandCommands.empty()) break;
@@ -495,6 +498,14 @@ void AsmWriterEmitter::run(std::ostream &O) {
for (unsigned i = 0, e = InstIdxs.size(); i != e; ++i)
OpcodeInfo[i] |= InstIdxs[i] << (BitsLeft+AsmStrBits);
+ // Remove the info about this operand.
+ for (unsigned i = 0, e = NumberedInstructions.size(); i != e; ++i) {
+ if (AsmWriterInst *Inst = getAsmWriterInstByID(i))
+ if (!Inst->Operands.empty())
+ Inst->Operands.erase(Inst->Operands.begin());
+ }
+
+ // Remember the handlers for this set of operands.
TableDrivenOperandPrinters.push_back(UniqueOperandCommands);
}
@@ -590,18 +601,13 @@ void AsmWriterEmitter::run(std::ostream &O) {
}
}
- // Okay, go through and strip out the operand information that we just
- // emitted.
- unsigned NumOpsToRemove = TableDrivenOperandPrinters.size();
+ // Okay, delete instructions with no operand info left.
for (unsigned i = 0, e = Instructions.size(); i != e; ++i) {
// Entire instruction has been emitted?
AsmWriterInst &Inst = Instructions[i];
- if (Inst.Operands.size() <= NumOpsToRemove) {
+ if (Inst.Operands.empty()) {
Instructions.erase(Instructions.begin()+i);
- --i; --e;
- } else {
- Inst.Operands.erase(Inst.Operands.begin(),
- Inst.Operands.begin()+NumOpsToRemove);
+ --i; --e;
}
}
diff --git a/utils/TableGen/AsmWriterEmitter.h b/utils/TableGen/AsmWriterEmitter.h
index c7a9c60bff..5def47efdd 100644
--- a/utils/TableGen/AsmWriterEmitter.h
+++ b/utils/TableGen/AsmWriterEmitter.h
@@ -43,8 +43,7 @@ private:
return I->second;
}
void FindUniqueOperandCommands(std::vector<std::string> &UOC,
- std::vector<unsigned> &InstIdxs,
- unsigned Op) const;
+ std::vector<unsigned> &InstIdxs) const;
};
}
#endif