<html>
  <head>
    <meta content="text/html; charset=UTF-8" http-equiv="Content-Type">
  </head>
  <body bgcolor="#FFFFFF" text="#000000">
    Hi David,<br>
    <br>
    On 11/11/2011 11:48 AM, David Holmes wrote:
    <blockquote cite="mid:4EBCBE4D.8020002@oracle.com" type="cite">Hi
      Poonam,
      <br>
      <br>
      I've cc'ed GC-dev as this is more their area. It seems very
      wasteful to potentially ensure_parsability and also do a full GC.
      And the check for the active GC_Locker is somewhat arbitrary as it
      could change the instant you've queried it.
      <br>
      <br>
    </blockquote>
    Thanks for adding GC-dev.<br>
    <br>
    <blockquote cite="mid:4EBCBE4D.8020002@oracle.com" type="cite">It
      seems to me that a more complete solution here would enable
      collect_as_vm_thread to indicate whether or not GC occurred. Which
      in turn requires that do_full_collection report that info - a RFE
      that is already noted in the G1 code at least:
      <br>
      <br>
      void G1CollectedHeap::do_full_collection(bool clear_all_soft_refs)
      {
      <br>
        // do_collection() will return whether it succeeded in
      performing
      <br>
        // the GC. Currently, there is no facility on the
      <br>
        // do_full_collection() API to notify the caller than the
      collection
      <br>
        // did not succeed (e.g., because it was locked out by the GC
      <br>
        // locker). So, right now, we'll ignore the return value.
      <br>
        bool dummy = do_collection(true,                /* explicit_gc
      */
      <br>
                                   clear_all_soft_refs,
      <br>
                                   0                    /* word_size
      */);
      <br>
      }
      <br>
      <br>
    </blockquote>
    Yes, that would be the ideal solution.<br>
    <br>
    What is the time frame of having this RFE implemented for other
    collectors? This bug was discovered during the FMW stress testing
    and needs to fixed as soon as we can. <br>
    <br>
    The solution I proposed is being used by other VM operations as well
    e.g. VM_GC_HeapInspection and was somehow missed for VM_HeapDumper..
    So, I guess until we have the RFE implemented that allows us to have
    the result whether a GC succeeded  or not, this could be a short
    term solution.<br>
    <br>
    <br>
    Thanks,<br>
    Poonam<br>
    <br>
    <br>
    <blockquote cite="mid:4EBCBE4D.8020002@oracle.com" type="cite">David
      <br>
      -----
      <br>
      <br>
      On 11/11/2011 3:20 PM, <a class="moz-txt-link-abbreviated" href="mailto:poonam.bajaj@oracle.com">poonam.bajaj@oracle.com</a> wrote:
      <br>
      <blockquote type="cite">Hi,
        <br>
        <br>
        Can I get a couple of reviews for this change:
        <br>
        <br>
        CR 7110428: Crash during HeapDump operation
        <br>
        <a class="moz-txt-link-freetext" href="http://monaco.sfbay.sun.com/detail.jsf?cr=7110428">http://monaco.sfbay.sun.com/detail.jsf?cr=7110428</a>
        <br>
        <br>
        The crash happens when VM thread traverses the heap during
        heapdump
        <br>
        operation and it finds the heap in non-parseable state. The heap
        can be
        <br>
        left in non-parseable state if due to some reason GC is skipped
        and we
        <br>
        didn't call ensure_parsability() either before dumping the heap.
        The
        <br>
        solution is to always call ensure_parsability() In
        <br>
        VM_HeapDumper::doit(), whether or not a GC is requested before
        the heap
        <br>
        dumping.
        <br>
        <br>
        <a class="moz-txt-link-freetext" href="http://cr.openjdk.java.net/~poonam/7110428/webrev.00/">http://cr.openjdk.java.net/~poonam/7110428/webrev.00/</a>
        <br>
        <br>
        <br>
        Thanks,
        <br>
        Poonam
        <br>
        <br>
        <br>
      </blockquote>
    </blockquote>
    <br>
    <div class="moz-signature">-- <br>
      Best regards, Poonam
      <p>
        <a href="http://www.oracle.com" target="_blank"><img
            src="cid:part1.00090403.01000507@oracle.com" alt="Oracle"
            border="0" height="26" width="114"></a><br>
        <font color="#666666" face="Verdana, Arial, Helvetica,
          sans-serif" size="2">Poonam Bajaj | Principal Member of
          Technical Staff<br>
          Phone: <a href="tel:+91%2080%2066937451">+91 80 66937451</a>
          | Mobile: <a href="tel:+91%209844511366">+91 9844511366</a> <br>
          <font color="#ff0000">Oracle</font> JVM Sustaining Engineering<br>
          <br>
          ORACLE India Bangalore</font>
        <br>
        <a href="http://www.oracle.com/commitment" target="_blank"><img
            src="cid:part2.01050905.00040601@oracle.com" alt="Green
            Oracle" align="absmiddle" border="0" height="28" width="44"></a>
        <font color="#4B7D42" face="Verdana, Arial, Helvetica,
          sans-serif" size="1">Oracle is committed to developing
          practices and products that help protect the environment</font>
        <!-- This signature was generated by the MyDesktop Oracle Business Signature utility version 3.8.7 -->
      </p>
    </div>
  </body>
</html>