[12] RFR(S): 8215410: Regression test for JDK-8214994
Vladimir Kozlov
vladimir.kozlov at oracle.com
Fri Dec 14 18:24:00 UTC 2018
Looks good.
Thanks,
Vladimir
On 12/14/18 9:22 AM, Tobias Hartmann wrote:
> Hi,
>
> please review the following change that adds a regression test for 8214994 [1]:
> https://bugs.openjdk.java.net/browse/JDK-8215410
> http://cr.openjdk.java.net/~thartmann/8215410/webrev.00/
>
> The inner loop of test1 is found to be a counted loop and a loop limit check is added by updating
> the Opaque1 input of the predicate template:
>
> Predicate-If(Conv2B(Opaque1(Bool(CmpI(Phi(..))))))
>
> where the inner Phi represents the value of 'limit'. This Opaque1 node is then pushed upwards to
> before the predicates of the outer loop and ends up right after the second 'if (b)'. The code that
> does this was introduced by 8205515 [2] in JDK 11 b21 (which was a fix on top of 8203197):
> http://hg.openjdk.java.net/jdk/jdk/file/339d2fbe8675/src/hotspot/share/opto/loopnode.cpp#l4307
>
> Then the split-if optimization kicks in and splits the first predicate of the outer loop (which is
> an "obj != NULL" check) through the 'if (b)' region. We fail because the region contains an
> unexpected Opaque1 node.
>
> After a long discussion with Roland, I came to the conclusion that this bug was fixed by accident
> with JDK-8211451 [3] in JDK 12 b21. With the fix, loop limit checks no longer update the input of
> the Opaque1 node but insert a new predicate. I've therefore closed [1] as duplicate of [3] which
> should also be backported to JDK 11 and would like to integrate the regression test with this patch.
>
> Thanks,
> Tobias
>
> [1] https://bugs.openjdk.java.net/browse/JDK-8214994
> [2] https://bugs.openjdk.java.net/browse/JDK-8205515
> [3] https://bugs.openjdk.java.net/browse/JDK-8211451
>
More information about the hotspot-compiler-dev
mailing list