From e3fbc486265590d527113ca433303f44ac006d5d Mon Sep 17 00:00:00 2001 From: Matt Knight Date: Fri, 18 Nov 2022 17:56:15 -0800 Subject: [PATCH] Some fixes for the wasi interpreter for macOS (#13587) * Remove usage of O_PATH, ifdef for macos stat struct, and integer formatting --- CMakeLists.txt | 4 ++-- stage1/zig1.c | 16 ++++++++++++---- 2 files changed, 14 insertions(+), 6 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index f8b242698422..4ebc876305cc 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -713,8 +713,8 @@ if(MSVC) set(ZIG2_COMPILE_FLAGS "/std:c99") set(ZIG2_LINK_FLAGS "/STACK:16777216") else() - set(ZIG1_COMPILE_FLAGS "-std=c99 -O1 -march=native") - set(ZIG2_COMPILE_FLAGS "-std=c99 -O1 -march=native") + set(ZIG1_COMPILE_FLAGS "-std=c99 -O1") + set(ZIG2_COMPILE_FLAGS "-std=c99 -O1") set(ZIG2_LINK_FLAGS "-Wl,-z,stack-size=0x10000000") endif() diff --git a/stage1/zig1.c b/stage1/zig1.c index 1f99d3edb8ca..b7d35fd57dd5 100755 --- a/stage1/zig1.c +++ b/stage1/zig1.c @@ -9,6 +9,7 @@ #include #include #include +#include #include #include @@ -859,9 +860,16 @@ static enum wasi_errno_t finish_wasi_stat(struct VirtualMachine *vm, write_u64_le(vm->memory + buf + 0x10, to_wasi_filetype(st.st_mode)); write_u64_le(vm->memory + buf + 0x18, 1); // nlink write_u64_le(vm->memory + buf + 0x20, st.st_size); +#if defined(__APPLE__) + write_u64_le(vm->memory + buf + 0x28, to_wasi_timestamp(st.st_atimespec)); + write_u64_le(vm->memory + buf + 0x30, to_wasi_timestamp(st.st_mtimespec)); + write_u64_le(vm->memory + buf + 0x38, to_wasi_timestamp(st.st_ctimespec)); +#else write_u64_le(vm->memory + buf + 0x28, to_wasi_timestamp(st.st_atim)); write_u64_le(vm->memory + buf + 0x30, to_wasi_timestamp(st.st_mtim)); write_u64_le(vm->memory + buf + 0x38, to_wasi_timestamp(st.st_ctim)); +#endif + return WASI_ESUCCESS; } @@ -1173,7 +1181,7 @@ static enum wasi_errno_t wasi_clock_time_get(struct VirtualMachine *vm, ///pub extern "wasi_snapshot_preview1" fn debug(string: [*:0]const u8, x: u64) void; void wasi_debug(struct VirtualMachine *vm, uint32_t text, uint64_t n) { - fprintf(stderr, "wasi_debug: '%s' number=%lu %lx\n", vm->memory + text, n, n); + fprintf(stderr, "wasi_debug: '%s' number=%" PRIu64" %" PRIx64 "\n", vm->memory + text, n, n); } /// pub extern "wasi_snapshot_preview1" fn debug_slice(ptr: [*]const u8, len: usize) void; @@ -4082,7 +4090,7 @@ int main(int argc, char **argv) { mkdir(cache_dir_buf, 0777); cache_dir = err_wrap("opening cache dir", - open(cache_dir_buf, O_DIRECTORY|O_RDONLY|O_CLOEXEC|O_PATH)); + open(cache_dir_buf, O_DIRECTORY|O_RDONLY|O_CLOEXEC)); } // Construct a new argv for the WASI code which has absolute paths @@ -4171,8 +4179,8 @@ int main(int argc, char **argv) { size_t mod_len = ZSTD_decompress(mod_ptr, max_uncompressed_size, compressed_bytes.ptr, compressed_bytes.len); - int cwd = err_wrap("opening cwd", open(".", O_DIRECTORY|O_RDONLY|O_CLOEXEC|O_PATH)); - int zig_lib_dir = err_wrap("opening zig lib dir", open(zig_lib_dir_path, O_DIRECTORY|O_RDONLY|O_CLOEXEC|O_PATH)); + int cwd = err_wrap("opening cwd", open(".", O_DIRECTORY|O_RDONLY|O_CLOEXEC)); + int zig_lib_dir = err_wrap("opening zig lib dir", open(zig_lib_dir_path, O_DIRECTORY|O_RDONLY|O_CLOEXEC)); add_preopen(0, "stdin", STDIN_FILENO); add_preopen(1, "stdout", STDOUT_FILENO);