mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-19 00:14:20 +00:00
[TableGen] Teach tablegen to allow SDNPCommutable nodes with more than 2 operands.
Summary: Tablegen already supports commutable instrinsics with more than 2 operands. There it just assumes the first two operands are commutable. I plan to use this to improve the generation of FMA patterns in the X86 backend. Reviewers: aymanmus, zvi, RKSimon, spatel, arsenm Reviewed By: arsenm Subscribers: arsenm, llvm-commits Differential Revision: https://reviews.llvm.org/D37430 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@312464 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
7f04a10c78
commit
911f6bba33
@ -3744,7 +3744,7 @@ static void GenerateVariantsOf(TreePatternNode *N,
|
||||
// If this node is commutative, consider the commuted order.
|
||||
bool isCommIntrinsic = N->isCommutativeIntrinsic(CDP);
|
||||
if (NodeInfo.hasProperty(SDNPCommutative) || isCommIntrinsic) {
|
||||
assert((N->getNumChildren()==2 || isCommIntrinsic) &&
|
||||
assert((N->getNumChildren()>=2 || isCommIntrinsic) &&
|
||||
"Commutative but doesn't have 2 children!");
|
||||
// Don't count children which are actually register references.
|
||||
unsigned NC = 0;
|
||||
@ -3772,9 +3772,14 @@ static void GenerateVariantsOf(TreePatternNode *N,
|
||||
for (unsigned i = 3; i != NC; ++i)
|
||||
Variants.push_back(ChildVariants[i]);
|
||||
CombineChildVariants(N, Variants, OutVariants, CDP, DepVars);
|
||||
} else if (NC == 2)
|
||||
CombineChildVariants(N, ChildVariants[1], ChildVariants[0],
|
||||
OutVariants, CDP, DepVars);
|
||||
} else if (NC == N->getNumChildren()) {
|
||||
std::vector<std::vector<TreePatternNode*> > Variants;
|
||||
Variants.push_back(ChildVariants[1]);
|
||||
Variants.push_back(ChildVariants[0]);
|
||||
for (unsigned i = 2; i != NC; ++i)
|
||||
Variants.push_back(ChildVariants[i]);
|
||||
CombineChildVariants(N, Variants, OutVariants, CDP, DepVars);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user