#![feature(test, libc)] extern crate test; #[macro_use] extern crate error_chain; #[macro_use] extern crate structopt; extern crate cranelift_codegen; extern crate cranelift_entity; extern crate cranelift_native; extern crate cranelift_wasm; extern crate wabt; #[macro_use] extern crate target_lexicon; extern crate spin; use std::time::{Duration, Instant}; // #[macro_use] extern crate log; use libc; use std::error::Error; use std::fs::File; use std::io; use std::io::Read; use std::path::PathBuf; use std::process::exit; use structopt::StructOpt; use wabt::wat2wasm; #[macro_use] mod macros; pub mod common; pub mod integrations; pub mod spectests; pub mod webassembly; #[derive(Debug, StructOpt)] #[structopt(name = "wasmer", about = "WASM execution runtime.")] /// The options for the wasmer Command Line Interface enum CLIOptions { /// Run a WebAssembly file. Formats accepted: wasm, wast #[structopt(name = "run")] Run(Run), } #[derive(Debug, StructOpt)] struct Run { #[structopt(short = "d", long = "debug")] debug: bool, /// Input file #[structopt(parse(from_os_str))] path: PathBuf, } /// Read the contents of a file fn read_file_contents(path: PathBuf) -> Result, io::Error> { let mut buffer: Vec = Vec::new(); let mut file = File::open(path)?; file.read_to_end(&mut buffer)?; Ok(buffer) } /// Execute a WASM/WAT file fn execute_wasm(wasm_path: PathBuf) -> Result<(), String> { let mut wasm_binary: Vec = read_file_contents(wasm_path).map_err(|err| String::from(err.description()))?; if !webassembly::utils::is_wasm_binary(&wasm_binary) { wasm_binary = wat2wasm(wasm_binary).map_err(|err| String::from(err.description()))?; } let import_object = integrations::generate_libc_env(); let webassembly::ResultObject { module, mut instance } = webassembly::instantiate(wasm_binary, import_object) .map_err(|err| String::from(err.description()))?; let func_index = instance .start_func .unwrap_or_else(|| match module.info.exports.get("main") { Some(&webassembly::Export::Function(index)) => index, _ => panic!("Main function not found"), }); let main: fn(&webassembly::VmCtx) = get_instance_function!(instance, func_index); let mainn_func_index = match module.info.exports.get("mainn") { Some(&webassembly::Export::Function(index)) => index, _ => panic!("Mainn function not found"), }; let mainn: fn(*const usize) -> i32 = get_instance_function!(instance, mainn_func_index); let context = &instance.generate_context(); let pointer_context = &context as *const _; // println!("Context ptr {:p}", context); println!("Context ptr {:?}", pointer_context); // println!("Context ptr {:?}", &context as *const _); // println!("Memories ptr {:?}", context.memories.as_ptr()); let pointer_tables = &context.tables as *const _; println!("Tables ptr {:?}", pointer_tables); println!("Tables ptr {:p}", pointer_tables); let ref tables_ptr_2 = unsafe { (&*pointer_tables as *const _) }; println!("Tables ptr {:?}", tables_ptr_2); println!("DIFF {:?}", (pointer_tables as usize-pointer_context as usize)); // println!("Tables ptr {:?}", context.tables.as_ptr()); // println!("Tables ptr {:?}", &context.tables as *const _); // println!("Tables ptr {:?}", &context.tables as *const _); // println!("User data ptr {:?}", &context.user_data as *const _); // println!("Globals ptr {:?}", &context.globals as *const _); // println!("Memories ptr {:?}", &context.memories as *const _); // println!("Tables ptr {:?}", &context.tables as *const _); // unsafe { // println!("Tables 0 ptr {:p}", &context.tables.get_unchecked(0)); // println!("Tables 0 ptr {:p}", &context.tables.get_unchecked(0).get(0)); // } let table_ptr = &context.tables as *const _; // let table: &Ta main(&context); println!("-------------NOW MAINN----------"); let res = mainn(pointer_context as *const usize); println!("RESULT {:?}", res); Ok(()) } fn run(options: Run) { match execute_wasm(options.path.clone()) { Ok(()) => {} Err(message) => { let name = options.path.as_os_str().to_string_lossy(); println!("error while executing {}: {}", name, message); exit(1); } } } fn main() { let options = CLIOptions::from_args(); match options { CLIOptions::Run(options) => run(options), } }