--- libcoro/coro.c 2008/04/04 20:07:35 1.30 +++ libcoro/coro.c 2008/07/16 00:47:05 1.32 @@ -45,10 +45,10 @@ # if __sgi # define STACK_ADJUST_PTR(sp,ss) ((char *)(sp) + (ss) - 8) # define STACK_ADJUST_SIZE(sp,ss) ((ss) - 8) -# elif __i386__ && CORO_LINUX +# elif (__i386__ && CORO_LINUX) || (_M_IX86 && CORO_LOSER) # define STACK_ADJUST_PTR(sp,ss) ((char *)(sp) + (ss)) # define STACK_ADJUST_SIZE(sp,ss) (ss) -# elif __amd64__ && CORO_LINUX +# elif (__amd64__ && CORO_LINUX) || ((_M_AMD64 || _M_IA64) && CORO_LOSER) # define STACK_ADJUST_PTR(sp,ss) ((char *)(sp) + (ss) - 8) # define STACK_ADJUST_SIZE(sp,ss) (ss) # else @@ -122,12 +122,12 @@ #endif #if CORO_ASM -void __attribute__((__noinline__, __fastcall__)) +void __attribute__((__noinline__, __regparm__(2))) coro_transfer (struct coro_context *prev, struct coro_context *next) { asm volatile ( #if __amd64 -# define NUM_CLOBBERED 5 +# define NUM_SAVED 5 "push %%rbx\n\t" "push %%r12\n\t" "push %%r13\n\t" @@ -141,7 +141,7 @@ "pop %%r12\n\t" "pop %%rbx\n\t" #elif __i386 -# define NUM_CLOBBERED 4 +# define NUM_SAVED 4 "push %%ebx\n\t" "push %%esi\n\t" "push %%edi\n\t" @@ -287,13 +287,13 @@ ctx->env[8] = (long)coro_init; #elif defined(_M_IX86) ((_JUMP_BUFFER *)&ctx->env)->Eip = (long)coro_init; - ((_JUMP_BUFFER *)&ctx->env)->Esp = (long)STACK_ADJUST_PTR (sptr,ssize); + ((_JUMP_BUFFER *)&ctx->env)->Esp = (long)STACK_ADJUST_PTR (sptr, ssize); #elif defined(_M_AMD64) ((_JUMP_BUFFER *)&ctx->env)->Rip = (__int64)coro_init; - ((_JUMP_BUFFER *)&ctx->env)->Rsp = (__int64)STACK_ADJUST_PTR (sptr,ssize); + ((_JUMP_BUFFER *)&ctx->env)->Rsp = (__int64)STACK_ADJUST_PTR (sptr, ssize); #elif defined(_M_IA64) ((_JUMP_BUFFER *)&ctx->env)->StIIP = (__int64)coro_init; - ((_JUMP_BUFFER *)&ctx->env)->IntSp = (__int64)STACK_ADJUST_PTR (sptr,ssize); + ((_JUMP_BUFFER *)&ctx->env)->IntSp = (__int64)STACK_ADJUST_PTR (sptr, ssize); #else # error "microsoft libc or architecture not supported" #endif @@ -328,7 +328,7 @@ ctx->sp = (volatile void **)(ssize + (char *)sptr); *--ctx->sp = (void *)coro_init; *--ctx->sp = (void *)coro_init; // this is needed when the prologue saves ebp - ctx->sp -= NUM_CLOBBERED; + ctx->sp -= NUM_SAVED; # endif