d8221df3f9
This is a reland of 28ead05405
The failure is a test that is sensitive to adding a function
in a FunctionTemplate in d8: https://bugs.chromium.org/p/v8/issues/detail?id=10783
Original change's description:
> [Atomics.waitAsync] Fix removing multiple nodes when Isolate deinits
>
> RemoveNode already nullifies the next_ pointer of FutexWaitListNode,
> and DeleteAsyncNode was trying to retrieve it.
>
> Bug: v8:10239
> Change-Id: I595885de87f433d263eeacfc825a689efd467f5e
> Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2332812
> Commit-Queue: Marja Hölttä <marja@chromium.org>
> Reviewed-by: Ulan Degenbaev <ulan@chromium.org>
> Reviewed-by: Shu-yu Guo <syg@chromium.org>
> Cr-Commit-Position: refs/heads/master@{#69259}
Bug: v8:10239
Tbr: leszeks@chromium.org
Change-Id: Icec590354886433a0b41c8f9b7af7101b54b7690
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2339469
Reviewed-by: Marja Hölttä <marja@chromium.org>
Commit-Queue: Marja Hölttä <marja@chromium.org>
Cr-Commit-Position: refs/heads/master@{#69275}
38 lines
1.2 KiB
JavaScript
38 lines
1.2 KiB
JavaScript
// Copyright 2020 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: --allow-natives-syntax --harmony-sharedarraybuffer --harmony-atomics-waitasync
|
|
|
|
(function test() {
|
|
const sab = new SharedArrayBuffer(16);
|
|
const i32a = new Int32Array(sab);
|
|
const location = 0;
|
|
|
|
(function createWorker() {
|
|
const script = `onmessage = function(msg) {
|
|
if (msg.sab) {
|
|
const i32a = new Int32Array(msg.sab);
|
|
Atomics.waitAsync(i32a, ${location}, 0);
|
|
postMessage('worker waiting');
|
|
}
|
|
}`;
|
|
// Create 2 workers which wait on the same location.
|
|
let workers = [];
|
|
const worker_count = 2;
|
|
for (let i = 0; i < worker_count; ++i) {
|
|
workers[i] = new Worker(script, {type : 'string'});
|
|
workers[i].postMessage({sab: sab});
|
|
const m = workers[i].getMessage();
|
|
assertEquals('worker waiting', m);
|
|
}
|
|
for (let i = 0; i < worker_count; ++i) {
|
|
workers[i].terminateAndWait();
|
|
}
|
|
})();
|
|
|
|
const notify_return_value = Atomics.notify(i32a, location, 2);
|
|
// No waiters got notified, since they got cleaned up before it.
|
|
assertEquals(0, notify_return_value);
|
|
})();
|