RFR(S): 8055153: nsk/stress/jck60/jck60014 crashes on sparc
Roland Westrelin
roland.westrelin at oracle.com
Tue Aug 19 18:00:16 UTC 2014
Thanks for the review, Vladimir & Igor.
Roland.
On Aug 19, 2014, at 7:47 PM, Igor Veresov <igor.veresov at oracle.com> wrote:
> Looks good.
>
> igor
>
> On Aug 19, 2014, at 8:41 AM, Roland Westrelin <roland.westrelin at oracle.com> wrote:
>
>> During macro expansion the control of LoadRange nodes is not set (same problem exists for LoadKlass nodes) allowing LoadRange nodes to float above a null check. The code in arraycopy macro expansion used to be executed at parse time where it was ok to not set the LoadRange control because the dependency on the null check is expressed there through a CastPP. Because macro expansion happens after CCP, CastPP nodes no longer exist in the IR when the LoadRange nodes are created, now. To fix this, I created the LoadRange (and LoadKlass) nodes when the ArrayCopyNode is created, during parsing. This way, there’s no need to set the control for the nodes (CCP will do it) and the compiler has a chance to use a previous LoadRange (or LoadKlass) and optimize it out. I found a problem in PhaseMacroExpand::copy_call_debug_info() when testing this change, where the JVMState can be shared between macro nodes and we can end up adjusting it several times.
>>
>> http://cr.openjdk.java.net/~roland/8055153/webrev.00/
>>
>> Roland.
>
More information about the hotspot-compiler-dev
mailing list