C2 support for reference fields in value types
Tobias Hartmann
tobias.hartmann at oracle.com
Fri May 5 09:32:59 UTC 2017
Hi,
I updated the webrev to include tests for array fields in value types and fixed some minor issues:
http://cr.openjdk.java.net/~thartmann/valhalla/vt_prototype/webrev.15/
Thanks,
Tobias
On 04.05.2017 13:56, Tobias Hartmann wrote:
> Hi Roland,
>
> I refactored the changes in nmethod.cpp and fixed some other issues. JPRT now passes:
> http://cr.openjdk.java.net/~thartmann/valhalla/vt_prototype/webrev.15/
>
> I still need to disable the assert in ConstantPool::klass_at_impl(). In the long term, we need to find a better solution to get to the extended signature without (re-)resolving the call site in nmethod::preserve_callee_argument_oops(). I would like to push this version and then work on fixing the remaining issues.
>
> On 27.04.2017 17:57, Roland Westrelin wrote:
>> Instead of indirecting through the adapter to get the extended
>> signature, could you instead:
>>
>> - in gen_c2i_adapter() rather than build an OopMap with all registers,
>> construct one that only contains live oops
>>
>> - then make the gc code use that oop map, maybe by not going through
>> nmethod::preserve_callee_argument_oops() at all?
>
> I think that's not sufficient as we may not have an adapter frame on the stack but block while resolving the call in SharedRuntime::resolve_virtual_call_C().
>
> Thanks,
> Tobias
>
More information about the valhalla-dev
mailing list