2007-09-21 22:56:01 -04:00
|
|
|
#include "asm.h"
|
|
|
|
|
|
|
|
#define STACK_REG %rsp
|
|
|
|
#define DS_REG %r14
|
2007-09-26 00:34:37 -04:00
|
|
|
#define RETURN_REG %rax
|
2007-09-21 22:56:01 -04:00
|
|
|
|
|
|
|
#define CELL_SIZE 8
|
2008-11-07 21:33:32 -05:00
|
|
|
#define STACK_PADDING 56
|
2007-09-21 22:56:01 -04:00
|
|
|
|
2008-11-08 21:32:23 -05:00
|
|
|
#define NV_TEMP_REG %rbp
|
|
|
|
|
2008-11-26 05:22:39 -05:00
|
|
|
#define ARITH_TEMP_1 %r8
|
|
|
|
#define ARITH_TEMP_2 %r9
|
|
|
|
#define DIV_RESULT %rax
|
|
|
|
|
2008-11-07 21:33:32 -05:00
|
|
|
#ifdef WINDOWS
|
2007-09-21 22:56:01 -04:00
|
|
|
|
2008-11-07 21:33:32 -05:00
|
|
|
#define ARG0 %rcx
|
|
|
|
#define ARG1 %rdx
|
|
|
|
#define ARG2 %r8
|
|
|
|
#define ARG3 %r9
|
|
|
|
|
|
|
|
#define PUSH_NONVOLATILE \
|
|
|
|
push %r12 ; \
|
|
|
|
push %r13 ; \
|
|
|
|
push %rdi ; \
|
|
|
|
push %rsi ; \
|
|
|
|
push %rbx ; \
|
2008-11-08 21:32:23 -05:00
|
|
|
push %rbp ; \
|
2008-11-07 21:33:32 -05:00
|
|
|
push %rbp
|
|
|
|
|
|
|
|
#define POP_NONVOLATILE \
|
2008-11-08 21:32:23 -05:00
|
|
|
pop %rbp ; \
|
2008-11-07 21:33:32 -05:00
|
|
|
pop %rbp ; \
|
|
|
|
pop %rbx ; \
|
|
|
|
pop %rsi ; \
|
|
|
|
pop %rdi ; \
|
|
|
|
pop %r13 ; \
|
|
|
|
pop %r12
|
|
|
|
|
|
|
|
#else
|
|
|
|
|
|
|
|
#define ARG0 %rdi
|
|
|
|
#define ARG1 %rsi
|
|
|
|
#define ARG2 %rdx
|
|
|
|
#define ARG3 %rcx
|
|
|
|
|
|
|
|
#define PUSH_NONVOLATILE \
|
|
|
|
push %rbx ; \
|
|
|
|
push %rbp ; \
|
|
|
|
push %r12 ; \
|
2008-11-08 21:32:23 -05:00
|
|
|
push %r13 ; \
|
2008-11-07 21:33:32 -05:00
|
|
|
push %r13
|
|
|
|
|
|
|
|
#define POP_NONVOLATILE \
|
2008-11-08 21:32:23 -05:00
|
|
|
pop %r13 ; \
|
2008-11-07 21:33:32 -05:00
|
|
|
pop %r13 ; \
|
|
|
|
pop %r12 ; \
|
|
|
|
pop %rbp ; \
|
|
|
|
pop %rbx
|
|
|
|
|
|
|
|
#endif
|
2007-09-21 22:56:01 -04:00
|
|
|
|
2009-05-12 04:09:15 -04:00
|
|
|
#define QUOT_XT_OFFSET 28
|
2007-09-21 22:56:01 -04:00
|
|
|
|
2007-09-22 02:28:49 -04:00
|
|
|
/* We pass a function pointer to memcpy to work around a Mac OS X
|
2007-09-21 22:56:01 -04:00
|
|
|
ABI limitation which would otherwise require us to do a bizzaro PC-relative
|
|
|
|
trampoline to retrieve the function address */
|
|
|
|
DEF(void,set_callstack,(F_STACK_FRAME *to, F_STACK_FRAME *from, CELL length, void *memcpy)):
|
2008-11-07 21:33:32 -05:00
|
|
|
sub ARG2,ARG0 /* compute new stack pointer */
|
|
|
|
mov ARG0,%rsp
|
|
|
|
call *ARG3 /* call memcpy */
|
2007-09-21 22:56:01 -04:00
|
|
|
ret /* return _with new stack_ */
|
|
|
|
|
2009-05-31 16:02:14 -04:00
|
|
|
DEF(long long,read_timestamp_counter,(void)):
|
|
|
|
mov $0,%rax
|
|
|
|
rdtsc
|
|
|
|
shl $32,%rdx
|
|
|
|
or %rdx,%rax
|
|
|
|
ret
|
|
|
|
|
2009-05-07 13:33:31 -04:00
|
|
|
DEF(void,primitive_inline_cache_miss,(void)):
|
2009-05-06 20:22:22 -04:00
|
|
|
mov (%rsp),%rbx
|
2009-05-07 13:33:31 -04:00
|
|
|
DEF(void,primitive_inline_cache_miss_tail,(void)):
|
2009-04-28 17:58:38 -04:00
|
|
|
sub $STACK_PADDING,%rsp
|
2009-05-06 20:22:22 -04:00
|
|
|
mov %rbx,ARG0
|
2009-04-28 17:58:38 -04:00
|
|
|
call MANGLE(inline_cache_miss)
|
|
|
|
add $STACK_PADDING,%rsp
|
2009-04-30 19:00:49 -04:00
|
|
|
jmp *%rax
|
2009-04-28 17:58:38 -04:00
|
|
|
|
2009-09-08 16:29:29 -04:00
|
|
|
DEF(void,get_sse_env,(void*)):
|
2009-09-14 04:14:48 -04:00
|
|
|
stmxcsr (%rdi)
|
|
|
|
ret
|
2009-09-05 20:48:13 -04:00
|
|
|
|
2009-09-08 16:29:29 -04:00
|
|
|
DEF(void,set_sse_env,(const void*)):
|
2009-09-14 04:14:48 -04:00
|
|
|
ldmxcsr (%rdi)
|
|
|
|
ret
|
2009-09-08 16:29:29 -04:00
|
|
|
|
|
|
|
DEF(void,get_x87_env,(void*)):
|
2009-09-14 04:14:48 -04:00
|
|
|
fnstsw (%rdi)
|
|
|
|
fnstcw 2(%rdi)
|
|
|
|
ret
|
2009-09-08 16:29:29 -04:00
|
|
|
|
|
|
|
DEF(void,set_x87_env,(const void*)):
|
2009-09-14 04:14:48 -04:00
|
|
|
fnclex
|
|
|
|
fldcw 2(%rdi)
|
|
|
|
ret
|
2009-09-05 20:48:13 -04:00
|
|
|
|
2007-09-21 22:56:01 -04:00
|
|
|
#include "cpu-x86.S"
|