RFR: 8340733: Add scope for relaxing constraint on JavaCalls from CompilerThread [v6]
duke
duke at openjdk.org
Fri Nov 1 12:59:32 UTC 2024
On Thu, 31 Oct 2024 12:38:17 GMT, Tomáš Zezula <duke at openjdk.org> wrote:
>> [JDK-8318694](https://bugs.openjdk.org/browse/JDK-8318694) limited the ability for JVMCI CompilerThreads to make Java upcalls. This is to mitigate against deadlock when an upcall does class loading. Class loading can easily create deadlock situations in -Xcomp or -Xbatch mode.
>>
>> However, for Truffle, upcalls are unavoidable if Truffle partial evaluation occurs as part of JIT compilation inlining. This occurs when the Graal inliner sees a constant Truffle AST node which allows a Truffle-specific inlining extension to perform Truffle partial evaluation (PE) on the constant. Such PE involves upcalls to the Truffle runtime (running in Java).
>>
>> This PR provides the escape hatch such that Truffle specific logic can put a compiler thread into "allow Java upcall" mode during the scope of the Truffle logic.
>
> Tomáš Zezula has updated the pull request incrementally with one additional commit since the last revision:
>
> Improved a comment in CompilerThread.
@tzezula
Your change (at version 7e0f1a4227f388dc8e22e6200dc026f056d26eed) is now ready to be sponsored by a Committer.
-------------
PR Comment: https://git.openjdk.org/jdk/pull/21285#issuecomment-2451829766
More information about the hotspot-compiler-dev
mailing list