RFR: 8302673: [SuperWord] MaxReduction and MinReduction should vectorize for int [v3]
    Emanuel Peter 
    epeter at openjdk.org
       
    Thu Jun  1 10:33:10 UTC 2023
    
    
  
On Thu, 1 Jun 2023 09:15:45 GMT, Roberto Castañeda Lozano <rcastanedalo at openjdk.org> wrote:
>> The canonicalization of MinI/MaxI chains into right-spline graphs within `MinINode/MaxINode::Ideal()` inhibits the vectorization of reductions of these nodes. This changeset reworks `MinINode/MaxINode::Ideal()` to perform the same algebraic optimizations without the need for canonicalization, re-enabling auto-vectorization of MinI/MaxI reductions. This is achieved by handling all four permutations of the targeted Ideal subgraph induced by the commutativity of MinI/MaxI directly. The algorithm (for the MaxI case, the MinI case is analogous) tries to apply two Ideal graph rewrites in the following order, where `c0` and `c1` are constants and `MAX` is a compile-time operation:
>> 1. `max(x + c0, max(x + c1, z))` (or a permutation of it) to `max(x + MAX(c0, c1), z)`.
>> 2. `max(x + c0, x + c1)` (or a permutation of it) to `x + MAX(c0, c1)`.
>> 
>> Here is an example of the four permutations handled in step 1 with `x = RShiftI`, `c0 = 100` or `150`, `c1 = 150` or `100`, and `z = ConI (#int:200)`:
>> 
>> 
>> 
>> Here is an example of the two permutations handled in step 2 with `x = RShiftI`, `c0 = 10` or `11`, and `c1 = 11` or `10`:
>> 
>> 
>> 
>> The changeset implements `MinINode/MaxINode::Ideal()` in a common method `MaxNode::IdealI()`, since the algorithm is symmetric for both node types. The changeset also extends the existing MinI/MaxI Idealization tests with positive tests for all targeted permutations and negative tests, and adds a new test (contributed by @jbhateja) to assert that MinI/MaxI reductions are vectorized.
>> 
>> #### Testing
>> 
>> ##### Functionality
>> 
>> - tier1-5, stress test, fuzzing (windows-x64, linux-x64, linux-aarch64, macosx-x64, macosx-aarch64; release and debug mode).
>> 
>> ##### Performance
>> 
>> - Tested performance on a set of standard benchmark suites (DaCapo, SPECjbb2015, SPECjvm2008). No significant change was observed.
>
> Roberto Castañeda Lozano has updated the pull request incrementally with four additional commits since the last revision:
> 
>  - Complete test battery with remaining no-add cases
>  - Handle case without inner additions by restoring 'as_add_with_constant' to its previous state
>  - Add tests to exercise the case without inner additions
>  - Extract MinI/MaxI construction; pass around ConstAddOperands instead of individual components
Now it looks much cleaner, thanks for the new changes!
Thanks for the extra tests.
src/hotspot/share/opto/addnode.cpp line 1186:
> 1184:       Node* add_transformed = phase->transform(add_extracted);
> 1185:       Node* inner_other = inner_op->in(inner_add_index == 1 ? 2 : 1);
> 1186:       return build_min_max_int(add_transformed, inner_other, opcode == Op_MaxI);
Did something prevent you from directly using `MaxNode::build_min_max`?
-------------
Marked as reviewed by epeter (Committer).
PR Review: https://git.openjdk.org/jdk/pull/13924#pullrequestreview-1455132142
PR Review Comment: https://git.openjdk.org/jdk/pull/13924#discussion_r1212945144
    
    
More information about the hotspot-compiler-dev
mailing list