X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=rts%2Fsm%2FEvac.h;h=c0db81432f35f453dc4d9916c13f97931ae5d3fa;hb=f86e7206ea94b48b94fb61007a1c5d55b8c60f45;hp=c0aeeb546dd8942e21a557457379713ed70644d0;hpb=64c17c4561cf419a4c70511bafc0815ea670bb2e;p=ghc-hetmet.git diff --git a/rts/sm/Evac.h b/rts/sm/Evac.h index c0aeeb5..c0db814 100644 --- a/rts/sm/Evac.h +++ b/rts/sm/Evac.h @@ -12,12 +12,22 @@ * ---------------------------------------------------------------------------*/ // Use a register argument for evacuate, if available. -#if __GNUC__ >= 2 +// Earlier, the regparm attribute was used whenever __GNUC__ >= 2, but this +// generated warnings on PPC. So the use is restricted further. +// See http://gcc.gnu.org/onlinedocs/gcc/Function-Attributes.html that says +// regparm (number) +// On the Intel 386, the regparm attribute causes the compiler to pass +// arguments number one to number if they are of integral type in +// registers EAX, EDX, and ECX instead of on the stack. Functions that +// take a variable number of arguments will continue to be passed all of +// their arguments on the stack. +#if __GNUC__ >= 2 && (defined(x86_64_TARGET_ARCH) || defined(i386_TARGET_ARCH)) #define REGPARM1 __attribute__((regparm(1))) #else #define REGPARM1 #endif -REGPARM1 StgClosure * evacuate (StgClosure *q); +REGPARM1 void evacuate (StgClosure **p); +REGPARM1 void evacuate1 (StgClosure **p); extern lnat thunk_selector_depth;