summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--includes/RtsExternal.h17
-rw-r--r--rts/Hpc.c21
2 files changed, 21 insertions, 17 deletions
diff --git a/includes/RtsExternal.h b/includes/RtsExternal.h
index 58b6ef0e39..30a5b56702 100644
--- a/includes/RtsExternal.h
+++ b/includes/RtsExternal.h
@@ -72,11 +72,18 @@ extern void freeHaskellFunctionPtr(void* ptr);
/* Hpc stuff */
extern int hs_hpc_module(char *modName,int modCount,int modHashNo,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 void hs_hpc_read(char *filename);
-extern void hs_hpc_write(char *filename);
+// 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 );
diff --git a/rts/Hpc.c b/rts/Hpc.c
index 7ad2666228..ebd5af15d1 100644
--- a/rts/Hpc.c
+++ b/rts/Hpc.c
@@ -22,21 +22,10 @@
*
*/
-#define WOP_SIZE 1024
-
static int hpc_inited = 0; // Have you started this component?
static FILE *tixFile; // file being read/written
static int tix_ch; // current char
-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 from the program execution (local for this module)
- struct _HpcModuleInfo *next;
-} HpcModuleInfo;
-
// This is a cruel hack, we should completely redesign the format specifier handling in the RTS.
#if SIZEOF_LONG == 8
#define PRIuWORD64 "lu"
@@ -50,6 +39,9 @@ int totalTixes = 0; // total number of tix boxes.
static char *tixFilename;
+void hs_hpc_read(char *filename);
+void hs_hpc_write(char *filename);
+
static void failure(char *msg) {
debugTrace(DEBUG_hpc,"hpc failure: %s\n",msg);
fprintf(stderr,"Hpc failure: %s\n",msg);
@@ -371,5 +363,10 @@ void hs_hpc_write(char *filename) {
writeTix(fopen(filename,"w"));
}
+//////////////////////////////////////////////////////////////////////////////
+// This is the API into Hpc RTS from Haskell, allowing the tixs boxes
+// to be first class.
-
+HpcModuleInfo *hs_hpc_rootModule(void) {
+ return modules;
+}