diff options
author | Evan Cheng <evan.cheng@apple.com> | 2009-06-26 05:59:16 +0000 |
---|---|---|
committer | Evan Cheng <evan.cheng@apple.com> | 2009-06-26 05:59:16 +0000 |
commit | c0ad80fd9edbbe41461a62d26585bd6263328b90 (patch) | |
tree | 0c5f618df36afcb1eb256a45eb139d98035c709a /utils/TableGen | |
parent | 0b0deab4648c3b5c3db9fbd4a7b1653be1e1b9cc (diff) | |
download | external_llvm-c0ad80fd9edbbe41461a62d26585bd6263328b90.zip external_llvm-c0ad80fd9edbbe41461a62d26585bd6263328b90.tar.gz external_llvm-c0ad80fd9edbbe41461a62d26585bd6263328b90.tar.bz2 |
Fix a CodeGenDAGPatterns bug. Check if top level predicates match when it's looking for duplicates.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@74276 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'utils/TableGen')
-rw-r--r-- | utils/TableGen/CodeGenDAGPatterns.cpp | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/utils/TableGen/CodeGenDAGPatterns.cpp b/utils/TableGen/CodeGenDAGPatterns.cpp index 839059d..6a7d305 100644 --- a/utils/TableGen/CodeGenDAGPatterns.cpp +++ b/utils/TableGen/CodeGenDAGPatterns.cpp @@ -2390,6 +2390,10 @@ void CodeGenDAGPatterns::GenerateVariants() { // Scan to see if an instruction or explicit pattern already matches this. bool AlreadyExists = false; for (unsigned p = 0, e = PatternsToMatch.size(); p != e; ++p) { + // Skip if the top level predicates do not match. + if (PatternsToMatch[i].getPredicates() != + PatternsToMatch[p].getPredicates()) + continue; // Check to see if this variant already exists. if (Variant->isIsomorphicTo(PatternsToMatch[p].getSrcPattern(), DepVars)) { DOUT << " *** ALREADY EXISTS, ignoring variant.\n"; |