From 8d88f320fb915b60b57e3bca3c377b7d0bfb7063 Mon Sep 17 00:00:00 2001 From: Andrew Johnson Date: Fri, 27 Dec 2024 23:37:34 +0800 Subject: [PATCH] Fix compilation of quickjs-libc under emscripten (#773) --- .github/workflows/ci.yml | 2 +- quickjs-libc.c | 10 ++++++++-- 2 files changed, 9 insertions(+), 3 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index a99cf3c..2b5006a 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -398,7 +398,7 @@ jobs: run: emcc -v - name: build run: | - emcmake cmake -B build + emcmake cmake -B build -DBUILD_QJS_LIBC=ON emmake make -C build qjs_wasm -j$(getconf _NPROCESSORS_ONLN) - name: result run: ls -lh build diff --git a/quickjs-libc.c b/quickjs-libc.c index 6dbe501..a7b334f 100644 --- a/quickjs-libc.c +++ b/quickjs-libc.c @@ -3035,15 +3035,19 @@ static int my_execvpe(const char *filename, char **argv, char **envp) return -1; } -static js_once_t js_os_exec_once = JS_ONCE_INIT; - static void (*js_os_exec_closefrom)(int); +#if !defined(EMSCRIPTEN) && !defined(__wasi__) + +static js_once_t js_os_exec_once = JS_ONCE_INIT; + static void js_os_exec_once_init(void) { js_os_exec_closefrom = dlsym(RTLD_DEFAULT, "closefrom"); } +#endif + /* exec(args[, options]) -> exitcode */ static JSValue js_os_exec(JSContext *ctx, JSValue this_val, int argc, JSValue *argv) @@ -3163,9 +3167,11 @@ static JSValue js_os_exec(JSContext *ctx, JSValue this_val, } } +#if !defined(EMSCRIPTEN) && !defined(__wasi__) // should happen pre-fork because it calls dlsym() // and that's not an async-signal-safe function js_once(&js_os_exec_once, js_os_exec_once_init); +#endif pid = fork(); if (pid < 0) {