| 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 20 matching lines...) Expand all Loading... |
| 31 public TileTaskRunner, | 31 public TileTaskRunner, |
| 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 bool have_persistent_gpu_memory_buffers); |
| 42 | 43 |
| 43 // Overridden from TileTaskWorkerPool: | 44 // Overridden from TileTaskWorkerPool: |
| 44 TileTaskRunner* AsTileTaskRunner() override; | 45 TileTaskRunner* AsTileTaskRunner() override; |
| 45 | 46 |
| 46 // Overridden from TileTaskRunner: | 47 // Overridden from TileTaskRunner: |
| 47 void SetClient(TileTaskRunnerClient* client) override; | 48 void SetClient(TileTaskRunnerClient* client) override; |
| 48 void Shutdown() override; | 49 void Shutdown() override; |
| 49 void ScheduleTasks(TileTaskQueue* queue) override; | 50 void ScheduleTasks(TileTaskQueue* queue) override; |
| 50 void CheckForCompletedTasks() override; | 51 void CheckForCompletedTasks() override; |
| 51 ResourceFormat GetResourceFormat() override; | 52 ResourceFormat GetResourceFormat() override; |
| 52 | 53 |
| 53 // Overridden from TileTaskClient: | 54 // Overridden from TileTaskClient: |
| 54 scoped_ptr<RasterBuffer> AcquireBufferForRaster( | 55 scoped_ptr<RasterBuffer> AcquireBufferForRaster( |
| 55 const Resource* resource) override; | 56 const TileTaskData& data) override; |
| 56 void ReleaseBufferForRaster(scoped_ptr<RasterBuffer> buffer) override; | 57 void ReleaseBufferForRaster(scoped_ptr<RasterBuffer> buffer) override; |
| 57 | 58 |
| 58 // Playback raster source and schedule copy of |src| resource to |dst| | 59 // Playback raster source and schedule copy of |raster_resource| resource to |
| 59 // resource. Returns a non-zero sequence number for this copy operation. | 60 // |data|'s resource. Returns a non-zero sequence number for this copy |
| 61 // operation. |
| 60 CopySequenceNumber PlaybackAndScheduleCopyOnWorkerThread( | 62 CopySequenceNumber PlaybackAndScheduleCopyOnWorkerThread( |
| 61 scoped_ptr<ResourceProvider::ScopedWriteLockGpuMemoryBuffer> write_lock, | 63 bool reusing_raster_resource, |
| 62 scoped_ptr<ScopedResource> src, | 64 scoped_ptr<ResourceProvider::ScopedWriteLockGpuMemoryBuffer> |
| 63 const Resource* dst, | 65 raster_resource_write_lock, |
| 66 scoped_ptr<ScopedResource> raster_resource, |
| 67 const TileTaskData& data, |
| 64 const RasterSource* raster_source, | 68 const RasterSource* raster_source, |
| 65 const gfx::Rect& rect, | 69 const gfx::Rect& rect, |
| 66 float scale); | 70 float scale); |
| 67 | 71 |
| 68 // Issues copy operations until |sequence| has been processed. This will | 72 // Issues copy operations until |sequence| has been processed. This will |
| 69 // return immediately if |sequence| has already been processed. | 73 // return immediately if |sequence| has already been processed. |
| 70 void AdvanceLastIssuedCopyTo(CopySequenceNumber sequence); | 74 void AdvanceLastIssuedCopyTo(CopySequenceNumber sequence); |
| 71 | 75 |
| 76 bool have_persistent_gpu_memory_buffers() const { |
| 77 return have_persistent_gpu_memory_buffers_; |
| 78 } |
| 79 |
| 72 protected: | 80 protected: |
| 73 OneCopyTileTaskWorkerPool(base::SequencedTaskRunner* task_runner, | 81 OneCopyTileTaskWorkerPool(base::SequencedTaskRunner* task_runner, |
| 74 TaskGraphRunner* task_graph_runner, | 82 TaskGraphRunner* task_graph_runner, |
| 75 ContextProvider* context_provider, | 83 ContextProvider* context_provider, |
| 76 ResourceProvider* resource_provider, | 84 ResourceProvider* resource_provider, |
| 77 ResourcePool* resource_pool); | 85 ResourcePool* resource_pool, |
| 86 bool have_persistent_gpu_memory_buffers); |
| 78 | 87 |
| 79 private: | 88 private: |
| 80 struct CopyOperation { | 89 struct CopyOperation { |
| 81 typedef ScopedPtrDeque<CopyOperation> Deque; | 90 typedef ScopedPtrDeque<CopyOperation> Deque; |
| 82 | 91 |
| 83 CopyOperation( | 92 CopyOperation(scoped_ptr<ResourceProvider::ScopedWriteLockGpuMemoryBuffer> |
| 84 scoped_ptr<ResourceProvider::ScopedWriteLockGpuMemoryBuffer> write_lock, | 93 raster_resource_write_lock, |
| 85 scoped_ptr<ScopedResource> src, | 94 scoped_ptr<ScopedResource> raster_resource, |
| 86 const Resource* dst); | 95 const TileTaskData& data); |
| 87 ~CopyOperation(); | 96 ~CopyOperation(); |
| 88 | 97 |
| 89 scoped_ptr<ResourceProvider::ScopedWriteLockGpuMemoryBuffer> write_lock; | 98 scoped_ptr<ResourceProvider::ScopedWriteLockGpuMemoryBuffer> |
| 90 scoped_ptr<ScopedResource> src; | 99 raster_resource_write_lock; |
| 91 const Resource* dst; | 100 scoped_ptr<ScopedResource> raster_resource; |
| 101 TileTaskData tile_task_data; |
| 92 }; | 102 }; |
| 93 | 103 |
| 94 void OnTaskSetFinished(TaskSet task_set); | 104 void OnTaskSetFinished(TaskSet task_set); |
| 95 void AdvanceLastFlushedCopyTo(CopySequenceNumber sequence); | 105 void AdvanceLastFlushedCopyTo(CopySequenceNumber sequence); |
| 96 void IssueCopyOperations(int64 count); | 106 void IssueCopyOperations(int64 count); |
| 97 void ScheduleCheckForCompletedCopyOperationsWithLockAcquired( | 107 void ScheduleCheckForCompletedCopyOperationsWithLockAcquired( |
| 98 bool wait_if_needed); | 108 bool wait_if_needed); |
| 99 void CheckForCompletedCopyOperations(bool wait_if_needed); | 109 void CheckForCompletedCopyOperations(bool wait_if_needed); |
| 100 scoped_refptr<base::trace_event::ConvertableToTraceFormat> StateAsValue() | 110 scoped_refptr<base::trace_event::ConvertableToTraceFormat> StateAsValue() |
| 101 const; | 111 const; |
| 102 void StagingStateAsValueInto( | 112 void StagingStateAsValueInto( |
| 103 base::trace_event::TracedValue* staging_state) const; | 113 base::trace_event::TracedValue* staging_state) const; |
| 104 | 114 |
| 115 const bool have_persistent_gpu_memory_buffers_; |
| 116 |
| 105 scoped_refptr<base::SequencedTaskRunner> task_runner_; | 117 scoped_refptr<base::SequencedTaskRunner> task_runner_; |
| 106 TaskGraphRunner* task_graph_runner_; | 118 TaskGraphRunner* task_graph_runner_; |
| 107 const NamespaceToken namespace_token_; | 119 const NamespaceToken namespace_token_; |
| 108 TileTaskRunnerClient* client_; | 120 TileTaskRunnerClient* client_; |
| 109 ContextProvider* context_provider_; | 121 ContextProvider* context_provider_; |
| 110 ResourceProvider* resource_provider_; | 122 ResourceProvider* resource_provider_; |
| 111 ResourcePool* resource_pool_; | 123 ResourcePool* resource_pool_; |
| 112 TaskSetCollection tasks_pending_; | 124 TaskSetCollection tasks_pending_; |
| 113 scoped_refptr<TileTask> task_set_finished_tasks_[kNumberOfTaskSets]; | 125 scoped_refptr<TileTask> task_set_finished_tasks_[kNumberOfTaskSets]; |
| 114 CopySequenceNumber last_issued_copy_operation_; | 126 CopySequenceNumber last_issued_copy_operation_; |
| (...skipping 20 matching lines...) Expand all Loading... |
| 135 // canceled when ScheduleTasks() is called. | 147 // canceled when ScheduleTasks() is called. |
| 136 base::WeakPtrFactory<OneCopyTileTaskWorkerPool> | 148 base::WeakPtrFactory<OneCopyTileTaskWorkerPool> |
| 137 task_set_finished_weak_ptr_factory_; | 149 task_set_finished_weak_ptr_factory_; |
| 138 | 150 |
| 139 DISALLOW_COPY_AND_ASSIGN(OneCopyTileTaskWorkerPool); | 151 DISALLOW_COPY_AND_ASSIGN(OneCopyTileTaskWorkerPool); |
| 140 }; | 152 }; |
| 141 | 153 |
| 142 } // namespace cc | 154 } // namespace cc |
| 143 | 155 |
| 144 #endif // CC_RASTER_ONE_COPY_TILE_TASK_WORKER_POOL_H_ | 156 #endif // CC_RASTER_ONE_COPY_TILE_TASK_WORKER_POOL_H_ |
| OLD | NEW |