#[repr(C)]pub struct VMDynamicFunctionContext<T> {
pub address: *const VMFunctionBody,
pub ctx: T,
}
Expand description
The VMDynamicFunctionContext
is the context that dynamic
functions will receive when called (rather than vmctx
).
A dynamic function is a function for which we don’t know the signature
until runtime.
As such, we need to expose the dynamic function context
containing the relevant context for running the function indicated
in address
.
Fields§
§address: *const VMFunctionBody
The address of the inner dynamic function.
Note: The function must be on the form of
(*mut T, SignatureIndex, *mut i128)
.
ctx: T
The context that the inner dynamic function will receive.
Trait Implementations§
impl<T: Sized + Send + Sync> Send for VMDynamicFunctionContext<T>
impl<T: Sized + Send + Sync> Sync for VMDynamicFunctionContext<T>
Auto Trait Implementations§
impl<T> Freeze for VMDynamicFunctionContext<T>where
T: Freeze,
impl<T> RefUnwindSafe for VMDynamicFunctionContext<T>where
T: RefUnwindSafe,
impl<T> Unpin for VMDynamicFunctionContext<T>where
T: Unpin,
impl<T> UnwindSafe for VMDynamicFunctionContext<T>where
T: UnwindSafe,
Blanket Implementations§
Source§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
Source§type ArchivedMetadata = ()
type ArchivedMetadata = ()
The archived version of the pointer metadata for this type.
Source§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
Converts some archived metadata to the pointer metadata for itself.
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> LayoutRaw for T
impl<T> LayoutRaw for T
Source§fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
Returns the layout of the type.
Source§impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
Source§unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
Returns whether the given value has been niched. Read more
Source§fn resolve_niched(out: Place<NichedOption<T, N1>>)
fn resolve_niched(out: Place<NichedOption<T, N1>>)
Writes data to
out
indicating that a T
is niched.