www.digitalmars.com         C & C++   DMDScript  

digitalmars.D.learn - Windows X64 Calling conventions

reply Tofu Ninja <joeyemmons yahoo.com> writes:
I am trying to learn the calling conventions in DMD, I am sure I 
will have more than one question about them so as I come across 
them I will ask them in this thread. I am mainly reading the MSDN 
docs on the x64 calls and looking at disassemblies to confirm 
what I learn.


While I was looking at a call of the form void foo(float), I get 
the following disassembly:

movss       xmm0,dword ptr [_TMP0]
sub         rsp,20h
movd        rcx,xmm0
call        void main.foo(float)
add         rsp,20h


My question is, why is it passed twice, both in xmm0 and rcx? The 
MSDN docs say floating point are passed in xmm registers, why is 
it also copied in into rcx? Is it necessary for anything? If it 
was skipped would anything break?


Thanks
Apr 19 2017
parent reply kinke <noone nowhere.com> writes:
On Thursday, 20 April 2017 at 01:16:11 UTC, Tofu Ninja wrote:
 My question is, why is it passed twice, both in xmm0 and rcx? 
 The MSDN docs say floating point are passed in xmm registers, 
 why is it also copied in into rcx? Is it necessary for anything?
That is only required for variadics, quoting MSDN [https://msdn.microsoft.com/en-us/library/dd2wa36c.aspx]:
 For floating-point values only, both the integer and the
 floating-point register will contain the float value in case
 the callee expects the value in the integer registers.
Apr 20 2017
parent Tofu Ninja <joeyemmons yahoo.com> writes:
On Thursday, 20 April 2017 at 08:36:32 UTC, kinke wrote:
 On Thursday, 20 April 2017 at 01:16:11 UTC, Tofu Ninja wrote:
 My question is, why is it passed twice, both in xmm0 and rcx? 
 The MSDN docs say floating point are passed in xmm registers, 
 why is it also copied in into rcx? Is it necessary for 
 anything?
That is only required for variadics, quoting MSDN [https://msdn.microsoft.com/en-us/library/dd2wa36c.aspx]:
 For floating-point values only, both the integer and the
 floating-point register will contain the float value in case
 the callee expects the value in the integer registers.
Oh thanks, that answers my question, but it seem odd that dmd does it no matter what even when variadics are not used.
Apr 20 2017