OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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_RESOURCES_RASTER_WORKER_POOL_H_ | 5 #ifndef CC_RESOURCES_RASTER_WORKER_POOL_H_ |
6 #define CC_RESOURCES_RASTER_WORKER_POOL_H_ | 6 #define CC_RESOURCES_RASTER_WORKER_POOL_H_ |
7 | 7 |
8 #include <vector> | 8 #include <vector> |
9 | 9 |
10 #include "base/containers/hash_tables.h" | 10 #include "base/containers/hash_tables.h" |
(...skipping 87 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
98 bool is_tile_in_pending_tree_now_bin; | 98 bool is_tile_in_pending_tree_now_bin; |
99 TileResolution tile_resolution; | 99 TileResolution tile_resolution; |
100 int layer_id; | 100 int layer_id; |
101 const void* tile_id; | 101 const void* tile_id; |
102 int source_frame_number; | 102 int source_frame_number; |
103 }; | 103 }; |
104 | 104 |
105 class CC_EXPORT RasterWorkerPoolClient { | 105 class CC_EXPORT RasterWorkerPoolClient { |
106 public: | 106 public: |
107 virtual bool ShouldForceTasksRequiredForActivationToComplete() const = 0; | 107 virtual bool ShouldForceTasksRequiredForActivationToComplete() const = 0; |
| 108 virtual void DidFinishedRunningTasks() = 0; |
| 109 virtual void DidFinishedRunningTasksRequiredForActivation() = 0; |
108 | 110 |
109 protected: | 111 protected: |
110 virtual ~RasterWorkerPoolClient() {} | 112 virtual ~RasterWorkerPoolClient() {} |
111 }; | 113 }; |
112 | 114 |
113 // A worker thread pool that runs raster tasks. | 115 // A worker thread pool that runs raster tasks. |
114 class CC_EXPORT RasterWorkerPool : public WorkerPool { | 116 class CC_EXPORT RasterWorkerPool : public WorkerPool { |
115 public: | 117 public: |
116 class CC_EXPORT Task { | 118 class CC_EXPORT Task { |
117 public: | 119 public: |
(...skipping 107 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
225 const Task::Reply& reply); | 227 const Task::Reply& reply); |
226 | 228 |
227 protected: | 229 protected: |
228 typedef std::vector<scoped_refptr<internal::WorkerPoolTask> > TaskVector; | 230 typedef std::vector<scoped_refptr<internal::WorkerPoolTask> > TaskVector; |
229 typedef std::vector<scoped_refptr<internal::RasterWorkerPoolTask> > | 231 typedef std::vector<scoped_refptr<internal::RasterWorkerPoolTask> > |
230 RasterTaskVector; | 232 RasterTaskVector; |
231 typedef internal::RasterWorkerPoolTask* TaskMapKey; | 233 typedef internal::RasterWorkerPoolTask* TaskMapKey; |
232 typedef base::hash_map<TaskMapKey, | 234 typedef base::hash_map<TaskMapKey, |
233 scoped_refptr<internal::WorkerPoolTask> > TaskMap; | 235 scoped_refptr<internal::WorkerPoolTask> > TaskMap; |
234 | 236 |
235 class CC_EXPORT RasterTaskGraph { | |
236 public: | |
237 RasterTaskGraph(); | |
238 ~RasterTaskGraph(); | |
239 | |
240 void InsertRasterTask(internal::WorkerPoolTask* raster_task, | |
241 const TaskVector& decode_tasks); | |
242 | |
243 private: | |
244 friend class RasterWorkerPool; | |
245 | |
246 TaskGraph graph_; | |
247 scoped_refptr<internal::WorkerPoolTask> raster_finished_task_; | |
248 scoped_ptr<GraphNode> raster_finished_node_; | |
249 unsigned next_priority_; | |
250 | |
251 DISALLOW_COPY_AND_ASSIGN(RasterTaskGraph); | |
252 }; | |
253 | |
254 RasterWorkerPool(ResourceProvider* resource_provider, size_t num_threads); | 237 RasterWorkerPool(ResourceProvider* resource_provider, size_t num_threads); |
255 | 238 |
256 virtual void OnRasterTasksFinished() {} | |
257 | |
258 void SetRasterTasks(RasterTask::Queue* queue); | 239 void SetRasterTasks(RasterTask::Queue* queue); |
259 void SetRasterTaskGraph(RasterTaskGraph* graph); | |
260 bool IsRasterTaskRequiredForActivation( | 240 bool IsRasterTaskRequiredForActivation( |
261 internal::RasterWorkerPoolTask* task) const; | 241 internal::RasterWorkerPoolTask* task) const; |
262 | 242 |
263 RasterWorkerPoolClient* client() const { return client_; } | 243 RasterWorkerPoolClient* client() const { return client_; } |
264 ResourceProvider* resource_provider() const { return resource_provider_; } | 244 ResourceProvider* resource_provider() const { return resource_provider_; } |
265 const RasterTask::Queue::TaskVector& raster_tasks() const { | 245 const RasterTask::Queue::TaskVector& raster_tasks() const { |
266 return raster_tasks_; | 246 return raster_tasks_; |
267 } | 247 } |
268 | 248 |
| 249 static scoped_ptr<GraphNode> CreateRasterTaskGraphNode( |
| 250 internal::WorkerPoolTask* raster_task, |
| 251 const TaskVector& decode_tasks, |
| 252 unsigned priority, |
| 253 TaskGraph* graph); |
| 254 |
269 private: | 255 private: |
270 void OnRasterFinished(int64 schedule_raster_tasks_count); | |
271 | |
272 RasterWorkerPoolClient* client_; | 256 RasterWorkerPoolClient* client_; |
273 ResourceProvider* resource_provider_; | 257 ResourceProvider* resource_provider_; |
274 RasterTask::Queue::TaskVector raster_tasks_; | 258 RasterTask::Queue::TaskVector raster_tasks_; |
275 RasterTask::Queue::TaskSet raster_tasks_required_for_activation_; | 259 RasterTask::Queue::TaskSet raster_tasks_required_for_activation_; |
276 | |
277 base::WeakPtrFactory<RasterWorkerPool> weak_ptr_factory_; | |
278 scoped_refptr<internal::WorkerPoolTask> raster_finished_task_; | |
279 int64 schedule_raster_tasks_count_; | |
280 }; | 260 }; |
281 | 261 |
282 } // namespace cc | 262 } // namespace cc |
283 | 263 |
284 #endif // CC_RESOURCES_RASTER_WORKER_POOL_H_ | 264 #endif // CC_RESOURCES_RASTER_WORKER_POOL_H_ |
OLD | NEW |