Index: src/objects.cc |
diff --git a/src/objects.cc b/src/objects.cc |
index aa6e2808b46d283c5178cbff07f05da6db8ebdbd..11c8ffcacdd5483351e8915cd8261f95b861eceb 100644 |
--- a/src/objects.cc |
+++ b/src/objects.cc |
@@ -9631,42 +9631,46 @@ void SharedFunctionInfo::ClearOptimizedCodeMap() { |
} |
-void SharedFunctionInfo::EvictFromOptimizedCodeMap(Code* optimized_code, |
+void SharedFunctionInfo::EvictFromOptimizedCodeMap(Context* context, |
const char* reason) { |
+ ASSERT(context->IsNativeContext()); |
if (optimized_code_map()->IsSmi()) return; |
- int i; |
- bool removed_entry = false; |
FixedArray* code_map = FixedArray::cast(optimized_code_map()); |
- for (i = kEntriesStart; i < code_map->length(); i += kEntryLength) { |
- ASSERT(code_map->get(i)->IsNativeContext()); |
- if (Code::cast(code_map->get(i + 1)) == optimized_code) { |
+ int dst = kEntriesStart; |
+ int length = code_map->length(); |
+ for (int src = kEntriesStart; src < length; src += kEntryLength) { |
+ Context* context_key = Context::cast(code_map->get(src)); |
+ ASSERT(context->IsNativeContext()); |
+ if (context_key == context) { |
if (FLAG_trace_opt) { |
PrintF("[evicting entry from optimizing code map (%s) for ", reason); |
ShortPrint(); |
- PrintF("]\n"); |
+ BailoutId osr(Smi::cast(code_map->get(src + kOsrAstIdOffset))->value()); |
+ if (osr.IsNone()) { |
+ PrintF("]\n"); |
+ } else { |
+ PrintF(" (osr ast id %d)]\n", osr.ToInt()); |
+ } |
} |
- removed_entry = true; |
- break; |
+ continue; |
} |
+ if (dst != src) { |
+ code_map->set(dst + kContextOffset, |
+ code_map->get(src + kContextOffset)); |
+ code_map->set(dst + kCachedCodeOffset, |
+ code_map->get(src + kCachedCodeOffset)); |
+ code_map->set(dst + kLiteralsOffset, |
+ code_map->get(src + kLiteralsOffset)); |
+ code_map->set(dst + kOsrAstIdOffset, |
+ code_map->get(src + kOsrAstIdOffset)); |
+ } |
+ dst += kEntryLength; |
} |
- while (i < (code_map->length() - kEntryLength)) { |
- code_map->set(i + kContextOffset, |
- code_map->get(i + kContextOffset + kEntryLength)); |
- code_map->set(i + kCachedCodeOffset, |
- code_map->get(i + kCachedCodeOffset + kEntryLength)); |
- code_map->set(i + kLiteralsOffset, |
- code_map->get(i + kLiteralsOffset + kEntryLength)); |
- code_map->set(i + kOsrAstIdOffset, |
- code_map->get(i + kOsrAstIdOffset + kEntryLength)); |
- i += kEntryLength; |
- } |
- if (removed_entry) { |
+ if (dst != length) { |
// Always trim even when array is cleared because of heap verifier. |
- RightTrimFixedArray<FROM_MUTATOR>(GetHeap(), code_map, kEntryLength); |
- if (code_map->length() == kEntriesStart) { |
- ClearOptimizedCodeMap(); |
- } |
+ RightTrimFixedArray<FROM_MUTATOR>(GetHeap(), code_map, length - dst); |
+ if (code_map->length() == kEntriesStart) ClearOptimizedCodeMap(); |
} |
} |