mirror of
https://github.com/corda/corda.git
synced 2025-01-23 21:08:48 +00:00
compile-x86.S bugfixes and cleanups
This commit is contained in:
parent
14613193fa
commit
f30e31e5f6
@ -35,6 +35,8 @@
|
|||||||
#define CONTINUATION_LENGTH 56
|
#define CONTINUATION_LENGTH 56
|
||||||
#define CONTINUATION_BODY 64
|
#define CONTINUATION_BODY 64
|
||||||
|
|
||||||
|
#define CALLEE_SAVED_REGISTER_FOOTPRINT 48
|
||||||
|
|
||||||
.globl GLOBAL(vmInvoke)
|
.globl GLOBAL(vmInvoke)
|
||||||
GLOBAL(vmInvoke):
|
GLOBAL(vmInvoke):
|
||||||
pushq %rbp
|
pushq %rbp
|
||||||
@ -48,8 +50,8 @@ GLOBAL(vmInvoke):
|
|||||||
// %r9 : returnType (ignored)
|
// %r9 : returnType (ignored)
|
||||||
|
|
||||||
// allocate stack space, adding room for callee-saved registers
|
// allocate stack space, adding room for callee-saved registers
|
||||||
subq %r8,%rsp
|
subq %r8,%rsp
|
||||||
subq $48,%rsp
|
subq $CALLEE_SAVED_REGISTER_FOOTPRINT,%rsp
|
||||||
|
|
||||||
// save callee-saved registers
|
// save callee-saved registers
|
||||||
movq %rsp,%r9
|
movq %rsp,%r9
|
||||||
@ -91,11 +93,14 @@ GLOBAL(vmInvoke_returnAddress):
|
|||||||
cmpq $0,%rcx
|
cmpq $0,%rcx
|
||||||
je LOCAL(vmInvoke_exit)
|
je LOCAL(vmInvoke_exit)
|
||||||
|
|
||||||
|
// allocate a frame of size (continuation.length * BYTES_PER_WORD)
|
||||||
|
// + CALLEE_SAVED_REGISTER_FOOTPRINT
|
||||||
movq CONTINUATION_LENGTH(%rcx),%rsi
|
movq CONTINUATION_LENGTH(%rcx),%rsi
|
||||||
shlq $3,%rsi
|
shlq $3,%rsi
|
||||||
subq %rsi,%rsp
|
subq %rsi,%rsp
|
||||||
subq $48,%rsp
|
subq $CALLEE_SAVED_REGISTER_FOOTPRINT,%rsp
|
||||||
|
|
||||||
|
// copy the continuation body into the frame
|
||||||
leaq CONTINUATION_BODY(%rcx),%rdi
|
leaq CONTINUATION_BODY(%rcx),%rdi
|
||||||
|
|
||||||
movq $0,%r9
|
movq $0,%r9
|
||||||
@ -110,15 +115,18 @@ LOCAL(vmInvoke_continuationTest):
|
|||||||
cmpq %rsi,%r9
|
cmpq %rsi,%r9
|
||||||
jb LOCAL(vmInvoke_continuationLoop)
|
jb LOCAL(vmInvoke_continuationLoop)
|
||||||
|
|
||||||
|
// set the return address to vmInvoke_returnAddress
|
||||||
movq CONTINUATION_RETURN_ADDRESS_OFFSET(%rcx),%rdi
|
movq CONTINUATION_RETURN_ADDRESS_OFFSET(%rcx),%rdi
|
||||||
movq vmInvoke_returnAddress@GOTPCREL(%rip),%r10
|
movq vmInvoke_returnAddress@GOTPCREL(%rip),%r10
|
||||||
movq %r10,(%rsp,%rdi,1)
|
movq %r10,(%rsp,%rdi,1)
|
||||||
|
|
||||||
|
// save the current base pointer in the frame and update it
|
||||||
movq CONTINUATION_FRAME_POINTER_OFFSET(%rcx),%rdi
|
movq CONTINUATION_FRAME_POINTER_OFFSET(%rcx),%rdi
|
||||||
movq %rbp,(%rsp,%rdi,1)
|
movq %rbp,(%rsp,%rdi,1)
|
||||||
addq %rsp,%rdi
|
addq %rsp,%rdi
|
||||||
movq %rdi,%rbp
|
movq %rdi,%rbp
|
||||||
|
|
||||||
|
// consume the continuation
|
||||||
movq CONTINUATION_NEXT(%rcx),%rdi
|
movq CONTINUATION_NEXT(%rcx),%rdi
|
||||||
movq %rdi,THREAD_CONTINUATION(%rbx)
|
movq %rdi,THREAD_CONTINUATION(%rbx)
|
||||||
|
|
||||||
@ -141,9 +149,10 @@ LOCAL(vmInvoke_handleException):
|
|||||||
LOCAL(vmInvoke_exit):
|
LOCAL(vmInvoke_exit):
|
||||||
#endif // AVIAN_CONTINUATIONS
|
#endif // AVIAN_CONTINUATIONS
|
||||||
|
|
||||||
// restore callee-saved registers
|
// restore callee-saved registers (below the stack pointer, but in
|
||||||
|
// the red zone)
|
||||||
movq %rsp,%r9
|
movq %rsp,%r9
|
||||||
subq $48,%r9
|
subq $CALLEE_SAVED_REGISTER_FOOTPRINT,%r9
|
||||||
|
|
||||||
movq 0(%r9),%rbx
|
movq 0(%r9),%rbx
|
||||||
movq 8(%r9),%r12
|
movq 8(%r9),%r12
|
||||||
@ -161,16 +170,23 @@ GLOBAL(vmJumpAndInvoke):
|
|||||||
// %rdi: thread
|
// %rdi: thread
|
||||||
// %rsi: address
|
// %rsi: address
|
||||||
// %rdx: base
|
// %rdx: base
|
||||||
// %rcx: stack
|
// %rcx: (unused)
|
||||||
// %r8 : argumentFootprint
|
// %r8 : argumentFootprint
|
||||||
// %r9 : arguments
|
// %r9 : arguments
|
||||||
// 8(%rsp): frameSize
|
// 8(%rsp): frameSize
|
||||||
|
|
||||||
movq %rdx,%rbp
|
movq %rdx,%rbp
|
||||||
|
|
||||||
movq %rdi,%rbx
|
// restore (pseudo)-stack pointer (we don't want to touch the real
|
||||||
|
// stack pointer, since we haven't copied the arguments yet)
|
||||||
|
movq %rbp,%rcx
|
||||||
|
|
||||||
subq 8(%rsp),%rcx
|
// allocate new frame, adding room for callee-saved registers
|
||||||
|
movl 8(%rsp),%eax
|
||||||
|
subq %rax,%rcx
|
||||||
|
subq $CALLEE_SAVED_REGISTER_FOOTPRINT,%rcx
|
||||||
|
|
||||||
|
movq %rdi,%rbx
|
||||||
|
|
||||||
// set return address
|
// set return address
|
||||||
movq vmInvoke_returnAddress@GOTPCREL(%rip),%r10
|
movq vmInvoke_returnAddress@GOTPCREL(%rip),%r10
|
||||||
@ -189,6 +205,8 @@ LOCAL(vmJumpAndInvoke_argumentTest):
|
|||||||
cmpq %r8,%r11
|
cmpq %r8,%r11
|
||||||
jb LOCAL(vmJumpAndInvoke_argumentLoop)
|
jb LOCAL(vmJumpAndInvoke_argumentLoop)
|
||||||
|
|
||||||
|
// the arguments have been copied, so we can set the real stack
|
||||||
|
// pointer now
|
||||||
movq %rcx,%rsp
|
movq %rcx,%rsp
|
||||||
|
|
||||||
jmp *%rsi
|
jmp *%rsi
|
||||||
@ -213,6 +231,8 @@ LOCAL(vmJumpAndInvoke_argumentTest):
|
|||||||
#define CONTINUATION_LENGTH 28
|
#define CONTINUATION_LENGTH 28
|
||||||
#define CONTINUATION_BODY 32
|
#define CONTINUATION_BODY 32
|
||||||
|
|
||||||
|
#define CALLEE_SAVED_REGISTER_FOOTPRINT 16
|
||||||
|
|
||||||
.globl GLOBAL(vmInvoke)
|
.globl GLOBAL(vmInvoke)
|
||||||
GLOBAL(vmInvoke):
|
GLOBAL(vmInvoke):
|
||||||
pushl %ebp
|
pushl %ebp
|
||||||
@ -227,7 +247,7 @@ GLOBAL(vmInvoke):
|
|||||||
|
|
||||||
// allocate stack space, adding room for callee-saved registers
|
// allocate stack space, adding room for callee-saved registers
|
||||||
subl 24(%ebp),%esp
|
subl 24(%ebp),%esp
|
||||||
subl $16,%esp
|
subl $CALLEE_SAVED_REGISTER_FOOTPRINT,%esp
|
||||||
|
|
||||||
// save callee-saved registers
|
// save callee-saved registers
|
||||||
movl %esp,%ecx
|
movl %esp,%ecx
|
||||||
@ -259,9 +279,10 @@ LOCAL(vmInvoke_argumentTest):
|
|||||||
|
|
||||||
.globl vmInvoke_returnAddress
|
.globl vmInvoke_returnAddress
|
||||||
vmInvoke_returnAddress:
|
vmInvoke_returnAddress:
|
||||||
// restore stack pointer
|
// restore stack pointer, preserving the area containing saved
|
||||||
|
// registers
|
||||||
movl %ebp,%ecx
|
movl %ebp,%ecx
|
||||||
subl $16,%ecx
|
subl $CALLEE_SAVED_REGISTER_FOOTPRINT,%ecx
|
||||||
movl %ecx,%esp
|
movl %ecx,%esp
|
||||||
|
|
||||||
#ifdef AVIAN_CONTINUATIONS
|
#ifdef AVIAN_CONTINUATIONS
|
||||||
@ -270,11 +291,12 @@ vmInvoke_returnAddress:
|
|||||||
cmpl $0,%ecx
|
cmpl $0,%ecx
|
||||||
je LOCAL(vmInvoke_exit)
|
je LOCAL(vmInvoke_exit)
|
||||||
|
|
||||||
|
// allocate a frame of size (continuation.length * BYTES_PER_WORD)
|
||||||
movl CONTINUATION_LENGTH(%ecx),%esi
|
movl CONTINUATION_LENGTH(%ecx),%esi
|
||||||
shll $2,%esi
|
shll $2,%esi
|
||||||
subl %esi,%esp
|
subl %esi,%esp
|
||||||
subl $16,%esp
|
|
||||||
|
|
||||||
|
// copy the continuation body into the frame
|
||||||
leal CONTINUATION_BODY(%ecx),%edi
|
leal CONTINUATION_BODY(%ecx),%edi
|
||||||
|
|
||||||
push %eax
|
push %eax
|
||||||
@ -295,17 +317,20 @@ LOCAL(vmInvoke_continuationTest):
|
|||||||
pop %edx
|
pop %edx
|
||||||
pop %eax
|
pop %eax
|
||||||
|
|
||||||
|
// set the return address to vmInvoke_returnAddress
|
||||||
movl CONTINUATION_RETURN_ADDRESS_OFFSET(%ecx),%edi
|
movl CONTINUATION_RETURN_ADDRESS_OFFSET(%ecx),%edi
|
||||||
call LOCAL(getPC)
|
call LOCAL(getPC)
|
||||||
addl $_GLOBAL_OFFSET_TABLE_,%esi
|
addl $_GLOBAL_OFFSET_TABLE_,%esi
|
||||||
movl vmInvoke_returnAddress@GOT(%esi),%esi
|
movl vmInvoke_returnAddress@GOT(%esi),%esi
|
||||||
movl %esi,(%esp,%edi,1)
|
movl %esi,(%esp,%edi,1)
|
||||||
|
|
||||||
|
// save the current base pointer in the frame and update it
|
||||||
movl CONTINUATION_FRAME_POINTER_OFFSET(%ecx),%edi
|
movl CONTINUATION_FRAME_POINTER_OFFSET(%ecx),%edi
|
||||||
movl %ebp,(%esp,%edi,1)
|
movl %ebp,(%esp,%edi,1)
|
||||||
addl %esp,%edi
|
addl %esp,%edi
|
||||||
movl %edi,%ebp
|
movl %edi,%ebp
|
||||||
|
|
||||||
|
// consume the continuation
|
||||||
movl CONTINUATION_NEXT(%ecx),%edi
|
movl CONTINUATION_NEXT(%ecx),%edi
|
||||||
movl %edi,THREAD_CONTINUATION(%ebx)
|
movl %edi,THREAD_CONTINUATION(%ebx)
|
||||||
|
|
||||||
@ -337,7 +362,7 @@ LOCAL(vmInvoke_exit):
|
|||||||
// handle return value based on expected type
|
// handle return value based on expected type
|
||||||
movl 28(%ebp),%ecx
|
movl 28(%ebp),%ecx
|
||||||
|
|
||||||
addl $16,%esp
|
addl $CALLEE_SAVED_REGISTER_FOOTPRINT,%esp
|
||||||
|
|
||||||
LOCAL(vmInvoke_void):
|
LOCAL(vmInvoke_void):
|
||||||
cmpl $VOID_TYPE,%ecx
|
cmpl $VOID_TYPE,%ecx
|
||||||
@ -366,15 +391,22 @@ GLOBAL(vmJumpAndInvoke):
|
|||||||
// 4(%esp): thread
|
// 4(%esp): thread
|
||||||
// 8(%esp): address
|
// 8(%esp): address
|
||||||
// 12(%esp): base
|
// 12(%esp): base
|
||||||
// 16(%esp): stack
|
// 16(%esp): (unused)
|
||||||
// 20(%esp): argumentFootprint
|
// 20(%esp): argumentFootprint
|
||||||
// 24(%esp): arguments
|
// 24(%esp): arguments
|
||||||
// 28(%esp): frameSize
|
// 28(%esp): frameSize
|
||||||
|
|
||||||
movl 12(%esp),%ebp
|
movl 12(%esp),%ebp
|
||||||
|
|
||||||
movl 16(%esp),%ecx
|
// restore (pseudo)-stack pointer (we don't want to touch the real
|
||||||
|
// stack pointer, since we haven't copied the arguments yet)
|
||||||
|
movl %ebp,%ecx
|
||||||
|
|
||||||
|
// allocate new frame, adding room for callee-saved registers
|
||||||
subl 28(%esp),%ecx
|
subl 28(%esp),%ecx
|
||||||
|
subl $CALLEE_SAVED_REGISTER_FOOTPRINT,%ecx
|
||||||
|
|
||||||
|
movl 4(%esp),%ebx
|
||||||
|
|
||||||
// set return address
|
// set return address
|
||||||
call LOCAL(getPC)
|
call LOCAL(getPC)
|
||||||
@ -397,8 +429,10 @@ LOCAL(vmJumpAndInvoke_argumentTest):
|
|||||||
cmpl %edx,%esi
|
cmpl %edx,%esi
|
||||||
jb LOCAL(vmJumpAndInvoke_argumentLoop)
|
jb LOCAL(vmJumpAndInvoke_argumentLoop)
|
||||||
|
|
||||||
movl 4(%esp),%ebx
|
|
||||||
movl 8(%esp),%esi
|
movl 8(%esp),%esi
|
||||||
|
|
||||||
|
// the arguments have been copied, so we can set the real stack
|
||||||
|
// pointer now
|
||||||
movl %ecx,%esp
|
movl %ecx,%esp
|
||||||
|
|
||||||
jmp *%esi
|
jmp *%esi
|
||||||
|
Loading…
Reference in New Issue
Block a user