Commit 7c9b5251 authored by Alexandre Julliard's avatar Alexandre Julliard

winebuild: Use the correct registers for relay debugging of floating point arguments on x86_64.

parent 451d5043
...@@ -378,6 +378,10 @@ __ASM_GLOBAL_FUNC( call_entry_point, ...@@ -378,6 +378,10 @@ __ASM_GLOBAL_FUNC( call_entry_point,
"movq 8(%rsp),%rdx\n\t" "movq 8(%rsp),%rdx\n\t"
"movq 16(%rsp),%r8\n\t" "movq 16(%rsp),%r8\n\t"
"movq 24(%rsp),%r9\n\t" "movq 24(%rsp),%r9\n\t"
"movq %rcx,%xmm0\n\t"
"movq %rdx,%xmm1\n\t"
"movq %r8,%xmm2\n\t"
"movq %r9,%xmm3\n\t"
"callq *%rax\n\t" "callq *%rax\n\t"
"leaq -16(%rbp),%rsp\n\t" "leaq -16(%rbp),%rsp\n\t"
"popq %rdi\n\t" "popq %rdi\n\t"
......
...@@ -58,6 +58,12 @@ static inline int needs_relay( const ORDDEF *odp ) ...@@ -58,6 +58,12 @@ static inline int needs_relay( const ORDDEF *odp )
return 1; return 1;
} }
static int is_float_arg( const ORDDEF *odp, unsigned int arg )
{
if (arg >= odp->u.func.nb_args) return 0;
return (odp->u.func.args[arg] == ARG_FLOAT || odp->u.func.args[arg] == ARG_DOUBLE);
}
/* check if dll will output relay thunks */ /* check if dll will output relay thunks */
int has_relays( DLLSPEC *spec ) int has_relays( DLLSPEC *spec )
{ {
...@@ -189,10 +195,14 @@ static void output_relay_debug( DLLSPEC *spec ) ...@@ -189,10 +195,14 @@ static void output_relay_debug( DLLSPEC *spec )
output( "\t.cfi_startproc\n" ); output( "\t.cfi_startproc\n" );
output( "\tsubq $40,%%rsp\n" ); output( "\tsubq $40,%%rsp\n" );
output( "\t.cfi_adjust_cfa_offset 40\n" ); output( "\t.cfi_adjust_cfa_offset 40\n" );
output( "\tmovq %%rcx,48(%%rsp)\n" ); switch (args)
output( "\tmovq %%rdx,56(%%rsp)\n" ); {
output( "\tmovq %%r8,64(%%rsp)\n" ); default: output( "\tmovq %%%s,72(%%rsp)\n", is_float_arg( odp, 3 ) ? "xmm3" : "r9" );
output( "\tmovq %%r9,72(%%rsp)\n" ); case 3: output( "\tmovq %%%s,64(%%rsp)\n", is_float_arg( odp, 2 ) ? "xmm2" : "r8" );
case 2: output( "\tmovq %%%s,56(%%rsp)\n", is_float_arg( odp, 1 ) ? "xmm1" : "rdx" );
case 1: output( "\tmovq %%%s,48(%%rsp)\n", is_float_arg( odp, 0 ) ? "xmm0" : "rcx" );
case 0: break;
}
output( "\tleaq 40(%%rsp),%%r8\n" ); output( "\tleaq 40(%%rsp),%%r8\n" );
output( "\tmovq $%u,%%rdx\n", (flags << 24) | (args << 16) | (i - spec->base) ); output( "\tmovq $%u,%%rdx\n", (flags << 24) | (args << 16) | (i - spec->base) );
output( "\tleaq .L__wine_spec_relay_descr(%%rip),%%rcx\n" ); output( "\tleaq .L__wine_spec_relay_descr(%%rip),%%rcx\n" );
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment