projects
/
ghc-hetmet.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
[project @ 2001-08-08 13:44:13 by simonmar]
[ghc-hetmet.git]
/
ghc
/
rts
/
Main.c
diff --git
a/ghc/rts/Main.c
b/ghc/rts/Main.c
index
f66ecdf
..
41f9d99
100644
(file)
--- a/
ghc/rts/Main.c
+++ b/
ghc/rts/Main.c
@@
-1,5
+1,5
@@
/* -----------------------------------------------------------------------------
/* -----------------------------------------------------------------------------
- * $Id: Main.c,v 1.25 2000/06/25 17:25:42 panne Exp $
+ * $Id: Main.c,v 1.29 2001/08/07 20:10:30 ken Exp $
*
* (c) The GHC Team 1998-2000
*
*
* (c) The GHC Team 1998-2000
*
@@
-25,8
+25,8
@@
#endif
#ifdef PAR
#endif
#ifdef PAR
-# include "ParInit.h"
# include "Parallel.h"
# include "Parallel.h"
+# include "ParallelRts.h"
# include "LLC.h"
#endif
# include "LLC.h"
#endif
@@
-38,7
+38,7
@@
# include <windows.h>
#endif
# include <windows.h>
#endif
-EXTFUN(__init_PrelMain);
+extern void __init_PrelMain(void);
/* Hack: we assume that we're building a batch-mode system unless
* INTERPRETER is set
/* Hack: we assume that we're building a batch-mode system unless
* INTERPRETER is set
@@
-78,7
+78,8
@@
int main(int argc, char *argv[])
# endif
if (IAmMainThread == rtsTrue) {
# endif
if (IAmMainThread == rtsTrue) {
- fprintf(stderr, "Main Thread Started ...\n");
+ IF_PAR_DEBUG(verbose,
+ fprintf(stderr, "==== [%x] Main Thread Started ...\n", mytid));
/* ToDo: Dump event for the main thread */
status = rts_evalIO((HaskellObj)mainIO_closure, NULL);
/* ToDo: Dump event for the main thread */
status = rts_evalIO((HaskellObj)mainIO_closure, NULL);
@@
-89,7
+90,8
@@
int main(int argc, char *argv[])
mytid));
/* all non-main threads enter the scheduler without work */
mytid));
/* all non-main threads enter the scheduler without work */
- status = rts_evalNothing((StgClosure*)NULL);
+ taskStart();
+ status = Success; // declare victory (see shutdownParallelSystem)
}
# elif defined(GRAN)
}
# elif defined(GRAN)
@@
-104,7
+106,6
@@
int main(int argc, char *argv[])
# endif /* !PAR && !GRAN */
# endif /* !PAR && !GRAN */
- // ToDo: update for parallel execution
/* check the status of the entire Haskell computation */
switch (status) {
case Deadlock:
/* check the status of the entire Haskell computation */
switch (status) {
case Deadlock:
@@
-122,6
+123,12
@@
int main(int argc, char *argv[])
case Success:
exit_status = EXIT_SUCCESS;
break;
case Success:
exit_status = EXIT_SUCCESS;
break;
+#if defined(PAR)
+ case NoStatus:
+ prog_belch("main thread PE killed; probably due to failure of another PE; check /tmp/pvml...");
+ exit_status = EXIT_KILLED;
+ break;
+#endif
default:
barf("main thread completed with invalid status");
}
default:
barf("main thread completed with invalid status");
}