summaryrefslogtreecommitdiffstats
path: root/js/src/wasm/WasmRealm.cpp
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-06-12 05:35:37 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-06-12 05:35:37 +0000
commita90a5cba08fdf6c0ceb95101c275108a152a3aed (patch)
tree532507288f3defd7f4dcf1af49698bcb76034855 /js/src/wasm/WasmRealm.cpp
parentAdding debian version 126.0.1-1. (diff)
downloadfirefox-a90a5cba08fdf6c0ceb95101c275108a152a3aed.tar.xz
firefox-a90a5cba08fdf6c0ceb95101c275108a152a3aed.zip
Merging upstream version 127.0.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'js/src/wasm/WasmRealm.cpp')
-rw-r--r--js/src/wasm/WasmRealm.cpp19
1 files changed, 19 insertions, 0 deletions
diff --git a/js/src/wasm/WasmRealm.cpp b/js/src/wasm/WasmRealm.cpp
index 8907715c8f..61d8b96a44 100644
--- a/js/src/wasm/WasmRealm.cpp
+++ b/js/src/wasm/WasmRealm.cpp
@@ -150,3 +150,22 @@ void wasm::ResetInterruptState(JSContext* cx) {
instance->resetInterrupt(cx);
}
}
+
+#ifdef ENABLE_WASM_JSPI
+void wasm::UpdateInstanceStackLimitsForSuspendableStack(
+ JSContext* cx, JS::NativeStackLimit limit) {
+ auto runtimeInstances = cx->runtime()->wasmInstances.lock();
+ cx->wasm().suspendableStackLimit = limit;
+ for (Instance* instance : runtimeInstances.get()) {
+ instance->setTemporaryStackLimit(limit);
+ }
+}
+
+void wasm::ResetInstanceStackLimits(JSContext* cx) {
+ auto runtimeInstances = cx->runtime()->wasmInstances.lock();
+ cx->wasm().suspendableStackLimit = JS::NativeStackLimitMin;
+ for (Instance* instance : runtimeInstances.get()) {
+ instance->resetTemporaryStackLimit(cx);
+ }
+}
+#endif // ENABLE_WASM_JSPI