RFR(S): 8161379: @CallerSensitive methods should be forcefully inlined to get Reflection.getCallerClass optimization
Christian Thalinger
cthalinger at twitter.com
Sat Jul 16 02:17:17 UTC 2016
Why are you not setting the _force_inline bit on @CallerSensitive? It would be less intrusive and more global so other compilers would pick it up as well.
> On Jul 15, 2016, at 2:12 PM, Claes Redestad <claes.redestad at oracle.com> wrote:
>
> Hi,
>
> Aleksey and I would like to contribute this patch which change the
> inlining policy to treat @CallerSensitive as it would
> @ForceSensitive.
>
> Bug: https://bugs.openjdk.java.net/browse/JDK-8161379
> Webrev: http://cr.openjdk.java.net/~redestad/8161379/webrev.01/
>
> The issue is that the JNI call behind Reflection.getCallerClass() is
> very expensive compared to the C2 intrinsic. This shows up in various
> microbenchmarks stress-testing reflection, method handle lookup etc,
> and can be linked to a number of intermittent regressions we see appear
> in various benchmarks.
>
> See the bug for more information.
>
> Testing: JPRT -testset hotspot, RBT hotspot-nightly-compiler
>
> Thanks!
>
> /Claes
More information about the hotspot-compiler-dev
mailing list