move wasm into its own module

This commit is contained in:
Cadey Ratio 2019-10-24 09:43:00 -04:00
parent cee9a17f90
commit 43f5f9196a
3 changed files with 68 additions and 66 deletions

View File

@ -14,6 +14,7 @@ pub mod interrupts;
pub mod memory; pub mod memory;
pub mod serial; pub mod serial;
pub mod vga_buffer; pub mod vga_buffer;
pub mod wasm;
use linked_list_allocator::LockedHeap; use linked_list_allocator::LockedHeap;

View File

@ -10,11 +10,6 @@ mod hack;
use bootloader::{entry_point, BootInfo}; use bootloader::{entry_point, BootInfo};
use core::panic::PanicInfo; use core::panic::PanicInfo;
use xe_os::{print, println}; use xe_os::{print, println};
use wasmi::{
Error as InterpreterError, Externals, FuncInstance, FuncRef, HostError, ImportsBuilder,
ModuleImportResolver, ModuleInstance, ModuleRef, RuntimeArgs, RuntimeValue, Signature, Trap,
ValueType,
};
entry_point!(kernel_main); entry_point!(kernel_main);
@ -28,31 +23,12 @@ fn kernel_main(boot_info: &'static BootInfo) -> ! {
println!("It did not crash!"); println!("It did not crash!");
run_wasm(); xe_os::wasm::run();
println!("THE WASM RAN :DDDD"); println!("THE WASM RAN :DDDD");
xe_os::hlt_loop(); xe_os::hlt_loop();
} }
fn run_wasm() {
use alloc::vec::Vec;
let bytes = include_bytes!("../data/h.wasm");
let b: Vec<u8> = bytes.iter().cloned().collect();
println!("loaded wasm into a Vec");
let module = wasmi::Module::from_buffer(&b).unwrap();
let mut imports = ImportsBuilder::new();
imports.push_resolver("h", &H);
let instance = ModuleInstance::new(&module, &imports)
.expect("failed to load wasm module")
.assert_no_start();
println!("invoking export");
let _ = instance.invoke_export("h", &[], &mut H);
}
// our existing panic handler // our existing panic handler
#[cfg(not(test))] // new attribute #[cfg(not(test))] // new attribute
#[panic_handler] #[panic_handler]
@ -67,44 +43,3 @@ fn panic(info: &PanicInfo) -> ! {
fn panic(info: &PanicInfo) -> ! { fn panic(info: &PanicInfo) -> ! {
xe_os::test_panic_handler(info); xe_os::test_panic_handler(info);
} }
struct H;
const H_FUNC: usize = 0;
impl Externals for H {
fn invoke_index(
&mut self,
index: usize,
args: RuntimeArgs,
) -> Result<Option<RuntimeValue>, Trap> {
use core::char::from_u32;
match index {
H_FUNC => {
let ch_t: i32 = args.nth(0);
let ch = from_u32(ch_t as u32);
print!("{}", ch.unwrap());
Ok(None)
}
_ => panic!("unknown function called"),
}
}
}
impl ModuleImportResolver for H {
fn resolve_func(
&self,
field_name: &str,
_signature: &Signature,
) -> Result<FuncRef, InterpreterError> {
let func_ref = match field_name {
"h" => FuncInstance::alloc_host(
Signature::new(&[ValueType::I32][..], None),
H_FUNC,
),
_ => panic!("unknwon function asked for"),
};
Ok(func_ref)
}
}

66
src/wasm/mod.rs Normal file
View File

@ -0,0 +1,66 @@
use wasmi::{
Error as InterpreterError, Externals, FuncInstance, FuncRef, HostError, ImportsBuilder,
ModuleImportResolver, ModuleInstance, ModuleRef, RuntimeArgs, RuntimeValue, Signature, Trap,
ValueType,
};
use crate::{print, println};
pub fn run() {
use alloc::vec::Vec;
let bytes = include_bytes!("../../data/h.wasm");
let b: Vec<u8> = bytes.iter().cloned().collect();
println!("loaded wasm into a Vec");
let module = wasmi::Module::from_buffer(&b).unwrap();
let mut imports = ImportsBuilder::new();
imports.push_resolver("h", &H);
let instance = ModuleInstance::new(&module, &imports)
.expect("failed to load wasm module")
.assert_no_start();
println!("invoking export");
let _ = instance.invoke_export("h", &[], &mut H);
}
struct H;
const H_FUNC: usize = 0;
impl Externals for H {
fn invoke_index(
&mut self,
index: usize,
args: RuntimeArgs,
) -> Result<Option<RuntimeValue>, Trap> {
use core::char::from_u32;
match index {
H_FUNC => {
let ch_t: i32 = args.nth(0);
let ch = from_u32(ch_t as u32);
print!("{}", ch.unwrap());
Ok(None)
}
_ => panic!("unknown function called"),
}
}
}
impl ModuleImportResolver for H {
fn resolve_func(
&self,
field_name: &str,
_signature: &Signature,
) -> Result<FuncRef, InterpreterError> {
let func_ref = match field_name {
"h" => FuncInstance::alloc_host(
Signature::new(&[ValueType::I32][..], None),
H_FUNC,
),
_ => panic!("unknwon function asked for"),
};
Ok(func_ref)
}
}