From fac70f2f4494f4d53bafc17ba4ed0d3a0798cff0 Mon Sep 17 00:00:00 2001 From: Anton Korobeynikov Date: Mon, 28 Apr 2008 07:40:07 +0000 Subject: [PATCH] Fix FP return for Win64 ABI llvm-svn: 50342 --- llvm/lib/Target/X86/X86CallingConv.td | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/llvm/lib/Target/X86/X86CallingConv.td b/llvm/lib/Target/X86/X86CallingConv.td index e32a891eba15..60ee0a1bd33d 100644 --- a/llvm/lib/Target/X86/X86CallingConv.td +++ b/llvm/lib/Target/X86/X86CallingConv.td @@ -83,6 +83,10 @@ def RetCC_X86_Win64_C : CallingConv<[ // The X86-Win64 calling convention always returns __m64 values in RAX. CCIfType<[v8i8, v4i16, v2i32, v1i64], CCAssignToReg<[RAX]>>, + // And FP in XMM0 only. + CCIfType<[f32], CCAssignToReg<[XMM0]>>, + CCIfType<[f64], CCAssignToReg<[XMM0]>>, + // Otherwise, everything is the same as 'normal' X86-64 C CC. CCDelegateTo ]>;