blob: f9410f8b41eef519d9f5e433275da9abb75df9a2 [file] [log] [blame]
Ben Murdochb8a8cc12014-11-26 15:28:44 +00001// 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
3// found in the LICENSE file.
4
5#ifndef V8_COMPILER_SIMPLIFIED_LOWERING_H_
6#define V8_COMPILER_SIMPLIFIED_LOWERING_H_
7
8#include "src/compiler/js-graph.h"
9#include "src/compiler/machine-operator.h"
10#include "src/compiler/node.h"
11#include "src/compiler/simplified-operator.h"
12
13namespace v8 {
14namespace internal {
Ben Murdoch4a90d5f2016-03-22 12:00:34 +000015
16// Forward declarations.
17class TypeCache;
18
19
Ben Murdochb8a8cc12014-11-26 15:28:44 +000020namespace compiler {
21
Emily Bernierd0a1eb72015-03-24 16:35:39 -040022// Forward declarations.
23class RepresentationChanger;
Ben Murdoch4a90d5f2016-03-22 12:00:34 +000024class SourcePositionTable;
Emily Bernierd0a1eb72015-03-24 16:35:39 -040025
Ben Murdoch4a90d5f2016-03-22 12:00:34 +000026class SimplifiedLowering final {
Ben Murdochb8a8cc12014-11-26 15:28:44 +000027 public:
Ben Murdoch4a90d5f2016-03-22 12:00:34 +000028 SimplifiedLowering(JSGraph* jsgraph, Zone* zone,
29 SourcePositionTable* source_positions);
Emily Bernierd0a1eb72015-03-24 16:35:39 -040030 ~SimplifiedLowering() {}
Ben Murdochb8a8cc12014-11-26 15:28:44 +000031
32 void LowerAllNodes();
33
Ben Murdoch4a90d5f2016-03-22 12:00:34 +000034 // TODO(turbofan): The representation can be removed once the result of the
Emily Bernierd0a1eb72015-03-24 16:35:39 -040035 // representation analysis is stored in the node bounds.
Ben Murdoch4a90d5f2016-03-22 12:00:34 +000036 void DoLoadBuffer(Node* node, MachineRepresentation rep,
Emily Bernierd0a1eb72015-03-24 16:35:39 -040037 RepresentationChanger* changer);
38 void DoStoreBuffer(Node* node);
Ben Murdoch4a90d5f2016-03-22 12:00:34 +000039 void DoObjectIsNumber(Node* node);
40 void DoObjectIsSmi(Node* node);
41 void DoShift(Node* node, Operator const* op, Type* rhs_type);
Ben Murdochb8a8cc12014-11-26 15:28:44 +000042 void DoStringEqual(Node* node);
43 void DoStringLessThan(Node* node);
44 void DoStringLessThanOrEqual(Node* node);
45
46 private:
Emily Bernierd0a1eb72015-03-24 16:35:39 -040047 JSGraph* const jsgraph_;
48 Zone* const zone_;
Ben Murdoch4a90d5f2016-03-22 12:00:34 +000049 TypeCache const& type_cache_;
Ben Murdochb8a8cc12014-11-26 15:28:44 +000050
Ben Murdoch4a90d5f2016-03-22 12:00:34 +000051 // TODO(danno): SimplifiedLowering shouldn't know anything about the source
52 // positions table, but must for now since there currently is no other way to
53 // pass down source position information to nodes created during
54 // lowering. Once this phase becomes a vanilla reducer, it should get source
55 // position information via the SourcePositionWrapper like all other reducers.
56 SourcePositionTable* source_positions_;
57
58 Node* StringComparison(Node* node);
Emily Bernierd0a1eb72015-03-24 16:35:39 -040059 Node* Int32Div(Node* const node);
60 Node* Int32Mod(Node* const node);
61 Node* Uint32Div(Node* const node);
62 Node* Uint32Mod(Node* const node);
Ben Murdochb8a8cc12014-11-26 15:28:44 +000063
64 friend class RepresentationSelector;
65
Ben Murdoch4a90d5f2016-03-22 12:00:34 +000066 Isolate* isolate() { return jsgraph_->isolate(); }
Ben Murdochb8a8cc12014-11-26 15:28:44 +000067 Zone* zone() { return jsgraph_->zone(); }
68 JSGraph* jsgraph() { return jsgraph_; }
69 Graph* graph() { return jsgraph()->graph(); }
70 CommonOperatorBuilder* common() { return jsgraph()->common(); }
71 MachineOperatorBuilder* machine() { return jsgraph()->machine(); }
72};
73
74} // namespace compiler
75} // namespace internal
76} // namespace v8
77
78#endif // V8_COMPILER_SIMPLIFIED_LOWERING_H_