RFR: 8283094: Add Ideal transformation: x + (con - y) -> (x - y) + con [v5]
Vladimir Kozlov
kvn at openjdk.java.net
Tue Mar 29 17:26:44 UTC 2022
On Fri, 25 Mar 2022 21:16:03 GMT, Zhiqiang Zang <duke at openjdk.java.net> wrote:
>> Hello,
>>
>> `x + (con - y) -> (x - y) + con` is a widely seen pattern; however it is missing in current implementation, which prevents some obvious constant folding from happening, such as `x + (1 - y) + 2` will be not optimized at all, rather than into `x - y + 3`.
>>
>> This pull request adds this transformation.
>
> Zhiqiang Zang has updated the pull request with a new target base due to a merge or a rebase. The pull request now contains six commits:
>
> - Merge master.
> - rename test cases.
> - move tests to existing test classes.
> - comment out "x+(0-y)" -> "(x-y)" and "(0-y)+x" -> "(x-y)" because they
> are covered already.
> - Merge master.
> - include transformation from (con - y) + x into (x - y) + con and x + (con - y) into (x - y) + con.
src/hotspot/share/opto/addnode.cpp line 314:
> 312: // Convert x + (con - y) into "(x - y) + con"
> 313: if (op2 == Op_Sub(bt) && in2->in(1)->Opcode() == Op_ConIL(bt)) {
> 314: return AddNode::make(phase->transform(SubNode::make(in1, in2->in(2), bt)), in2->in(1), bt);
Both of proposed transformations are similar one in `AddNode::Ideal()` lines 181-214.
There is exception there to avoid transformation if (y+con) could be increment for loop's variable. I wonder if we need the same check here.
-------------
PR: https://git.openjdk.java.net/jdk/pull/7795
More information about the hotspot-compiler-dev
mailing list