From 7b00d0eb759b3e87828e70ded35e509aea699e0d Mon Sep 17 00:00:00 2001 From: root Date: Wed, 16 Jul 2008 00:47:05 +0000 Subject: *** empty log message *** --- coro.c | 8 ++++---- coro.h | 2 +- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/coro.c b/coro.c index 55e9f73..20266e7 100644 --- a/coro.c +++ b/coro.c @@ -122,12 +122,12 @@ trampoline (int sig) #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 @@ coro_transfer (struct coro_context *prev, struct coro_context *next) "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" @@ -328,7 +328,7 @@ void coro_create (coro_context *ctx, 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 diff --git a/coro.h b/coro.h index 28fc40b..b48583f 100644 --- a/coro.h +++ b/coro.h @@ -210,7 +210,7 @@ struct coro_context { volatile void **sp; }; -void __attribute__ ((__noinline__, __fastcall__)) +void __attribute__ ((__noinline__, __regparm__(2))) coro_transfer (coro_context *prev, coro_context *next); #elif CORO_PTHREAD -- cgit v1.2.3