<html>
  <head>
    <meta content="text/html; charset=ISO-8859-1"
      http-equiv="Content-Type">
  </head>
  <body text="#000000" bgcolor="#FFFFFF">
    Hi Martin,<br>
    <br>
    An enqueued card let's the refinment threads know that the oops
    spanned by that card need to be walked but we're only interested in
    the latest contents of the fields in those oops. IOW the oop in (3')
    doesn't need to be the oop stored in (1). If there's a subsequent
    store (3) to the same location then we want the load at (3') to see
    the lastest contents. For example suppose we have:<br>
    <br>
    x.f = a;<br>
    x.f = b;<br>
    <br>
    If the application thread sees the card spanning x.f is dirty at the
    second store then we won't enqueue the card after the second store.
    As long as the refinement thread sees 'b' when the card is 'refined'
    then we're OK since we no longer need to add an entry into the RSet
    for the region containing a - we do need an entry in the RSet for
    the region containing b.<br>
    <br>
    If the application thread sees the card as clean at the second store
    before the refinement thread loads x.f we have just needlessly
    enqueued the card again.<br>
    <br>
    It is only if the application thread sees the card as dirty but the
    refinement thread reads 'a' then there could be a problem. We have a
    missing RSet entry for 'b'.<br>
    <br>
    JohnC<br>
    <br>
    <div class="moz-cite-prefix">On 5/17/2013 1:29 AM, Doerr, Martin
      wrote:<br>
    </div>
    <blockquote
cite="mid:7C9B87B351A4BA4AA9EC95BB4181165668F5446C@DEWDFEMB13A.global.corp.sap"
      type="cite">
      <meta http-equiv="Content-Type" content="text/html;
        charset=ISO-8859-1">
      <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;}
span.EmailStyle17
        {mso-style-type:personal-compose;
        font-family:"Calibri","sans-serif";
        color:windowtext;}
.MsoChpDefault
        {mso-style-type:export-only;
        font-family:"Calibri","sans-serif";
        mso-fareast-language:EN-US;}
@page WordSection1
        {size:612.0pt 792.0pt;
        margin:70.85pt 70.85pt 2.0cm 70.85pt;}
div.WordSection1
        {page:WordSection1;}
--></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" style="text-autospace:none"><span
            style="font-family:"Courier New"" lang="EN-US">Hi
            all,<o:p></o:p></span></p>
        <p class="MsoNormal" style="text-autospace:none"><span
            style="font-family:"Courier New"" lang="EN-US"><o:p> </o:p></span></p>
        <p class="MsoNormal" style="text-autospace:none"><span
            style="font-family:"Courier New"" lang="EN-US">we
            have a question about the interaction between G1 post
            barriers and the refinement thread's concurrent dirty card
            cleaning.<o:p></o:p></span></p>
        <p class="MsoNormal" style="text-autospace:none"><span
            style="font-family:"Courier New"" lang="EN-US">The
            case in which the G1 post barrier sees a clean card is
            obviously not problematic, because it will add an entry in a
            dirty card queue.<o:p></o:p></span></p>
        <p class="MsoNormal" style="text-autospace:none"><span
            style="font-family:"Courier New"" lang="EN-US">However,
            in case in which the Java thread (mutator thread) sees the
            card already dirtied, it won’t enqueue the card again. Which
            is safe as long as its stored oop (1) is seen and processed
            (3’) by the parallel refinement after having cleaned the
            card (1’):<o:p></o:p></span></p>
        <p class="MsoNormal" style="text-autospace:none"><span
            style="font-family:"Courier New"" lang="EN-US"><o:p> </o:p></span></p>
        <p class="MsoNormal" style="text-autospace:none"><span
            style="font-family:"Courier New"" lang="EN-US">Java
            Thread (mutator)              Refinement Thread
            (G1RemSet::concurrentRefineOneCard_impl calls
            oops_on_card_seq_iterate_careful)<o:p></o:p></span></p>
        <p class="MsoNormal" style="text-autospace:none"><span
            style="font-family:"Courier New"" lang="EN-US"><o:p> </o:p></span></p>
        <p class="MsoNormal" style="text-autospace:none"><span
            style="font-family:"Courier New"" lang="EN-US">(1) 
            store(oop)<o:p></o:p></span></p>
        <p class="MsoNormal" style="text-autospace:none"><span
            style="font-family:"Courier New"" lang="EN-US">(
            StoreLoad required here ?)<o:p></o:p></span></p>
        <p class="MsoNormal" style="text-autospace:none"><span
            style="font-family:"Courier New"" lang="EN-US">(2) 
            load(card==dirty)<o:p></o:p></span></p>
        <p class="MsoNormal" style="text-autospace:none"><span
            style="font-family:"Courier New"" lang="EN-US"><o:p> </o:p></span></p>
        <p class="MsoNormal" style="text-autospace:none"><span
            style="font-family:"Courier New"" lang="EN-US">                    
                          (1’) store(card==clean)<o:p></o:p></span></p>
        <p class="MsoNormal" style="text-autospace:none"><span
            style="font-family:"Courier New"" lang="EN-US">                                
              (2’) StoreLoad barrier<o:p></o:p></span></p>
        <p class="MsoNormal" style="text-autospace:none"><span
            style="font-family:"Courier New"" lang="EN-US">                         
                     (3’) load(oop)<o:p></o:p></span></p>
        <p class="MsoNormal" style="text-autospace:none"><span
            style="font-family:"Courier New"" lang="EN-US"><o:p> </o:p></span></p>
        <p class="MsoNormal" style="text-autospace:none"><span
            style="font-family:"Courier New"" lang="EN-US">So
            the refinement thread seems to rely on getting the oop which
            was written BEFORE the (2) load(card==dirty) was observed.<o:p></o:p></span></p>
        <p class="MsoNormal" style="text-autospace:none"><span
            style="font-family:"Courier New"" lang="EN-US">We
            wonder how this ordering is guaranteed? There are no
            StoreLoad barriers in the Java Thread's path. (StoreLoad
            ordering needs explicit barriers even on TSO platforms.)<o:p></o:p></span></p>
        <p class="MsoNormal" style="text-autospace:none"><span
            style="font-family:"Courier New"" lang="EN-US"><o:p> </o:p></span></p>
        <p class="MsoNormal" style="text-autospace:none"><span
            style="font-family:"Courier New"" lang="EN-US">Kind
            regards,<o:p></o:p></span></p>
        <p class="MsoNormal" style="text-autospace:none"><span
            style="font-family:"Courier New"">Martin<o:p></o:p></span></p>
        <p class="MsoNormal"><o:p> </o:p></p>
      </div>
    </blockquote>
    <br>
  </body>
</html>