diff --git a/.github/workflows/ci-large.yml b/.github/workflows/ci-large.yml index 4a35aedbf..880e1f370 100644 --- a/.github/workflows/ci-large.yml +++ b/.github/workflows/ci-large.yml @@ -26,7 +26,7 @@ jobs: ngx: [1.25.2] runtime: [wasmtime, wasmer, v8] wasmtime: [12.0.1] - wasmer: [3.1.1] + wasmer: [4.2.0] v8: [11.4.183.23] debug: [debug, no_debug] hup: [hup, no_hup] @@ -69,7 +69,7 @@ jobs: ngx: [1.25.2] runtime: [wasmer, wasmtime, v8] wasmtime: [12.0.1] - wasmer: [3.1.1] + wasmer: [4.2.0] v8: [11.4.183.23] hup: [hup, no_hup] debug: [debug] @@ -80,7 +80,7 @@ jobs: cc: gcc-10 openresty: 1.21.4.2 runtime: wasmer - wasmer: 3.1.1 + wasmer: 4.2.0 debug: debug hup: no_hup uses: ./.github/workflows/job-valgrind-tests.yml @@ -107,7 +107,7 @@ jobs: openresty: [1.21.4.2] runtime: [wasmtime, wasmer, v8] wasmtime: [12.0.1] - wasmer: [3.1.1] + wasmer: [4.2.0] v8: [11.4.183.23] ssl: [no_ssl, ssl] debug: [debug, no_debug] diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 23784e803..a59a5c26b 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -33,7 +33,7 @@ jobs: openresty: [""] runtime: [wasmer] wasmtime: [""] - wasmer: [3.1.1] + wasmer: [4.2.0] v8: [""] ssl: [ssl] debug: [debug, no_debug] @@ -64,7 +64,7 @@ jobs: cc: gcc-9 ngx: 1.21.6 runtime: wasmer - wasmer: 3.1.1 + wasmer: 4.2.0 ssl: ssl debug: debug hup: no_hup @@ -84,7 +84,7 @@ jobs: cc: gcc-9 ngx: 1.25.2 runtime: wasmer - wasmer: 3.1.1 + wasmer: 4.2.0 ssl: no_ssl debug: no_debug hup: no_hup @@ -152,7 +152,7 @@ jobs: openresty: [""] runtime: [wasmer] wasmtime: [""] - wasmer: [3.1.1] + wasmer: [4.2.0] v8: [""] hup: [no_hup, hup] debug: [debug] @@ -180,7 +180,7 @@ jobs: openresty: 1.21.4.2 ngx: runtime: wasmer - wasmer: 3.1.1 + wasmer: 4.2.0 debug: debug hup: no_hup uses: ./.github/workflows/job-valgrind-tests.yml @@ -244,7 +244,7 @@ jobs: openresty: [1.21.4.2] runtime: [wasmtime, wasmer, v8] wasmtime: [12.0.1] - wasmer: [3.1.1] + wasmer: [4.2.0] v8: [11.4.183.23] ssl: [ssl] debug: [debug, no_debug] @@ -254,7 +254,7 @@ jobs: cc: clang-11 ngx: 1.25.2 runtime: wasmer - wasmer: 3.1.1 + wasmer: 4.2.0 ssl: no_ssl debug: debug uses: ./.github/workflows/job-clang-analyzer.yml @@ -282,7 +282,7 @@ jobs: ngx: [1.25.2] runtime: [wasmtime, wasmer, v8] wasmtime: [12.0.1] - wasmer: [3.1.1] + wasmer: [4.2.0] v8: [11.4.183.23] include: - label: old_nginx diff --git a/Makefile b/Makefile index 1203b1d12..14c4c3c6f 100644 --- a/Makefile +++ b/Makefile @@ -1,7 +1,7 @@ NGX ?= 1.25.2 OPENSSL ?= 3.1.2 WASMTIME ?= 12.0.1 -WASMER ?= 3.1.1 +WASMER ?= 4.2.0 V8 ?= 11.4.183.23 PCRE ?= 8.45 ZLIB ?= 1.2.13 diff --git a/src/wasm/wrt/ngx_wrt.h b/src/wasm/wrt/ngx_wrt.h index 6869df54d..fc7c141f4 100644 --- a/src/wasm/wrt/ngx_wrt.h +++ b/src/wasm/wrt/ngx_wrt.h @@ -112,9 +112,9 @@ void ngx_wasmtime_valvec2wasm(wasm_val_vec_t *out, wasmtime_val_t *vec, #elif NGX_WASM_HAVE_WASMER #include -#if WASMER_VERSION_MAJOR != 3 +#if WASMER_VERSION_MAJOR != 4 # error Unsupported Wasmer version -#elif WASMER_VERSION_MINOR > 1 +#elif WASMER_VERSION_MINOR > 2 # warning Untested Wasmer version #endif diff --git a/src/wasm/wrt/ngx_wrt_wasmer.c b/src/wasm/wrt/ngx_wrt_wasmer.c index 497e4cdfe..ef0ff6298 100644 --- a/src/wasm/wrt/ngx_wrt_wasmer.c +++ b/src/wasm/wrt/ngx_wrt_wasmer.c @@ -604,6 +604,14 @@ ngx_wasmer_init_instance(ngx_wrt_instance_t *instance, ngx_wrt_store_t *store, instance->ctxs = hctxs; + if (module->wasi + && !wasi_env_initialize_instance(store->wasi_env, store->store, + instance->instance)) + { + dd("wasi_env_initialize_instance failed"); + goto error; + } + return NGX_OK; error: @@ -690,11 +698,6 @@ ngx_wasmer_init_extern(ngx_wrt_extern_t *ext, ngx_wrt_instance_t *instance, ngx_wasm_assert(wasm_extern_kind(ext->ext) == WASM_EXTERN_MEMORY); ext->kind = NGX_WRT_EXTERN_MEMORY; instance->memory = wasm_extern_as_memory(ext->ext); - - if (module->wasi) { - wasi_env_set_memory(instance->store->wasi_env, instance->memory); - } - break; case WASM_EXTERN_GLOBAL: diff --git a/valgrind.suppress b/valgrind.suppress index 6286fe397..4fe2002d3 100644 --- a/valgrind.suppress +++ b/valgrind.suppress @@ -22,14 +22,14 @@ fun:ngx_crc32_table_init } { - + Memcheck:Cond fun:_ZN10wasmparser6parser6Parser5parse17h* ... fun:main } { - + Memcheck:Leak match-leak-kinds: definite fun:malloc @@ -38,7 +38,7 @@ fun:wasm_instance_new } { - + Memcheck:Leak match-leak-kinds: possible fun:calloc