2013-02-03 20:15:43 -06:00
|
|
|
// 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.
|
|
|
|
|
2013-05-07 01:11:02 -05:00
|
|
|
/*! The Rust Runtime, including the task scheduler and I/O
|
|
|
|
|
|
|
|
The `rt` module provides the private runtime infrastructure necessary
|
|
|
|
to support core language features like the exchange and local heap,
|
|
|
|
the garbage collector, logging, local data and unwinding. It also
|
|
|
|
implements the default task scheduler and task model. Initialization
|
|
|
|
routines are provided for setting up runtime resources in common
|
|
|
|
configurations, including that used by `rustc` when generating
|
|
|
|
executables.
|
|
|
|
|
|
|
|
It is intended that the features provided by `rt` can be factored in a
|
|
|
|
way such that the core library can be built with different 'profiles'
|
|
|
|
for different use cases, e.g. excluding the task scheduler. A number
|
|
|
|
of runtime features though are critical to the functioning of the
|
|
|
|
language and an implementation must be provided regardless of the
|
|
|
|
execution environment.
|
|
|
|
|
|
|
|
Of foremost importance is the global exchange heap, in the module
|
|
|
|
`global_heap`. Very little practical Rust code can be written without
|
|
|
|
access to the global heap. Unlike most of `rt` the global heap is
|
|
|
|
truly a global resource and generally operates independently of the
|
|
|
|
rest of the runtime.
|
|
|
|
|
2013-05-19 03:04:01 -05:00
|
|
|
All other runtime features are task-local, including the local heap,
|
2013-05-07 01:11:02 -05:00
|
|
|
the garbage collector, local storage, logging and the stack unwinder.
|
|
|
|
|
|
|
|
The relationship between `rt` and the rest of the core library is
|
|
|
|
not entirely clear yet and some modules will be moving into or
|
|
|
|
out of `rt` as development proceeds.
|
|
|
|
|
|
|
|
Several modules in `core` are clients of `rt`:
|
|
|
|
|
2013-08-16 00:54:14 -05:00
|
|
|
* `std::task` - The user-facing interface to the Rust task model.
|
|
|
|
* `std::task::local_data` - The interface to local data.
|
|
|
|
* `std::gc` - The garbage collector.
|
|
|
|
* `std::unstable::lang` - Miscellaneous lang items, some of which rely on `std::rt`.
|
|
|
|
* `std::condition` - Uses local data.
|
|
|
|
* `std::cleanup` - Local heap destruction.
|
|
|
|
* `std::io` - In the future `std::io` will use an `rt` implementation.
|
|
|
|
* `std::logging`
|
|
|
|
* `std::pipes`
|
|
|
|
* `std::comm`
|
|
|
|
* `std::stackwalk`
|
2013-05-07 01:11:02 -05:00
|
|
|
|
|
|
|
*/
|
2013-04-23 21:21:37 -05:00
|
|
|
|
2013-09-19 00:18:38 -05:00
|
|
|
// XXX: this should not be here.
|
|
|
|
#[allow(missing_doc)];
|
2013-03-24 20:59:04 -05:00
|
|
|
|
2013-06-18 02:17:14 -05:00
|
|
|
use clone::Clone;
|
|
|
|
use container::Container;
|
2013-09-08 10:01:16 -05:00
|
|
|
use iter::Iterator;
|
2013-08-08 13:38:10 -05:00
|
|
|
use option::{Option, None, Some};
|
2013-06-03 12:50:29 -05:00
|
|
|
use ptr::RawPtr;
|
2013-07-19 16:25:05 -05:00
|
|
|
use rt::local::Local;
|
2013-06-26 18:41:00 -05:00
|
|
|
use rt::sched::{Scheduler, Shutdown};
|
2013-06-18 02:17:14 -05:00
|
|
|
use rt::sleeper_list::SleeperList;
|
2013-12-05 20:19:06 -06:00
|
|
|
use task::TaskResult;
|
2013-07-29 15:34:08 -05:00
|
|
|
use rt::task::{Task, SchedTask, GreenTask, Sched};
|
2013-11-01 11:16:11 -05:00
|
|
|
use send_str::SendStrStatic;
|
2013-10-05 23:58:55 -05:00
|
|
|
use unstable::atomics::{AtomicInt, AtomicBool, SeqCst};
|
2013-08-27 05:00:57 -05:00
|
|
|
use unstable::sync::UnsafeArc;
|
2013-08-29 06:49:55 -05:00
|
|
|
use vec::{OwnedVector, MutableVector, ImmutableVector};
|
2013-10-11 16:20:34 -05:00
|
|
|
use vec;
|
2013-03-12 15:05:45 -05:00
|
|
|
|
2013-10-05 16:44:37 -05:00
|
|
|
use self::thread::Thread;
|
|
|
|
|
2013-10-09 12:34:27 -05:00
|
|
|
// the os module needs to reach into this helper, so allow general access
|
|
|
|
// through this reexport.
|
|
|
|
pub use self::util::set_exit_status;
|
|
|
|
|
|
|
|
// this is somewhat useful when a program wants to spawn a "reasonable" number
|
|
|
|
// of workers based on the constraints of the system that it's running on.
|
|
|
|
// Perhaps this shouldn't be a `pub use` though and there should be another
|
|
|
|
// method...
|
|
|
|
pub use self::util::default_sched_threads;
|
|
|
|
|
2013-10-22 17:09:23 -05:00
|
|
|
// Re-export of the functionality in the kill module
|
2013-11-21 18:55:40 -06:00
|
|
|
pub use self::kill::BlockedTask;
|
2013-10-22 17:09:23 -05:00
|
|
|
|
2013-10-05 16:44:37 -05:00
|
|
|
// XXX: these probably shouldn't be public...
|
|
|
|
#[doc(hidden)]
|
|
|
|
pub mod shouldnt_be_public {
|
2013-11-26 22:23:56 -06:00
|
|
|
pub use super::local_ptr::native::maybe_tls_key;
|
2013-11-28 14:22:53 -06:00
|
|
|
#[cfg(not(windows), not(target_os = "android"))]
|
2013-11-26 22:23:56 -06:00
|
|
|
pub use super::local_ptr::compiled::RT_TLS_PTR;
|
2013-10-05 16:44:37 -05:00
|
|
|
}
|
|
|
|
|
2013-10-09 12:34:27 -05:00
|
|
|
// Internal macros used by the runtime.
|
|
|
|
mod macros;
|
|
|
|
|
2013-10-22 17:00:37 -05:00
|
|
|
/// Basic implementation of an EventLoop, provides no I/O interfaces
|
|
|
|
mod basic;
|
|
|
|
|
2013-05-07 17:54:06 -05:00
|
|
|
/// The global (exchange) heap.
|
|
|
|
pub mod global_heap;
|
|
|
|
|
2013-05-19 03:04:01 -05:00
|
|
|
/// Implementations of language-critical runtime features like @.
|
|
|
|
pub mod task;
|
|
|
|
|
2013-07-02 20:15:34 -05:00
|
|
|
/// Facilities related to task failure, killing, and death.
|
|
|
|
mod kill;
|
|
|
|
|
2013-05-19 03:04:01 -05:00
|
|
|
/// The coroutine task scheduler, built on the `io` event loop.
|
2013-10-22 17:09:23 -05:00
|
|
|
pub mod sched;
|
2013-04-27 01:21:58 -05:00
|
|
|
|
2013-05-07 01:11:02 -05:00
|
|
|
/// The EventLoop and internal synchronous I/O interface.
|
2013-10-22 17:09:23 -05:00
|
|
|
pub mod rtio;
|
2013-04-27 01:21:58 -05:00
|
|
|
|
2013-05-19 03:13:53 -05:00
|
|
|
/// The Local trait for types that are accessible via thread-local
|
|
|
|
/// or task-local storage.
|
|
|
|
pub mod local;
|
|
|
|
|
2013-10-03 21:23:47 -05:00
|
|
|
/// A mostly lock-free multi-producer, single consumer queue.
|
2013-12-05 20:19:06 -06:00
|
|
|
pub mod mpsc_queue;
|
|
|
|
|
|
|
|
/// A lock-free single-producer, single consumer queue.
|
|
|
|
pub mod spsc_queue;
|
2013-10-03 21:23:47 -05:00
|
|
|
|
2013-10-07 02:07:04 -05:00
|
|
|
/// A lock-free multi-producer, multi-consumer bounded queue.
|
|
|
|
mod mpmc_bounded_queue;
|
|
|
|
|
2013-11-26 11:40:24 -06:00
|
|
|
/// A parallel work-stealing deque
|
|
|
|
pub mod deque;
|
|
|
|
|
2013-05-28 20:39:52 -05:00
|
|
|
/// A parallel data structure for tracking sleeping schedulers.
|
2013-10-22 17:09:23 -05:00
|
|
|
pub mod sleeper_list;
|
2013-05-28 20:39:52 -05:00
|
|
|
|
2013-05-07 01:11:02 -05:00
|
|
|
/// Stack segments and caching.
|
2013-08-13 11:10:05 -05:00
|
|
|
pub mod stack;
|
2013-04-27 01:21:58 -05:00
|
|
|
|
2013-05-07 01:11:02 -05:00
|
|
|
/// CPU context swapping.
|
2013-02-03 20:15:43 -06:00
|
|
|
mod context;
|
2013-04-27 01:21:58 -05:00
|
|
|
|
2013-05-07 01:11:02 -05:00
|
|
|
/// Bindings to system threading libraries.
|
2013-10-22 17:09:23 -05:00
|
|
|
pub mod thread;
|
2013-04-27 01:21:58 -05:00
|
|
|
|
2013-08-01 01:12:20 -05:00
|
|
|
/// The runtime configuration, read from environment variables.
|
2013-03-12 14:23:24 -05:00
|
|
|
pub mod env;
|
2013-04-27 01:21:58 -05:00
|
|
|
|
|
|
|
/// The local, managed heap
|
2013-06-22 03:09:06 -05:00
|
|
|
pub mod local_heap;
|
2013-03-15 20:06:19 -05:00
|
|
|
|
2013-04-27 20:57:15 -05:00
|
|
|
/// The Logger trait and implementations
|
|
|
|
pub mod logging;
|
|
|
|
|
2013-09-09 17:04:29 -05:00
|
|
|
/// Crate map
|
|
|
|
pub mod crate_map;
|
|
|
|
|
2013-04-20 02:33:49 -05:00
|
|
|
/// Tools for testing the runtime
|
|
|
|
pub mod test;
|
|
|
|
|
2013-05-03 18:58:20 -05:00
|
|
|
/// Reference counting
|
|
|
|
pub mod rc;
|
|
|
|
|
2013-05-04 19:30:31 -05:00
|
|
|
/// A simple single-threaded channel type for passing buffered data between
|
|
|
|
/// scheduler and task context
|
|
|
|
pub mod tube;
|
|
|
|
|
2013-05-19 16:39:46 -05:00
|
|
|
/// The runtime needs to be able to put a pointer into thread-local storage.
|
2013-10-09 12:34:27 -05:00
|
|
|
mod local_ptr;
|
2013-05-19 16:39:46 -05:00
|
|
|
|
|
|
|
/// Bindings to pthread/windows thread-local storage.
|
2013-10-09 12:34:27 -05:00
|
|
|
mod thread_local_storage;
|
2013-05-19 16:39:46 -05:00
|
|
|
|
2013-12-15 19:17:07 -06:00
|
|
|
/// Stack unwinding
|
|
|
|
pub mod unwind;
|
|
|
|
|
2013-06-18 00:17:51 -05:00
|
|
|
/// Just stuff
|
2013-10-09 12:34:27 -05:00
|
|
|
mod util;
|
2013-05-19 16:39:46 -05:00
|
|
|
|
2013-06-21 03:28:23 -05:00
|
|
|
// Global command line argument storage
|
|
|
|
pub mod args;
|
|
|
|
|
2013-06-22 18:52:40 -05:00
|
|
|
// Support for dynamic borrowck
|
|
|
|
pub mod borrowck;
|
|
|
|
|
2013-12-12 19:14:18 -06:00
|
|
|
/// The default error code of the rust runtime if the main task fails instead
|
|
|
|
/// of exiting cleanly.
|
|
|
|
pub static DEFAULT_ERROR_CODE: int = 101;
|
2013-09-18 03:58:52 -05:00
|
|
|
|
2013-12-12 19:14:18 -06:00
|
|
|
/// The interface to the current runtime.
|
2013-07-17 18:48:46 -05:00
|
|
|
///
|
2013-12-12 19:14:18 -06:00
|
|
|
/// This trait is used as the abstraction between 1:1 and M:N scheduling. The
|
|
|
|
/// two independent crates, libnative and libgreen, both have objects which
|
|
|
|
/// implement this trait. The goal of this trait is to encompass all the
|
|
|
|
/// fundamental differences in functionality between the 1:1 and M:N runtime
|
|
|
|
/// modes.
|
|
|
|
pub trait Runtime {
|
|
|
|
// Necessary scheduling functions, used for channels and blocking I/O
|
|
|
|
// (sometimes).
|
|
|
|
fn yield_now(~self, cur_task: ~Task);
|
|
|
|
fn maybe_yield(~self, cur_task: ~Task);
|
|
|
|
fn deschedule(~self, times: uint, cur_task: ~Task,
|
|
|
|
f: |BlockedTask| -> Result<(), BlockedTask>);
|
|
|
|
fn reawaken(~self, to_wake: ~Task, can_resched: bool);
|
|
|
|
|
|
|
|
// Miscellaneous calls which are very different depending on what context
|
|
|
|
// you're in.
|
|
|
|
fn spawn_sibling(~self, cur_task: ~Task, opts: TaskOpts, f: proc());
|
|
|
|
fn local_io<'a>(&'a mut self) -> Option<rtio::LocalIo<'a>>;
|
|
|
|
|
|
|
|
// XXX: This is a serious code smell and this should not exist at all.
|
|
|
|
fn wrap(~self) -> ~Any;
|
2013-09-18 03:58:52 -05:00
|
|
|
}
|
2013-07-17 18:48:46 -05:00
|
|
|
|
2013-06-21 03:28:23 -05:00
|
|
|
/// One-time runtime initialization.
|
|
|
|
///
|
|
|
|
/// Initializes global state, including frobbing
|
|
|
|
/// the crate's logging flags, registering GC
|
|
|
|
/// metadata, and storing the process arguments.
|
2013-09-18 03:58:52 -05:00
|
|
|
pub fn init(argc: int, argv: **u8) {
|
|
|
|
// XXX: Derefing these pointers is not safe.
|
|
|
|
// Need to propagate the unsafety to `start`.
|
|
|
|
unsafe {
|
|
|
|
args::init(argc, argv);
|
|
|
|
env::init();
|
|
|
|
logging::init();
|
|
|
|
}
|
|
|
|
}
|
2013-05-08 18:53:40 -05:00
|
|
|
|
2013-06-19 03:08:47 -05:00
|
|
|
/// One-time runtime cleanup.
|
2013-11-25 20:27:27 -06:00
|
|
|
///
|
|
|
|
/// This function is unsafe because it performs no checks to ensure that the
|
|
|
|
/// runtime has completely ceased running. It is the responsibility of the
|
|
|
|
/// caller to ensure that the runtime is entirely shut down and nothing will be
|
|
|
|
/// poking around at the internal components.
|
|
|
|
///
|
|
|
|
/// Invoking cleanup while portions of the runtime are still in use may cause
|
|
|
|
/// undefined behavior.
|
|
|
|
pub unsafe fn cleanup() {
|
2013-06-21 03:28:23 -05:00
|
|
|
args::cleanup();
|
2013-11-25 20:27:27 -06:00
|
|
|
local_ptr::cleanup();
|
2013-06-18 01:18:20 -05:00
|
|
|
}
|