forked from OSchip/llvm-project
completely eliminate TreePattern::PatternType
llvm-svn: 23335
This commit is contained in:
parent
0f965a615e
commit
f365e25a5c
|
@ -329,66 +329,15 @@ bool TreePatternNode::ApplyTypeConstraints(TreePattern &TP) {
|
|||
// TreePattern implementation
|
||||
//
|
||||
|
||||
TreePattern::TreePattern(PatternType pty, Record *TheRec,
|
||||
const std::vector<DagInit *> &RawPat,
|
||||
DAGISelEmitter &ise)
|
||||
: PTy(pty), TheRecord(TheRec), ISE(ise) {
|
||||
TreePattern::TreePattern(Record *TheRec, const std::vector<DagInit *> &RawPat,
|
||||
DAGISelEmitter &ise) : TheRecord(TheRec), ISE(ise) {
|
||||
|
||||
for (unsigned i = 0, e = RawPat.size(); i != e; ++i)
|
||||
Trees.push_back(ParseTreePattern(RawPat[i]));
|
||||
|
||||
// Sanity checks and cleanup.
|
||||
switch (PTy) {
|
||||
case PatFrag: {
|
||||
assert(Trees.size() == 1 && "How can we have more than one pattern here?");
|
||||
|
||||
// Validate arguments list, convert it to map, to discard duplicates.
|
||||
std::set<std::string> OperandsMap(Args.begin(), Args.end());
|
||||
|
||||
if (OperandsMap.count(""))
|
||||
error("Cannot have unnamed 'node' values in pattern fragment!");
|
||||
|
||||
// Parse the operands list.
|
||||
DagInit *OpsList = TheRec->getValueAsDag("Operands");
|
||||
if (OpsList->getNodeType()->getName() != "ops")
|
||||
error("Operands list should start with '(ops ... '!");
|
||||
|
||||
// Copy over the arguments.
|
||||
Args.clear();
|
||||
for (unsigned i = 0, e = OpsList->getNumArgs(); i != e; ++i) {
|
||||
if (!dynamic_cast<DefInit*>(OpsList->getArg(i)) ||
|
||||
static_cast<DefInit*>(OpsList->getArg(i))->
|
||||
getDef()->getName() != "node")
|
||||
error("Operands list should all be 'node' values.");
|
||||
if (OpsList->getArgName(i).empty())
|
||||
error("Operands list should have names for each operand!");
|
||||
if (!OperandsMap.count(OpsList->getArgName(i)))
|
||||
error("'" + OpsList->getArgName(i) +
|
||||
"' does not occur in pattern or was multiply specified!");
|
||||
OperandsMap.erase(OpsList->getArgName(i));
|
||||
Args.push_back(OpsList->getArgName(i));
|
||||
}
|
||||
|
||||
if (!OperandsMap.empty())
|
||||
error("Operands list does not contain an entry for operand '" +
|
||||
*OperandsMap.begin() + "'!");
|
||||
|
||||
break;
|
||||
}
|
||||
default:
|
||||
if (!Args.empty())
|
||||
error("Only pattern fragments can have operands (use 'node' values)!");
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
void TreePattern::error(const std::string &Msg) const {
|
||||
std::string M = "In ";
|
||||
switch (PTy) {
|
||||
case PatFrag: M += "patfrag "; break;
|
||||
case Instruction: M += "instruction "; break;
|
||||
}
|
||||
throw M + TheRecord->getName() + ": " + Msg;
|
||||
throw "In " + TheRecord->getName() + ": " + Msg;
|
||||
}
|
||||
|
||||
/// getIntrinsicType - Check to see if the specified record has an intrinsic
|
||||
|
@ -507,11 +456,6 @@ bool TreePattern::InferAllTypes() {
|
|||
}
|
||||
|
||||
void TreePattern::print(std::ostream &OS) const {
|
||||
switch (getPatternType()) {
|
||||
case TreePattern::PatFrag: OS << "PatFrag pattern "; break;
|
||||
case TreePattern::Instruction: OS << "Inst pattern "; break;
|
||||
}
|
||||
|
||||
OS << getRecord()->getName();
|
||||
if (!Args.empty()) {
|
||||
OS << "(" << Args[0];
|
||||
|
@ -565,10 +509,41 @@ void DAGISelEmitter::ParseAndResolvePatternFragments(std::ostream &OS) {
|
|||
for (unsigned i = 0, e = Fragments.size(); i != e; ++i) {
|
||||
std::vector<DagInit*> Trees;
|
||||
Trees.push_back(Fragments[i]->getValueAsDag("Fragment"));
|
||||
TreePattern *P = new TreePattern(TreePattern::PatFrag, Fragments[i],
|
||||
Trees, *this);
|
||||
TreePattern *P = new TreePattern(Fragments[i], Trees, *this);
|
||||
PatternFragments[Fragments[i]] = P;
|
||||
|
||||
// Validate the argument list, converting it to map, to discard duplicates.
|
||||
std::vector<std::string> &Args = P->getArgList();
|
||||
std::set<std::string> OperandsMap(Args.begin(), Args.end());
|
||||
|
||||
if (OperandsMap.count(""))
|
||||
P->error("Cannot have unnamed 'node' values in pattern fragment!");
|
||||
|
||||
// Parse the operands list.
|
||||
DagInit *OpsList = Fragments[i]->getValueAsDag("Operands");
|
||||
if (OpsList->getNodeType()->getName() != "ops")
|
||||
P->error("Operands list should start with '(ops ... '!");
|
||||
|
||||
// Copy over the arguments.
|
||||
Args.clear();
|
||||
for (unsigned j = 0, e = OpsList->getNumArgs(); j != e; ++j) {
|
||||
if (!dynamic_cast<DefInit*>(OpsList->getArg(j)) ||
|
||||
static_cast<DefInit*>(OpsList->getArg(j))->
|
||||
getDef()->getName() != "node")
|
||||
P->error("Operands list should all be 'node' values.");
|
||||
if (OpsList->getArgName(j).empty())
|
||||
P->error("Operands list should have names for each operand!");
|
||||
if (!OperandsMap.count(OpsList->getArgName(j)))
|
||||
P->error("'" + OpsList->getArgName(j) +
|
||||
"' does not occur in pattern or was multiply specified!");
|
||||
OperandsMap.erase(OpsList->getArgName(j));
|
||||
Args.push_back(OpsList->getArgName(j));
|
||||
}
|
||||
|
||||
if (!OperandsMap.empty())
|
||||
P->error("Operands list does not contain an entry for operand '" +
|
||||
*OperandsMap.begin() + "'!");
|
||||
|
||||
// If there is a code init for this fragment, emit the predicate code and
|
||||
// keep track of the fact that this fragment uses it.
|
||||
CodeInit *CI =
|
||||
|
@ -631,8 +606,7 @@ void DAGISelEmitter::ParseAndResolveInstructions() {
|
|||
Trees.push_back((DagInit*)LI->getElement(j));
|
||||
|
||||
// Parse the instruction.
|
||||
TreePattern *I = new TreePattern(TreePattern::Instruction, Instrs[i],
|
||||
Trees, *this);
|
||||
TreePattern *I = new TreePattern(Instrs[i], Trees, *this);
|
||||
// Inline pattern fragments into it.
|
||||
I->InlinePatternFragments();
|
||||
|
||||
|
|
|
@ -190,19 +190,10 @@ namespace llvm {
|
|||
};
|
||||
|
||||
|
||||
/// TreePattern - Represent a pattern of one form or another. Currently, two
|
||||
/// types of patterns are possible: Instructions and PatFrags.
|
||||
/// TreePattern - Represent a pattern, used for instructions, pattern
|
||||
/// fragments, etc.
|
||||
///
|
||||
class TreePattern {
|
||||
public:
|
||||
enum PatternType {
|
||||
PatFrag, Instruction
|
||||
};
|
||||
private:
|
||||
/// PTy - The type of pattern this is.
|
||||
///
|
||||
PatternType PTy;
|
||||
|
||||
/// Trees - The list of pattern trees which corresponds to this pattern.
|
||||
/// Note that PatFrag's only have a single tree.
|
||||
///
|
||||
|
@ -223,13 +214,9 @@ namespace llvm {
|
|||
|
||||
/// TreePattern constructor - Parse the specified DagInits into the
|
||||
/// current record.
|
||||
TreePattern(PatternType pty, Record *TheRec,
|
||||
TreePattern(Record *TheRec,
|
||||
const std::vector<DagInit *> &RawPat, DAGISelEmitter &ise);
|
||||
|
||||
/// getPatternType - Return what flavor of Record this pattern originated from
|
||||
///
|
||||
PatternType getPatternType() const { return PTy; }
|
||||
|
||||
/// getTrees - Return the tree patterns which corresponds to this pattern.
|
||||
///
|
||||
const std::vector<TreePatternNode*> &getTrees() const { return Trees; }
|
||||
|
@ -250,6 +237,7 @@ namespace llvm {
|
|||
assert(i < Args.size() && "Argument reference out of range!");
|
||||
return Args[i];
|
||||
}
|
||||
std::vector<std::string> &getArgList() { return Args; }
|
||||
|
||||
DAGISelEmitter &getDAGISelEmitter() const { return ISE; }
|
||||
|
||||
|
|
Loading…
Reference in New Issue