Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(342)

Side by Side Diff: cc/raster/gpu_tile_task_worker_pool.cc

Issue 1351283003: Allow task pools to reason about transparency. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Make StagingBuffer constructor non-explicit Created 5 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « cc/raster/gpu_tile_task_worker_pool.h ('k') | cc/raster/one_copy_tile_task_worker_pool.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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 #include "cc/raster/gpu_tile_task_worker_pool.h" 5 #include "cc/raster/gpu_tile_task_worker_pool.h"
6 6
7 #include <algorithm> 7 #include <algorithm>
8 8
9 #include "base/trace_event/trace_event.h" 9 #include "base/trace_event/trace_event.h"
10 #include "cc/playback/raster_source.h" 10 #include "cc/playback/raster_source.h"
(...skipping 183 matching lines...) Expand 10 before | Expand all | Expand 10 after
194 194
195 void GpuTileTaskWorkerPool::CheckForCompletedTasks() { 195 void GpuTileTaskWorkerPool::CheckForCompletedTasks() {
196 TRACE_EVENT0("cc", "GpuTileTaskWorkerPool::CheckForCompletedTasks"); 196 TRACE_EVENT0("cc", "GpuTileTaskWorkerPool::CheckForCompletedTasks");
197 197
198 task_graph_runner_->CollectCompletedTasks(namespace_token_, 198 task_graph_runner_->CollectCompletedTasks(namespace_token_,
199 &completed_tasks_); 199 &completed_tasks_);
200 CompleteTasks(completed_tasks_); 200 CompleteTasks(completed_tasks_);
201 completed_tasks_.clear(); 201 completed_tasks_.clear();
202 } 202 }
203 203
204 ResourceFormat GpuTileTaskWorkerPool::GetResourceFormat() const { 204 ResourceFormat GpuTileTaskWorkerPool::GetResourceFormat(
205 bool must_support_alpha) const {
205 return rasterizer_->resource_provider()->best_render_buffer_format(); 206 return rasterizer_->resource_provider()->best_render_buffer_format();
206 } 207 }
207 208
208 bool GpuTileTaskWorkerPool::GetResourceRequiresSwizzle() const { 209 bool GpuTileTaskWorkerPool::GetResourceRequiresSwizzle(
210 bool must_support_alpha) const {
209 // This doesn't require a swizzle because we rasterize to the correct format. 211 // This doesn't require a swizzle because we rasterize to the correct format.
210 return false; 212 return false;
211 } 213 }
212 214
213 void GpuTileTaskWorkerPool::CompleteTasks(const Task::Vector& tasks) { 215 void GpuTileTaskWorkerPool::CompleteTasks(const Task::Vector& tasks) {
214 for (auto& task : tasks) { 216 for (auto& task : tasks) {
215 TileTask* tile_task = static_cast<TileTask*>(task.get()); 217 TileTask* tile_task = static_cast<TileTask*>(task.get());
216 218
217 tile_task->WillComplete(); 219 tile_task->WillComplete();
218 tile_task->CompleteOnOriginThread(this); 220 tile_task->CompleteOnOriginThread(this);
(...skipping 18 matching lines...) Expand all
237 void GpuTileTaskWorkerPool::OnTaskSetFinished(TaskSet task_set) { 239 void GpuTileTaskWorkerPool::OnTaskSetFinished(TaskSet task_set) {
238 TRACE_EVENT1("cc", "GpuTileTaskWorkerPool::OnTaskSetFinished", "task_set", 240 TRACE_EVENT1("cc", "GpuTileTaskWorkerPool::OnTaskSetFinished", "task_set",
239 task_set); 241 task_set);
240 242
241 DCHECK(tasks_pending_[task_set]); 243 DCHECK(tasks_pending_[task_set]);
242 tasks_pending_[task_set] = false; 244 tasks_pending_[task_set] = false;
243 client_->DidFinishRunningTileTasks(task_set); 245 client_->DidFinishRunningTileTasks(task_set);
244 } 246 }
245 247
246 } // namespace cc 248 } // namespace cc
OLDNEW
« no previous file with comments | « cc/raster/gpu_tile_task_worker_pool.h ('k') | cc/raster/one_copy_tile_task_worker_pool.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698