mirror of
https://github.com/tc39/test262.git
synced 2025-05-03 14:30:27 +02:00
* [javascriptcore-test262-automation] changes from git@github.com:WebKit/webkit.git at sha 949e26452cfa153a7f4afe593da97e2fe9e1b706 on Tue Jul 03 2018 14:35:15 GMT-0400 (Eastern Daylight Time)
31 lines
1.1 KiB
JavaScript
31 lines
1.1 KiB
JavaScript
// This microbenchmarks validates that the fix in https://webkit.org/b/170961
|
|
// does not regress the performance gains from r211670: <http://trac.webkit.org/changeset/211670>.
|
|
// r211670 reduces the size of operationToInt32SensibleSlow() for handling double numbers with
|
|
// binary exponent 31. Hence, this microbenchmark stresses doubleToIn32 conversion on
|
|
// numbers with binary exponents in the vicinity of 31.
|
|
|
|
let doubleValues = [
|
|
2.147483648e8, // exp = 27
|
|
2.147483648e9, // exp = 31
|
|
2.147483648e10, // exp = 34
|
|
];
|
|
|
|
function test(q, r, s, t, u, v, w, x, y, z) {
|
|
// Do a lot of double to int32 conversions to weigh more on the conversion.
|
|
return q|0 + r|0 + s|0 + t|0 + u|0 + v|0 + w|0 + x|0 + y|0 + z|0;
|
|
}
|
|
noInline(test);
|
|
|
|
var result = 0;
|
|
let length = doubleValues.length;
|
|
for (var i = 0; i < 1000000; ++i) {
|
|
for (var j = 0; j < length; j++) {
|
|
var value = doubleValues[j];
|
|
result |= test(value, value, value, value, value, value, value, value, value, value);
|
|
}
|
|
}
|
|
|
|
if (result != -1932735284) {
|
|
throw "Bad result: " + result;
|
|
}
|