[llvm-commits] [llvm] r118112 - /llvm/trunk/utils/TableGen/AsmMatcherEmitter.cpp
Chris Lattner
sabre at nondot.org
Tue Nov 2 16:18:43 PDT 2010
Author: lattner
Date: Tue Nov 2 18:18:43 2010
New Revision: 118112
URL: http://llvm.org/viewvc/llvm-project?rev=118112&view=rev
Log:
make MatchableInfo::Validate reject instructions (like LDR_PRE in ARM)
that have complicated tying going on.
Modified:
llvm/trunk/utils/TableGen/AsmMatcherEmitter.cpp
Modified: llvm/trunk/utils/TableGen/AsmMatcherEmitter.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/utils/TableGen/AsmMatcherEmitter.cpp?rev=118112&r1=118111&r2=118112&view=diff
==============================================================================
--- llvm/trunk/utils/TableGen/AsmMatcherEmitter.cpp (original)
+++ llvm/trunk/utils/TableGen/AsmMatcherEmitter.cpp Tue Nov 2 18:18:43 2010
@@ -638,6 +638,7 @@
"' not supported by asm matcher. Mark isCodeGenOnly!");
// Verify that any operand is only mentioned once.
+ // We reject aliases and ignore instructions for now.
if (Tok[0] == '$' && !OperandNames.insert(Tok).second) {
if (!Hack)
throw TGError(TheDef->getLoc(),
@@ -654,6 +655,33 @@
}
}
+ // Validate the operand list to ensure we can handle this instruction.
+ for (unsigned i = 0, e = OperandList.size(); i != e; ++i) {
+ const CGIOperandList::OperandInfo &OI = OperandList[i];
+
+ // Validate tied operands.
+ if (OI.getTiedRegister() != -1) {
+ // If we have a tied operand that consists of multiple MCOperands, reject
+ // it. We reject aliases and ignore instructions for now.
+ if (OI.MINumOperands != 1) {
+ if (!Hack)
+ throw TGError(TheDef->getLoc(),
+ "ERROR: tied operand '" + OI.Name +
+ "' has multiple MCOperands!");
+
+ // FIXME: Should reject these. The ARM backend hits this with $lane in a
+ // bunch of instructions. It is unclear what the right answer is.
+ DEBUG({
+ errs() << "warning: '" << InstrName << "': "
+ << "ignoring instruction with multi-operand tied operand '"
+ << OI.Name << "'\n";
+ });
+ return false;
+ }
+ }
+ }
+
+
return true;
}
@@ -1086,7 +1114,7 @@
// Start the enum, which we will generate inline.
- OS << "// Unified function for converting operants to MCInst instances.\n\n";
+ OS << "// Unified function for converting operands to MCInst instances.\n\n";
OS << "enum ConversionKind {\n";
// TargetOperandClass - This is the target's operand class, like X86Operand.
@@ -1153,11 +1181,8 @@
// from the earlier one.
int TiedOp = OpInfo.getTiedRegister();
if (TiedOp != -1) {
- // Copy the tied operand.
- // FIXME: What if the operand has multiple MINumOperands? This happens
- // in ARM.
- //assert(OpInfo.MINumOperands == 1);
-
+ // Copy the tied operand. We can only tie single MCOperand values.
+ assert(OpInfo.MINumOperands == 1 && "Not a singular MCOperand");
assert(i > unsigned(TiedOp) && "Tied operand preceeds its target!");
CaseOS << " Inst.addOperand(Inst.getOperand(" << TiedOp << "));\n";
Signature += "__Tie" + itostr(TiedOp);
More information about the llvm-commits
mailing list