RFR: 8218733: SA: CollectedHeap provides broken implementation for used() and capacity()
Stefan Karlsson
stefan.karlsson at oracle.com
Thu Feb 14 09:10:50 UTC 2019
Thanks, Erik.
Stefank
On 2019-02-14 09:38, Erik Österlund wrote:
> Hi Stefan,
>
> Looks good.
>
> Thanks,
> /Erik
>
> On 2019-02-11 09:13, Stefan Karlsson wrote:
>> Hi all,
>>
>> Please review this patch to remove the broken implementation of
>> CollectedHeap used() and capacity() and instead force all GCs to
>> provide their own implementations.
>>
>> https://cr.openjdk.java.net/~stefank/8218733/webrev.01/
>> https://bugs.openjdk.java.net/browse/JDK-8218733
>>
>> This was found while running
>> serviceability/sa/TestHeapDumpForLargeArray.java on an experimental
>> implementation of heap dumping in ZGC.
>>
>> ZGC didn't provide a ZCollectedHeap.used() function and
>> CollectedHeap.used() was used instead at:
>> // Check weather we should dump the heap as segments
>> useSegmentedHeapDump = vm.getUniverse().heap().used() >
>> HPROF_SEGMENTED_HEAP_DUMP_THRESHOLD;
>>
>> Because of this we incorrectly did not use segmented heap dumps, and
>> therefore overflowed later in the code
>>
>> Aleksey and Roman,
>>
>> Could you verify that the implementation for Epsilon is correct? I
>> also haven't implemented capacity for Shenandoah, as the information
>> isn't trivially available in the ShenandoahHeap SA class. Do you want
>> to fix it as part of this patch, or should I create a separate RFE for
>> Shenandoah?
>>
>> Thanks,
>> StefanK
More information about the hotspot-gc-dev
mailing list