RFR: 8352415: x86: Tighten up template interpreter method entry code
Aleksey Shipilev
shade at openjdk.org
Wed Mar 19 13:50:46 UTC 2025
Interpreter performance is the still important for faster startup, since it would carry application until compilers kick in. After looking at Leyden scenarios in Xint mode, I believe incremental improvements are possible in template interpreter to make it faster.
One of those improvements is tightening up method entry code. Profiling shows the hottest path in the whole ordeal for non-native methods is resolving the Java mirror to store the GC root for currently executing Method*. It involves 4-5 chained memory accesses, which incurs significant latency.
We can massage the code to reuse some memory accesses and also spread them out to allow more latency-hiding hardware mechanisms to kick in.
Additional testing:
- [x] Ad-hoc `-Xint` benchmarks
- [ ] Linux x86_64 server fastdebug, `all`
-------------
Commit messages:
- Fix
Changes: https://git.openjdk.org/jdk/pull/24114/files
Webrev: https://webrevs.openjdk.org/?repo=jdk&pr=24114&range=00
Issue: https://bugs.openjdk.org/browse/JDK-8352415
Stats: 27 lines in 1 file changed: 11 ins; 1 del; 15 mod
Patch: https://git.openjdk.org/jdk/pull/24114.diff
Fetch: git fetch https://git.openjdk.org/jdk.git pull/24114/head:pull/24114
PR: https://git.openjdk.org/jdk/pull/24114
More information about the hotspot-dev
mailing list