summaryrefslogtreecommitdiff
path: root/utils/TableGen/CodeGenDAGPatterns.cpp
diff options
context:
space:
mode:
authorJakob Stoklund Olesen <stoklund@2pi.dk>2012-08-24 21:08:09 +0000
committerJakob Stoklund Olesen <stoklund@2pi.dk>2012-08-24 21:08:09 +0000
commitaaaecfce70c0aaed9225359fc56c67b59dca768e (patch)
tree0306451f1b6a14f517b7b92bf1945dd58b970940 /utils/TableGen/CodeGenDAGPatterns.cpp
parent0745b649ed5c362f1c2f7db59254a76041ddef05 (diff)
downloadllvm-aaaecfce70c0aaed9225359fc56c67b59dca768e.tar.gz
llvm-aaaecfce70c0aaed9225359fc56c67b59dca768e.tar.bz2
llvm-aaaecfce70c0aaed9225359fc56c67b59dca768e.tar.xz
Stop inferring isVariadic from instruction patterns.
Instructions are now only marked as variadic if they use variable_ops in their ins list. A variadic SDNode is typically used for call nodes that have the call arguments as operands. A variadic MachineInstr can actually encode a variable number of operands, for example ARM's stm/ldm instructions. A call instruction does not have to be variadic. The call argument registers are added as implicit operands. This change remove the MCID::Variadic flags from most call and return instructions, allowing us to better verify their operands. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@162599 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'utils/TableGen/CodeGenDAGPatterns.cpp')
-rw-r--r--utils/TableGen/CodeGenDAGPatterns.cpp6
1 files changed, 5 insertions, 1 deletions
diff --git a/utils/TableGen/CodeGenDAGPatterns.cpp b/utils/TableGen/CodeGenDAGPatterns.cpp
index 2e4ec67d54..7512ae8a25 100644
--- a/utils/TableGen/CodeGenDAGPatterns.cpp
+++ b/utils/TableGen/CodeGenDAGPatterns.cpp
@@ -2502,7 +2502,11 @@ static bool InferFromPattern(CodeGenInstruction &InstInfo,
// These flags are silently added without any verification.
InstInfo.isBitcast |= PatInfo.isBitcast;
- InstInfo.Operands.isVariadic |= PatInfo.isVariadic;
+
+ // Don't infer isVariadic. This flag means something different on SDNodes and
+ // instructions. For example, a CALL SDNode is variadic because it has the
+ // call arguments as operands, but a CALL instruction is not variadic - it
+ // has argument registers as implicit, not explicit uses.
return Error;
}