| Index: src/compiler/js-builtin-reducer.cc
|
| diff --git a/src/compiler/js-builtin-reducer.cc b/src/compiler/js-builtin-reducer.cc
|
| index be7d8b59ef2ceb7dafca510911eba37d27a8f767..0d69a8921913f43151a206e268e4ca2018072024 100644
|
| --- a/src/compiler/js-builtin-reducer.cc
|
| +++ b/src/compiler/js-builtin-reducer.cc
|
| @@ -117,13 +117,15 @@ Reduction JSBuiltinReducer::ReduceMathMax(Node* node) {
|
| return NoChange();
|
| }
|
|
|
| -
|
| -// ES6 draft 08-24-14, section 20.2.2.19.
|
| +// ES6 section 20.2.2.19 Math.imul ( x, y )
|
| Reduction JSBuiltinReducer::ReduceMathImul(Node* node) {
|
| JSCallReduction r(node);
|
| - if (r.InputsMatchTwo(Type::Integral32(), Type::Integral32())) {
|
| - // Math.imul(a:int32, b:int32) -> Int32Mul(a, b)
|
| - Node* value = graph()->NewNode(machine()->Int32Mul(), r.left(), r.right());
|
| + if (r.InputsMatchTwo(Type::Number(), Type::Number())) {
|
| + // Math.imul(a:number, b:number) -> NumberImul(NumberToUint32(a),
|
| + // NumberToUint32(b))
|
| + Node* a = graph()->NewNode(simplified()->NumberToUint32(), r.left());
|
| + Node* b = graph()->NewNode(simplified()->NumberToUint32(), r.right());
|
| + Node* value = graph()->NewNode(simplified()->NumberImul(), a, b);
|
| return Replace(value);
|
| }
|
| return NoChange();
|
|
|