feat: implement memory.atomic.notify,wait32,wait64 (#5255)
* feat: implement memory.atomic.notify,wait32,wait64 Added the parking_spot crate, which provides the needed registry for the operations. Signed-off-by: Harald Hoyer <harald@profian.com> * fix: change trap message for HeapMisaligned The threads spec test wants "unaligned atomic" instead of "misaligned memory access". Signed-off-by: Harald Hoyer <harald@profian.com> * tests: add test for atomic wait on non-shared memory Signed-off-by: Harald Hoyer <harald@profian.com> * tests: add tests/spec_testsuite/proposals/threads without pooling and reference types. Also "shared_memory" is added to the "spectest" interface. Signed-off-by: Harald Hoyer <harald@profian.com> * tests: add atomics_notify.wast checking that notify with 0 waiters returns 0 on shared and non-shared memory. Signed-off-by: Harald Hoyer <harald@profian.com> * tests: add tests for atomic wait on shared memory - return 2 - timeout for 0 - return 2 - timeout for 1000ns - return 1 - invalid value Signed-off-by: Harald Hoyer <harald@profian.com> * fixup! feat: implement memory.atomic.notify,wait32,wait64 Signed-off-by: Harald Hoyer <harald@profian.com> * fixup! feat: implement memory.atomic.notify,wait32,wait64 Signed-off-by: Harald Hoyer <harald@profian.com> Signed-off-by: Harald Hoyer <harald@profian.com>
This commit is contained in:
@@ -84,6 +84,10 @@ pub enum Trap {
|
||||
/// When wasm code is configured to consume fuel and it runs out of fuel
|
||||
/// then this trap will be raised.
|
||||
OutOfFuel,
|
||||
|
||||
/// Used to indicate that a trap was raised by atomic wait operations on non shared memory.
|
||||
AtomicWaitNonSharedMemory,
|
||||
// if adding a variant here be sure to update the `check!` macro below
|
||||
}
|
||||
|
||||
impl fmt::Display for Trap {
|
||||
@@ -93,7 +97,7 @@ impl fmt::Display for Trap {
|
||||
let desc = match self {
|
||||
StackOverflow => "call stack exhausted",
|
||||
MemoryOutOfBounds => "out of bounds memory access",
|
||||
HeapMisaligned => "misaligned memory access",
|
||||
HeapMisaligned => "unaligned atomic",
|
||||
TableOutOfBounds => "undefined element: out of bounds table access",
|
||||
IndirectCallToNull => "uninitialized element",
|
||||
BadSignature => "indirect call type mismatch",
|
||||
@@ -104,6 +108,7 @@ impl fmt::Display for Trap {
|
||||
Interrupt => "interrupt",
|
||||
AlwaysTrapAdapter => "degenerate component adapter called",
|
||||
OutOfFuel => "all fuel consumed by WebAssembly",
|
||||
AtomicWaitNonSharedMemory => "atomic wait on non-shared memory",
|
||||
};
|
||||
write!(f, "wasm trap: {desc}")
|
||||
}
|
||||
@@ -217,6 +222,7 @@ pub fn lookup_trap_code(section: &[u8], offset: usize) -> Option<Trap> {
|
||||
Interrupt
|
||||
AlwaysTrapAdapter
|
||||
OutOfFuel
|
||||
AtomicWaitNonSharedMemory
|
||||
}
|
||||
|
||||
if cfg!(debug_assertions) {
|
||||
|
||||
Reference in New Issue
Block a user