mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-05 18:49:06 +00:00
* Added an explicit type field to ComplexPattern.
* Renamed MatchingNodes to RootNodes. llvm-svn: 24636
This commit is contained in:
parent
1712ee5ab9
commit
ed205f20a5
@ -335,7 +335,9 @@ unsigned CodeGenInstruction::getOperandNamed(const std::string &Name) const {
|
|||||||
// ComplexPattern implementation
|
// ComplexPattern implementation
|
||||||
//
|
//
|
||||||
ComplexPattern::ComplexPattern(Record *R) {
|
ComplexPattern::ComplexPattern(Record *R) {
|
||||||
NumOperands = R->getValueAsInt("NumOperands");
|
Ty = ::getValueType(R->getValueAsDef("Ty"));
|
||||||
SelectFunc = R->getValueAsString("SelectFunc");
|
NumOperands = R->getValueAsInt("NumOperands");
|
||||||
MatchingNodes = R->getValueAsListOfDefs("MatchingNodes");
|
SelectFunc = R->getValueAsString("SelectFunc");
|
||||||
|
RootNodes = R->getValueAsListOfDefs("RootNodes");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -160,17 +160,19 @@ public:
|
|||||||
/// ComplexPattern - ComplexPattern info, corresponding to the ComplexPattern
|
/// ComplexPattern - ComplexPattern info, corresponding to the ComplexPattern
|
||||||
/// tablegen class in TargetSelectionDAG.td
|
/// tablegen class in TargetSelectionDAG.td
|
||||||
class ComplexPattern {
|
class ComplexPattern {
|
||||||
|
MVT::ValueType Ty;
|
||||||
unsigned NumOperands;
|
unsigned NumOperands;
|
||||||
std::string SelectFunc;
|
std::string SelectFunc;
|
||||||
std::vector<Record*> MatchingNodes;
|
std::vector<Record*> RootNodes;
|
||||||
public:
|
public:
|
||||||
ComplexPattern() : NumOperands(0) {};
|
ComplexPattern() : NumOperands(0) {};
|
||||||
ComplexPattern(Record *R);
|
ComplexPattern(Record *R);
|
||||||
|
|
||||||
|
MVT::ValueType getValueType() const { return Ty; }
|
||||||
unsigned getNumOperands() const { return NumOperands; }
|
unsigned getNumOperands() const { return NumOperands; }
|
||||||
const std::string &getSelectFunc() const { return SelectFunc; }
|
const std::string &getSelectFunc() const { return SelectFunc; }
|
||||||
const std::vector<Record*> &getMatchingNodes() const {
|
const std::vector<Record*> &getRootNodes() const {
|
||||||
return MatchingNodes;
|
return RootNodes;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -478,8 +478,7 @@ static unsigned char getIntrinsicType(Record *R, bool NotRegisters,
|
|||||||
// Using a VTSDNode or CondCodeSDNode.
|
// Using a VTSDNode or CondCodeSDNode.
|
||||||
return MVT::Other;
|
return MVT::Other;
|
||||||
} else if (R->isSubClassOf("ComplexPattern")) {
|
} else if (R->isSubClassOf("ComplexPattern")) {
|
||||||
const CodeGenTarget &T = TP.getDAGISelEmitter().getTargetInfo();
|
return TP.getDAGISelEmitter().getComplexPattern(R).getValueType();
|
||||||
return T.getPointerType();
|
|
||||||
} else if (R->getName() == "node") {
|
} else if (R->getName() == "node") {
|
||||||
// Placeholder.
|
// Placeholder.
|
||||||
return MVT::isUnknown;
|
return MVT::isUnknown;
|
||||||
@ -2256,7 +2255,7 @@ void DAGISelEmitter::EmitInstructionSelector(std::ostream &OS) {
|
|||||||
dynamic_cast<IntInit*>(Node->getLeafValue())) {
|
dynamic_cast<IntInit*>(Node->getLeafValue())) {
|
||||||
PatternsByOpcode[getSDNodeNamed("imm")].push_back(&PatternsToMatch[i]);
|
PatternsByOpcode[getSDNodeNamed("imm")].push_back(&PatternsToMatch[i]);
|
||||||
} else if ((CP = NodeGetComplexPattern(Node, *this))) {
|
} else if ((CP = NodeGetComplexPattern(Node, *this))) {
|
||||||
std::vector<Record*> OpNodes = CP->getMatchingNodes();
|
std::vector<Record*> OpNodes = CP->getRootNodes();
|
||||||
for (unsigned j = 0, e = OpNodes.size(); j != e; j++) {
|
for (unsigned j = 0, e = OpNodes.size(); j != e; j++) {
|
||||||
PatternsByOpcode[OpNodes[j]].insert(PatternsByOpcode[OpNodes[j]].begin(),
|
PatternsByOpcode[OpNodes[j]].insert(PatternsByOpcode[OpNodes[j]].begin(),
|
||||||
&PatternsToMatch[i]);
|
&PatternsToMatch[i]);
|
||||||
|
Loading…
Reference in New Issue
Block a user