From 6f3a82a69c292105b6eed15e4613c3d685294aad Mon Sep 17 00:00:00 2001 From: Michael Dawson Date: Mon, 30 Jan 2023 18:39:33 -0500 Subject: [PATCH] wasi: add wasi socki_accept stub Refs: https://github.com/nodejs/uvwasi/pull/185 Add stub for sock_accept so that we have stubs for all of the sock methods in wasi_snapshot_preview1. Its a bit awkward as the method was added after the initial definitial of wasi_snapshot-preview1 but I think it should be semver minor at most to add the method. Depends on https://github.com/nodejs/uvwasi/pull/185 being landed in uvwasi first and an updated version of uvwasi that includes that being pulled into Node.js Signed-off-by: Michael Dawson --- src/node_wasi.cc | 27 +++++++++------------------ src/node_wasi.h | 2 +- test/wasi/c/sock.c | 17 +++++++++++++++++ test/wasi/test-wasi.js | 1 + test/wasi/wasm/sock.wasm | Bin 0 -> 18983 bytes 5 files changed, 28 insertions(+), 19 deletions(-) create mode 100644 test/wasi/c/sock.c create mode 100755 test/wasi/wasm/sock.wasm diff --git a/src/node_wasi.cc b/src/node_wasi.cc index f22e4adeddc121..cadff31752b9f2 100644 --- a/src/node_wasi.cc +++ b/src/node_wasi.cc @@ -1234,36 +1234,26 @@ uint32_t WASI::SockShutdown(WASI& wasi, return uvwasi_sock_shutdown(&wasi.uvw_, sock, how); } -void WASI::SockAccept(const FunctionCallbackInfo& args) { - WASI* wasi; - uint32_t sock; - uint32_t flags; - uint32_t fd_ptr; - char* memory; - size_t mem_size; - RETURN_IF_BAD_ARG_COUNT(args, 3); - CHECK_TO_TYPE_OR_RETURN(args, args[0], Uint32, sock); - CHECK_TO_TYPE_OR_RETURN(args, args[1], Uint32, flags); - CHECK_TO_TYPE_OR_RETURN(args, args[2], Uint32, fd_ptr); - ASSIGN_INITIALIZED_OR_RETURN_UNWRAP(&wasi, args.This()); +uint32_t WASI::SockAccept(WASI& wasi, + WasmMemory memory, + uint32_t sock, + uint32_t flags, + uint32_t fd_ptr) { Debug(wasi, "sock_accept(%d, %d, %d)\n", sock, flags, fd_ptr); - GET_BACKING_STORE_OR_RETURN(wasi, args, &memory, &mem_size); - CHECK_BOUNDS_OR_RETURN(args, mem_size, fd_ptr, UVWASI_SERDES_SIZE_fd_t); - uvwasi_fd_t fd; - uvwasi_errno_t err = uvwasi_sock_accept(&wasi->uvw_, + uvwasi_errno_t err = uvwasi_sock_accept(&wasi.uvw_, sock, flags, &fd); if (err == UVWASI_ESUCCESS) - uvwasi_serdes_write_size_t(memory, fd_ptr, fd); + uvwasi_serdes_write_size_t(memory.data, fd_ptr, fd); - args.GetReturnValue().Set(err); + return err; } void WASI::_SetMemory(const FunctionCallbackInfo& args) { @@ -1338,6 +1328,7 @@ static void Initialize(Local target, V(SockRecv, "sock_recv") V(SockSend, "sock_send") V(SockShutdown, "sock_shutdown") + V(SockAccept, "sock_accept") #undef V SetInstanceMethod(isolate, tmpl, "_setMemory", WASI::_SetMemory); diff --git a/src/node_wasi.h b/src/node_wasi.h index 8f306afd0188d3..f29dfc0fc02a05 100644 --- a/src/node_wasi.h +++ b/src/node_wasi.h @@ -142,7 +142,7 @@ class WASI : public BaseObject, static uint32_t SockSend( WASI&, WasmMemory, uint32_t, uint32_t, uint32_t, uint32_t, uint32_t); static uint32_t SockShutdown(WASI&, WasmMemory, uint32_t, uint32_t); - static void SockAccept(const v8::FunctionCallbackInfo& args); + static uint32_t SockAccept(WASI&, WasmMemory, uint32_t, uint32_t, uint32_t); static void _SetMemory(const v8::FunctionCallbackInfo& args); diff --git a/test/wasi/c/sock.c b/test/wasi/c/sock.c new file mode 100644 index 00000000000000..2b415c25ea87d1 --- /dev/null +++ b/test/wasi/c/sock.c @@ -0,0 +1,17 @@ +#include +#include +#include +#include +#include + +int main(void) { + + int fd = 0 ; + socklen_t addrlen = 0; + int flags = 0; + int ret = accept(0, NULL, &addrlen); + assert(ret == -1); + assert(errno == 58); + + return 0; +} diff --git a/test/wasi/test-wasi.js b/test/wasi/test-wasi.js index e262d4a45c3718..31ff4f2ae1d85a 100644 --- a/test/wasi/test-wasi.js +++ b/test/wasi/test-wasi.js @@ -98,6 +98,7 @@ if (process.argv[2] === 'wasi-child') { stdout: `hello from input.txt${checkoutEOL}hello from input.txt${checkoutEOL}`, }); runWASI({ test: 'stat' }); + runWASI({ test: 'sock' }); runWASI({ test: 'write_file' }); // Tests that are currently unsupported on Windows. diff --git a/test/wasi/wasm/sock.wasm b/test/wasi/wasm/sock.wasm new file mode 100755 index 0000000000000000000000000000000000000000..367c0621a0477fd586a21f67fcad73852695f170 GIT binary patch literal 18983 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 literal 0 HcmV?d00001