OLD | NEW |
---|---|
1 /* | 1 /* |
2 * Copyright 2015 Google Inc. | 2 * Copyright 2015 Google Inc. |
3 * | 3 * |
4 * Use of this source code is governed by a BSD-style license that can be | 4 * Use of this source code is governed by a BSD-style license that can be |
5 * found in the LICENSE file. | 5 * found in the LICENSE file. |
6 */ | 6 */ |
7 | 7 |
8 #ifndef GrDrawBatch_DEFINED | 8 #ifndef GrDrawBatch_DEFINED |
9 #define GrDrawBatch_DEFINED | 9 #define GrDrawBatch_DEFINED |
10 | 10 |
11 #include <functional> | |
11 #include "GrBatch.h" | 12 #include "GrBatch.h" |
12 #include "GrPipeline.h" | 13 #include "GrPipeline.h" |
13 | 14 |
14 struct GrInitInvariantOutput; | 15 struct GrInitInvariantOutput; |
15 | 16 |
16 /** | 17 /** |
17 * GrDrawBatches are flushed in two phases (preDraw, and draw). In preDraw uploa ds to GrGpuResources | 18 * GrDrawBatches are flushed in two phases (preDraw, and draw). In preDraw uploa ds to GrGpuResources |
18 * and draws are determined and scheduled. They are issued in the draw phase. Gr BatchToken is used | 19 * and draws are determined and scheduled. They are issued in the draw phase. Gr BatchToken is used |
19 * to sequence the uploads relative to each other and to draws. | 20 * to sequence the uploads relative to each other and to draws. |
20 **/ | 21 **/ |
21 | 22 |
22 typedef uint64_t GrBatchToken; | 23 class GrBatchDrawToken { |
24 public: | |
25 static GrBatchDrawToken AlreadyFlushedToken() { return GrBatchDrawToken(0); } | |
23 | 26 |
24 class GrBatchUploader : public SkRefCnt { | 27 GrBatchDrawToken(const GrBatchDrawToken& that) : fSequenceNumber(that.fSeque nceNumber) {} |
25 public: | 28 GrBatchDrawToken& operator =(const GrBatchDrawToken& that) { |
26 class TextureUploader; | 29 fSequenceNumber = that.fSequenceNumber; |
27 | 30 return *this; |
28 GrBatchUploader(GrBatchToken lastUploadToken) : fLastUploadToken(lastUploadT oken) {} | 31 } |
29 GrBatchToken lastUploadToken() const { return fLastUploadToken; } | 32 bool operator==(const GrBatchDrawToken& that) const { |
30 virtual void upload(TextureUploader*)=0; | 33 return fSequenceNumber == that.fSequenceNumber; |
34 } | |
35 bool operator!=(const GrBatchDrawToken& that) const { return !(*this == that ); } | |
31 | 36 |
32 private: | 37 private: |
33 GrBatchToken fLastUploadToken; | 38 GrBatchDrawToken(); |
39 explicit GrBatchDrawToken(uint64_t sequenceNumber) : fSequenceNumber(sequenc eNumber) {} | |
40 friend class GrBatchFlushState; | |
41 uint64_t fSequenceNumber; | |
34 }; | 42 }; |
35 | 43 |
36 /** | 44 /** |
37 * Base class for GrBatches that draw. These batches have a GrPipeline installed by GrDrawTarget. | 45 * Base class for GrBatches that draw. These batches have a GrPipeline installed by GrDrawTarget. |
38 */ | 46 */ |
39 class GrDrawBatch : public GrBatch { | 47 class GrDrawBatch : public GrBatch { |
40 public: | 48 public: |
49 /** Method that performs an upload on behalf of a DeferredUploadFn. */ | |
50 using WritePixelsFn = std::function<bool(GrSurface* texture, | |
51 int left, int top, int width, int h eight, | |
52 GrPixelConfig config, const void* b uffer, | |
53 size_t rowBytes)>; | |
54 | |
55 /** | |
56 * Batches can insert uploads when preparing their draws. The can eithe be i nserted before | |
egdaniel
2016/03/28 20:05:20
The->They, eithe->either
| |
57 * all the draws (of all batches in a flush), which is called an "asap uploa d", or schedule | |
58 * them between draws, which is called an "inline upload". ASAP uploads are typically used | |
egdaniel
2016/03/28 20:05:20
Wouldn't you want inline uploads in the case where
bsalomon
2016/03/28 20:11:02
Yes, mental slip
| |
59 * when the content of the GrSurface must be modified between draws because two draws require | |
60 * different contents to appear in the surface. | |
61 */ | |
62 using DeferredUploadFn = std::function<void(WritePixelsFn&)>; | |
63 | |
41 class Target; | 64 class Target; |
42 | 65 |
43 GrDrawBatch(uint32_t classID); | 66 GrDrawBatch(uint32_t classID); |
44 ~GrDrawBatch() override; | 67 ~GrDrawBatch() override; |
45 | 68 |
46 /** | 69 /** |
47 * Fills in a structure informing the XP of overrides to its normal behavior . | 70 * Fills in a structure informing the XP of overrides to its normal behavior . |
48 */ | 71 */ |
49 void getPipelineOptimizations(GrPipelineOptimizations* override) const; | 72 void getPipelineOptimizations(GrPipelineOptimizations* override) const; |
50 | 73 |
(...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
93 GrBatchToXPOverrides* overrides) c onst = 0; | 116 GrBatchToXPOverrides* overrides) c onst = 0; |
94 | 117 |
95 private: | 118 private: |
96 /** | 119 /** |
97 * initBatchTracker is a hook for the some additional overrides / optimizati on possibilities | 120 * initBatchTracker is a hook for the some additional overrides / optimizati on possibilities |
98 * from the GrXferProcessor. | 121 * from the GrXferProcessor. |
99 */ | 122 */ |
100 virtual void initBatchTracker(const GrXPOverridesForBatch&) = 0; | 123 virtual void initBatchTracker(const GrXPOverridesForBatch&) = 0; |
101 | 124 |
102 protected: | 125 protected: |
103 SkTArray<SkAutoTUnref<GrBatchUploader>, true> fInlineUploads; | 126 struct QueuedUpload { |
127 QueuedUpload(DeferredUploadFn&& upload, GrBatchDrawToken token) | |
128 : fUpload(std::move(upload)) | |
129 , fUploadBeforeToken(token) {} | |
130 DeferredUploadFn fUpload; | |
131 GrBatchDrawToken fUploadBeforeToken; | |
132 }; | |
133 SkTArray<QueuedUpload> fInlineUploads; | |
104 | 134 |
105 private: | 135 private: |
106 SkAlignedSTStorage<1, GrPipeline> fPipelineStorage; | 136 SkAlignedSTStorage<1, GrPipeline> fPipelineStorage; |
107 bool fPipelineInstalled; | 137 bool fPipelineInstalled; |
108 typedef GrBatch INHERITED; | 138 typedef GrBatch INHERITED; |
109 }; | 139 }; |
110 | 140 |
111 #endif | 141 #endif |
OLD | NEW |