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 // |data|'s resource. Returns a non-zero sequence number for this copy |
reveman
2015/05/29 14:50:27
nit: update comment, |data| -> X
danakj
2015/05/29 17:16:07
Done.
| |
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* upload_resource, | |
reveman
2015/05/29 14:50:27
nit: kill 'upload_' prefix. 'resource' alone is go
danakj
2015/05/29 17:16:07
ok output_resource everywhere.
| |
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 raster_resource_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; |
reveman
2015/05/29 14:50:27
nit: raster_resource_write_lock like the ctor?
danakj
2015/05/29 17:16:06
meant to leave CopyOperation as src/dst, fixed the
| |
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 |