From: Geoff Norton Date: Thu, 1 Nov 2007 19:02:09 +0000 (+0000) Subject: 2007-11-01 Geoff Norton X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=2f25d06494d53075a3eefab43f4b4dbc4a8c57d1;p=gc 2007-11-01 Geoff Norton * darwin_stop_world.c: Handle Leopards renaming of some structure members. svn path=/trunk/mono/; revision=88671 --- diff --git a/ChangeLog b/ChangeLog index a650423f..04b419c8 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,7 @@ +2007-11-01 Geoff Norton + + * darwin_stop_world.c: Handle Leopards renaming of some structure + members. Mon Sep 24 16:15:47 CEST 2007 Paolo Molaro diff --git a/darwin_stop_world.c b/darwin_stop_world.c index 6dcc0680..242c9495 100644 --- a/darwin_stop_world.c +++ b/darwin_stop_world.c @@ -102,6 +102,17 @@ void GC_push_all_stacks() { if(r != KERN_SUCCESS) ABORT("thread_get_state failed"); #if defined(I386) +#if defined(_STRUCT_X86_EXCEPTION_STATE) + lo = state.__esp; + + GC_push_one(state.__eax); + GC_push_one(state.__ebx); + GC_push_one(state.__ecx); + GC_push_one(state.__edx); + GC_push_one(state.__edi); + GC_push_one(state.__esi); + GC_push_one(state.__ebp); +#else lo = state.esp; GC_push_one(state.eax); @@ -111,7 +122,43 @@ void GC_push_all_stacks() { GC_push_one(state.edi); GC_push_one(state.esi); GC_push_one(state.ebp); +#endif #elif defined(POWERPC) +#if defined(_STRUCT_PPC_EXCEPTION_STATE) + lo = (void*)(state.__r1 - PPC_RED_ZONE_SIZE); + + GC_push_one(state.__r0); + GC_push_one(state.__r2); + GC_push_one(state.__r3); + GC_push_one(state.__r4); + GC_push_one(state.__r5); + GC_push_one(state.__r6); + GC_push_one(state.__r7); + GC_push_one(state.__r8); + GC_push_one(state.__r9); + GC_push_one(state.__r10); + GC_push_one(state.__r11); + GC_push_one(state.__r12); + GC_push_one(state.__r13); + GC_push_one(state.__r14); + GC_push_one(state.__r15); + GC_push_one(state.__r16); + GC_push_one(state.__r17); + GC_push_one(state.__r18); + GC_push_one(state.__r19); + GC_push_one(state.__r20); + GC_push_one(state.__r21); + GC_push_one(state.__r22); + GC_push_one(state.__r23); + GC_push_one(state.__r24); + GC_push_one(state.__r25); + GC_push_one(state.__r26); + GC_push_one(state.__r27); + GC_push_one(state.__r28); + GC_push_one(state.__r29); + GC_push_one(state.__r30); + GC_push_one(state.__r31); +#else lo = (void*)(state.r1 - PPC_RED_ZONE_SIZE); GC_push_one(state.r0); @@ -145,6 +192,7 @@ void GC_push_all_stacks() { GC_push_one(state.r29); GC_push_one(state.r30); GC_push_one(state.r31); +#endif #else # error FIXME for non-x86 || ppc architectures #endif @@ -199,6 +247,42 @@ void GC_push_all_stacks() { (natural_t *)&info, &outCount); if(r != KERN_SUCCESS) continue; +#if defined(_STRUCT_PPC_EXCEPTION_STATE) + lo = (void*)(info.__r1 - PPC_RED_ZONE_SIZE); + hi = (ptr_t)FindTopOfStack(info.__r1); + + GC_push_one(info.__r0); + GC_push_one(info.__r2); + GC_push_one(info.__r3); + GC_push_one(info.__r4); + GC_push_one(info.__r5); + GC_push_one(info.__r6); + GC_push_one(info.__r7); + GC_push_one(info.__r8); + GC_push_one(info.__r9); + GC_push_one(info.__r10); + GC_push_one(info.__r11); + GC_push_one(info.__r12); + GC_push_one(info.__r13); + GC_push_one(info.__r14); + GC_push_one(info.__r15); + GC_push_one(info.__r16); + GC_push_one(info.__r17); + GC_push_one(info.__r18); + GC_push_one(info.__r19); + GC_push_one(info.__r20); + GC_push_one(info.__r21); + GC_push_one(info.__r22); + GC_push_one(info.__r23); + GC_push_one(info.__r24); + GC_push_one(info.__r25); + GC_push_one(info.__r26); + GC_push_one(info.__r27); + GC_push_one(info.__r28); + GC_push_one(info.__r29); + GC_push_one(info.__r30); + GC_push_one(info.__r31); +#else lo = (void*)(info.r1 - PPC_RED_ZONE_SIZE); hi = (ptr_t)FindTopOfStack(info.r1); @@ -233,6 +317,7 @@ void GC_push_all_stacks() { GC_push_one(info.r29); GC_push_one(info.r30); GC_push_one(info.r31); +#endif # else /* FIXME: Remove after testing: */ WARN("This is completely untested and likely will not work\n", 0); @@ -242,6 +327,26 @@ void GC_push_all_stacks() { (natural_t *)&info, &outCount); if(r != KERN_SUCCESS) continue; +#if defined(_STRUCT_X86_EXCEPTION_STATE) + lo = (void*)info.__esp; + hi = (ptr_t)FindTopOfStack(info.__esp); + + GC_push_one(info.__eax); + GC_push_one(info.__ebx); + GC_push_one(info.__ecx); + GC_push_one(info.__edx); + GC_push_one(info.__edi); + GC_push_one(info.__esi); + /* GC_push_one(info.__ebp); */ + /* GC_push_one(info.__esp); */ + GC_push_one(info.__ss); + GC_push_one(info.__eip); + GC_push_one(info.__cs); + GC_push_one(info.__ds); + GC_push_one(info.__es); + GC_push_one(info.__fs); + GC_push_one(info.__gs); +#else lo = (void*)info.esp; hi = (ptr_t)FindTopOfStack(info.esp); @@ -260,6 +365,7 @@ void GC_push_all_stacks() { GC_push_one(info.es); GC_push_one(info.fs); GC_push_one(info.gs); +#endif # endif /* !POWERPC */ } # if DEBUG_THREADS