RFR: 8038925: Java with G1 crashes in dump_instance_fields using jmap or jcmd without fullgc

Andreas Eriksson andreas.eriksson at oracle.com
Thu May 22 08:14:42 UTC 2014


OK, I'll remove it.

Thanks,
Andreas

On 2014-05-22 10:02, Bengt Rutisson wrote:
>
>
> Hi Andreas,
>
> On 5/21/14 2:05 PM, Andreas Eriksson wrote:
>> A new webrev is up:
>> http://cr.openjdk.java.net/~aeriksso/8038925/webrev.02/
>>
>> The test now verifies that no full GC has been done after doing the 
>> heap dump.
>> I also modified the test to not run if it for some reason is not 
>> using G1.
>
> Thanks for the update, Andreas.
>
> The test looks good except for the @run tag.
>
> @run main/othervm -Xms512m -Xmx1024m -XX:+UseG1GC 
> -XX:+ExplicitGCInvokesConcurrent TestG1ConcurrentGCHeapDump
>
> The problem is that more GC flags will be added when the test is run 
> in nightly testing. Some GC flags will conflict with UseG1GC. On the 
> other hand at some point UseG1GC will be one of the flags that is added.
>
> So, I think what you need to do is just remove "-XX:+UseG1GC" from the 
> @run tag. Then your test will report log "skipped" when it is run in 
> the nightly testing except for the nightly testing done with G1 where 
> it will actually do something.
>
> Bengt
>
>>
>> Regards,
>> Andreas
>>
>> On 2014-05-21 12:31, Bengt Rutisson wrote:
>>> On 5/21/14 12:12 PM, Andreas Eriksson wrote:
>>>> Hi Bengt, thanks for looking at this.
>>>>
>>>> I agree that verifying that no full GC has happened would be good.
>>>> One thing I see as problematic though, is what to do if a full GC 
>>>> has happened.
>>>> Should I make the test fail? Or is there some way to signal that 
>>>> the test was inconclusive / couldn't finish?
>>>
>>> Personally I would prefer to make the test fail. JTreg only has two 
>>> states, PASS or FAIL, and I think that if we allow it to pass we 
>>> might not notice if there is some change that makes the test always 
>>> get a full GC and then never actually testing anything.
>>>
>>> I don't think it will fail intermittently by getting full GCs. I 
>>> think the test is pretty stable. But I think it would be good to 
>>> have a way of noticing if it stops testing what it is supposed to test.
>>>
>>> (By the way, I would really like a "SKIPPED" state in JTreg but I 
>>> haven't had any luck pushing for that. I think it could be useful 
>>> for other things as well. There is for example no good reason for 
>>> your test to be run 4 times each night with the exact same binary. 
>>> But that is what happens since we can't say that we should skip this 
>>> test if we run with any other GC than G1.)
>>>
>>> Thanks,
>>> Bengt
>>>
>>>>
>>>> Regards,
>>>> Andreas
>>>>
>>>> On 2014-05-21 11:55, Bengt Rutisson wrote:
>>>>>
>>>>> Hi Andreas,
>>>>>
>>>>> The fix looks good.
>>>>>
>>>>> One comment about the test. It does not verify that no full GC 
>>>>> happens. The way the test is set up I guess that should not happen 
>>>>> and I am not sure it is worth the effort to add a check for it. 
>>>>> Just wanted to mention it if you want to make test more resilient 
>>>>> to future changes in the JVM that for some reason can trigger a 
>>>>> full GC for this test.
>>>>>
>>>>> I'm fine with leaving the test as it is.
>>>>>
>>>>> Thanks,
>>>>> Bengt
>>>>>
>>>>>
>>>>> On 5/20/14 4:26 PM, Andreas Eriksson wrote:
>>>>>> Hi,
>>>>>>
>>>>>> Could I have a review for this G1 jdk7 only fix please?
>>>>>> (There is a related problem in jdk8 and jdk9, where an assert can 
>>>>>> fail because of this problem. I have logged another bug for this.)
>>>>>>
>>>>>> Description:
>>>>>> Due to the marking cleanup reclaiming empty regions, and having 
>>>>>> stale references a crash can occur when doing a heap dump.
>>>>>> The code tries to do an is_klass check on the object, which 
>>>>>> crashes the VM.
>>>>>> The fix is to add an is_perm check before doing the check, since 
>>>>>> is_perm will do a bounds check on the oop and if it's in the perm 
>>>>>> gen we know it's safe to look at it since G1 only ever does full 
>>>>>> compactions of the perm gen.
>>>>>>
>>>>>> For more information, and a more in-depth analysis, please see 
>>>>>> the jira bug.
>>>>>>
>>>>>> http://cr.openjdk.java.net/~aeriksso/8038925/webrev.01/
>>>>>> https://bugs.openjdk.java.net/browse/JDK-8038925
>>>>>>
>>>>>> Regards,
>>>>>> Andreas
>>>>>
>>>>
>>>
>>
>

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://mail.openjdk.org/pipermail/hotspot-gc-dev/attachments/20140522/e7be2a5e/attachment.htm>


More information about the hotspot-gc-dev mailing list