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 TileTaskData& data) override; |
57 void ReleaseBufferForRaster(scoped_ptr<RasterBuffer> buffer) override; | 58 void ReleaseBufferForRaster(scoped_ptr<RasterBuffer> buffer) override; |
58 | 59 |
59 // Playback raster source and schedule copy of |src| resource to |dst| | 60 // Playback raster source and schedule copy of |raster_resource| resource to |
60 // resource. Returns a non-zero sequence number for this copy operation. | 61 // |data|'s resource. Returns a non-zero sequence number for this copy |
62 // operation. | |
61 CopySequenceNumber PlaybackAndScheduleCopyOnWorkerThread( | 63 CopySequenceNumber PlaybackAndScheduleCopyOnWorkerThread( |
62 scoped_ptr<ResourceProvider::ScopedWriteLockGpuMemoryBuffer> write_lock, | 64 bool reusing_raster_resource, |
63 const Resource* src, | 65 scoped_ptr<ResourceProvider::ScopedWriteLockGpuMemoryBuffer> |
64 const Resource* dst, | 66 raster_resource_write_lock, |
67 const Resource* raster_resource, | |
68 const Resource* upload_resource, | |
reveman
2015/05/28 05:07:24
s/upload/copy/. what's wrong with |write_lock|, |s
danakj
2015/05/28 18:54:46
see previous comment?
| |
65 const RasterSource* raster_source, | 69 const RasterSource* raster_source, |
66 const gfx::Rect& rect, | 70 const gfx::Rect& raster_full_rect, |
71 const gfx::Rect& raster_dirty_rect, | |
67 float scale); | 72 float scale); |
68 | 73 |
69 // Issues copy operations until |sequence| has been processed. This will | 74 // Issues copy operations until |sequence| has been processed. This will |
70 // return immediately if |sequence| has already been processed. | 75 // return immediately if |sequence| has already been processed. |
71 void AdvanceLastIssuedCopyTo(CopySequenceNumber sequence); | 76 void AdvanceLastIssuedCopyTo(CopySequenceNumber sequence); |
72 | 77 |
78 bool have_persistent_gpu_memory_buffers() const { | |
79 return have_persistent_gpu_memory_buffers_; | |
80 } | |
81 | |
73 protected: | 82 protected: |
74 OneCopyTileTaskWorkerPool(base::SequencedTaskRunner* task_runner, | 83 OneCopyTileTaskWorkerPool(base::SequencedTaskRunner* task_runner, |
75 TaskGraphRunner* task_graph_runner, | 84 TaskGraphRunner* task_graph_runner, |
76 ContextProvider* context_provider, | 85 ContextProvider* context_provider, |
77 ResourceProvider* resource_provider, | 86 ResourceProvider* resource_provider, |
78 ResourcePool* resource_pool, | 87 ResourcePool* resource_pool, |
79 size_t max_bytes_per_copy_operation); | 88 size_t max_bytes_per_copy_operation, |
89 bool have_persistent_gpu_memory_buffers); | |
80 | 90 |
81 private: | 91 private: |
82 struct CopyOperation { | 92 struct CopyOperation { |
83 typedef ScopedPtrDeque<CopyOperation> Deque; | 93 typedef ScopedPtrDeque<CopyOperation> Deque; |
84 | 94 |
85 CopyOperation( | 95 CopyOperation(scoped_ptr<ResourceProvider::ScopedWriteLockGpuMemoryBuffer> |
86 scoped_ptr<ResourceProvider::ScopedWriteLockGpuMemoryBuffer> write_lock, | 96 raster_resource_write_lock, |
87 const Resource* src, | 97 const Resource* src, |
88 const Resource* dst, | 98 const Resource* dst, |
89 const gfx::Rect& rect); | 99 const gfx::Rect& rect); |
90 ~CopyOperation(); | 100 ~CopyOperation(); |
91 | 101 |
92 scoped_ptr<ResourceProvider::ScopedWriteLockGpuMemoryBuffer> write_lock; | 102 scoped_ptr<ResourceProvider::ScopedWriteLockGpuMemoryBuffer> src_write_lock; |
reveman
2015/05/28 05:07:24
is this name change necessary?
| |
93 const Resource* src; | 103 const Resource* src; |
94 const Resource* dst; | 104 const Resource* dst; |
95 const gfx::Rect rect; | 105 const gfx::Rect rect; |
96 }; | 106 }; |
97 | 107 |
98 void OnTaskSetFinished(TaskSet task_set); | 108 void OnTaskSetFinished(TaskSet task_set); |
99 void AdvanceLastFlushedCopyTo(CopySequenceNumber sequence); | 109 void AdvanceLastFlushedCopyTo(CopySequenceNumber sequence); |
100 void IssueCopyOperations(int64 count); | 110 void IssueCopyOperations(int64 count); |
101 void ScheduleCheckForCompletedCopyOperationsWithLockAcquired( | 111 void ScheduleCheckForCompletedCopyOperationsWithLockAcquired( |
102 bool wait_if_needed); | 112 bool wait_if_needed); |
103 void CheckForCompletedCopyOperations(bool wait_if_needed); | 113 void CheckForCompletedCopyOperations(bool wait_if_needed); |
104 scoped_refptr<base::trace_event::ConvertableToTraceFormat> StateAsValue() | 114 scoped_refptr<base::trace_event::ConvertableToTraceFormat> StateAsValue() |
105 const; | 115 const; |
106 void StagingStateAsValueInto( | 116 void StagingStateAsValueInto( |
107 base::trace_event::TracedValue* staging_state) const; | 117 base::trace_event::TracedValue* staging_state) const; |
108 | 118 |
109 scoped_refptr<base::SequencedTaskRunner> task_runner_; | 119 scoped_refptr<base::SequencedTaskRunner> task_runner_; |
110 TaskGraphRunner* task_graph_runner_; | 120 TaskGraphRunner* task_graph_runner_; |
111 const NamespaceToken namespace_token_; | 121 const NamespaceToken namespace_token_; |
112 TileTaskRunnerClient* client_; | 122 TileTaskRunnerClient* client_; |
113 ContextProvider* context_provider_; | 123 ContextProvider* context_provider_; |
114 ResourceProvider* resource_provider_; | 124 ResourceProvider* resource_provider_; |
115 ResourcePool* resource_pool_; | 125 ResourcePool* resource_pool_; |
116 const size_t max_bytes_per_copy_operation_; | 126 const size_t max_bytes_per_copy_operation_; |
127 const bool have_persistent_gpu_memory_buffers_; | |
117 TaskSetCollection tasks_pending_; | 128 TaskSetCollection tasks_pending_; |
118 scoped_refptr<TileTask> task_set_finished_tasks_[kNumberOfTaskSets]; | 129 scoped_refptr<TileTask> task_set_finished_tasks_[kNumberOfTaskSets]; |
119 CopySequenceNumber last_issued_copy_operation_; | 130 CopySequenceNumber last_issued_copy_operation_; |
120 CopySequenceNumber last_flushed_copy_operation_; | 131 CopySequenceNumber last_flushed_copy_operation_; |
121 | 132 |
122 // Task graph used when scheduling tasks and vector used to gather | 133 // Task graph used when scheduling tasks and vector used to gather |
123 // completed tasks. | 134 // completed tasks. |
124 TaskGraph graph_; | 135 TaskGraph graph_; |
125 Task::Vector completed_tasks_; | 136 Task::Vector completed_tasks_; |
126 | 137 |
(...skipping 12 matching lines...) Expand all Loading... | |
139 // canceled when ScheduleTasks() is called. | 150 // canceled when ScheduleTasks() is called. |
140 base::WeakPtrFactory<OneCopyTileTaskWorkerPool> | 151 base::WeakPtrFactory<OneCopyTileTaskWorkerPool> |
141 task_set_finished_weak_ptr_factory_; | 152 task_set_finished_weak_ptr_factory_; |
142 | 153 |
143 DISALLOW_COPY_AND_ASSIGN(OneCopyTileTaskWorkerPool); | 154 DISALLOW_COPY_AND_ASSIGN(OneCopyTileTaskWorkerPool); |
144 }; | 155 }; |
145 | 156 |
146 } // namespace cc | 157 } // namespace cc |
147 | 158 |
148 #endif // CC_RASTER_ONE_COPY_TILE_TASK_WORKER_POOL_H_ | 159 #endif // CC_RASTER_ONE_COPY_TILE_TASK_WORKER_POOL_H_ |
OLD | NEW |