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

Side by Side Diff: cc/resources/gpu_raster_worker_pool.cc

Issue 523243002: cc: Generalize raster task notifications (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Renaming Created 6 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
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/resources/gpu_raster_worker_pool.h" 5 #include "cc/resources/gpu_raster_worker_pool.h"
6 6
7 #include <algorithm>
8
7 #include "base/debug/trace_event.h" 9 #include "base/debug/trace_event.h"
8 #include "cc/output/context_provider.h" 10 #include "cc/output/context_provider.h"
9 #include "cc/resources/resource.h" 11 #include "cc/resources/resource.h"
10 #include "cc/resources/resource_provider.h" 12 #include "cc/resources/resource_provider.h"
11 #include "cc/resources/scoped_gpu_raster.h" 13 #include "cc/resources/scoped_gpu_raster.h"
12 #include "gpu/command_buffer/client/gles2_interface.h" 14 #include "gpu/command_buffer/client/gles2_interface.h"
13 #include "third_party/skia/include/gpu/GrContext.h" 15 #include "third_party/skia/include/gpu/GrContext.h"
14 16
15 namespace cc { 17 namespace cc {
16 18
17 // static 19 // static
18 scoped_ptr<RasterWorkerPool> GpuRasterWorkerPool::Create( 20 scoped_ptr<RasterWorkerPool> GpuRasterWorkerPool::Create(
19 base::SequencedTaskRunner* task_runner, 21 base::SequencedTaskRunner* task_runner,
20 ContextProvider* context_provider, 22 ContextProvider* context_provider,
21 ResourceProvider* resource_provider) { 23 ResourceProvider* resource_provider) {
22 return make_scoped_ptr<RasterWorkerPool>(new GpuRasterWorkerPool( 24 return make_scoped_ptr<RasterWorkerPool>(new GpuRasterWorkerPool(
23 task_runner, context_provider, resource_provider)); 25 task_runner, context_provider, resource_provider));
24 } 26 }
25 27
26 GpuRasterWorkerPool::GpuRasterWorkerPool(base::SequencedTaskRunner* task_runner, 28 GpuRasterWorkerPool::GpuRasterWorkerPool(base::SequencedTaskRunner* task_runner,
27 ContextProvider* context_provider, 29 ContextProvider* context_provider,
28 ResourceProvider* resource_provider) 30 ResourceProvider* resource_provider)
29 : task_runner_(task_runner), 31 : task_runner_(task_runner),
30 task_graph_runner_(new TaskGraphRunner), 32 task_graph_runner_(new TaskGraphRunner),
31 namespace_token_(task_graph_runner_->GetNamespaceToken()), 33 namespace_token_(task_graph_runner_->GetNamespaceToken()),
32 context_provider_(context_provider), 34 context_provider_(context_provider),
33 resource_provider_(resource_provider), 35 resource_provider_(resource_provider),
34 run_tasks_on_origin_thread_pending_(false), 36 run_tasks_on_origin_thread_pending_(false),
35 raster_tasks_pending_(false),
36 raster_tasks_required_for_activation_pending_(false),
37 raster_finished_weak_ptr_factory_(this), 37 raster_finished_weak_ptr_factory_(this),
38 weak_ptr_factory_(this) { 38 weak_ptr_factory_(this) {
39 DCHECK(context_provider_); 39 DCHECK(context_provider_);
40 } 40 }
41 41
42 GpuRasterWorkerPool::~GpuRasterWorkerPool() { 42 GpuRasterWorkerPool::~GpuRasterWorkerPool() {
43 DCHECK_EQ(0u, completed_tasks_.size()); 43 DCHECK_EQ(0u, completed_tasks_.size());
44 } 44 }
45 45
46 Rasterizer* GpuRasterWorkerPool::AsRasterizer() { 46 Rasterizer* GpuRasterWorkerPool::AsRasterizer() {
47 return this; 47 return this;
48 } 48 }
49 49
50 void GpuRasterWorkerPool::SetClient(RasterizerClient* client) { 50 void GpuRasterWorkerPool::SetClient(RasterizerClient* client) {
51 client_ = client; 51 client_ = client;
52 } 52 }
53 53
54 void GpuRasterWorkerPool::Shutdown() { 54 void GpuRasterWorkerPool::Shutdown() {
55 TRACE_EVENT0("cc", "GpuRasterWorkerPool::Shutdown"); 55 TRACE_EVENT0("cc", "GpuRasterWorkerPool::Shutdown");
56 56
57 TaskGraph empty; 57 TaskGraph empty;
58 task_graph_runner_->ScheduleTasks(namespace_token_, &empty); 58 task_graph_runner_->ScheduleTasks(namespace_token_, &empty);
59 task_graph_runner_->WaitForTasksToFinishRunning(namespace_token_); 59 task_graph_runner_->WaitForTasksToFinishRunning(namespace_token_);
60 } 60 }
61 61
62 void GpuRasterWorkerPool::ScheduleTasks(RasterTaskQueue* queue) { 62 void GpuRasterWorkerPool::ScheduleTasks(RasterTaskQueue* queue) {
63 TRACE_EVENT0("cc", "GpuRasterWorkerPool::ScheduleTasks"); 63 TRACE_EVENT0("cc", "GpuRasterWorkerPool::ScheduleTasks");
64 64
65 DCHECK_EQ(queue->required_for_activation_count, 65 // Mark all task sets as pending.
66 static_cast<size_t>( 66 raster_pending_.set();
67 std::count_if(queue->items.begin(),
68 queue->items.end(),
69 RasterTaskQueue::Item::IsRequiredForActivation)));
70
71 raster_tasks_pending_ = true;
72 raster_tasks_required_for_activation_pending_ = true;
73 67
74 unsigned priority = kRasterTaskPriorityBase; 68 unsigned priority = kRasterTaskPriorityBase;
75 69
76 graph_.Reset(); 70 graph_.Reset();
77 71
78 // Cancel existing OnRasterFinished callbacks. 72 // Cancel existing OnRasterFinished callbacks.
79 raster_finished_weak_ptr_factory_.InvalidateWeakPtrs(); 73 raster_finished_weak_ptr_factory_.InvalidateWeakPtrs();
80 74
81 scoped_refptr<RasterizerTask> 75 scoped_refptr<RasterizerTask> new_raster_finished_tasks[kNumberOfTaskSets];
82 new_raster_required_for_activation_finished_task( 76
83 CreateRasterRequiredForActivationFinishedTask( 77 TaskSetSizes task_set_sizes(queue);
84 queue->required_for_activation_count, 78
85 task_runner_.get(), 79 for (TaskSet task_set = 0; task_set < kNumberOfTaskSets; ++task_set) {
86 base::Bind( 80 base::debug::TraceEventSyntheticDelay* synthetic_delay = NULL;
87 &GpuRasterWorkerPool::OnRasterRequiredForActivationFinished, 81 if (task_set_sizes[task_set] > 0)
88 raster_finished_weak_ptr_factory_.GetWeakPtr()))); 82 synthetic_delay = client_->SyntheticDelayForTasks(task_set);
89 scoped_refptr<RasterizerTask> new_raster_finished_task( 83
90 CreateRasterFinishedTask( 84 new_raster_finished_tasks[task_set] = CreateRasterFinishedTask(
91 task_runner_.get(), 85 task_runner_.get(),
92 base::Bind(&GpuRasterWorkerPool::OnRasterFinished, 86 base::Bind(&GpuRasterWorkerPool::OnRasterFinished,
93 raster_finished_weak_ptr_factory_.GetWeakPtr()))); 87 raster_finished_weak_ptr_factory_.GetWeakPtr(),
88 task_set),
89 synthetic_delay);
90 }
94 91
95 for (RasterTaskQueue::Item::Vector::const_iterator it = queue->items.begin(); 92 for (RasterTaskQueue::Item::Vector::const_iterator it = queue->items.begin();
96 it != queue->items.end(); 93 it != queue->items.end();
97 ++it) { 94 ++it) {
98 const RasterTaskQueue::Item& item = *it; 95 const RasterTaskQueue::Item& item = *it;
99 RasterTask* task = item.task; 96 RasterTask* task = item.task;
100 DCHECK(!task->HasCompleted()); 97 DCHECK(!task->HasCompleted());
101 98
102 if (item.required_for_activation) { 99 for (TaskSet task_set = 0; task_set < kNumberOfTaskSets; task_set++) {
reveman 2014/09/10 19:41:27 As the intent of this loop is to iterate over all
ernstm 2014/09/11 21:15:53 std::bitset doesn't have iterators, and I think ad
reveman 2014/09/12 16:33:51 While it might not make sense for std::bitset to h
103 graph_.edges.push_back(TaskGraph::Edge( 100 if (!item.task_sets[task_set])
104 task, new_raster_required_for_activation_finished_task.get())); 101 continue;
102
103 graph_.edges.push_back(
104 TaskGraph::Edge(task, new_raster_finished_tasks[task_set].get()));
105 } 105 }
106 106
107 InsertNodesForRasterTask(&graph_, task, task->dependencies(), priority++); 107 InsertNodesForRasterTask(&graph_, task, task->dependencies(), priority++);
108
109 graph_.edges.push_back(
110 TaskGraph::Edge(task, new_raster_finished_task.get()));
111 } 108 }
112 109
113 InsertNodeForTask(&graph_, 110 for (TaskSet task_set = 0; task_set < kNumberOfTaskSets; task_set++) {
114 new_raster_required_for_activation_finished_task.get(), 111 InsertNodeForTask(&graph_,
115 kRasterRequiredForActivationFinishedTaskPriority, 112 new_raster_finished_tasks[task_set].get(),
116 queue->required_for_activation_count); 113 kRasterFinishedTaskPriority,
117 InsertNodeForTask(&graph_, 114 task_set_sizes[task_set]);
118 new_raster_finished_task.get(), 115 }
119 kRasterFinishedTaskPriority,
120 queue->items.size());
121 116
122 ScheduleTasksOnOriginThread(this, &graph_); 117 ScheduleTasksOnOriginThread(this, &graph_);
123 task_graph_runner_->ScheduleTasks(namespace_token_, &graph_); 118 task_graph_runner_->ScheduleTasks(namespace_token_, &graph_);
124 119
125 ScheduleRunTasksOnOriginThread(); 120 ScheduleRunTasksOnOriginThread();
126 121
127 raster_finished_task_ = new_raster_finished_task; 122 std::copy(new_raster_finished_tasks,
128 raster_required_for_activation_finished_task_ = 123 new_raster_finished_tasks + kNumberOfTaskSets,
129 new_raster_required_for_activation_finished_task; 124 raster_finished_tasks_);
130 } 125 }
131 126
132 void GpuRasterWorkerPool::CheckForCompletedTasks() { 127 void GpuRasterWorkerPool::CheckForCompletedTasks() {
133 TRACE_EVENT0("cc", "GpuRasterWorkerPool::CheckForCompletedTasks"); 128 TRACE_EVENT0("cc", "GpuRasterWorkerPool::CheckForCompletedTasks");
134 129
135 task_graph_runner_->CollectCompletedTasks(namespace_token_, 130 task_graph_runner_->CollectCompletedTasks(namespace_token_,
136 &completed_tasks_); 131 &completed_tasks_);
137 for (Task::Vector::const_iterator it = completed_tasks_.begin(); 132 for (Task::Vector::const_iterator it = completed_tasks_.begin();
138 it != completed_tasks_.end(); 133 it != completed_tasks_.end();
139 ++it) { 134 ++it) {
140 RasterizerTask* task = static_cast<RasterizerTask*>(it->get()); 135 RasterizerTask* task = static_cast<RasterizerTask*>(it->get());
141 136
142 task->WillComplete(); 137 task->WillComplete();
143 task->CompleteOnOriginThread(this); 138 task->CompleteOnOriginThread(this);
144 task->DidComplete(); 139 task->DidComplete();
145 140
146 task->RunReplyOnOriginThread(); 141 task->RunReplyOnOriginThread();
147 } 142 }
148 completed_tasks_.clear(); 143 completed_tasks_.clear();
149 } 144 }
150 145
151 RasterBuffer* GpuRasterWorkerPool::AcquireBufferForRaster(RasterTask* task) { 146 RasterBuffer* GpuRasterWorkerPool::AcquireBufferForRaster(RasterTask* task) {
152 return resource_provider_->AcquireGpuRasterBuffer(task->resource()->id()); 147 return resource_provider_->AcquireGpuRasterBuffer(task->resource()->id());
153 } 148 }
154 149
155 void GpuRasterWorkerPool::ReleaseBufferForRaster(RasterTask* task) { 150 void GpuRasterWorkerPool::ReleaseBufferForRaster(RasterTask* task) {
156 resource_provider_->ReleaseGpuRasterBuffer(task->resource()->id()); 151 resource_provider_->ReleaseGpuRasterBuffer(task->resource()->id());
157 } 152 }
158 153
159 void GpuRasterWorkerPool::OnRasterFinished() { 154 void GpuRasterWorkerPool::OnRasterFinished(TaskSet task_set) {
160 TRACE_EVENT0("cc", "GpuRasterWorkerPool::OnRasterFinished"); 155 TRACE_EVENT1(
156 "cc", "GpuRasterWorkerPool::OnRasterFinished", "task_set", task_set);
161 157
162 DCHECK(raster_tasks_pending_); 158 DCHECK(raster_pending_[task_set]);
163 raster_tasks_pending_ = false; 159 raster_pending_[task_set] = false;
164 client_->DidFinishRunningTasks(); 160 client_->DidFinishRunningTasks(task_set);
165 }
166
167 void GpuRasterWorkerPool::OnRasterRequiredForActivationFinished() {
168 TRACE_EVENT0("cc",
169 "GpuRasterWorkerPool::OnRasterRequiredForActivationFinished");
170
171 DCHECK(raster_tasks_required_for_activation_pending_);
172 raster_tasks_required_for_activation_pending_ = false;
173 client_->DidFinishRunningTasksRequiredForActivation();
174 } 161 }
175 162
176 void GpuRasterWorkerPool::ScheduleRunTasksOnOriginThread() { 163 void GpuRasterWorkerPool::ScheduleRunTasksOnOriginThread() {
177 if (run_tasks_on_origin_thread_pending_) 164 if (run_tasks_on_origin_thread_pending_)
178 return; 165 return;
179 166
180 task_runner_->PostTask( 167 task_runner_->PostTask(
181 FROM_HERE, 168 FROM_HERE,
182 base::Bind(&GpuRasterWorkerPool::RunTasksOnOriginThread, 169 base::Bind(&GpuRasterWorkerPool::RunTasksOnOriginThread,
183 weak_ptr_factory_.GetWeakPtr())); 170 weak_ptr_factory_.GetWeakPtr()));
184 run_tasks_on_origin_thread_pending_ = true; 171 run_tasks_on_origin_thread_pending_ = true;
185 } 172 }
186 173
187 void GpuRasterWorkerPool::RunTasksOnOriginThread() { 174 void GpuRasterWorkerPool::RunTasksOnOriginThread() {
188 TRACE_EVENT0("cc", "GpuRasterWorkerPool::RunTasksOnOriginThread"); 175 TRACE_EVENT0("cc", "GpuRasterWorkerPool::RunTasksOnOriginThread");
189 176
190 DCHECK(run_tasks_on_origin_thread_pending_); 177 DCHECK(run_tasks_on_origin_thread_pending_);
191 run_tasks_on_origin_thread_pending_ = false; 178 run_tasks_on_origin_thread_pending_ = false;
192 179
193 ScopedGpuRaster gpu_raster(context_provider_); 180 ScopedGpuRaster gpu_raster(context_provider_);
194 task_graph_runner_->RunUntilIdle(); 181 task_graph_runner_->RunUntilIdle();
195 } 182 }
196 183
197 } // namespace cc 184 } // namespace cc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698