Skip to content

Commit

Permalink
rt: Remove rust_task_thread::dead_tasks
Browse files Browse the repository at this point in the history
  • Loading branch information
brson committed Mar 19, 2012
1 parent 6f6650e commit 7dcac31
Show file tree
Hide file tree
Showing 2 changed files with 10 additions and 20 deletions.
28 changes: 9 additions & 19 deletions src/rt/rust_task_thread.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@ rust_task_thread::rust_task_thread(rust_scheduler *sched,
id(id),
should_exit(false),
cached_c_stack(NULL),
dead_task(NULL),
kernel(sched->kernel),
sched(sched),
srv(srv),
Expand Down Expand Up @@ -108,23 +109,18 @@ rust_task_thread::number_of_live_tasks() {
*/
void
rust_task_thread::reap_dead_tasks() {
if (dead_tasks.length() == 0) {
if (dead_task == NULL) {
return;
}

A(this, dead_tasks.length() == 1,
"Only one task should die during a single turn of the event loop");

// First make a copy of the dead_task list with the lock held
rust_task *dead_task = dead_tasks.pop_value();

// Dereferencing the task will probably cause it to be released
// from the scheduler, which may end up trying to take this lock
lock.unlock();

dead_task->delete_all_stacks();
// Deref the task, which may cause it to request us to release it
dead_task->deref();
dead_task = NULL;

lock.lock();
}
Expand Down Expand Up @@ -187,14 +183,6 @@ rust_task_thread::log_state() {
blocked_tasks[i]->get_cond_name());
}
}

if (!dead_tasks.is_empty()) {
log(NULL, log_debug, "dead tasks:");
for (size_t i = 0; i < dead_tasks.length(); i++) {
log(NULL, log_debug, "\t task: %s 0x%" PRIxPTR,
dead_tasks[i]->name, dead_tasks[i]);
}
}
}
/**
* Starts the main scheduler loop which performs task scheduling for this
Expand All @@ -221,7 +209,7 @@ rust_task_thread::start_main_loop() {
"all tasks are blocked, scheduler id %d yielding ...",
id);
lock.wait();
A(this, dead_tasks.length() == 0,
A(this, dead_task == NULL,
"Tasks should only die after running");
DLOG(this, task,
"scheduler %d resuming ...", id);
Expand Down Expand Up @@ -257,7 +245,7 @@ rust_task_thread::start_main_loop() {

A(this, running_tasks.is_empty(), "Should have no running tasks");
A(this, blocked_tasks.is_empty(), "Should have no blocked tasks");
A(this, dead_tasks.is_empty(), "Should have no dead tasks");
A(this, dead_task == NULL, "Should have no dead tasks");

DLOG(this, dom, "finished main-loop %d", id);

Expand Down Expand Up @@ -290,8 +278,6 @@ rust_task_thread::state_list(rust_task_state state) {
return &running_tasks;
case task_state_blocked:
return &blocked_tasks;
case task_state_dead:
return &dead_tasks;
default:
return NULL;
}
Expand Down Expand Up @@ -332,6 +318,10 @@ rust_task_thread::transition(rust_task *task,
if (dst_list) {
dst_list->append(task);
}
if (dst == task_state_dead) {
I(this, dead_task == NULL);
dead_task = task;
}
task->set_state(dst, cond, cond_name);

lock.signal();
Expand Down
2 changes: 1 addition & 1 deletion src/rt/rust_task_thread.h
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,7 @@ struct rust_task_thread : public kernel_owned<rust_task_thread>,

rust_task_list running_tasks;
rust_task_list blocked_tasks;
rust_task_list dead_tasks;
rust_task *dead_task;

void prepare_c_stack(rust_task *task);
void unprepare_c_stack();
Expand Down

0 comments on commit 7dcac31

Please sign in to comment.