blob: 793a97cf600411a589a36e41bf39df6e7b20e140 [file] [log] [blame]
robertphillips77a2e522015-10-17 07:43:27 -07001/*
2 * Copyright 2015 Google Inc.
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#ifndef GrDrawingManager_DEFINED
9#define GrDrawingManager_DEFINED
10
Brian Salomon601ac802019-02-07 13:37:16 -050011#include "GrBufferAllocPool.h"
Herb Derbydc214c22018-11-08 13:31:39 -050012#include "GrDeferredUpload.h"
robertphillips68737822015-10-29 12:12:21 -070013#include "GrPathRenderer.h"
Brian Salomon742e31d2016-12-07 17:06:19 -050014#include "GrPathRendererChain.h"
bsalomonb77a9072016-09-07 10:02:04 -070015#include "GrResourceCache.h"
Robert Phillipseb35f4d2017-03-21 07:56:47 -040016#include "SkTArray.h"
Herb Derby26cbe512018-05-24 14:39:01 -040017#include "text/GrTextContext.h"
Robert Phillipsf2361d22016-10-25 14:20:06 -040018
robertphillips77a2e522015-10-17 07:43:27 -070019class GrContext;
Chris Daltonfddb6c02017-11-04 15:22:22 -060020class GrCoverageCountingPathRenderer;
Robert Phillipsfbcef6e2017-06-15 12:07:18 -040021class GrOnFlushCallbackObject;
Herb Derbydc214c22018-11-08 13:31:39 -050022class GrOpFlushState;
Brian Osman11052242016-10-27 14:47:55 -040023class GrRenderTargetContext;
Robert Phillipsc7635fa2016-10-28 13:25:24 -040024class GrRenderTargetProxy;
joshualittde8dc7e2016-01-08 10:09:13 -080025class GrSingleOWner;
Brian Salomon653f42f2018-07-10 10:07:31 -040026class GrRenderTargetOpList;
robertphillips68737822015-10-29 12:12:21 -070027class GrSoftwarePathRenderer;
Brian Osman45580d32016-11-23 09:37:01 -050028class GrTextureContext;
29class GrTextureOpList;
Brian Salomon653f42f2018-07-10 10:07:31 -040030class SkDeferredDisplayList;
robertphillips77a2e522015-10-17 07:43:27 -070031
Brian Osman11052242016-10-27 14:47:55 -040032// The GrDrawingManager allocates a new GrRenderTargetContext for each GrRenderTarget
Robert Phillipsf2361d22016-10-25 14:20:06 -040033// but all of them still land in the same GrOpList!
robertphillips77a2e522015-10-17 07:43:27 -070034//
Brian Osman11052242016-10-27 14:47:55 -040035// In the future this class will allocate a new GrRenderTargetContext for
Robert Phillipsf2361d22016-10-25 14:20:06 -040036// each GrRenderTarget/GrOpList and manage the DAG.
robertphillips77a2e522015-10-17 07:43:27 -070037class GrDrawingManager {
38public:
39 ~GrDrawingManager();
40
robertphillips68737822015-10-29 12:12:21 -070041 void freeGpuResources();
robertphillips77a2e522015-10-17 07:43:27 -070042
Robert Phillips37430132016-11-09 06:50:43 -050043 sk_sp<GrRenderTargetContext> makeRenderTargetContext(sk_sp<GrSurfaceProxy>,
Brian Osman11052242016-10-27 14:47:55 -040044 sk_sp<SkColorSpace>,
Robert Phillips941d1442017-06-14 16:37:02 -040045 const SkSurfaceProps*,
46 bool managedOpList = true);
Robert Phillips2c862492017-01-18 10:08:39 -050047 sk_sp<GrTextureContext> makeTextureContext(sk_sp<GrSurfaceProxy>, sk_sp<SkColorSpace>);
robertphillips77a2e522015-10-17 07:43:27 -070048
Robert Phillipsf2361d22016-10-25 14:20:06 -040049 // The caller automatically gets a ref on the returned opList. It must
robertphillips77a2e522015-10-17 07:43:27 -070050 // be balanced by an unref call.
Robert Phillips941d1442017-06-14 16:37:02 -040051 // A managed opList is controlled by the drawing manager (i.e., sorted & flushed with the
52 // other). An unmanaged one is created and used by the onFlushCallback.
53 sk_sp<GrRenderTargetOpList> newRTOpList(GrRenderTargetProxy* rtp, bool managedOpList);
Robert Phillipsb6deea82017-05-11 14:14:30 -040054 sk_sp<GrTextureOpList> newTextureOpList(GrTextureProxy* textureProxy);
robertphillips77a2e522015-10-17 07:43:27 -070055
56 GrContext* getContext() { return fContext; }
57
Herb Derby26cbe512018-05-24 14:39:01 -040058 GrTextContext* getTextContext();
brianosman86e76262016-08-11 12:17:31 -070059
robertphillips68737822015-10-29 12:12:21 -070060 GrPathRenderer* getPathRenderer(const GrPathRenderer::CanDrawPathArgs& args,
61 bool allowSW,
62 GrPathRendererChain::DrawType drawType,
Ben Wagnera93a14a2017-08-28 10:34:05 -040063 GrPathRenderer::StencilSupport* stencilSupport = nullptr);
robertphillips68737822015-10-29 12:12:21 -070064
Brian Salomone7df0bb2018-05-07 14:44:57 -040065 GrPathRenderer* getSoftwarePathRenderer();
66
Chris Daltonfddb6c02017-11-04 15:22:22 -060067 // Returns a direct pointer to the coverage counting path renderer, or null if it is not
68 // supported and turned on.
69 GrCoverageCountingPathRenderer* getCoverageCountingPathRenderer();
70
Brian Salomon653f42f2018-07-10 10:07:31 -040071 void flushIfNecessary();
bsalomonb77a9072016-09-07 10:02:04 -070072
Greg Daniel78325c12017-06-19 16:39:13 -040073 static bool ProgramUnitTest(GrContext* context, int maxStages, int maxLevels);
robertphillipsa13e2022015-11-11 12:01:09 -080074
Greg Daniel51316782017-08-02 15:10:09 +000075 GrSemaphoresSubmitted prepareSurfaceForExternalIO(GrSurfaceProxy*,
76 int numSemaphores,
77 GrBackendSemaphore backendSemaphores[]);
bsalomon6a2b1942016-09-08 11:28:59 -070078
Chris Daltonfe199b72017-05-05 11:26:15 -040079 void addOnFlushCallbackObject(GrOnFlushCallbackObject*);
Robert Phillipsdbaf3172019-02-06 15:12:53 -050080
81#if GR_TEST_UTILS
Chris Daltonfe199b72017-05-05 11:26:15 -040082 void testingOnly_removeOnFlushCallbackObject(GrOnFlushCallbackObject*);
Robert Phillipsdbaf3172019-02-06 15:12:53 -050083#endif
Robert Phillipseb35f4d2017-03-21 07:56:47 -040084
Robert Phillips62000362018-02-01 09:10:04 -050085 void moveOpListsToDDL(SkDeferredDisplayList* ddl);
86 void copyOpListsFromDDL(const SkDeferredDisplayList*, GrRenderTargetProxy* newDest);
87
robertphillips77a2e522015-10-17 07:43:27 -070088private:
Robert Phillips22310d62018-09-05 11:07:21 -040089 // This class encapsulates maintenance and manipulation of the drawing manager's DAG of opLists.
90 class OpListDAG {
91 public:
92 OpListDAG(bool explicitlyAllocating, GrContextOptions::Enable sortOpLists);
93 ~OpListDAG();
94
95 // Currently, when explicitly allocating resources, this call will topologically sort the
96 // opLists.
97 // MDB TODO: remove once incremental opList sorting is enabled
98 void prepForFlush();
99
100 void closeAll(const GrCaps* caps);
101
102 // A yucky combination of closeAll and reset
103 void cleanup(const GrCaps* caps);
104
105 void gatherIDs(SkSTArray<8, uint32_t, true>* idArray) const;
106
107 void reset();
108
109 // These calls forceably remove an opList from the DAG. They are problematic bc they just
110 // remove the opList but don't cleanup any refering pointers (i.e., dependency pointers
111 // in the DAG). They work right now bc they are only called at flush time, after the
112 // topological sort is complete (so the dangling pointers aren't used).
113 void removeOpList(int index);
114 void removeOpLists(int startIndex, int stopIndex);
115
116 bool empty() const { return fOpLists.empty(); }
117 int numOpLists() const { return fOpLists.count(); }
118
119 GrOpList* opList(int index) { return fOpLists[index].get(); }
120 const GrOpList* opList(int index) const { return fOpLists[index].get(); }
121
122 GrOpList* back() { return fOpLists.back().get(); }
123 const GrOpList* back() const { return fOpLists.back().get(); }
124
125 void add(sk_sp<GrOpList>);
126 void add(const SkTArray<sk_sp<GrOpList>>&);
127
128 void swap(SkTArray<sk_sp<GrOpList>>* opLists);
129
Robert Phillips46acf9d2018-10-09 09:31:40 -0400130 bool sortingOpLists() const { return fSortOpLists; }
131
Robert Phillips22310d62018-09-05 11:07:21 -0400132 private:
133 SkTArray<sk_sp<GrOpList>> fOpLists;
134 bool fSortOpLists;
135 };
136
Robert Phillipsa3f70262018-02-08 10:59:38 -0500137 GrDrawingManager(GrContext*, const GrPathRendererChain::Options&,
Herb Derby26cbe512018-05-24 14:39:01 -0400138 const GrTextContext::Options&, GrSingleOwner*,
Robert Phillips46acf9d2018-10-09 09:31:40 -0400139 bool explicitlyAllocating, GrContextOptions::Enable sortRenderTargets,
140 GrContextOptions::Enable reduceOpListSplitting);
robertphillips77a2e522015-10-17 07:43:27 -0700141
Robert Phillipsa9162df2019-02-11 14:12:03 -0500142 bool wasAbandoned() const;
143
robertphillips77a2e522015-10-17 07:43:27 -0700144 void cleanup();
Robert Phillipseafd48a2017-11-16 07:52:08 -0500145
146 // return true if any opLists were actually executed; false otherwise
Greg Danield2073452018-12-07 11:20:33 -0500147 bool executeOpLists(int startIndex, int stopIndex, GrOpFlushState*, int* numOpListsExecuted);
Robert Phillipseafd48a2017-11-16 07:52:08 -0500148
Greg Daniel51316782017-08-02 15:10:09 +0000149 GrSemaphoresSubmitted flush(GrSurfaceProxy* proxy,
150 int numSemaphores = 0,
Brian Salomon57d2bea2018-09-10 09:35:41 -0400151 GrBackendSemaphore backendSemaphores[] = nullptr);
robertphillips77a2e522015-10-17 07:43:27 -0700152
Robert Phillips38d64b02018-09-04 13:23:26 -0400153 SkDEBUGCODE(void validate() const);
154
robertphillips77a2e522015-10-17 07:43:27 -0700155 friend class GrContext; // for access to: ctor, abandon, reset & flush
Robert Phillips7ee385e2017-03-30 08:02:11 -0400156 friend class GrContextPriv; // access to: flush
Chris Daltonfe199b72017-05-05 11:26:15 -0400157 friend class GrOnFlushResourceProvider; // this is just a shallow wrapper around this class
robertphillips77a2e522015-10-17 07:43:27 -0700158
159 static const int kNumPixelGeometries = 5; // The different pixel geometries
160 static const int kNumDFTOptions = 2; // DFT or no DFT
161
brianosman86e76262016-08-11 12:17:31 -0700162 GrContext* fContext;
bsalomon6b2552f2016-09-15 13:50:26 -0700163 GrPathRendererChain::Options fOptionsForPathRendererChain;
Herb Derby26cbe512018-05-24 14:39:01 -0400164 GrTextContext::Options fOptionsForTextContext;
Brian Salomon601ac802019-02-07 13:37:16 -0500165 // This cache is used by both the vertex and index pools. It reuses memory across multiple
166 // flushes.
167 sk_sp<GrBufferAllocPool::CpuBufferCache> fCpuBufferCache;
joshualittde8dc7e2016-01-08 10:09:13 -0800168 // In debug builds we guard against improper thread handling
brianosman86e76262016-08-11 12:17:31 -0700169 GrSingleOwner* fSingleOwner;
joshualittde8dc7e2016-01-08 10:09:13 -0800170
Robert Phillips22310d62018-09-05 11:07:21 -0400171 OpListDAG fDAG;
Robert Phillips38d64b02018-09-04 13:23:26 -0400172 GrOpList* fActiveOpList = nullptr;
Chris Dalton3968ff92017-11-27 12:26:31 -0700173 // These are the IDs of the opLists currently being flushed (in internalFlush)
174 SkSTArray<8, uint32_t, true> fFlushingOpListIDs;
175 // These are the new opLists generated by the onFlush CBs
176 SkSTArray<8, sk_sp<GrOpList>> fOnFlushCBOpLists;
robertphillips77a2e522015-10-17 07:43:27 -0700177
Herb Derby26cbe512018-05-24 14:39:01 -0400178 std::unique_ptr<GrTextContext> fTextContext;
robertphillipsa13e2022015-11-11 12:01:09 -0800179
Ben Wagner9ec70c62018-07-12 13:30:47 -0400180 std::unique_ptr<GrPathRendererChain> fPathRendererChain;
181 sk_sp<GrSoftwarePathRenderer> fSoftwarePathRenderer;
brianosman86e76262016-08-11 12:17:31 -0700182
Robert Phillips40a29d72018-01-18 12:59:22 -0500183 GrTokenTracker fTokenTracker;
brianosman86e76262016-08-11 12:17:31 -0700184 bool fFlushing;
Robert Phillips46acf9d2018-10-09 09:31:40 -0400185 bool fReduceOpListSplitting;
bsalomonb77a9072016-09-07 10:02:04 -0700186
Chris Daltonfe199b72017-05-05 11:26:15 -0400187 SkTArray<GrOnFlushCallbackObject*> fOnFlushCBObjects;
robertphillips77a2e522015-10-17 07:43:27 -0700188};
189
190#endif