RFR(M): 8248401: Refactor/unify RMI gc support functionality
Albert Yang
albert.m.yang at oracle.com
Fri Aug 7 11:28:12 UTC 2020
Thank you; the new patch looks good to me.
On 2020-08-07 13:22, Thomas Schatzl wrote:
> Hi Albert,
>
> thanks for your review.
>
> On 07.08.20 12:22, Albert Yang wrote:
>> Hi,
>>
>> The patch looks good to me; some small comments/suggestions.
>>
>> The comment for `millis_since_last_whole_heap_examined` seems
>> incorrect; it should be "the whole heap" not "any patr of the heap".
>> ```
>> // Returns the longest time (in ms) that has elapsed since the last
>> // time that any part of the heap was examined by a garbage
>> collection.
>> ```
>
> You are right. I meant it as "all parts of the heap".
>
>>
>> The name, `next_whole_heap_examined`, doesn't sound quite right.
>> (It's not obvious to me what that function does from its name.) Maybe
>> `record_whole_heap_examined_timestamp`?
>
> Done.
>
>>
>> I think it's best to call `next_whole_heap_examined` at the end of
>> `PSParallelCompact::post_compact()`, just like before this patch.
>
> Fine with me.
>
>>
>> Maybe we can preserve this commment in the declaration of
>> `_last_whole_heap_examined_time_ns` so that readers know we choose
>> `ns` on purpose, even though the caller,
>> `JVM_MaxObjectInspectionAge`, only need `ms`.
>> ```
>> // We need to use a monotonically non-decreasing time in ms
>> // or we will see time-warp warnings and os::javaTimeMillis()
>> // does not guarantee monotonicity. > ```
>
> I added a comment, but left the specifics about os::javaTimeMillis()
> out there. First, it would be better placed at the implementation, and
> second we are using the nanosecond counter anyway. Talking about a
> method that returns milliseconds seems confusing.
>
> New webrevs:
>
> http://cr.openjdk.java.net/~tschatzl/8248401/webrev.1_to_2 (diff)
> http://cr.openjdk.java.net/~tschatzl/8248401/webrev.2 (full)
>
> Testing: local with new test
>
> Thanks,
> Thomas
>
>>
>> On 2020-08-04 12:02, Thomas Schatzl wrote:
>>> Hi Stefan,
>>>
>>> thanks for your review.
>>>
>>> On 03.08.20 13:30, Stefan Karlsson wrote:
>>>> Hi Thomas,
>>>>
>>>> Not a complete review, but regarding the ZGC change, I don't think
>>>> it's appropriate to add a callback to Universe/CollectedHeap to
>>>> ZStatCycle. Most functions in ZStat only collects and print
>>>> statistics, and does not trigger external events. I think moving it
>>>> to the call would be cleaner:
>>>>
>>>> ~ZDriverGCScope() {
>>>> ...
>>>> // Update statistics
>>>> ZStatCycle::at_end(_gc_cause, boost_factor);
>>>>
>>>> // Update data used by soft reference policy
>>>> Universe::update_heap_info_at_gc();
>>>>
>>>> // Maybe add the call here?
>>>> ...
>>>> }
>>>>
>>>
>>> Thank you for pointing out the appropriate place in ZGC. Done.
>>>
>>>> Seeing this, it's also apparent that some of the "last_gc" info has
>>>> historically been recorded in Universe:
>>>>
>>>> void Universe::update_heap_info_at_gc() {
>>>> _heap_capacity_at_last_gc = heap()->capacity();
>>>> _heap_used_at_last_gc = heap()->used();
>>>> }
>>>>
>>>> while _last_whole_heap_examined_time_ns is recorded in
>>>> CollectedHeap. I think we should create a RFR to move the heap
>>>> variables out of Universe.
>>>
>>> Done, JDK-8250961.
>>>
>>> In addition to above changes, I tried to move the new call closer to
>>> Universe::update_heap_info_at_gc() in a few places and improve
>>> naming of some local variables.
>>>
>>> New webrevs:
>>> http://cr.openjdk.java.net/~tschatzl/8248401/webrev.0_to_1 (diff)
>>> http://cr.openjdk.java.net/~tschatzl/8248401/webrev.1 (full)
>>>
>>> Reran the test 300 times with these changes.
>>>
>>> Thanks,
>>> Thomas
>>
>
--
/Albert
More information about the hotspot-gc-dev
mailing list