Remove dependency on TargetIsa from Wasmtime crates (#3178)
This commit started off by deleting the `cranelift_codegen::settings` reexport in the `wasmtime-environ` crate and then basically played whack-a-mole until everything compiled again. The main result of this is that the `wasmtime-*` family of crates have generally less of a dependency on the `TargetIsa` trait and type from Cranelift. While the dependency isn't entirely severed yet this is at least a significant start. This commit is intended to be largely refactorings, no functional changes are intended here. The refactorings are: * A `CompilerBuilder` trait has been added to `wasmtime_environ` which server as an abstraction used to create compilers and configure them in a uniform fashion. The `wasmtime::Config` type now uses this instead of cranelift-specific settings. The `wasmtime-jit` crate exports the ability to create a compiler builder from a `CompilationStrategy`, which only works for Cranelift right now. In a cranelift-less build of Wasmtime this is expected to return a trait object that fails all requests to compile. * The `Compiler` trait in the `wasmtime_environ` crate has been souped up with a number of methods that Wasmtime and other crates needed. * The `wasmtime-debug` crate is now moved entirely behind the `wasmtime-cranelift` crate. * The `wasmtime-cranelift` crate is now only depended on by the `wasmtime-jit` crate. * Wasm types in `cranelift-wasm` no longer contain their IR type, instead they only contain the `WasmType`. This is required to get everything to align correctly but will also be required in a future refactoring where the types used by `cranelift-wasm` will be extracted to a separate crate. * I moved around a fair bit of code in `wasmtime-cranelift`. * Some gdb-specific jit-specific code has moved from `wasmtime-debug` to `wasmtime-jit`.
This commit is contained in:
@@ -77,19 +77,14 @@ pub fn create_function(
|
||||
func: Box<dyn Fn(*mut VMContext, *mut u128) -> Result<(), Trap> + Send + Sync>,
|
||||
engine: &Engine,
|
||||
) -> Result<(InstanceHandle, VMTrampoline)> {
|
||||
// Note that we specifically enable reference types here in our ISA because
|
||||
// `Func::new` is intended to be infallible, but our signature may use
|
||||
// reference types which requires safepoints.
|
||||
let isa = &*engine.config().target_isa_with_reference_types();
|
||||
let wasm_trampoline = engine.compiler().compiler().wasm_to_host_trampoline(
|
||||
isa,
|
||||
ft.as_wasm_func_type(),
|
||||
stub_fn as usize,
|
||||
)?;
|
||||
let wasm_trampoline = engine
|
||||
.compiler()
|
||||
.compiler()
|
||||
.wasm_to_host_trampoline(ft.as_wasm_func_type(), stub_fn as usize)?;
|
||||
let host_trampoline = engine
|
||||
.compiler()
|
||||
.compiler()
|
||||
.host_to_wasm_trampoline(isa, ft.as_wasm_func_type())?;
|
||||
.host_to_wasm_trampoline(ft.as_wasm_func_type())?;
|
||||
|
||||
let mut code_memory = CodeMemory::new();
|
||||
let host_trampoline = code_memory
|
||||
@@ -98,7 +93,7 @@ pub fn create_function(
|
||||
let wasm_trampoline =
|
||||
code_memory.allocate_for_function(&wasm_trampoline)? as *mut [VMFunctionBody];
|
||||
|
||||
code_memory.publish(isa);
|
||||
code_memory.publish(engine.compiler());
|
||||
|
||||
let sig = engine.signatures().register(ft.as_wasm_func_type());
|
||||
|
||||
|
||||
Reference in New Issue
Block a user