mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-25 10:27:04 +00:00 
			
		
		
		
	Revert r111394. It was too aggressive.
We must complete the DFS, otherwise we might miss needed phi-defs, and prematurely color live ranges with a non-dominating value. This is not a big deal since we get to color more of the CFG and the next mapValue call will be faster. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@111397 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
		| @@ -193,15 +193,6 @@ public: | ||||
|   NodeType *getPath(unsigned n) const { | ||||
|     return VisitStack[n].first.getPointer(); | ||||
|   } | ||||
|  | ||||
|   /// skipChildren - Skip all children of Node, assuming that Node is on the | ||||
|   /// current path. This allows more aggressive pruning than just skipping | ||||
|   /// children of the current node. | ||||
|   _Self& skipChildren(NodeType *Node) { | ||||
|     while (!VisitStack.empty() && **this != Node) | ||||
|       VisitStack.pop_back(); | ||||
|     return skipChildren(); | ||||
|   } | ||||
| }; | ||||
|  | ||||
|  | ||||
|   | ||||
| @@ -446,9 +446,9 @@ VNInfo *LiveIntervalMap::mapValue(const VNInfo *ParentVNI, SlotIndex Idx) { | ||||
|     } | ||||
|  | ||||
|     // No need to search the children, we found a dominating value. | ||||
|     // MBB is either the found dominating value, or the last phi-def we created. | ||||
|     // Either way, the children of MBB would be shadowed, so don't search them. | ||||
|     IDFI.skipChildren(MBB); | ||||
|     // FIXME: We could prune up to the last phi-def we inserted, need df_iterator | ||||
|     // for that. | ||||
|     IDFI.skipChildren(); | ||||
|   } | ||||
|  | ||||
|   // The search should at least find a dominating value for IdxMBB. | ||||
|   | ||||
		Reference in New Issue
	
	Block a user