X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=ghc%2Frts%2FTask.c;h=7366480094da1554c1f34b0c85700a56f542cb60;hb=28a464a75e14cece5db40f2765a29348273ff2d2;hp=b8bf1c4c8b3c2079cd923134401e8fb385e82f2c;hpb=cc2926f3a6942e6c512bb64bfe2c2a6aae2c72b4;p=ghc-hetmet.git diff --git a/ghc/rts/Task.c b/ghc/rts/Task.c index b8bf1c4..7366480 100644 --- a/ghc/rts/Task.c +++ b/ghc/rts/Task.c @@ -97,7 +97,8 @@ newTask (void) #endif #if defined(THREADED_RTS) - getProcessTimes(¤tUserTime, ¤tElapsedTime); + currentUserTime = getThreadCPUTime(); + currentElapsedTime = getProcessElapsedTime(); task->mut_time = 0.0; task->mut_etime = 0.0; task->gc_time = 0.0; @@ -170,17 +171,25 @@ boundTaskExiting (Task *task) IF_DEBUG(scheduler,sched_belch("task exiting")); } +#ifdef THREADED_RTS +#define TASK_ID(t) (t)->id +#else +#define TASK_ID(t) (t) +#endif + void discardTask (Task *task) { ASSERT_LOCK_HELD(&sched_mutex); -#if defined(THREADED_RTS) - closeCondition(&task->cond); -#endif - task->stopped = rtsTrue; - task->cap = NULL; - task->next = task_free_list; - task_free_list = task; + if (!task->stopped) { + IF_DEBUG(scheduler,sched_belch("discarding task %p", TASK_ID(task))); + task->cap = NULL; + task->tso = NULL; + task->stopped = rtsTrue; + tasksRunning--; + task->next = task_free_list; + task_free_list = task; + } } void @@ -194,7 +203,8 @@ taskStop (Task *task) ASSERT(task->id == id); ASSERT(myTask() == task); - getProcessTimes(¤tUserTime, ¤tElapsedTime); + currentUserTime = getThreadCPUTime(); + currentElapsedTime = getProcessElapsedTime(); // XXX this is wrong; we want elapsed GC time since the // Task started.