added lookup_vm and removed last usage of vm from windows code

db4
Phil Dawes 2009-08-24 20:46:34 +01:00
parent 12ca7bdc57
commit 9cac5e8aa9
9 changed files with 50 additions and 31 deletions

View File

@ -165,7 +165,7 @@ void factorvm::memory_signal_handler_impl()
void memory_signal_handler_impl() void memory_signal_handler_impl()
{ {
return vm->memory_signal_handler_impl(); SIGNAL_VM_PTR->misc_signal_handler_impl();
} }
void factorvm::misc_signal_handler_impl() void factorvm::misc_signal_handler_impl()
@ -175,7 +175,7 @@ void factorvm::misc_signal_handler_impl()
void misc_signal_handler_impl() void misc_signal_handler_impl()
{ {
vm->misc_signal_handler_impl(); SIGNAL_VM_PTR->misc_signal_handler_impl();
} }
void factorvm::fp_signal_handler_impl() void factorvm::fp_signal_handler_impl()
@ -185,7 +185,7 @@ void factorvm::fp_signal_handler_impl()
void fp_signal_handler_impl() void fp_signal_handler_impl()
{ {
vm->fp_signal_handler_impl(); SIGNAL_VM_PTR->fp_signal_handler_impl();
} }
} }

View File

@ -27,13 +27,6 @@ PRIMITIVE(die);
PRIMITIVE(call_clear); PRIMITIVE(call_clear);
PRIMITIVE(unimplemented); PRIMITIVE(unimplemented);
/* Global variables used to pass fault handler state from signal handler to
user-space */
extern cell signal_number;
extern cell signal_fault_addr;
extern unsigned int signal_fpu_status;
extern stack_frame *signal_callstack_top;
void memory_signal_handler_impl(); void memory_signal_handler_impl();
void fp_signal_handler_impl(); void fp_signal_handler_impl();
void misc_signal_handler_impl(); void misc_signal_handler_impl();

View File

@ -5,6 +5,19 @@ namespace factor
factorvm *vm; factorvm *vm;
unordered_map<long,factorvm*> thread_vms;
factorvm *lookup_vm(long threadid)
{
return thread_vms[threadid];
}
void register_vm(long threadid, factorvm *vm)
{
thread_vms[threadid] = vm;
}
void factorvm::default_parameters(vm_parameters *p) void factorvm::default_parameters(vm_parameters *p)
{ {
p->image_path = NULL; p->image_path = NULL;
@ -199,6 +212,8 @@ void factorvm::factor_sleep(long us)
void factorvm::start_standalone_factor(int argc, vm_char **argv) void factorvm::start_standalone_factor(int argc, vm_char **argv)
{ {
printf("thread id is %d\n",GetCurrentThreadId());fflush(stdout);
register_vm(GetCurrentThreadId(),this);
vm_parameters p; vm_parameters p;
default_parameters(&p); default_parameters(&p);
init_parameters_from_args(&p,argc,argv); init_parameters_from_args(&p,argc,argv);

View File

@ -42,17 +42,17 @@ static void call_fault_handler(
/* Are we in compiled Factor code? Then use the current stack pointer */ /* Are we in compiled Factor code? Then use the current stack pointer */
if(vm->in_code_heap_p(MACH_PROGRAM_COUNTER(thread_state))) if(vm->in_code_heap_p(MACH_PROGRAM_COUNTER(thread_state)))
signal_callstack_top = (stack_frame *)MACH_STACK_POINTER(thread_state); vm->signal_callstack_top = (stack_frame *)MACH_STACK_POINTER(thread_state);
/* Are we in C? Then use the saved callstack top */ /* Are we in C? Then use the saved callstack top */
else else
signal_callstack_top = NULL; vm->signal_callstack_top = NULL;
MACH_STACK_POINTER(thread_state) = fix_stack_pointer(MACH_STACK_POINTER(thread_state)); MACH_STACK_POINTER(thread_state) = fix_stack_pointer(MACH_STACK_POINTER(thread_state));
/* Now we point the program counter at the right handler function. */ /* Now we point the program counter at the right handler function. */
if(exception == EXC_BAD_ACCESS) if(exception == EXC_BAD_ACCESS)
{ {
signal_fault_addr = MACH_EXC_STATE_FAULT(exc_state); vm->signal_fault_addr = MACH_EXC_STATE_FAULT(exc_state);
MACH_PROGRAM_COUNTER(thread_state) = (cell)memory_signal_handler_impl; MACH_PROGRAM_COUNTER(thread_state) = (cell)memory_signal_handler_impl;
} }
else if(exception == EXC_ARITHMETIC && code != MACH_EXC_INTEGER_DIV) else if(exception == EXC_ARITHMETIC && code != MACH_EXC_INTEGER_DIV)
@ -63,7 +63,7 @@ static void call_fault_handler(
} }
else else
{ {
signal_number = (exception == EXC_ARITHMETIC ? SIGFPE : SIGABRT); vm->signal_number = (exception == EXC_ARITHMETIC ? SIGFPE : SIGABRT);
MACH_PROGRAM_COUNTER(thread_state) = (cell)misc_signal_handler_impl; MACH_PROGRAM_COUNTER(thread_state) = (cell)misc_signal_handler_impl;
} }
} }

View File

@ -120,15 +120,15 @@ static stack_frame *uap_stack_pointer(void *uap)
void memory_signal_handler(int signal, siginfo_t *siginfo, void *uap) void memory_signal_handler(int signal, siginfo_t *siginfo, void *uap)
{ {
signal_fault_addr = (cell)siginfo->si_addr; vm->signal_fault_addr = (cell)siginfo->si_addr;
signal_callstack_top = uap_stack_pointer(uap); vm->signal_callstack_top = uap_stack_pointer(uap);
UAP_PROGRAM_COUNTER(uap) = (cell)memory_signal_handler_impl; UAP_PROGRAM_COUNTER(uap) = (cell)memory_signal_handler_impl;
} }
void misc_signal_handler(int signal, siginfo_t *siginfo, void *uap) void misc_signal_handler(int signal, siginfo_t *siginfo, void *uap)
{ {
signal_number = signal; vm->signal_number = signal;
signal_callstack_top = uap_stack_pointer(uap); vm->signal_callstack_top = uap_stack_pointer(uap);
UAP_PROGRAM_COUNTER(uap) = (cell)misc_signal_handler_impl; UAP_PROGRAM_COUNTER(uap) = (cell)misc_signal_handler_impl;
} }

View File

@ -58,4 +58,5 @@ void sleep_micros(cell usec);
void open_console(); void open_console();
#define SIGNAL_VM_PTR vm
} }

View File

@ -3,8 +3,8 @@
namespace factor namespace factor
{ {
void start_thread(void *(*start_routine)(void *),void *args){ void *start_thread(void *(*start_routine)(void *),void *args){
CreateThread(NULL, 0, (LPTHREAD_START_ROUTINE)start_routine, args, 0, 0); return CreateThread(NULL, 0, (LPTHREAD_START_ROUTINE)start_routine, args, 0, 0);
} }
@ -18,18 +18,19 @@ s64 factorvm::current_micros()
FACTOR_STDCALL LONG exception_handler(PEXCEPTION_POINTERS pe) FACTOR_STDCALL LONG exception_handler(PEXCEPTION_POINTERS pe)
{ {
printf("exception handler %d\n",GetCurrentThreadId());
factorvm *myvm = lookup_vm(GetCurrentThreadId());
PEXCEPTION_RECORD e = (PEXCEPTION_RECORD)pe->ExceptionRecord; PEXCEPTION_RECORD e = (PEXCEPTION_RECORD)pe->ExceptionRecord;
CONTEXT *c = (CONTEXT*)pe->ContextRecord; CONTEXT *c = (CONTEXT*)pe->ContextRecord;
if(vm->in_code_heap_p(c->EIP)) if(myvm->in_code_heap_p(c->EIP))
signal_callstack_top = (stack_frame *)c->ESP; myvm->signal_callstack_top = (stack_frame *)c->ESP;
else else
signal_callstack_top = NULL; myvm->signal_callstack_top = NULL;
switch (e->ExceptionCode) switch (e->ExceptionCode) {
{
case EXCEPTION_ACCESS_VIOLATION: case EXCEPTION_ACCESS_VIOLATION:
signal_fault_addr = e->ExceptionInformation[1]; myvm->signal_fault_addr = e->ExceptionInformation[1];
c->EIP = (cell)memory_signal_handler_impl; c->EIP = (cell)memory_signal_handler_impl;
break; break;
@ -42,7 +43,7 @@ FACTOR_STDCALL LONG exception_handler(PEXCEPTION_POINTERS pe)
case STATUS_FLOAT_UNDERFLOW: case STATUS_FLOAT_UNDERFLOW:
case STATUS_FLOAT_MULTIPLE_FAULTS: case STATUS_FLOAT_MULTIPLE_FAULTS:
case STATUS_FLOAT_MULTIPLE_TRAPS: case STATUS_FLOAT_MULTIPLE_TRAPS:
signal_fpu_status = fpu_status(X87SW(c) | MXCSR(c)); myvm->signal_fpu_status = fpu_status(X87SW(c) | MXCSR(c));
X87SW(c) = 0; X87SW(c) = 0;
MXCSR(c) &= 0xffffffc0; MXCSR(c) &= 0xffffffc0;
c->EIP = (cell)fp_signal_handler_impl; c->EIP = (cell)fp_signal_handler_impl;
@ -56,7 +57,7 @@ FACTOR_STDCALL LONG exception_handler(PEXCEPTION_POINTERS pe)
enabled. Don't really have any idea what this exception means. */ enabled. Don't really have any idea what this exception means. */
break; break;
default: default:
signal_number = e->ExceptionCode; myvm->signal_number = e->ExceptionCode;
c->EIP = (cell)misc_signal_handler_impl; c->EIP = (cell)misc_signal_handler_impl;
break; break;
} }

View File

@ -21,12 +21,13 @@ typedef char symbol_char;
FACTOR_STDCALL LONG exception_handler(PEXCEPTION_POINTERS pe); FACTOR_STDCALL LONG exception_handler(PEXCEPTION_POINTERS pe);
// SSE traps raise these exception codes, which are defined in internal NT headers // SSE traps raise these exception codes, which are defined in internal NT headers
// but not winbase.h // but not winbase.h
#define STATUS_FLOAT_MULTIPLE_FAULTS 0xC00002B4 #define STATUS_FLOAT_MULTIPLE_FAULTS 0xC00002B4
#define STATUS_FLOAT_MULTIPLE_TRAPS 0xC00002B5 #define STATUS_FLOAT_MULTIPLE_TRAPS 0xC00002B5
void start_thread(void *(*start_routine)(void *),void *args); void *start_thread(void *(*start_routine)(void *),void *args);
#define SIGNAL_VM_PTR lookup_vm(GetCurrentThreadId())
} }

View File

@ -59,6 +59,12 @@ struct factorvm {
inline void vmprim_profiling(); inline void vmprim_profiling();
// errors // errors
/* Global variables used to pass fault handler state from signal handler to
user-space */
cell signal_number;
cell signal_fault_addr;
unsigned int signal_fpu_status;
stack_frame *signal_callstack_top;
void out_of_memory(); void out_of_memory();
void fatal_error(const char* msg, cell tagged); void fatal_error(const char* msg, cell tagged);
void critical_error(const char* msg, cell tagged); void critical_error(const char* msg, cell tagged);
@ -692,4 +698,6 @@ struct factorvm {
extern factorvm *vm; extern factorvm *vm;
extern factorvm *lookup_vm(long threadid);
extern void register_vm(long threadid,factorvm *vm);
} }