X-Git-Url: http://git.megacz.com/?p=ghc-hetmet.git;a=blobdiff_plain;f=rts%2FHpc.c;h=0b327f1e5ea5f656adaac7f75497e9b46b56015c;hp=bc9ba0e29a6dc36c184ea6f9a959dcdab44b393a;hb=b2acf7a7179f08f7e4099799180017825154567d;hpb=0578dfbc6a7eefd85ba4e6a4ad23d101060d86c3 diff --git a/rts/Hpc.c b/rts/Hpc.c index bc9ba0e..0b327f1 100644 --- a/rts/Hpc.c +++ b/rts/Hpc.c @@ -23,6 +23,8 @@ */ static int hpc_inited = 0; // Have you started this component? +static pid_t hpc_pid = 0; // pid of this process at hpc-boot time. + // Only this pid will read or write .tix file(s). static FILE *tixFile; // file being read/written static int tix_ch; // current char @@ -167,6 +169,7 @@ static void hpc_init(void) { return; } hpc_inited = 1; + hpc_pid = getpid(); tixFilename = (char *) malloc(strlen(prog_name) + 6); sprintf(tixFilename, "%s.tix", prog_name); @@ -321,8 +324,14 @@ exitHpc(void) { return; } - FILE *f = fopen(tixFilename,"w"); - writeTix(f); + // Only write the tix file if you are the original process. + // Any sub-process from use of fork from inside Haskell will + // not clober the .tix file. + + if (hpc_pid == getpid()) { + FILE *f = fopen(tixFilename,"w"); + writeTix(f); + } } //////////////////////////////////////////////////////////////////////////////