2014-11-03 10:04:37 +00:00
|
|
|
// Copyright 2014 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.
|
|
|
|
|
|
|
|
var stdlib = {};
|
|
|
|
var foreign = {};
|
|
|
|
var heap = new ArrayBuffer(64 * 1024);
|
|
|
|
|
|
|
|
function Uint32Div(divisor) {
|
|
|
|
var name = "div_";
|
|
|
|
name += divisor;
|
2017-02-14 09:26:52 +00:00
|
|
|
var m = eval(
|
|
|
|
'function Module(stdlib, foreign, heap) {\n' +
|
|
|
|
' "use asm";\n' +
|
|
|
|
' function ' + name + '(dividend) {\n' +
|
|
|
|
' dividend = dividend | 0;\n' +
|
|
|
|
' return ((dividend >>> 0) / ' + divisor + ') | 0;\n' +
|
|
|
|
' }\n' +
|
|
|
|
' return { f: ' + name + '}\n' +
|
|
|
|
'}; Module');
|
2014-11-03 10:04:37 +00:00
|
|
|
return m(stdlib, foreign, heap).f;
|
|
|
|
}
|
|
|
|
|
|
|
|
var divisors = [0, 1, 3, 4, 10, 42, 64, 100, 1024, 2147483647, 4294967295];
|
|
|
|
for (var i in divisors) {
|
|
|
|
var divisor = divisors[i];
|
2014-11-04 11:37:31 +00:00
|
|
|
var div = Uint32Div(divisor);
|
2014-11-03 10:04:37 +00:00
|
|
|
for (var dividend = 0; dividend < 4294967296; dividend += 3999773) {
|
2017-02-14 09:26:52 +00:00
|
|
|
assertEquals((dividend / divisor) | 0, div(dividend));
|
2014-11-04 11:37:31 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
var div = (function(stdlib, foreign, heap) {
|
|
|
|
"use asm";
|
|
|
|
function div(dividend, divisor) {
|
2017-02-14 09:26:52 +00:00
|
|
|
dividend = dividend | 0;
|
|
|
|
divisor = divisor | 0;
|
2014-11-04 11:37:31 +00:00
|
|
|
return (dividend >>> 0) / (divisor >>> 0) | 0;
|
|
|
|
}
|
|
|
|
return {div: div};
|
|
|
|
})(stdlib, foreign, heap).div;
|
|
|
|
|
|
|
|
for (var i in divisors) {
|
|
|
|
var divisor = divisors[i];
|
|
|
|
for (var dividend = 0; dividend < 4294967296; dividend += 3999773) {
|
|
|
|
assertEquals((dividend >>> 0) / (divisor >>> 0) | 0,
|
|
|
|
div(dividend, divisor));
|
2014-11-03 10:04:37 +00:00
|
|
|
}
|
|
|
|
}
|