RFR(S): 8000831: Heap verification output incorrect/incomplete

Bengt Rutisson bengt.rutisson at oracle.com
Tue Oct 16 06:01:24 UTC 2012


Hi John,

On 2012-10-15 18:26, John Cuthbertson wrote:
> Hi Bengt,
>
> Thanks for looking at the code.
>
> I honestly don't know the answer to your question. As I said in my 
> earlier response to Ramki - I was surprised that all of the call sites 
> were passing false for the silent parameter. I can't remember if that 
> has always been the case. I'm also not sure if it always will be 
> either. My guess is that no one thought of using a global flag, or if 
> they did they reasoned that others may still want a finer grained 
> control.

OK. I was just wondering. I think your fix is fine for now.

Bengt

>
> Regards,
>
> JohnC
>
> On 10/15/12 06:30, Bengt Rutisson wrote:
>
>> Hi John,
>>
>> The changes look good to me.
>>
>> One kind of high level question. Why do we have a parameter and let 
>> every caller decide whether or not to print verbose output instead of 
>> having a flag to allow the user to turn it on and off on the command 
>> line? Seems more consistent with other log output to have a flag like 
>> PrintGCVerification or TraceGCVerification. A bit like the flag 
>> TraceProtectionDomainVerification does now.
>>
>> Bengt
>>
>> On 2012-10-13 01:22, John Cuthbertson wrote:
>>> Sending to the correct alias....
>>>
>>> Hi Everyone,
>>>
>>> Can I have a couple of volunteers review the fix for this CR - the 
>>> webrev can be found at: 
>>> http://cr.openjdk.java.net/~johnc/8000831/webrev.0/
>>>
>>> Summary:
>>> An earlier change inadvertently turned off part of the output of 
>>> heap verification:
>>>
>>> [Verifying threads syms strs zone dict hand C-heap code cache ]
>>> VerifyBeforeGC:4.619: [GC [PSYoungGen: 16896K->416K(19712K)] 
>>> 16896K->420K(62720K), 0.0170685 secs] [Times: user=0.02 sys=0.00, 
>>> real=0.02 secs]
>>> VerifyBeforeGC:5.013: [GC [PSYoungGen: 17312K->416K(19712K)] 
>>> 17316K->424K(62720K), 0.0125283 secs] [Times: user=0.02 sys=0.00, 
>>> real=0.01 secs]
>>> VerifyBeforeGC:5.239: [GC [PSYoungGen: 17312K->400K(19712K)] 
>>> 17320K->412K(62720K), 0.0586610 secs] [Times: user=0.04 sys=0.03, 
>>> real=0.06 secs]
>>> VerifyBeforeGC:5.439: [GC [PSYoungGen: 17296K->432K(36608K)] 
>>> 17308K->448K(79616K), 0.0167533 secs] [Times: user=0.02 sys=0.00, 
>>> real=0.02 secs]
>>> VerifyBeforeGC:5.721: [GC [PSYoungGen: 34224K->392K(38144K)] 
>>> 34240K->412K(81152K), 0.0909802 secs] [Times: user=0.05 sys=0.04, 
>>> real=0.09 secs]
>>> VerifyBeforeGC:6.034: [GC [PSYoungGen: 35720K->400K(69184K)] 
>>> 35740K->424K(112192K), 0.0344226 secs] [Times: user=0.04 sys=0.00, 
>>> real=0.03 secs]
>>> VerifyBeforeGC:6.709: [GC [PSYoungGen: 69136K->64K(69184K)] 
>>> 69160K->440K(112192K), 0.1976060 secs] [Times: user=0.10 sys=0.11, 
>>> real=0.20 secs]
>>>
>>> Previously it was:
>>>
>>> [Verifying threads syms strs zone dict hand C-heap code cache ]
>>> VerifyBeforeGC:[Verifying threads permanent tenured eden syms strs 
>>> zone dict hand C-heap code cache ]
>>> 4.818: [GC [PSYoungGen: 16896K->392K(19712K)] 16896K->396K(62720K), 
>>> 0.0244147 secs] [Times: user=0.02 sys=0.00, real=0.02 secs]
>>> VerifyBeforeGC:[Verifying threads permanent tenured eden syms strs 
>>> zone dict hand C-heap code cache ]
>>> 5.087: [GC [PSYoungGen: 17288K->392K(19712K)] 17292K->400K(62720K), 
>>> 0.0597174 secs] [Times: user=0.04 sys=0.03, real=0.06 secs]
>>> VerifyBeforeGC:[Verifying threads permanent tenured eden syms strs 
>>> zone dict hand C-heap code cache ]
>>> 5.410: [GC [PSYoungGen: 17288K->400K(19712K)] 17296K->412K(62720K), 
>>> 0.0173056 secs] [Times: user=0.02 sys=0.00, real=0.02 secs]
>>> VerifyBeforeGC:[Verifying threads permanent tenured eden syms strs 
>>> zone dict hand C-heap code cache ]
>>> 5.595: [GC [PSYoungGen: 17296K->400K(36608K)] 17308K->416K(79616K), 
>>> 0.0134239 secs] [Times: user=0.02 sys=0.00, real=0.01 secs]
>>>
>>> The changes restore the previous output for the affected collectors.
>>>
>>> Testing:
>>> GCBasher with VerifyBeforeGC, VerifyAfterGC, VerifyDuringGC with 
>>> serial, parallel, concurrent, and G1 collectors.
>>>
>>> Thanks,
>>>
>>> JohnC
>>
>




More information about the hotspot-gc-dev mailing list