CRR (S): 7119027: G1: use atomics to update RS length / predict time of inc CSet

Tony Printezis tony.printezis at oracle.com
Tue Dec 20 17:52:37 UTC 2011


Hi all,

I'd like a couple of code reviews for this small change that resolves 
the race that we identified a few weeks ago (and which we already guard 
against in the code):

http://cr.openjdk.java.net/~tonyp/7119027/webrev.0/

Instead of using atomics I decided to take an alternative approach to 
eliminate the race which as described in the CR:

"The final fix is somewhat different to what I had originally planned 
and does not use atomics. The observation is that only two threads can 
update the fields in question: a mutator thread that retires a region 
before allocating a new one (and it has to take the Heap_lock in order 
to do so - so those updates are serialized anyway) and a concurrent 
refinement thread that samples the RSets in the inc CSet. What we'll do 
is to accumulate the updates from each thread on separate fields and 
we'll just combine them at the start of a GC."

Thanks,

Tony



More information about the hotspot-gc-dev mailing list