<html>
  <head>
    <meta content="text/html; charset=utf-8" http-equiv="Content-Type">
  </head>
  <body bgcolor="#FFFFFF" text="#000000">
    <div class="moz-cite-prefix">Possible pre-existing bug, see below...<br>
      <br>
      On 3/17/16 6:34 PM, Derek White wrote:<br>
    </div>
    <blockquote cite="mid:56EB30DF.1000801@oracle.com" type="cite">
      <meta content="text/html; charset=utf-8" http-equiv="Content-Type">
      <div class="moz-cite-prefix">On 3/10/16 3:10 PM, Joseph Provino
        wrote:<br>
      </div>
      <blockquote cite="mid:56E1D4C1.5030208@oracle.com" type="cite">
        <meta http-equiv="content-type" content="text/html;
          charset=utf-8">
        Please review these changes.  <br>
        <br>
        CR:  <a moz-do-not-send="true" class="issue-link"
          data-issue-key="JDK-8085983"
          href="https://bugs.openjdk.java.net/browse/JDK-8085983"
          id="key-val" rel="4786093" style="color: rgb(59, 115, 175);
          text-decoration: none;">JDK-8085983
          G1CollectedHeap::collection_set_iterate_from() has unused code
          and can be simplified</a><br>
        <br>
        Webrev:  <a moz-do-not-send="true"
          class="moz-txt-link-freetext"
          href="http://cr.openjdk.java.net/%7Ejprovino/8085983/webrev.02">http://cr.openjdk.java.net/~jprovino/8085983/webrev.02</a><br>
        <br>
        Thanks.<br>
        <br>
        joe<br>
      </blockquote>
      Hi Joe,<br>
      Here are my comments.  The last issue looks serious, but I
      suggested several possible solutions.<br>
      <br>
      heapRegionManager.hpp<br>
       - Copyright<br>
      <br>
        - Line 267: too many b's<br>
           - Does iterate really call doHeapRegionAbortabble()? (sp)<br>
      <br>
      heapRegionManager.inline.hpp<br>
       - Odd spacing at line 102.<br>
      <br>
       - In HeapRegionManager::iterate(), line 118:<br>
         - Should be calling HeapRegionManager::do_heap_region() here,
      so iterate can abort?<br>
            Wait! What happened to the call to incomplete()?<br>
    </blockquote>
    <br>
    And why didn't the old (or new) par_iterate() call <tt>blk->incomplete();</tt>
    when bailing out of iteration? I think the current callers of
    par_iterate() don't check for complete() iterations, but that's
    waiting to happen.<tt></tt>
    <blockquote cite="mid:56EB30DF.1000801@oracle.com" type="cite">   
      Wait! not all Closure objects have an incomplete() method, only<br>
         AbortableHeapRegionClosures.<br>
      <br>
         OK, one fix would be to catch the abort condition in<br>
         HeapRegionManager::do_heap_region(AbortableHeapRegionClosure,
      *):<br>
         <br>
      <tt>    bool do_heap_region(AbortableHeapRegionClosure* blk,
        HeapRegion* r) const {</tt><tt><br>
      </tt><tt>      bool res = blk->doHeapRegion(r);</tt><tt><br>
      </tt><tt>      if (res) {</tt><tt><br>
      </tt><tt>        blk->incomplete();</tt><tt><br>
      </tt><tt>      }</tt><tt><br>
      </tt><tt>      return res;</tt><tt><br>
      </tt><tt>    }</tt><br>
      <br>
         But this means that the _complete field is only valid if<br>
         AbortableHeapRegionClosure::doHeapRegion() is only called from
      the<br>
         new method above. Could enforce this by making doHeapRegion()<br>
         private and making HeapRegionManager a friend.<br>
      <br>
         Alternatively, if we want doHeapRegion() callable from other<br>
         places, we could have a public non-virtual doHeapRegion()
      method<br>
         that is a wrapper around a protected virtual doHeapRegionWork()<br>
         method. The wrapper calls  doHeapRegionWork() and calls<br>
         incomplete() if it return TRUE. But this means renaming all of
      the<br>
         overriden method implementations (or could do it in reverse and<br>
         rename the wrapper and all of it's callers).<br>
      <br>
         Alternatively (3rd option), we could make the<br>
         AbortableHeapRegionClosure::doHeapRegion() overrides all
      responsible for<br>
         calling incomplete() if they return true.<br>
      <br>
         Anyone have an opinion here? Am I calling wolf on this issue?<br>
      <br>
      OK, what were we simplifying again in this RFE? :-)<br>
      <br>
       - Derek<br>
    </blockquote>
    <br>
  </body>
</html>