Struct wasmi::MemoryInstance
source · pub struct MemoryInstance { /* private fields */ }
Expand description
Runtime representation of a linear memory (or memory
for short).
A memory is a contiguous, mutable array of raw bytes. Wasm code can load and store values from/to a linear memory at any byte address. A trap occurs if an access is not within the bounds of the current memory size.
A memory is created with an initial size but can be grown dynamically. The growth can be limited by specifying maximum size. The size of a memory is always a integer multiple of a page size - 64KiB.
At the moment, wasm doesn’t provide any way to shrink the memory.
Implementations§
source§impl MemoryInstance
impl MemoryInstance
sourcepub fn alloc(initial: Pages, maximum: Option<Pages>) -> Result<MemoryRef, Error>
pub fn alloc(initial: Pages, maximum: Option<Pages>) -> Result<MemoryRef, Error>
Allocate a memory instance.
The memory allocated with initial number of pages specified by initial
.
Minimal possible value for initial
is 0 and maximum possible is 65536
.
(Since maximum addressible memory is 232 = 4GiB = 65536 * 64KiB).
It is possible to limit maximum number of pages this memory instance can have by specifying
maximum
. If not specified, this memory instance would be able to allocate up to 4GiB.
Allocated memory is always zeroed.
Errors
Returns Err
if:
initial
is greater thanmaximum
- either
initial
ormaximum
is greater than65536
.
sourcepub fn maximum(&self) -> Option<Pages>
pub fn maximum(&self) -> Option<Pages>
Returns maximum amount of pages this MemoryInstance
can grow to.
Returns None
if there is no limit set.
Maximum memory size cannot exceed 65536
pages or 4GiB.
sourcepub fn current_size(&self) -> Pages
pub fn current_size(&self) -> Pages
Returns current linear memory size.
Maximum memory size cannot exceed 65536
pages or 4GiB.
Example
To convert number of pages to number of bytes you can use the following code:
use wasmi::MemoryInstance;
use wasmi::memory_units::*;
let memory = MemoryInstance::alloc(Pages(1), None).unwrap();
let byte_size: Bytes = memory.current_size().into();
assert_eq!(
byte_size,
Bytes(65536),
);
sourcepub fn get_value<T: LittleEndianConvert>(&self, offset: u32) -> Result<T, Error>
pub fn get_value<T: LittleEndianConvert>(&self, offset: u32) -> Result<T, Error>
Get value from memory at given offset.
sourcepub fn get(&self, offset: u32, size: usize) -> Result<Vec<u8>, Error>
pub fn get(&self, offset: u32, size: usize) -> Result<Vec<u8>, Error>
Copy data from memory at given offset.
This will allocate vector for you.
If you can provide a mutable slice you can use get_into
.
sourcepub fn get_into(&self, offset: u32, target: &mut [u8]) -> Result<(), Error>
pub fn get_into(&self, offset: u32, target: &mut [u8]) -> Result<(), Error>
Copy data from given offset in the memory into target
slice.
Errors
Returns Err
if the specified region is out of bounds.
sourcepub fn set(&self, offset: u32, value: &[u8]) -> Result<(), Error>
pub fn set(&self, offset: u32, value: &[u8]) -> Result<(), Error>
Copy data in the memory at given offset.
sourcepub fn set_value<T: LittleEndianConvert>(
&self,
offset: u32,
value: T
) -> Result<(), Error>
pub fn set_value<T: LittleEndianConvert>(
&self,
offset: u32,
value: T
) -> Result<(), Error>
Copy value in the memory at given offset.
sourcepub fn grow(&self, additional: Pages) -> Result<Pages, Error>
pub fn grow(&self, additional: Pages) -> Result<Pages, Error>
Increases the size of the linear memory by given number of pages. Returns previous memory size if succeeds.
Errors
Returns Err
if attempted to allocate more memory than permited by the limit.
sourcepub fn copy(
&self,
src_offset: usize,
dst_offset: usize,
len: usize
) -> Result<(), Error>
pub fn copy(
&self,
src_offset: usize,
dst_offset: usize,
len: usize
) -> Result<(), Error>
Copy contents of one memory region to another.
Semantically equivalent to memmove
.
Errors
Returns Err
if either of specified regions is out of bounds.
sourcepub fn copy_nonoverlapping(
&self,
src_offset: usize,
dst_offset: usize,
len: usize
) -> Result<(), Error>
pub fn copy_nonoverlapping(
&self,
src_offset: usize,
dst_offset: usize,
len: usize
) -> Result<(), Error>
Copy contents of one memory region to another (non-overlapping version).
Semantically equivalent to memcpy
.
but returns Error if source overlaping with destination.
Errors
Returns Err
if:
- either of specified regions is out of bounds,
- these regions overlaps.
sourcepub fn transfer(
src: &MemoryRef,
src_offset: usize,
dst: &MemoryRef,
dst_offset: usize,
len: usize
) -> Result<(), Error>
pub fn transfer(
src: &MemoryRef,
src_offset: usize,
dst: &MemoryRef,
dst_offset: usize,
len: usize
) -> Result<(), Error>
Copy memory between two (possibly distinct) memory instances.
If the same memory instance passed as src
and dst
then usual copy
will be used.
sourcepub fn clear(&self, offset: usize, new_val: u8, len: usize) -> Result<(), Error>
pub fn clear(&self, offset: usize, new_val: u8, len: usize) -> Result<(), Error>
Fill the memory region with the specified value.
Semantically equivalent to memset
.
Errors
Returns Err
if the specified region is out of bounds.
sourcepub fn zero(&self, offset: usize, len: usize) -> Result<(), Error>
pub fn zero(&self, offset: usize, len: usize) -> Result<(), Error>
Fill the specified memory region with zeroes.
Errors
Returns Err
if the specified region is out of bounds.
sourcepub fn erase(&self) -> Result<(), Error>
pub fn erase(&self) -> Result<(), Error>
Set every byte in the entire linear memory to 0, preserving its size.
Might be useful for some optimization shenanigans.
sourcepub fn with_direct_access<R, F: FnOnce(&[u8]) -> R>(&self, f: F) -> R
pub fn with_direct_access<R, F: FnOnce(&[u8]) -> R>(&self, f: F) -> R
sourcepub fn with_direct_access_mut<R, F: FnOnce(&mut [u8]) -> R>(&self, f: F) -> R
pub fn with_direct_access_mut<R, F: FnOnce(&mut [u8]) -> R>(&self, f: F) -> R
sourcepub fn direct_access<'a>(&'a self) -> impl AsRef<[u8]> + 'a
pub fn direct_access<'a>(&'a self) -> impl AsRef<[u8]> + 'a
sourcepub fn direct_access_mut<'a>(&'a self) -> impl AsMut<[u8]> + 'a
pub fn direct_access_mut<'a>(&'a self) -> impl AsMut<[u8]> + 'a
Trait Implementations§
Auto Trait Implementations§
impl !RefUnwindSafe for MemoryInstance
impl Send for MemoryInstance
impl !Sync for MemoryInstance
impl Unpin for MemoryInstance
impl UnwindSafe for MemoryInstance
Blanket Implementations§
source§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
source§fn into_any(self: Box<T, Global>) -> Box<dyn Any + 'static, Global>
fn into_any(self: Box<T, Global>) -> Box<dyn Any + 'static, Global>
Box<dyn Trait>
(where Trait: Downcast
) to Box<dyn Any>
. Box<dyn Any>
can
then be further downcast
into Box<ConcreteType>
where ConcreteType
implements Trait
. Read moresource§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any + 'static>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any + 'static>
Rc<Trait>
(where Trait: Downcast
) to Rc<Any>
. Rc<Any>
can then be
further downcast
into Rc<ConcreteType>
where ConcreteType
implements Trait
. Read moresource§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
&Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &Any
’s vtable from &Trait
’s. Read moresource§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
&mut Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &mut Any
’s vtable from &mut Trait
’s. Read more