From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 From: Andreas Haas Date: Sun, 28 Jul 2024 09:20:12 +0200 Subject: src: stop using deprecated fields of `v8::FastApiCallbackOptions` Two fields on the `v8::FastApiCallbackOptions` struct were deprecated recently: `fallback` and `wasm_memory`. This PR removes uses of these two fields in node.js. (This is a subset of upstream commit d0000b118 from the `canary-base` branch of Node.js. This patch can be removed when Electron upgrades to a stable Node release that contains the change. -- Charles) diff --git a/src/crypto/crypto_timing.cc b/src/crypto/crypto_timing.cc index dbc46400501b61814d5be0ec1cb01b0dcd94e1d0..fe669d40c31a29334b047b9cfee3067f64ef0a7b 100644 --- a/src/crypto/crypto_timing.cc +++ b/src/crypto/crypto_timing.cc @@ -60,7 +60,8 @@ bool FastTimingSafeEqual(Local receiver, if (a.length() != b.length() || !a.getStorageIfAligned(&data_a) || !b.getStorageIfAligned(&data_b)) { TRACK_V8_FAST_API_CALL("crypto.timingSafeEqual.error"); - options.fallback = true; + v8::HandleScope scope(options.isolate); + THROW_ERR_CRYPTO_TIMING_SAFE_EQUAL_LENGTH(options.isolate); return false; } diff --git a/src/histogram.cc b/src/histogram.cc index b655808e43d7c700ddeab7690e287bdbc9bfa50a..b0f7ae4e3af652c6dfe09f66d88485c5783f4037 100644 --- a/src/histogram.cc +++ b/src/histogram.cc @@ -187,7 +187,8 @@ void HistogramBase::FastRecord(Local unused, const int64_t value, FastApiCallbackOptions& options) { if (value < 1) { - options.fallback = true; + Environment* env = Environment::GetCurrent(options.isolate); + THROW_ERR_OUT_OF_RANGE(env, "value is out of range"); return; } HistogramBase* histogram; diff --git a/src/node_wasi.cc b/src/node_wasi.cc index 090866960beb8f1759c99e95536924b8b61fb723..3f91b651b83a20e70d5b368e012f5ee4b9d16092 100644 --- a/src/node_wasi.cc +++ b/src/node_wasi.cc @@ -275,17 +275,19 @@ R WASI::WasiFunction::FastCallback( return EinvalError(); } - if (options.wasm_memory == nullptr || wasi->memory_.IsEmpty()) [[unlikely]] { - // fallback to slow path which to throw an error about missing memory. - options.fallback = true; + v8::Isolate* isolate = receiver->GetIsolate(); + v8::HandleScope handle_scope(isolate); + if (wasi->memory_.IsEmpty()) { + THROW_ERR_WASI_NOT_STARTED(isolate); return EinvalError(); } - uint8_t* memory = nullptr; - CHECK(options.wasm_memory->getStorageIfAligned(&memory)); - return F(*wasi, - {reinterpret_cast(memory), options.wasm_memory->length()}, - args...); + Local ab = wasi->memory_.Get(isolate)->Buffer(); + size_t mem_size = ab->ByteLength(); + char* mem_data = static_cast(ab->Data()); + CHECK_NOT_NULL(mem_data); + + return F(*wasi, {mem_data, mem_size}, args...); } namespace {