| Index: src/compiler/js-builtin-reducer-unittest.cc
|
| diff --git a/src/compiler/js-builtin-reducer-unittest.cc b/src/compiler/js-builtin-reducer-unittest.cc
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..ca12c50d8b58cb38060466ec198bcc01be8bc281
|
| --- /dev/null
|
| +++ b/src/compiler/js-builtin-reducer-unittest.cc
|
| @@ -0,0 +1,89 @@
|
| +// 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.
|
| +
|
| +#include "src/compiler/graph-unittest.h"
|
| +#include "src/compiler/js-builtin-reducer.h"
|
| +#include "src/compiler/js-graph.h"
|
| +#include "src/compiler/node-properties-inl.h"
|
| +#include "src/compiler/typer.h"
|
| +
|
| +namespace v8 {
|
| +namespace internal {
|
| +namespace compiler {
|
| +
|
| +class JSBuiltinReducerTest : public GraphTest {
|
| + public:
|
| + JSBuiltinReducerTest() : javascript_(zone()) {}
|
| +
|
| + protected:
|
| + Reduction Reduce(Node* node) {
|
| + Typer typer(zone());
|
| + MachineOperatorBuilder machine;
|
| + JSGraph jsgraph(graph(), common(), javascript(), &typer, &machine);
|
| + JSBuiltinReducer reducer(&jsgraph);
|
| + return reducer.Reduce(node);
|
| + }
|
| +
|
| + Node* Parameter(Type* t, int32_t index = 0) {
|
| + Node* n = graph()->NewNode(common()->Parameter(index), graph()->start());
|
| + NodeProperties::SetBounds(n, Bounds(Type::None(), t));
|
| + return n;
|
| + }
|
| +
|
| + Node* UndefinedConstant() {
|
| + return HeapConstant(
|
| + Unique<HeapObject>::CreateImmovable(factory()->undefined_value()));
|
| + }
|
| +
|
| + JSOperatorBuilder* javascript() { return &javascript_; }
|
| +
|
| + private:
|
| + JSOperatorBuilder javascript_;
|
| +};
|
| +
|
| +
|
| +namespace {
|
| +
|
| +// TODO(mstarzinger): Find a common place and unify with test-js-typed-lowering.
|
| +Type* const kNumberTypes[] = {
|
| + Type::UnsignedSmall(), Type::OtherSignedSmall(), Type::OtherUnsigned31(),
|
| + Type::OtherUnsigned32(), Type::OtherSigned32(), Type::SignedSmall(),
|
| + Type::Signed32(), Type::Unsigned32(), Type::Integral32(),
|
| + Type::MinusZero(), Type::NaN(), Type::OtherNumber(),
|
| + Type::OrderedNumber(), Type::Number()};
|
| +
|
| +} // namespace
|
| +
|
| +
|
| +// -----------------------------------------------------------------------------
|
| +// Math.imul
|
| +
|
| +
|
| +TEST_F(JSBuiltinReducerTest, MathImul) {
|
| + Handle<JSFunction> f(isolate()->context()->math_imul_fun());
|
| +
|
| + TRACED_FOREACH(Type*, t0, kNumberTypes) {
|
| + TRACED_FOREACH(Type*, t1, kNumberTypes) {
|
| + Node* p0 = Parameter(t0, 0);
|
| + Node* p1 = Parameter(t1, 1);
|
| + Node* fun = HeapConstant(Unique<HeapObject>::CreateUninitialized(f));
|
| + Node* call =
|
| + graph()->NewNode(javascript()->Call(4, NO_CALL_FUNCTION_FLAGS), fun,
|
| + UndefinedConstant(), p0, p1);
|
| + Reduction r = Reduce(call);
|
| +
|
| + if (t0->Is(Type::Integral32()) && t1->Is(Type::Integral32())) {
|
| + EXPECT_TRUE(r.Changed());
|
| + EXPECT_THAT(r.replacement(), IsInt32Mul(p0, p1));
|
| + } else {
|
| + EXPECT_FALSE(r.Changed());
|
| + EXPECT_EQ(IrOpcode::kJSCallFunction, call->opcode());
|
| + }
|
| + }
|
| + }
|
| +}
|
| +
|
| +} // namespace compiler
|
| +} // namespace internal
|
| +} // namespace v8
|
|
|