RFR(XS) 8193577: nsk/jvmti/IterateThroughHeap/filter-tagged fails with Graal in Xcomp mode
dean.long at oracle.com
dean.long at oracle.com
Wed Nov 28 23:16:30 UTC 2018
It sounds like the test could also fail with C2 if the fields are in a
virtual object that was eliminated. I'm OK with your fix, but I would
feel a little better if we only relaxed the check for Graal. I guess
you'd need to use the whitebox api for that.
dl
On 11/28/18 2:28 PM, Igor Veresov wrote:
> Oh, I haven’t understood your idea before pressing reply. Yes, we can
> match the objects by matching their shape, but it’s also not an exact
> solution prone to erroneous matches. Especially considering the
> iteration API does callbacks for the fields out of order - it does
> primitives, strings, arrays, in that order.
>
> There are also ways to make it fail with Graal that are not related to
> constant representation. Graal treats allocations as side effect free.
> So it’s possible to allocate something and then deopt to a point
> before the allocation and redo the allocation in the interpreter. In
> this case there are going to be multiple objects on the heap with only
> one of them being reachable.
>
> igor
>
>
>
>> On Nov 28, 2018, at 2:08 PM, Igor Veresov <igor.veresov at oracle.com
>> <mailto:igor.veresov at oracle.com>> wrote:
>>
>> I don’t think there is a way to identify an untagged object. There is
>> nothing that is passed in the callback to allow that.
>>
>> igor
>>
>>
>>> On Nov 28, 2018, at 1:32 PM, dean.long at oracle.com
>>> <mailto:dean.long at oracle.com> wrote:
>>>
>>> I'm guessing Graal creates Constant boxes of the individual fields
>>> and not of the test objects? If so, can't we fix the matching so
>>> that it checks that all fields of an object match? I guess that
>>> would mean moving the "expected" and "found" counts up from fields[]
>>> to objects_info[].
>>>
>>> dl
>>>
>>> On 11/28/18 1:13 PM, Igor Veresov wrote:
>>>> When doing heap iteration with JVMTI the way the object identity is
>>>> tracked is by tagging. This particular test checks if it can
>>>> observe an untagged object. Since there is no way to truly track
>>>> the identity of an untagged object the test validates the identity
>>>> by checking the value of the fields of such object. When being
>>>> compiled with Graal there are objects produced (such as Constant
>>>> boxes) that have field values that are equal to the expected values
>>>> for the fields in UntaggedClass. During the subsequent heap
>>>> iteration these objects are reported to the test and are treated as
>>>> if they were instances of UntaggedClass.
>>>>
>>>> The fix is to relax the test requirement and allow (for the
>>>> untagged case) the number of the object found during iteration to
>>>> be more than expected.
>>>>
>>>> Webrev: http://cr.openjdk.java.net/~iveresov/8193577/webrev.00/
>>>> JBS: https://bugs.openjdk.java.net/browse/JDK-8193577
>>>>
>>>> igor
>>>>
>>>>
>>>>
>>>
>>
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.openjdk.java.net/pipermail/serviceability-dev/attachments/20181128/9ad69e53/attachment.html>
More information about the serviceability-dev
mailing list