X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=ghc%2Fincludes%2FRtsExternal.h;h=919fe795fb3a6c22a99c0e8960f9aefd80f80a95;hb=3595da95b2ca0d60c9100f77541b6ce36e49363c;hp=da4f02e10225b6efd491ac39928b63070e33c946;hpb=423d477bfecd490de1449c59325c8776f91d7aac;p=ghc-hetmet.git diff --git a/ghc/includes/RtsExternal.h b/ghc/includes/RtsExternal.h index da4f02e..919fe79 100644 --- a/ghc/includes/RtsExternal.h +++ b/ghc/includes/RtsExternal.h @@ -1,5 +1,4 @@ /* ----------------------------------------------------------------------------- - * $Id: RtsExternal.h,v 1.2 2004/08/13 13:09:29 simonmar Exp $ * * (c) The GHC Team, 1998-2004 * @@ -30,10 +29,15 @@ extern void newCAF(StgClosure*); extern I_ genSymZh(void); extern I_ resetGenSymZh(void); +/* Alternate to raise(3) for threaded rts, for OpenBSD */ +extern int genericRaise(int sig); + /* Concurrency/Exception PrimOps. */ extern int cmp_thread(StgPtr tso1, StgPtr tso2); extern int rts_getThreadId(StgPtr tso); extern int forkOS_createThread ( HsStablePtr entry ); +extern StgInt forkProcess(HsStablePtr *entry); +extern StgBool rtsSupportsBoundThreads(void); /* grimy low-level support functions defined in StgPrimFloat.c */ extern StgDouble __encodeDouble (I_ size, StgByteArray arr, I_ e); @@ -53,6 +57,21 @@ extern StgInt isFloatNegativeZero(StgFloat f); extern StgInt suspendThread ( StgRegTable * ); extern StgRegTable * resumeThread ( StgInt ); +/* Creating and destroying an adjustor thunk */ +extern void* createAdjustor(int cconv, StgStablePtr hptr, StgFunPtr wptr, + char *typeString); +extern void freeHaskellFunctionPtr(void* ptr); + +#if defined(mingw32_HOST_OS) +extern int rts_InstallConsoleEvent ( int action, StgStablePtr *handler ); +extern void rts_ConsoleHandlerDone ( int ev ); +#else +extern int stg_sig_install (int, int, StgStablePtr *, void *); +#endif + +extern void startSignalHandler(int sig); +extern void setIOManagerPipe (int fd); + /* ----------------------------------------------------------------------------- Storage manager stuff exported -------------------------------------------------------------------------- */ @@ -63,5 +82,7 @@ typedef void (*evac_fn)(StgClosure **); extern void performGC(void); extern void performMajorGC(void); extern void performGCWithRoots(void (*get_roots)(evac_fn)); +extern HsInt64 getAllocations( void ); +extern void revertCAFs( void ); #endif /* RTSEXTERNAL_H */