Struct wasmtime_runtime::Instance 
source · #[repr(C)]pub struct Instance { /* private fields */ }Expand description
A type that roughly corresponds to a WebAssembly instance, but is also used for host-defined objects.
This structure is is never allocated directly but is instead managed through
an InstanceHandle. This structure ends with a VMContext which has a
dynamic size corresponding to the module configured within. Memory
management of this structure is always externalized.
Instances here can correspond to actual instantiated modules, but it’s also
used ubiquitously for host-defined objects. For example creating a
host-defined memory will have a module that looks like it exports a single
memory (and similar for other constructs).
This Instance type is used as a ubiquitous representation for WebAssembly
values, whether or not they were created on the host or through a module.
Implementations§
source§impl Instance
 
impl Instance
sourcepub unsafe fn from_vmctx<R>(
    vmctx: *mut VMContext,
    f: impl FnOnce(&mut Instance) -> R
) -> R
 
pub unsafe fn from_vmctx<R>( vmctx: *mut VMContext, f: impl FnOnce(&mut Instance) -> R ) -> R
Converts the provided *mut VMContext to an Instance pointer and runs
the provided closure with the instance.
This method will move the vmctx pointer backwards to point to the
original Instance that precedes it. The closure is provided a
temporary version of the Instance pointer with a constrained lifetime
to the closure to ensure it doesn’t accidentally escape.
Unsafety
Callers must validate that the vmctx pointer is a valid allocation
and that it’s valid to acquire &mut Instance at this time. For example
this can’t be called twice on the same VMContext to get two active
pointers to the same Instance.
sourcepub fn defined_memories<'a>(
    &'a self
) -> impl ExactSizeIterator<Item = (DefinedMemoryIndex, &'a Memory)> + 'a
 
pub fn defined_memories<'a>( &'a self ) -> impl ExactSizeIterator<Item = (DefinedMemoryIndex, &'a Memory)> + 'a
Return the memories defined within this instance (not imported).
sourcepub fn all_globals<'a>(
    &'a mut self
) -> impl ExactSizeIterator<Item = (GlobalIndex, ExportGlobal)> + 'a
 
pub fn all_globals<'a>( &'a mut self ) -> impl ExactSizeIterator<Item = (GlobalIndex, ExportGlobal)> + 'a
Get all globals within this instance.
Returns both import and defined globals.
Returns both exported and non-exported globals.
Gives access to the full globals space.
sourcepub fn defined_globals<'a>(
    &'a mut self
) -> impl ExactSizeIterator<Item = (DefinedGlobalIndex, ExportGlobal)> + 'a
 
pub fn defined_globals<'a>( &'a mut self ) -> impl ExactSizeIterator<Item = (DefinedGlobalIndex, ExportGlobal)> + 'a
Get the globals defined in this instance (not imported).
sourcepub fn runtime_limits(&mut self) -> *mut *const VMRuntimeLimits
 
pub fn runtime_limits(&mut self) -> *mut *const VMRuntimeLimits
Return a pointer to the interrupts structure
sourcepub fn epoch_ptr(&mut self) -> *mut *const AtomicU64
 
pub fn epoch_ptr(&mut self) -> *mut *const AtomicU64
Return a pointer to the global epoch counter used by this instance.
sourcepub fn externref_activations_table(
    &mut self
) -> *mut *mut VMExternRefActivationsTable
 
pub fn externref_activations_table( &mut self ) -> *mut *mut VMExternRefActivationsTable
Return a pointer to the VMExternRefActivationsTable.
sourcepub fn store(&self) -> *mut dyn Store
 
pub fn store(&self) -> *mut dyn Store
Gets a pointer to this instance’s Store which was originally
configured on creation.
Panics
This will panic if the originally configured store was None. That can
happen for host functions so host functions can’t be queried what their
original Store was since it’s just retained as null (since host
functions are shared amongst threads and don’t all share the same
store).
sourcepub fn vmctx(&self) -> *mut VMContext
 
pub fn vmctx(&self) -> *mut VMContext
Return a reference to the vmctx used by compiled wasm code.
sourcepub fn exports(&self) -> Iter<'_, String, EntityIndex>
 
pub fn exports(&self) -> Iter<'_, String, EntityIndex>
Return an iterator over the exports of this instance.
Specifically, it provides access to the key-value pairs, where the keys
are export names, and the values are export declarations which can be
resolved lookup_by_declaration.
sourcepub fn host_state(&self) -> &dyn Any
 
pub fn host_state(&self) -> &dyn Any
Return a reference to the custom state attached to this instance.
sourcepub unsafe fn table_index(
    &mut self,
    table: &VMTableDefinition
) -> DefinedTableIndex
 
pub unsafe fn table_index( &mut self, table: &VMTableDefinition ) -> DefinedTableIndex
Return the table index for the given VMTableDefinition.
sourcepub fn get_defined_memory(&mut self, index: DefinedMemoryIndex) -> *mut Memory
 
pub fn get_defined_memory(&mut self, index: DefinedMemoryIndex) -> *mut Memory
Get a locally-defined memory.