| 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 |