| OLD | NEW |
| 1 // Copyright 2012 The Chromium Authors. All rights reserved. | 1 // Copyright 2012 The Chromium 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 "cc/resources/tile_manager.h" | 5 #include "cc/resources/tile_manager.h" |
| 6 | 6 |
| 7 #include <algorithm> | 7 #include <algorithm> |
| 8 #include <limits> | 8 #include <limits> |
| 9 #include <string> | 9 #include <string> |
| 10 | 10 |
| 11 #include "base/bind.h" | 11 #include "base/bind.h" |
| 12 #include "base/debug/trace_event_argument.h" |
| 12 #include "base/json/json_writer.h" | 13 #include "base/json/json_writer.h" |
| 13 #include "base/logging.h" | 14 #include "base/logging.h" |
| 14 #include "base/metrics/histogram.h" | 15 #include "base/metrics/histogram.h" |
| 15 #include "cc/debug/devtools_instrumentation.h" | 16 #include "cc/debug/devtools_instrumentation.h" |
| 16 #include "cc/debug/frame_viewer_instrumentation.h" | 17 #include "cc/debug/frame_viewer_instrumentation.h" |
| 17 #include "cc/debug/traced_value.h" | 18 #include "cc/debug/traced_value.h" |
| 18 #include "cc/layers/picture_layer_impl.h" | 19 #include "cc/layers/picture_layer_impl.h" |
| 19 #include "cc/resources/raster_worker_pool.h" | 20 #include "cc/resources/raster_worker_pool.h" |
| 20 #include "cc/resources/tile.h" | 21 #include "cc/resources/tile.h" |
| 21 #include "skia/ext/paint_simplifier.h" | 22 #include "skia/ext/paint_simplifier.h" |
| (...skipping 638 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 660 AssignGpuMemoryToTiles(&prioritized_tiles_, | 661 AssignGpuMemoryToTiles(&prioritized_tiles_, |
| 661 &tiles_that_need_to_be_rasterized); | 662 &tiles_that_need_to_be_rasterized); |
| 662 | 663 |
| 663 // Finally, schedule rasterizer tasks. | 664 // Finally, schedule rasterizer tasks. |
| 664 ScheduleTasks(tiles_that_need_to_be_rasterized); | 665 ScheduleTasks(tiles_that_need_to_be_rasterized); |
| 665 | 666 |
| 666 TRACE_EVENT_INSTANT1("cc", | 667 TRACE_EVENT_INSTANT1("cc", |
| 667 "DidManage", | 668 "DidManage", |
| 668 TRACE_EVENT_SCOPE_THREAD, | 669 TRACE_EVENT_SCOPE_THREAD, |
| 669 "state", | 670 "state", |
| 670 TracedValue::FromValue(BasicStateAsValue().release())); | 671 BasicStateAsValue()); |
| 671 | 672 |
| 672 TRACE_COUNTER_ID1("cc", | 673 TRACE_COUNTER_ID1("cc", |
| 673 "unused_memory_bytes", | 674 "unused_memory_bytes", |
| 674 this, | 675 this, |
| 675 resource_pool_->total_memory_usage_bytes() - | 676 resource_pool_->total_memory_usage_bytes() - |
| 676 resource_pool_->acquired_memory_usage_bytes()); | 677 resource_pool_->acquired_memory_usage_bytes()); |
| 677 } | 678 } |
| 678 | 679 |
| 679 bool TileManager::UpdateVisibleTiles() { | 680 bool TileManager::UpdateVisibleTiles() { |
| 680 TRACE_EVENT0("cc", "TileManager::UpdateVisibleTiles"); | 681 TRACE_EVENT0("cc", "TileManager::UpdateVisibleTiles"); |
| 681 | 682 |
| 682 rasterizer_->CheckForCompletedTasks(); | 683 rasterizer_->CheckForCompletedTasks(); |
| 683 did_check_for_completed_tasks_since_last_schedule_tasks_ = true; | 684 did_check_for_completed_tasks_since_last_schedule_tasks_ = true; |
| 684 | 685 |
| 685 TRACE_EVENT_INSTANT1( | 686 TRACE_EVENT_INSTANT1( |
| 686 "cc", | 687 "cc", |
| 687 "DidUpdateVisibleTiles", | 688 "DidUpdateVisibleTiles", |
| 688 TRACE_EVENT_SCOPE_THREAD, | 689 TRACE_EVENT_SCOPE_THREAD, |
| 689 "stats", | 690 "stats", |
| 690 TracedValue::FromValue(RasterTaskCompletionStatsAsValue( | 691 TracedValue::FromValue(RasterTaskCompletionStatsAsValue( |
| 691 update_visible_tiles_stats_).release())); | 692 update_visible_tiles_stats_).release())); |
| 692 update_visible_tiles_stats_ = RasterTaskCompletionStats(); | 693 update_visible_tiles_stats_ = RasterTaskCompletionStats(); |
| 693 | 694 |
| 694 bool did_initialize_visible_tile = did_initialize_visible_tile_; | 695 bool did_initialize_visible_tile = did_initialize_visible_tile_; |
| 695 did_initialize_visible_tile_ = false; | 696 did_initialize_visible_tile_ = false; |
| 696 return did_initialize_visible_tile; | 697 return did_initialize_visible_tile; |
| 697 } | 698 } |
| 698 | 699 |
| 699 scoped_ptr<base::Value> TileManager::BasicStateAsValue() const { | 700 scoped_refptr<base::debug::ConvertableToTraceFormat> |
| 700 scoped_ptr<base::DictionaryValue> state(new base::DictionaryValue()); | 701 TileManager::BasicStateAsValue() const { |
| 701 state->SetInteger("tile_count", tiles_.size()); | 702 scoped_refptr<base::debug::TracedValue> value = |
| 702 state->Set("global_state", global_state_.AsValue().release()); | 703 new base::debug::TracedValue(); |
| 703 return state.PassAs<base::Value>(); | 704 BasicStateAsValueInto(value.get()); |
| 705 return value; |
| 704 } | 706 } |
| 705 | 707 |
| 706 scoped_ptr<base::Value> TileManager::AllTilesAsValue() const { | 708 void TileManager::BasicStateAsValueInto(base::debug::TracedValue* state) const { |
| 707 scoped_ptr<base::ListValue> state(new base::ListValue()); | 709 state->SetInteger("tile_count", tiles_.size()); |
| 708 for (TileMap::const_iterator it = tiles_.begin(); it != tiles_.end(); ++it) | 710 state->BeginDictionary("global_state"); |
| 709 state->Append(it->second->AsValue().release()); | 711 global_state_.AsValueInto(state); |
| 712 state->EndDictionary(); |
| 713 } |
| 710 | 714 |
| 711 return state.PassAs<base::Value>(); | 715 void TileManager::AllTilesAsValueInto(base::debug::TracedValue* state) const { |
| 716 for (TileMap::const_iterator it = tiles_.begin(); it != tiles_.end(); ++it) { |
| 717 state->BeginDictionary(); |
| 718 it->second->AsValueInto(state); |
| 719 state->EndDictionary(); |
| 720 } |
| 712 } | 721 } |
| 713 | 722 |
| 714 void TileManager::AssignGpuMemoryToTiles( | 723 void TileManager::AssignGpuMemoryToTiles( |
| 715 PrioritizedTileSet* tiles, | 724 PrioritizedTileSet* tiles, |
| 716 TileVector* tiles_that_need_to_be_rasterized) { | 725 TileVector* tiles_that_need_to_be_rasterized) { |
| 717 TRACE_EVENT0("cc", "TileManager::AssignGpuMemoryToTiles"); | 726 TRACE_EVENT0("cc", "TileManager::AssignGpuMemoryToTiles"); |
| 718 | 727 |
| 719 // Maintain the list of released resources that can potentially be re-used | 728 // Maintain the list of released resources that can potentially be re-used |
| 720 // or deleted. | 729 // or deleted. |
| 721 // If this operation becomes expensive too, only do this after some | 730 // If this operation becomes expensive too, only do this after some |
| (...skipping 436 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1158 TRACE_EVENT0("cc", "TileManager::CheckIfReadyToActivate"); | 1167 TRACE_EVENT0("cc", "TileManager::CheckIfReadyToActivate"); |
| 1159 | 1168 |
| 1160 rasterizer_->CheckForCompletedTasks(); | 1169 rasterizer_->CheckForCompletedTasks(); |
| 1161 did_check_for_completed_tasks_since_last_schedule_tasks_ = true; | 1170 did_check_for_completed_tasks_since_last_schedule_tasks_ = true; |
| 1162 | 1171 |
| 1163 if (IsReadyToActivate()) | 1172 if (IsReadyToActivate()) |
| 1164 client_->NotifyReadyToActivate(); | 1173 client_->NotifyReadyToActivate(); |
| 1165 } | 1174 } |
| 1166 | 1175 |
| 1167 } // namespace cc | 1176 } // namespace cc |
| OLD | NEW |