OK, this is fixed.  Thanks, Jon.  The bug was that the pop of the folded constant did not record the implicit send in the folding, hence pc mapping was wrong.  i.e. 1-1 gets folded away to 0, and the code generator marks the result 0 as being the result of a send, but then the result gets discarded (when it is popped) without being noted in the pc map.  In the machine code there needs to be at least a nop generated, and in the map there needs to be an entry, to correspond to the send of +, so that when machine code pcs are mapped to bytecode pcs there are the correct number of entries in the map.  In the above case, the VM converts the interpreted frame to a machine code frame (coincidently) on the 20th iteration and needs to map the bytecode pc to the correct machine code pc to continue in machine code.  But because of the missing entry in the map for 1-1, the pc mapping machinery answered 0, and the VM ended up jumping into the void.<div>
<br></div><div>Thanks very much for the bug report!</div><div class="gmail_extra"><br><br><div class="gmail_quote">On Fri, Nov 30, 2012 at 9:07 AM, Jon Anderson <span dir="ltr">&lt;<a href="mailto:jonkanderson@gmail.com" target="_blank">jonkanderson@gmail.com</a>&gt;</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 don&#39;t post to lists often, but I thought some of you might be<br>
interested in these few lines of code that crash the CogVM on both<br>
Linux and Windows.  File-in the Smalltalk code below, then evaluate<br>
[nil crashCogVM].  The code uses [1-1] but it could use [1+1] or<br>
[56+98].  I put the code on nil, but that is not important either.  I<br>
think the important thing is that the primitive (+ or -) is evaluated<br>
but the result is not assigned into any variable.  Also important is<br>
that the code is put into a loop that I assume has been JIT optimized.<br>
The image I used is Pharo 1.4 one-click with latest update #14459.<br>
This code does not crash StackVM. Have fun! - Jon.<br>
<br>
!UndefinedObject methodsFor: &#39;crash&#39; stamp: &#39;JonKAnderson 11/29/2012 17:26&#39;!<br>
crashCogVM<br>
        &quot; Evaluate [<br>
                nil crashCogVM ]&quot;<br>
<br>
        | i |<br>
        i := 20.<br>
        1 to: i do: [:d | 1-1 ]<br>
! !<br>
<br>
</blockquote></div><br><br clear="all"><div><br></div>-- <br>best,<div>Eliot</div><br>
</div>