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 |
(...skipping 136 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
147 return SOON_BIN; | 147 return SOON_BIN; |
148 | 148 |
149 return EVENTUALLY_BIN; | 149 return EVENTUALLY_BIN; |
150 } | 150 } |
151 | 151 |
152 // Limit to the number of raster tasks that can be scheduled. | 152 // Limit to the number of raster tasks that can be scheduled. |
153 // This is high enough to not cause unnecessary scheduling but | 153 // This is high enough to not cause unnecessary scheduling but |
154 // gives us an insurance that we're not spending a huge amount | 154 // gives us an insurance that we're not spending a huge amount |
155 // of time scheduling one enormous set of tasks. | 155 // of time scheduling one enormous set of tasks. |
156 const size_t kMaxRasterTasks = 256u; | 156 const size_t kMaxRasterTasks = 256u; |
| 157 const size_t kTilePoolSize = 256u; |
157 | 158 |
158 } // namespace | 159 } // namespace |
159 | 160 |
160 RasterTaskCompletionStats::RasterTaskCompletionStats() | 161 RasterTaskCompletionStats::RasterTaskCompletionStats() |
161 : completed_count(0u), | 162 : completed_count(0u), |
162 canceled_count(0u) { | 163 canceled_count(0u) { |
163 } | 164 } |
164 | 165 |
165 scoped_ptr<base::Value> RasterTaskCompletionStatsAsValue( | 166 scoped_ptr<base::Value> RasterTaskCompletionStatsAsValue( |
166 const RasterTaskCompletionStats& stats) { | 167 const RasterTaskCompletionStats& stats) { |
(...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
206 all_tiles_required_for_activation_have_memory_(true), | 207 all_tiles_required_for_activation_have_memory_(true), |
207 memory_required_bytes_(0), | 208 memory_required_bytes_(0), |
208 memory_nice_to_have_bytes_(0), | 209 memory_nice_to_have_bytes_(0), |
209 bytes_releasable_(0), | 210 bytes_releasable_(0), |
210 resources_releasable_(0), | 211 resources_releasable_(0), |
211 ever_exceeded_memory_budget_(false), | 212 ever_exceeded_memory_budget_(false), |
212 rendering_stats_instrumentation_(rendering_stats_instrumentation), | 213 rendering_stats_instrumentation_(rendering_stats_instrumentation), |
213 did_initialize_visible_tile_(false), | 214 did_initialize_visible_tile_(false), |
214 did_check_for_completed_tasks_since_last_schedule_tasks_(true) { | 215 did_check_for_completed_tasks_since_last_schedule_tasks_(true) { |
215 raster_worker_pool_->SetClient(this); | 216 raster_worker_pool_->SetClient(this); |
| 217 tile_pool_.reserve(kTilePoolSize); |
216 } | 218 } |
217 | 219 |
218 TileManager::~TileManager() { | 220 TileManager::~TileManager() { |
219 // Reset global state and manage. This should cause | 221 // Reset global state and manage. This should cause |
220 // our memory usage to drop to zero. | 222 // our memory usage to drop to zero. |
221 global_state_ = GlobalStateThatImpactsTilePriority(); | 223 global_state_ = GlobalStateThatImpactsTilePriority(); |
222 | 224 |
223 CleanUpReleasedTiles(); | 225 CleanUpReleasedTiles(); |
224 DCHECK_EQ(0u, tiles_.size()); | 226 DCHECK_EQ(0u, tiles_.size()); |
225 | 227 |
| 228 for (size_t i = 0; i < tile_pool_.size(); ++i) |
| 229 delete tile_pool_[i]; |
| 230 tile_pool_.clear(); |
| 231 |
226 RasterWorkerPool::RasterTask::Queue empty; | 232 RasterWorkerPool::RasterTask::Queue empty; |
227 raster_worker_pool_->ScheduleTasks(&empty); | 233 raster_worker_pool_->ScheduleTasks(&empty); |
228 | 234 |
229 // This should finish all pending tasks and release any uninitialized | 235 // This should finish all pending tasks and release any uninitialized |
230 // resources. | 236 // resources. |
231 raster_worker_pool_->Shutdown(); | 237 raster_worker_pool_->Shutdown(); |
232 raster_worker_pool_->CheckForCompletedTasks(); | 238 raster_worker_pool_->CheckForCompletedTasks(); |
233 | 239 |
234 DCHECK_EQ(0u, bytes_releasable_); | 240 DCHECK_EQ(0u, bytes_releasable_); |
235 DCHECK_EQ(0u, resources_releasable_); | 241 DCHECK_EQ(0u, resources_releasable_); |
(...skipping 10 matching lines...) Expand all Loading... |
246 | 252 |
247 bool TileManager::ShouldForceTasksRequiredForActivationToComplete() const { | 253 bool TileManager::ShouldForceTasksRequiredForActivationToComplete() const { |
248 return global_state_.tree_priority != SMOOTHNESS_TAKES_PRIORITY; | 254 return global_state_.tree_priority != SMOOTHNESS_TAKES_PRIORITY; |
249 } | 255 } |
250 | 256 |
251 void TileManager::CleanUpReleasedTiles() { | 257 void TileManager::CleanUpReleasedTiles() { |
252 for (std::vector<Tile*>::iterator it = released_tiles_.begin(); | 258 for (std::vector<Tile*>::iterator it = released_tiles_.begin(); |
253 it != released_tiles_.end(); | 259 it != released_tiles_.end(); |
254 ++it) { | 260 ++it) { |
255 Tile* tile = *it; | 261 Tile* tile = *it; |
| 262 ManagedTileState& mts = tile->managed_state(); |
256 | 263 |
257 FreeResourcesForTile(tile); | 264 for (int mode = 0; mode < NUM_RASTER_MODES; ++mode) { |
| 265 FreeResourceForTile(tile, static_cast<RasterMode>(mode)); |
| 266 mts.tile_versions[mode].set_use_resource(); |
| 267 mts.tile_versions[mode].raster_task_.Reset(); |
| 268 } |
| 269 tile->reset_picture_pile(); |
258 | 270 |
259 DCHECK(tiles_.find(tile->id()) != tiles_.end()); | 271 DCHECK(tiles_.find(tile->id()) != tiles_.end()); |
260 tiles_.erase(tile->id()); | 272 tiles_.erase(tile->id()); |
261 | 273 |
262 LayerCountMap::iterator layer_it = | 274 LayerCountMap::iterator layer_it = |
263 used_layer_counts_.find(tile->layer_id()); | 275 used_layer_counts_.find(tile->layer_id()); |
264 DCHECK_GT(layer_it->second, 0); | 276 DCHECK_GT(layer_it->second, 0); |
265 if (--layer_it->second == 0) { | 277 if (--layer_it->second == 0) { |
266 used_layer_counts_.erase(layer_it); | 278 used_layer_counts_.erase(layer_it); |
267 image_decode_tasks_.erase(tile->layer_id()); | 279 image_decode_tasks_.erase(tile->layer_id()); |
268 } | 280 } |
269 | 281 |
270 delete tile; | 282 if (tile_pool_.size() < kTilePoolSize) |
| 283 tile_pool_.push_back(tile); |
| 284 else |
| 285 delete tile; |
271 } | 286 } |
272 | 287 |
273 released_tiles_.clear(); | 288 released_tiles_.clear(); |
274 } | 289 } |
275 | 290 |
276 void TileManager::UpdatePrioritizedTileSetIfNeeded() { | 291 void TileManager::UpdatePrioritizedTileSetIfNeeded() { |
277 if (!prioritized_tiles_dirty_) | 292 if (!prioritized_tiles_dirty_) |
278 return; | 293 return; |
279 | 294 |
280 CleanUpReleasedTiles(); | 295 CleanUpReleasedTiles(); |
(...skipping 528 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
809 base::Unretained(this), | 824 base::Unretained(this), |
810 tile->layer_id(), | 825 tile->layer_id(), |
811 base::Unretained(pixel_ref))); | 826 base::Unretained(pixel_ref))); |
812 } | 827 } |
813 | 828 |
814 RasterWorkerPool::RasterTask TileManager::CreateRasterTask(Tile* tile) { | 829 RasterWorkerPool::RasterTask TileManager::CreateRasterTask(Tile* tile) { |
815 ManagedTileState& mts = tile->managed_state(); | 830 ManagedTileState& mts = tile->managed_state(); |
816 | 831 |
817 scoped_ptr<ResourcePool::Resource> resource = | 832 scoped_ptr<ResourcePool::Resource> resource = |
818 resource_pool_->AcquireResource( | 833 resource_pool_->AcquireResource( |
819 tile->tile_size_.size(), | 834 tile->tile_size_, |
820 raster_worker_pool_->GetResourceFormat()); | 835 raster_worker_pool_->GetResourceFormat()); |
821 const Resource* const_resource = resource.get(); | 836 const Resource* const_resource = resource.get(); |
822 | 837 |
823 // Create and queue all image decode tasks that this tile depends on. | 838 // Create and queue all image decode tasks that this tile depends on. |
824 RasterWorkerPool::Task::Set decode_tasks; | 839 RasterWorkerPool::Task::Set decode_tasks; |
825 PixelRefTaskMap& existing_pixel_refs = image_decode_tasks_[tile->layer_id()]; | 840 PixelRefTaskMap& existing_pixel_refs = image_decode_tasks_[tile->layer_id()]; |
826 for (PicturePileImpl::PixelRefIterator iter(tile->content_rect(), | 841 for (PicturePileImpl::PixelRefIterator iter(tile->content_rect(), |
827 tile->contents_scale(), | 842 tile->contents_scale(), |
828 tile->picture_pile()); | 843 tile->picture_pile()); |
829 iter; ++iter) { | 844 iter; ++iter) { |
(...skipping 102 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
932 } | 947 } |
933 | 948 |
934 scoped_refptr<Tile> TileManager::CreateTile(PicturePileImpl* picture_pile, | 949 scoped_refptr<Tile> TileManager::CreateTile(PicturePileImpl* picture_pile, |
935 gfx::Size tile_size, | 950 gfx::Size tile_size, |
936 gfx::Rect content_rect, | 951 gfx::Rect content_rect, |
937 gfx::Rect opaque_rect, | 952 gfx::Rect opaque_rect, |
938 float contents_scale, | 953 float contents_scale, |
939 int layer_id, | 954 int layer_id, |
940 int source_frame_number, | 955 int source_frame_number, |
941 bool can_use_lcd_text) { | 956 bool can_use_lcd_text) { |
942 scoped_refptr<Tile> tile = make_scoped_refptr(new Tile(this, | 957 scoped_refptr<Tile> tile; |
943 picture_pile, | 958 if (!tile_pool_.empty()) { |
944 tile_size, | 959 tile = make_scoped_refptr(tile_pool_.back()); |
945 content_rect, | 960 tile_pool_.pop_back(); |
946 opaque_rect, | 961 } else { |
947 contents_scale, | 962 tile = make_scoped_refptr(new Tile(this)); |
948 layer_id, | 963 } |
949 source_frame_number, | 964 |
950 can_use_lcd_text)); | 965 tile->Reset(picture_pile, |
| 966 tile_size, |
| 967 content_rect, |
| 968 opaque_rect, |
| 969 contents_scale, |
| 970 layer_id, |
| 971 source_frame_number, |
| 972 can_use_lcd_text); |
| 973 |
951 DCHECK(tiles_.find(tile->id()) == tiles_.end()); | 974 DCHECK(tiles_.find(tile->id()) == tiles_.end()); |
952 | 975 |
953 tiles_[tile->id()] = tile; | 976 tiles_[tile->id()] = tile; |
954 used_layer_counts_[tile->layer_id()]++; | 977 used_layer_counts_[tile->layer_id()]++; |
955 prioritized_tiles_dirty_ = true; | 978 prioritized_tiles_dirty_ = true; |
956 return tile; | 979 return tile; |
957 } | 980 } |
958 | 981 |
959 } // namespace cc | 982 } // namespace cc |
OLD | NEW |