To handle passing registers arguments in registers is by doing it in mono_arch_emit_call. Look at how amd64<div>implements this as it uses more than 2 regs. What you basically needs to emit is:</div><div><br></div><div>R100 is your valuetype register</div>
<div><br></div><div>LDADDR R101 <- R100</div><div><div>LOAD_MEMBASE HREG_0, [R101] + 0</div></div><div><div>LOAD_MEMBASE HREG_1, [R101] + 8</div></div><div><div>...</div></div><div><div>LOAD_MEMBASE HREG_n, [R101] + n * 8</div>
</div><div><br></div><div>Where HREG_? is the physical register you need to use.</div><div><br></div><div><br></div><div>You might notice that this code sequence is inefficient since it requires the valuetype to be in memory. This is a limitation</div>
<div>of the current compiler which doesn't support regalloc'ing or scalarzing valuetypes.</div><div><br></div><div><div><div><br><br><div class="gmail_quote">On Mon, Oct 8, 2012 at 7:42 PM, Braddock Gaskill (Contractor) <span dir="ltr"><<a href="mailto:braddock.gaskill@apx-labs.com" target="_blank">braddock.gaskill@apx-labs.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.  I'm still working on the Tilera CPU port.<br>
<br>
The TILE-Gx ABI specifies that structures smaller than 80 bytes should be passed in the first 10 registers.  Larger structs get returned in a caller-allocated space.<br>
<br>
I can't figure out how to specify to the mono runtime that I want to pass a valuetype entirely in the registers.  The special case of a register pair is handled, but 10 registers?<br>
<br>
Is there any way to do this?<br>
<br>
Thanks,<br>
Braddock Gaskill<br>
_______________________________________________<br>
Mono-devel-list mailing list<br>
<a href="mailto:Mono-devel-list@lists.ximian.com">Mono-devel-list@lists.ximian.com</a><br>
<a href="http://lists.ximian.com/mailman/listinfo/mono-devel-list" target="_blank">http://lists.ximian.com/mailman/listinfo/mono-devel-list</a><br>
</blockquote></div><br></div></div></div>