[9] RFR(S): 8130309: need to bailout cleanly if CompiledStaticCall::emit_to_interp_stub fails when codecache is out of space
Vladimir Kozlov
vladimir.kozlov at oracle.com
Mon Jul 27 17:29:21 UTC 2015
Use ciEnv()::current() instead of Compile::current()->env().
compile.cpp why special case for StressCodeBuffers?
Otherwise looks good.
Thanks,
Vladimir
On 7/27/15 7:36 AM, Tobias Hartmann wrote:
>
> On 27.07.2015 13:31, Roland Westrelin wrote:
>>>> Here is the new webrev:
>>>> http://cr.openjdk.java.net/~thartmann/8130309/webrev.02/
>>>
>>> CompiledStaticCall::emit_to_interp_stub() is compiler independent code. Shouldn’t the call be ciEnv::current()->record_failure() even if the method is only called from c2 (for now?)? (which is what Dean suggested as well I think)
>
> Right, I missed that and got confused because the method is guarded by "#ifdef COMPILER2" on Sparc.
>
>> Actually, why not have emit_to_interp_stub() returns an error and bail out from compilation in the caller?
>
> I changed 'emit_to_interpr_stub()' accordingly and now bail out from the caller if it fails. I also had to adapt the ppc code and the 'emit_trampoline_stub()' method on aarch64.
>
> I left the special handling of -XX:TraceJumps in the Sparc code since JDK-8132344 will fix it.
>
> Here is the new webrev:
> http://cr.openjdk.java.net/~thartmann/8130309/webrev.03/
>
> Thanks,
> Tobias
>
>>
>> Roland.
>>
More information about the hotspot-compiler-dev
mailing list