2017-02-07 17:17:31 +01:00
|
|
|
// Copyright (C) 2017 Mozilla Corporation. All rights reserved.
|
|
|
|
// This code is governed by the BSD license found in the LICENSE file.
|
|
|
|
|
|
|
|
/*---
|
2017-07-26 23:49:55 +02:00
|
|
|
esid: sec-atomics.compareexchange
|
2017-02-07 17:17:31 +01:00
|
|
|
description: Test Atomics.compareExchange on arrays that allow atomic operations.
|
|
|
|
includes: [testAtomics.js, testTypedArray.js]
|
2017-09-08 18:34:19 +02:00
|
|
|
features: [SharedArrayBuffer, ArrayBuffer, DataView, Atomics, arrow-function, let, TypedArray, for-of]
|
2017-02-07 17:17:31 +01:00
|
|
|
---*/
|
|
|
|
|
|
|
|
var sab = new SharedArrayBuffer(1024);
|
|
|
|
var ab = new ArrayBuffer(16);
|
|
|
|
|
|
|
|
var int_views = [Int8Array, Uint8Array, Int16Array, Uint16Array, Int32Array, Uint32Array];
|
|
|
|
|
2018-02-09 18:09:47 +01:00
|
|
|
var good_indices = [ (view) => 0/-1, // -0
|
|
|
|
(view) => '-0',
|
|
|
|
(view) => view.length - 1,
|
|
|
|
(view) => ({ valueOf: () => 0 }),
|
|
|
|
(view) => ({ toString: () => '0', valueOf: false }) // non-callable valueOf triggers invocation of toString
|
|
|
|
];
|
2017-02-07 17:17:31 +01:00
|
|
|
|
|
|
|
testWithTypedArrayConstructors(function(View) {
|
2018-02-09 18:09:47 +01:00
|
|
|
// Make it interesting - use non-zero byteOffsets and non-zero indexes.
|
2017-02-07 17:17:31 +01:00
|
|
|
|
2018-02-09 18:09:47 +01:00
|
|
|
var view = new View(sab, 32, 20);
|
|
|
|
var control = new View(ab, 0, 2);
|
2017-02-07 17:17:31 +01:00
|
|
|
|
2018-02-09 18:09:47 +01:00
|
|
|
// Performs the exchange
|
|
|
|
view[8] = 0;
|
|
|
|
assert.sameValue(Atomics.compareExchange(view, 8, 0, 10), 0);
|
|
|
|
assert.sameValue(view[8], 10);
|
2017-02-07 17:17:31 +01:00
|
|
|
|
2018-02-09 18:09:47 +01:00
|
|
|
view[8] = 0;
|
|
|
|
assert.sameValue(Atomics.compareExchange(view, 8, 1, 10), 0,
|
|
|
|
"Does not perform the exchange");
|
|
|
|
assert.sameValue(view[8], 0);
|
2017-02-07 17:17:31 +01:00
|
|
|
|
2018-02-09 18:09:47 +01:00
|
|
|
view[8] = 0;
|
|
|
|
assert.sameValue(Atomics.compareExchange(view, 8, 0, -5), 0,
|
|
|
|
"Performs the exchange, coercing the value being stored");
|
|
|
|
control[0] = -5;
|
|
|
|
assert.sameValue(view[8], control[0]);
|
2017-02-07 17:17:31 +01:00
|
|
|
|
|
|
|
|
2018-02-09 18:09:47 +01:00
|
|
|
view[3] = -5;
|
|
|
|
control[0] = -5;
|
|
|
|
assert.sameValue(Atomics.compareExchange(view, 3, -5, 0), control[0],
|
|
|
|
"Performs the exchange, coercing the value being tested");
|
|
|
|
assert.sameValue(view[3], 0);
|
2017-02-07 17:17:31 +01:00
|
|
|
|
|
|
|
|
2018-02-09 18:09:47 +01:00
|
|
|
control[0] = 12345;
|
|
|
|
view[3] = 12345;
|
|
|
|
assert.sameValue(Atomics.compareExchange(view, 3, 12345, 0), control[0],
|
|
|
|
"Performs the exchange, chopping the value being tested");
|
|
|
|
assert.sameValue(view[3], 0);
|
2017-02-07 17:17:31 +01:00
|
|
|
|
2018-02-09 18:09:47 +01:00
|
|
|
control[0] = 123456789;
|
|
|
|
view[3] = 123456789;
|
|
|
|
assert.sameValue(Atomics.compareExchange(view, 3, 123456789, 0), control[0],
|
|
|
|
"Performs the exchange, chopping the value being tested");
|
|
|
|
assert.sameValue(view[3], 0);
|
2017-02-07 17:17:31 +01:00
|
|
|
|
2018-02-09 18:09:47 +01:00
|
|
|
// In-bounds boundary cases for indexing
|
|
|
|
testWithAtomicsInBoundsIndices(function(IdxGen) {
|
|
|
|
let Idx = IdxGen(view);
|
|
|
|
view.fill(0);
|
|
|
|
// Atomics.store() computes an index from Idx in the same way as other
|
|
|
|
// Atomics operations, not quite like view[Idx].
|
|
|
|
Atomics.store(view, Idx, 37);
|
|
|
|
assert.sameValue(Atomics.compareExchange(view, Idx, 37, 0), 37);
|
|
|
|
});
|
2017-02-07 17:17:31 +01:00
|
|
|
}, int_views);
|