<html>
<head>
<meta content="text/html; charset=ISO-8859-1"
http-equiv="Content-Type">
</head>
<body bgcolor="#FFFFFF" text="#000000">
Ramki,<br>
<br>
On 12/23/2011 04:52 PM, Srinivas Ramakrishna wrote:
<blockquote
cite="mid:CABzyjykZGWpAF55ykdRxkZAtugW=1UKv6Ru77fq7-60h9fWgRw@mail.gmail.com"
type="cite">>From sheer gut instinct (and nothing rational), it
seems better to try and manage the race in the reading of the size
in the from-space field (you know<br>
when you've read a negative size that you've lost a race; add
appropriate asserts to see that the object is forwarded,<br>
use the size from the post-copy image, and bail out), than it is
to mess with the length of the to-space image. Just sheer gut
instinct -- the pre-image is<br>
something we can play with once we have copied it (or have safely
won the race to copy it and know we are the<br>
only ones who will be modifying it). The post-copy image is the
pristine thing that we typically don't want to mess<br>
with lest we screw up. </blockquote>
<br>
I understand what you're saying but I see this slightly differently.
Currently, when we chunk arrays, we actually mutate both images:<br>
<br>
from-image: length field maintains the next index<br>
to-image: copy object, write mark word, and update ref fields as we
process them and we find that they point to objects that have been /
will be moved<br>
<br>
It'd be nice if one of the images was actually pristine / consistent
and currently neither is: each of them might be inconsistent at
different times and for different reasons. Using the length field of
the to-space object to encode the "next index" ensures that at least
the from-image is always consistent and not mutated (apart from the
forwarding reference of course). So, we can always reliably read the
size from the from-image and we won't have to have any special code
to detect which image is consistent and where to read the length
from.<br>
<br>
Regarding accidentally leaving the to-image length inconsistent:
well, that'd be a bug and we'll have to fix it (heap verification
will come across this sooner or later). If we don't update the
length correctly that probably means that we also didn't process the
last chunk on the array, which might leave some reference fields on
it unprocessed, which is not a good situation anyway, length field
being correct or not. :-)<br>
<br>
Tony<br>
<br>
<blockquote
cite="mid:CABzyjykZGWpAF55ykdRxkZAtugW=1UKv6Ru77fq7-60h9fWgRw@mail.gmail.com"
type="cite">OK, I am waving my hands wildly and this is not always
true. But still, see if you can manage the<br>
race in the reading of the pre-image without undue cost.<br>
<br>
I'll think about it too at bed-time today :-)<br>
<br>
Happy Holidays!<br>
-- ramki<br>
<br>
<div class="gmail_quote">On Fri, Dec 23, 2011 at 12:37 AM, Tony
Printezis <span dir="ltr"><<a moz-do-not-send="true"
href="mailto:tony.printezis@oracle.com">tony.printezis@oracle.com</a>></span>
wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0
.8ex;border-left:1px #ccc solid;padding-left:1ex">Hi all,<br>
<br>
I have some bad news, it turns out that there's a subtle race
in the code. I've been testing the marking changes for quite a
while now (which rely on this patch) and I got a single
failure. I'm pretty sure it's the race I describe below. BTW,
there's a question at the end of the e-mail. :-)<br>
<br>
Let's assume two threads, A and B, are racing to forward the
same object array X. Consider the following interleaving:<br>
<br>
Thread A:<br>
is X forwarded? no<br>
<br>
Thread B:<br>
is X forwarded? no<br>
size = X.size();<br>
X' = allocate size<br>
try to forward X to X'? yes<br>
copy X to X'<br>
chunk X, X.length is negative<br>
<br>
Thread A:<br>
size = X.size(); -> BOOM, as size() just read a negative
length<br>
<br>
Interesting this race exists today but it's benign due to
either careful design or sheer luck. When A reads size =
X.size() it will actually get a smaller size than the actual
size of X and will allocate a chunk smaller than X (!!!).
However, given that X is already forwarded it won't need to
copy it and will undo the allocation. So, no harm done.<br>
<br>
Question: Is there a reason why we use the from-space length
field to encode the next index instead of the to-space length
field? If we used the latter we can simplify the code by quite
a lot. I can't immediately think of any issues that this might
cause.<span class="HOEnZb"><font color="#888888"><br>
<br>
Tony</font></span>
<div class="HOEnZb">
<div class="h5"><br>
<br>
On 12/21/2011 5:25 PM, Tony Printezis wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0
.8ex;border-left:1px #ccc solid;padding-left:1ex">
Hi all,<br>
<br>
I have two code reviews (thanks to John and Ramki!). Can
I push or is anybody else still looking at this?<br>
<br>
Tony<br>
<br>
On 12/14/2011 05:17 PM, Tony Printezis wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0
.8ex;border-left:1px #ccc solid;padding-left:1ex">
Hi all,<br>
<br>
Can I have a couple of code review for this small
change?<br>
<br>
<a moz-do-not-send="true"
href="http://cr.openjdk.java.net/%7Etonyp/7121623/webrev.0/"
target="_blank">http://cr.openjdk.java.net/~tonyp/7121623/webrev.0/</a><br>
<br>
The CR has a bit more explanation. The short version
is that I'm now encoding the "start index of the next
chunk" in the from-space length field of a chunked
array (say *that* quickly!) as a negative value to
always be able to distinguish it from the real length.
This will simplify the code for the CR John is
currently working on (6484965) but it's a small,
self-contained change so it's good to get it code
reviewed and pushed separately.<br>
<br>
Tony<br>
<br>
<br>
</blockquote>
</blockquote>
</div>
</div>
</blockquote>
</div>
<br>
</blockquote>
</body>
</html>