[go: nahoru, domu]

blob: 9f78d388eb4d22808abc89635e94cae88bb49883 [file] [log] [blame]
prashant.nb4d4f492016-04-29 12:51:281// Copyright 2016 The Chromium Authors. All rights reserved.
2// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
5#include "cc/tiles/tile_task_manager.h"
6
7#include "base/memory/ptr_util.h"
8#include "base/trace_event/trace_event.h"
9
10namespace cc {
11
12TileTaskManager::TileTaskManager() {}
13
14TileTaskManager::~TileTaskManager() {}
15
16// static
17std::unique_ptr<TileTaskManagerImpl> TileTaskManagerImpl::Create(
18 std::unique_ptr<RasterBufferProvider> raster_buffer_provider,
19 TaskGraphRunner* task_graph_runner) {
20 return base::WrapUnique<TileTaskManagerImpl>(new TileTaskManagerImpl(
21 std::move(raster_buffer_provider), task_graph_runner));
22}
23
24TileTaskManagerImpl::TileTaskManagerImpl(
25 std::unique_ptr<RasterBufferProvider> raster_buffer_provider,
26 TaskGraphRunner* task_graph_runner)
27 : raster_buffer_provider_(std::move(raster_buffer_provider)),
28 task_graph_runner_(task_graph_runner),
29 namespace_token_(task_graph_runner->GetNamespaceToken()) {}
30
31TileTaskManagerImpl::~TileTaskManagerImpl() {
32 DCHECK_EQ(0u, completed_tasks_.size());
33}
34
35void TileTaskManagerImpl::ScheduleTasks(TaskGraph* graph) {
36 TRACE_EVENT0("cc", "TileTaskManagerImpl::ScheduleTasks");
37
38 for (TaskGraph::Node::Vector::iterator it = graph->nodes.begin();
39 it != graph->nodes.end(); ++it) {
40 TaskGraph::Node& node = *it;
41 TileTask* task = static_cast<TileTask*>(node.task);
42
43 if (!task->HasBeenScheduled()) {
44 task->WillSchedule();
45 task->ScheduleOnOriginThread(raster_buffer_provider_.get());
46 task->DidSchedule();
47 }
48 }
49
50 raster_buffer_provider_->OrderingBarrier();
51
52 task_graph_runner_->ScheduleTasks(namespace_token_, graph);
53}
54
55void TileTaskManagerImpl::CheckForCompletedTasks() {
56 TRACE_EVENT0("cc", "TileTaskManagerImpl::CheckForCompletedTasks");
57
58 task_graph_runner_->CollectCompletedTasks(namespace_token_,
59 &completed_tasks_);
60 for (Task::Vector::const_iterator it = completed_tasks_.begin();
61 it != completed_tasks_.end(); ++it) {
62 TileTask* task = static_cast<TileTask*>(it->get());
63
64 task->WillComplete();
65 task->CompleteOnOriginThread(raster_buffer_provider_.get());
66 task->DidComplete();
67 }
68 completed_tasks_.clear();
69}
70
71void TileTaskManagerImpl::Shutdown() {
72 TRACE_EVENT0("cc", "TileTaskManagerImpl::Shutdown");
73
74 // Cancel non-scheduled tasks and wait for running tasks to finish.
75 TaskGraph empty;
76 task_graph_runner_->ScheduleTasks(namespace_token_, &empty);
77 task_graph_runner_->WaitForTasksToFinishRunning(namespace_token_);
78
79 raster_buffer_provider_->Shutdown();
80}
81
82RasterBufferProvider* TileTaskManagerImpl::GetRasterBufferProvider() const {
83 return raster_buffer_provider_.get();
84}
85
86} // namespace cc