Chromium Code Reviews| 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(); | |
| 393 DCHECK_EQ(0u, tiles_.size()); | |
|
reveman
2014/07/11 17:06:36
why remove this DCHECK? this is very useful. pleas
sohanjg
2014/07/12 11:41:59
Done.
| |
| 394 | |
| 395 RasterTaskQueue empty; | 392 RasterTaskQueue empty; |
| 396 rasterizer_->ScheduleTasks(&empty); | 393 rasterizer_->ScheduleTasks(&empty); |
| 397 orphan_raster_tasks_.clear(); | |
| 398 | 394 |
| 399 // This should finish all pending tasks and release any uninitialized | 395 // This should finish all pending tasks and release any uninitialized |
| 400 // resources. | 396 // resources. |
| 401 rasterizer_->Shutdown(); | 397 rasterizer_->Shutdown(); |
| 402 rasterizer_->CheckForCompletedTasks(); | 398 rasterizer_->CheckForCompletedTasks(); |
| 403 | 399 |
| 400 FreeResourcesForReleasedTiles(); | |
| 401 CleanUpReleasedTiles(); | |
| 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::FreeResourcesForReleasedTiles() { |
| 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(); |
| 424 ++it) { | 423 ++it) { |
| 425 Tile* tile = *it; | 424 Tile* tile = *it; |
| 426 ManagedTileState& mts = tile->managed_state(); | 425 for (int mode = 0; mode < NUM_RASTER_MODES; ++mode) |
| 426 FreeResourceForTile(tile, static_cast<RasterMode>(mode)); | |
| 427 } | |
| 428 } | |
| 427 | 429 |
| 430 bool TileManager::TileHasRasterTask(Tile* tile) { | |
| 431 DCHECK(tile); | |
|
reveman
2014/07/11 17:06:36
I don't think this DCHECK is useful. please remove
sohanjg
2014/07/12 11:41:59
Done.
| |
| 432 ManagedTileState& mts = tile->managed_state(); | |
| 433 bool tile_has_raster_task = false; | |
|
reveman
2014/07/11 17:06:36
you don't need this variable
sohanjg
2014/07/12 11:41:58
Done.
| |
| 428 for (int mode = 0; mode < NUM_RASTER_MODES; ++mode) { | 434 for (int mode = 0; mode < NUM_RASTER_MODES; ++mode) { |
| 429 FreeResourceForTile(tile, static_cast<RasterMode>(mode)); | 435 if (mts.tile_versions[mode].raster_task_) |
| 430 orphan_raster_tasks_.push_back(mts.tile_versions[mode].raster_task_); | 436 tile_has_raster_task = true; |
|
reveman
2014/07/11 17:06:36
no need to iterate through all modes. just "return
sohanjg
2014/07/12 11:41:58
Done.
| |
| 437 } | |
| 438 return tile_has_raster_task; | |
|
reveman
2014/07/11 17:06:36
and just "return false" here.
sohanjg
2014/07/12 11:41:59
Done.
| |
| 439 } | |
| 440 | |
| 441 void TileManager::CleanUpReleasedTiles() { | |
| 442 std::vector<Tile*>::iterator it = released_tiles_.begin(); | |
| 443 while (it != released_tiles_.end()) { | |
| 444 Tile* tile = *it; | |
| 445 if (TileHasRasterTask(tile)) { | |
|
reveman
2014/07/11 17:06:36
nit: I'd add a blank line before "if (TileHasR.."
sohanjg
2014/07/12 11:41:59
Done.
| |
| 446 ++it; | |
| 447 continue; | |
| 431 } | 448 } |
| 432 | 449 |
| 433 DCHECK(tiles_.find(tile->id()) != tiles_.end()); | 450 DCHECK(tiles_.find(tile->id()) != tiles_.end()); |
| 434 tiles_.erase(tile->id()); | 451 tiles_.erase(tile->id()); |
| 435 | 452 |
| 436 LayerCountMap::iterator layer_it = | 453 LayerCountMap::iterator layer_it = |
| 437 used_layer_counts_.find(tile->layer_id()); | 454 used_layer_counts_.find(tile->layer_id()); |
| 438 DCHECK_GT(layer_it->second, 0); | 455 DCHECK_GT(layer_it->second, 0); |
| 439 if (--layer_it->second == 0) { | 456 if (--layer_it->second == 0) { |
| 440 used_layer_counts_.erase(layer_it); | 457 used_layer_counts_.erase(layer_it); |
| 441 image_decode_tasks_.erase(tile->layer_id()); | 458 image_decode_tasks_.erase(tile->layer_id()); |
| 442 } | 459 } |
| 443 | 460 |
| 444 delete tile; | 461 delete tile; |
|
reveman
2014/07/11 17:06:36
please add a DCHECK(!tile->HasResources()) here so
sohanjg
2014/07/12 11:41:58
Done.
| |
| 462 it = released_tiles_.erase(it); | |
| 445 } | 463 } |
| 446 | |
| 447 released_tiles_.clear(); | |
| 448 } | 464 } |
| 449 | 465 |
| 450 void TileManager::UpdatePrioritizedTileSetIfNeeded() { | 466 void TileManager::UpdatePrioritizedTileSetIfNeeded() { |
| 451 if (!prioritized_tiles_dirty_) | 467 if (!prioritized_tiles_dirty_) |
| 452 return; | 468 return; |
| 453 | 469 |
| 470 FreeResourcesForReleasedTiles(); | |
| 454 CleanUpReleasedTiles(); | 471 CleanUpReleasedTiles(); |
| 455 | 472 |
| 456 prioritized_tiles_.Clear(); | 473 prioritized_tiles_.Clear(); |
| 457 GetTilesWithAssignedBins(&prioritized_tiles_); | 474 GetTilesWithAssignedBins(&prioritized_tiles_); |
| 458 prioritized_tiles_dirty_ = false; | 475 prioritized_tiles_dirty_ = false; |
| 459 } | 476 } |
| 460 | 477 |
| 461 void TileManager::DidFinishRunningTasks() { | 478 void TileManager::DidFinishRunningTasks() { |
| 462 TRACE_EVENT0("cc", "TileManager::DidFinishRunningTasks"); | 479 TRACE_EVENT0("cc", "TileManager::DidFinishRunningTasks"); |
| 463 | 480 |
| (...skipping 499 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 963 | 980 |
| 964 // We must reduce the amount of unused resoruces before calling | 981 // We must reduce the amount of unused resoruces before calling |
| 965 // ScheduleTasks to prevent usage from rising above limits. | 982 // ScheduleTasks to prevent usage from rising above limits. |
| 966 resource_pool_->ReduceResourceUsage(); | 983 resource_pool_->ReduceResourceUsage(); |
| 967 | 984 |
| 968 // Schedule running of |raster_tasks_|. This replaces any previously | 985 // Schedule running of |raster_tasks_|. This replaces any previously |
| 969 // scheduled tasks and effectively cancels all tasks not present | 986 // scheduled tasks and effectively cancels all tasks not present |
| 970 // in |raster_tasks_|. | 987 // in |raster_tasks_|. |
| 971 rasterizer_->ScheduleTasks(&raster_queue_); | 988 rasterizer_->ScheduleTasks(&raster_queue_); |
| 972 | 989 |
| 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; | 990 did_check_for_completed_tasks_since_last_schedule_tasks_ = false; |
| 979 } | 991 } |
| 980 | 992 |
| 981 scoped_refptr<ImageDecodeTask> TileManager::CreateImageDecodeTask( | 993 scoped_refptr<ImageDecodeTask> TileManager::CreateImageDecodeTask( |
| 982 Tile* tile, | 994 Tile* tile, |
| 983 SkPixelRef* pixel_ref) { | 995 SkPixelRef* pixel_ref) { |
| 984 return make_scoped_refptr(new ImageDecodeTaskImpl( | 996 return make_scoped_refptr(new ImageDecodeTaskImpl( |
| 985 pixel_ref, | 997 pixel_ref, |
| 986 tile->layer_id(), | 998 tile->layer_id(), |
| 987 rendering_stats_instrumentation_, | 999 rendering_stats_instrumentation_, |
| (...skipping 74 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1062 pixel_ref_tasks.erase(task_it); | 1074 pixel_ref_tasks.erase(task_it); |
| 1063 } | 1075 } |
| 1064 | 1076 |
| 1065 void TileManager::OnRasterTaskCompleted( | 1077 void TileManager::OnRasterTaskCompleted( |
| 1066 Tile::Id tile_id, | 1078 Tile::Id tile_id, |
| 1067 scoped_ptr<ScopedResource> resource, | 1079 scoped_ptr<ScopedResource> resource, |
| 1068 RasterMode raster_mode, | 1080 RasterMode raster_mode, |
| 1069 const PicturePileImpl::Analysis& analysis, | 1081 const PicturePileImpl::Analysis& analysis, |
| 1070 bool was_canceled) { | 1082 bool was_canceled) { |
| 1071 TileMap::iterator it = tiles_.find(tile_id); | 1083 TileMap::iterator it = tiles_.find(tile_id); |
| 1072 if (it == tiles_.end()) { | 1084 DCHECK(it != tiles_.end()); |
| 1073 ++update_visible_tiles_stats_.canceled_count; | |
| 1074 resource_pool_->ReleaseResource(resource.Pass()); | |
| 1075 return; | |
| 1076 } | |
| 1077 | 1085 |
| 1078 Tile* tile = it->second; | 1086 Tile* tile = it->second; |
| 1079 ManagedTileState& mts = tile->managed_state(); | 1087 ManagedTileState& mts = tile->managed_state(); |
| 1080 ManagedTileState::TileVersion& tile_version = mts.tile_versions[raster_mode]; | 1088 ManagedTileState::TileVersion& tile_version = mts.tile_versions[raster_mode]; |
| 1081 DCHECK(tile_version.raster_task_); | 1089 DCHECK(tile_version.raster_task_); |
| 1082 orphan_raster_tasks_.push_back(tile_version.raster_task_); | |
| 1083 tile_version.raster_task_ = NULL; | 1090 tile_version.raster_task_ = NULL; |
| 1084 | 1091 |
| 1085 if (was_canceled) { | 1092 if (was_canceled) { |
| 1086 ++update_visible_tiles_stats_.canceled_count; | 1093 ++update_visible_tiles_stats_.canceled_count; |
| 1087 resource_pool_->ReleaseResource(resource.Pass()); | 1094 resource_pool_->ReleaseResource(resource.Pass()); |
| 1088 return; | 1095 return; |
| 1089 } | 1096 } |
| 1090 | 1097 |
| 1091 ++update_visible_tiles_stats_.completed_count; | 1098 ++update_visible_tiles_stats_.completed_count; |
| 1092 | 1099 |
| (...skipping 483 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1576 TRACE_EVENT0("cc", "TileManager::CheckIfReadyToActivate"); | 1583 TRACE_EVENT0("cc", "TileManager::CheckIfReadyToActivate"); |
| 1577 | 1584 |
| 1578 rasterizer_->CheckForCompletedTasks(); | 1585 rasterizer_->CheckForCompletedTasks(); |
| 1579 did_check_for_completed_tasks_since_last_schedule_tasks_ = true; | 1586 did_check_for_completed_tasks_since_last_schedule_tasks_ = true; |
| 1580 | 1587 |
| 1581 if (IsReadyToActivate()) | 1588 if (IsReadyToActivate()) |
| 1582 client_->NotifyReadyToActivate(); | 1589 client_->NotifyReadyToActivate(); |
| 1583 } | 1590 } |
| 1584 | 1591 |
| 1585 } // namespace cc | 1592 } // namespace cc |
| OLD | NEW |