Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(674)

Side by Side Diff: src/compiler/pipeline.h

Issue 484273003: Load closure from activation for building literals. (Closed) Base URL: https://v8.googlecode.com/svn/branches/bleeding_edge
Patch Set: Load closure from activation for building literals. Created 6 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « src/compiler/ast-graph-builder.cc ('k') | src/compiler/pipeline.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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 #ifndef V8_COMPILER_PIPELINE_H_ 5 #ifndef V8_COMPILER_PIPELINE_H_
6 #define V8_COMPILER_PIPELINE_H_ 6 #define V8_COMPILER_PIPELINE_H_
7 7
8 #include "src/v8.h" 8 #include "src/v8.h"
9 9
10 #include "src/compiler.h" 10 #include "src/compiler.h"
11 11
12 // Note: TODO(turbofan) implies a performance improvement opportunity, 12 // Note: TODO(turbofan) implies a performance improvement opportunity,
13 // and TODO(name) implies an incomplete implementation 13 // and TODO(name) implies an incomplete implementation
14 14
15 namespace v8 { 15 namespace v8 {
16 namespace internal { 16 namespace internal {
17 namespace compiler { 17 namespace compiler {
18 18
19 // Clients of this interface shouldn't depend on lots of compiler internals. 19 // Clients of this interface shouldn't depend on lots of compiler internals.
20 class Graph; 20 class Graph;
21 class Schedule; 21 class Schedule;
22 class SourcePositionTable; 22 class SourcePositionTable;
23 class Linkage; 23 class Linkage;
24 24
25 class Pipeline { 25 class Pipeline {
26 public: 26 public:
27 explicit Pipeline(CompilationInfo* info) : info_(info) {} 27 explicit Pipeline(CompilationInfo* info)
28 : info_(info), context_specialization_(FLAG_context_specialization) {}
28 29
29 // Run the entire pipeline and generate a handle to a code object. 30 // Run the entire pipeline and generate a handle to a code object.
30 Handle<Code> GenerateCode(); 31 Handle<Code> GenerateCode();
31 32
32 // Run the pipeline on a machine graph and generate code. If {schedule} 33 // Run the pipeline on a machine graph and generate code. If {schedule}
33 // is {NULL}, then compute a new schedule for code generation. 34 // is {NULL}, then compute a new schedule for code generation.
34 Handle<Code> GenerateCodeForMachineGraph(Linkage* linkage, Graph* graph, 35 Handle<Code> GenerateCodeForMachineGraph(Linkage* linkage, Graph* graph,
35 Schedule* schedule = NULL); 36 Schedule* schedule = NULL);
36 37
37 static inline bool SupportedBackend() { return V8_TURBOFAN_BACKEND != 0; } 38 static inline bool SupportedBackend() { return V8_TURBOFAN_BACKEND != 0; }
38 static inline bool SupportedTarget() { return V8_TURBOFAN_TARGET != 0; } 39 static inline bool SupportedTarget() { return V8_TURBOFAN_TARGET != 0; }
39 40
40 static void SetUp(); 41 static void SetUp();
41 static void TearDown(); 42 static void TearDown();
43 bool context_specialization() { return context_specialization_; }
44 void set_context_specialization(bool context_specialization) {
45 context_specialization_ = context_specialization;
46 }
42 47
43 private: 48 private:
44 CompilationInfo* info_; 49 CompilationInfo* info_;
50 bool context_specialization_;
45 51
46 CompilationInfo* info() const { return info_; } 52 CompilationInfo* info() const { return info_; }
47 Isolate* isolate() { return info_->isolate(); } 53 Isolate* isolate() { return info_->isolate(); }
48 Zone* zone() { return info_->zone(); } 54 Zone* zone() { return info_->zone(); }
49 55
50 Schedule* ComputeSchedule(Graph* graph); 56 Schedule* ComputeSchedule(Graph* graph);
51 void VerifyAndPrintGraph(Graph* graph, const char* phase); 57 void VerifyAndPrintGraph(Graph* graph, const char* phase);
52 Handle<Code> GenerateCode(Linkage* linkage, Graph* graph, Schedule* schedule, 58 Handle<Code> GenerateCode(Linkage* linkage, Graph* graph, Schedule* schedule,
53 SourcePositionTable* source_positions); 59 SourcePositionTable* source_positions);
54 }; 60 };
55 } 61 }
56 } 62 }
57 } // namespace v8::internal::compiler 63 } // namespace v8::internal::compiler
58 64
59 #endif // V8_COMPILER_PIPELINE_H_ 65 #endif // V8_COMPILER_PIPELINE_H_
OLDNEW
« no previous file with comments | « src/compiler/ast-graph-builder.cc ('k') | src/compiler/pipeline.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698