2014-07-30 13:54:45 +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.
|
|
|
|
|
|
|
|
#include "test/cctest/compiler/simplified-graph-builder.h"
|
|
|
|
|
2014-09-04 10:23:51 +00:00
|
|
|
#include "src/compiler/operator-properties.h"
|
|
|
|
#include "src/compiler/operator-properties-inl.h"
|
|
|
|
|
2014-07-30 13:54:45 +00:00
|
|
|
namespace v8 {
|
|
|
|
namespace internal {
|
|
|
|
namespace compiler {
|
|
|
|
|
|
|
|
SimplifiedGraphBuilder::SimplifiedGraphBuilder(
|
|
|
|
Graph* graph, CommonOperatorBuilder* common,
|
|
|
|
MachineOperatorBuilder* machine, SimplifiedOperatorBuilder* simplified)
|
2014-09-04 10:23:51 +00:00
|
|
|
: GraphBuilder(graph),
|
|
|
|
effect_(NULL),
|
|
|
|
return_(NULL),
|
|
|
|
common_(common),
|
2014-07-30 13:54:45 +00:00
|
|
|
machine_(machine),
|
|
|
|
simplified_(simplified) {}
|
|
|
|
|
|
|
|
|
2014-08-05 08:47:39 +00:00
|
|
|
void SimplifiedGraphBuilder::Begin(int num_parameters) {
|
2014-08-04 11:34:54 +00:00
|
|
|
DCHECK(graph()->start() == NULL);
|
2014-08-05 08:47:39 +00:00
|
|
|
Node* start = graph()->NewNode(common()->Start(num_parameters));
|
2014-07-30 13:54:45 +00:00
|
|
|
graph()->SetStart(start);
|
2014-09-04 10:23:51 +00:00
|
|
|
effect_ = start;
|
2014-07-30 13:54:45 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void SimplifiedGraphBuilder::Return(Node* value) {
|
2014-09-04 10:23:51 +00:00
|
|
|
return_ =
|
|
|
|
graph()->NewNode(common()->Return(), value, effect_, graph()->start());
|
|
|
|
effect_ = NULL;
|
2014-07-30 13:54:45 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void SimplifiedGraphBuilder::End() {
|
2014-09-04 10:23:51 +00:00
|
|
|
Node* end = graph()->NewNode(common()->End(), return_);
|
|
|
|
graph()->SetEnd(end);
|
2014-07-30 13:54:45 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2014-09-10 12:23:45 +00:00
|
|
|
Node* SimplifiedGraphBuilder::MakeNode(const Operator* op,
|
|
|
|
int value_input_count,
|
2014-10-27 10:12:16 +00:00
|
|
|
Node** value_inputs, bool incomplete) {
|
2014-09-04 10:23:51 +00:00
|
|
|
DCHECK(op->InputCount() == value_input_count);
|
|
|
|
|
|
|
|
DCHECK(!OperatorProperties::HasContextInput(op));
|
|
|
|
DCHECK(!OperatorProperties::HasFrameStateInput(op));
|
|
|
|
bool has_control = OperatorProperties::GetControlInputCount(op) == 1;
|
|
|
|
bool has_effect = OperatorProperties::GetEffectInputCount(op) == 1;
|
|
|
|
|
|
|
|
DCHECK(OperatorProperties::GetControlInputCount(op) < 2);
|
|
|
|
DCHECK(OperatorProperties::GetEffectInputCount(op) < 2);
|
|
|
|
|
|
|
|
Node* result = NULL;
|
|
|
|
if (!has_control && !has_effect) {
|
2014-10-27 10:12:16 +00:00
|
|
|
result = graph()->NewNode(op, value_input_count, value_inputs, incomplete);
|
2014-09-04 10:23:51 +00:00
|
|
|
} else {
|
|
|
|
int input_count_with_deps = value_input_count;
|
|
|
|
if (has_control) ++input_count_with_deps;
|
|
|
|
if (has_effect) ++input_count_with_deps;
|
|
|
|
Node** buffer = zone()->NewArray<Node*>(input_count_with_deps);
|
|
|
|
memcpy(buffer, value_inputs, kPointerSize * value_input_count);
|
|
|
|
Node** current_input = buffer + value_input_count;
|
|
|
|
if (has_effect) {
|
|
|
|
*current_input++ = effect_;
|
|
|
|
}
|
|
|
|
if (has_control) {
|
|
|
|
*current_input++ = graph()->start();
|
|
|
|
}
|
2014-10-27 10:12:16 +00:00
|
|
|
result = graph()->NewNode(op, input_count_with_deps, buffer, incomplete);
|
2014-09-04 10:23:51 +00:00
|
|
|
if (has_effect) {
|
|
|
|
effect_ = result;
|
|
|
|
}
|
2014-10-29 14:40:47 +00:00
|
|
|
// This graph builder does not support control flow.
|
|
|
|
CHECK_EQ(0, op->ControlOutputCount());
|
2014-09-04 10:23:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return result;
|
2014-07-30 13:54:45 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace compiler
|
|
|
|
} // namespace internal
|
|
|
|
} // namespace v8
|