Request for reviews (M): 7128355: assert(!nocreate) failed: Cannot build a phi for a block already parsed

Vladimir Kozlov vladimir.kozlov at oracle.com
Wed Jan 11 17:51:28 PST 2012


Updated changes.

http://cr.openjdk.java.net/~kvn/7128355/webrev.01

Don not common BoxLock nodes and avoid creating phis of boxes. During parsing 
replace new BoxLock node with old BoxLock node at merge points. Use as_BoxLock() 
  which checks that node is BoxLockNode instead of BoxLockNode::box_node(). Call 
box_node() node only after RA which may create spills of BoxLock nodes.

Vladimir

Vladimir Kozlov wrote:
> Tom Rodriguez wrote:
>> On Jan 10, 2012, at 4:52 PM, Vladimir Kozlov wrote:
>>
>>> Tom Rodriguez wrote:
>>>> On Jan 10, 2012, at 3:36 PM, Vladimir Kozlov wrote:
>>>>> http://cr.openjdk.java.net/~kvn/7128355/webrev
>>>>>
>>>>> 7128355: assert(!nocreate) failed: Cannot build a phi for a block 
>>>>> already parsed
>>>> Doesn't that break nested lock elimination?
>>> Possible but rare since merged boxes are rare cases.
>>
>> But it would still be a bug wouldn't it?  Nested lock elimination is 
>> relying on the BoxLock identity to eliminate the useless operations 
>> for some locking region.
> 
> Why it is bug? It is only opportunity lost: nested lock will not be 
> eliminated if Box is marked as commoned.
> 
> But I agree with you, the logic become too complex. I will try to 
> replace Phi with Box node after Parse and add checks to make sure such 
> phis are not created during optimizations. I will not common boxes in 
> new code. But I want to keep EliminateNestedLocks flags to be able 
> restore previous behavior.
> 
> Thanks,
> Vladimir
> 
>>
>> I think the rules for the box lock are way too complicated after these 
>> changes.  The commoning behaviour shouldn't be conditional on 
>> EliminateNestedLocks so that we can settle on some standard set of 
>> rules for how they operate.  I think BoxLockNodes should never common 
>> and any Phi of BoxLocks should simplify into a single set BoxLock.  
>> This could be done with specific logic in PhiNode::Ideal that replaces 
>> any Phi with a single BoxLock during IGVN.  We'll have to make sure we 
>> reprocess them after parse but that doesn't seem that hard.  I think 
>> we want to maintain the invariant that after parse there aren't any 
>> Phi's of BoxLock.  That's a good rule.
>>
>> tom
>>
>>> It does not affect normal case when Box node is unique for nested 
>>> lock region. The failure I see is OSR compilations of nested loop 
>>> inside synchronized scope and compilations of irreducible loops. The 
>>> scenario where nested lock elimination will be broken is when during 
>>> first locks nodes elimination (after EA) Box node was commoned 
>>> because it has Phi user but later after CCP that Phi could be 
>>> eliminated so Box could became unique. I thought about doing box 
>>> commoning only after all optimizations done. But I concern that 
>>> during first locks elimination after EA not all safepoints will be 
>>> patched.
>>>
>>>> Two unrelated boxes that happened to participate in different Phis 
>>>> could end up commoned together wouldn't they?  Don't you want to 
>>>> perform explicit Phi simplification instead, replacing the Phi and 
>>>> all other boxes with one of the boxes feeding the Phi?
>>> For eliminating locks of non escaped objects it does not matter that 
>>> unrelated Boxes are commoned - it worked before. And I want this 
>>> because it allows to find all related safepoints. Consider case of 
>>> different lock regions of the same non escaped object.
>>>
>>> Thanks,
>>> Vladimir
>>>
>>>> tom
>>>>> Tested with full CTW and compiler regression tests.
>>>>>
>>>>> Thanks,
>>>>> Vladimir
>>


More information about the hotspot-compiler-dev mailing list