Flutter Engine
The Flutter Engine
Loading...
Searching...
No Matches
Public Types | Public Member Functions | Static Public Member Functions | List of all members
skgpu::graphite::ComputeTask Class Referencefinal

#include <ComputeTask.h>

Inheritance diagram for skgpu::graphite::ComputeTask:
skgpu::graphite::Task SkRefCnt SkRefCntBase

Public Types

using DispatchGroupList = skia_private::STArray< 1, std::unique_ptr< DispatchGroup > >
 
- Public Types inherited from skgpu::graphite::Task
enum class  Status { kSuccess , kDiscard , kFail }
 

Public Member Functions

 ~ComputeTask () override
 
Status prepareResources (ResourceProvider *, const RuntimeEffectDictionary *) override
 
Status addCommands (Context *, CommandBuffer *, ReplayTargetData) override
 
- Public Member Functions inherited from SkRefCntBase
 SkRefCntBase ()
 
virtual ~SkRefCntBase ()
 
bool unique () const
 
void ref () const
 
void unref () const
 

Static Public Member Functions

static sk_sp< ComputeTaskMake (DispatchGroupList dispatchGroups)
 

Detailed Description

ComputeTask handles preparing and recording DispatchGroups into a series of compute dispatches within a command buffer. It is guaranteed that dispatches within a DispatchGroup will be executed sequentially.

Definition at line 26 of file ComputeTask.h.

Member Typedef Documentation

◆ DispatchGroupList

Definition at line 28 of file ComputeTask.h.

Constructor & Destructor Documentation

◆ ~ComputeTask()

skgpu::graphite::ComputeTask::~ComputeTask ( )
overridedefault

Member Function Documentation

◆ addCommands()

Task::Status skgpu::graphite::ComputeTask::addCommands ( Context ctx,
CommandBuffer commandBuffer,
ReplayTargetData  rtd 
)
overridevirtual

Implements skgpu::graphite::Task.

Definition at line 50 of file ComputeTask.cpp.

50 {
51 if (fDispatchGroups.empty()) {
52 return Status::kDiscard;
53 }
54 SkASSERT(fDispatchGroups.size() == fChildTasks.size());
55 const std::unique_ptr<DispatchGroup>* currentSpanPtr = &fDispatchGroups[0];
56 size_t currentSpanSize = 0u;
57 for (int i = 0; i < fDispatchGroups.size(); ++i) {
58 // If the next DispatchGroup has a dependent task, then encode the accumulated span as a
59 // compute pass now. CommandBuffer encodes each compute pass with a separate encoder, so
60 // the dependent task can use a non-compute encoder if needed.
61 Task* child = fChildTasks[i].get();
62 if (child) {
63 if (currentSpanSize > 0u) {
64 if (!commandBuffer->addComputePass({currentSpanPtr, currentSpanSize})) {
65 return Status::kFail;
66 }
67 currentSpanPtr = &fDispatchGroups[i];
68 currentSpanSize = 0u;
69 }
70
71 Status status = child->addCommands(ctx, commandBuffer, rtd);
72 if (status == Status::kFail) {
73 return Status::kFail;
74 } else if (status == Status::kDiscard) {
75 fChildTasks[i].reset();
76 }
77 }
78 currentSpanSize++;
79 }
80 return (currentSpanSize == 0u ||
81 commandBuffer->addComputePass({currentSpanPtr, currentSpanSize})) ? Status::kSuccess
82 : Status::kFail;
83}
#define SkASSERT(cond)
Definition SkAssert.h:116
bool empty() const
Definition SkTArray.h:194
int size() const
Definition SkTArray.h:416
Definition DM.cpp:1161

◆ Make()

sk_sp< ComputeTask > skgpu::graphite::ComputeTask::Make ( DispatchGroupList  dispatchGroups)
static

Definition at line 17 of file ComputeTask.cpp.

17 {
18 return sk_sp<ComputeTask>(new ComputeTask(std::move(dispatchGroups)));
19}

◆ prepareResources()

Task::Status skgpu::graphite::ComputeTask::prepareResources ( ResourceProvider provider,
const RuntimeEffectDictionary rtd 
)
overridevirtual

Implements skgpu::graphite::Task.

Definition at line 30 of file ComputeTask.cpp.

31 {
32 for (auto& child : fChildTasks) {
33 if (child) {
34 Status status = child->prepareResources(provider, rtd);
35 if (status == Status::kFail) {
36 return Status::kFail;
37 } else if (status == Status::kDiscard) {
38 child.reset();
39 }
40 }
41 }
42 for (const auto& group : fDispatchGroups) {
43 if (!group->prepareResources(provider)) {
44 return Status::kFail;
45 }
46 }
47 return Status::kSuccess;
48}

The documentation for this class was generated from the following files: