RFR: 8283094: Add Ideal transformation: x + (con - y) -> (x - y) + con [v5]
Vladimir Kozlov
kvn at openjdk.java.net
Tue Mar 29 20:59:42 UTC 2022
On Tue, 29 Mar 2022 20:46:31 GMT, Zhiqiang Zang <duke at openjdk.java.net> wrote:
>> 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.
>
> Thanks for reviewing! That is indeed an interesting observation. I feel `con - y` could not be a loop increment so it should be sufficient to check `x` is not a loop induction variable?
I think we need to check `y`. For example:
for (int i = 0; i < 10000; i++) {
a[MAX - i] = b[MAX - i];
}
-------------
PR: https://git.openjdk.java.net/jdk/pull/7795
More information about the hotspot-compiler-dev
mailing list