RFR(S): 8224580: Matcher can cause oop field/array element to be reloaded
Roman Kennke
rkennke at redhat.com
Mon Jun 3 08:01:41 UTC 2019
Hi Roland,
> Hi Dean,
>
> Thanks for looking at this.
>
>> It seems to do what you want, but I'm curious, what's the worse that can
>> happen if we call set_shared() on a node that doesn't need it?
>
> Some complex match rules wouldn't trigger anymore. Let's say we have
> (CmpN (LoadN ... and we erroneously call set_shared on the LoadN then
> this:
>
> instruct testN_mem(rFlagsReg cr, memory mem, immN0 zero)
> %{
> predicate(CompressedOops::base() != NULL);
> match(Set cr (CmpN (LoadN mem) zero));
>
> won't match and instead of a single instruction we would have a load
> instruction followed by a comparison.
>
> So worse case, correctness is not affected but code quality can be.
In general? Or only in offset==0 case?
Roman
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 833 bytes
Desc: OpenPGP digital signature
URL: <https://mail.openjdk.java.net/pipermail/hotspot-compiler-dev/attachments/20190603/0726b46a/signature.asc>
More information about the hotspot-compiler-dev
mailing list