RFR: 8350086: Inline hot Method accessors for faster task selection [v3]

Coleen Phillimore coleenp at openjdk.org
Fri Feb 14 18:38:18 UTC 2025


On Fri, 14 Feb 2025 15:12:50 GMT, Aleksey Shipilev <shade at openjdk.org> wrote:

>> These methods show up prominently on Leyden profiles, as compilation policy asks these properties for methods very often during compile task selection:
>>  - `Method::invocation_count`
>>  - `Method::backedge_count`
>>  - `Method::highest_comp_level`
>> 
>> We can move the definitions for these methods to method.inline.hpp to make them eligible for better inlining.
>> 
>> `interpreter_invocation_count()` method is a bit weird, looks like a leftover from [JDK-8251462](https://bugs.openjdk.org/browse/JDK-8251462). Removing it would prompt more cleanups and renamings in `ciMethod`, so I would leave it for future enhancement.
>> 
>> Additional testing: 
>>  - [x] Spot-checked Leyden profiles, methods are now fully inlined into hot `CompilerBroker` methods
>>  - [x] Ad-hoc Leyden benchmarks show minor improvements (< 1%) for time spent in compiler threads
>
> Aleksey Shipilev has updated the pull request incrementally with two additional commits since the last revision:
> 
>  - One more include for Minimal VM
>  - Turn declarations proper inline

This seems fine but at one point we were talking about moving what looks like the duplicated InvocationCounters from MethodCounters and use MDO instead.  I think this looks like it could be something to clean up.

-------------

Marked as reviewed by coleenp (Reviewer).

PR Review: https://git.openjdk.org/jdk/pull/23634#pullrequestreview-2618549865


More information about the hotspot-dev mailing list