wasmtime

Trait StackCreator

Source
pub unsafe trait StackCreator: Send + Sync {
    // Required method
    fn new_stack(
        &self,
        size: usize,
        zeroed: bool,
    ) -> Result<Box<dyn StackMemory>, Error>;
}
Available on crate features async and runtime only.
Expand description

A stack creator. Can be used to provide a stack creator to wasmtime which supplies stacks for async support.

§Safety

This trait is unsafe, as memory safety depends on a proper implementation of memory management. Stacks created by the StackCreator should always be treated as owned by an wasmtime instance, and any modification of them outside of wasmtime invoked routines is unsafe and may lead to corruption.

Note that this is a relatively new and experimental feature and it is recommended to be familiar with wasmtime runtime code to use it.

Required Methods§

Source

fn new_stack( &self, size: usize, zeroed: bool, ) -> Result<Box<dyn StackMemory>, Error>

Create a new StackMemory object with the specified size.

The size parameter is the expected size of the stack without any guard pages.

The zeroed parameter is whether the stack’s memory should be zeroed, as a defense-in-depth measure.

Note there should be at least one guard page of protected memory at the bottom of the stack to catch potential stack overflow scenarios. Additionally, stacks should be page aligned and zero filled.

Implementors§