OLD | NEW |
---|---|
1 /* | 1 /* |
2 * Copyright 2011 Google Inc. | 2 * Copyright 2011 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 GrInOrderDrawBuffer_DEFINED | 8 #ifndef GrInOrderDrawBuffer_DEFINED |
9 #define GrInOrderDrawBuffer_DEFINED | 9 #define GrInOrderDrawBuffer_DEFINED |
10 | 10 |
(...skipping 54 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
65 if (0 != xformBytes) { | 65 if (0 != xformBytes) { |
66 *xformsLocation = (float*) fPathTransformBuffer.alloc(count * xformB ytes, | 66 *xformsLocation = (float*) fPathTransformBuffer.alloc(count * xformB ytes, |
67 SkChunkAlloc::kTh row_AllocFailType); | 67 SkChunkAlloc::kTh row_AllocFailType); |
68 SkASSERT(SkIsAlign4((uintptr_t)*xformsLocation)); | 68 SkASSERT(SkIsAlign4((uintptr_t)*xformsLocation)); |
69 memcpy(*xformsLocation, transformValues, count * xformBytes); | 69 memcpy(*xformsLocation, transformValues, count * xformBytes); |
70 } | 70 } |
71 } | 71 } |
72 | 72 |
73 private: | 73 private: |
74 friend class GrTargetCommands; | 74 friend class GrTargetCommands; |
75 typedef GrTargetCommands::State State; | |
76 | |
77 State* allocState(const GrPrimitiveProcessor* primProc = NULL) { | |
78 void* allocation = fPipelineBuffer.alloc(sizeof(State), SkChunkAlloc::kT hrow_AllocFailType); | |
79 return SkNEW_PLACEMENT_ARGS(allocation, State, (primProc)); | |
80 } | |
81 | |
82 void unallocState(State* state) { | |
83 state->unref(); | |
84 fPipelineBuffer.unalloc(state); | |
85 } | |
75 | 86 |
76 void onReset() override; | 87 void onReset() override; |
77 void onFlush() override; | 88 void onFlush() override; |
78 | 89 |
79 // overrides from GrDrawTarget | 90 // overrides from GrDrawTarget |
80 void onDrawBatch(GrBatch*, const PipelineInfo&) override; | 91 void onDrawBatch(GrBatch*, const PipelineInfo&) override; |
81 void onDrawRect(GrPipelineBuilder*, | 92 void onDrawRect(GrPipelineBuilder*, |
82 GrColor, | 93 GrColor, |
83 const SkMatrix& viewMatrix, | 94 const SkMatrix& viewMatrix, |
84 const SkRect& rect, | 95 const SkRect& rect, |
85 const SkRect* localRect, | 96 const SkRect* localRect, |
86 const SkMatrix* localMatrix) override; | 97 const SkMatrix* localMatrix) override; |
87 | |
88 void onStencilPath(const GrPipelineBuilder&, | 98 void onStencilPath(const GrPipelineBuilder&, |
89 const GrPathProcessor*, | 99 const GrPathProcessor*, |
90 const GrPath*, | 100 const GrPath*, |
91 const GrScissorState&, | 101 const GrScissorState&, |
92 const GrStencilSettings&) override; | 102 const GrStencilSettings&) override; |
93 void onDrawPath(const GrPathProcessor*, | 103 void onDrawPath(const GrPathProcessor*, |
94 const GrPath*, | 104 const GrPath*, |
95 const GrStencilSettings&, | 105 const GrStencilSettings&, |
96 const PipelineInfo&) override; | 106 const PipelineInfo&) override; |
97 void onDrawPaths(const GrPathProcessor*, | 107 void onDrawPaths(const GrPathProcessor*, |
(...skipping 17 matching lines...) Expand all Loading... | |
115 // We lazily record clip changes in order to skip clips that have no effect. | 125 // We lazily record clip changes in order to skip clips that have no effect. |
116 void recordClipIfNecessary(); | 126 void recordClipIfNecessary(); |
117 // Records any trace markers for a command | 127 // Records any trace markers for a command |
118 void recordTraceMarkersIfNecessary(GrTargetCommands::Cmd*); | 128 void recordTraceMarkersIfNecessary(GrTargetCommands::Cmd*); |
119 SkString getCmdString(int index) const { | 129 SkString getCmdString(int index) const { |
120 SkASSERT(index < fGpuCmdMarkers.count()); | 130 SkASSERT(index < fGpuCmdMarkers.count()); |
121 return fGpuCmdMarkers[index].toString(); | 131 return fGpuCmdMarkers[index].toString(); |
122 } | 132 } |
123 bool isIssued(uint32_t drawID) override { return drawID != fDrawID; } | 133 bool isIssued(uint32_t drawID) override { return drawID != fDrawID; } |
124 | 134 |
135 State* SK_WARN_UNUSED_RESULT setupPipelineAndShouldDraw(const GrPrimitivePro cessor*, | |
136 const GrDrawTarget:: PipelineInfo&); | |
137 State* SK_WARN_UNUSED_RESULT setupPipelineAndShouldDraw(GrBatch*, | |
138 const GrDrawTarget:: PipelineInfo&); | |
139 | |
125 // TODO: Use a single allocator for commands and records | 140 // TODO: Use a single allocator for commands and records |
126 enum { | 141 enum { |
127 kPathIdxBufferMinReserve = 2 * 64, // 64 uint16_t's | 142 kPathIdxBufferMinReserve = 2 * 64, // 64 uint16_t's |
128 kPathXformBufferMinReserve = 2 * 64, // 64 two-float transforms | 143 kPathXformBufferMinReserve = 2 * 64, // 64 two-float transforms |
144 kPipelineBufferMinReserve = 32 * sizeof(State), | |
joshualitt
2015/05/01 19:55:02
Not sure what we should preallocate
| |
129 }; | 145 }; |
130 | 146 |
147 // every 100 flushes we should reset our fPipelineBuffer to prevent us from holding at a | |
148 // highwater mark | |
149 static const int kPipelineBufferHighWaterMark = 100; | |
150 | |
131 GrTargetCommands fCommands; | 151 GrTargetCommands fCommands; |
132 SkTArray<GrTraceMarkerSet, false> fGpuCmdMarkers; | 152 SkTArray<GrTraceMarkerSet, false> fGpuCmdMarkers; |
133 SkChunkAlloc fPathIndexBuffer; | 153 SkChunkAlloc fPathIndexBuffer; |
134 SkChunkAlloc fPathTransformBuffer; | 154 SkChunkAlloc fPathTransformBuffer; |
155 SkChunkAlloc fPipelineBuffer; | |
135 uint32_t fDrawID; | 156 uint32_t fDrawID; |
157 SkAutoTUnref<State> fPrevState; | |
136 | 158 |
137 typedef GrClipTarget INHERITED; | 159 typedef GrClipTarget INHERITED; |
138 }; | 160 }; |
139 | 161 |
140 #endif | 162 #endif |
OLD | NEW |