1#![deny(missing_docs, trivial_numeric_casts, unused_extern_crates)]
4#![warn(unused_import_braces)]
5#![cfg_attr(feature = "clippy", plugin(clippy(conf_file = "../../clippy.toml")))]
6#![cfg_attr(
7 feature = "cargo-clippy",
8 allow(clippy::new_without_default, clippy::new_without_default)
9)]
10#![cfg_attr(
11 feature = "cargo-clippy",
12 warn(
13 clippy::float_arithmetic,
14 clippy::mut_mut,
15 clippy::nonminimal_bool,
16 clippy::map_unwrap_or,
17 clippy::clippy::print_stdout,
18 clippy::unicode_not_nfc,
19 clippy::use_self
20 )
21)]
22
23use anyhow::Error;
24use std::fmt;
25use std::sync::atomic::{AtomicU64, AtomicUsize, Ordering};
26use std::sync::Arc;
27use wasmtime_environ::{DefinedFuncIndex, DefinedMemoryIndex, HostPtr, VMOffsets};
28
29#[macro_use]
30mod trampolines;
31
32#[cfg(feature = "component-model")]
33pub mod component;
34mod export;
35mod externref;
36mod imports;
37mod instance;
38mod memory;
39mod mmap;
40mod mmap_vec;
41mod parking_spot;
42mod table;
43mod traphandlers;
44mod vmcontext;
45
46pub mod debug_builtins;
47pub mod libcalls;
48
49pub use wasmtime_jit_debug::gdb_jit_int::GdbJitImageRegistration;
50
51pub use crate::export::*;
52pub use crate::externref::*;
53pub use crate::imports::Imports;
54pub use crate::instance::{
55 InstanceAllocationRequest, InstanceAllocator, InstanceHandle, OnDemandInstanceAllocator,
56 StorePtr,
57};
58#[cfg(feature = "pooling-allocator")]
59pub use crate::instance::{
60 InstanceLimits, PoolingInstanceAllocator, PoolingInstanceAllocatorConfig,
61};
62pub use crate::memory::{
63 DefaultMemoryCreator, Memory, RuntimeLinearMemory, RuntimeMemoryCreator, SharedMemory,
64};
65pub use crate::mmap::Mmap;
66pub use crate::mmap_vec::MmapVec;
67pub use crate::table::{Table, TableElement};
68pub use crate::trampolines::prepare_host_to_wasm_trampoline;
69pub use crate::traphandlers::{
70 catch_traps, init_traps, raise_lib_trap, raise_user_trap, resume_panic, tls_eager_initialize,
71 Backtrace, SignalHandler, TlsRestore, Trap, TrapReason,
72};
73pub use crate::vmcontext::{
74 VMCallerCheckedFuncRef, VMContext, VMFunctionBody, VMFunctionImport, VMGlobalDefinition,
75 VMGlobalImport, VMHostFuncContext, VMInvokeArgument, VMMemoryDefinition, VMMemoryImport,
76 VMOpaqueContext, VMRuntimeLimits, VMSharedSignatureIndex, VMTableDefinition, VMTableImport,
77 VMTrampoline, ValRaw,
78};
79
80mod module_id;
81pub use module_id::{CompiledModuleId, CompiledModuleIdAllocator};
82
83mod cow;
84pub use crate::cow::{MemoryImage, MemoryImageSlot, ModuleMemoryImages};
85
86pub const VERSION: &str = env!("CARGO_PKG_VERSION");
88
89pub unsafe trait Store {
102 fn vmruntime_limits(&self) -> *mut VMRuntimeLimits;
108
109 fn epoch_ptr(&self) -> *const AtomicU64;
113
114 fn externref_activations_table(
120 &mut self,
121 ) -> (&mut VMExternRefActivationsTable, &dyn ModuleInfoLookup);
122
123 fn memory_growing(
126 &mut self,
127 current: usize,
128 desired: usize,
129 maximum: Option<usize>,
130 ) -> Result<bool, Error>;
131 fn memory_grow_failed(&mut self, error: &Error);
134 fn table_growing(
137 &mut self,
138 current: u32,
139 desired: u32,
140 maximum: Option<u32>,
141 ) -> Result<bool, Error>;
142 fn table_grow_failed(&mut self, error: &Error);
145 fn out_of_gas(&mut self) -> Result<(), Error>;
149 fn new_epoch(&mut self) -> Result<u64, Error>;
153}
154
155pub trait ModuleRuntimeInfo: Send + Sync + 'static {
169 fn module(&self) -> &Arc<wasmtime_environ::Module>;
171
172 fn function(&self, index: DefinedFuncIndex) -> *mut VMFunctionBody;
174
175 fn memory_image(&self, memory: DefinedMemoryIndex)
178 -> anyhow::Result<Option<&Arc<MemoryImage>>>;
179
180 fn unique_id(&self) -> Option<CompiledModuleId>;
184
185 fn wasm_data(&self) -> &[u8];
187
188 fn signature_ids(&self) -> &[VMSharedSignatureIndex];
191
192 fn offsets(&self) -> &VMOffsets<HostPtr>;
194}
195
196pub fn page_size() -> usize {
198 static PAGE_SIZE: AtomicUsize = AtomicUsize::new(0);
199
200 return match PAGE_SIZE.load(Ordering::Relaxed) {
201 0 => {
202 let size = get_page_size();
203 assert!(size != 0);
204 PAGE_SIZE.store(size, Ordering::Relaxed);
205 size
206 }
207 n => n,
208 };
209
210 #[cfg(windows)]
211 fn get_page_size() -> usize {
212 use std::mem::MaybeUninit;
213 use windows_sys::Win32::System::SystemInformation::*;
214
215 unsafe {
216 let mut info = MaybeUninit::uninit();
217 GetSystemInfo(info.as_mut_ptr());
218 info.assume_init_ref().dwPageSize as usize
219 }
220 }
221
222 #[cfg(unix)]
223 fn get_page_size() -> usize {
224 unsafe { libc::sysconf(libc::_SC_PAGESIZE) as usize }
225 }
226}
227
228#[derive(Copy, Clone, PartialEq, Eq, Debug)]
230pub enum WaitResult {
231 Ok = 0,
234 Mismatch = 1,
237 TimedOut = 2,
240}
241
242#[derive(Debug)]
244pub struct WasmFault {
245 pub memory_size: usize,
247 pub wasm_address: u64,
249}
250
251impl fmt::Display for WasmFault {
252 fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
253 write!(
254 f,
255 "memory fault at wasm address 0x{:x} in linear memory of size 0x{:x}",
256 self.wasm_address, self.memory_size,
257 )
258 }
259}