RFR: 8339733: C2: some nodes can have incorrect control after do_range_check() [v4]
Christian Hagedorn
chagedorn at openjdk.org
Wed Sep 11 12:05:05 UTC 2024
On Wed, 11 Sep 2024 11:21:41 GMT, Roland Westrelin <roland at openjdk.org> wrote:
>> PhaseIdealLoop::do_range_check() sets the control of the new pre and
>> main limits to be the entry control of the pre loop but it eliminates
>> all conditions whose parameters are invariant in the main loop. Most
>> of the time they are also invariant in the pre loop but that's not
>> guaranteed. It does happen sometimes that those parameters are pinned
>> in the pre loop. In that case, PhaseIdealLoop::do_range_check() sets
>> wrong controls.
>>
>> This doesn't cause any issue today AFAICT.
>>
>> Also, this seems to be a typo in PhaseIdealLoop::insert_pre_post_loops():
>>
>>
>> pre_head->in(0)
>>
>>
>> is `pre_head`. I fixed that one too.
>
> Roland Westrelin has updated the pull request incrementally with two additional commits since the last revision:
>
> - Update src/hotspot/share/opto/loopTransform.cpp
>
> Co-authored-by: Christian Hagedorn <christian.hagedorn at oracle.com>
> - Update src/hotspot/share/opto/loopTransform.cpp
>
> Co-authored-by: Christian Hagedorn <christian.hagedorn at oracle.com>
That looks good to me, thanks!
-------------
Marked as reviewed by chagedorn (Reviewer).
PR Review: https://git.openjdk.org/jdk/pull/20908#pullrequestreview-2296682919
More information about the hotspot-compiler-dev
mailing list