OLD | NEW |
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_SIMPLIFIED_LOWERING_H_ | 5 #ifndef V8_COMPILER_SIMPLIFIED_LOWERING_H_ |
6 #define V8_COMPILER_SIMPLIFIED_LOWERING_H_ | 6 #define V8_COMPILER_SIMPLIFIED_LOWERING_H_ |
7 | 7 |
8 #include "src/compiler/js-graph.h" | 8 #include "src/compiler/js-graph.h" |
9 #include "src/compiler/machine-operator.h" | 9 #include "src/compiler/machine-operator.h" |
10 #include "src/compiler/node.h" | 10 #include "src/compiler/node.h" |
(...skipping 15 matching lines...) Expand all Loading... |
26 void DoStoreField(Node* node); | 26 void DoStoreField(Node* node); |
27 void DoLoadElement(Node* node); | 27 void DoLoadElement(Node* node); |
28 void DoStoreElement(Node* node); | 28 void DoStoreElement(Node* node); |
29 void DoStringAdd(Node* node); | 29 void DoStringAdd(Node* node); |
30 void DoStringEqual(Node* node); | 30 void DoStringEqual(Node* node); |
31 void DoStringLessThan(Node* node); | 31 void DoStringLessThan(Node* node); |
32 void DoStringLessThanOrEqual(Node* node); | 32 void DoStringLessThanOrEqual(Node* node); |
33 | 33 |
34 private: | 34 private: |
35 JSGraph* jsgraph_; | 35 JSGraph* jsgraph_; |
36 MachineOperatorBuilder machine_; | |
37 | 36 |
38 Node* SmiTag(Node* node); | 37 Node* SmiTag(Node* node); |
39 Node* IsTagged(Node* node); | 38 Node* IsTagged(Node* node); |
40 Node* Untag(Node* node); | 39 Node* Untag(Node* node); |
41 Node* OffsetMinusTagConstant(int32_t offset); | 40 Node* OffsetMinusTagConstant(int32_t offset); |
42 Node* ComputeIndex(const ElementAccess& access, Node* index); | 41 Node* ComputeIndex(const ElementAccess& access, Node* index); |
43 Node* StringComparison(Node* node, bool requires_ordering); | 42 Node* StringComparison(Node* node, bool requires_ordering); |
44 | 43 |
45 friend class RepresentationSelector; | 44 friend class RepresentationSelector; |
46 | 45 |
47 Zone* zone() { return jsgraph_->zone(); } | 46 Zone* zone() { return jsgraph_->zone(); } |
48 JSGraph* jsgraph() { return jsgraph_; } | 47 JSGraph* jsgraph() { return jsgraph_; } |
49 Graph* graph() { return jsgraph()->graph(); } | 48 Graph* graph() { return jsgraph()->graph(); } |
50 CommonOperatorBuilder* common() { return jsgraph()->common(); } | 49 CommonOperatorBuilder* common() { return jsgraph()->common(); } |
51 MachineOperatorBuilder* machine() { return &machine_; } | 50 MachineOperatorBuilder* machine() { return jsgraph()->machine(); } |
52 }; | 51 }; |
53 | 52 |
54 } // namespace compiler | 53 } // namespace compiler |
55 } // namespace internal | 54 } // namespace internal |
56 } // namespace v8 | 55 } // namespace v8 |
57 | 56 |
58 #endif // V8_COMPILER_SIMPLIFIED_LOWERING_H_ | 57 #endif // V8_COMPILER_SIMPLIFIED_LOWERING_H_ |
OLD | NEW |