diff options
author | Owen Anderson <resistor@mac.com> | 2008-08-25 23:43:09 +0000 |
---|---|---|
committer | Owen Anderson <resistor@mac.com> | 2008-08-25 23:43:09 +0000 |
commit | 81b6a174112595ac211ce17441a0ede03d505e7d (patch) | |
tree | 4673b5d424d895463f3a70a1bce4373fe9f956a8 /utils | |
parent | e91a2d65596549d60c6844016ccb774bf19a4599 (diff) | |
download | external_llvm-81b6a174112595ac211ce17441a0ede03d505e7d.zip external_llvm-81b6a174112595ac211ce17441a0ede03d505e7d.tar.gz external_llvm-81b6a174112595ac211ce17441a0ede03d505e7d.tar.bz2 |
Deepen the map structure tablegen uses to compute FastISel patterns, in preparation for having patterns
with return types that differ from their input types. This is not yet used.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@55344 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'utils')
-rw-r--r-- | utils/TableGen/FastISelEmitter.cpp | 115 |
1 files changed, 61 insertions, 54 deletions
diff --git a/utils/TableGen/FastISelEmitter.cpp b/utils/TableGen/FastISelEmitter.cpp index f730f1d..bd0fc13 100644 --- a/utils/TableGen/FastISelEmitter.cpp +++ b/utils/TableGen/FastISelEmitter.cpp @@ -182,10 +182,11 @@ void FastISelEmitter::run(std::ostream &OS) { OS << "\n"; typedef std::map<std::string, InstructionMemo> PredMap; - typedef std::map<MVT::SimpleValueType, PredMap> TypePredMap; - typedef std::map<std::string, TypePredMap> OpcodeTypePredMap; - typedef std::map<OperandsSignature, OpcodeTypePredMap> OperandsOpcodeTypePredMap; - OperandsOpcodeTypePredMap SimplePatterns; + typedef std::map<MVT::SimpleValueType, PredMap> RetPredMap; + typedef std::map<MVT::SimpleValueType, RetPredMap> TypeRetPredMap; + typedef std::map<std::string, TypeRetPredMap> OpcodeTypeRetPredMap; + typedef std::map<OperandsSignature, OpcodeTypeRetPredMap> OperandsOpcodeTypeRetPredMap; + OperandsOpcodeTypeRetPredMap SimplePatterns; // Scan through all the patterns and record the simple ones. for (CodeGenDAGPatterns::ptm_iterator I = CGP.ptm_begin(), @@ -243,24 +244,24 @@ void FastISelEmitter::run(std::ostream &OS) { Pattern.getDstPattern()->getOperator()->getName(), DstRC }; - assert(!SimplePatterns[Operands][OpcodeName][VT].count(PredicateCheck) && + assert(!SimplePatterns[Operands][OpcodeName][VT][VT].count(PredicateCheck) && "Duplicate pattern!"); - SimplePatterns[Operands][OpcodeName][VT][PredicateCheck] = Memo; + SimplePatterns[Operands][OpcodeName][VT][VT][PredicateCheck] = Memo; } // Declare the target FastISel class. OS << "class FastISel : public llvm::FastISel {\n"; - for (OperandsOpcodeTypePredMap::const_iterator OI = SimplePatterns.begin(), + for (OperandsOpcodeTypeRetPredMap::const_iterator OI = SimplePatterns.begin(), OE = SimplePatterns.end(); OI != OE; ++OI) { const OperandsSignature &Operands = OI->first; - const OpcodeTypePredMap &OTM = OI->second; + const OpcodeTypeRetPredMap &OTM = OI->second; - for (OpcodeTypePredMap::const_iterator I = OTM.begin(), E = OTM.end(); + for (OpcodeTypeRetPredMap::const_iterator I = OTM.begin(), E = OTM.end(); I != E; ++I) { const std::string &Opcode = I->first; - const TypePredMap &TM = I->second; + const TypeRetPredMap &TM = I->second; - for (TypePredMap::const_iterator TI = TM.begin(), TE = TM.end(); + for (TypeRetPredMap::const_iterator TI = TM.begin(), TE = TM.end(); TI != TE; ++TI) { MVT::SimpleValueType VT = TI->first; @@ -312,63 +313,69 @@ void FastISelEmitter::run(std::ostream &OS) { OS << "\n"; // Now emit code for all the patterns that we collected. - for (OperandsOpcodeTypePredMap::const_iterator OI = SimplePatterns.begin(), + for (OperandsOpcodeTypeRetPredMap::const_iterator OI = SimplePatterns.begin(), OE = SimplePatterns.end(); OI != OE; ++OI) { const OperandsSignature &Operands = OI->first; - const OpcodeTypePredMap &OTM = OI->second; + const OpcodeTypeRetPredMap &OTM = OI->second; - for (OpcodeTypePredMap::const_iterator I = OTM.begin(), E = OTM.end(); + for (OpcodeTypeRetPredMap::const_iterator I = OTM.begin(), E = OTM.end(); I != E; ++I) { const std::string &Opcode = I->first; - const TypePredMap &TM = I->second; + const TypeRetPredMap &TM = I->second; OS << "// FastEmit functions for " << Opcode << ".\n"; OS << "\n"; // Emit one function for each opcode,type pair. - for (TypePredMap::const_iterator TI = TM.begin(), TE = TM.end(); + for (TypeRetPredMap::const_iterator TI = TM.begin(), TE = TM.end(); TI != TE; ++TI) { MVT::SimpleValueType VT = TI->first; - const PredMap &PM = TI->second; - bool HasPred = false; + const RetPredMap &RM = TI->second; - OS << "unsigned FastISel::FastEmit_" - << getLegalCName(Opcode) - << "_" << getLegalCName(getName(VT)) << "_"; - Operands.PrintManglingSuffix(OS); - OS << "("; - Operands.PrintParameters(OS); - OS << ") {\n"; - - // Emit code for each possible instruction. There may be - // multiple if there are subtarget concerns. - for (PredMap::const_iterator PI = PM.begin(), PE = PM.end(); - PI != PE; ++PI) { - std::string PredicateCheck = PI->first; - const InstructionMemo &Memo = PI->second; + for (RetPredMap::const_iterator RI = RM.begin(), RE = RM.end(); + RI != RE; ++RI) { + const PredMap &PM = RI->second; + bool HasPred = false; + + OS << "unsigned FastISel::FastEmit_" + << getLegalCName(Opcode) + << "_" << getLegalCName(getName(VT)) << "_"; + Operands.PrintManglingSuffix(OS); + OS << "("; + Operands.PrintParameters(OS); + OS << ") {\n"; + + // Emit code for each possible instruction. There may be + // multiple if there are subtarget concerns. + for (PredMap::const_iterator PI = PM.begin(), PE = PM.end(); + PI != PE; ++PI) { + std::string PredicateCheck = PI->first; + const InstructionMemo &Memo = PI->second; - if (PredicateCheck.empty()) { - assert(!HasPred && "Multiple instructions match, at least one has " - "a predicate and at least one doesn't!"); - } else { - OS << " if (" + PredicateCheck + ")\n"; - OS << " "; - HasPred = true; + if (PredicateCheck.empty()) { + assert(!HasPred && + "Multiple instructions match, at least one has " + "a predicate and at least one doesn't!"); + } else { + OS << " if (" + PredicateCheck + ")\n"; + OS << " "; + HasPred = true; + } + OS << " return FastEmitInst_"; + Operands.PrintManglingSuffix(OS); + OS << "(" << InstNS << Memo.Name << ", "; + OS << InstNS << Memo.RC->getName() << "RegisterClass"; + if (!Operands.empty()) + OS << ", "; + Operands.PrintArguments(OS); + OS << ");\n"; } - OS << " return FastEmitInst_"; - Operands.PrintManglingSuffix(OS); - OS << "(" << InstNS << Memo.Name << ", "; - OS << InstNS << Memo.RC->getName() << "RegisterClass"; - if (!Operands.empty()) - OS << ", "; - Operands.PrintArguments(OS); - OS << ");\n"; + // Return 0 if none of the predicates were satisfied. + if (HasPred) + OS << " return 0;\n"; + OS << "}\n"; + OS << "\n"; } - // Return 0 if none of the predicates were satisfied. - if (HasPred) - OS << " return 0;\n"; - OS << "}\n"; - OS << "\n"; } // Emit one function for the opcode that demultiplexes based on the type. @@ -381,7 +388,7 @@ void FastISelEmitter::run(std::ostream &OS) { Operands.PrintParameters(OS); OS << ") {\n"; OS << " switch (VT) {\n"; - for (TypePredMap::const_iterator TI = TM.begin(), TE = TM.end(); + for (TypeRetPredMap::const_iterator TI = TM.begin(), TE = TM.end(); TI != TE; ++TI) { MVT::SimpleValueType VT = TI->first; std::string TypeName = getName(VT); @@ -411,7 +418,7 @@ void FastISelEmitter::run(std::ostream &OS) { Operands.PrintParameters(OS); OS << ") {\n"; OS << " switch (Opcode) {\n"; - for (OpcodeTypePredMap::const_iterator I = OTM.begin(), E = OTM.end(); + for (OpcodeTypeRetPredMap::const_iterator I = OTM.begin(), E = OTM.end(); I != E; ++I) { const std::string &Opcode = I->first; |