RFR: JDK-8055845 - Add trace event for promoted objects
Staffan Friberg
staffan.friberg at oracle.com
Wed Nov 19 16:23:26 UTC 2014
Hi,
Erik and Tomas asked me to separate the G1 changes which was pushed
separately in JDK-8064473.
Erik also had some further comments offline that I have taken care of.
Here is the new webrev, cr.openjdk.java.net/~sfriberg/8055845/webrev.06
Thanks,
Staffan
On 11/06/2014 01:53 PM, Bengt Rutisson wrote:
>
>
> On 2014-11-06 14:00, Staffan Friberg wrote:
>> Good catch, fixed.
>>
>> // Too large; allocate the object individually.
>> obj = sp->par_allocate(word_sz);
>> if (obj != NULL) {
>> gc_tracer()->report_promotion_outside_plab_event(old, word_sz, age,
>> false);
>> }
>>
>> Please let me know if anyone wants a full new webrev with this.
>
>
> Looks good. Reviewed.
>
> Bengt
>
>>
>> Thanks,
>> Staffan
>>
>>
>> On 11/06/2014 12:01 PM, Bengt Rutisson wrote:
>>>
>>> Hi Staffan,
>>>
>>> On 2014-11-06 11:12, Staffan Friberg wrote:
>>>> Hi,
>>>>
>>>> After further off list discussion it was decided to keep the
>>>> gc_tracer in par_promote as is.
>>>>
>>>> I have uploaded a new webrev,
>>>> http://cr.openjdk.java.net/~sfriberg/8055845/webrev.05
>>>>
>>>> The main change here is a rewrite of the G1 code which is cleaner
>>>> and also reuses the read age. By sending the markOop down through
>>>> the call we can now trust the read age and do not need to reread it
>>>> when incrementing which improves the YC performance slightly as it
>>>> avoids the rather complex bit extraction.
>>>
>>>
>>> Looks good to me. One detail in parNewGeneration.cpp:
>>>
>>> 274 } else {
>>> 275 // Too large; allocate the object individually.
>>> 276 gc_tracer()->report_promotion_outside_plab_event(old, word_sz,
>>> age, false);
>>> 277 obj = sp->par_allocate(word_sz);
>>> 278 }
>>>
>>> Seems like par_allocate() return NULL. Maybe we should check that
>>> before reporting the event. Similarly to what you do in the other
>>> GCs, for example G1:
>>>
>>> g1Allocator.cpp
>>>
>>> 141 obj = _g1h->par_allocate_during_gc(purpose, word_sz, context);
>>> 142 if (obj != NULL
>>> 143 &&
>>> _g1h->_gc_tracer_stw->should_report_promotion_outside_plab_event()) {
>>> 144 bool tenured =
>>> _g1h->heap_region_containing_raw(obj)->is_old();
>>> 145 _g1h->_gc_tracer_stw->report_promotion_outside_plab_event(old,
>>> word_sz,
>>> 146 age, tenured);
>>> 147 }
>>>
>>> Thanks,
>>> Bengt
>>>
>>>
>>>
>>>>
>>>> Cheers,
>>>> Staffan
>>>>
>>>> On 09/15/2014 02:06 PM, Bengt Rutisson wrote:
>>>>>
>>>>> Hi Staffan,
>>>>>
>>>>> psPromotionManager.inline.hpp
>>>>>
>>>>> I think the PSPromotionManager::copy_to_survivor_space() might
>>>>> send multiple events. If the allocation to the young gen fails we
>>>>> will fall through to do an old gen allocation. But we send the
>>>>> events before we realize that the allocation has failed, i.e.
>>>>> new_obj is NULL.
>>>>>
>>>>> I talked to Erik a bit about how to handle the gc_tracer in
>>>>> par_promote. He'll get back to you with some thoughts on that.
>>>>>
>>>>> Thanks,
>>>>> Bengt
>>>>>
>>>>>
>>>>> On 2014-09-06 00:20, Staffan Friberg wrote:
>>>>>> Hi,
>>>>>>
>>>>>> I have uploaded a new webrev here,
>>>>>> cr.openjdk.java.net/~sfriberg/8055845/webrev.03
>>>>>>
>>>>>> It contains several changes
>>>>>>
>>>>>> - Split event into two events (PromoteObjectInNewPLAB,
>>>>>> PromoteObjectOutsidePLAB)
>>>>>> - Moved events to "vm/gc/detailed/PromoteObject..."
>>>>>> - Supporting ParNew+CMS and ParNew+SerialOld tenuring
>>>>>> - Not sure if the way I do it with passing the
>>>>>> ParNewTracer is the best solution, please let me know if you have
>>>>>> an idea how to improve it
>>>>>> - Simplified the G1 code to avoid sending age and having a
>>>>>> single call site
>>>>>> - Fixed so that the generated event has size information in
>>>>>> bytes rather than words
>>>>>>
>>>>>> Thanks for offline comments and suggestions from Dmitry and Thomas.
>>>>>>
>>>>>> Cheers,
>>>>>> Staffan
>>>>>>
>>>>>> On 08/29/2014 03:32 PM, Staffan Friberg wrote:
>>>>>>> Hi Erik,
>>>>>>>
>>>>>>> On 08/28/2014 11:34 PM, Erik Helin wrote:
>>>>>>>> (it seems like we lost hotspot-gc-dev at openjdk.java.net
>>>>>>>> somewhere in this thread, I'm adding it back)
>>>>>>>>
>>>>>>>> On 2014-08-28 23:15, Staffan Friberg wrote:
>>>>>>>>> Hi Erik,
>>>>>>>>>
>>>>>>>>> Thanks for the comments.
>>>>>>>>>> - Aren't the events for promotion to the tenured generation
>>>>>>>>>> (SerialOld)
>>>>>>>>>> and the CMS generation missing?
>>>>>>>>> The reason for leaving out these two, Serial completely and CMS
>>>>>>>>> promotion, was due to that neither as far as I understand make
>>>>>>>>> use of
>>>>>>>>> PLABs.
>>>>>>>>
>>>>>>>> I might be wrong here, but looking at the function
>>>>>>>> TenuredGeneration::par_promote (in tenuredGeneration.cpp) it
>>>>>>>> looks to me like SerialOld is using PLABs when ParNew is
>>>>>>>> promoting objects from young to old.
>>>>>>>>
>>>>>>>> As for CMS, looking at
>>>>>>>> ConcurrentMarkSweepGeneration::par_promote (in
>>>>>>>> concurrentMarkSweepGeneration.cpp) it seems like each
>>>>>>>> CMSParGCThreadState has a CFLS_LAB (CompactibleFreeListSpace
>>>>>>>> Local Allocation Buffer) that is a thread-local allocation
>>>>>>>> buffer. See compactibleFreeListSpace.{hpp,cpp} for more details.
>>>>>>>>
>>>>>>>> Given this, I think we should add events for Serial and CMS as
>>>>>>>> well.
>>>>>>>>
>>>>>>>
>>>>>>> Ok I see what you mean with CMS, basically the equivalent to
>>>>>>> getting a PLAB would be when we refill the CFLS_LAB in the alloc
>>>>>>> function. It still does the allocation to a small memory (~ size
>>>>>>> of object) area from the freelist, but at least we did extra
>>>>>>> work to refill the local CFLS_LAB. Need to do some analysis to
>>>>>>> see how often we refill so the overhead doesn't get too high.
>>>>>>> The only issue I run into is how I can in a nice way get access
>>>>>>> to the ParNewTracer from ParNewGeneration to call the report
>>>>>>> function. Let's sync up next week and see how it can be solved.
>>>>>>>
>>>>>>> The tenured GC requires something similar to be supported,
>>>>>>> however since ParNewGC is deprecated for usage without CMS in
>>>>>>> JDK 8 we might want to skip that combination.
>>>>>>>
>>>>>>>
>>>>>>>>
>>>>>>>> On 2014-08-28 23:15, Staffan Friberg wrote:
>>>>>>>>>> - Would it make sense to differentiate, either by separate
>>>>>>>>>> events or by
>>>>>>>>>> a field in a event, between promotions to to-space and to
>>>>>>>>>> the old
>>>>>>>>>> generation?
>>>>>>>>>> - The are two events for TLAB allocations,
>>>>>>>>>> java/object_alloc_in_new_TLAB and
>>>>>>>>>> java/object_alloc_outside_TLAB.
>>>>>>>>>> What do you think about using two events for PLAB
>>>>>>>>>> allocations as well:
>>>>>>>>>> - java/object_alloc_in_new_PLAB
>>>>>>>>>> - java/object_alloc_outside_PLAB
>>>>>>>>> I think this is a matter of taste and probably how similar we
>>>>>>>>> want the
>>>>>>>>> event to be to the existing allocation event. I personally
>>>>>>>>> prefer a
>>>>>>>>> single event but if the GC team and serviceability team feel
>>>>>>>>> it would be
>>>>>>>>> better to have two I can certainly rewrite. The reason for me
>>>>>>>>> preferring
>>>>>>>>> a single event is just ease of analysis, you can easily filter
>>>>>>>>> a list of
>>>>>>>>> events on a field, it is harder to merge two different events
>>>>>>>>> with
>>>>>>>>> different fields and work with them in an straight forward
>>>>>>>>> fashion.
>>>>>>>>>
>>>>>>>>> Any general preference for having a single or multiple events?
>>>>>>>>
>>>>>>>> I would prefer to have two events in this case and try to
>>>>>>>> follow the existing allocation events as much as possible (both
>>>>>>>> in naming and in style). Keeping the tenured field (I missed it
>>>>>>>> the first time I read the patch) is good.
>>>>>>>>
>>>>>>> Yes, tenured would be independent of having two events, only
>>>>>>> PLAB size and directAllocation would be affected when having two
>>>>>>> event types.
>>>>>>>
>>>>>>> *Erik Gahlin*, any preference from your end?
>>>>>>>
>>>>>>>
>>>>>>>
>>>>>>>> On 2014-08-28 23:15, Staffan Friberg wrote:
>>>>>>>>>> - In PSPromotionManager, instead of utilizing the C++
>>>>>>>>>> friendship with
>>>>>>>>>> PSScavenge, should we add a getter function for the gc_tracer?
>>>>>>>>> Created a getter function.
>>>>>>>>
>>>>>>>> Thanks! If you make report_promotion_sample const, then the
>>>>>>>> getter can return a const ParallelScavengeTracer*, right?
>>>>>>>>
>>>>>>> Done
>>>>>>>
>>>>>>> //Staffan
>>>>>>
>>>>>
>>>>
>>>
>>
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://mail.openjdk.org/pipermail/hotspot-gc-dev/attachments/20141119/f7e534df/attachment.htm>
More information about the hotspot-gc-dev
mailing list