wasmer_vm::libcalls

Enum LibCall

Source
#[repr(u16)]
pub enum LibCall {
Show 37 variants CeilF32 = 0, CeilF64 = 1, FloorF32 = 2, FloorF64 = 3, NearestF32 = 4, NearestF64 = 5, TruncF32 = 6, TruncF64 = 7, Memory32Size = 8, ImportedMemory32Size = 9, TableCopy = 10, TableInit = 11, TableFill = 12, TableSize = 13, ImportedTableSize = 14, TableGet = 15, ImportedTableGet = 16, TableSet = 17, ImportedTableSet = 18, TableGrow = 19, ImportedTableGrow = 20, FuncRef = 21, ElemDrop = 22, Memory32Copy = 23, ImportedMemory32Copy = 24, Memory32Fill = 25, ImportedMemory32Fill = 26, Memory32Init = 27, DataDrop = 28, RaiseTrap = 29, Probestack = 30, Memory32AtomicWait32 = 31, ImportedMemory32AtomicWait32 = 32, Memory32AtomicWait64 = 33, ImportedMemory32AtomicWait64 = 34, Memory32AtomicNotify = 35, ImportedMemory32AtomicNotify = 36,
}
Expand description

The name of a runtime library routine.

This list is likely to grow over time.

Variants§

§

CeilF32 = 0

ceil.f32

§

CeilF64 = 1

ceil.f64

§

FloorF32 = 2

floor.f32

§

FloorF64 = 3

floor.f64

§

NearestF32 = 4

nearest.f32

§

NearestF64 = 5

nearest.f64

§

TruncF32 = 6

trunc.f32

§

TruncF64 = 7

trunc.f64

§

Memory32Size = 8

memory.size for local functions

§

ImportedMemory32Size = 9

memory.size for imported functions

§

TableCopy = 10

table.copy

§

TableInit = 11

table.init

§

TableFill = 12

table.fill

§

TableSize = 13

table.size for local tables

§

ImportedTableSize = 14

table.size for imported tables

§

TableGet = 15

table.get for local tables

§

ImportedTableGet = 16

table.get for imported tables

§

TableSet = 17

table.set for local tables

§

ImportedTableSet = 18

table.set for imported tables

§

TableGrow = 19

table.grow for local tables

§

ImportedTableGrow = 20

table.grow for imported tables

§

FuncRef = 21

ref.func

§

ElemDrop = 22

elem.drop

§

Memory32Copy = 23

memory.copy for local memories

§

ImportedMemory32Copy = 24

memory.copy for imported memories

§

Memory32Fill = 25

memory.fill for local memories

§

ImportedMemory32Fill = 26

memory.fill for imported memories

§

Memory32Init = 27

memory.init

§

DataDrop = 28

data.drop

§

RaiseTrap = 29

A custom trap

§

Probestack = 30

probe for stack overflow. These are emitted for functions which need when the enable_probestack setting is true.

§

Memory32AtomicWait32 = 31

memory.atomic.wait32 for local memories

§

ImportedMemory32AtomicWait32 = 32

memory.atomic.wait32 for imported memories

§

Memory32AtomicWait64 = 33

memory.atomic.wait64 for local memories

§

ImportedMemory32AtomicWait64 = 34

memory.atomic.wait64 for imported memories

§

Memory32AtomicNotify = 35

memory.atomic.notify for local memories

§

ImportedMemory32AtomicNotify = 36

memory.atomic.botify for imported memories

Implementations§

Source§

impl LibCall

Source

pub fn to_function_name(&self) -> &str

Return the function name associated to the libcall.

Trait Implementations§

Source§

impl Archive for LibCall

Source§

type Archived = ArchivedLibCall

The archived representation of this type. Read more
Source§

type Resolver = LibCallResolver

The resolver for this type. It must contain all the additional information from serializing needed to make the archived type from the normal type.
Source§

fn resolve( &self, resolver: <LibCall as Archive>::Resolver, out: Place<<LibCall as Archive>::Archived>, )

Creates the archived version of this value at the given position and writes it to the given output. Read more
Source§

const COPY_OPTIMIZATION: CopyOptimization<Self> = _

An optimization flag that allows the bytes of this type to be copied directly to a writer instead of calling serialize. Read more
Source§

impl Clone for LibCall

Source§

fn clone(&self) -> LibCall

Returns a copy of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for LibCall

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
Source§

impl<__D> Deserialize<LibCall, __D> for <LibCall as Archive>::Archived
where __D: Fallible + ?Sized,

Source§

fn deserialize( &self, deserializer: &mut __D, ) -> Result<LibCall, <__D as Fallible>::Error>

Deserializes using the given deserializer
Source§

impl Display for LibCall

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
Source§

impl Hash for LibCall

Source§

fn hash<__H>(&self, state: &mut __H)
where __H: Hasher,

Feeds this value into the given Hasher. Read more
1.3.0 · Source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
Source§

impl IntoEnumIterator for LibCall

Source§

const VARIANT_COUNT: usize = 37usize

Number of variants.
Source§

type Iterator = LibCallEnumIterator

Type of the iterator over the variants.
Source§

fn into_enum_iter() -> <LibCall as IntoEnumIterator>::Iterator

Returns an iterator over the variants. Read more
Source§

impl PartialEq<ArchivedLibCall> for LibCall

Source§

fn eq(&self, other: &ArchivedLibCall) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl PartialEq for LibCall

Source§

fn eq(&self, other: &LibCall) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl<__S> Serialize<__S> for LibCall
where __S: Fallible + ?Sized,

Source§

fn serialize( &self, serializer: &mut __S, ) -> Result<<LibCall as Archive>::Resolver, <__S as Fallible>::Error>

Writes the dependencies for the object and returns a resolver that can create the archived type.
Source§

impl Copy for LibCall

Source§

impl Eq for LibCall

Source§

impl StructuralPartialEq for LibCall

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> ArchivePointee for T

Source§

type ArchivedMetadata = ()

The archived version of the pointer metadata for this type.
Source§

fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata

Converts some archived metadata to the pointer metadata for itself.
Source§

impl<T> ArchiveUnsized for T
where T: Archive,

Source§

type Archived = <T as Archive>::Archived

The archived counterpart of this type. Unlike Archive, it may be unsized. Read more
Source§

fn archived_metadata( &self, ) -> <<T as ArchiveUnsized>::Archived as ArchivePointee>::ArchivedMetadata

Creates the archived version of the metadata for this value.
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dst: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> LayoutRaw for T

Source§

fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>

Returns the layout of the type.
Source§

impl<T> Pointee for T

Source§

type Metadata = ()

The metadata type for pointers and references to this type.
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T, S> SerializeUnsized<S> for T
where T: Serialize<S>, S: Fallible + Writer + ?Sized,

Source§

fn serialize_unsized( &self, serializer: &mut S, ) -> Result<usize, <S as Fallible>::Error>

Writes the object and returns the position of the archived type.
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T> ToString for T
where T: Display + ?Sized,

Source§

default fn to_string(&self) -> String

Converts the given value to a String. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.