assertion in ciTypeFlow OSR'ing in finally clause

Vladimir Kozlov vladimir.kozlov at oracle.com
Mon Feb 17 11:34:30 PST 2014


Hi Goetz,

Do you have a simple test case? It would be nice to have it in VM regression tests as part of changes.
I would suggest to bail out from compilation immediately and leave asserts as they are. It looks like a corner case 
which I see for the first time.
But before that, can you check that there is no issue in RPO blocks ordering in ciTypeFlow?

Regards,
Vladimir

On 2/17/14 5:56 AM, Lindenmaier, Goetz wrote:
> Hi,
>
> I get an assertion in ciTypeFlow running the ppc port with DeotimizeALot.
>
> It tries to osr-compile a method at a bytecode in a finally clause.
>
> As far as I understand the assertion is too strict.
>
> The initial assertion is
>
>    #  Internal Error (/sapmnt/home1/d045726/oJ/raw-2-stage-hotspot/src/share/vm/ci/ciTypeFlow.cpp:218), pid=7287,
> tid=4398488891968
>
>    #  assert(return_address->is_return_address()) failed: verify: wrong type
>
> This happens because a block in the finally clause is analyzed while not
>
> both predecessor blocks have been looked at.  Thus the join of the
>
> slots that should contain the return address yields bottom, and the assertion
>
> fires.
>
> To get the dbg build passing, I have to remove 5 assertions:
>
> ciTypeFlow.cpp:195  assert(false, "verify: returning from invalid subroutine");
>
> ciTypeFlow.cpp:218  assert(return_address->is_return_address(), "verify: wrong type");
>
> ciTypeFlow.cpp:812  assert(address->is_return_address(), "bad return address");
>
> ciTypeFlow.cpp:1758 assert(return_address->is_return_address(), "verify: wrong type");
>
> ciMetadata.hpp:83  assert(is_return_address(), "bad cast");
>
> If I remove these, compilation is aborted a bit later with the message:
>
> “COMPILE SKIPPED: OSR starts with non-empty stack (not retryable)”
>
> I wonder whether I should fix this by adapting the assertions, or
>
> whether I should abort the compilation right away.
>
> I would appreciate some comments on this issue!
>
> Best regards,
>
>    Goetz.
>


More information about the ppc-aix-port-dev mailing list