| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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_RASTER_TILE_TASK_RUNNER_H_ | 5 #ifndef CC_RASTER_TILE_TASK_RUNNER_H_ |
| 6 #define CC_RASTER_TILE_TASK_RUNNER_H_ | 6 #define CC_RASTER_TILE_TASK_RUNNER_H_ |
| 7 | 7 |
| 8 #include <stdint.h> | 8 #include <stdint.h> |
| 9 | 9 |
| 10 #include <vector> | 10 #include <vector> |
| 11 | 11 |
| 12 #include "base/callback.h" | 12 #include "base/callback.h" |
| 13 #include "cc/raster/task_graph_runner.h" | 13 #include "cc/raster/task_graph_runner.h" |
| 14 #include "cc/resources/resource_format.h" | 14 #include "cc/resources/resource_format.h" |
| 15 | 15 |
| 16 namespace cc { | 16 namespace cc { |
| 17 class ImageDecodeTask; | 17 class ImageDecodeTask; |
| 18 class RasterTask; | 18 class RasterTask; |
| 19 class Resource; | 19 class Resource; |
| 20 class RasterBuffer; | 20 class RasterBuffer; |
| 21 | 21 |
| 22 enum TaskType : TaskTypeId { |
| 23 TASK_TYPE_DEFAULT = kDefaultTaskTypeId, |
| 24 TASK_TYPE_RASTER, |
| 25 TASK_TYPE_IMAGE_DECODE, |
| 26 TASK_TYPE_IMAGE_UPLOAD |
| 27 }; |
| 28 |
| 22 class CC_EXPORT TileTaskClient { | 29 class CC_EXPORT TileTaskClient { |
| 23 public: | 30 public: |
| 24 virtual std::unique_ptr<RasterBuffer> AcquireBufferForRaster( | 31 virtual std::unique_ptr<RasterBuffer> AcquireBufferForRaster( |
| 25 const Resource* resource, | 32 const Resource* resource, |
| 26 uint64_t resource_content_id, | 33 uint64_t resource_content_id, |
| 27 uint64_t previous_content_id) = 0; | 34 uint64_t previous_content_id) = 0; |
| 28 virtual void ReleaseBufferForRaster(std::unique_ptr<RasterBuffer> buffer) = 0; | 35 virtual void ReleaseBufferForRaster(std::unique_ptr<RasterBuffer> buffer) = 0; |
| 29 | 36 |
| 30 protected: | 37 protected: |
| 31 virtual ~TileTaskClient() {} | 38 virtual ~TileTaskClient() {} |
| 32 }; | 39 }; |
| 33 | 40 |
| 34 class CC_EXPORT TileTask : public Task { | 41 class CC_EXPORT TileTask : public Task { |
| 35 public: | 42 public: |
| 36 typedef std::vector<scoped_refptr<TileTask>> Vector; | 43 typedef std::vector<scoped_refptr<TileTask>> Vector; |
| 37 | 44 |
| 38 virtual void ScheduleOnOriginThread(TileTaskClient* client) = 0; | |
| 39 virtual void CompleteOnOriginThread(TileTaskClient* client) = 0; | |
| 40 | |
| 41 void WillSchedule(); | |
| 42 void DidSchedule(); | |
| 43 bool HasBeenScheduled() const; | |
| 44 | |
| 45 void WillComplete(); | |
| 46 void DidComplete(); | 45 void DidComplete(); |
| 47 bool HasCompleted() const; | 46 bool HasCompleted() const; |
| 48 | 47 |
| 49 protected: | 48 protected: |
| 50 TileTask(); | 49 TileTask(); |
| 51 ~TileTask() override; | 50 ~TileTask() override; |
| 52 | 51 |
| 53 bool did_schedule_; | |
| 54 bool did_complete_; | 52 bool did_complete_; |
| 55 }; | 53 }; |
| 56 | 54 |
| 57 class CC_EXPORT ImageDecodeTask : public TileTask { | 55 class CC_EXPORT ImageDecodeTask : public TileTask { |
| 58 public: | 56 public: |
| 59 typedef std::vector<scoped_refptr<ImageDecodeTask>> Vector; | 57 typedef std::vector<scoped_refptr<ImageDecodeTask>> Vector; |
| 60 | 58 |
| 61 // Indicates whether this ImageDecodeTask can be run at the same time as | 59 // Indicates whether this ImageDecodeTask can be run at the same time as |
| 62 // other tasks in the task graph. If false, this task will be scheduled with | 60 // other tasks in the task graph. If false, this task will be scheduled with |
| 63 // TASK_CATEGORY_NONCONCURRENT_FOREGROUND. The base implementation always | 61 // TASK_CATEGORY_NONCONCURRENT_FOREGROUND. The base implementation always |
| (...skipping 20 matching lines...) Expand all Loading... |
| 84 | 82 |
| 85 protected: | 83 protected: |
| 86 explicit RasterTask(ImageDecodeTask::Vector* dependencies); | 84 explicit RasterTask(ImageDecodeTask::Vector* dependencies); |
| 87 ~RasterTask() override; | 85 ~RasterTask() override; |
| 88 | 86 |
| 89 private: | 87 private: |
| 90 ImageDecodeTask::Vector dependencies_; | 88 ImageDecodeTask::Vector dependencies_; |
| 91 }; | 89 }; |
| 92 | 90 |
| 93 // This interface can be used to schedule and run tile tasks. | 91 // This interface can be used to schedule and run tile tasks. |
| 94 // The client can call CheckForCompletedTasks() at any time to dispatch | 92 // The client can call CollectCompletedTasks() at any time to process |
| 95 // pending completion callbacks for all tasks that have finished running. | 93 // all completed tasks at the moment that have finished running or cancelled. |
| 96 class CC_EXPORT TileTaskRunner { | 94 class CC_EXPORT TileTaskRunner { |
| 97 public: | 95 public: |
| 98 // Tells the worker pool to shutdown after canceling all previously scheduled | 96 // Tells the worker pool to shutdown after canceling all previously scheduled |
| 99 // tasks. Reply callbacks are still guaranteed to run when | 97 // tasks. Reply callbacks are still guaranteed to run when |
| 100 // CheckForCompletedTasks() is called. | 98 // CollectCompletedTasks() is called. |
| 101 virtual void Shutdown() = 0; | 99 virtual void Shutdown() = 0; |
| 102 | 100 |
| 103 // Schedule running of tile tasks in |graph| and all dependencies. | 101 // Schedule running of tile tasks in |graph| and all dependencies. |
| 104 // Previously scheduled tasks that are not in |graph| will be canceled unless | 102 // Previously scheduled tasks that are not in |graph| will be canceled unless |
| 105 // already running. Once scheduled, reply callbacks are guaranteed to run for | 103 // already running. Once scheduled, reply callbacks are guaranteed to run for |
| 106 // all tasks even if they later get canceled by another call to | 104 // all tasks even if they later get canceled by another call to |
| 107 // ScheduleTasks(). | 105 // ScheduleTasks(). |
| 108 virtual void ScheduleTasks(TaskGraph* graph) = 0; | 106 virtual void ScheduleTasks(TaskGraph* graph) = 0; |
| 109 | 107 |
| 110 // Check for completed tasks and dispatch reply callbacks. | 108 // Collect completed tasks. |
| 111 virtual void CheckForCompletedTasks() = 0; | 109 virtual void CollectCompletedTasks(Task::Vector* completed_tasks) = 0; |
| 112 | 110 |
| 113 // Returns the format to use for the tiles. | 111 // Returns the format to use for the tiles. |
| 114 virtual ResourceFormat GetResourceFormat(bool must_support_alpha) const = 0; | 112 virtual ResourceFormat GetResourceFormat(bool must_support_alpha) const = 0; |
| 115 | 113 |
| 116 // Determine if the resource requires swizzling. | 114 // Determine if the resource requires swizzling. |
| 117 virtual bool GetResourceRequiresSwizzle(bool must_support_alpha) const = 0; | 115 virtual bool GetResourceRequiresSwizzle(bool must_support_alpha) const = 0; |
| 118 | 116 |
| 117 // TODO(prashant.n): This will be removed soon. Don't use this. |
| 118 virtual TileTaskClient* AsTileTaskClient() = 0; |
| 119 |
| 119 protected: | 120 protected: |
| 120 // Check if resource format matches output format. | 121 // Check if resource format matches output format. |
| 121 static bool ResourceFormatRequiresSwizzle(ResourceFormat format); | 122 static bool ResourceFormatRequiresSwizzle(ResourceFormat format); |
| 122 | 123 |
| 123 virtual ~TileTaskRunner() {} | 124 virtual ~TileTaskRunner() {} |
| 124 }; | 125 }; |
| 125 | 126 |
| 126 } // namespace cc | 127 } // namespace cc |
| 127 | 128 |
| 128 #endif // CC_RASTER_TILE_TASK_RUNNER_H_ | 129 #endif // CC_RASTER_TILE_TASK_RUNNER_H_ |
| OLD | NEW |