<div dir="ltr">Regarding strategies for the back end, it might be worth taking a look at the following existing C compilers for the 6502 and related bits:<div><br></div><div><a href="http://www.cc65.org/">http://www.cc65.org/</a> (recent activity moved to to <a href="http://cc65.github.io/cc65/">http://cc65.github.io/cc65/</a>)<br>
</div><div><a href="https://groups.yahoo.com/neo/groups/staticrecompilers/conversations/topics/315">https://groups.yahoo.com/neo/groups/staticrecompilers/conversations/topics/315</a><br></div><div><br></div><div>The topic of targeting the 4502 / 65C02 is an interesting one because it contains features that seem to have been specifically included to support compilation and execution of compiled software:</div>
<div><br></div><div>1. The are instructions that dereference pointers on the stack: LDA (SP+#$nn),y / STA (SP+#$nn),y (but usually misleadingly written as ($nn,SP),y)</div><div>2. The stack can be switched to 16 bit mode with CLE (although it still silently over/under flows).</div>
<div>3. Zero-page can be moved anywhere you like with TBA.</div><div>4. There is a third index, Z, that provides slight register pressure relief.</div><div>5. X, Y and Z can be pushed and pulled from the stack directly (PHX etc)</div>
<div><br></div><div>Ophis is an assembler with full support for the 4502.</div><div><br></div><div>I don't have the time to actively work on an llvm backend for 6502 or 4502, but I would certainly welcome one and am happy to contribute my knowledge of those CPUs and to run code on them etc. For the C65GS it would be nice to be able to create a new optional operating system written in C, rather than assembler. </div>
<div><br></div><div>Paul.</div></div>