LRB midpath code quality
Roman Kennke
rkennke at redhat.com
Wed Mar 6 09:44:29 UTC 2019
In case you want to see or experiment with it:
http://cr.openjdk.java.net/~rkennke/streamline-lrb-midpath/streamline-lrb-midpath.patch
hotspot_gc_shenandoah seems fine without the cloned null-check. Will
also run all of specjvm before RFRing.
Roland, WDYT?
Roman
> On 3/6/19 10:34 AM, Roman Kennke wrote:
>>>>> Well yes, an implicit null-check would be good. It would never fire,
>>>>> because if the value is null, it would blow up earlier in the cset
>>>>> check. Or am I missing something?
>>>>
>>>> I suppose PhaseCFG::implicit_null_check() doesn't recognize the barrier
>>>> load as a candidate for implicit null checks for some reason.
>>>
>>> Yes, maybe.
>>>
>>> But can you explain to me why it should be needed at all? If a
>>> dominating (implicit?) null-check before the in-cset-check should catch
>>> all nulls on that path already? Why does it matter?
>>
>> Also, I don't think we want to generate an NPE/SEGV on that path. We
>> want to skip a bunch of stuff if the value is NULL.
>
> We might just back-branch to the access, no? And let NPE be handled there?
>
> In here:
> https://paste.fedoraproject.org/paste/nMZb19apbJq0uOB9CboUOA
>
> This branch:
>
> 0x00007f46f04b9272: test %rax,%rax
> 0x00007f46f04b9275: je 0x00007f46f04b9294
>
> ...can just go to where every other branch is going:
>
> 0x00007f46f04b9247: movl $0x2a,0x20(%rax)
> ; implicit exception: dispatches to 0x00007f46f04b9294
>
> -Aleksey
>
More information about the shenandoah-dev
mailing list