2018-04-25 23:29:53 +02:00
|
|
|
// Copyright (C) 2018 Rick Waldron. All rights reserved.
|
|
|
|
// This code is governed by the BSD license found in the LICENSE file.
|
|
|
|
|
|
|
|
/*---
|
|
|
|
esid: sec-atomics.xor
|
|
|
|
description: Test Atomics.xor on arrays that allow atomic operations
|
|
|
|
includes: [testAtomics.js, testBigIntTypedArray.js]
|
2018-05-22 21:10:33 +02:00
|
|
|
features: [ArrayBuffer, arrow-function, Atomics, BigInt, DataView, for-of, let, SharedArrayBuffer, TypedArray]
|
2018-04-25 23:29:53 +02:00
|
|
|
---*/
|
|
|
|
|
|
|
|
var sab = new SharedArrayBuffer(1024);
|
|
|
|
var ab = new ArrayBuffer(16);
|
|
|
|
|
|
|
|
testWithBigIntTypedArrayConstructors(function(TA) {
|
|
|
|
// Make it interesting - use non-zero byteOffsets and non-zero indexes.
|
|
|
|
|
|
|
|
var view = new TA(sab, 32, 20);
|
|
|
|
var control = new TA(ab, 0, 2);
|
|
|
|
|
|
|
|
view[8] = 0x33333333;
|
|
|
|
control[0] = 0x33333333;
|
|
|
|
assert.sameValue(Atomics.xor(view, 8, 0x55555555), control[0],
|
|
|
|
"Result is subject to chopping");
|
|
|
|
|
|
|
|
control[0] = 0x66666666;
|
|
|
|
assert.sameValue(view[8], control[0]);
|
|
|
|
assert.sameValue(Atomics.xor(view, 8, 0xF0F0F0F0), control[0],
|
|
|
|
"Result is subject to chopping");
|
|
|
|
|
|
|
|
control[0] = 0x96969696;
|
|
|
|
assert.sameValue(view[8], control[0]);
|
|
|
|
|
|
|
|
view[3] = -5;
|
|
|
|
control[0] = -5;
|
|
|
|
assert.sameValue(Atomics.xor(view, 3, 0), control[0],
|
|
|
|
"Result is negative and subject to coercion");
|
|
|
|
assert.sameValue(view[3], control[0]);
|
|
|
|
|
|
|
|
control[0] = 12345;
|
|
|
|
view[3] = 12345;
|
|
|
|
assert.sameValue(Atomics.xor(view, 3, 0), control[0],
|
|
|
|
"Result is subject to chopping");
|
|
|
|
assert.sameValue(view[3], control[0]);
|
|
|
|
|
|
|
|
// And again
|
|
|
|
control[0] = 123456789;
|
|
|
|
view[3] = 123456789;
|
|
|
|
assert.sameValue(Atomics.xor(view, 3, 0), control[0],
|
|
|
|
"Result is subject to chopping");
|
|
|
|
assert.sameValue(view[3], control[0]);
|
|
|
|
|
|
|
|
// 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.xor(view, Idx, 0), 37);
|
|
|
|
});
|
|
|
|
});
|