OLD | NEW |
1 // Copyright 2014 the V8 project authors. All rights reserved. | 1 // Copyright 2014 the V8 project authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 var stdlib = {}; | 5 var stdlib = {}; |
6 var foreign = {}; | 6 var foreign = {}; |
7 var heap = new ArrayBuffer(64 * 1024); | 7 var heap = new ArrayBuffer(64 * 1024); |
8 | 8 |
9 function Int32Div(divisor) { | 9 function Int32Div(divisor) { |
10 var name = "div_"; | 10 var name = "div_"; |
11 if (divisor < 0) { | 11 if (divisor < 0) { |
12 name += "minus_"; | 12 name += "minus_"; |
13 } | 13 } |
14 name += Math.abs(divisor); | 14 name += Math.abs(divisor); |
15 var m = eval("function Module(stdlib, foreign, heap) {\n" | 15 var m = eval( |
16 + " \"use asm\";\n" | 16 'function Module(stdlib, foreign, heap) {\n' + |
17 + " function " + name + "(dividend) {\n" | 17 ' "use asm";\n' + |
18 + " return ((dividend | 0) / " + divisor + ") | 0;\n" | 18 ' function ' + name + '(dividend) {\n' + |
19 + " }\n" | 19 ' dividend = dividend | 0;\n' + |
20 + " return { f: " + name + "}\n" | 20 ' return ((dividend | 0) / ' + divisor + ') | 0;\n' + |
21 + "}; Module"); | 21 ' }\n' + |
| 22 ' return { f: ' + name + '}\n' + |
| 23 '}; Module'); |
22 return m(stdlib, foreign, heap).f; | 24 return m(stdlib, foreign, heap).f; |
23 } | 25 } |
24 | 26 |
25 var divisors = [-2147483648, -32 * 1024, -1000, -16, -7, -2, -1, 0, | 27 var divisors = [-2147483648, -32 * 1024, -1000, -16, -7, -2, -1, 0, |
26 1, 3, 4, 10, 64, 100, 1024, 2147483647]; | 28 1, 3, 4, 10, 64, 100, 1024, 2147483647]; |
27 for (var i in divisors) { | 29 for (var i in divisors) { |
28 var divisor = divisors[i]; | 30 var divisor = divisors[i]; |
29 var div = Int32Div(divisor); | 31 var div = Int32Div(divisor); |
30 for (var dividend = -2147483648; dividend < 2147483648; dividend += 3999773) { | 32 for (var dividend = -2147483648; dividend < 2147483648; dividend += 3999773) { |
31 assertEquals((dividend / divisor) | 0, div(dividend)); | 33 assertEquals((dividend / divisor) | 0, div(dividend)); |
32 } | 34 } |
33 } | 35 } |
OLD | NEW |