diff options
| author | Dan Gohman <gohman@apple.com> | 2008-04-09 17:54:37 +0000 |
|---|---|---|
| committer | Dan Gohman <gohman@apple.com> | 2008-04-09 17:54:37 +0000 |
| commit | 3d074a312562fa26a5d1348190ecdec524802da7 (patch) | |
| tree | 64b339464fb3c463058ab4002f6168aa226ec991 | |
| parent | cbf87313a2dcfd74b945cada8a0bded2bd63dd84 (diff) | |
| download | bcm5719-llvm-3d074a312562fa26a5d1348190ecdec524802da7.tar.gz bcm5719-llvm-3d074a312562fa26a5d1348190ecdec524802da7.zip | |
Add XMM1 as a second return value register for f32 and f64 on x86-64. This
is needed for the x86-64-ABI handling of structs that contain floating-point
members that are returned by value.
llvm-svn: 49441
| -rw-r--r-- | llvm/lib/Target/X86/X86CallingConv.td | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/llvm/lib/Target/X86/X86CallingConv.td b/llvm/lib/Target/X86/X86CallingConv.td index dc2105327ca..8a580df6ae6 100644 --- a/llvm/lib/Target/X86/X86CallingConv.td +++ b/llvm/lib/Target/X86/X86CallingConv.td @@ -65,16 +65,16 @@ def RetCC_X86_32_Fast : CallingConv<[ def RetCC_X86_32_SSE : CallingConv<[ // The X86-32 sseregparm calling convention returns FP values in XMM0 if the // target has SSE2, otherwise it is the C calling convention. - CCIfType<[f32], CCIfSubtarget<"hasSSE2()", CCAssignToReg<[XMM0]>>>, - CCIfType<[f64], CCIfSubtarget<"hasSSE2()", CCAssignToReg<[XMM0]>>>, + CCIfType<[f32], CCIfSubtarget<"hasSSE2()", CCAssignToReg<[XMM0, XMM1]>>>, + CCIfType<[f64], CCIfSubtarget<"hasSSE2()", CCAssignToReg<[XMM0, XMM1]>>>, CCDelegateTo<RetCC_X86Common> ]>; // X86-64 C return-value convention. def RetCC_X86_64_C : CallingConv<[ // The X86-64 calling convention always returns FP values in XMM0. - CCIfType<[f32], CCAssignToReg<[XMM0]>>, - CCIfType<[f64], CCAssignToReg<[XMM0]>>, + CCIfType<[f32], CCAssignToReg<[XMM0, XMM1]>>, + CCIfType<[f64], CCAssignToReg<[XMM0, XMM1]>>, CCDelegateTo<RetCC_X86Common> ]>; |

