Soften language for notify
on unshared memories
#191
Merged
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Since #144, we've specified that
memory.atomic.notify
is allowed to be executed on unshared memories, but always returns 0 since it is impossible for there to be anything waiting on an unshared memory since all variations of the wait instructions in Wasm and JS trap or throw exceptions on unshared memories. However, I realized recently that there is no technical reason whyAtomics.waitAsync
shouldn't be able to wait on an unshared memory. BecauseAtomics.waitAsync
returns a promise rather than blocking, it can in principle be used to synchronize between multiple asynchronous tasks in flight concurrently in the same JS context, and now that JSPI is becoming more real, this actually might be a useful thing to do. In particularAtomics.waitAsync
could be used to build suspending versions of mutexes and condition variables to synchronize between threads running as different asynchronous tasks within a single JS context.Actually realizing this vision of asynchronous threading with JSPI on top of
Atomics.waitAsync
requires changes on the JS side to allowAtomics.waitAsync
andAtomics.notify
to be used on unshared ArrayBuffers, but in the meantime we can prepare for that change on the Wasm side by softening the language stating thatmemory.atomic.notify
unconditionally returns 0 for unshared memories.cc @syg