diff --git a/ghc/includes/COptWraps.lh b/ghc/includes/COptWraps.lh index 409693b811830ff8243c7f4dba2abb9c67999378..81c266b90968fce2b8c2635c6059d6a84af9c57f 100644 --- a/ghc/includes/COptWraps.lh +++ b/ghc/includes/COptWraps.lh @@ -232,7 +232,8 @@ in the end. Getting this right requires three extremely @MAGIC@ macros, no doubt chock full of assembly gook for the current platform. These are -@MAGIC_CALL_SETUP@, which gets ready for one of these magic calls, +@MAGIC_CALL_SET +UP@, which gets ready for one of these magic calls, @MAGIC_CALL@, which performs the call and stashes away all possible results, and @MAGIC_RETURN@, which collects all possible results back up again. @@ -533,6 +534,7 @@ gets whatever it's after. "\ts.d $f0, -8($sp)\n" \ "\tsw $2, -12($sp)"); + #define MAGIC_RETURN \ __asm__ volatile ( \ "l.d $f0, -8($sp)\n" \ @@ -540,6 +542,13 @@ gets whatever it's after. #define WRAPPER_NAME(f) /* nothing */ +/* + Threaded code needs to be able to grab the return address, in case we have + an intervening context switch. + */ + +#define SET_RETADDR(loc) { register StgFunPtrFunPtr ra __asm__ ("$31"); loc = ra; } + #define WRAPPER_SETUP(f,ignore1,ignore2) SaveAllStgContext(); #define WRAPPER_RETURN(x) \