.CODE
extern abort:near
extern ffi_closure_win64_inner:near
ALIGN 8
PUBLIC ffi_call_win64
; .safesh ffi_call_win64
ffi_call_win64 proc frame
mov RAX, [RSP] ; movq (%rsp), %rax
mov [rdx], RBP ; movq %rbp, (rdx)
mov [rdx + 8], RAX; movq %rax, 8(rdx)
mov RBP, rdx; movq rdx, %rbp
.pushreg rbp
.setframe rbp, 0
.endprolog
mov RSP, rcx ; movq rcx, %rsp
mov R10, r8 ; movq r8, %r10
mov RCX, [RSP] ; movq (%rsp), %rcx
movsd XMM0, qword ptr [RSP] ; movsd (%rsp), %xmm0
mov RDX, [RSP + 8] ;movq 8(%rsp), %rdx
movsd XMM1, qword ptr [RSP + 8]; movsd 8(%rsp), %xmm1
mov R8, [RSP + 16] ; movq 16(%rsp), %r8
movsd XMM2, qword ptr [RSP + 16] ; movsd 16(%rsp), %xmm2
mov R9, [RSP + 24] ; movq 24(%rsp), %r9
movsd XMM3, qword ptr [RSP + 24] ;movsd 24(%rsp), %xmm3
CALL qword ptr [RBP + 16] ; call *16(%rbp)
mov ECX, [RBP + 24] ; movl 24(%rbp), %ecx
mov R8, [RBP + 32] ; movq 32(%rbp), %r8
LEA R10, ffi_call_win64_tab ; leaq 0f(%rip), %r10
CMP ECX, (15 + 3) ; cmpl $FFI_TYPE_SMALL_STRUCT_4B, %ecx
LEA R10, [R10 + RCX*8] ; leaq (%r10, %rcx, 8), %r10
JA L99 ; ja 99f
JMP R10 ; jmp *%r10
epilogue macro
LEAVE
RET
endm
ALIGN 8
ffi_call_win64_tab LABEL NEAR
ALIGN 8; ORG 0b + 0 * 8
epilogue
ALIGN 8; ORG 0b + 1 * 8
movsxd rax, eax ; movslq %eax, %rax
mov qword ptr [r8], rax; movq %rax, (%r8)
epilogue
ALIGN 8; ORG 0b + 2 * 8
movss dword ptr [r8], xmm0 ; movss %xmm0, (%r8)
epilogue
ALIGN 8; ORG 0b + 3 * 8
movsd qword ptr[r8], xmm0; movsd %xmm0, (%r8)
epilogue
ALIGN 8; ORG 0b + 3 * 8
call abort
ALIGN 8; ORG 0b + 5 * 8
movzx eax, al ;movzbl %al, %eax
mov qword ptr[r8], rax; movq %rax, (%r8)
epilogue
ALIGN 8; ORG 0b + 6 * 8
movsx rax, al ; movsbq %al, %rax
jmp L98
ALIGN 8; ORG 0b + 7 * 8
movzx eax, ax ; movzwl %ax, %eax
mov qword ptr[r8], rax; movq %rax, (%r8)
epilogue
ALIGN 8; ORG 0b + 8 * 8
movsx rax, ax; movswq %ax, %rax
jmp L98
ALIGN 8; ORG 0b + 9 * 8
mov eax, eax; movl %eax, %eax
mov qword ptr[r8], rax ; movq %rax, (%r8)
epilogue
ALIGN 8; ORG 0b + 10 * 8
movsxd rax, eax; movslq %eax, %rax
mov qword ptr [r8], rax; movq %rax, (%r8)
epilogue
ALIGN 8; ORG 0b + 11 * 8
L98 LABEL near
mov qword ptr [r8], rax ; movq %rax, (%r8)
epilogue
ALIGN 8; ORG 0b + 12 * 8
mov qword ptr [r8], rax;movq %rax, (%r8)
epilogue
ALIGN 8; ORG 0b + 13 * 8
epilogue
ALIGN 8; ORG 0b + 14 * 8
mov qword ptr [r8], rax ;movq %rax, (%r8)
epilogue
ALIGN 8; ORG 0b + 15 * 8
call abort
ALIGN 8; ORG 0b + (15 + 1) * 8
mov byte ptr [r8], al ; movb %al, (%r8)
epilogue
ALIGN 8; ORG 0b + (15 + 2) * 8
mov word ptr [r8], ax ; movw %ax, (%r8)
epilogue
ALIGN 8; ORG 0b + (15 + 3) * 8
mov dword ptr [r8], eax ; movl %eax, (%r8)
epilogue
align 8
L99 LABEL near
call abort
epilogue
ffi_call_win64 endp
align 8
PUBLIC ffi_go_closure_win64
ffi_go_closure_win64 proc
mov qword ptr [rsp + 8], rcx; movq %rcx, 8(%rsp)
mov qword ptr [rsp + 16], rdx; movq %rdx, 16(%rsp)
mov qword ptr [rsp + 24], r8; movq %r8, 24(%rsp)
mov qword ptr [rsp + 32], r9 ;movq %r9, 32(%rsp)
mov rcx, qword ptr [r10 + 8]; movq 8(%r10), %rcx
mov rdx, qword ptr [r10 + 16]; movq 16(%r10), %rdx
mov r8, r10 ; movq %r10, %r8
jmp ffi_closure_win64_2
ffi_go_closure_win64 endp
align 8
PUBLIC ffi_closure_win64
ffi_closure_win64 PROC FRAME
mov qword ptr [rsp + 8], rcx; movq %rcx, 8(%rsp)
mov qword ptr [rsp + 16], rdx; movq %rdx, 16(%rsp)
mov qword ptr [rsp + 24], r8; movq %r8, 24(%rsp)
mov qword ptr [rsp + 32], r9; movq %r9, 32(%rsp)
mov rcx, qword ptr [24 + r10] ;movq 24(%r10), %rcx
mov rdx, qword ptr [24 + 8 + r10] ; movq 24+8(%r10), %rdx
mov r8, qword ptr [24+16+r10] ;movq 24+16(%r10), %r8
ffi_closure_win64_2 LABEL near
sub rsp, (32+8+16+32) ;subq $ffi_clo_FS, %rsp
.allocstack (32+8+16+32)
.endprolog
movsd qword ptr [(32+8+16) + rsp], xmm0 ; movsd %xmm0, (32+8+16)(%rsp)
movsd qword ptr [(32+8+16)+8+rsp], xmm1 ; movsd %xmm1, (32+8+16)+8(%rsp)
movsd qword ptr [(32+8+16)+16+rsp], xmm2 ; movsd %xmm2, (32+8+16)+16(%rsp)
movsd qword ptr [(32+8+16)+24+rsp], xmm3 ; movsd %xmm3, (32+8+16)+24(%rsp)
lea r9, [(32+8) + rsp] ; leaq (32+8)(%rsp), %r9
call ffi_closure_win64_inner
mov rax, qword ptr [(32+8) + rsp] ;movq (32+8)(%rsp), %rax
movsd xmm0, qword ptr [rsp + (32+8)] ;movsd (32+8)(%rsp), %xmm0
add rsp, (32+8+16+32) ;addq $ffi_clo_FS, %rsp
ret
ffi_closure_win64 endp
_text ends
end