<div dir="ltr">Hi Roman and Christine,<div><br></div><div>I'd like to ask a couple of questions about the barriers, out of curiosity.</div><div><br></div><div>The JEP says:</div><div><br></div><div>"...All reads by the Java Threads indirect through this forwarding pointer. All writes to objects in targeted regions must first copy the object and then write to the object in its new location."<br>
</div><div><br></div><div>Does this mean Shenandoah employs both read and write barriers? The read barrier is a Brooks-style barrier, but the write barrier is more than a plain SATB write barrier (as in G1), right?</div><div>
Will Shenandoah try to reuse the existing write barrier logic in HotSpot and extend it to catch all field writes as opposed to just reference field writes, or will it use some other form of write barrier?</div><div><br></div>
<div>e.g. The Chakra JavaScript engine from Microsoft apparently uses a write barrier implemented via memory protection trick, as noted in one of their blog posts: <a href="http://blogs.msdn.com/b/ie/archive/2012/06/13/advances-in-javascript-performance-in-ie10-and-windows-8.aspx">http://blogs.msdn.com/b/ie/archive/2012/06/13/advances-in-javascript-performance-in-ie10-and-windows-8.aspx</a></div>
<div><br></div><div>"Because Chakra’s collector works concurrently with the main script thread, the running script may modify or create new objects on pages that have already been processed. To make sure such objects aren’t prematurely collected, Chakra write-protects pages before the mark phase starts. Pages that have been written to during the mark phase must be later rescanned on the main script thread. Because leaf objects don’t require such processing, pages from the leaf object space don’t need to be write-protected or rescanned later. This saves precious time on the main script thread, reducing pauses."</div>
<div><br></div><div>Thanks,</div><div>Kris</div></div><div class="gmail_extra"><br><br><div class="gmail_quote">On Fri, Jan 17, 2014 at 11:28 AM, Roman Kennke <span dir="ltr"><<a href="mailto:rkennke@redhat.com" target="_blank">rkennke@redhat.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Hi there,<br>
<br>
Sorry being so silent... we are very happy that the Shenandoah JEP has<br>
finally been posted and would welcome any comments, questions,<br>
discussion from the community.<br>
<br>
Cheers,<br>
Roman<br>
<br>
Am Mittwoch, den 15.01.2014, 11:49 -0800 schrieb<br>
<a href="mailto:mark.reinhold@oracle.com">mark.reinhold@oracle.com</a>:<br>
<div class="HOEnZb"><div class="h5">> Posted: <a href="http://openjdk.java.net/jeps/189" target="_blank">http://openjdk.java.net/jeps/189</a><br>
><br>
> - Mark<br>
<br>
<br>
</div></div></blockquote></div><br></div>