| 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_ONE_COPY_TILE_TASK_WORKER_POOL_H_ | 5 #ifndef CC_RASTER_ONE_COPY_TILE_TASK_WORKER_POOL_H_ |
| 6 #define CC_RASTER_ONE_COPY_TILE_TASK_WORKER_POOL_H_ | 6 #define CC_RASTER_ONE_COPY_TILE_TASK_WORKER_POOL_H_ |
| 7 | 7 |
| 8 #include "base/memory/weak_ptr.h" | 8 #include "base/memory/weak_ptr.h" |
| 9 #include "base/synchronization/lock.h" | 9 #include "base/synchronization/lock.h" |
| 10 #include "base/values.h" | 10 #include "base/values.h" |
| (...skipping 21 matching lines...) Expand all Loading... |
| 32 public TileTaskClient { | 32 public TileTaskClient { |
| 33 public: | 33 public: |
| 34 ~OneCopyTileTaskWorkerPool() override; | 34 ~OneCopyTileTaskWorkerPool() override; |
| 35 | 35 |
| 36 static scoped_ptr<TileTaskWorkerPool> Create( | 36 static scoped_ptr<TileTaskWorkerPool> Create( |
| 37 base::SequencedTaskRunner* task_runner, | 37 base::SequencedTaskRunner* task_runner, |
| 38 TaskGraphRunner* task_graph_runner, | 38 TaskGraphRunner* task_graph_runner, |
| 39 ContextProvider* context_provider, | 39 ContextProvider* context_provider, |
| 40 ResourceProvider* resource_provider, | 40 ResourceProvider* resource_provider, |
| 41 ResourcePool* resource_pool, | 41 ResourcePool* resource_pool, |
| 42 size_t max_bytes_per_copy_operation); | 42 size_t max_bytes_per_copy_operation, |
| 43 bool have_persistent_gpu_memory_buffers); |
| 43 | 44 |
| 44 // Overridden from TileTaskWorkerPool: | 45 // Overridden from TileTaskWorkerPool: |
| 45 TileTaskRunner* AsTileTaskRunner() override; | 46 TileTaskRunner* AsTileTaskRunner() override; |
| 46 | 47 |
| 47 // Overridden from TileTaskRunner: | 48 // Overridden from TileTaskRunner: |
| 48 void SetClient(TileTaskRunnerClient* client) override; | 49 void SetClient(TileTaskRunnerClient* client) override; |
| 49 void Shutdown() override; | 50 void Shutdown() override; |
| 50 void ScheduleTasks(TileTaskQueue* queue) override; | 51 void ScheduleTasks(TileTaskQueue* queue) override; |
| 51 void CheckForCompletedTasks() override; | 52 void CheckForCompletedTasks() override; |
| 52 ResourceFormat GetResourceFormat() override; | 53 ResourceFormat GetResourceFormat() override; |
| 53 | 54 |
| 54 // Overridden from TileTaskClient: | 55 // Overridden from TileTaskClient: |
| 55 scoped_ptr<RasterBuffer> AcquireBufferForRaster( | 56 scoped_ptr<RasterBuffer> AcquireBufferForRaster( |
| 56 const Resource* resource) override; | 57 const Resource* resource, |
| 58 uint64_t new_content_id, |
| 59 uint64_t previous_content_id) override; |
| 57 void ReleaseBufferForRaster(scoped_ptr<RasterBuffer> buffer) override; | 60 void ReleaseBufferForRaster(scoped_ptr<RasterBuffer> buffer) override; |
| 58 | 61 |
| 59 // Playback raster source and schedule copy of |src| resource to |dst| | 62 // Playback raster source and schedule copy of |raster_resource| resource to |
| 60 // resource. Returns a non-zero sequence number for this copy operation. | 63 // |output_resource|. Returns a non-zero sequence number for this copy |
| 64 // operation. |
| 61 CopySequenceNumber PlaybackAndScheduleCopyOnWorkerThread( | 65 CopySequenceNumber PlaybackAndScheduleCopyOnWorkerThread( |
| 62 scoped_ptr<ResourceProvider::ScopedWriteLockGpuMemoryBuffer> write_lock, | 66 bool reusing_raster_resource, |
| 63 const Resource* src, | 67 scoped_ptr<ResourceProvider::ScopedWriteLockGpuMemoryBuffer> |
| 64 const Resource* dst, | 68 raster_resource_write_lock, |
| 69 const Resource* raster_resource, |
| 70 const Resource* output_resource, |
| 65 const RasterSource* raster_source, | 71 const RasterSource* raster_source, |
| 66 const gfx::Rect& rect, | 72 const gfx::Rect& raster_full_rect, |
| 73 const gfx::Rect& raster_dirty_rect, |
| 67 float scale); | 74 float scale); |
| 68 | 75 |
| 69 // Issues copy operations until |sequence| has been processed. This will | 76 // Issues copy operations until |sequence| has been processed. This will |
| 70 // return immediately if |sequence| has already been processed. | 77 // return immediately if |sequence| has already been processed. |
| 71 void AdvanceLastIssuedCopyTo(CopySequenceNumber sequence); | 78 void AdvanceLastIssuedCopyTo(CopySequenceNumber sequence); |
| 72 | 79 |
| 80 bool have_persistent_gpu_memory_buffers() const { |
| 81 return have_persistent_gpu_memory_buffers_; |
| 82 } |
| 83 |
| 73 protected: | 84 protected: |
| 74 OneCopyTileTaskWorkerPool(base::SequencedTaskRunner* task_runner, | 85 OneCopyTileTaskWorkerPool(base::SequencedTaskRunner* task_runner, |
| 75 TaskGraphRunner* task_graph_runner, | 86 TaskGraphRunner* task_graph_runner, |
| 76 ContextProvider* context_provider, | 87 ContextProvider* context_provider, |
| 77 ResourceProvider* resource_provider, | 88 ResourceProvider* resource_provider, |
| 78 ResourcePool* resource_pool, | 89 ResourcePool* resource_pool, |
| 79 size_t max_bytes_per_copy_operation); | 90 size_t max_bytes_per_copy_operation, |
| 91 bool have_persistent_gpu_memory_buffers); |
| 80 | 92 |
| 81 private: | 93 private: |
| 82 struct CopyOperation { | 94 struct CopyOperation { |
| 83 typedef ScopedPtrDeque<CopyOperation> Deque; | 95 typedef ScopedPtrDeque<CopyOperation> Deque; |
| 84 | 96 |
| 85 CopyOperation( | 97 CopyOperation(scoped_ptr<ResourceProvider::ScopedWriteLockGpuMemoryBuffer> |
| 86 scoped_ptr<ResourceProvider::ScopedWriteLockGpuMemoryBuffer> write_lock, | 98 src_write_lock, |
| 87 const Resource* src, | 99 const Resource* src, |
| 88 const Resource* dst, | 100 const Resource* dst, |
| 89 const gfx::Rect& rect); | 101 const gfx::Rect& rect); |
| 90 ~CopyOperation(); | 102 ~CopyOperation(); |
| 91 | 103 |
| 92 scoped_ptr<ResourceProvider::ScopedWriteLockGpuMemoryBuffer> write_lock; | 104 scoped_ptr<ResourceProvider::ScopedWriteLockGpuMemoryBuffer> src_write_lock; |
| 93 const Resource* src; | 105 const Resource* src; |
| 94 const Resource* dst; | 106 const Resource* dst; |
| 95 const gfx::Rect rect; | 107 const gfx::Rect rect; |
| 96 }; | 108 }; |
| 97 | 109 |
| 98 void OnTaskSetFinished(TaskSet task_set); | 110 void OnTaskSetFinished(TaskSet task_set); |
| 99 void AdvanceLastFlushedCopyTo(CopySequenceNumber sequence); | 111 void AdvanceLastFlushedCopyTo(CopySequenceNumber sequence); |
| 100 void IssueCopyOperations(int64 count); | 112 void IssueCopyOperations(int64 count); |
| 101 void ScheduleCheckForCompletedCopyOperationsWithLockAcquired( | 113 void ScheduleCheckForCompletedCopyOperationsWithLockAcquired( |
| 102 bool wait_if_needed); | 114 bool wait_if_needed); |
| 103 void CheckForCompletedCopyOperations(bool wait_if_needed); | 115 void CheckForCompletedCopyOperations(bool wait_if_needed); |
| 104 scoped_refptr<base::trace_event::ConvertableToTraceFormat> StateAsValue() | 116 scoped_refptr<base::trace_event::ConvertableToTraceFormat> StateAsValue() |
| 105 const; | 117 const; |
| 106 void StagingStateAsValueInto( | 118 void StagingStateAsValueInto( |
| 107 base::trace_event::TracedValue* staging_state) const; | 119 base::trace_event::TracedValue* staging_state) const; |
| 108 | 120 |
| 109 scoped_refptr<base::SequencedTaskRunner> task_runner_; | 121 scoped_refptr<base::SequencedTaskRunner> task_runner_; |
| 110 TaskGraphRunner* task_graph_runner_; | 122 TaskGraphRunner* task_graph_runner_; |
| 111 const NamespaceToken namespace_token_; | 123 const NamespaceToken namespace_token_; |
| 112 TileTaskRunnerClient* client_; | 124 TileTaskRunnerClient* client_; |
| 113 ContextProvider* context_provider_; | 125 ContextProvider* context_provider_; |
| 114 ResourceProvider* resource_provider_; | 126 ResourceProvider* resource_provider_; |
| 115 ResourcePool* resource_pool_; | 127 ResourcePool* resource_pool_; |
| 116 const size_t max_bytes_per_copy_operation_; | 128 const size_t max_bytes_per_copy_operation_; |
| 129 const bool have_persistent_gpu_memory_buffers_; |
| 117 TaskSetCollection tasks_pending_; | 130 TaskSetCollection tasks_pending_; |
| 118 scoped_refptr<TileTask> task_set_finished_tasks_[kNumberOfTaskSets]; | 131 scoped_refptr<TileTask> task_set_finished_tasks_[kNumberOfTaskSets]; |
| 119 CopySequenceNumber last_issued_copy_operation_; | 132 CopySequenceNumber last_issued_copy_operation_; |
| 120 CopySequenceNumber last_flushed_copy_operation_; | 133 CopySequenceNumber last_flushed_copy_operation_; |
| 121 | 134 |
| 122 // Task graph used when scheduling tasks and vector used to gather | 135 // Task graph used when scheduling tasks and vector used to gather |
| 123 // completed tasks. | 136 // completed tasks. |
| 124 TaskGraph graph_; | 137 TaskGraph graph_; |
| 125 Task::Vector completed_tasks_; | 138 Task::Vector completed_tasks_; |
| 126 | 139 |
| (...skipping 12 matching lines...) Expand all Loading... |
| 139 // canceled when ScheduleTasks() is called. | 152 // canceled when ScheduleTasks() is called. |
| 140 base::WeakPtrFactory<OneCopyTileTaskWorkerPool> | 153 base::WeakPtrFactory<OneCopyTileTaskWorkerPool> |
| 141 task_set_finished_weak_ptr_factory_; | 154 task_set_finished_weak_ptr_factory_; |
| 142 | 155 |
| 143 DISALLOW_COPY_AND_ASSIGN(OneCopyTileTaskWorkerPool); | 156 DISALLOW_COPY_AND_ASSIGN(OneCopyTileTaskWorkerPool); |
| 144 }; | 157 }; |
| 145 | 158 |
| 146 } // namespace cc | 159 } // namespace cc |
| 147 | 160 |
| 148 #endif // CC_RASTER_ONE_COPY_TILE_TASK_WORKER_POOL_H_ | 161 #endif // CC_RASTER_ONE_COPY_TILE_TASK_WORKER_POOL_H_ |
| OLD | NEW |