// This file is part of libfringe, a low-level green threading library. // Copyright (c) edef // Licensed under the Apache License, Version 2.0, or the MIT license , at your option. This file may not be // copied, modified, or distributed except according to those terms. //! Traits for stacks. mod slice_stack; pub use stack::slice_stack::SliceStack; #[cfg(feature = "alloc")] mod owned_stack; #[cfg(feature = "alloc")] pub use stack::owned_stack::OwnedStack; #[cfg(unix)] mod os; #[cfg(unix)] pub use stack::os::OsStack; /// A trait for objects that hold ownership of a stack. /// /// To preserve memory safety, an implementation of this trait must fulfill /// the following contract: /// /// * The base address of the stack must be aligned to /// a [`STACK_ALIGNMENT`][align]-byte boundary. /// * Every address between the base and the limit must be readable and writable. /// /// [align]: constant.STACK_ALIGNMENT.html pub unsafe trait Stack { /// Returns the base address of the stack. /// On all modern architectures, the stack grows downwards, /// so this is the highest address. fn base(&self) -> *mut u8; /// Returns the limit address of the stack. /// On all modern architectures, the stack grows downwards, /// so this is the lowest address. fn limit(&self) -> *mut u8; } /// A marker trait for `Stack` objects with a guard page. /// /// To preserve memory safety, an implementation of this trait must fulfill /// the following contract, in addition to the [contract](trait.Stack.html) of `Stack`: /// /// * Any access of data at addresses `limit()` to `limit().offset(4096)` must /// abnormally terminate, at least, the thread that performs the access. pub unsafe trait GuardedStack {}