<p><br>
On Feb 17, 2013 9:50 PM, "Iain Buclaw" <<a href="mailto:ibuclaw@ubuntu.com">ibuclaw@ubuntu.com</a>> wrote:<br>
><br>
><br>
> On Feb 16, 2013 8:27 PM, "Walter Bright" <<a href="mailto:walter@digitalmars.com">walter@digitalmars.com</a>> wrote:<br>
> ><br>
> ><br>
> > On 2/16/2013 12:17 PM, Johannes Pfau wrote:<br>
> >><br>
> >> Am 16.02.2013 21:06, schrieb Walter Bright:<br>
> >>><br>
> >>> A non-POD cannot be in registers because its address gets taken for constructors/destructors.<br>
> >>><br>
> >>><br>
> >> But creating temporary (bit) copies on the stack is still allowed for non-PODs, right?<br>
> ><br>
> ><br>
> > No.<br>
> ><br>
> ><br>
> >><br>
> >> Wouldn't it be legal to still pass non-PODs in registers when calling functions and only copying them back to the stack if the address is needed? As we pass structs by value anyway, how could this be problematic?<br>

> >><br>
> ><br>
> > No, not allowed. Consider why there are copy constructors, and what they do.<br>
><br>
> Just catching up to speed with this, would this be passed by value on the stack or by reference?  (The latter would be easier, however the former could probably be forced by adding some language hook to the backend in gdc as a temporary workaround).<br>

><br>
> Thanks,<br>
> Iain. <br></p>
<p>By the way Johannes, the issue is clear I think.  You can't make temporaries with non-POD structs?  This is something gdc is a bit zealous in doing this around a lot of the code generation.  So addressing that would certainly fix problems around the other thread where you were marking the type as addressable to prevent it being passed in registers.</p>

<p>Regards<br>
Iain. </p>