OLD | NEW |
1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
4 // met: | 4 // met: |
5 // | 5 // |
6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
(...skipping 947 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
958 isolate_->counters()->objs_since_last_young()->Set(0); | 958 isolate_->counters()->objs_since_last_young()->Set(0); |
959 | 959 |
960 // Callbacks that fire after this point might trigger nested GCs and | 960 // Callbacks that fire after this point might trigger nested GCs and |
961 // restart incremental marking, the assertion can't be moved down. | 961 // restart incremental marking, the assertion can't be moved down. |
962 ASSERT(collector == SCAVENGER || incremental_marking()->IsStopped()); | 962 ASSERT(collector == SCAVENGER || incremental_marking()->IsStopped()); |
963 | 963 |
964 gc_post_processing_depth_++; | 964 gc_post_processing_depth_++; |
965 { DisableAssertNoAllocation allow_allocation; | 965 { DisableAssertNoAllocation allow_allocation; |
966 GCTracer::Scope scope(tracer, GCTracer::Scope::EXTERNAL); | 966 GCTracer::Scope scope(tracer, GCTracer::Scope::EXTERNAL); |
967 next_gc_likely_to_collect_more = | 967 next_gc_likely_to_collect_more = |
968 isolate_->global_handles()->PostGarbageCollectionProcessing(collector); | 968 isolate_->global_handles()->PostGarbageCollectionProcessing( |
| 969 collector, tracer); |
969 } | 970 } |
970 gc_post_processing_depth_--; | 971 gc_post_processing_depth_--; |
971 | 972 |
972 // Update relocatables. | 973 // Update relocatables. |
973 Relocatable::PostGarbageCollectionProcessing(); | 974 Relocatable::PostGarbageCollectionProcessing(); |
974 | 975 |
975 if (collector == MARK_COMPACTOR) { | 976 if (collector == MARK_COMPACTOR) { |
976 // Register the amount of external allocated memory. | 977 // Register the amount of external allocated memory. |
977 amount_of_external_allocated_memory_at_last_global_gc_ = | 978 amount_of_external_allocated_memory_at_last_global_gc_ = |
978 amount_of_external_allocated_memory_; | 979 amount_of_external_allocated_memory_; |
(...skipping 5878 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
6857 const char* gc_reason, | 6858 const char* gc_reason, |
6858 const char* collector_reason) | 6859 const char* collector_reason) |
6859 : start_time_(0.0), | 6860 : start_time_(0.0), |
6860 start_object_size_(0), | 6861 start_object_size_(0), |
6861 start_memory_size_(0), | 6862 start_memory_size_(0), |
6862 gc_count_(0), | 6863 gc_count_(0), |
6863 full_gc_count_(0), | 6864 full_gc_count_(0), |
6864 allocated_since_last_gc_(0), | 6865 allocated_since_last_gc_(0), |
6865 spent_in_mutator_(0), | 6866 spent_in_mutator_(0), |
6866 promoted_objects_size_(0), | 6867 promoted_objects_size_(0), |
| 6868 nodes_died_in_new_space_(0), |
| 6869 nodes_copied_in_new_space_(0), |
| 6870 nodes_promoted_(0), |
6867 heap_(heap), | 6871 heap_(heap), |
6868 gc_reason_(gc_reason), | 6872 gc_reason_(gc_reason), |
6869 collector_reason_(collector_reason) { | 6873 collector_reason_(collector_reason) { |
6870 if (!FLAG_trace_gc && !FLAG_print_cumulative_gc_stat) return; | 6874 if (!FLAG_trace_gc && !FLAG_print_cumulative_gc_stat) return; |
6871 start_time_ = OS::TimeCurrentMillis(); | 6875 start_time_ = OS::TimeCurrentMillis(); |
6872 start_object_size_ = heap_->SizeOfObjects(); | 6876 start_object_size_ = heap_->SizeOfObjects(); |
6873 start_memory_size_ = heap_->isolate()->memory_allocator()->Size(); | 6877 start_memory_size_ = heap_->isolate()->memory_allocator()->Size(); |
6874 | 6878 |
6875 for (int i = 0; i < Scope::kNumberOfScopes; i++) { | 6879 for (int i = 0; i < Scope::kNumberOfScopes; i++) { |
6876 scopes_[i] = 0; | 6880 scopes_[i] = 0; |
(...skipping 120 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
6997 static_cast<int>(scopes_[Scope::MC_UPDATE_MISC_POINTERS])); | 7001 static_cast<int>(scopes_[Scope::MC_UPDATE_MISC_POINTERS])); |
6998 | 7002 |
6999 PrintF("total_size_before=%" V8_PTR_PREFIX "d ", start_object_size_); | 7003 PrintF("total_size_before=%" V8_PTR_PREFIX "d ", start_object_size_); |
7000 PrintF("total_size_after=%" V8_PTR_PREFIX "d ", heap_->SizeOfObjects()); | 7004 PrintF("total_size_after=%" V8_PTR_PREFIX "d ", heap_->SizeOfObjects()); |
7001 PrintF("holes_size_before=%" V8_PTR_PREFIX "d ", | 7005 PrintF("holes_size_before=%" V8_PTR_PREFIX "d ", |
7002 in_free_list_or_wasted_before_gc_); | 7006 in_free_list_or_wasted_before_gc_); |
7003 PrintF("holes_size_after=%" V8_PTR_PREFIX "d ", CountTotalHolesSize()); | 7007 PrintF("holes_size_after=%" V8_PTR_PREFIX "d ", CountTotalHolesSize()); |
7004 | 7008 |
7005 PrintF("allocated=%" V8_PTR_PREFIX "d ", allocated_since_last_gc_); | 7009 PrintF("allocated=%" V8_PTR_PREFIX "d ", allocated_since_last_gc_); |
7006 PrintF("promoted=%" V8_PTR_PREFIX "d ", promoted_objects_size_); | 7010 PrintF("promoted=%" V8_PTR_PREFIX "d ", promoted_objects_size_); |
| 7011 PrintF("nodes_died_in_new=%d ", nodes_died_in_new_space_); |
| 7012 PrintF("nodes_copied_in_new=%d ", nodes_copied_in_new_space_); |
| 7013 PrintF("nodes_promoted=%d ", nodes_promoted_); |
7007 | 7014 |
7008 if (collector_ == SCAVENGER) { | 7015 if (collector_ == SCAVENGER) { |
7009 PrintF("stepscount=%d ", steps_count_since_last_gc_); | 7016 PrintF("stepscount=%d ", steps_count_since_last_gc_); |
7010 PrintF("stepstook=%d ", static_cast<int>(steps_took_since_last_gc_)); | 7017 PrintF("stepstook=%d ", static_cast<int>(steps_took_since_last_gc_)); |
7011 } else { | 7018 } else { |
7012 PrintF("stepscount=%d ", steps_count_); | 7019 PrintF("stepscount=%d ", steps_count_); |
7013 PrintF("stepstook=%d ", static_cast<int>(steps_took_)); | 7020 PrintF("stepstook=%d ", static_cast<int>(steps_took_)); |
7014 PrintF("longeststep=%.f ", longest_step_); | 7021 PrintF("longeststep=%.f ", longest_step_); |
7015 } | 7022 } |
7016 | 7023 |
(...skipping 269 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
7286 static_cast<int>(object_sizes_last_time_[index])); | 7293 static_cast<int>(object_sizes_last_time_[index])); |
7287 FIXED_ARRAY_SUB_INSTANCE_TYPE_LIST(ADJUST_LAST_TIME_OBJECT_COUNT) | 7294 FIXED_ARRAY_SUB_INSTANCE_TYPE_LIST(ADJUST_LAST_TIME_OBJECT_COUNT) |
7288 #undef ADJUST_LAST_TIME_OBJECT_COUNT | 7295 #undef ADJUST_LAST_TIME_OBJECT_COUNT |
7289 | 7296 |
7290 memcpy(object_counts_last_time_, object_counts_, sizeof(object_counts_)); | 7297 memcpy(object_counts_last_time_, object_counts_, sizeof(object_counts_)); |
7291 memcpy(object_sizes_last_time_, object_sizes_, sizeof(object_sizes_)); | 7298 memcpy(object_sizes_last_time_, object_sizes_, sizeof(object_sizes_)); |
7292 ClearObjectStats(); | 7299 ClearObjectStats(); |
7293 } | 7300 } |
7294 | 7301 |
7295 } } // namespace v8::internal | 7302 } } // namespace v8::internal |
OLD | NEW |