This extracts everything related to green scheduling from libstd and introduces a new libgreen crate. This mostly involves deleting most of std::rt and moving it to libgreen. Along with the movement of code, this commit rearchitects many functions in the scheduler in order to adapt to the fact that Local::take now *only* works on a Task, not a scheduler. This mostly just involved threading the current green task through in a few locations, but there were one or two spots where things got hairy. There are a few repercussions of this commit: * tube/rc have been removed (the runtime implementation of rc) * There is no longer a "single threaded" spawning mode for tasks. This is now encompassed by 1:1 scheduling + communication. Convenience methods have been introduced that are specific to libgreen to assist in the spawning of pools of schedulers.
46 lines
1.2 KiB
Rust
46 lines
1.2 KiB
Rust
// Copyright 2013 The Rust Project Developers. See the COPYRIGHT
|
|
// file at the top-level directory of this distribution and at
|
|
// http://rust-lang.org/COPYRIGHT.
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
|
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
|
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
|
// option. This file may not be copied, modified, or distributed
|
|
// except according to those terms.
|
|
|
|
//! Maintains a shared list of sleeping schedulers. Schedulers
|
|
//! use this to wake each other up.
|
|
|
|
use std::sync::mpmc_bounded_queue::Queue;
|
|
|
|
use sched::SchedHandle;
|
|
|
|
pub struct SleeperList {
|
|
priv q: Queue<SchedHandle>,
|
|
}
|
|
|
|
impl SleeperList {
|
|
pub fn new() -> SleeperList {
|
|
SleeperList{q: Queue::with_capacity(8*1024)}
|
|
}
|
|
|
|
pub fn push(&mut self, value: SchedHandle) {
|
|
assert!(self.q.push(value))
|
|
}
|
|
|
|
pub fn pop(&mut self) -> Option<SchedHandle> {
|
|
self.q.pop()
|
|
}
|
|
|
|
pub fn casual_pop(&mut self) -> Option<SchedHandle> {
|
|
self.q.pop()
|
|
}
|
|
}
|
|
|
|
impl Clone for SleeperList {
|
|
fn clone(&self) -> SleeperList {
|
|
SleeperList {
|
|
q: self.q.clone()
|
|
}
|
|
}
|
|
}
|