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/ic/handler-compiler.h" | 7 #include "src/ic/handler-compiler.h" |
8 #include "src/ic/ic-inl.h" | 8 #include "src/ic/ic-inl.h" |
9 #include "src/ic/ic-compiler.h" | 9 #include "src/ic/ic-compiler.h" |
10 | 10 |
(...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
56 } | 56 } |
57 | 57 |
58 CacheHolderFlag flag; | 58 CacheHolderFlag flag; |
59 Handle<Map> stub_holder = IC::GetICCacheHolder(*type, isolate, &flag); | 59 Handle<Map> stub_holder = IC::GetICCacheHolder(*type, isolate, &flag); |
60 if (kind == Code::KEYED_STORE_IC) { | 60 if (kind == Code::KEYED_STORE_IC) { |
61 // Always set the "property" bit. | 61 // Always set the "property" bit. |
62 extra_ic_state = | 62 extra_ic_state = |
63 KeyedStoreIC::IcCheckTypeField::update(extra_ic_state, PROPERTY); | 63 KeyedStoreIC::IcCheckTypeField::update(extra_ic_state, PROPERTY); |
64 DCHECK(STANDARD_STORE == | 64 DCHECK(STANDARD_STORE == |
65 KeyedStoreIC::GetKeyedAccessStoreMode(extra_ic_state)); | 65 KeyedStoreIC::GetKeyedAccessStoreMode(extra_ic_state)); |
66 } else if (kind == Code::KEYED_LOAD_IC) { | |
67 extra_ic_state = KeyedLoadIC::IcCheckTypeField::update(extra_ic_state, | |
68 PROPERTY); | |
66 } | 69 } |
67 | 70 |
68 Handle<Code> ic; | 71 Handle<Code> ic; |
69 // There are multiple string maps that all use the same prototype. That | 72 // There are multiple string maps that all use the same prototype. That |
70 // prototype cannot hold multiple handlers, one for each of the string maps, | 73 // prototype cannot hold multiple handlers, one for each of the string maps, |
71 // for a single name. Hence, turn off caching of the IC. | 74 // for a single name. Hence, turn off caching of the IC. |
72 bool can_be_cached = !type->Is(HeapType::String()); | 75 bool can_be_cached = !type->Is(HeapType::String()); |
73 if (can_be_cached) { | 76 if (can_be_cached) { |
74 ic = Find(name, stub_holder, kind, extra_ic_state, flag); | 77 ic = Find(name, stub_holder, kind, extra_ic_state, flag); |
75 if (!ic.is_null()) return ic; | 78 if (!ic.is_null()) return ic; |
76 } | 79 } |
77 | 80 |
78 PropertyICCompiler ic_compiler(isolate, kind, extra_ic_state, flag); | 81 PropertyICCompiler ic_compiler(isolate, kind, extra_ic_state, flag); |
79 ic = ic_compiler.CompileMonomorphic(type, handler, name, PROPERTY); | 82 ic = ic_compiler.CompileMonomorphic(type, handler, name, PROPERTY); |
80 | 83 |
81 if (can_be_cached) Map::UpdateCodeCache(stub_holder, name, ic); | 84 if (can_be_cached) Map::UpdateCodeCache(stub_holder, name, ic); |
82 return ic; | 85 return ic; |
83 } | 86 } |
84 | 87 |
85 | 88 |
86 Handle<Code> PropertyICCompiler::ComputeKeyedLoadMonomorphic( | 89 Handle<Code> PropertyICCompiler::ComputeKeyedLoadMonomorphic( |
87 Handle<Map> receiver_map) { | 90 Handle<Map> receiver_map, |
91 ExtraICState extra_ic_state) { | |
Jakob Kummerow
2014/12/12 10:14:27
If you insist on keeping this additional argument,
indutny
2014/12/12 13:05:37
I'd either need to pass this, or StrictMode to be
Jakob Kummerow
2014/12/12 13:34:16
Why do you need StrictMode? Loads don't depend on
| |
88 Isolate* isolate = receiver_map->GetIsolate(); | 92 Isolate* isolate = receiver_map->GetIsolate(); |
89 Code::Flags flags = Code::ComputeMonomorphicFlags(Code::KEYED_LOAD_IC); | 93 extra_ic_state = KeyedLoadIC::IcCheckTypeField::update(extra_ic_state, |
94 ELEMENT); | |
95 Code::Flags flags = Code::ComputeMonomorphicFlags(Code::KEYED_LOAD_IC, | |
96 extra_ic_state); | |
90 Handle<Name> name = isolate->factory()->KeyedLoadMonomorphic_string(); | 97 Handle<Name> name = isolate->factory()->KeyedLoadMonomorphic_string(); |
91 | 98 |
92 Handle<Object> probe(receiver_map->FindInCodeCache(*name, flags), isolate); | 99 Handle<Object> probe(receiver_map->FindInCodeCache(*name, flags), isolate); |
93 if (probe->IsCode()) return Handle<Code>::cast(probe); | 100 if (probe->IsCode()) return Handle<Code>::cast(probe); |
94 | 101 |
95 Handle<Code> stub = ComputeKeyedLoadMonomorphicHandler(receiver_map); | 102 Handle<Code> stub = ComputeKeyedLoadMonomorphicHandler(receiver_map); |
96 PropertyICCompiler compiler(isolate, Code::KEYED_LOAD_IC); | 103 PropertyICCompiler compiler(isolate, Code::KEYED_LOAD_IC, extra_ic_state); |
97 Handle<Code> code = | 104 Handle<Code> code = |
98 compiler.CompileMonomorphic(HeapType::Class(receiver_map, isolate), stub, | 105 compiler.CompileMonomorphic(HeapType::Class(receiver_map, isolate), stub, |
99 isolate->factory()->empty_string(), ELEMENT); | 106 isolate->factory()->empty_string(), ELEMENT); |
100 | 107 |
101 Map::UpdateCodeCache(receiver_map, name, code); | 108 Map::UpdateCodeCache(receiver_map, name, code); |
102 return code; | 109 return code; |
103 } | 110 } |
104 | 111 |
105 | 112 |
106 Handle<Code> PropertyICCompiler::ComputeKeyedLoadMonomorphicHandler( | 113 Handle<Code> PropertyICCompiler::ComputeKeyedLoadMonomorphicHandler( |
(...skipping 139 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
246 if (!receiver_map->is_dictionary_map()) { | 253 if (!receiver_map->is_dictionary_map()) { |
247 Map::UpdateCodeCache(receiver_map, name, ic); | 254 Map::UpdateCodeCache(receiver_map, name, ic); |
248 } | 255 } |
249 | 256 |
250 return ic; | 257 return ic; |
251 } | 258 } |
252 | 259 |
253 | 260 |
254 // TODO(verwaest): Change this method so it takes in a TypeHandleList. | 261 // TODO(verwaest): Change this method so it takes in a TypeHandleList. |
255 Handle<Code> PropertyICCompiler::ComputeKeyedLoadPolymorphic( | 262 Handle<Code> PropertyICCompiler::ComputeKeyedLoadPolymorphic( |
256 MapHandleList* receiver_maps) { | 263 MapHandleList* receiver_maps, |
264 ExtraICState extra_ic_state) { | |
257 Isolate* isolate = receiver_maps->at(0)->GetIsolate(); | 265 Isolate* isolate = receiver_maps->at(0)->GetIsolate(); |
258 Code::Flags flags = Code::ComputeFlags(Code::KEYED_LOAD_IC, POLYMORPHIC); | 266 extra_ic_state = KeyedLoadIC::IcCheckTypeField::update(extra_ic_state, |
267 ELEMENT); | |
268 Code::Flags flags = Code::ComputeFlags(Code::KEYED_LOAD_IC, | |
269 POLYMORPHIC, | |
270 extra_ic_state); | |
259 Handle<PolymorphicCodeCache> cache = | 271 Handle<PolymorphicCodeCache> cache = |
260 isolate->factory()->polymorphic_code_cache(); | 272 isolate->factory()->polymorphic_code_cache(); |
261 Handle<Object> probe = cache->Lookup(receiver_maps, flags); | 273 Handle<Object> probe = cache->Lookup(receiver_maps, flags); |
262 if (probe->IsCode()) return Handle<Code>::cast(probe); | 274 if (probe->IsCode()) return Handle<Code>::cast(probe); |
263 | 275 |
264 TypeHandleList types(receiver_maps->length()); | 276 TypeHandleList types(receiver_maps->length()); |
265 for (int i = 0; i < receiver_maps->length(); i++) { | 277 for (int i = 0; i < receiver_maps->length(); i++) { |
266 types.Add(HeapType::Class(receiver_maps->at(i), isolate)); | 278 types.Add(HeapType::Class(receiver_maps->at(i), isolate)); |
267 } | 279 } |
268 CodeHandleList handlers(receiver_maps->length()); | 280 CodeHandleList handlers(receiver_maps->length()); |
269 ElementHandlerCompiler compiler(isolate); | 281 ElementHandlerCompiler compiler(isolate); |
270 compiler.CompileElementHandlers(receiver_maps, &handlers); | 282 compiler.CompileElementHandlers(receiver_maps, &handlers); |
271 PropertyICCompiler ic_compiler(isolate, Code::KEYED_LOAD_IC); | 283 PropertyICCompiler ic_compiler(isolate, Code::KEYED_LOAD_IC, extra_ic_state); |
272 Handle<Code> code = ic_compiler.CompilePolymorphic( | 284 Handle<Code> code = ic_compiler.CompilePolymorphic( |
273 &types, &handlers, isolate->factory()->empty_string(), Code::NORMAL, | 285 &types, &handlers, isolate->factory()->empty_string(), Code::NORMAL, |
274 ELEMENT); | 286 ELEMENT); |
275 | 287 |
276 isolate->counters()->keyed_load_polymorphic_stubs()->Increment(); | 288 isolate->counters()->keyed_load_polymorphic_stubs()->Increment(); |
277 | 289 |
278 PolymorphicCodeCache::Update(cache, receiver_maps, flags, code); | 290 PolymorphicCodeCache::Update(cache, receiver_maps, flags, code); |
279 return code; | 291 return code; |
280 } | 292 } |
281 | 293 |
(...skipping 167 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
449 | 461 |
450 TailCallBuiltin(masm(), Builtins::kKeyedStoreIC_Miss); | 462 TailCallBuiltin(masm(), Builtins::kKeyedStoreIC_Miss); |
451 | 463 |
452 return GetCode(kind(), Code::NORMAL, factory()->empty_string()); | 464 return GetCode(kind(), Code::NORMAL, factory()->empty_string()); |
453 } | 465 } |
454 | 466 |
455 | 467 |
456 #undef __ | 468 #undef __ |
457 } | 469 } |
458 } // namespace v8::internal | 470 } // namespace v8::internal |
OLD | NEW |