RFR: 8323220: Reassociate loop invariants involved in Cmps and Add/Subs [v10]
Joshua Cao
duke at openjdk.org
Fri Feb 16 08:48:00 UTC 2024
On Fri, 16 Feb 2024 07:29:16 GMT, Emanuel Peter <epeter at openjdk.org> wrote:
>> Joshua Cao 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:
>>
>> - Update test to utilize @setup method for arguments
>> - Merge branch 'master' into licm
>> - Add correctness test for some random tests with random inputs
>> - Add some correctness tests where we do reassociate
>> - Remove unused TestInfo parameter. Have some tests exit mid-loop.
>> - Merge branch 'master' into licm
>> - Small fixes and add check methods for tests
>> - reassociate_add_sub -> reassociate_add_sub_cmp
>> - Formatting and fix typo
>> - Assert for n2. Variables for n1/n2 opcode. More concise comments.
>> Overflow/random tests
>> - ... and 2 more: https://git.openjdk.org/jdk/compare/c715eb59...ad073ef2
>
> test/hotspot/jtreg/compiler/loopopts/InvariantCodeMotionReassociateCmp.java line 66:
>
>> 64: }
>> 65: // Setup inputs to be equals sometimes to avoid uncommon traps
>> 66: inv2 = inv1;
>
> You may want to use the `SetupInfo` instead, and make this deterministic. Just in the case where the randomness here fails in all cases - then you would not have any equal case.
> Also: why can `inv1` not be zero?
Sure, can look into `SetupInfo`.
`inv1` can be zero. I'll remove that block.
-------------
PR Review Comment: https://git.openjdk.org/jdk/pull/17375#discussion_r1492140006
More information about the hotspot-compiler-dev
mailing list