b6d4d9be9c
This is a reland of commitb1020a4345
Changes since revert: - Fixed global safepoint interrupts in https://chromium-review.googlesource.com/c/v8/v8/+/3820913 Original change's description: > Reland "[shared-struct] Add Atomics.Condition" > > This is a reland of commite2066ff6bf
> > Changes since revert: > - Rebased againstc991852491
, which > uses the external pointer table for the WaiterQueueNode stored > in the state field when compressing pointers. This relaxes > the alignment requirement of the state field to be 4-bytes when > compressing pointers. > - Moved the state field into the JSSynchronizationPrimitive base > class, since alignment and padding can now be made simpler. > > Original change's description: > > [shared-struct] Add Atomics.Condition > > > > Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3630350 > > Reviewed-by: Dominik Inführ <dinfuehr@chromium.org> > > Reviewed-by: Adam Klein <adamk@chromium.org> > > Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3763787 > Reviewed-by: Adam Klein <adamk@chromium.org> > Reviewed-by: Dominik Inführ <dinfuehr@chromium.org> Bug: v8:12547 Change-Id: Ibc6de74c7853e4ea766ff2c70f92339ba69f2675 Cq-Include-Trybots: luci.v8.try:v8_linux_arm64_rel_ng,v8_linux64_tsan_rel_ng Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3820901 Reviewed-by: Adam Klein <adamk@chromium.org> Commit-Queue: Shu-yu Guo <syg@chromium.org> Cr-Commit-Position: refs/heads/main@{#82368}
37 lines
984 B
JavaScript
37 lines
984 B
JavaScript
// Copyright 2022 the V8 project authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
//
|
|
// Flags: --harmony-struct --allow-natives-syntax
|
|
|
|
let mutex = new Atomics.Mutex;
|
|
let cv = new Atomics.Condition;
|
|
|
|
(function TestConditionWaitNotAllowed() {
|
|
assertThrows(() => {
|
|
Atomics.Mutex.lock(mutex, () => {
|
|
%SetAllowAtomicsWait(false);
|
|
Atomics.Condition.wait(cv, mutex);
|
|
});
|
|
});
|
|
%SetAllowAtomicsWait(true);
|
|
})();
|
|
|
|
(function TestConditionMutexNotHeld() {
|
|
// Cannot wait on a mutex not owned by the current thread.
|
|
assertThrows(() => {
|
|
Atomics.Condition.wait(cv, mutex);
|
|
});
|
|
})();
|
|
|
|
(function TestConditionNoWaiters() {
|
|
// Notify returns number of threads woken up.
|
|
assertEquals(0, Atomics.Condition.notify(cv));
|
|
})();
|
|
|
|
(function TestConditionWaitTimeout() {
|
|
Atomics.Mutex.lock(mutex, () => {
|
|
assertEquals(false, Atomics.Condition.wait(cv, mutex, 100));
|
|
});
|
|
})();
|