-extern StgTSO *createThread(nat stack_size, StgInt pri);
-#else
-extern StgTSO *createThread(nat stack_size);
-#endif
-#if defined(PAR) || defined(SMP)
-extern void taskStart(void);
-#endif
-extern void scheduleThread(StgTSO *tso);
-extern SchedulerStatus scheduleWaitThread(StgTSO *tso, /*out*/HaskellObj* ret);
-
-static inline void pushClosure (StgTSO *tso, StgClosure *c) {
- tso->sp--;
- tso->sp[0] = (W_) c;
-}
-
-static inline void pushRealWorld (StgTSO *tso) {
- tso->sp--;
- tso->sp[0] = (W_) REALWORLD_TAG;
-}
-static inline StgTSO *
-createGenThread(nat stack_size, StgClosure *closure) {
- StgTSO *t;
-#if defined(GRAN)
- t = createThread(stack_size, NO_PRI);
-#else
- t = createThread(stack_size);
-#endif
- pushClosure(t,closure);
- return t;
-}
-
-static inline StgTSO *
-createIOThread(nat stack_size, StgClosure *closure) {
- StgTSO *t;
-#if defined(GRAN)
- t = createThread(stack_size, NO_PRI);