Chromium Code Reviews| Index: src/objects.cc |
| diff --git a/src/objects.cc b/src/objects.cc |
| index ddc53ccad5cf1adb9239efa3b45d76281f6703a0..307bcbf13cdc539eaf041e835fa97910e0caa34c 100644 |
| --- a/src/objects.cc |
| +++ b/src/objects.cc |
| @@ -11786,7 +11786,7 @@ bool DependentCode::MarkCodeForDeoptimization( |
| if (is_code_at(i)) { |
| Code* code = code_at(i); |
| if (!code->marked_for_deoptimization()) { |
| - code->set_marked_for_deoptimization(true); |
| + SetMarkedForDeoptimization(code, group); |
| marked = true; |
| } |
| } else { |
| @@ -11837,6 +11837,51 @@ void DependentCode::AddToDependentICList(Handle<Code> stub) { |
| } |
| +void DependentCode::SetMarkedForDeoptimization(Code* code, |
| + DependencyGroup group) { |
| + code->set_marked_for_deoptimization(true); |
| + if (FLAG_trace_deopt && |
| + (code->deoptimization_data() != code->GetHeap()->empty_fixed_array())) { |
| + DeoptimizationInputData* deopt_data = |
| + DeoptimizationInputData::cast(code->deoptimization_data()); |
| + CodeTracer::Scope scope(code->GetHeap()->isolate()->GetCodeTracer()); |
| + PrintF(scope.file(), "[marking dependent code 0x%08" V8PRIxPTR |
| + " (opt #%d) for deoptimization, reason: %s]\n", |
| + reinterpret_cast<intptr_t>(code), |
| + deopt_data->OptimizationId()->value(), DependencyGroupName(group)); |
| + } |
| +} |
| + |
| + |
| +const char* DependentCode::DependencyGroupName(DependencyGroup group) { |
| + switch (group) { |
| + case kWeakICGroup: |
| + return "weak-ic"; |
| + case kWeakCodeGroup: |
| + return "weak-code"; |
| + case kTransitionGroup: |
| + return "transition"; |
| + case kPrototypeCheckGroup: |
| + return "prototype-check"; |
| + case kElementsCantBeAddedGroup: |
| + return "elements-cant-be-added"; |
| + case kPropertyCellChangedGroup: |
| + return "property-cell-changed"; |
| + case kFieldTypeGroup: |
| + return "field-type"; |
| + case kInitialMapChangedGroup: |
| + return "initial-map-changed"; |
| + case kAllocationSiteTenuringChangedGroup: |
| + return "allocation-site-tenuring-changed"; |
| + case kAllocationSiteTransitionChangedGroup: |
| + return "allocation-site-transition-changed"; |
| + default: |
|
Toon Verwaest
2014/08/19 11:08:04
Any reason why you added a default case? That kind
Vyacheslav Egorov (Google)
2014/08/19 11:14:41
Well, main reason is that enumeration has parasiti
|
| + UNREACHABLE(); |
| + return "?"; |
| + } |
| +} |
| + |
| + |
| Handle<Map> Map::TransitionToPrototype(Handle<Map> map, |
| Handle<Object> prototype) { |
| Handle<Map> new_map = GetPrototypeTransition(map, prototype); |