Index: src/objects.cc |
diff --git a/src/objects.cc b/src/objects.cc |
index bef6dba7932e0297f3471f22b7829395c6379a24..8b6afc36bb09463c51921ad344ac81ffc4df1000 100644 |
--- a/src/objects.cc |
+++ b/src/objects.cc |
@@ -11989,7 +11989,7 @@ void SharedFunctionInfo::AddSharedCodeToOptimizedCodeMap( |
} |
-void SharedFunctionInfo::AddToOptimizedCodeMap( |
+void SharedFunctionInfo::AddToOptimizedCodeMapInternal( |
Handle<SharedFunctionInfo> shared, Handle<Context> native_context, |
Handle<HeapObject> code, Handle<LiteralsArray> literals, |
BailoutId osr_ast_id) { |
@@ -12001,6 +12001,7 @@ void SharedFunctionInfo::AddToOptimizedCodeMap( |
Code::cast(*code)->kind() == Code::OPTIMIZED_FUNCTION); |
DCHECK(native_context->IsNativeContext()); |
STATIC_ASSERT(kEntryLength == 4); |
+ Handle<FixedArray> old_code_map(shared->optimized_code_map(), isolate); |
Handle<FixedArray> new_code_map; |
int entry; |
@@ -12010,19 +12011,21 @@ void SharedFunctionInfo::AddToOptimizedCodeMap( |
SKIP_WRITE_BARRIER); |
entry = kEntriesStart; |
} else { |
- Handle<FixedArray> old_code_map(shared->optimized_code_map(), isolate); |
entry = shared->SearchOptimizedCodeMapEntry(*native_context, osr_ast_id); |
if (entry > kSharedCodeIndex) { |
- // Found an existing context-specific entry, it must not contain any code. |
- DCHECK(WeakCell::cast(old_code_map->get(entry + kCachedCodeOffset)) |
+ // Found an existing context-specific entry. If the user provided valid |
+ // code, it must not contain any code. |
+ DCHECK(code->IsUndefined() || |
+ WeakCell::cast(old_code_map->get(entry + kCachedCodeOffset)) |
->cleared()); |
+ |
// Just set the code and literals to the entry. |
- Handle<WeakCell> code_cell = code->IsUndefined() |
- ? isolate->factory()->empty_weak_cell() |
- : isolate->factory()->NewWeakCell(code); |
+ if (!code->IsUndefined()) { |
+ Handle<WeakCell> code_cell = isolate->factory()->NewWeakCell(code); |
+ old_code_map->set(entry + kCachedCodeOffset, *code_cell); |
+ } |
Handle<WeakCell> literals_cell = |
isolate->factory()->NewWeakCell(literals); |
- old_code_map->set(entry + kCachedCodeOffset, *code_cell); |
old_code_map->set(entry + kLiteralsOffset, *literals_cell); |
return; |
} |
@@ -12051,15 +12054,20 @@ void SharedFunctionInfo::AddToOptimizedCodeMap( |
} |
} |
- Handle<WeakCell> code_cell = code->IsUndefined() |
- ? isolate->factory()->empty_weak_cell() |
- : isolate->factory()->NewWeakCell(code); |
- Handle<WeakCell> literals_cell = isolate->factory()->NewWeakCell(literals); |
WeakCell* context_cell = native_context->self_weak_cell(); |
- |
new_code_map->set(entry + kContextOffset, context_cell); |
- new_code_map->set(entry + kCachedCodeOffset, *code_cell); |
+ |
+ bool created_new_map = !old_code_map.is_identical_to(new_code_map); |
+ if (!code->IsUndefined() || created_new_map) { |
+ Handle<WeakCell> code_cell = code->IsUndefined() |
+ ? isolate->factory()->empty_weak_cell() |
+ : isolate->factory()->NewWeakCell(code); |
+ new_code_map->set(entry + kCachedCodeOffset, *code_cell); |
+ } |
+ |
+ Handle<WeakCell> literals_cell = isolate->factory()->NewWeakCell(literals); |
new_code_map->set(entry + kLiteralsOffset, *literals_cell); |
+ |
new_code_map->set(entry + kOsrAstIdOffset, Smi::FromInt(osr_ast_id.ToInt())); |
#ifdef DEBUG |
@@ -12076,8 +12084,7 @@ void SharedFunctionInfo::AddToOptimizedCodeMap( |
} |
#endif |
- FixedArray* old_code_map = shared->optimized_code_map(); |
- if (old_code_map != *new_code_map) { |
+ if (created_new_map) { |
shared->set_optimized_code_map(*new_code_map); |
} |
} |