<html>
<head>
<meta content="text/html; charset=utf-8" http-equiv="Content-Type">
</head>
<body bgcolor="#FFFFFF" text="#000000">
<div class="moz-cite-prefix">Hi Per,<br>
<br>
On 10/9/15 4:56 AM, Per Liden wrote:<br>
</div>
<blockquote
cite="mid:79875301-88F9-4950-95B1-5898895A2A92@oracle.com"
type="cite">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<div class="">Hi Derek,</div>
<br class="">
<div>
<blockquote type="cite" class="">
<div class="">On 09 Oct 2015, at 00:29, Derek White <<a
moz-do-not-send="true"
href="mailto:derek.white@oracle.com" class=""><a class="moz-txt-link-abbreviated" href="mailto:derek.white@oracle.com">derek.white@oracle.com</a></a>>
wrote:</div>
<br class="Apple-interchange-newline">
<div class="">
<meta content="text/html; charset=utf-8"
http-equiv="Content-Type" class="">
<div bgcolor="#FFFFFF" text="#000000" class="">
<div class="moz-cite-prefix">Another call for review:<br
class="">
<br class="">
2nd webrev:<br class="">
<a moz-do-not-send="true"
href="http://cr.openjdk.java.net/%7Edrwhite/8138920/webrev.02/"
class="">http://cr.openjdk.java.net/~drwhite/8138920/webrev.02/</a><br
class="">
</div>
</div>
</div>
</blockquote>
<div><br class="">
</div>
<div>Breaking out the sampling thread from refinement thread
seems like a really good idea. Thanks for addressing that.</div>
<div><br class="">
</div>
<div>However, I have a problem with the new
ConcurrentServiceThread, which I don’t think we need. I don’t
see a problem with moving some of the common things to
ConcurrentGCThread. I think you’re on the right track, but too
much thread specific logic (more specifically _monitor and
_notify_all) has leaked up into the common layer. You probably
just want a callback to the thread and let the thread itself
figure out what it needs to do to get stopped. That way I
think you can have the same model for all threads here,
including the string dedup and cms thread.</div>
</div>
</blockquote>
Yes, I was thinking that might work out. _notify_all was a hack.
Even worse I suspect that it's not necessary (notify would have been
fine), but I couldn't prove it.<br>
<blockquote
cite="mid:79875301-88F9-4950-95B1-5898895A2A92@oracle.com"
type="cite">
<div>
<div><br class="">
</div>
<div>To avoid stalling what this change is really about (the
sampling thread fix), I'd suggest that we leave the
ConcurrentServiceThread out of this patch, let the sampling
thread inherit form ConcurrentGCThread and we can do a cleanup
of the ConcurrentGCThread as a separate change later.</div>
</div>
</blockquote>
<br>
OK, sounds good to me.<br>
<blockquote
cite="mid:79875301-88F9-4950-95B1-5898895A2A92@oracle.com"
type="cite">
<div>
<div><br class="">
</div>
<div>cheers</div>
<div>/Per</div>
</div>
</blockquote>
<br>
Thanks!<br>
<br>
- Derek<br>
<blockquote
cite="mid:79875301-88F9-4950-95B1-5898895A2A92@oracle.com"
type="cite">
<div><br class="">
<blockquote type="cite" class="">
<div class="">
<div bgcolor="#FFFFFF" text="#000000" class="">
<div class="moz-cite-prefix"> <br class="">
See changes and comments below:<br class="">
<br class="">
On 10/8/15 2:47 AM, Bengt Rutisson wrote:<br class="">
</div>
<blockquote cite="mid:5616118F.2060208@oracle.com"
type="cite" class="">
<meta content="text/html; charset=utf-8"
http-equiv="Content-Type" class="">
<br class="">
Hi Derek,<br class="">
<br class="">
<div class="moz-cite-prefix">On 2015-10-07 17:19, Derek
White wrote:<br class="">
</div>
<blockquote cite="mid:5615381F.9010801@oracle.com"
type="cite" class="">
<meta content="text/html; charset=utf-8"
http-equiv="Content-Type" class="">
<div class="moz-cite-prefix">Hi Bengt,<br class="">
<br class="">
On 10/7/15 4:02 AM, Bengt Rutisson wrote:<br
class="">
</div>
<blockquote cite="mid:5614D1AA.5000105@oracle.com"
type="cite" class="">
<meta content="text/html; charset=utf-8"
http-equiv="Content-Type" class="">
Hi Derek,<br class="">
<br class="">
Thanks for fixing this!<br class="">
<br class="">
<div class="moz-cite-prefix">On 2015-10-06 19:51,
Derek White wrote:<br class="">
</div>
<blockquote cite="mid:56140A14.2030703@oracle.com"
type="cite" class="">
<meta http-equiv="content-type"
content="text/html; charset=utf-8" class="">
Refactor and cleanup the G1 concurrent thread
classes:<br class="">
- Pull out a sampling thread class (now
ConcurrentG1SampleThread) from
ConcurrentG1RefineThread.<br class="">
- Factor out an abstract base class
ConcurrentG1ServiceThread that is used by:<br
class="">
- ConcurrentG1RefineThread<br class="">
- ConcurrentG1SampleThread<br class="">
- ConcurrentMarkThread<br class="">
- Made the handling of the "primary" refinement
thread more explicit.<br class="">
- Updated obsolete and confusing comments<br
class="">
<br class="">
This is tech debt that also will allow disabling
concurrent refinement (if desired) and also fixes
a P4 bug.<br class="">
Patch started by Thomas and improved and/or
mangled myself.<br class="">
<br class="">
RFE:
<meta http-equiv="content-type"
content="text/html; charset=utf-8" class="">
<a moz-do-not-send="true" class="issue-link"
data-issue-key="JDK-8138920"
href="https://bugs.openjdk.java.net/browse/JDK-8138920"
id="key-val" rel="4848143">JDK-8138920</a>
Refactor the sampling thread from
ConcurrentG1RefineThread<br class="">
<br class="">
Webrev: <a moz-do-not-send="true"
class="moz-txt-link-freetext"
href="http://cr.openjdk.java.net/%7Edrwhite/8138920/webrev.01/">http://cr.openjdk.java.net/~drwhite/8138920/webrev.01/</a><br
class="">
</blockquote>
<br class="">
Overall this looks really good to me. <br class="">
<br class="">
Some comments:<br class="">
<br class="">
No one seems to depend on
ConcurrentG1ServiceThread::vtime_accum(). All uses
have the specific subclass available. So, I don't
think the pure virtual declaration in
ConcurrentG1ServiceThread is needed. I'd just remove
that and also make the corresponding methods in the
subclasses non-virtual.<br class="">
</blockquote>
<br class="">
OK. At some point we need to systematic rewrite of
timing, but that can wait.<br class="">
</blockquote>
<br class="">
Quite agree. <br class="">
<br class="">
<blockquote cite="mid:5615381F.9010801@oracle.com"
type="cite" class="">
<blockquote cite="mid:5614D1AA.5000105@oracle.com"
type="cite" class=""> That more or less only leaves
the run() and stop() methods in
ConcurrentG1ServiceThread. It is kind of nice for
the subclasses to get help with this, but I wonder
if it is not possible to improve the
ConcurrentGCThread class to help with this instead.
Basically I guess I am a little unsure if the extra
class ConcurrentG1ServiceThread is really needed.<br
class="">
<br class="">
</blockquote>
I'll look at ConcurrentGCThread to see how well it
could cover these cases.<br class="">
</blockquote>
<br class="">
Thanks. I think it is worth a try. If it doesn't turn
out well we can keep the intermediate class, but I think
it is worth exploring.<br class="">
</blockquote>
<br class="">
I looked at pushing ConcurrentServiceThread up into
ConcurrentGCThread, but things got a little complicated.
ConcurrentG1RefineThread, ConcurrentMarkThread, and
ConcurrentSampleThread have a very "regularized"
implementation of the "termination protocol".
G1StringDedupThread is slightly off from this, and
ConcurrentMarkSweepThread more so. Pushing the shared
code up into ConcurrentGCThread but not using it in
G1StringDedupThread and ConcurrentMarkSweepThread seems
confusing.<br class="">
<br class="">
There's a tension between providing a framework that
handles all shared factorizable code, but can become a
straight jacket for future code, and everyone doing
everything separately and differently. This webrev is
somewhere in the middle. Some of the changes between
webrev.01 and .02 are to make the duplicated code more
similar, even though it's not shared.<br class="">
<br class="">
<blockquote cite="mid:5616118F.2060208@oracle.com"
type="cite" class="">
<blockquote cite="mid:5615381F.9010801@oracle.com"
type="cite" class="">
<blockquote cite="mid:5614D1AA.5000105@oracle.com"
type="cite" class=""> Naming. The naming in G1 is a
bit inconsistent. Some files and classes are
prefixed with G1 and some are not. But if they are
called something with G1 it is normally a prefix.
So, I would prefer the new classes to be called
G1Concurrent* instead of ConcurrentG1*.<br class="">
</blockquote>
<br class="">
So we have:<br class="">
- ConcurrentG1RefineThread<br class="">
- ConcurrentMarkThread<br class="">
<br class="">
And I added:<br class="">
- ConcurrentG1SampleThread<br class="">
- ConcurrentG1ServiceThread<br class="">
<br class="">
And maybe I'm removing ConcurrentG1ServiceThread. In
that case I'd be inclined to rename:<br class="">
ConcurrentG1SampleThread =>
ConcurrentSampleThread </blockquote>
<br class="">
Sounds good. The ConcurrentG1Refine* classes are really
the only oddly named G1 classes, so I think it is better
not to let that naming spread.<br class="">
</blockquote>
This version includes the class renaming.
<blockquote cite="mid:5616118F.2060208@oracle.com"
type="cite" class=""> <br class="">
<blockquote cite="mid:5615381F.9010801@oracle.com"
type="cite" class="">
<blockquote cite="mid:5614D1AA.5000105@oracle.com"
type="cite" class=""> You write "and also fixes a P4
bug". Which bug is that?<br class="">
</blockquote>
<meta http-equiv="content-type" content="text/html;
charset=utf-8" class="">
<a moz-do-not-send="true" class="issue-link"
data-issue-key="JDK-8136856"
href="https://bugs.openjdk.java.net/browse/JDK-8136856"
id="key-val" rel="4845182">JDK-8136856</a> G1 makes
two concurrent refinement threads with
-XX:G1ConcRefinementThreads=1<br class="">
(because the sampling thread "is-a" concurrent
refinement thread.<br class="">
</blockquote>
<br class="">
Ah. I see. Makes sense. Thanks.<br class="">
<br class="">
But it is still not possible to turn refinement off by
setting -XX:G1ConcRefinementThreads=0 since that is
considered the default, right?<br class="">
</blockquote>
<br class="">
I'm not sure about this. If I recall correctly, Thomas
implied that it was hard to disable concurrent refinement
without disabling the sampling thread too.<br class="">
<br class="">
<blockquote cite="mid:5616118F.2060208@oracle.com"
type="cite" class="">
<blockquote cite="mid:5615381F.9010801@oracle.com"
type="cite" class=""> I cant' recall how to mark a bug
as blocking another bug.<br class="">
</blockquote>
<br class="">
You add a link (More->Link) to the other bug and
choose "block" or "is blocked by".<br class="">
<br class="">
Thanks,<br class="">
Bengt<br class="">
</blockquote>
Thanks for the tip!<br class="">
<br class="">
- Derek<br class="">
<br class="">
</div>
</div>
</blockquote>
</div>
<br class="">
</blockquote>
<br>
</body>
</html>