2013-02-03 18:15:43 -08: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-12-24 17:08:28 +01:00
|
|
|
/*! Runtime services, including the task scheduler and I/O dispatcher
|
2013-05-06 23:11:02 -07:00
|
|
|
|
|
|
|
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 01:04:01 -07:00
|
|
|
All other runtime features are task-local, including the local heap,
|
2013-05-06 23:11:02 -07: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 15:54:14 +10: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-06 23:11:02 -07:00
|
|
|
|
|
|
|
*/
|
2013-04-23 19:21:37 -07:00
|
|
|
|
2013-09-18 22:18:38 -07:00
|
|
|
// XXX: this should not be here.
|
|
|
|
#[allow(missing_doc)];
|
2013-03-24 18:59:04 -07:00
|
|
|
|
2013-12-12 18:01:59 -08:00
|
|
|
use any::Any;
|
2013-06-18 00:17:14 -07:00
|
|
|
use clone::Clone;
|
|
|
|
use container::Container;
|
2013-09-08 11:01:16 -04:00
|
|
|
use iter::Iterator;
|
2013-12-12 18:01:59 -08:00
|
|
|
use option::Option;
|
2013-06-03 13:50:29 -04:00
|
|
|
use ptr::RawPtr;
|
2013-12-12 18:01:59 -08:00
|
|
|
use result::Result;
|
|
|
|
use task::TaskOpts;
|
2013-08-29 21:49:55 +10:00
|
|
|
use vec::{OwnedVector, MutableVector, ImmutableVector};
|
2013-03-12 13:05:45 -07:00
|
|
|
|
2013-12-12 18:01:59 -08:00
|
|
|
use self::task::{Task, BlockedTask};
|
2013-10-09 10:34:27 -07:00
|
|
|
|
|
|
|
// 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-12-12 18:01:59 -08:00
|
|
|
// Export unwinding facilities used by the failure macros
|
|
|
|
pub use self::unwind::{begin_unwind, begin_unwind_raw};
|
2013-10-22 15:09:23 -07:00
|
|
|
|
2013-10-05 14:44:37 -07:00
|
|
|
// XXX: these probably shouldn't be public...
|
|
|
|
#[doc(hidden)]
|
|
|
|
pub mod shouldnt_be_public {
|
2013-11-26 20:23:56 -08:00
|
|
|
pub use super::local_ptr::native::maybe_tls_key;
|
2013-11-28 12:22:53 -08:00
|
|
|
#[cfg(not(windows), not(target_os = "android"))]
|
2013-11-26 20:23:56 -08:00
|
|
|
pub use super::local_ptr::compiled::RT_TLS_PTR;
|
2013-10-05 14:44:37 -07:00
|
|
|
}
|
|
|
|
|
2013-10-09 10:34:27 -07:00
|
|
|
// Internal macros used by the runtime.
|
|
|
|
mod macros;
|
|
|
|
|
2013-05-07 15:54:06 -07:00
|
|
|
/// The global (exchange) heap.
|
|
|
|
pub mod global_heap;
|
|
|
|
|
2013-05-19 01:04:01 -07:00
|
|
|
/// Implementations of language-critical runtime features like @.
|
|
|
|
pub mod task;
|
|
|
|
|
2013-05-06 23:11:02 -07:00
|
|
|
/// The EventLoop and internal synchronous I/O interface.
|
2013-10-22 15:09:23 -07:00
|
|
|
pub mod rtio;
|
2013-04-26 23:21:58 -07:00
|
|
|
|
2013-05-19 01:13:53 -07:00
|
|
|
/// The Local trait for types that are accessible via thread-local
|
|
|
|
/// or task-local storage.
|
|
|
|
pub mod local;
|
|
|
|
|
2013-05-06 23:11:02 -07:00
|
|
|
/// Bindings to system threading libraries.
|
2013-10-22 15:09:23 -07:00
|
|
|
pub mod thread;
|
2013-04-26 23:21:58 -07:00
|
|
|
|
2013-07-31 23:12:20 -07:00
|
|
|
/// The runtime configuration, read from environment variables.
|
2013-03-12 12:23:24 -07:00
|
|
|
pub mod env;
|
2013-04-26 23:21:58 -07:00
|
|
|
|
|
|
|
/// The local, managed heap
|
2013-06-22 01:09:06 -07:00
|
|
|
pub mod local_heap;
|
2013-03-15 18:06:19 -07:00
|
|
|
|
2013-04-27 18:57:15 -07:00
|
|
|
/// The Logger trait and implementations
|
|
|
|
pub mod logging;
|
|
|
|
|
2013-09-10 00:04:29 +02:00
|
|
|
/// Crate map
|
|
|
|
pub mod crate_map;
|
|
|
|
|
2013-05-19 14:39:46 -07:00
|
|
|
/// The runtime needs to be able to put a pointer into thread-local storage.
|
2013-10-09 10:34:27 -07:00
|
|
|
mod local_ptr;
|
2013-05-19 14:39:46 -07:00
|
|
|
|
|
|
|
/// Bindings to pthread/windows thread-local storage.
|
2013-10-09 10:34:27 -07:00
|
|
|
mod thread_local_storage;
|
2013-05-19 14:39:46 -07:00
|
|
|
|
2013-12-15 17:17:07 -08:00
|
|
|
/// Stack unwinding
|
|
|
|
pub mod unwind;
|
|
|
|
|
2013-06-17 22:17:51 -07:00
|
|
|
/// Just stuff
|
2013-10-09 10:34:27 -07:00
|
|
|
mod util;
|
2013-05-19 14:39:46 -07:00
|
|
|
|
2013-06-21 01:28:23 -07:00
|
|
|
// Global command line argument storage
|
|
|
|
pub mod args;
|
|
|
|
|
2013-06-22 16:52:40 -07:00
|
|
|
// Support for dynamic borrowck
|
|
|
|
pub mod borrowck;
|
|
|
|
|
2013-12-12 17:14:18 -08: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 04:58:52 -04:00
|
|
|
|
2013-12-12 17:14:18 -08:00
|
|
|
/// The interface to the current runtime.
|
2013-07-17 16:48:46 -07:00
|
|
|
///
|
2013-12-12 17:14:18 -08: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>>;
|
2014-01-07 13:39:55 +11:00
|
|
|
/// The (low, high) edges of the current stack.
|
|
|
|
fn stack_bounds(&self) -> (uint, uint); // (lo, hi)
|
2013-12-12 17:14:18 -08:00
|
|
|
|
|
|
|
// XXX: This is a serious code smell and this should not exist at all.
|
|
|
|
fn wrap(~self) -> ~Any;
|
2013-09-18 04:58:52 -04:00
|
|
|
}
|
2013-07-17 16:48:46 -07:00
|
|
|
|
2013-06-21 01:28:23 -07: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 04:58:52 -04: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-12-18 09:57:58 -08:00
|
|
|
local_ptr::init();
|
2013-09-18 04:58:52 -04:00
|
|
|
}
|
|
|
|
}
|
2013-05-08 16:53:40 -07:00
|
|
|
|
2013-06-19 01:08:47 -07:00
|
|
|
/// One-time runtime cleanup.
|
2013-11-25 18:27:27 -08: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 01:28:23 -07:00
|
|
|
args::cleanup();
|
2013-11-25 18:27:27 -08:00
|
|
|
local_ptr::cleanup();
|
2013-06-17 23:18:20 -07:00
|
|
|
}
|