Line data Source code
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
3 : // found in the LICENSE file.
4 :
5 : #include "src/compiler/js-graph.h"
6 :
7 : #include "src/code-factory.h"
8 : #include "src/compiler/node-properties.h"
9 : #include "src/compiler/typer.h"
10 : #include "src/objects-inl.h"
11 :
12 : namespace v8 {
13 : namespace internal {
14 : namespace compiler {
15 :
16 : #define GET_CACHED_FIELD(ptr, expr) (*(ptr)) ? *(ptr) : (*(ptr) = (expr))
17 :
18 : #define DEFINE_GETTER(name, expr) \
19 : Node* JSGraph::name() { return GET_CACHED_FIELD(&name##_, expr); }
20 :
21 863358 : Node* JSGraph::CEntryStubConstant(int result_size, SaveFPRegsMode save_doubles,
22 458489 : ArgvMode argv_mode, bool builtin_exit_frame) {
23 863358 : if (save_doubles == kDontSaveFPRegs && argv_mode == kArgvOnStack) {
24 : DCHECK(result_size >= 1 && result_size <= 3);
25 863358 : if (!builtin_exit_frame) {
26 : Node** ptr = nullptr;
27 861213 : if (result_size == 1) {
28 860274 : ptr = &CEntryStub1Constant_;
29 939 : } else if (result_size == 2) {
30 939 : ptr = &CEntryStub2Constant_;
31 : } else {
32 : DCHECK_EQ(3, result_size);
33 0 : ptr = &CEntryStub3Constant_;
34 : }
35 1775518 : return GET_CACHED_FIELD(ptr, HeapConstant(CodeFactory::CEntry(
36 : isolate(), result_size, save_doubles,
37 : argv_mode, builtin_exit_frame)));
38 : }
39 : Node** ptr = builtin_exit_frame ? &CEntryStub1WithBuiltinExitFrameConstant_
40 2145 : : &CEntryStub1Constant_;
41 4821 : return GET_CACHED_FIELD(ptr, HeapConstant(CodeFactory::CEntry(
42 : isolate(), result_size, save_doubles,
43 : argv_mode, builtin_exit_frame)));
44 : }
45 : return HeapConstant(CodeFactory::CEntry(isolate(), result_size, save_doubles,
46 0 : argv_mode, builtin_exit_frame));
47 : }
48 :
49 5931000 : Node* JSGraph::Constant(Handle<Object> value) {
50 : // Dereference the handle to determine if a number constant or other
51 : // canonicalized node can be used.
52 2136564 : if (value->IsNumber()) {
53 93861 : return Constant(value->Number());
54 1948842 : } else if (value->IsUndefined(isolate())) {
55 2195 : return UndefinedConstant();
56 1944452 : } else if (value->IsTrue(isolate())) {
57 62 : return TrueConstant();
58 1944328 : } else if (value->IsFalse(isolate())) {
59 147 : return FalseConstant();
60 1944034 : } else if (value->IsNull(isolate())) {
61 127 : return NullConstant();
62 1943780 : } else if (value->IsTheHole(isolate())) {
63 5 : return TheHoleConstant();
64 : } else {
65 971885 : return HeapConstant(Handle<HeapObject>::cast(value));
66 : }
67 : }
68 :
69 987344 : Node* JSGraph::Constant(const ObjectRef& ref) {
70 802596 : if (ref.IsSmi()) return Constant(ref.AsSmi());
71 : OddballType oddball_type =
72 791559 : ref.AsHeapObject().GetHeapObjectType().oddball_type();
73 791560 : if (ref.IsHeapNumber()) {
74 401 : return Constant(ref.AsHeapNumber().value());
75 791159 : } else if (oddball_type == OddballType::kUndefined) {
76 : DCHECK(ref.object().equals(isolate()->factory()->undefined_value()));
77 1517 : return UndefinedConstant();
78 789642 : } else if (oddball_type == OddballType::kNull) {
79 : DCHECK(ref.object().equals(isolate()->factory()->null_value()));
80 187 : return NullConstant();
81 789455 : } else if (oddball_type == OddballType::kHole) {
82 : DCHECK(ref.object().equals(isolate()->factory()->the_hole_value()));
83 2509 : return TheHoleConstant();
84 786946 : } else if (oddball_type == OddballType::kBoolean) {
85 369495 : if (ref.object().equals(isolate()->factory()->true_value())) {
86 63988 : return TrueConstant();
87 : } else {
88 : DCHECK(ref.object().equals(isolate()->factory()->false_value()));
89 120759 : return FalseConstant();
90 : }
91 : } else {
92 602198 : return HeapConstant(ref.AsHeapObject().object());
93 : }
94 : }
95 :
96 3336428 : Node* JSGraph::Constant(double value) {
97 3664314 : if (bit_cast<int64_t>(value) == bit_cast<int64_t>(0.0)) return ZeroConstant();
98 3244899 : if (bit_cast<int64_t>(value) == bit_cast<int64_t>(1.0)) return OneConstant();
99 2772185 : return NumberConstant(value);
100 : }
101 :
102 3479531 : Node* JSGraph::NumberConstant(double value) {
103 : Node** loc = cache_.FindNumberConstant(value);
104 3479530 : if (*loc == nullptr) {
105 4958878 : *loc = graph()->NewNode(common()->NumberConstant(value));
106 : }
107 3479534 : return *loc;
108 : }
109 :
110 13664117 : Node* JSGraph::HeapConstant(Handle<HeapObject> value) {
111 13664117 : Node** loc = cache_.FindHeapConstant(value);
112 13664137 : if (*loc == nullptr) {
113 14107443 : *loc = graph()->NewNode(common()->HeapConstant(value));
114 : }
115 13664130 : return *loc;
116 : }
117 :
118 4659328 : void JSGraph::GetCachedNodes(NodeVector* nodes) {
119 4659328 : cache_.GetCachedNodes(nodes);
120 : #define DO_CACHED_FIELD(name) \
121 : if (name##_) nodes->push_back(name##_);
122 :
123 4659337 : CACHED_GLOBAL_LIST(DO_CACHED_FIELD)
124 4659333 : CACHED_CENTRY_LIST(DO_CACHED_FIELD)
125 : #undef DO_CACHED_FIELD
126 4659333 : }
127 :
128 306313 : DEFINE_GETTER(AllocateInNewSpaceStubConstant,
129 : HeapConstant(BUILTIN_CODE(isolate(), AllocateInNewSpace)))
130 :
131 842 : DEFINE_GETTER(AllocateInOldSpaceStubConstant,
132 : HeapConstant(BUILTIN_CODE(isolate(), AllocateInOldSpace)))
133 :
134 195 : DEFINE_GETTER(ArrayConstructorStubConstant,
135 : HeapConstant(BUILTIN_CODE(isolate(), ArrayConstructorImpl)))
136 :
137 122 : DEFINE_GETTER(BooleanMapConstant, HeapConstant(factory()->boolean_map()))
138 :
139 58 : DEFINE_GETTER(ToNumberBuiltinConstant,
140 : HeapConstant(BUILTIN_CODE(isolate(), ToNumber)))
141 :
142 160337 : DEFINE_GETTER(EmptyFixedArrayConstant,
143 : HeapConstant(factory()->empty_fixed_array()))
144 :
145 75273 : DEFINE_GETTER(EmptyStringConstant, HeapConstant(factory()->empty_string()))
146 :
147 3303 : DEFINE_GETTER(FixedArrayMapConstant, HeapConstant(factory()->fixed_array_map()))
148 :
149 2495 : DEFINE_GETTER(PropertyArrayMapConstant,
150 : HeapConstant(factory()->property_array_map()))
151 :
152 54 : DEFINE_GETTER(FixedDoubleArrayMapConstant,
153 : HeapConstant(factory()->fixed_double_array_map()))
154 :
155 240888 : DEFINE_GETTER(HeapNumberMapConstant, HeapConstant(factory()->heap_number_map()))
156 :
157 18437370 : DEFINE_GETTER(OptimizedOutConstant, HeapConstant(factory()->optimized_out()))
158 :
159 17945 : DEFINE_GETTER(StaleRegisterConstant, HeapConstant(factory()->stale_register()))
160 :
161 2185319 : DEFINE_GETTER(UndefinedConstant, HeapConstant(factory()->undefined_value()))
162 :
163 487260 : DEFINE_GETTER(TheHoleConstant, HeapConstant(factory()->the_hole_value()))
164 :
165 1485863 : DEFINE_GETTER(TrueConstant, HeapConstant(factory()->true_value()))
166 :
167 1567910 : DEFINE_GETTER(FalseConstant, HeapConstant(factory()->false_value()))
168 :
169 42937 : DEFINE_GETTER(NullConstant, HeapConstant(factory()->null_value()))
170 :
171 1443241 : DEFINE_GETTER(ZeroConstant, NumberConstant(0.0))
172 :
173 418971 : DEFINE_GETTER(OneConstant, NumberConstant(1.0))
174 :
175 283 : DEFINE_GETTER(MinusOneConstant, NumberConstant(-1.0))
176 :
177 1239 : DEFINE_GETTER(NaNConstant,
178 : NumberConstant(std::numeric_limits<double>::quiet_NaN()))
179 :
180 22066 : DEFINE_GETTER(EmptyStateValues,
181 : graph()->NewNode(common()->StateValues(0,
182 : SparseInputMask::Dense())))
183 :
184 6264884 : DEFINE_GETTER(SingleDeadTypedStateValues,
185 : graph()->NewNode(common()->TypedStateValues(
186 : new (graph()->zone()->New(sizeof(ZoneVector<MachineType>)))
187 : ZoneVector<MachineType>(0, graph()->zone()),
188 : SparseInputMask(SparseInputMask::kEndMarker << 1))))
189 :
190 : #undef DEFINE_GETTER
191 : #undef GET_CACHED_FIELD
192 :
193 : } // namespace compiler
194 : } // namespace internal
195 178779 : } // namespace v8
|