X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=includes%2FRtsExternal.h;h=41c608dbf2639981580f424b54cd8b170c5b8ee9;hb=78658a70f78b6725055eabafab8a058e835f6d15;hp=6e23a9ce82d100a95deb5897cb307fb7488624f9;hpb=85174045bbcc05adb28447d423794d1f087da59e;p=ghc-hetmet.git diff --git a/includes/RtsExternal.h b/includes/RtsExternal.h index 6e23a9c..41c608d 100644 --- a/includes/RtsExternal.h +++ b/includes/RtsExternal.h @@ -43,6 +43,7 @@ extern int forkOS_createThread ( HsStablePtr entry ); extern pid_t forkProcess(HsStablePtr *entry); extern HsBool rtsSupportsBoundThreads(void); extern StgInt newSpark (StgRegTable *reg, StgClosure *p); +extern void stopTimer(void); /* grimy low-level support functions defined in StgPrimFloat.c */ extern StgDouble __encodeDouble (I_ size, StgByteArray arr, I_ e); @@ -71,10 +72,19 @@ extern void* createAdjustor(int cconv, StgStablePtr hptr, StgFunPtr wptr, extern void freeHaskellFunctionPtr(void* ptr); /* Hpc stuff */ -extern int hs_hpc_module(char *modName,int modCount,StgWord64 *tixArr); -extern void hs_hpc_tick(int globIx,struct StgTSO_ *current_tso); -extern void hs_hpc_raise_event(struct StgTSO_ *current_tso); -extern void hs_hpc_thread_finished_event(struct StgTSO_ *current_tso); +extern int hs_hpc_module(char *modName,int modCount,int modHashNo,StgWord64 *tixArr); +// Simple linked list of modules +typedef struct _HpcModuleInfo { + char *modName; // name of module + int tickCount; // number of ticks + int tickOffset; // offset into a single large .tix Array + int hashNo; // Hash number for this module's mix info + StgWord64 *tixArr; // tix Array; local for this module + struct _HpcModuleInfo *next; +} HpcModuleInfo; + +extern HpcModuleInfo *hs_hpc_rootModule(void); + #if defined(mingw32_HOST_OS) extern int rts_InstallConsoleEvent ( int action, StgStablePtr *handler ); @@ -90,7 +100,7 @@ extern StgInt *signal_handlers; #endif #if defined(mingw32_HOST_OS) -HANDLE getIOManagerEvent (void); +void *getIOManagerEvent (void); HsWord32 readIOManagerEvent (void); void sendIOManagerEvent (HsWord32 event); #else @@ -99,6 +109,11 @@ extern void setIOManagerPipe (int fd); extern void* allocateExec(unsigned int len); +// Breakpoint stuff +extern int rts_stop_next_breakpoint; +extern int rts_stop_on_exception; +extern HsStablePtr rts_breakpoint_io_action; + /* ----------------------------------------------------------------------------- Storage manager stuff exported -------------------------------------------------------------------------- */