RFR: 8332442: C2: refactor Mod cases in Compile::final_graph_reshaping_main_switch() [v6]

Jasmine Karthikeyan jkarthikeyan at openjdk.org
Wed Sep 11 20:12:08 UTC 2024


On Wed, 11 Sep 2024 15:57:29 GMT, Kangcheng Xu <kxu at openjdk.org> wrote:

>> Hello all. This patch addresses [JDK-8332442](https://bugs.openjdk.org/browse/JDK-8332442) and refactors `Op_ModI`/`Op_ModL`/`Op_UModI`/`Op_UModL` cases in `DIVMOD` transforamtions. The purpose of the transformation to convert adjacent div `/`  and mod `%` operations of the same operands into one should the platform support this feature (e.g., x86-64).
>> 
>> I took the liberty adding _signed_ DIVMOD nodes (i.e., `DIV_MOD_I` and `DIV_MOD_L`) to the `IRNode` class constants as they are previously missing. Please let me know if they were left intentionally and if there are any other concerns. Thanks!
>> 
>> ~This will be a draft PR before GHA tests are confirmed passing.~
>
> Kangcheng Xu has updated the pull request with a new target base due to a merge or a rebase. The incremental webrev excludes the unrelated changes brought in by the merge/rebase. The pull request contains 12 additional commits since the last revision:
> 
>  - Merge branch 'openjdk:master' into refactor-mod-cases
>  - improve formatting, nullptr comparison, update test flags, use custom @Run tests
>  - allow one div on platforms without hardware divmod
>  - remove platform restriction
>  - Merge branch 'openjdk:master' into refactor-mod-cases
>  - include aarch64 in tests, add more configuration combinations
>  - remove redundant arguments, test with -XX:-UseDivMod
>  - Merge branch 'master' into refactor-mod-cases
>  - Add test and IRNode for signed int/long divmod
>  - created IR tests
>  - ... and 2 more: https://git.openjdk.org/jdk/compare/bf2d8c7b...fe7b82ef

src/hotspot/share/opto/compile.cpp line 3181:

> 3179:     n->subsume_by(divmod->mod_proj(), this);
> 3180:   } else {
> 3181:     // replace "a % b" with "a - ((a / b) *b)"

Suggestion:

    // Replace "a % b" with "a - ((a / b) * b)"

test/hotspot/jtreg/compiler/c2/TestDivModNodes.java line 33:

> 31: /*
> 32:  * @test
> 33:  * @summary Test that DIV and MOD nodes are converted into DIVMOD where possible

I think you're missing `@bug 8332442` here.

test/hotspot/jtreg/compiler/c2/TestDivModNodes.java line 68:

> 66:     private static void runSignedIntDivMod() {
> 67:         int dividend = RANDOM.nextInt();
> 68:         int divisor = RANDOM.nextInt();

Since `nextInt()` can return 0, this might lead to a very rare test failure since div/mod by 0 results in an `ArithmeticException`. You could do `divisor = (divisor == 0) ? 1 : divisor` to avoid that, like we do in the other division idealization tests:
https://github.com/openjdk/jdk/blob/51b85a1f692fed7a66bdc0fae21438a60aafe7c2/test/hotspot/jtreg/compiler/c2/irTests/DivINodeIdealizationTests.java#L45-L46

-------------

PR Review Comment: https://git.openjdk.org/jdk/pull/20877#discussion_r1755363063
PR Review Comment: https://git.openjdk.org/jdk/pull/20877#discussion_r1755371635
PR Review Comment: https://git.openjdk.org/jdk/pull/20877#discussion_r1755392758


More information about the hotspot-compiler-dev mailing list