RFR: 8325495: C2: implement optimization for series of Add of unique value [v3]
Kangcheng Xu
kxu at openjdk.org
Fri Sep 20 19:54:19 UTC 2024
> This pull request resolves [JDK-8325495](https://bugs.openjdk.org/browse/JDK-8325495) by converting series of additions of the same operand into multiplications. I.e., `a + a + ... + a + a + a => n*a`.
>
> As an added benefit, it also converts `C * a + a` into `(C+1) * a` and `a << C + a` into `(2^C + 1) * a` (with respect to constant `C`). This is actually a side effect of IGVN being iterative: at converting the `i`-th addition, the previous `i-1` additions would have already been optimized to multiplication (and thus, further into bit shifts and additions/subtractions if possible).
>
> Some notable examples of this transformation include:
> - `a + a + a` => `a*3` => `(a<<1) + a`
> - `a + a + a + a` => `a*4` => `a<<2`
> - `a*3 + a` => `a*4` => `a<<2`
> - `(a << 1) + a + a` => `a*2 + a + a` => `a*3 + a` => `a*4 => a<<2`
>
> See included IR unit tests for more.
Kangcheng Xu has updated the pull request incrementally with six additional commits since the last revision:
- Merge pull request #2 from tabjy/arithmetic-canonicalization-v2
Arithmetic canonicalization v2
- remove unused variables
- remove debug printfs
- fix detecting optimized power-of-2 multiplication
- revert usage of integercon(): truncation during jlong to jint is intended
- implement rwestrel's changes, passing TestDigest
-------------
Changes:
- all: https://git.openjdk.org/jdk/pull/20754/files
- new: https://git.openjdk.org/jdk/pull/20754/files/c8fdb74c..30f119c5
Webrevs:
- full: https://webrevs.openjdk.org/?repo=jdk&pr=20754&range=02
- incr: https://webrevs.openjdk.org/?repo=jdk&pr=20754&range=01-02
Stats: 43 lines in 2 files changed: 12 ins; 1 del; 30 mod
Patch: https://git.openjdk.org/jdk/pull/20754.diff
Fetch: git fetch https://git.openjdk.org/jdk.git pull/20754/head:pull/20754
PR: https://git.openjdk.org/jdk/pull/20754
More information about the hotspot-compiler-dev
mailing list