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

Side by Side Diff: src/compiler/js-context-specialization.h

Issue 473263004: Towards removing dependency from generic lowering on compilation info. (Closed) Base URL: https://v8.googlecode.com/svn/branches/bleeding_edge
Patch Set: 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
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_JS_CONTEXT_SPECIALIZATION_H_ 5 #ifndef V8_COMPILER_JS_CONTEXT_SPECIALIZATION_H_
6 #define V8_COMPILER_JS_CONTEXT_SPECIALIZATION_H_ 6 #define V8_COMPILER_JS_CONTEXT_SPECIALIZATION_H_
7 7
8 #include "src/compiler/graph-reducer.h" 8 #include "src/compiler/graph-reducer.h"
9 #include "src/compiler/js-graph.h" 9 #include "src/compiler/js-graph.h"
10 #include "src/contexts.h" 10 #include "src/contexts.h"
11 #include "src/v8.h" 11 #include "src/v8.h"
12 12
13 namespace v8 { 13 namespace v8 {
14 namespace internal { 14 namespace internal {
15 namespace compiler { 15 namespace compiler {
16 16
17 // Specializes a given JSGraph to a given context, potentially constant folding 17 // Specializes a given JSGraph to a given context, potentially constant folding
18 // some {LoadContext} nodes or strength reducing some {StoreContext} nodes. 18 // some {LoadContext} nodes or strength reducing some {StoreContext} nodes.
19 class JSContextSpecializer { 19 class JSContextSpecializer {
titzer 2014/08/20 12:54:38 This class is becoming more general now. I think w
20 public: 20 public:
21 JSContextSpecializer(CompilationInfo* info, JSGraph* jsgraph, Node* context) 21 JSContextSpecializer(CompilationInfo* info, JSGraph* jsgraph, Node* context)
22 : info_(info), jsgraph_(jsgraph), context_(context) {} 22 : specialized_(false),
titzer 2014/08/20 12:54:38 If you make this a parameter, then you can simplif
23 info_(info),
24 jsgraph_(jsgraph),
25 context_(context) {}
23 26
24 void SpecializeToContext(); 27 void SpecializeToContext();
25 Reduction ReduceJSLoadContext(Node* node); 28 Reduction ReduceJSLoadContext(Node* node);
26 Reduction ReduceJSStoreContext(Node* node); 29 Reduction ReduceJSStoreContext(Node* node);
30 Node* InsertBuiltinLoadBefore(Node* before, Builtins::JavaScript id);
27 31
28 private: 32 private:
33 bool specialized_;
29 CompilationInfo* info_; 34 CompilationInfo* info_;
30 JSGraph* jsgraph_; 35 JSGraph* jsgraph_;
31 Node* context_; 36 Node* context_;
32 }; 37 };
33 } 38 }
34 } 39 }
35 } // namespace v8::internal::compiler 40 } // namespace v8::internal::compiler
36 41
37 #endif // V8_COMPILER_JS_CONTEXT_SPECIALIZATION_H_ 42 #endif // V8_COMPILER_JS_CONTEXT_SPECIALIZATION_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698