| 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 #ifndef CC_TILES_TILE_MANAGER_H_ | 5 #ifndef CC_TILES_TILE_MANAGER_H_ |
| 6 #define CC_TILES_TILE_MANAGER_H_ | 6 #define CC_TILES_TILE_MANAGER_H_ |
| 7 | 7 |
| 8 #include <stddef.h> | 8 #include <stddef.h> |
| 9 #include <stdint.h> | 9 #include <stdint.h> |
| 10 | 10 |
| 11 #include <memory> |
| 11 #include <set> | 12 #include <set> |
| 12 #include <unordered_map> | 13 #include <unordered_map> |
| 13 #include <utility> | 14 #include <utility> |
| 14 #include <vector> | 15 #include <vector> |
| 15 | 16 |
| 16 #include "base/macros.h" | 17 #include "base/macros.h" |
| 17 #include "base/memory/scoped_ptr.h" | |
| 18 #include "base/values.h" | 18 #include "base/values.h" |
| 19 #include "cc/base/unique_notifier.h" | 19 #include "cc/base/unique_notifier.h" |
| 20 #include "cc/playback/raster_source.h" | 20 #include "cc/playback/raster_source.h" |
| 21 #include "cc/raster/tile_task_runner.h" | 21 #include "cc/raster/tile_task_runner.h" |
| 22 #include "cc/resources/memory_history.h" | 22 #include "cc/resources/memory_history.h" |
| 23 #include "cc/resources/resource_pool.h" | 23 #include "cc/resources/resource_pool.h" |
| 24 #include "cc/tiles/eviction_tile_priority_queue.h" | 24 #include "cc/tiles/eviction_tile_priority_queue.h" |
| 25 #include "cc/tiles/image_decode_controller.h" | 25 #include "cc/tiles/image_decode_controller.h" |
| 26 #include "cc/tiles/raster_tile_priority_queue.h" | 26 #include "cc/tiles/raster_tile_priority_queue.h" |
| 27 #include "cc/tiles/tile.h" | 27 #include "cc/tiles/tile.h" |
| (...skipping 25 matching lines...) Expand all Loading... |
| 53 // Called when the visible representation of a tile might have changed. Some | 53 // Called when the visible representation of a tile might have changed. Some |
| 54 // examples are: | 54 // examples are: |
| 55 // - Tile version initialized. | 55 // - Tile version initialized. |
| 56 // - Tile resources freed. | 56 // - Tile resources freed. |
| 57 // - Tile marked for on-demand raster. | 57 // - Tile marked for on-demand raster. |
| 58 virtual void NotifyTileStateChanged(const Tile* tile) = 0; | 58 virtual void NotifyTileStateChanged(const Tile* tile) = 0; |
| 59 | 59 |
| 60 // Given an empty raster tile priority queue, this will build a priority queue | 60 // Given an empty raster tile priority queue, this will build a priority queue |
| 61 // that will return tiles in order in which they should be rasterized. | 61 // that will return tiles in order in which they should be rasterized. |
| 62 // Note if the queue was previous built, Reset must be called on it. | 62 // Note if the queue was previous built, Reset must be called on it. |
| 63 virtual scoped_ptr<RasterTilePriorityQueue> BuildRasterQueue( | 63 virtual std::unique_ptr<RasterTilePriorityQueue> BuildRasterQueue( |
| 64 TreePriority tree_priority, | 64 TreePriority tree_priority, |
| 65 RasterTilePriorityQueue::Type type) = 0; | 65 RasterTilePriorityQueue::Type type) = 0; |
| 66 | 66 |
| 67 // Given an empty eviction tile priority queue, this will build a priority | 67 // Given an empty eviction tile priority queue, this will build a priority |
| 68 // queue that will return tiles in order in which they should be evicted. | 68 // queue that will return tiles in order in which they should be evicted. |
| 69 // Note if the queue was previous built, Reset must be called on it. | 69 // Note if the queue was previous built, Reset must be called on it. |
| 70 virtual scoped_ptr<EvictionTilePriorityQueue> BuildEvictionQueue( | 70 virtual std::unique_ptr<EvictionTilePriorityQueue> BuildEvictionQueue( |
| 71 TreePriority tree_priority) = 0; | 71 TreePriority tree_priority) = 0; |
| 72 | 72 |
| 73 // Informs the client that due to the currently rasterizing (or scheduled to | 73 // Informs the client that due to the currently rasterizing (or scheduled to |
| 74 // be rasterized) tiles, we will be in a position that will likely require a | 74 // be rasterized) tiles, we will be in a position that will likely require a |
| 75 // draw. This can be used to preemptively start a frame. | 75 // draw. This can be used to preemptively start a frame. |
| 76 virtual void SetIsLikelyToRequireADraw(bool is_likely_to_require_a_draw) = 0; | 76 virtual void SetIsLikelyToRequireADraw(bool is_likely_to_require_a_draw) = 0; |
| 77 | 77 |
| 78 protected: | 78 protected: |
| 79 virtual ~TileManagerClient() {} | 79 virtual ~TileManagerClient() {} |
| 80 }; | 80 }; |
| 81 | 81 |
| 82 struct RasterTaskCompletionStats { | 82 struct RasterTaskCompletionStats { |
| 83 RasterTaskCompletionStats(); | 83 RasterTaskCompletionStats(); |
| 84 | 84 |
| 85 size_t completed_count; | 85 size_t completed_count; |
| 86 size_t canceled_count; | 86 size_t canceled_count; |
| 87 }; | 87 }; |
| 88 scoped_ptr<base::trace_event::ConvertableToTraceFormat> | 88 std::unique_ptr<base::trace_event::ConvertableToTraceFormat> |
| 89 RasterTaskCompletionStatsAsValue(const RasterTaskCompletionStats& stats); | 89 RasterTaskCompletionStatsAsValue(const RasterTaskCompletionStats& stats); |
| 90 | 90 |
| 91 // This class manages tiles, deciding which should get rasterized and which | 91 // This class manages tiles, deciding which should get rasterized and which |
| 92 // should no longer have any memory assigned to them. Tile objects are "owned" | 92 // should no longer have any memory assigned to them. Tile objects are "owned" |
| 93 // by layers; they automatically register with the manager when they are | 93 // by layers; they automatically register with the manager when they are |
| 94 // created, and unregister from the manager when they are deleted. | 94 // created, and unregister from the manager when they are deleted. |
| 95 class CC_EXPORT TileManager { | 95 class CC_EXPORT TileManager { |
| 96 public: | 96 public: |
| 97 static scoped_ptr<TileManager> Create(TileManagerClient* client, | 97 static std::unique_ptr<TileManager> Create( |
| 98 base::SequencedTaskRunner* task_runner, | 98 TileManagerClient* client, |
| 99 size_t scheduled_raster_task_limit, | 99 base::SequencedTaskRunner* task_runner, |
| 100 bool use_partial_raster); | 100 size_t scheduled_raster_task_limit, |
| 101 bool use_partial_raster); |
| 101 virtual ~TileManager(); | 102 virtual ~TileManager(); |
| 102 | 103 |
| 103 // Assigns tile memory and schedules work to prepare tiles for drawing. | 104 // Assigns tile memory and schedules work to prepare tiles for drawing. |
| 104 // - Runs client_->NotifyReadyToActivate() when all tiles required for | 105 // - Runs client_->NotifyReadyToActivate() when all tiles required for |
| 105 // activation are prepared, or failed to prepare due to OOM. | 106 // activation are prepared, or failed to prepare due to OOM. |
| 106 // - Runs client_->NotifyReadyToDraw() when all tiles required draw are | 107 // - Runs client_->NotifyReadyToDraw() when all tiles required draw are |
| 107 // prepared, or failed to prepare due to OOM. | 108 // prepared, or failed to prepare due to OOM. |
| 108 bool PrepareTiles(const GlobalStateThatImpactsTilePriority& state); | 109 bool PrepareTiles(const GlobalStateThatImpactsTilePriority& state); |
| 109 | 110 |
| 110 // Synchronously finish any in progress work, cancel the rest, and clean up as | 111 // Synchronously finish any in progress work, cancel the rest, and clean up as |
| (...skipping 15 matching lines...) Expand all Loading... |
| 126 void Flush(); | 127 void Flush(); |
| 127 | 128 |
| 128 ScopedTilePtr CreateTile(const Tile::CreateInfo& info, | 129 ScopedTilePtr CreateTile(const Tile::CreateInfo& info, |
| 129 int layer_id, | 130 int layer_id, |
| 130 int source_frame_number, | 131 int source_frame_number, |
| 131 int flags); | 132 int flags); |
| 132 | 133 |
| 133 bool IsReadyToActivate() const; | 134 bool IsReadyToActivate() const; |
| 134 bool IsReadyToDraw() const; | 135 bool IsReadyToDraw() const; |
| 135 | 136 |
| 136 scoped_ptr<base::trace_event::ConvertableToTraceFormat> BasicStateAsValue() | 137 std::unique_ptr<base::trace_event::ConvertableToTraceFormat> |
| 137 const; | 138 BasicStateAsValue() const; |
| 138 void BasicStateAsValueInto(base::trace_event::TracedValue* dict) const; | 139 void BasicStateAsValueInto(base::trace_event::TracedValue* dict) const; |
| 139 const MemoryHistory::Entry& memory_stats_from_last_assign() const { | 140 const MemoryHistory::Entry& memory_stats_from_last_assign() const { |
| 140 return memory_stats_from_last_assign_; | 141 return memory_stats_from_last_assign_; |
| 141 } | 142 } |
| 142 | 143 |
| 143 // Public methods for testing. | 144 // Public methods for testing. |
| 144 void InitializeTilesWithResourcesForTesting(const std::vector<Tile*>& tiles) { | 145 void InitializeTilesWithResourcesForTesting(const std::vector<Tile*>& tiles) { |
| 145 for (size_t i = 0; i < tiles.size(); ++i) { | 146 for (size_t i = 0; i < tiles.size(); ++i) { |
| 146 TileDrawInfo& draw_info = tiles[i]->draw_info(); | 147 TileDrawInfo& draw_info = tiles[i]->draw_info(); |
| 147 draw_info.resource_ = resource_pool_->AcquireResource( | 148 draw_info.resource_ = resource_pool_->AcquireResource( |
| (...skipping 96 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 244 void OnRasterTaskCompleted( | 245 void OnRasterTaskCompleted( |
| 245 Tile::Id tile, | 246 Tile::Id tile, |
| 246 Resource* resource, | 247 Resource* resource, |
| 247 bool was_canceled); | 248 bool was_canceled); |
| 248 | 249 |
| 249 void FreeResourcesForTile(Tile* tile); | 250 void FreeResourcesForTile(Tile* tile); |
| 250 void FreeResourcesForTileAndNotifyClientIfTileWasReadyToDraw(Tile* tile); | 251 void FreeResourcesForTileAndNotifyClientIfTileWasReadyToDraw(Tile* tile); |
| 251 scoped_refptr<RasterTask> CreateRasterTask( | 252 scoped_refptr<RasterTask> CreateRasterTask( |
| 252 const PrioritizedTile& prioritized_tile); | 253 const PrioritizedTile& prioritized_tile); |
| 253 | 254 |
| 254 scoped_ptr<EvictionTilePriorityQueue> | 255 std::unique_ptr<EvictionTilePriorityQueue> |
| 255 FreeTileResourcesUntilUsageIsWithinLimit( | 256 FreeTileResourcesUntilUsageIsWithinLimit( |
| 256 scoped_ptr<EvictionTilePriorityQueue> eviction_priority_queue, | 257 std::unique_ptr<EvictionTilePriorityQueue> eviction_priority_queue, |
| 257 const MemoryUsage& limit, | 258 const MemoryUsage& limit, |
| 258 MemoryUsage* usage); | 259 MemoryUsage* usage); |
| 259 scoped_ptr<EvictionTilePriorityQueue> | 260 std::unique_ptr<EvictionTilePriorityQueue> |
| 260 FreeTileResourcesWithLowerPriorityUntilUsageIsWithinLimit( | 261 FreeTileResourcesWithLowerPriorityUntilUsageIsWithinLimit( |
| 261 scoped_ptr<EvictionTilePriorityQueue> eviction_priority_queue, | 262 std::unique_ptr<EvictionTilePriorityQueue> eviction_priority_queue, |
| 262 const MemoryUsage& limit, | 263 const MemoryUsage& limit, |
| 263 const TilePriority& oother_priority, | 264 const TilePriority& oother_priority, |
| 264 MemoryUsage* usage); | 265 MemoryUsage* usage); |
| 265 bool TilePriorityViolatesMemoryPolicy(const TilePriority& priority); | 266 bool TilePriorityViolatesMemoryPolicy(const TilePriority& priority); |
| 266 bool AreRequiredTilesReadyToDraw(RasterTilePriorityQueue::Type type) const; | 267 bool AreRequiredTilesReadyToDraw(RasterTilePriorityQueue::Type type) const; |
| 267 void CheckIfMoreTilesNeedToBePrepared(); | 268 void CheckIfMoreTilesNeedToBePrepared(); |
| 268 void CheckAndIssueSignals(); | 269 void CheckAndIssueSignals(); |
| 269 bool MarkTilesOutOfMemory(scoped_ptr<RasterTilePriorityQueue> queue) const; | 270 bool MarkTilesOutOfMemory( |
| 271 std::unique_ptr<RasterTilePriorityQueue> queue) const; |
| 270 | 272 |
| 271 ResourceFormat DetermineResourceFormat(const Tile* tile) const; | 273 ResourceFormat DetermineResourceFormat(const Tile* tile) const; |
| 272 bool DetermineResourceRequiresSwizzle(const Tile* tile) const; | 274 bool DetermineResourceRequiresSwizzle(const Tile* tile) const; |
| 273 | 275 |
| 274 void DidFinishRunningTileTasksRequiredForActivation(); | 276 void DidFinishRunningTileTasksRequiredForActivation(); |
| 275 void DidFinishRunningTileTasksRequiredForDraw(); | 277 void DidFinishRunningTileTasksRequiredForDraw(); |
| 276 void DidFinishRunningAllTileTasks(); | 278 void DidFinishRunningAllTileTasks(); |
| 277 | 279 |
| 278 scoped_refptr<TileTask> CreateTaskSetFinishedTask( | 280 scoped_refptr<TileTask> CreateTaskSetFinishedTask( |
| 279 void (TileManager::*callback)()); | 281 void (TileManager::*callback)()); |
| 280 | 282 |
| 281 scoped_ptr<base::trace_event::ConvertableToTraceFormat> | 283 std::unique_ptr<base::trace_event::ConvertableToTraceFormat> |
| 282 ScheduledTasksStateAsValue() const; | 284 ScheduledTasksStateAsValue() const; |
| 283 | 285 |
| 284 TileManagerClient* client_; | 286 TileManagerClient* client_; |
| 285 scoped_refptr<base::SequencedTaskRunner> task_runner_; | 287 scoped_refptr<base::SequencedTaskRunner> task_runner_; |
| 286 ResourcePool* resource_pool_; | 288 ResourcePool* resource_pool_; |
| 287 TileTaskRunner* tile_task_runner_; | 289 TileTaskRunner* tile_task_runner_; |
| 288 GlobalStateThatImpactsTilePriority global_state_; | 290 GlobalStateThatImpactsTilePriority global_state_; |
| 289 size_t scheduled_raster_task_limit_; | 291 size_t scheduled_raster_task_limit_; |
| 290 const bool use_partial_raster_; | 292 const bool use_partial_raster_; |
| 291 bool use_gpu_rasterization_; | 293 bool use_gpu_rasterization_; |
| (...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 337 std::unordered_map<Tile::Id, std::vector<DrawImage>> scheduled_draw_images_; | 339 std::unordered_map<Tile::Id, std::vector<DrawImage>> scheduled_draw_images_; |
| 338 | 340 |
| 339 base::WeakPtrFactory<TileManager> task_set_finished_weak_ptr_factory_; | 341 base::WeakPtrFactory<TileManager> task_set_finished_weak_ptr_factory_; |
| 340 | 342 |
| 341 DISALLOW_COPY_AND_ASSIGN(TileManager); | 343 DISALLOW_COPY_AND_ASSIGN(TileManager); |
| 342 }; | 344 }; |
| 343 | 345 |
| 344 } // namespace cc | 346 } // namespace cc |
| 345 | 347 |
| 346 #endif // CC_TILES_TILE_MANAGER_H_ | 348 #endif // CC_TILES_TILE_MANAGER_H_ |
| OLD | NEW |