OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 #include <stddef.h> | 5 #include <stddef.h> |
6 #include <stdint.h> | 6 #include <stdint.h> |
7 | 7 |
8 #include "base/macros.h" | 8 #include "base/macros.h" |
9 #include "base/memory/ptr_util.h" | 9 #include "base/memory/ptr_util.h" |
10 #include "base/test/test_simple_task_runner.h" | 10 #include "base/test/test_simple_task_runner.h" |
(...skipping 103 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
114 RASTER_BUFFER_PROVIDER_TYPE_ZERO_COPY, | 114 RASTER_BUFFER_PROVIDER_TYPE_ZERO_COPY, |
115 RASTER_BUFFER_PROVIDER_TYPE_ONE_COPY, | 115 RASTER_BUFFER_PROVIDER_TYPE_ONE_COPY, |
116 RASTER_BUFFER_PROVIDER_TYPE_GPU, | 116 RASTER_BUFFER_PROVIDER_TYPE_GPU, |
117 RASTER_BUFFER_PROVIDER_TYPE_BITMAP | 117 RASTER_BUFFER_PROVIDER_TYPE_BITMAP |
118 }; | 118 }; |
119 | 119 |
120 static const int kTimeLimitMillis = 2000; | 120 static const int kTimeLimitMillis = 2000; |
121 static const int kWarmupRuns = 5; | 121 static const int kWarmupRuns = 5; |
122 static const int kTimeCheckInterval = 10; | 122 static const int kTimeCheckInterval = 10; |
123 | 123 |
124 class PerfImageDecodeTaskImpl : public TileTask { | 124 class PerfTileTask : public TileTask { |
125 public: | 125 public: |
126 PerfImageDecodeTaskImpl() : TileTask(true) {} | 126 PerfTileTask() : TileTask(true) {} |
| 127 explicit PerfTileTask(TileTask::Vector* dependencies) |
| 128 : TileTask(true, dependencies) {} |
| 129 |
| 130 void Reset() { |
| 131 did_complete_ = false; |
| 132 state().Reset(); |
| 133 } |
| 134 |
| 135 void Cancel() { |
| 136 if (!state().IsCanceled()) |
| 137 state().DidCancel(); |
| 138 |
| 139 did_complete_ = true; |
| 140 } |
| 141 |
| 142 protected: |
| 143 ~PerfTileTask() override {} |
| 144 }; |
| 145 |
| 146 class PerfImageDecodeTaskImpl : public PerfTileTask { |
| 147 public: |
| 148 PerfImageDecodeTaskImpl() {} |
127 | 149 |
128 // Overridden from Task: | 150 // Overridden from Task: |
129 void RunOnWorkerThread() override {} | 151 void RunOnWorkerThread() override {} |
130 | 152 |
131 // Overridden from TileTask: | 153 // Overridden from TileTask: |
132 void OnTaskCompleted() override {} | 154 void OnTaskCompleted() override {} |
133 | 155 |
134 protected: | 156 protected: |
135 ~PerfImageDecodeTaskImpl() override {} | 157 ~PerfImageDecodeTaskImpl() override {} |
136 | 158 |
137 private: | 159 private: |
138 DISALLOW_COPY_AND_ASSIGN(PerfImageDecodeTaskImpl); | 160 DISALLOW_COPY_AND_ASSIGN(PerfImageDecodeTaskImpl); |
139 }; | 161 }; |
140 | 162 |
141 class PerfRasterBufferProviderHelper { | 163 class PerfRasterBufferProviderHelper { |
142 public: | 164 public: |
143 virtual std::unique_ptr<RasterBuffer> AcquireBufferForRaster( | 165 virtual std::unique_ptr<RasterBuffer> AcquireBufferForRaster( |
144 const Resource* resource, | 166 const Resource* resource, |
145 uint64_t resource_content_id, | 167 uint64_t resource_content_id, |
146 uint64_t previous_content_id) = 0; | 168 uint64_t previous_content_id) = 0; |
147 virtual void ReleaseBufferForRaster(std::unique_ptr<RasterBuffer> buffer) = 0; | 169 virtual void ReleaseBufferForRaster(std::unique_ptr<RasterBuffer> buffer) = 0; |
148 }; | 170 }; |
149 | 171 |
150 class PerfRasterTaskImpl : public TileTask { | 172 class PerfRasterTaskImpl : public PerfTileTask { |
151 public: | 173 public: |
152 PerfRasterTaskImpl(PerfRasterBufferProviderHelper* helper, | 174 PerfRasterTaskImpl(PerfRasterBufferProviderHelper* helper, |
153 std::unique_ptr<ScopedResource> resource, | 175 std::unique_ptr<ScopedResource> resource, |
154 std::unique_ptr<RasterBuffer> raster_buffer, | 176 std::unique_ptr<RasterBuffer> raster_buffer, |
155 TileTask::Vector* dependencies) | 177 TileTask::Vector* dependencies) |
156 : TileTask(true, dependencies), | 178 : PerfTileTask(dependencies), |
157 helper_(helper), | 179 helper_(helper), |
158 resource_(std::move(resource)), | 180 resource_(std::move(resource)), |
159 raster_buffer_(std::move(raster_buffer)) {} | 181 raster_buffer_(std::move(raster_buffer)) {} |
160 | 182 |
161 // Overridden from Task: | 183 // Overridden from Task: |
162 void RunOnWorkerThread() override {} | 184 void RunOnWorkerThread() override {} |
163 | 185 |
164 // Overridden from TileTask: | 186 // Overridden from TileTask: |
165 void OnTaskCompleted() override { | 187 void OnTaskCompleted() override { |
166 if (helper_) | 188 if (helper_) |
(...skipping 52 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
219 TileTask::Vector dependencies = image_decode_tasks; | 241 TileTask::Vector dependencies = image_decode_tasks; |
220 raster_tasks->push_back( | 242 raster_tasks->push_back( |
221 new PerfRasterTaskImpl(helper, std::move(resource), | 243 new PerfRasterTaskImpl(helper, std::move(resource), |
222 std::move(raster_buffer), &dependencies)); | 244 std::move(raster_buffer), &dependencies)); |
223 } | 245 } |
224 } | 246 } |
225 | 247 |
226 void ResetRasterTasks(const RasterTaskVector& raster_tasks) { | 248 void ResetRasterTasks(const RasterTaskVector& raster_tasks) { |
227 for (auto& raster_task : raster_tasks) { | 249 for (auto& raster_task : raster_tasks) { |
228 for (auto& decode_task : raster_task->dependencies()) | 250 for (auto& decode_task : raster_task->dependencies()) |
229 decode_task->state().Reset(); | 251 static_cast<PerfTileTask*>(decode_task.get())->Reset(); |
230 | 252 |
231 raster_task->state().Reset(); | 253 static_cast<PerfTileTask*>(raster_task.get())->Reset(); |
232 } | 254 } |
233 } | 255 } |
234 | 256 |
235 void CancelRasterTasks(const RasterTaskVector& raster_tasks) { | 257 void CancelRasterTasks(const RasterTaskVector& raster_tasks) { |
236 for (auto& raster_task : raster_tasks) { | 258 for (auto& raster_task : raster_tasks) { |
237 for (auto& decode_task : raster_task->dependencies()) { | 259 for (auto& decode_task : raster_task->dependencies()) |
238 if (!decode_task->state().IsCanceled()) | 260 static_cast<PerfTileTask*>(decode_task.get())->Cancel(); |
239 decode_task->state().DidCancel(); | |
240 } | |
241 | 261 |
242 if (!raster_task->state().IsCanceled()) | 262 static_cast<PerfTileTask*>(raster_task.get())->Cancel(); |
243 raster_task->state().DidCancel(); | |
244 } | 263 } |
245 } | 264 } |
246 | 265 |
247 void BuildTileTaskGraph(TaskGraph* graph, | 266 void BuildTileTaskGraph(TaskGraph* graph, |
248 const RasterTaskVector& raster_tasks) { | 267 const RasterTaskVector& raster_tasks) { |
249 uint16_t priority = 0; | 268 uint16_t priority = 0; |
250 | 269 |
251 for (auto& raster_task : raster_tasks) { | 270 for (auto& raster_task : raster_tasks) { |
252 priority++; | 271 priority++; |
253 | 272 |
(...skipping 307 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
561 RunBuildTileTaskGraphTest("1_0", 1, 0); | 580 RunBuildTileTaskGraphTest("1_0", 1, 0); |
562 RunBuildTileTaskGraphTest("32_0", 32, 0); | 581 RunBuildTileTaskGraphTest("32_0", 32, 0); |
563 RunBuildTileTaskGraphTest("1_1", 1, 1); | 582 RunBuildTileTaskGraphTest("1_1", 1, 1); |
564 RunBuildTileTaskGraphTest("32_1", 32, 1); | 583 RunBuildTileTaskGraphTest("32_1", 32, 1); |
565 RunBuildTileTaskGraphTest("1_4", 1, 4); | 584 RunBuildTileTaskGraphTest("1_4", 1, 4); |
566 RunBuildTileTaskGraphTest("32_4", 32, 4); | 585 RunBuildTileTaskGraphTest("32_4", 32, 4); |
567 } | 586 } |
568 | 587 |
569 } // namespace | 588 } // namespace |
570 } // namespace cc | 589 } // namespace cc |
OLD | NEW |