blob: a6be0870952099e01a1fdf32a08b185e183b3a52 [file] [log] [blame]
Robert Phillips07f675d2020-11-16 13:44:01 -05001/*
2 * Copyright 2020 Google LLC
3 *
4 * Use of this source code is governed by a BSD-style license that can be
5 * found in the LICENSE file.
6 */
7
8#include "src/gpu/GrDDLTask.h"
9
10#include "include/core/SkDeferredDisplayList.h"
11#include "src/core/SkDeferredDisplayListPriv.h"
12#include "src/gpu/GrResourceAllocator.h"
13
14GrDDLTask::GrDDLTask(GrDrawingManager* drawingMgr,
15 sk_sp<GrRenderTargetProxy> ddlTarget,
Robert Phillips88b29612020-11-16 15:15:08 -050016 sk_sp<const SkDeferredDisplayList> ddl,
17 SkIPoint offset)
Robert Phillips07f675d2020-11-16 13:44:01 -050018 : fDDL(std::move(ddl))
Robert Phillips88b29612020-11-16 15:15:08 -050019 , fDDLTarget(std::move(ddlTarget))
20 , fOffset(offset) {
21 (void) fOffset; // fOffset will be used shortly
Robert Phillips07f675d2020-11-16 13:44:01 -050022
Robert Phillips14357842021-01-06 12:13:34 -050023 for (auto& task : fDDL->priv().renderTasks()) {
Robert Phillips07f675d2020-11-16 13:44:01 -050024 SkASSERT(task->isClosed());
25
26 for (int i = 0; i < task->numTargets(); ++i) {
27 drawingMgr->setLastRenderTask(task->target(i).proxy(), task.get());
28 }
29 }
30
31 // The DDL task never accepts additional tasks
32 this->setFlag(kClosed_Flag);
33}
34
35GrDDLTask::~GrDDLTask() { }
36
37void GrDDLTask::endFlush(GrDrawingManager* drawingManager) {
38 for (auto& task : fDDL->priv().renderTasks()) {
39 task->endFlush(drawingManager);
40 }
41
42 INHERITED::endFlush(drawingManager);
43}
44
45void GrDDLTask::disown(GrDrawingManager* drawingManager) {
46 for (auto& task : fDDL->priv().renderTasks()) {
47 task->disown(drawingManager);
48 }
49
50 INHERITED::disown(drawingManager);
51}
52
53bool GrDDLTask::onIsUsed(GrSurfaceProxy* proxy) const {
54 for (auto& task : fDDL->priv().renderTasks()) {
55 if (task->isUsed(proxy)) {
56 return true;
57 }
58 }
59
60 return false;
61}
62
63void GrDDLTask::handleInternalAllocationFailure() {
64 for (auto& task : fDDL->priv().renderTasks()) {
65 task->handleInternalAllocationFailure();
66 }
67}
68
69void GrDDLTask::gatherProxyIntervals(GrResourceAllocator* alloc) const {
70 // We don't have any proxies, but the resource allocator will still bark
71 // if a task doesn't claim any op indices, so we oblige it.
72 alloc->incOps();
73
74 for (auto& task : fDDL->priv().renderTasks()) {
75 task->gatherProxyIntervals(alloc);
76 }
77}
78
79GrRenderTask::ExpectedOutcome GrDDLTask::onMakeClosed(const GrCaps& caps,
80 SkIRect* targetUpdateBounds) {
81 SkASSERT(0);
82 return ExpectedOutcome::kTargetUnchanged;
83}
84
85void GrDDLTask::gatherIDs(SkSTArray<8, uint32_t, true>* idArray) const {
86 for (auto& task : fDDL->priv().renderTasks()) {
87 task->gatherIDs(idArray);
88 }
89}
90
91void GrDDLTask::onPrepare(GrOpFlushState* flushState) {
92 for (auto& task : fDDL->priv().renderTasks()) {
93 task->prepare(flushState);
94 }
95}
96
97bool GrDDLTask::onExecute(GrOpFlushState* flushState) {
98 bool anyCommandsIssued = false;
99 for (auto& task : fDDL->priv().renderTasks()) {
100 if (task->execute(flushState)) {
101 anyCommandsIssued = true;
102 }
103 }
104
105 return anyCommandsIssued;
106}
Robert Phillips14357842021-01-06 12:13:34 -0500107
108#if GR_TEST_UTILS
109void GrDDLTask::dump(bool printDependencies) const {
110 INHERITED::dump(printDependencies);
111
112 for (auto& task : fDDL->priv().renderTasks()) {
113 task->dump(printDependencies);
114 }
115}
116#endif