在lib/cli/src/cli.rs
中的wasmer_main
函数开始执行。在这个函数中,调用wasmer_main_inner
函数。在wasmer_main_inner
中,调用run.execute
函数。run.execute
函数在lib/cli/src/commands/run/mod.rs
中,然后调用execute_inner
函数。在execute_inner
函数中会调用execute_wasm
。然后在execute_wasm
函数中会调用execute_wasi_module
。接着在execute_wasi_module
函数中会调用runner.run_wasm
。然后在runner.run_wasm
函数中会调用env.run_with_store
。env.run_with_store
函数在lib/wasix/src/state/builder.rs
中,然后调用self.instantiate
函数进行实例化。在self.instantiate
函数中会调用WasiEnv::instantiate
。然后在WasiEnv::instantiate
函数中会调用Instance::new
来创建实例并处理导入函数。Instance::new
函数在lib/api/src/instance.rs
中,然后调用instance_imp::Instance::new
。instance_imp::Instance::new
函数在lib/api/src/sys/instance.rs
中,然后调用module.0.instantiate
。在module.0.instantiate
函数中会调用self.artifact.instantiate
。self.artifact.instantiate
函数在lib/compiler/src/engine/artifact.rs
中,然后调用module.0.instantiate
。在module.0.instantiate
函数中会调用VMInstance::new
。VMInstance::new
函数在lib/vm/src/instance/mod.rs
中,然后通过ptr::copy
将imports.functions
复制到instance.imported_functions_ptr()
中。这样在后端编译WASM代码时,运行时就能够找到import的函数。其中,HostFunc由Function::new_typed_with_env
函数生成。在new_typed_with_env
函数中,func.function_callback
返回函数体,call_trampoline_address
返回调用import函数时的跳板代码。function_callback
和call_trampoline_address
都在lib/api/src/sys/externals/function.rs
中由impl_host_function
宏生成。在function_callback
中定义了一个C函数func_wrapper
,在func_wrapper
中调用native函数时会通过on_host_stack
将调用栈从WASM栈切换到本地栈。
我们可以看到在Wasmer中整个wasm代码的执行流程是非常清晰的,不像Wasmtime一样有过多的匿名函数。