<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>