1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
|
// |jit-test| test-join=--spectre-mitigations=off
// These do not test atomicity, just that code generation for BigInt values
// works correctly.
const bigIntValues = [
// Definitely heap digits.
-(2n ** 2000n),
-(2n ** 1000n),
// -(2n**64n)
-18446744073709551617n,
-18446744073709551616n,
-18446744073709551615n,
// -(2n**63n)
-9223372036854775809n,
-9223372036854775808n,
-9223372036854775807n,
// -(2**32)
-4294967297n,
-4294967296n,
-4294967295n,
// -(2**31)
-2147483649n,
-2147483648n,
-2147483647n,
-1n,
0n,
1n,
// 2**31
2147483647n,
2147483648n,
2147483649n,
// 2**32
4294967295n,
4294967296n,
4294967297n,
// 2n**63n
9223372036854775807n,
9223372036854775808n,
9223372036854775809n,
// 2n**64n
18446744073709551615n,
18446744073709551616n,
18446744073709551617n,
// Definitely heap digits.
2n ** 1000n,
2n ** 2000n,
];
function testSub() {
const int64 = new BigInt64Array(2);
const uint64 = new BigUint64Array(2);
// Test with constant index.
for (let i = 0; i < 20; ++i) {
for (let j = 0; j < bigIntValues.length; ++j) {
let value = bigIntValues[j];
Atomics.sub(int64, 0, value);
assertEq(int64[0], BigInt.asIntN(64, -value));
Atomics.sub(uint64, 0, value);
assertEq(uint64[0], BigInt.asUintN(64, -value));
Atomics.sub(int64, 0, -value);
assertEq(int64[0], 0n);
Atomics.sub(uint64, 0, -value);
assertEq(uint64[0], 0n);
}
}
// Test with variable index.
for (let i = 0; i < 20; ++i) {
for (let j = 0; j < bigIntValues.length; ++j) {
let value = bigIntValues[j];
let idx = j & 1;
Atomics.sub(int64, idx, value);
assertEq(int64[idx], BigInt.asIntN(64, -value));
Atomics.sub(uint64, idx, value);
assertEq(uint64[idx], BigInt.asUintN(64, -value));
Atomics.sub(int64, idx, -value);
assertEq(int64[idx], 0n);
Atomics.sub(uint64, idx, -value);
assertEq(uint64[idx], 0n);
}
}
}
for (let i = 0; i < 2; ++i) testSub();
|