Formatted files

This commit is contained in:
Syrus
2019-01-23 12:35:14 -08:00
parent 70c512ecb3
commit 83d0c3e647
6 changed files with 69 additions and 183 deletions

View File

@ -143,14 +143,14 @@ pub extern "C" fn _getgrnam(name_ptr: c_int, vmctx: &mut Ctx) -> c_int {
pub fn call_malloc(size: i32, vmctx: &mut Ctx) -> u32 {
unimplemented!()
// let ret = instance
// .call("_malloc", &[Value::I32(size)])
// .expect("_malloc call failed");
// if let [Value::I32(x)] = ret.as_slice() {
// *x as u32
// } else {
// panic!("unexpected value from _malloc: {:?}", ret);
// }
// let ret = instance
// .call("_malloc", &[Value::I32(size)])
// .expect("_malloc call failed");
// if let [Value::I32(x)] = ret.as_slice() {
// *x as u32
// } else {
// panic!("unexpected value from _malloc: {:?}", ret);
// }
}
pub fn call_memalign(alignment: u32, size: u32, vmctx: &mut Ctx) -> u32 {
@ -171,21 +171,21 @@ pub fn call_memalign(alignment: u32, size: u32, vmctx: &mut Ctx) -> u32 {
pub fn call_memset(pointer: u32, value: i32, size: u32, vmctx: &mut Ctx) -> u32 {
unimplemented!()
// let ret = instance
// .call(
// "_memset",
// &[
// Value::I32(pointer as i32),
// Value::I32(value),
// Value::I32(size as i32),
// ],
// )
// .expect("_memset call failed");
// if let [Value::I32(x)] = ret.as_slice() {
// *x as u32
// } else {
// panic!("unexpected value from _memset {:?}", ret);
// }
// let ret = instance
// .call(
// "_memset",
// &[
// Value::I32(pointer as i32),
// Value::I32(value),
// Value::I32(size as i32),
// ],
// )
// .expect("_memset call failed");
// if let [Value::I32(x)] = ret.as_slice() {
// *x as u32
// } else {
// panic!("unexpected value from _memset {:?}", ret);
// }
}
pub extern "C" fn _getpagesize() -> u32 {

View File

@ -1,6 +1,6 @@
use super::env;
use super::process::_abort;
use wasmer_runtime_core::{Instance, vm::Ctx};
use wasmer_runtime_core::{vm::Ctx, Instance};
/// emscripten: ___cxa_allocate_exception
pub extern "C" fn ___cxa_allocate_exception(size: u32, vmctx: &mut Ctx) -> u32 {

View File

@ -9,16 +9,12 @@ use wasmer_runtime_core::{
export::{Context, Export, FuncPointer, GlobalPointer, MemoryPointer, TablePointer},
import::{ImportObject, Namespace},
memory::LinearMemory,
structures::TypedIndex,
table::TableBacking,
types::{
FuncSig, GlobalDesc,
ElementType, FuncSig, GlobalDesc, LocalMemoryIndex, Memory, Table,
Type::{self, *},
Memory,
LocalMemoryIndex,
ElementType,
Table,
},
structures::TypedIndex,
vm::LocalGlobal,
vm::LocalMemory,
vm::LocalTable,
@ -183,7 +179,13 @@ impl<'a> EmscriptenGlobals<'a> {
data.insert("env", env_namepace);
data.insert("global", global_namepace);
Self { data, memory, vm_memory, table, vm_table }
Self {
data,
memory,
vm_memory,
table,
vm_table,
}
}
}
@ -203,9 +205,7 @@ pub fn generate_emscripten_env(globals: &mut EmscriptenGlobals) -> ImportObject
let null_ctx = Context::External(ptr::null_mut());
// Memory
let local_memory = unsafe {
MemoryPointer::new(&mut globals.vm_memory)
};
let local_memory = unsafe { MemoryPointer::new(&mut globals.vm_memory) };
env_namespace.insert(
"memory".to_string(),
@ -216,14 +216,12 @@ pub fn generate_emscripten_env(globals: &mut EmscriptenGlobals) -> ImportObject
min: 256,
max: Some(256),
shared: false,
}
},
},
);
// Table
let local_table = unsafe {
TablePointer::new(&mut globals.vm_table)
};
let local_table = unsafe { TablePointer::new(&mut globals.vm_table) };
env_namespace.insert(
"table".to_string(),
@ -235,7 +233,7 @@ pub fn generate_emscripten_env(globals: &mut EmscriptenGlobals) -> ImportObject
ty: ElementType::Anyfunc,
min: 10,
max: Some(10),
}
},
},
);

View File

@ -105,11 +105,7 @@ pub extern "C" fn ___syscall1(which: c_int, mut varargs: VarArgs, vmctx: &mut Ct
}
/// read
pub extern "C" fn ___syscall3(
which: c_int,
mut varargs: VarArgs,
vmctx: &mut Ctx,
) -> ssize_t {
pub extern "C" fn ___syscall3(which: c_int, mut varargs: VarArgs, vmctx: &mut Ctx) -> ssize_t {
debug!("emscripten::___syscall3 (read) {}", which);
let fd: i32 = varargs.get(vmctx);
let buf: u32 = varargs.get(vmctx);
@ -122,11 +118,7 @@ pub extern "C" fn ___syscall3(
}
/// write
pub extern "C" fn ___syscall4(
which: c_int,
mut varargs: VarArgs,
vmctx: &mut Ctx,
) -> c_int {
pub extern "C" fn ___syscall4(which: c_int, mut varargs: VarArgs, vmctx: &mut Ctx) -> c_int {
debug!("emscripten::___syscall4 (write) {}", which);
let fd: i32 = varargs.get(vmctx);
let buf: u32 = varargs.get(vmctx);
@ -137,11 +129,7 @@ pub extern "C" fn ___syscall4(
}
/// open
pub extern "C" fn ___syscall5(
which: c_int,
mut varargs: VarArgs,
vmctx: &mut Ctx,
) -> c_int {
pub extern "C" fn ___syscall5(which: c_int, mut varargs: VarArgs, vmctx: &mut Ctx) -> c_int {
debug!("emscripten::___syscall5 (open) {}", which);
let pathname: u32 = varargs.get(vmctx);
let flags: i32 = varargs.get(vmctx);
@ -157,11 +145,7 @@ pub extern "C" fn ___syscall5(
}
/// close
pub extern "C" fn ___syscall6(
which: c_int,
mut varargs: VarArgs,
vmctx: &mut Ctx,
) -> c_int {
pub extern "C" fn ___syscall6(which: c_int, mut varargs: VarArgs, vmctx: &mut Ctx) -> c_int {
debug!("emscripten::___syscall6 (close) {}", which);
let fd: i32 = varargs.get(vmctx);
debug!("fd: {}", fd);
@ -169,11 +153,7 @@ pub extern "C" fn ___syscall6(
}
// chdir
pub extern "C" fn ___syscall12(
which: c_int,
mut varargs: VarArgs,
vmctx: &mut Ctx,
) -> c_int {
pub extern "C" fn ___syscall12(which: c_int, mut varargs: VarArgs, vmctx: &mut Ctx) -> c_int {
debug!("emscripten::___syscall12 (chdir) {}", which);
let path_addr: i32 = varargs.get(vmctx);
unsafe {
@ -192,11 +172,7 @@ pub extern "C" fn ___syscall20() -> pid_t {
}
// mkdir
pub extern "C" fn ___syscall39(
which: c_int,
mut varargs: VarArgs,
vmctx: &mut Ctx,
) -> c_int {
pub extern "C" fn ___syscall39(which: c_int, mut varargs: VarArgs, vmctx: &mut Ctx) -> c_int {
debug!("emscripten::___syscall39 (mkdir) {}", which);
let pathname: u32 = varargs.get(vmctx);
let mode: u32 = varargs.get(vmctx);
@ -205,11 +181,7 @@ pub extern "C" fn ___syscall39(
}
// rmdir
pub extern "C" fn ___syscall40(
_which: c_int,
mut varargs: VarArgs,
vmctx: &mut Ctx,
) -> c_int {
pub extern "C" fn ___syscall40(_which: c_int, mut varargs: VarArgs, vmctx: &mut Ctx) -> c_int {
debug!("emscripten::___syscall40 (rmdir)");
let pathname: u32 = varargs.get(vmctx);
let pathname_addr = vmctx.memory(0)[pathname as usize] as *const i8;
@ -217,11 +189,7 @@ pub extern "C" fn ___syscall40(
}
/// ioctl
pub extern "C" fn ___syscall54(
which: c_int,
mut varargs: VarArgs,
vmctx: &mut Ctx,
) -> c_int {
pub extern "C" fn ___syscall54(which: c_int, mut varargs: VarArgs, vmctx: &mut Ctx) -> c_int {
debug!("emscripten::___syscall54 (ioctl) {}", which);
let fd: i32 = varargs.get(vmctx);
let request: u32 = varargs.get(vmctx);
@ -263,11 +231,7 @@ pub extern "C" fn ___syscall54(
}
// setpgid
pub extern "C" fn ___syscall57(
which: c_int,
mut varargs: VarArgs,
vmctx: &mut Ctx,
) -> c_int {
pub extern "C" fn ___syscall57(which: c_int, mut varargs: VarArgs, vmctx: &mut Ctx) -> c_int {
debug!("emscripten::___syscall57 (setpgid) {}", which);
let pid: i32 = varargs.get(vmctx);
let pgid: i32 = varargs.get(vmctx);
@ -275,11 +239,7 @@ pub extern "C" fn ___syscall57(
}
// dup2
pub extern "C" fn ___syscall63(
which: c_int,
mut varargs: VarArgs,
vmctx: &mut Ctx,
) -> c_int {
pub extern "C" fn ___syscall63(which: c_int, mut varargs: VarArgs, vmctx: &mut Ctx) -> c_int {
debug!("emscripten::___syscall63 (dup2) {}", which);
let src: i32 = varargs.get(vmctx);
@ -296,11 +256,7 @@ pub extern "C" fn ___syscall64() -> pid_t {
// socketcall
#[allow(clippy::cast_ptr_alignment)]
pub extern "C" fn ___syscall102(
which: c_int,
mut varargs: VarArgs,
vmctx: &mut Ctx,
) -> c_int {
pub extern "C" fn ___syscall102(which: c_int, mut varargs: VarArgs, vmctx: &mut Ctx) -> c_int {
debug!("emscripten::___syscall102 (socketcall) {}", which);
let call: u32 = varargs.get(vmctx);
let mut socket_varargs: VarArgs = varargs.get(vmctx);
@ -547,11 +503,7 @@ pub extern "C" fn ___syscall102(
/// wait4
#[allow(clippy::cast_ptr_alignment)]
pub extern "C" fn ___syscall114(
_which: c_int,
mut varargs: VarArgs,
vmctx: &mut Ctx,
) -> pid_t {
pub extern "C" fn ___syscall114(_which: c_int, mut varargs: VarArgs, vmctx: &mut Ctx) -> pid_t {
debug!("emscripten::___syscall114 (wait4)");
let pid: pid_t = varargs.get(vmctx);
let status: u32 = varargs.get(vmctx);
@ -569,11 +521,7 @@ pub extern "C" fn ___syscall114(
/// uname
// NOTE: Wondering if we should return custom utsname, like Emscripten.
pub extern "C" fn ___syscall122(
which: c_int,
mut varargs: VarArgs,
vmctx: &mut Ctx,
) -> c_int {
pub extern "C" fn ___syscall122(which: c_int, mut varargs: VarArgs, vmctx: &mut Ctx) -> c_int {
debug!("emscripten::___syscall122 (uname) {}", which);
let buf: u32 = varargs.get(vmctx);
debug!("=> buf: {}", buf);
@ -583,11 +531,7 @@ pub extern "C" fn ___syscall122(
// select
#[allow(clippy::cast_ptr_alignment)]
pub extern "C" fn ___syscall142(
which: c_int,
mut varargs: VarArgs,
vmctx: &mut Ctx,
) -> c_int {
pub extern "C" fn ___syscall142(which: c_int, mut varargs: VarArgs, vmctx: &mut Ctx) -> c_int {
debug!("emscripten::___syscall142 (newselect) {}", which);
let nfds: i32 = varargs.get(vmctx);
@ -606,11 +550,7 @@ pub extern "C" fn ___syscall142(
}
// mmap2
pub extern "C" fn ___syscall192(
which: c_int,
mut varargs: VarArgs,
vmctx: &mut Ctx,
) -> c_int {
pub extern "C" fn ___syscall192(which: c_int, mut varargs: VarArgs, vmctx: &mut Ctx) -> c_int {
debug!("emscripten::___syscall192 (mmap2) {}", which);
let addr: i32 = varargs.get(vmctx);
let len: u32 = varargs.get(vmctx);
@ -636,11 +576,7 @@ pub extern "C" fn ___syscall192(
}
/// lseek
pub extern "C" fn ___syscall140(
which: c_int,
mut varargs: VarArgs,
vmctx: &mut Ctx,
) -> off_t {
pub extern "C" fn ___syscall140(which: c_int, mut varargs: VarArgs, vmctx: &mut Ctx) -> off_t {
debug!("emscripten::___syscall140 (lseek) {}", which);
let fd: i32 = varargs.get(vmctx);
let offset: i64 = varargs.get(vmctx);
@ -651,11 +587,7 @@ pub extern "C" fn ___syscall140(
/// readv
#[allow(clippy::cast_ptr_alignment)]
pub extern "C" fn ___syscall145(
which: c_int,
mut varargs: VarArgs,
vmctx: &mut Ctx,
) -> ssize_t {
pub extern "C" fn ___syscall145(which: c_int, mut varargs: VarArgs, vmctx: &mut Ctx) -> ssize_t {
debug!("emscripten::___syscall145 (readv) {}", which);
// let fd: i32 = varargs.get(vmctx);
// let iov: u32 = varargs.get(vmctx);
@ -695,11 +627,7 @@ pub extern "C" fn ___syscall145(
// writev
#[allow(clippy::cast_ptr_alignment)]
pub extern "C" fn ___syscall146(
which: c_int,
mut varargs: VarArgs,
vmctx: &mut Ctx,
) -> ssize_t {
pub extern "C" fn ___syscall146(which: c_int, mut varargs: VarArgs, vmctx: &mut Ctx) -> ssize_t {
debug!("emscripten::___syscall146 (writev) {}", which);
let fd: i32 = varargs.get(vmctx);
let iov: i32 = varargs.get(vmctx);
@ -731,11 +659,7 @@ pub extern "C" fn ___syscall146(
}
// pread
pub extern "C" fn ___syscall180(
which: c_int,
mut varargs: VarArgs,
vmctx: &mut Ctx,
) -> c_int {
pub extern "C" fn ___syscall180(which: c_int, mut varargs: VarArgs, vmctx: &mut Ctx) -> c_int {
debug!("emscripten::___syscall180 (pread) {}", which);
let fd: i32 = varargs.get(vmctx);
let buf: u32 = varargs.get(vmctx);
@ -752,11 +676,7 @@ pub extern "C" fn ___syscall180(
}
// pwrite
pub extern "C" fn ___syscall181(
which: c_int,
mut varargs: VarArgs,
vmctx: &mut Ctx,
) -> c_int {
pub extern "C" fn ___syscall181(which: c_int, mut varargs: VarArgs, vmctx: &mut Ctx) -> c_int {
debug!("emscripten::___syscall181 (pwrite) {}", which);
let fd: i32 = varargs.get(vmctx);
let buf: u32 = varargs.get(vmctx);
@ -777,11 +697,7 @@ pub extern "C" fn ___syscall181(
}
// stat64
pub extern "C" fn ___syscall195(
which: c_int,
mut varargs: VarArgs,
vmctx: &mut Ctx,
) -> c_int {
pub extern "C" fn ___syscall195(which: c_int, mut varargs: VarArgs, vmctx: &mut Ctx) -> c_int {
debug!("emscripten::___syscall195 (stat64) {}", which);
let pathname: u32 = varargs.get(vmctx);
let buf: u32 = varargs.get(vmctx);
@ -801,11 +717,7 @@ pub extern "C" fn ___syscall195(
}
// fstat64
pub extern "C" fn ___syscall197(
which: c_int,
mut varargs: VarArgs,
vmctx: &mut Ctx,
) -> c_int {
pub extern "C" fn ___syscall197(which: c_int, mut varargs: VarArgs, vmctx: &mut Ctx) -> c_int {
debug!("emscripten::___syscall197 (fstat64) {}", which);
let fd: c_int = varargs.get(vmctx);
let buf: u32 = varargs.get(vmctx);
@ -842,11 +754,7 @@ pub extern "C" fn ___syscall202() -> gid_t {
}
// chown
pub extern "C" fn ___syscall212(
which: c_int,
mut varargs: VarArgs,
vmctx: &mut Ctx,
) -> c_int {
pub extern "C" fn ___syscall212(which: c_int, mut varargs: VarArgs, vmctx: &mut Ctx) -> c_int {
debug!("emscripten::___syscall212 (chown) {}", which);
let pathname: u32 = varargs.get(vmctx);
@ -859,11 +767,7 @@ pub extern "C" fn ___syscall212(
}
// fcntl64
pub extern "C" fn ___syscall221(
which: c_int,
mut varargs: VarArgs,
vmctx: &mut Ctx,
) -> c_int {
pub extern "C" fn ___syscall221(which: c_int, mut varargs: VarArgs, vmctx: &mut Ctx) -> c_int {
debug!("emscripten::___syscall221 (fcntl64) {}", which);
// fcntl64
let _fd: i32 = varargs.get(vmctx);
@ -875,11 +779,7 @@ pub extern "C" fn ___syscall221(
}
/// dup3
pub extern "C" fn ___syscall330(
_which: c_int,
mut varargs: VarArgs,
vmctx: &mut Ctx,
) -> pid_t {
pub extern "C" fn ___syscall330(_which: c_int, mut varargs: VarArgs, vmctx: &mut Ctx) -> pid_t {
// Implementation based on description at https://linux.die.net/man/2/dup3
debug!("emscripten::___syscall330 (dup3)");
let oldfd: c_int = varargs.get(vmctx);
@ -913,11 +813,7 @@ pub extern "C" fn ___syscall330(
}
// prlimit64
pub extern "C" fn ___syscall340(
which: c_int,
mut varargs: VarArgs,
vmctx: &mut Ctx,
) -> c_int {
pub extern "C" fn ___syscall340(which: c_int, mut varargs: VarArgs, vmctx: &mut Ctx) -> c_int {
debug!("emscripten::___syscall340 (prlimit64), {}", which);
// NOTE: Doesn't really matter. Wasm modules cannot exceed WASM_PAGE_SIZE anyway.
let _pid: i32 = varargs.get(vmctx);

View File

@ -51,11 +51,7 @@ pub extern "C" fn _gettimeofday(tp: c_int, tz: c_int, vmctx: &mut Ctx) -> c_int
/// emscripten: _clock_gettime
#[allow(clippy::cast_ptr_alignment)]
pub extern "C" fn _clock_gettime(
clk_id: libc::clockid_t,
tp: c_int,
vmctx: &mut Ctx,
) -> c_int {
pub extern "C" fn _clock_gettime(clk_id: libc::clockid_t, tp: c_int, vmctx: &mut Ctx) -> c_int {
debug!("emscripten::_clock_gettime {} {}", clk_id, tp);
#[repr(C)]
struct GuestTimeSpec {
@ -84,11 +80,7 @@ pub extern "C" fn _clock_gettime(
}
/// emscripten: ___clock_gettime
pub extern "C" fn ___clock_gettime(
clk_id: libc::clockid_t,
tp: c_int,
vmctx: &mut Ctx,
) -> c_int {
pub extern "C" fn ___clock_gettime(clk_id: libc::clockid_t, tp: c_int, vmctx: &mut Ctx) -> c_int {
debug!("emscripten::___clock_gettime {} {}", clk_id, tp);
_clock_gettime(clk_id, tp, vmctx)
}

View File

@ -144,8 +144,8 @@ mod tests {
fn should_detect_emscripten_files() {
const wast_bytes: &[u8] = include_bytes!("tests/is_emscripten_true.wast");
let wasm_binary = wat2wasm(wast_bytes.to_vec()).expect("Can't convert to wasm");
let module =
compile_with(&wasm_binary[..], &CraneliftCompiler::new()).expect("WASM can't be compiled");
let module = compile_with(&wasm_binary[..], &CraneliftCompiler::new())
.expect("WASM can't be compiled");
let module = Arc::new(module);
assert!(is_emscripten_module(&module));
}
@ -154,8 +154,8 @@ mod tests {
fn should_detect_non_emscripten_files() {
const wast_bytes: &[u8] = include_bytes!("tests/is_emscripten_false.wast");
let wasm_binary = wat2wasm(wast_bytes.to_vec()).expect("Can't convert to wasm");
let module =
compile_with(&wasm_binary[..], &CraneliftCompiler::new()).expect("WASM can't be compiled");
let module = compile_with(&wasm_binary[..], &CraneliftCompiler::new())
.expect("WASM can't be compiled");
let module = Arc::new(module);
assert!(!is_emscripten_module(&module));
}