corda/src/compile.S

142 lines
2.1 KiB
ArmAsm
Raw Normal View History

#include "types.h"
.text
#ifdef __x86_64__
2007-10-04 00:41:54 +00:00
.globl vmInvoke
vmInvoke:
pushq %rbp
movq %rsp,%rbp
// rbx is a callee-saved register (so are r12-r15, but we don't use those)
pushq %rbx
2007-12-11 21:26:59 +00:00
// %rdi: thread
// %rsi: function
// %rdx: stack
// %rcx: stackSize
// %r8 : returnType
mov %rdi,%rbx
// reserve space for arguments
2007-12-11 21:26:59 +00:00
pushq %rcx
subq %rcx,%rsp
// copy memory arguments into place
2007-12-11 21:26:59 +00:00
movq $0,%r9
jmp test
loop:
2007-12-11 21:26:59 +00:00
movq %r9,%rax
movq %r9,%r10
addq %rsp,%r10
addq %rdx,%rax
movq (%rax),%rax
2007-12-11 21:26:59 +00:00
movq %rax,(%r10)
addq $8,%r9
test:
2007-12-11 21:26:59 +00:00
cmpq %rcx,%r9
jb loop
// call function
2007-12-11 21:26:59 +00:00
call *%rsi
// pop arguments
addq -16(%rbp),%rsp
addq $8,%rsp
popq %rbx
movq %rbp,%rsp
popq %rbp
ret
2007-10-04 00:41:54 +00:00
.globl vmJump
vmJump:
2007-10-04 22:41:19 +00:00
movq %rsi,%rbp
movq %rdx,%rsp
jmp *%rdi
#elif defined __i386__
2007-10-04 00:41:54 +00:00
.globl vmInvoke
vmInvoke:
pushl %ebp
movl %esp,%ebp
// ebx, esi and edi are callee-saved registers
pushl %ebx
pushl %esi
pushl %edi
2007-12-11 21:26:59 +00:00
// 8(%ebp): thread
// 12(%ebp): function
// 16(%ebp): stack
// 20(%ebp): stackSize
// 24(%ebp): returnType
mov 8(%ebp),%ebx
// reserve space for arguments
2007-12-11 21:26:59 +00:00
subl 20(%ebp),%esp
// copy arguments into place
movl $0,%ecx
jmp test
loop:
movl %ecx,%eax
movl %ecx,%edx
addl %esp,%edx
2007-12-11 21:26:59 +00:00
addl 16(%ebp),%eax
movl (%eax),%eax
movl %eax,(%edx)
addl $4,%ecx
test:
2007-12-11 21:26:59 +00:00
cmpl 20(%ebp),%ecx
jb loop
// call function
2007-12-11 21:26:59 +00:00
call *12(%ebp)
// pop arguments
2007-12-11 21:26:59 +00:00
addl 20(%ebp),%esp
// handle return value based on expected type
2007-12-11 21:26:59 +00:00
movl 24(%ebp),%ecx
void:
cmpl $VOID_TYPE,%ecx
jne int64
jmp exit
int64:
cmpl $INT64_TYPE,%ecx
jne int32
jmp exit
int32:
movl $0,%edx
exit:
popl %edi
popl %esi
popl %ebx
movl %ebp,%esp
popl %ebp
ret
2007-10-04 00:41:54 +00:00
.globl vmJump
vmJump:
2007-10-04 03:19:39 +00:00
movl 4(%esp),%eax
2007-10-04 22:41:19 +00:00
movl 8(%esp),%ebp
movl 12(%esp),%esp
2007-10-04 03:19:39 +00:00
jmp *%eax
2007-10-04 00:41:54 +00:00
#else
# error unsupported platform
#endif