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()); | |
| 394 | |
| 395 RasterTaskQueue empty; | 392 RasterTaskQueue empty; |
| 396 rasterizer_->ScheduleTasks(&empty); | 393 rasterizer_->ScheduleTasks(&empty); |
| 397 orphan_raster_tasks_.clear(); | 394 orphan_raster_tasks_.clear(); |
| 398 | 395 |
| 399 // This should finish all pending tasks and release any uninitialized | 396 // This should finish all pending tasks and release any uninitialized |
| 400 // resources. | 397 // resources. |
| 401 rasterizer_->Shutdown(); | 398 rasterizer_->Shutdown(); |
| 402 rasterizer_->CheckForCompletedTasks(); | 399 rasterizer_->CheckForCompletedTasks(); |
| 403 | 400 |
| 401 FreeResourcesForReleasedTiles(); | |
| 402 CleanUpReleasedTiles(); | |
| 403 | |
| 404 DCHECK_EQ(0u, tiles_.size()); | |
| 404 DCHECK_EQ(0u, bytes_releasable_); | 405 DCHECK_EQ(0u, bytes_releasable_); |
| 405 DCHECK_EQ(0u, resources_releasable_); | 406 DCHECK_EQ(0u, resources_releasable_); |
| 406 } | 407 } |
| 407 | 408 |
| 408 void TileManager::Release(Tile* tile) { | 409 void TileManager::Release(Tile* tile) { |
| 410 // Reset priority as tile is ref-counted and might still be used | |
| 411 // even though we no longer hold a reference to it here anymore. | |
|
vmpstr
2014/07/23 16:10:37
This comment was meant to be for the picture layer
reveman
2014/07/23 16:26:54
Yea, this doesn't make sense here.
sohanjg
2014/07/24 11:08:41
Done.
| |
| 412 tile->SetPriority(ACTIVE_TREE, TilePriority()); | |
| 413 tile->SetPriority(PENDING_TREE, TilePriority()); | |
|
reveman
2014/07/23 16:26:54
Please try to reset these when dropping the ref fr
sohanjg
2014/07/24 11:08:41
Done.
| |
| 414 | |
| 409 prioritized_tiles_dirty_ = true; | 415 prioritized_tiles_dirty_ = true; |
| 410 released_tiles_.push_back(tile); | 416 released_tiles_.push_back(tile); |
| 411 } | 417 } |
| 412 | 418 |
| 413 void TileManager::DidChangeTilePriority(Tile* tile) { | 419 void TileManager::DidChangeTilePriority(Tile* tile) { |
| 414 prioritized_tiles_dirty_ = true; | 420 prioritized_tiles_dirty_ = true; |
| 415 } | 421 } |
| 416 | 422 |
| 417 bool TileManager::ShouldForceTasksRequiredForActivationToComplete() const { | 423 bool TileManager::ShouldForceTasksRequiredForActivationToComplete() const { |
| 418 return global_state_.tree_priority != SMOOTHNESS_TAKES_PRIORITY; | 424 return global_state_.tree_priority != SMOOTHNESS_TAKES_PRIORITY; |
| 419 } | 425 } |
| 420 | 426 |
| 421 void TileManager::CleanUpReleasedTiles() { | 427 void TileManager::FreeResourcesForReleasedTiles() { |
| 422 for (std::vector<Tile*>::iterator it = released_tiles_.begin(); | 428 for (std::vector<Tile*>::iterator it = released_tiles_.begin(); |
| 423 it != released_tiles_.end(); | 429 it != released_tiles_.end(); |
| 424 ++it) { | 430 ++it) { |
| 425 Tile* tile = *it; | 431 Tile* tile = *it; |
| 426 ManagedTileState& mts = tile->managed_state(); | 432 FreeResourcesForTile(tile); |
| 433 } | |
| 434 } | |
| 427 | 435 |
| 428 for (int mode = 0; mode < NUM_RASTER_MODES; ++mode) { | 436 // TODO(sohanjg): Move it to UpdatePrioritizedTileSetIfNeeded to ensure |
| 429 FreeResourceForTile(tile, static_cast<RasterMode>(mode)); | 437 // the prioritized set is rebuild. |
| 430 orphan_raster_tasks_.push_back(mts.tile_versions[mode].raster_task_); | 438 void TileManager::CleanUpReleasedTiles() { |
| 439 std::vector<Tile*>::iterator it = released_tiles_.begin(); | |
| 440 while (it != released_tiles_.end()) { | |
| 441 Tile* tile = *it; | |
| 442 | |
| 443 if (tile->HasRasterTask()) { | |
| 444 ++it; | |
| 445 continue; | |
| 431 } | 446 } |
| 432 | 447 |
| 448 DCHECK(!tile->HasResources()); | |
| 433 DCHECK(tiles_.find(tile->id()) != tiles_.end()); | 449 DCHECK(tiles_.find(tile->id()) != tiles_.end()); |
| 434 tiles_.erase(tile->id()); | 450 tiles_.erase(tile->id()); |
| 435 | 451 |
| 436 LayerCountMap::iterator layer_it = | 452 LayerCountMap::iterator layer_it = |
| 437 used_layer_counts_.find(tile->layer_id()); | 453 used_layer_counts_.find(tile->layer_id()); |
| 438 DCHECK_GT(layer_it->second, 0); | 454 DCHECK_GT(layer_it->second, 0); |
| 439 if (--layer_it->second == 0) { | 455 if (--layer_it->second == 0) { |
| 440 used_layer_counts_.erase(layer_it); | 456 used_layer_counts_.erase(layer_it); |
| 441 image_decode_tasks_.erase(tile->layer_id()); | 457 image_decode_tasks_.erase(tile->layer_id()); |
| 442 } | 458 } |
| 443 | 459 |
| 444 delete tile; | 460 delete tile; |
| 461 it = released_tiles_.erase(it); | |
| 445 } | 462 } |
| 446 | |
| 447 released_tiles_.clear(); | |
| 448 } | 463 } |
| 449 | 464 |
| 450 void TileManager::UpdatePrioritizedTileSetIfNeeded() { | 465 void TileManager::UpdatePrioritizedTileSetIfNeeded() { |
| 451 if (!prioritized_tiles_dirty_) | 466 if (!prioritized_tiles_dirty_) |
| 452 return; | 467 return; |
| 453 | 468 |
| 469 FreeResourcesForReleasedTiles(); | |
| 454 CleanUpReleasedTiles(); | 470 CleanUpReleasedTiles(); |
| 455 | 471 |
| 456 prioritized_tiles_.Clear(); | 472 prioritized_tiles_.Clear(); |
| 457 GetTilesWithAssignedBins(&prioritized_tiles_); | 473 GetTilesWithAssignedBins(&prioritized_tiles_); |
| 458 prioritized_tiles_dirty_ = false; | 474 prioritized_tiles_dirty_ = false; |
| 459 } | 475 } |
| 460 | 476 |
| 461 void TileManager::DidFinishRunningTasks() { | 477 void TileManager::DidFinishRunningTasks() { |
| 462 TRACE_EVENT0("cc", "TileManager::DidFinishRunningTasks"); | 478 TRACE_EVENT0("cc", "TileManager::DidFinishRunningTasks"); |
| 463 | 479 |
| (...skipping 13 matching lines...) Expand all Loading... | |
| 477 AssignGpuMemoryToTiles(&prioritized_tiles_, | 493 AssignGpuMemoryToTiles(&prioritized_tiles_, |
| 478 &tiles_that_need_to_be_rasterized); | 494 &tiles_that_need_to_be_rasterized); |
| 479 | 495 |
| 480 // |tiles_that_need_to_be_rasterized| will be empty when we reach a | 496 // |tiles_that_need_to_be_rasterized| will be empty when we reach a |
| 481 // steady memory state. Keep scheduling tasks until we reach this state. | 497 // steady memory state. Keep scheduling tasks until we reach this state. |
| 482 if (!tiles_that_need_to_be_rasterized.empty()) { | 498 if (!tiles_that_need_to_be_rasterized.empty()) { |
| 483 ScheduleTasks(tiles_that_need_to_be_rasterized); | 499 ScheduleTasks(tiles_that_need_to_be_rasterized); |
| 484 return; | 500 return; |
| 485 } | 501 } |
| 486 | 502 |
| 503 FreeResourcesForReleasedTiles(); | |
| 504 | |
| 487 resource_pool_->ReduceResourceUsage(); | 505 resource_pool_->ReduceResourceUsage(); |
| 488 | 506 |
| 489 // We don't reserve memory for required-for-activation tiles during | 507 // We don't reserve memory for required-for-activation tiles during |
| 490 // accelerated gestures, so we just postpone activation when we don't | 508 // accelerated gestures, so we just postpone activation when we don't |
| 491 // have these tiles, and activate after the accelerated gesture. | 509 // have these tiles, and activate after the accelerated gesture. |
| 492 bool allow_rasterize_on_demand = | 510 bool allow_rasterize_on_demand = |
| 493 global_state_.tree_priority != SMOOTHNESS_TAKES_PRIORITY; | 511 global_state_.tree_priority != SMOOTHNESS_TAKES_PRIORITY; |
| 494 | 512 |
| 495 // Use on-demand raster for any required-for-activation tiles that have not | 513 // Use on-demand raster for any required-for-activation tiles that have not |
| 496 // been been assigned memory after reaching a steady memory state. This | 514 // been been assigned memory after reaching a steady memory state. This |
| (...skipping 567 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1064 if (task_it != pixel_ref_tasks.end()) | 1082 if (task_it != pixel_ref_tasks.end()) |
| 1065 pixel_ref_tasks.erase(task_it); | 1083 pixel_ref_tasks.erase(task_it); |
| 1066 } | 1084 } |
| 1067 | 1085 |
| 1068 void TileManager::OnRasterTaskCompleted( | 1086 void TileManager::OnRasterTaskCompleted( |
| 1069 Tile::Id tile_id, | 1087 Tile::Id tile_id, |
| 1070 scoped_ptr<ScopedResource> resource, | 1088 scoped_ptr<ScopedResource> resource, |
| 1071 RasterMode raster_mode, | 1089 RasterMode raster_mode, |
| 1072 const PicturePileImpl::Analysis& analysis, | 1090 const PicturePileImpl::Analysis& analysis, |
| 1073 bool was_canceled) { | 1091 bool was_canceled) { |
| 1074 TileMap::iterator it = tiles_.find(tile_id); | 1092 DCHECK(tiles_.find(tile_id) != tiles_.end()); |
| 1075 if (it == tiles_.end()) { | |
| 1076 ++update_visible_tiles_stats_.canceled_count; | |
| 1077 resource_pool_->ReleaseResource(resource.Pass()); | |
| 1078 return; | |
| 1079 } | |
| 1080 | 1093 |
| 1081 Tile* tile = it->second; | 1094 Tile* tile = tiles_[tile_id]; |
| 1082 ManagedTileState& mts = tile->managed_state(); | 1095 ManagedTileState& mts = tile->managed_state(); |
| 1083 ManagedTileState::TileVersion& tile_version = mts.tile_versions[raster_mode]; | 1096 ManagedTileState::TileVersion& tile_version = mts.tile_versions[raster_mode]; |
| 1084 DCHECK(tile_version.raster_task_); | 1097 DCHECK(tile_version.raster_task_); |
| 1085 orphan_raster_tasks_.push_back(tile_version.raster_task_); | 1098 orphan_raster_tasks_.push_back(tile_version.raster_task_); |
| 1086 tile_version.raster_task_ = NULL; | 1099 tile_version.raster_task_ = NULL; |
| 1087 | 1100 |
| 1088 if (was_canceled) { | 1101 if (was_canceled) { |
| 1089 ++update_visible_tiles_stats_.canceled_count; | 1102 ++update_visible_tiles_stats_.canceled_count; |
| 1090 resource_pool_->ReleaseResource(resource.Pass()); | 1103 resource_pool_->ReleaseResource(resource.Pass()); |
| 1091 return; | 1104 return; |
| (...skipping 501 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1593 TRACE_EVENT0("cc", "TileManager::CheckIfReadyToActivate"); | 1606 TRACE_EVENT0("cc", "TileManager::CheckIfReadyToActivate"); |
| 1594 | 1607 |
| 1595 rasterizer_->CheckForCompletedTasks(); | 1608 rasterizer_->CheckForCompletedTasks(); |
| 1596 did_check_for_completed_tasks_since_last_schedule_tasks_ = true; | 1609 did_check_for_completed_tasks_since_last_schedule_tasks_ = true; |
| 1597 | 1610 |
| 1598 if (IsReadyToActivate()) | 1611 if (IsReadyToActivate()) |
| 1599 client_->NotifyReadyToActivate(); | 1612 client_->NotifyReadyToActivate(); |
| 1600 } | 1613 } |
| 1601 | 1614 |
| 1602 } // namespace cc | 1615 } // namespace cc |
| OLD | NEW |