* @remarks This would help us answer queries such as "a dom b?" in constant time.
* For example, if a dominated b, then Pre[a] < Pre[b] but Post[a] > Post[b]
*/
-void SsaBuilder::DomTreeWalk(BasicBlock* curBlock, BlkToBlkSetMap* domTree, int* preIndex, int* postIndex)
+void SsaBuilder::DomTreeWalk(BasicBlock* curBlock, BlkToBlkVectorMap* domTree, int* preIndex, int* postIndex)
{
JITDUMP("[SsaBuilder::DomTreeWalk] block %s:\n", curBlock->dspToString());
m_pDomPreOrder[curBlock->bbNum] = *preIndex;
++(*preIndex);
- BlkSet* pBlkSet;
- if (domTree->Lookup(curBlock, &pBlkSet))
+ BlkVector* domChildren = domTree->LookupPointer(curBlock);
+ if (domChildren != nullptr)
{
- for (BlkSet::KeyIterator ki = pBlkSet->Begin(); !ki.Equal(pBlkSet->End()); ++ki)
+ for (BasicBlock* child : *domChildren)
{
- if (curBlock != ki.Get())
+ if (curBlock != child)
{
- DomTreeWalk(ki.Get(), domTree, preIndex, postIndex);
+ DomTreeWalk(child, domTree, preIndex, postIndex);
}
}
}
*
*/
/* static */
-void SsaBuilder::ConstructDomTreeForBlock(Compiler* pCompiler, BasicBlock* block, BlkToBlkSetMap* domTree)
+void SsaBuilder::ConstructDomTreeForBlock(Compiler* pCompiler, BasicBlock* block, BlkToBlkVectorMap* domTree)
{
BasicBlock* bbIDom = block->bbIDom;
}
// If the bbIDom map key doesn't exist, create one.
- BlkSet* pBlkSet;
- if (!domTree->Lookup(bbIDom, &pBlkSet))
- {
- pBlkSet = new (domTree->GetAllocator()) BlkSet(domTree->GetAllocator());
- domTree->Set(bbIDom, pBlkSet);
- }
+ BlkVector* domChildren = domTree->Emplace(bbIDom, domTree->GetAllocator());
DBG_SSA_JITDUMP("Inserting BB%02u as dom child of BB%02u.\n", block->bbNum, bbIDom->bbNum);
// Insert the block into the block's set.
- pBlkSet->Set(block, true);
+ domChildren->push_back(block);
}
/**
*
*/
/* static */
-void SsaBuilder::ComputeDominators(Compiler* pCompiler, BlkToBlkSetMap* domTree)
+void SsaBuilder::ComputeDominators(Compiler* pCompiler, BlkToBlkVectorMap* domTree)
{
JITDUMP("*************** In SsaBuilder::ComputeDominators(Compiler*, ...)\n");
* @param domTree A map of (block -> set of blocks) tree representation that is empty.
*
*/
-void SsaBuilder::ComputeDominators(BasicBlock** postOrder, int count, BlkToBlkSetMap* domTree)
+void SsaBuilder::ComputeDominators(BasicBlock** postOrder, int count, BlkToBlkVectorMap* domTree)
{
JITDUMP("*************** In SsaBuilder::ComputeDominators(BasicBlock** postOrder, int count, ...)\n");
* @param domTree A map of (block -> set of blocks) tree representation.
*/
/* static */
-void SsaBuilder::DisplayDominators(BlkToBlkSetMap* domTree)
+void SsaBuilder::DisplayDominators(BlkToBlkVectorMap* domTree)
{
printf("After computing dominator tree: \n");
- for (BlkToBlkSetMap::KeyIterator nodes = domTree->Begin(); !nodes.Equal(domTree->End()); ++nodes)
+ for (BlkToBlkVectorMap::KeyIterator nodes = domTree->Begin(); !nodes.Equal(domTree->End()); ++nodes)
{
printf("BB%02u := {", nodes.Get()->bbNum);
-
- BlkSet* pBlkSet = nodes.GetValue();
- for (BlkSet::KeyIterator ki = pBlkSet->Begin(); !ki.Equal(pBlkSet->End()); ++ki)
+ int index = 0;
+ for (BasicBlock* child : nodes.GetValue())
{
- if (!ki.Equal(pBlkSet->Begin()))
- {
- printf(",");
- }
- printf("BB%02u", ki.Get()->bbNum);
+ printf("%sBB%02u", (index++ == 0) ? "" : ",", child->bbNum);
}
printf("}\n");
}
* and Destruction of Static Single Assignment Form."
*/
-void SsaBuilder::RenameVariables(BlkToBlkSetMap* domTree, SsaRenameState* pRenameState)
+void SsaBuilder::RenameVariables(BlkToBlkVectorMap* domTree, SsaRenameState* pRenameState)
{
JITDUMP("*************** In SsaBuilder::RenameVariables()\n");
AssignPhiNodeRhsVariables(block, pRenameState);
// Recurse with the block's DOM children.
- BlkSet* pBlkSet;
- if (domTree->Lookup(block, &pBlkSet))
+ BlkVector* domChildren = domTree->LookupPointer(block);
+ if (domChildren != nullptr)
{
- for (BlkSet::KeyIterator child = pBlkSet->Begin(); !child.Equal(pBlkSet->End()); ++child)
+ for (BasicBlock* child : *domChildren)
{
- DBG_SSA_JITDUMP("[SsaBuilder::RenameVariables](pushing dom child BB%02u)\n", child.Get()->bbNum);
- blocksToDo->push_back(BlockWork(child.Get()));
+ DBG_SSA_JITDUMP("[SsaBuilder::RenameVariables](pushing dom child BB%02u)\n", child->bbNum);
+ blocksToDo->push_back(BlockWork(child));
}
}
}
ComputeImmediateDom(postOrder, count);
// Compute the dominator tree.
- BlkToBlkSetMap* domTree = new (&m_allocator) BlkToBlkSetMap(&m_allocator);
+ BlkToBlkVectorMap* domTree = new (&m_allocator) BlkToBlkVectorMap(&m_allocator);
ComputeDominators(postOrder, count, domTree);
EndPhase(PHASE_BUILD_SSA_DOMS);
// Using IDom of each basic block, compute the whole domTree. If a block "b" has IDom "i",
// then, block "b" is dominated by "i". The mapping then is i -> { ..., b, ... }, in
// other words, "domTree" is a tree represented by nodes mapped to their children.
- static void ComputeDominators(Compiler* pCompiler, BlkToBlkSetMap* domTree);
+ static void ComputeDominators(Compiler* pCompiler, BlkToBlkVectorMap* domTree);
private:
// Ensures that the basic block graph has a root for the dominator graph, by ensuring
// as children.) Requires "preIndex" and "postIndex" to be initialized to 0 at entry into recursion.
// Computes arrays "m_pDomPreOrder" and "m_pDomPostOrder" of block indices such that the blocks of a
// "domTree" are in pre and postorder respectively.
- void DomTreeWalk(BasicBlock* curBlock, BlkToBlkSetMap* domTree, int* preIndex, int* postIndex);
+ void DomTreeWalk(BasicBlock* curBlock, BlkToBlkVectorMap* domTree, int* preIndex, int* postIndex);
#endif
- // Requires all blocks to have computed "bbIDom." Requires "domTree" to be a preallocated BlkToBlkSetMap.
+ // Requires all blocks to have computed "bbIDom." Requires "domTree" to be a preallocated BlkToBlkVectorMap.
// Helper to compute "domTree" from the pre-computed bbIDom of the basic blocks.
- static void ConstructDomTreeForBlock(Compiler* pCompiler, BasicBlock* block, BlkToBlkSetMap* domTree);
+ static void ConstructDomTreeForBlock(Compiler* pCompiler, BasicBlock* block, BlkToBlkVectorMap* domTree);
// Requires "postOrder" to hold the blocks of the flowgraph in topologically sorted order. Requires
// count to be the valid entries in the "postOrder" array. Computes "domTree" as a adjacency list
// like object, i.e., a set of blocks with a set of blocks as children defining the DOM relation.
- void ComputeDominators(BasicBlock** postOrder, int count, BlkToBlkSetMap* domTree);
+ void ComputeDominators(BasicBlock** postOrder, int count, BlkToBlkVectorMap* domTree);
#ifdef DEBUG
// Display the dominator tree.
- static void DisplayDominators(BlkToBlkSetMap* domTree);
+ static void DisplayDominators(BlkToBlkVectorMap* domTree);
#endif // DEBUG
// Compute flow graph dominance frontiers.
// Requires "domTree" to be the dominator tree relation defined by a DOM b.
// Requires "pRenameState" to have counts and stacks at their initial state.
// Assigns gtSsaNames to all variables.
- void RenameVariables(BlkToBlkSetMap* domTree, SsaRenameState* pRenameState);
+ void RenameVariables(BlkToBlkVectorMap* domTree, SsaRenameState* pRenameState);
// Requires "block" to be any basic block participating in variable renaming, and has at least a
// definition that pushed a ssa number into the rename stack for a variable. Requires "pRenameState"