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 371 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
382 base::Bind(&TileManager::CheckIfReadyToActivate, | 382 base::Bind(&TileManager::CheckIfReadyToActivate, |
383 base::Unretained(this))) { | 383 base::Unretained(this))) { |
384 rasterizer_->SetClient(this); | 384 rasterizer_->SetClient(this); |
385 } | 385 } |
386 | 386 |
387 TileManager::~TileManager() { | 387 TileManager::~TileManager() { |
388 // Reset global state and manage. This should cause | 388 // Reset global state and manage. This should cause |
389 // our memory usage to drop to zero. | 389 // our memory usage to drop to zero. |
390 global_state_ = GlobalStateThatImpactsTilePriority(); | 390 global_state_ = GlobalStateThatImpactsTilePriority(); |
391 | 391 |
392 CleanUpReleasedTiles(); | 392 CleanUpReleasedTiles(); |
reveman
2014/07/03 18:12:46
I think you need to move this below CheckForComple
sohanjg
2014/07/04 11:56:58
Done.
| |
393 DCHECK_EQ(0u, tiles_.size()); | 393 DCHECK_EQ(0u, tiles_.size()); |
394 | 394 |
395 RasterTaskQueue empty; | 395 RasterTaskQueue empty; |
396 rasterizer_->ScheduleTasks(&empty); | 396 rasterizer_->ScheduleTasks(&empty); |
397 orphan_raster_tasks_.clear(); | |
398 | 397 |
399 // This should finish all pending tasks and release any uninitialized | 398 // This should finish all pending tasks and release any uninitialized |
400 // resources. | 399 // resources. |
401 rasterizer_->Shutdown(); | 400 rasterizer_->Shutdown(); |
402 rasterizer_->CheckForCompletedTasks(); | 401 rasterizer_->CheckForCompletedTasks(); |
403 | 402 |
404 DCHECK_EQ(0u, bytes_releasable_); | 403 DCHECK_EQ(0u, bytes_releasable_); |
405 DCHECK_EQ(0u, resources_releasable_); | 404 DCHECK_EQ(0u, resources_releasable_); |
406 } | 405 } |
407 | 406 |
408 void TileManager::Release(Tile* tile) { | 407 void TileManager::Release(Tile* tile) { |
409 prioritized_tiles_dirty_ = true; | 408 prioritized_tiles_dirty_ = true; |
410 released_tiles_.push_back(tile); | 409 released_tiles_.push_back(tile); |
411 } | 410 } |
412 | 411 |
413 void TileManager::DidChangeTilePriority(Tile* tile) { | 412 void TileManager::DidChangeTilePriority(Tile* tile) { |
414 prioritized_tiles_dirty_ = true; | 413 prioritized_tiles_dirty_ = true; |
415 } | 414 } |
416 | 415 |
417 bool TileManager::ShouldForceTasksRequiredForActivationToComplete() const { | 416 bool TileManager::ShouldForceTasksRequiredForActivationToComplete() const { |
418 return global_state_.tree_priority != SMOOTHNESS_TAKES_PRIORITY; | 417 return global_state_.tree_priority != SMOOTHNESS_TAKES_PRIORITY; |
419 } | 418 } |
420 | 419 |
421 void TileManager::CleanUpReleasedTiles() { | 420 void TileManager::CleanUpReleasedTiles() { |
422 for (std::vector<Tile*>::iterator it = released_tiles_.begin(); | 421 for (std::vector<Tile*>::iterator it = released_tiles_.begin(); |
423 it != released_tiles_.end(); | 422 it != released_tiles_.end();) { |
reveman
2014/07/03 18:12:47
nit: I prefer if you use a while loop when iterati
sohanjg
2014/07/04 11:56:58
Done.
| |
424 ++it) { | |
425 Tile* tile = *it; | 423 Tile* tile = *it; |
426 ManagedTileState& mts = tile->managed_state(); | 424 ManagedTileState& mts = tile->managed_state(); |
425 bool tile_has_raster_task = false; | |
427 | 426 |
428 for (int mode = 0; mode < NUM_RASTER_MODES; ++mode) { | 427 for (int mode = 0; mode < NUM_RASTER_MODES; ++mode) { |
429 FreeResourceForTile(tile, static_cast<RasterMode>(mode)); | 428 if (!mts.tile_versions[mode].raster_task_) |
430 orphan_raster_tasks_.push_back(mts.tile_versions[mode].raster_task_); | 429 FreeResourceForTile(tile, static_cast<RasterMode>(mode)); |
reveman
2014/07/03 18:12:47
I think it's a bit confusing that this code could
sohanjg
2014/07/04 11:56:58
Done.
vmpstr
2014/07/05 17:42:19
I actually think we should always release all reso
reveman
2014/07/07 18:15:16
Fine with me if actually worthwhile. Would we not
sohanjg
2014/07/08 06:21:15
Done.
| |
430 else | |
431 tile_has_raster_task = true; | |
431 } | 432 } |
432 | 433 |
434 if (tile_has_raster_task) { | |
435 ++it; | |
436 continue; | |
437 } | |
reveman
2014/07/03 18:12:47
nit: blank line here
sohanjg
2014/07/04 11:56:58
Done.
| |
433 DCHECK(tiles_.find(tile->id()) != tiles_.end()); | 438 DCHECK(tiles_.find(tile->id()) != tiles_.end()); |
434 tiles_.erase(tile->id()); | 439 tiles_.erase(tile->id()); |
435 | 440 |
436 LayerCountMap::iterator layer_it = | 441 LayerCountMap::iterator layer_it = |
437 used_layer_counts_.find(tile->layer_id()); | 442 used_layer_counts_.find(tile->layer_id()); |
438 DCHECK_GT(layer_it->second, 0); | 443 DCHECK_GT(layer_it->second, 0); |
439 if (--layer_it->second == 0) { | 444 if (--layer_it->second == 0) { |
440 used_layer_counts_.erase(layer_it); | 445 used_layer_counts_.erase(layer_it); |
441 image_decode_tasks_.erase(tile->layer_id()); | 446 image_decode_tasks_.erase(tile->layer_id()); |
442 } | 447 } |
443 | 448 |
449 it = released_tiles_.erase(it); | |
reveman
2014/07/03 18:12:47
nit: move this below "delete tile;" to maintain th
sohanjg
2014/07/04 11:56:58
Done.
| |
444 delete tile; | 450 delete tile; |
445 } | 451 } |
446 | |
447 released_tiles_.clear(); | |
448 } | 452 } |
449 | 453 |
450 void TileManager::UpdatePrioritizedTileSetIfNeeded() { | 454 void TileManager::UpdatePrioritizedTileSetIfNeeded() { |
451 if (!prioritized_tiles_dirty_) | 455 if (!prioritized_tiles_dirty_) |
452 return; | 456 return; |
453 | 457 |
454 CleanUpReleasedTiles(); | 458 CleanUpReleasedTiles(); |
reveman
2014/07/03 18:12:47
This is not the right place to call this anymore.
sohanjg
2014/07/04 11:56:58
Have moved it to ManageTiles, where it checks for
| |
455 | 459 |
456 prioritized_tiles_.Clear(); | 460 prioritized_tiles_.Clear(); |
457 GetTilesWithAssignedBins(&prioritized_tiles_); | 461 GetTilesWithAssignedBins(&prioritized_tiles_); |
458 prioritized_tiles_dirty_ = false; | 462 prioritized_tiles_dirty_ = false; |
459 } | 463 } |
460 | 464 |
461 void TileManager::DidFinishRunningTasks() { | 465 void TileManager::DidFinishRunningTasks() { |
462 TRACE_EVENT0("cc", "TileManager::DidFinishRunningTasks"); | 466 TRACE_EVENT0("cc", "TileManager::DidFinishRunningTasks"); |
463 | 467 |
464 bool memory_usage_above_limit = resource_pool_->total_memory_usage_bytes() > | 468 bool memory_usage_above_limit = resource_pool_->total_memory_usage_bytes() > |
(...skipping 498 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
963 | 967 |
964 // We must reduce the amount of unused resoruces before calling | 968 // We must reduce the amount of unused resoruces before calling |
965 // ScheduleTasks to prevent usage from rising above limits. | 969 // ScheduleTasks to prevent usage from rising above limits. |
966 resource_pool_->ReduceResourceUsage(); | 970 resource_pool_->ReduceResourceUsage(); |
967 | 971 |
968 // Schedule running of |raster_tasks_|. This replaces any previously | 972 // Schedule running of |raster_tasks_|. This replaces any previously |
969 // scheduled tasks and effectively cancels all tasks not present | 973 // scheduled tasks and effectively cancels all tasks not present |
970 // in |raster_tasks_|. | 974 // in |raster_tasks_|. |
971 rasterizer_->ScheduleTasks(&raster_queue_); | 975 rasterizer_->ScheduleTasks(&raster_queue_); |
972 | 976 |
973 // It's now safe to clean up orphan tasks as raster worker pool is not | |
974 // allowed to keep around unreferenced raster tasks after ScheduleTasks() has | |
975 // been called. | |
976 orphan_raster_tasks_.clear(); | |
977 | |
978 did_check_for_completed_tasks_since_last_schedule_tasks_ = false; | 977 did_check_for_completed_tasks_since_last_schedule_tasks_ = false; |
979 } | 978 } |
980 | 979 |
981 scoped_refptr<ImageDecodeTask> TileManager::CreateImageDecodeTask( | 980 scoped_refptr<ImageDecodeTask> TileManager::CreateImageDecodeTask( |
982 Tile* tile, | 981 Tile* tile, |
983 SkPixelRef* pixel_ref) { | 982 SkPixelRef* pixel_ref) { |
984 return make_scoped_refptr(new ImageDecodeTaskImpl( | 983 return make_scoped_refptr(new ImageDecodeTaskImpl( |
985 pixel_ref, | 984 pixel_ref, |
986 tile->layer_id(), | 985 tile->layer_id(), |
987 rendering_stats_instrumentation_, | 986 rendering_stats_instrumentation_, |
(...skipping 83 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
1071 TileMap::iterator it = tiles_.find(tile_id); | 1070 TileMap::iterator it = tiles_.find(tile_id); |
1072 if (it == tiles_.end()) { | 1071 if (it == tiles_.end()) { |
1073 ++update_visible_tiles_stats_.canceled_count; | 1072 ++update_visible_tiles_stats_.canceled_count; |
1074 resource_pool_->ReleaseResource(resource.Pass()); | 1073 resource_pool_->ReleaseResource(resource.Pass()); |
1075 return; | 1074 return; |
1076 } | 1075 } |
1077 | 1076 |
1078 Tile* tile = it->second; | 1077 Tile* tile = it->second; |
1079 ManagedTileState& mts = tile->managed_state(); | 1078 ManagedTileState& mts = tile->managed_state(); |
1080 ManagedTileState::TileVersion& tile_version = mts.tile_versions[raster_mode]; | 1079 ManagedTileState::TileVersion& tile_version = mts.tile_versions[raster_mode]; |
1081 DCHECK(tile_version.raster_task_); | |
1082 orphan_raster_tasks_.push_back(tile_version.raster_task_); | |
1083 tile_version.raster_task_ = NULL; | 1080 tile_version.raster_task_ = NULL; |
1084 | 1081 |
1085 if (was_canceled) { | 1082 if (was_canceled) { |
1086 ++update_visible_tiles_stats_.canceled_count; | 1083 ++update_visible_tiles_stats_.canceled_count; |
1087 resource_pool_->ReleaseResource(resource.Pass()); | 1084 resource_pool_->ReleaseResource(resource.Pass()); |
1088 return; | 1085 return; |
1089 } | 1086 } |
1090 | 1087 |
1091 ++update_visible_tiles_stats_.completed_count; | 1088 ++update_visible_tiles_stats_.completed_count; |
1092 | 1089 |
(...skipping 483 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
1576 TRACE_EVENT0("cc", "TileManager::CheckIfReadyToActivate"); | 1573 TRACE_EVENT0("cc", "TileManager::CheckIfReadyToActivate"); |
1577 | 1574 |
1578 rasterizer_->CheckForCompletedTasks(); | 1575 rasterizer_->CheckForCompletedTasks(); |
1579 did_check_for_completed_tasks_since_last_schedule_tasks_ = true; | 1576 did_check_for_completed_tasks_since_last_schedule_tasks_ = true; |
1580 | 1577 |
1581 if (IsReadyToActivate()) | 1578 if (IsReadyToActivate()) |
1582 client_->NotifyReadyToActivate(); | 1579 client_->NotifyReadyToActivate(); |
1583 } | 1580 } |
1584 | 1581 |
1585 } // namespace cc | 1582 } // namespace cc |
OLD | NEW |