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

Unified Diff: src/compiler/js-type-feedback.h

Issue 1021713005: [turbofan]: Integrate basic type feedback for property accesses. (Closed) Base URL: https://chromium.googlesource.com/v8/v8.git@master
Patch Set: Created 5 years, 9 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « src/compiler/js-intrinsic-lowering.cc ('k') | src/compiler/js-type-feedback.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: src/compiler/js-type-feedback.h
diff --git a/src/compiler/js-type-feedback.h b/src/compiler/js-type-feedback.h
new file mode 100644
index 0000000000000000000000000000000000000000..033da657ff7ca9b29b5c373578ec0ced3bbe8120
--- /dev/null
+++ b/src/compiler/js-type-feedback.h
@@ -0,0 +1,91 @@
+// Copyright 2015 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.
+
+#ifndef V8_COMPILER_JS_TYPE_FEEDBACK_H_
+#define V8_COMPILER_JS_TYPE_FEEDBACK_H_
+
+#include "src/utils.h"
+
+#include "src/compiler/graph-reducer.h"
+#include "src/compiler/js-graph.h"
+#include "src/compiler/node-aux-data.h"
+#include "src/compiler/simplified-operator.h"
+
+namespace v8 {
+namespace internal {
+
+class TypeFeedbackOracle;
+class SmallMapList;
+
+namespace compiler {
+
+// Stores type feedback information for nodes in the graph in a separate
+// data structure.
+class JSTypeFeedbackTable : public ZoneObject {
+ public:
+ explicit JSTypeFeedbackTable(Zone* zone);
+
+ // TODO(titzer): support recording the feedback vector slot.
+
+ void Record(Node* node, TypeFeedbackId id);
+
+ private:
+ friend class JSTypeFeedbackSpecializer;
+ typedef std::map<NodeId, TypeFeedbackId, std::less<NodeId>,
+ zone_allocator<TypeFeedbackId> > TypeFeedbackIdMap;
+
+ TypeFeedbackIdMap map_;
+
+ TypeFeedbackId find(Node* node) {
+ TypeFeedbackIdMap::const_iterator it = map_.find(node->id());
+ return it == map_.end() ? TypeFeedbackId::None() : it->second;
+ }
+};
+
+
+// Specializes a graph to the type feedback recorded in the
+// {js_type_feedback} provided to the constructor.
+class JSTypeFeedbackSpecializer : public Reducer {
+ public:
+ JSTypeFeedbackSpecializer(JSGraph* jsgraph,
+ JSTypeFeedbackTable* js_type_feedback,
+ TypeFeedbackOracle* oracle)
+ : jsgraph_(jsgraph),
+ simplified_(jsgraph->graph()->zone()),
+ js_type_feedback_(js_type_feedback),
+ oracle_(oracle) {
+ CHECK(js_type_feedback);
+ }
+
+ Reduction Reduce(Node* node) OVERRIDE;
+
+ // Visible for unit testing.
+ Reduction ReduceJSLoadNamed(Node* node);
+ Reduction ReduceJSLoadProperty(Node* node);
+ Reduction ReduceJSStoreNamed(Node* node);
+ Reduction ReduceJSStoreProperty(Node* node);
+
+ private:
+ JSGraph* jsgraph_;
+ SimplifiedOperatorBuilder simplified_;
+ JSTypeFeedbackTable* js_type_feedback_;
+ TypeFeedbackOracle* oracle_;
+
+ TypeFeedbackOracle* oracle() { return oracle_; }
+ Graph* graph() { return jsgraph_->graph(); }
+ CommonOperatorBuilder* common() { return jsgraph_->common(); }
+ SimplifiedOperatorBuilder* simplified() { return &simplified_; }
+
+ void BuildMapCheck(Node* receiver, Handle<Map> map, bool smi_check,
+ Node* effect, Node* control, Node** success, Node** fail);
+
+ void GatherReceiverTypes(Node* receiver, Node* effect, TypeFeedbackId id,
+ Handle<Name> property, SmallMapList* maps);
+};
+
+} // namespace compiler
+} // namespace internal
+} // namespace v8
+
+#endif
« no previous file with comments | « src/compiler/js-intrinsic-lowering.cc ('k') | src/compiler/js-type-feedback.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698