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 #include "src/v8.h" | 5 #include "src/v8.h" |
6 | 6 |
7 #include "src/cpu-profiler.h" | 7 #include "src/cpu-profiler.h" |
8 #include "src/ic/handler-compiler.h" | 8 #include "src/ic/handler-compiler.h" |
9 #include "src/ic/ic-inl.h" | 9 #include "src/ic/ic-inl.h" |
10 #include "src/ic/ic-compiler.h" | 10 #include "src/ic/ic-compiler.h" |
(...skipping 70 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
81 | 81 |
82 PropertyICCompiler ic_compiler(isolate, kind, extra_ic_state, flag); | 82 PropertyICCompiler ic_compiler(isolate, kind, extra_ic_state, flag); |
83 ic = ic_compiler.CompileMonomorphic(map, handler, name, PROPERTY); | 83 ic = ic_compiler.CompileMonomorphic(map, handler, name, PROPERTY); |
84 | 84 |
85 if (can_be_cached) Map::UpdateCodeCache(stub_holder, name, ic); | 85 if (can_be_cached) Map::UpdateCodeCache(stub_holder, name, ic); |
86 return ic; | 86 return ic; |
87 } | 87 } |
88 | 88 |
89 | 89 |
90 Handle<Code> PropertyICCompiler::ComputeKeyedLoadMonomorphicHandler( | 90 Handle<Code> PropertyICCompiler::ComputeKeyedLoadMonomorphicHandler( |
91 Handle<Map> receiver_map) { | 91 Handle<Map> receiver_map, ExtraICState extra_ic_state) { |
92 Isolate* isolate = receiver_map->GetIsolate(); | 92 Isolate* isolate = receiver_map->GetIsolate(); |
93 bool is_js_array = receiver_map->instance_type() == JS_ARRAY_TYPE; | 93 bool is_js_array = receiver_map->instance_type() == JS_ARRAY_TYPE; |
94 ElementsKind elements_kind = receiver_map->elements_kind(); | 94 ElementsKind elements_kind = receiver_map->elements_kind(); |
95 | 95 |
96 // No need to check for an elements-free prototype chain here, the generated | 96 // No need to check for an elements-free prototype chain here, the generated |
97 // stub code needs to check that dynamically anyway. | 97 // stub code needs to check that dynamically anyway. |
98 bool convert_hole_to_undefined = | 98 bool convert_hole_to_undefined = |
99 is_js_array && elements_kind == FAST_HOLEY_ELEMENTS && | 99 is_js_array && elements_kind == FAST_HOLEY_ELEMENTS && |
100 *receiver_map == isolate->get_initial_js_array_map(elements_kind); | 100 *receiver_map == isolate->get_initial_js_array_map(elements_kind) && |
101 | 101 !(is_strong(LoadICState::GetLanguageMode(extra_ic_state))); |
102 Handle<Code> stub; | 102 Handle<Code> stub; |
103 if (receiver_map->has_indexed_interceptor()) { | 103 if (receiver_map->has_indexed_interceptor()) { |
104 stub = LoadIndexedInterceptorStub(isolate).GetCode(); | 104 stub = LoadIndexedInterceptorStub(isolate).GetCode(); |
105 } else if (receiver_map->IsStringMap()) { | 105 } else if (receiver_map->IsStringMap()) { |
106 // We have a string. | 106 // We have a string. |
107 stub = LoadIndexedStringStub(isolate).GetCode(); | 107 stub = LoadIndexedStringStub(isolate).GetCode(); |
108 } else if (receiver_map->has_sloppy_arguments_elements()) { | 108 } else if (receiver_map->has_sloppy_arguments_elements()) { |
109 stub = KeyedLoadSloppyArgumentsStub(isolate).GetCode(); | 109 stub = KeyedLoadSloppyArgumentsStub(isolate).GetCode(); |
110 } else if (receiver_map->has_fast_elements() || | 110 } else if (receiver_map->has_fast_elements() || |
111 receiver_map->has_external_array_elements() || | 111 receiver_map->has_external_array_elements() || |
112 receiver_map->has_fixed_typed_array_elements()) { | 112 receiver_map->has_fixed_typed_array_elements()) { |
113 stub = LoadFastElementStub(isolate, is_js_array, elements_kind, | 113 stub = LoadFastElementStub(isolate, is_js_array, elements_kind, |
114 convert_hole_to_undefined).GetCode(); | 114 convert_hole_to_undefined).GetCode(); |
115 } else { | 115 } else { |
116 stub = LoadDictionaryElementStub(isolate).GetCode(); | 116 stub = LoadDictionaryElementStub(isolate, LoadICState(extra_ic_state)) |
| 117 .GetCode(); |
117 } | 118 } |
118 return stub; | 119 return stub; |
119 } | 120 } |
120 | 121 |
121 | 122 |
122 Handle<Code> PropertyICCompiler::ComputeKeyedStoreMonomorphic( | 123 Handle<Code> PropertyICCompiler::ComputeKeyedStoreMonomorphic( |
123 Handle<Map> receiver_map, LanguageMode language_mode, | 124 Handle<Map> receiver_map, LanguageMode language_mode, |
124 KeyedAccessStoreMode store_mode) { | 125 KeyedAccessStoreMode store_mode) { |
125 Isolate* isolate = receiver_map->GetIsolate(); | 126 Isolate* isolate = receiver_map->GetIsolate(); |
126 ExtraICState extra_state = | 127 ExtraICState extra_state = |
(...skipping 87 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
214 | 215 |
215 if (!receiver_map->is_dictionary_map()) { | 216 if (!receiver_map->is_dictionary_map()) { |
216 Map::UpdateCodeCache(receiver_map, name, ic); | 217 Map::UpdateCodeCache(receiver_map, name, ic); |
217 } | 218 } |
218 | 219 |
219 return ic; | 220 return ic; |
220 } | 221 } |
221 | 222 |
222 | 223 |
223 Handle<Code> PropertyICCompiler::ComputeKeyedLoadPolymorphic( | 224 Handle<Code> PropertyICCompiler::ComputeKeyedLoadPolymorphic( |
224 MapHandleList* receiver_maps) { | 225 MapHandleList* receiver_maps, LanguageMode language_mode) { |
225 Isolate* isolate = receiver_maps->at(0)->GetIsolate(); | 226 Isolate* isolate = receiver_maps->at(0)->GetIsolate(); |
226 DCHECK(KeyedLoadIC::GetKeyType(kNoExtraICState) == ELEMENT); | 227 DCHECK(KeyedLoadIC::GetKeyType(kNoExtraICState) == ELEMENT); |
227 Code::Flags flags = Code::ComputeFlags(Code::KEYED_LOAD_IC, POLYMORPHIC); | 228 Code::Flags flags = Code::ComputeFlags(Code::KEYED_LOAD_IC, POLYMORPHIC); |
228 Handle<PolymorphicCodeCache> cache = | 229 Handle<PolymorphicCodeCache> cache = |
229 isolate->factory()->polymorphic_code_cache(); | 230 isolate->factory()->polymorphic_code_cache(); |
230 Handle<Object> probe = cache->Lookup(receiver_maps, flags); | 231 Handle<Object> probe = cache->Lookup(receiver_maps, flags); |
231 if (probe->IsCode()) return Handle<Code>::cast(probe); | 232 if (probe->IsCode()) return Handle<Code>::cast(probe); |
232 | 233 |
233 CodeHandleList handlers(receiver_maps->length()); | 234 CodeHandleList handlers(receiver_maps->length()); |
234 ElementHandlerCompiler compiler(isolate); | 235 ElementHandlerCompiler compiler(isolate); |
235 compiler.CompileElementHandlers(receiver_maps, &handlers); | 236 compiler.CompileElementHandlers(receiver_maps, &handlers, language_mode); |
236 PropertyICCompiler ic_compiler(isolate, Code::KEYED_LOAD_IC); | 237 PropertyICCompiler ic_compiler(isolate, Code::KEYED_LOAD_IC); |
237 Handle<Code> code = ic_compiler.CompilePolymorphic( | 238 Handle<Code> code = ic_compiler.CompilePolymorphic( |
238 receiver_maps, &handlers, isolate->factory()->empty_string(), | 239 receiver_maps, &handlers, isolate->factory()->empty_string(), |
239 Code::NORMAL, ELEMENT); | 240 Code::NORMAL, ELEMENT); |
240 | 241 |
241 isolate->counters()->keyed_load_polymorphic_stubs()->Increment(); | 242 isolate->counters()->keyed_load_polymorphic_stubs()->Increment(); |
242 | 243 |
243 PolymorphicCodeCache::Update(cache, receiver_maps, flags, code); | 244 PolymorphicCodeCache::Update(cache, receiver_maps, flags, code); |
244 return code; | 245 return code; |
245 } | 246 } |
(...skipping 168 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
414 | 415 |
415 TailCallBuiltin(masm(), Builtins::kKeyedStoreIC_Miss); | 416 TailCallBuiltin(masm(), Builtins::kKeyedStoreIC_Miss); |
416 | 417 |
417 return GetCode(kind(), Code::NORMAL, factory()->empty_string()); | 418 return GetCode(kind(), Code::NORMAL, factory()->empty_string()); |
418 } | 419 } |
419 | 420 |
420 | 421 |
421 #undef __ | 422 #undef __ |
422 } // namespace internal | 423 } // namespace internal |
423 } // namespace v8 | 424 } // namespace v8 |
OLD | NEW |