Commit acd6715d authored by svenpanne's avatar svenpanne Committed by Commit bot

Removed the funky 2-stage initialization of PipelineData.

Use simple old-skool constructors instead. Note that the long repeated
member initializer lists could be reduced a bit by using C++11's
brace-or-equal initializers, which are actually recommended by the
Google C++ style guide in this case, but the ARM toolchain is still
buggy in this area (see patch sets 1 and 2).  :-/

Review URL: https://codereview.chromium.org/913993004

Cr-Commit-Position: refs/heads/master@{#26654}
parent e66d39a6
...@@ -54,16 +54,18 @@ namespace compiler { ...@@ -54,16 +54,18 @@ namespace compiler {
class PipelineData { class PipelineData {
public: public:
explicit PipelineData(ZonePool* zone_pool, CompilationInfo* info) // For main entry point.
PipelineData(ZonePool* zone_pool, CompilationInfo* info,
PipelineStatistics* pipeline_statistics)
: isolate_(info->isolate()), : isolate_(info->isolate()),
info_(info), info_(info),
outer_zone_(nullptr), outer_zone_(info_->zone()),
zone_pool_(zone_pool), zone_pool_(zone_pool),
pipeline_statistics_(nullptr), pipeline_statistics_(pipeline_statistics),
compilation_failed_(false), compilation_failed_(false),
code_(Handle<Code>::null()), code_(Handle<Code>::null()),
graph_zone_scope_(zone_pool_), graph_zone_scope_(zone_pool_),
graph_zone_(nullptr), graph_zone_(graph_zone_scope_.zone()),
graph_(nullptr), graph_(nullptr),
loop_assignment_(nullptr), loop_assignment_(nullptr),
machine_(nullptr), machine_(nullptr),
...@@ -74,47 +76,81 @@ class PipelineData { ...@@ -74,47 +76,81 @@ class PipelineData {
context_node_(nullptr), context_node_(nullptr),
schedule_(nullptr), schedule_(nullptr),
instruction_zone_scope_(zone_pool_), instruction_zone_scope_(zone_pool_),
instruction_zone_(nullptr), instruction_zone_(instruction_zone_scope_.zone()),
sequence_(nullptr), sequence_(nullptr),
frame_(nullptr), frame_(nullptr),
register_allocator_(nullptr) {} register_allocator_(nullptr) {
~PipelineData() {
DeleteInstructionZone();
DeleteGraphZone();
}
// For main entry point.
void Initialize(PipelineStatistics* pipeline_statistics) {
PhaseScope scope(pipeline_statistics, "init pipeline data"); PhaseScope scope(pipeline_statistics, "init pipeline data");
outer_zone_ = info()->zone(); graph_ = new (graph_zone_) Graph(graph_zone_);
pipeline_statistics_ = pipeline_statistics; source_positions_.Reset(new SourcePositionTable(graph_));
graph_zone_ = graph_zone_scope_.zone(); machine_ = new (graph_zone_) MachineOperatorBuilder(
graph_ = new (graph_zone()) Graph(graph_zone()); graph_zone_, kMachPtr,
source_positions_.Reset(new SourcePositionTable(graph()));
machine_ = new (graph_zone()) MachineOperatorBuilder(
graph_zone(), kMachPtr,
InstructionSelector::SupportedMachineOperatorFlags()); InstructionSelector::SupportedMachineOperatorFlags());
common_ = new (graph_zone()) CommonOperatorBuilder(graph_zone()); common_ = new (graph_zone_) CommonOperatorBuilder(graph_zone_);
javascript_ = new (graph_zone()) JSOperatorBuilder(graph_zone()); javascript_ = new (graph_zone_) JSOperatorBuilder(graph_zone_);
jsgraph_ = new (graph_zone()) jsgraph_ = new (graph_zone_)
JSGraph(info()->isolate(), graph(), common(), javascript(), machine()); JSGraph(isolate_, graph_, common_, javascript_, machine_);
typer_.Reset(new Typer(info()->isolate(), graph(), info()->context())); typer_.Reset(new Typer(isolate_, graph_, info_->context()));
instruction_zone_ = instruction_zone_scope_.zone();
} }
// For machine graph testing entry point. // For machine graph testing entry point.
void InitializeTorTesting(Graph* graph, Schedule* schedule) { PipelineData(ZonePool* zone_pool, CompilationInfo* info, Graph* graph,
graph_ = graph; Schedule* schedule)
source_positions_.Reset(new SourcePositionTable(graph)); : isolate_(info->isolate()),
schedule_ = schedule; info_(info),
instruction_zone_ = instruction_zone_scope_.zone(); outer_zone_(nullptr),
} zone_pool_(zone_pool),
pipeline_statistics_(nullptr),
compilation_failed_(false),
code_(Handle<Code>::null()),
graph_zone_scope_(zone_pool_),
graph_zone_(nullptr),
graph_(graph),
source_positions_(new SourcePositionTable(graph_)),
loop_assignment_(nullptr),
machine_(nullptr),
common_(nullptr),
javascript_(nullptr),
jsgraph_(nullptr),
typer_(nullptr),
context_node_(nullptr),
schedule_(schedule),
instruction_zone_scope_(zone_pool_),
instruction_zone_(instruction_zone_scope_.zone()),
sequence_(nullptr),
frame_(nullptr),
register_allocator_(nullptr) {}
// For register allocation testing entry point. // For register allocation testing entry point.
void InitializeTorTesting(InstructionSequence* sequence) { PipelineData(ZonePool* zone_pool, CompilationInfo* info,
instruction_zone_ = sequence->zone(); InstructionSequence* sequence)
sequence_ = sequence; : isolate_(info->isolate()),
info_(info),
outer_zone_(nullptr),
zone_pool_(zone_pool),
pipeline_statistics_(nullptr),
compilation_failed_(false),
code_(Handle<Code>::null()),
graph_zone_scope_(zone_pool_),
graph_zone_(nullptr),
graph_(nullptr),
loop_assignment_(nullptr),
machine_(nullptr),
common_(nullptr),
javascript_(nullptr),
jsgraph_(nullptr),
typer_(nullptr),
context_node_(nullptr),
schedule_(nullptr),
instruction_zone_scope_(zone_pool_),
instruction_zone_(sequence->zone()),
sequence_(sequence),
frame_(nullptr),
register_allocator_(nullptr) {}
~PipelineData() {
DeleteInstructionZone();
DeleteGraphZone();
} }
Isolate* isolate() const { return isolate_; } Isolate* isolate() const { return isolate_; }
...@@ -849,9 +885,8 @@ Handle<Code> Pipeline::GenerateCode() { ...@@ -849,9 +885,8 @@ Handle<Code> Pipeline::GenerateCode() {
} }
} }
PipelineData data(&zone_pool, info()); PipelineData data(&zone_pool, info(), pipeline_statistics.get());
this->data_ = &data; this->data_ = &data;
data.Initialize(pipeline_statistics.get());
BeginPhaseKind("graph creation"); BeginPhaseKind("graph creation");
...@@ -978,10 +1013,9 @@ Handle<Code> Pipeline::GenerateCodeForTesting(CompilationInfo* info, ...@@ -978,10 +1013,9 @@ Handle<Code> Pipeline::GenerateCodeForTesting(CompilationInfo* info,
Schedule* schedule) { Schedule* schedule) {
// Construct a pipeline for scheduling and code generation. // Construct a pipeline for scheduling and code generation.
ZonePool zone_pool; ZonePool zone_pool;
PipelineData data(&zone_pool, info, graph, schedule);
Pipeline pipeline(info); Pipeline pipeline(info);
PipelineData data(&zone_pool, info);
pipeline.data_ = &data; pipeline.data_ = &data;
data.InitializeTorTesting(graph, schedule);
if (data.schedule() == nullptr) { if (data.schedule() == nullptr) {
// TODO(rossberg): Should this really be untyped? // TODO(rossberg): Should this really be untyped?
pipeline.RunPrintAndVerify("Machine", true); pipeline.RunPrintAndVerify("Machine", true);
...@@ -997,8 +1031,7 @@ bool Pipeline::AllocateRegistersForTesting(const RegisterConfiguration* config, ...@@ -997,8 +1031,7 @@ bool Pipeline::AllocateRegistersForTesting(const RegisterConfiguration* config,
FakeStubForTesting stub(sequence->isolate()); FakeStubForTesting stub(sequence->isolate());
CompilationInfo info(&stub, sequence->isolate(), sequence->zone()); CompilationInfo info(&stub, sequence->isolate(), sequence->zone());
ZonePool zone_pool; ZonePool zone_pool;
PipelineData data(&zone_pool, &info); PipelineData data(&zone_pool, &info, sequence);
data.InitializeTorTesting(sequence);
Pipeline pipeline(&info); Pipeline pipeline(&info);
pipeline.data_ = &data; pipeline.data_ = &data;
pipeline.AllocateRegisters(config, run_verifier); pipeline.AllocateRegisters(config, run_verifier);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment