diff options
| author | Ben Blum <bblum@andrew.cmu.edu> | 2012-07-24 18:22:44 -0400 |
|---|---|---|
| committer | Ben Blum <bblum@andrew.cmu.edu> | 2012-07-24 18:24:24 -0400 |
| commit | 695ab098995d23b0fa62248b5ce3052e5e072269 (patch) | |
| tree | c7324cde5232a91b211ffa1dc37032c09eabff98 /src/rt/rust_task.cpp | |
| parent | ac9df5841c09ca645638922365a9de56ac529251 (diff) | |
| download | rust-695ab098995d23b0fa62248b5ce3052e5e072269.tar.gz rust-695ab098995d23b0fa62248b5ce3052e5e072269.zip | |
Change yield() and wait_event() to be MUST_CHECK and return the killed flag. (closes #2875)
Diffstat (limited to 'src/rt/rust_task.cpp')
| -rw-r--r-- | src/rt/rust_task.cpp | 27 |
1 files changed, 18 insertions, 9 deletions
diff --git a/src/rt/rust_task.cpp b/src/rt/rust_task.cpp index 014e8e7948d..e7a18e90461 100644 --- a/src/rt/rust_task.cpp +++ b/src/rt/rust_task.cpp @@ -242,26 +242,30 @@ void rust_task_yield_fail(rust_task *task) { } // Only run this on the rust stack -void -rust_task::yield(bool *killed) { +MUST_CHECK bool rust_task::yield() { + bool killed = false; + if (disallow_yield > 0) { call_on_c_stack(this, (void *)rust_task_yield_fail); } - // FIXME (#2875): clean this up + + // This check is largely superfluous; it's the one after the context swap + // that really matters. This one allows us to assert a useful invariant. if (must_fail_from_being_killed()) { { scoped_lock with(lifecycle_lock); assert(!(state == task_state_blocked)); } - *killed = true; + killed = true; } // Return to the scheduler. ctx.next->swap(ctx); if (must_fail_from_being_killed()) { - *killed = true; + killed = true; } + return killed; } void @@ -687,19 +691,24 @@ void rust_task::allow_yield() { disallow_yield--; } -void * -rust_task::wait_event(bool *killed) { +MUST_CHECK bool rust_task::wait_event(void **result) { + bool killed = false; scoped_lock with(lifecycle_lock); if(!event_reject) { block_inner(&event_cond, "waiting on event"); lifecycle_lock.unlock(); - yield(killed); + killed = yield(); lifecycle_lock.lock(); + } else if (must_fail_from_being_killed_inner()) { + // If the deschedule was rejected, yield won't do our killed check for + // us. For thoroughness, do it here. FIXME (#524) + killed = true; } event_reject = false; - return event; + *result = event; + return killed; } void |
