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 "cc/raster/tile_task_worker_pool.h" | 5 #include "cc/raster/tile_task_worker_pool.h" |
6 | 6 |
7 #include "base/test/test_simple_task_runner.h" | 7 #include "base/test/test_simple_task_runner.h" |
8 #include "base/time/time.h" | 8 #include "base/time/time.h" |
9 #include "cc/debug/lap_timer.h" | 9 #include "cc/debug/lap_timer.h" |
10 #include "cc/output/context_provider.h" | 10 #include "cc/output/context_provider.h" |
(...skipping 143 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
154 public: | 154 public: |
155 PerfRasterTaskImpl(scoped_ptr<ScopedResource> resource, | 155 PerfRasterTaskImpl(scoped_ptr<ScopedResource> resource, |
156 ImageDecodeTask::Vector* dependencies) | 156 ImageDecodeTask::Vector* dependencies) |
157 : RasterTask(resource.get(), dependencies), resource_(resource.Pass()) {} | 157 : RasterTask(resource.get(), dependencies), resource_(resource.Pass()) {} |
158 | 158 |
159 // Overridden from Task: | 159 // Overridden from Task: |
160 void RunOnWorkerThread() override {} | 160 void RunOnWorkerThread() override {} |
161 | 161 |
162 // Overridden from TileTask: | 162 // Overridden from TileTask: |
163 void ScheduleOnOriginThread(TileTaskClient* client) override { | 163 void ScheduleOnOriginThread(TileTaskClient* client) override { |
164 raster_buffer_ = client->AcquireBufferForRaster(resource()); | 164 // No tile ids are given to support partial updates. |
| 165 raster_buffer_ = client->AcquireBufferForRaster(resource(), 0, 0); |
165 } | 166 } |
166 void CompleteOnOriginThread(TileTaskClient* client) override { | 167 void CompleteOnOriginThread(TileTaskClient* client) override { |
167 client->ReleaseBufferForRaster(raster_buffer_.Pass()); | 168 client->ReleaseBufferForRaster(raster_buffer_.Pass()); |
168 } | 169 } |
169 void RunReplyOnOriginThread() override { Reset(); } | 170 void RunReplyOnOriginThread() override { Reset(); } |
170 | 171 |
171 void Reset() { | 172 void Reset() { |
172 did_run_ = false; | 173 did_run_ = false; |
173 did_complete_ = false; | 174 did_complete_ = false; |
174 } | 175 } |
(...skipping 88 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
263 task_runner_.get(), task_graph_runner_.get(), | 264 task_runner_.get(), task_graph_runner_.get(), |
264 resource_provider_.get()); | 265 resource_provider_.get()); |
265 break; | 266 break; |
266 case TILE_TASK_WORKER_POOL_TYPE_ONE_COPY: | 267 case TILE_TASK_WORKER_POOL_TYPE_ONE_COPY: |
267 Create3dOutputSurfaceAndResourceProvider(); | 268 Create3dOutputSurfaceAndResourceProvider(); |
268 staging_resource_pool_ = ResourcePool::Create(resource_provider_.get(), | 269 staging_resource_pool_ = ResourcePool::Create(resource_provider_.get(), |
269 GL_TEXTURE_2D); | 270 GL_TEXTURE_2D); |
270 tile_task_worker_pool_ = OneCopyTileTaskWorkerPool::Create( | 271 tile_task_worker_pool_ = OneCopyTileTaskWorkerPool::Create( |
271 task_runner_.get(), task_graph_runner_.get(), | 272 task_runner_.get(), task_graph_runner_.get(), |
272 context_provider_.get(), resource_provider_.get(), | 273 context_provider_.get(), resource_provider_.get(), |
273 staging_resource_pool_.get(), std::numeric_limits<size_t>::max()); | 274 staging_resource_pool_.get(), std::numeric_limits<size_t>::max(), |
| 275 false); |
274 break; | 276 break; |
275 case TILE_TASK_WORKER_POOL_TYPE_GPU: | 277 case TILE_TASK_WORKER_POOL_TYPE_GPU: |
276 Create3dOutputSurfaceAndResourceProvider(); | 278 Create3dOutputSurfaceAndResourceProvider(); |
277 tile_task_worker_pool_ = GpuTileTaskWorkerPool::Create( | 279 tile_task_worker_pool_ = GpuTileTaskWorkerPool::Create( |
278 task_runner_.get(), task_graph_runner_.get(), | 280 task_runner_.get(), task_graph_runner_.get(), |
279 context_provider_.get(), resource_provider_.get(), false, 0); | 281 context_provider_.get(), resource_provider_.get(), false, 0); |
280 break; | 282 break; |
281 case TILE_TASK_WORKER_POOL_TYPE_BITMAP: | 283 case TILE_TASK_WORKER_POOL_TYPE_BITMAP: |
282 CreateSoftwareOutputSurfaceAndResourceProvider(); | 284 CreateSoftwareOutputSurfaceAndResourceProvider(); |
283 tile_task_worker_pool_ = BitmapTileTaskWorkerPool::Create( | 285 tile_task_worker_pool_ = BitmapTileTaskWorkerPool::Create( |
(...skipping 226 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
510 RunBuildTileTaskQueueTest("1_0", 1, 0); | 512 RunBuildTileTaskQueueTest("1_0", 1, 0); |
511 RunBuildTileTaskQueueTest("32_0", 32, 0); | 513 RunBuildTileTaskQueueTest("32_0", 32, 0); |
512 RunBuildTileTaskQueueTest("1_1", 1, 1); | 514 RunBuildTileTaskQueueTest("1_1", 1, 1); |
513 RunBuildTileTaskQueueTest("32_1", 32, 1); | 515 RunBuildTileTaskQueueTest("32_1", 32, 1); |
514 RunBuildTileTaskQueueTest("1_4", 1, 4); | 516 RunBuildTileTaskQueueTest("1_4", 1, 4); |
515 RunBuildTileTaskQueueTest("32_4", 32, 4); | 517 RunBuildTileTaskQueueTest("32_4", 32, 4); |
516 } | 518 } |
517 | 519 |
518 } // namespace | 520 } // namespace |
519 } // namespace cc | 521 } // namespace cc |
OLD | NEW |