<html>
  <head>
    <meta content="text/html; charset=windows-1252"
      http-equiv="Content-Type">
  </head>
  <body bgcolor="#FFFFFF" text="#000000">
    Ivan,<br>
    <br>
    You're correct about this bug.<br>
    <br>
    Is it correct that you're covered by the SAP contributor<br>
    agreement?<br>
    <br>
    Have you filed a bug report on this?<br>
    <br>
    Have you checked the other GC's for this problem?<br>
    <br>
    I can sponsor this fix.<br>
    <br>
    Thanks.<br>
    <br>
    Jon<br>
    <br>
    <br>
    <br>
    <div class="moz-cite-prefix">On 9/8/2015 2:21 AM, Galkin, Ivan
      wrote:<br>
    </div>
    <blockquote
cite="mid:8F4410BA1F99FD46B6A158A59E8585CD696DD00A@DEWDFEMB11B.global.corp.sap"
      type="cite">
      <meta http-equiv="Content-Type" content="text/html;
        charset=windows-1252">
      <meta name="Generator" content="Microsoft Word 14 (filtered
        medium)">
      <style><!--
/* Font Definitions */
@font-face
        {font-family:Calibri;
        panose-1:2 15 5 2 2 2 4 3 2 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
        {margin:0cm;
        margin-bottom:.0001pt;
        font-size:11.0pt;
        font-family:"Calibri","sans-serif";
        mso-fareast-language:EN-US;}
a:link, span.MsoHyperlink
        {mso-style-priority:99;
        color:blue;
        text-decoration:underline;}
a:visited, span.MsoHyperlinkFollowed
        {mso-style-priority:99;
        color:purple;
        text-decoration:underline;}
p.MsoListParagraph, li.MsoListParagraph, div.MsoListParagraph
        {mso-style-priority:34;
        margin-top:0cm;
        margin-right:0cm;
        margin-bottom:0cm;
        margin-left:36.0pt;
        margin-bottom:.0001pt;
        font-size:11.0pt;
        font-family:"Calibri","sans-serif";
        mso-fareast-language:EN-US;}
span.EmailStyle18
        {mso-style-type:personal;
        font-family:"Calibri","sans-serif";
        color:windowtext;}
span.EmailStyle19
        {mso-style-type:personal-reply;
        font-family:"Calibri","sans-serif";
        color:#1F497D;}
.MsoChpDefault
        {mso-style-type:export-only;
        font-size:10.0pt;}
@page WordSection1
        {size:612.0pt 792.0pt;
        margin:70.85pt 70.85pt 2.0cm 70.85pt;}
div.WordSection1
        {page:WordSection1;}
/* List Definitions */
@list l0
        {mso-list-id:980844461;
        mso-list-type:hybrid;
        mso-list-template-ids:2091041230 134807567 134807577 134807579 134807567 134807577 134807579 134807567 134807577 134807579;}
@list l0:level1
        {mso-level-tab-stop:none;
        mso-level-number-position:left;
        text-indent:-18.0pt;}
@list l0:level2
        {mso-level-number-format:alpha-lower;
        mso-level-tab-stop:none;
        mso-level-number-position:left;
        text-indent:-18.0pt;}
@list l0:level3
        {mso-level-number-format:roman-lower;
        mso-level-tab-stop:none;
        mso-level-number-position:right;
        text-indent:-9.0pt;}
@list l0:level4
        {mso-level-tab-stop:none;
        mso-level-number-position:left;
        text-indent:-18.0pt;}
@list l0:level5
        {mso-level-number-format:alpha-lower;
        mso-level-tab-stop:none;
        mso-level-number-position:left;
        text-indent:-18.0pt;}
@list l0:level6
        {mso-level-number-format:roman-lower;
        mso-level-tab-stop:none;
        mso-level-number-position:right;
        text-indent:-9.0pt;}
@list l0:level7
        {mso-level-tab-stop:none;
        mso-level-number-position:left;
        text-indent:-18.0pt;}
@list l0:level8
        {mso-level-number-format:alpha-lower;
        mso-level-tab-stop:none;
        mso-level-number-position:left;
        text-indent:-18.0pt;}
@list l0:level9
        {mso-level-number-format:roman-lower;
        mso-level-tab-stop:none;
        mso-level-number-position:right;
        text-indent:-9.0pt;}
ol
        {margin-bottom:0cm;}
ul
        {margin-bottom:0cm;}
--></style><!--[if gte mso 9]><xml>
<o:shapedefaults v:ext="edit" spidmax="1026" />
</xml><![endif]--><!--[if gte mso 9]><xml>
<o:shapelayout v:ext="edit">
<o:idmap v:ext="edit" data="1" />
</o:shapelayout></xml><![endif]-->
      <div class="WordSection1">
        <p class="MsoNormal">Hello all,<o:p></o:p></p>
        <p class="MsoNormal"><o:p> </o:p></p>
        <p class="MsoNormal">I believe the calculation of max_eden_size
          <span style="color:black">
            which is </span>needed to check the GC overhead in CMS is
          incorrect. Namely in concurrentMarkSweepGeneration.cpp the
          following expression is used:<o:p></o:p></p>
        <p class="MsoNormal"><o:p> </o:p></p>
        <p class="MsoNormal" style="text-indent:36.0pt">size_t
          max_eden_size = _young_gen->max_capacity() -
          _young_gen->to()->capacity() -
          _young_gen->from()->capacity();<o:p></o:p></p>
        <p class="MsoNormal"><o:p> </o:p></p>
        <p class="MsoNormal">According to the implementation of
          DefNewGeneration::max_capacity() the expression can be
          unfolded as:<o:p></o:p></p>
        <p class="MsoNormal"><o:p> </o:p></p>
        <p class="MsoNormal">                size_t max_eden_size =
          (“reserved size of young gen” – “size of survivor space”) –
          “size of survivor space” – “size of survivor space”;<o:p></o:p></p>
        <p class="MsoNormal"><o:p> </o:p></p>
        <p class="MsoNormal">So the value becomes too small (survival
          spaces are accounted 3 times!), which can lead to the
          following problems:<o:p></o:p></p>
        <p class="MsoNormal"><o:p> </o:p></p>
        <p class="MsoListParagraph"
          style="text-indent:-18.0pt;mso-list:l0 level1 lfo2"><!--[if !supportLists]--><span
            style="mso-list:Ignore">1.<span style="font:7.0pt
              "Times New Roman"">      
            </span></span><!--[endif]-->max_eden_size is too small and
          GC overhead is wrongfully recognized too early<o:p></o:p></p>
        <p class="MsoListParagraph"
          style="text-indent:-18.0pt;mso-list:l0 level1 lfo2"><!--[if !supportLists]--><span
            style="mso-list:Ignore">2.<span style="font:7.0pt
              "Times New Roman"">      
            </span></span><!--[endif]-->max_eden_size == 0 (all young
          spaces have the same size; -XX:SurvivorRatio=1) and GC
          overhead is never
          <span style="color:black">happens</span> (see implementation
          of <span style="color:black">
            AdaptiveSizePolicy::</span>check_gc_overhead_limit: <o:p></o:p></p>
        <p class="MsoListParagraph"
          style="margin-left:72.0pt;text-indent:-18.0pt;mso-list:l0
          level2 lfo2">
          <!--[if !supportLists]--><span style="mso-list:Ignore">a.<span
              style="font:7.0pt "Times New Roman"">      
            </span></span><!--[endif]-->max_eden_size == 0 leads to
          mem_free_eden_limit == 0; <o:p>
          </o:p></p>
        <p class="MsoListParagraph"
          style="margin-left:72.0pt;text-indent:-18.0pt;mso-list:l0
          level2 lfo2">
          <!--[if !supportLists]--><span style="mso-list:Ignore">b.<span
              style="font:7.0pt "Times New Roman"">     
            </span></span><!--[endif]-->free_in_eden <
          mem_free_eden_limit is always false, since both are unsigned
          integers and mem_free_eden_limit is 0)<o:p></o:p></p>
        <p class="MsoNormal"><o:p> </o:p></p>
        <p class="MsoNormal">I would <span style="color:black">therefore
          </span>suggest the following fix
          <span style="color:black">(</span>DefNewGeneration::
          max_eden_size() <span style="color:black">
            already </span>contains the correctly calculated capacity
          of eden<span style="color:black">):</span><o:p></o:p></p>
        <p class="MsoNormal"><o:p> </o:p></p>
        <p class="MsoNormal">diff -r f74b3ce62e1f
          src/share/vm/gc/cms/concurrentMarkSweepGeneration.cpp<o:p></o:p></p>
        <p class="MsoNormal">---
          a/src/share/vm/gc/cms/concurrentMarkSweepGeneration.cpp        
          Fri Sep 04 17:33:56 2015 -0700<o:p></o:p></p>
        <p class="MsoNormal">+++
          b/src/share/vm/gc/cms/concurrentMarkSweepGeneration.cpp     
          Mon Sep 07 18:08:39 2015 +0200<o:p></o:p></p>
        <p class="MsoNormal">@@ -1563,9 +1563,7 @@<o:p></o:p></p>
        <p class="MsoNormal">   do_compaction_work(clear_all_soft_refs);<o:p></o:p></p>
        <p class="MsoNormal"><o:p> </o:p></p>
        <p class="MsoNormal">   // Has the GC time limit been exceeded?<o:p></o:p></p>
        <p class="MsoNormal">-  size_t max_eden_size =
          _young_gen->max_capacity() -<o:p></o:p></p>
        <p class="MsoNormal">-                        
          _young_gen->to()->capacity() -<o:p></o:p></p>
        <p class="MsoNormal">-                        
          _young_gen->from()->capacity();<o:p></o:p></p>
        <p class="MsoNormal">+  size_t max_eden_size =
          _young_gen->max_eden_size();<o:p></o:p></p>
        <p class="MsoNormal">   GCCause::Cause gc_cause =
          gch->gc_cause();<o:p></o:p></p>
        <p class="MsoNormal">  
          size_policy()->check_gc_overhead_limit(_young_gen->used(),<o:p></o:p></p>
        <p class="MsoNormal">                                  
                 _young_gen->eden()->used(),<o:p></o:p></p>
        <p class="MsoNormal"><o:p> </o:p></p>
        <p class="MsoNormal">Could anybody please review and sponsor the
          change?<o:p></o:p></p>
        <p class="MsoNormal"><o:p> </o:p></p>
        <p class="MsoNormal">Thank you in advance,<o:p></o:p></p>
        <p class="MsoNormal">Ivan<o:p></o:p></p>
      </div>
    </blockquote>
    <br>
  </body>
</html>