blob: a0194151c74243c6cded7c1cb05265ba7dcc95b6 [file] [log] [blame]
reed@google.comac10a2d2010-12-22 21:39:39 +00001/*
epoger@google.comec3ed6a2011-07-28 14:26:00 +00002 * Copyright 2011 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.
reed@google.comac10a2d2010-12-22 21:39:39 +00006 */
7
8
epoger@google.comec3ed6a2011-07-28 14:26:00 +00009
reed@google.comac10a2d2010-12-22 21:39:39 +000010#ifndef GrGpuGL_DEFINED
11#define GrGpuGL_DEFINED
12
robertphillips@google.com37ebe3f2013-03-04 20:03:44 +000013
bsalomon@google.comc1d2a582012-06-01 15:08:19 +000014#include "GrBinHashKey.h"
tomhudson@google.comd8f856c2012-05-10 12:13:36 +000015#include "GrDrawState.h"
16#include "GrGpu.h"
robertphillips@google.com6177e692013-02-28 20:16:25 +000017#include "GrGLContext.h"
bsalomon@google.com4043ae22011-08-02 14:19:11 +000018#include "GrGLIndexBuffer.h"
bsalomon@google.com81c3f8d2011-08-03 15:18:33 +000019#include "GrGLIRect.h"
bsalomon@google.com5739d2c2012-05-31 15:07:19 +000020#include "GrGLProgram.h"
bsalomon@google.com81c3f8d2011-08-03 15:18:33 +000021#include "GrGLStencilBuffer.h"
22#include "GrGLTexture.h"
23#include "GrGLVertexBuffer.h"
bsalomon@google.comc1d2a582012-06-01 15:08:19 +000024#include "../GrTHashCache.h"
reed@google.comac10a2d2010-12-22 21:39:39 +000025
26class GrGpuGL : public GrGpu {
27public:
robertphillips@google.com6177e692013-02-28 20:16:25 +000028 GrGpuGL(const GrGLContext& ctx, GrContext* context);
reed@google.comac10a2d2010-12-22 21:39:39 +000029 virtual ~GrGpuGL();
30
robertphillips@google.com6177e692013-02-28 20:16:25 +000031 const GrGLInterface* glInterface() const { return fGLContext.interface(); }
32 GrGLBinding glBinding() const { return fGLContext.info().binding(); }
33 GrGLVersion glVersion() const { return fGLContext.info().version(); }
34 GrGLSLGeneration glslGeneration() const { return fGLContext.info().glslGeneration(); }
bsalomon@google.com0b77d682011-08-19 13:28:54 +000035
bsalomon@google.com34cccde2013-01-04 18:34:30 +000036 // Used by GrGLProgram to bind necessary textures for GrGLEffects.
37 void bindTexture(int unitIdx, const GrTextureParams& params, GrGLTexture* texture);
38
bsalomon@google.coma45afcf2013-02-04 18:46:49 +000039 bool programUnitTest(int maxStages);
bsalomon@google.com34cccde2013-01-04 18:34:30 +000040
bsalomon@google.com56d11e02011-11-30 19:59:08 +000041 // GrGpu overrides
bsalomon@google.com9c680582013-02-06 18:17:50 +000042 virtual GrPixelConfig preferredReadPixelsConfig(GrPixelConfig config) const SK_OVERRIDE;
43 virtual GrPixelConfig preferredWritePixelsConfig(GrPixelConfig config) const SK_OVERRIDE;
44 virtual bool canWriteTexturePixels(const GrTexture*, GrPixelConfig srcConfig) const SK_OVERRIDE;
bsalomon@google.comc4364992011-11-07 15:54:49 +000045 virtual bool readPixelsWillPayForYFlip(
46 GrRenderTarget* renderTarget,
47 int left, int top,
48 int width, int height,
49 GrPixelConfig config,
bsalomon@google.com56d11e02011-11-30 19:59:08 +000050 size_t rowBytes) const SK_OVERRIDE;
51 virtual bool fullReadPixelsIsFasterThanPartial() const SK_OVERRIDE;
bsalomon@google.com75f9f252012-01-31 13:35:56 +000052
bsalomon@google.com5739d2c2012-05-31 15:07:19 +000053 virtual void abandonResources() SK_OVERRIDE;
54
robertphillips@google.com6177e692013-02-28 20:16:25 +000055 const GrGLCaps& glCaps() const { return fGLContext.info().caps(); }
bsalomon@google.com91207482013-02-12 21:45:24 +000056
bsalomon@google.com880b8fc2013-02-19 20:17:28 +000057 // Callbacks to update state tracking when related GL objects are bound or deleted
bsalomon@google.come49ad452013-02-20 19:33:20 +000058 void notifyVertexBufferBind(GrGLuint id);
59 void notifyVertexBufferDelete(GrGLuint id);
60 void notifyIndexBufferBind(GrGLuint id);
61 void notifyIndexBufferDelete(GrGLuint id);
bsalomon@google.com880b8fc2013-02-19 20:17:28 +000062 void notifyTextureDelete(GrGLTexture* texture);
63 void notifyRenderTargetDelete(GrRenderTarget* renderTarget);
64
bsalomon@google.com02ddc8b2013-01-28 15:35:28 +000065private:
bsalomon@google.com1c13c962011-02-14 16:51:21 +000066 // GrGpu overrides
bsalomon@google.com1bf1c212011-11-05 12:18:58 +000067 virtual void onResetContext() SK_OVERRIDE;
bsalomon@google.coma7f84e12011-03-10 14:13:19 +000068
bsalomon@google.comfea37b52011-04-25 15:51:06 +000069 virtual GrTexture* onCreateTexture(const GrTextureDesc& desc,
bsalomon@google.combcdbbe62011-04-12 15:40:00 +000070 const void* srcData,
bsalomon@google.com13f1b6f2012-05-31 12:52:43 +000071 size_t rowBytes) SK_OVERRIDE;
bsalomon@google.combcdbbe62011-04-12 15:40:00 +000072 virtual GrVertexBuffer* onCreateVertexBuffer(uint32_t size,
bsalomon@google.com13f1b6f2012-05-31 12:52:43 +000073 bool dynamic) SK_OVERRIDE;
bsalomon@google.combcdbbe62011-04-12 15:40:00 +000074 virtual GrIndexBuffer* onCreateIndexBuffer(uint32_t size,
bsalomon@google.com13f1b6f2012-05-31 12:52:43 +000075 bool dynamic) SK_OVERRIDE;
bsalomon@google.com64aef2b2012-06-11 15:36:13 +000076 virtual GrPath* onCreatePath(const SkPath&) SK_OVERRIDE;
bsalomon@google.com16e3dde2012-10-25 18:43:28 +000077 virtual GrTexture* onWrapBackendTexture(const GrBackendTextureDesc&) SK_OVERRIDE;
78 virtual GrRenderTarget* onWrapBackendRenderTarget(const GrBackendRenderTargetDesc&) SK_OVERRIDE;
bsalomon@google.com81c3f8d2011-08-03 15:18:33 +000079 virtual bool createStencilBufferForRenderTarget(GrRenderTarget* rt,
bsalomon@google.com13f1b6f2012-05-31 12:52:43 +000080 int width,
81 int height) SK_OVERRIDE;
82 virtual bool attachStencilBufferToRenderTarget(
83 GrStencilBuffer* sb,
84 GrRenderTarget* rt) SK_OVERRIDE;
bsalomon@google.coma7f84e12011-03-10 14:13:19 +000085
bsalomon@google.com13f1b6f2012-05-31 12:52:43 +000086 virtual void onClear(const GrIRect* rect, GrColor color) SK_OVERRIDE;
bsalomon@google.coma7f84e12011-03-10 14:13:19 +000087
bsalomon@google.com13f1b6f2012-05-31 12:52:43 +000088 virtual void onForceRenderTargetFlush() SK_OVERRIDE;
bsalomon@google.coma7f84e12011-03-10 14:13:19 +000089
bsalomon@google.com5877ffd2011-04-11 17:58:48 +000090 virtual bool onReadPixels(GrRenderTarget* target,
rmistry@google.comd6176b02012-08-23 18:14:13 +000091 int left, int top,
bsalomon@google.comc6980972011-11-02 19:57:21 +000092 int width, int height,
rmistry@google.comd6176b02012-08-23 18:14:13 +000093 GrPixelConfig,
bsalomon@google.comc4364992011-11-07 15:54:49 +000094 void* buffer,
senorblanco@chromium.org3cb406b2013-02-05 19:50:46 +000095 size_t rowBytes) SK_OVERRIDE;
bsalomon@google.coma7f84e12011-03-10 14:13:19 +000096
bsalomon@google.com9c680582013-02-06 18:17:50 +000097 virtual bool onWriteTexturePixels(GrTexture* texture,
bsalomon@google.com6f379512011-11-16 20:36:03 +000098 int left, int top, int width, int height,
99 GrPixelConfig config, const void* buffer,
100 size_t rowBytes) SK_OVERRIDE;
101
bsalomon@google.com75f9f252012-01-31 13:35:56 +0000102 virtual void onResolveRenderTarget(GrRenderTarget* target) SK_OVERRIDE;
103
bsalomon@google.com74749cd2013-01-30 16:12:41 +0000104 virtual void onGpuDraw(const DrawInfo&) SK_OVERRIDE;
bsalomon@google.comded4f4b2012-06-28 18:48:06 +0000105
106 virtual void setStencilPathSettings(const GrPath&,
sugoi@google.com12b4e272012-12-06 20:13:11 +0000107 SkPath::FillType,
bsalomon@google.comded4f4b2012-06-28 18:48:06 +0000108 GrStencilSettings* settings)
109 SK_OVERRIDE;
sugoi@google.com12b4e272012-12-06 20:13:11 +0000110 virtual void onGpuStencilPath(const GrPath*, SkPath::FillType) SK_OVERRIDE;
robertphillips@google.com730ebe52012-04-16 16:33:13 +0000111
bsalomon@google.com13f1b6f2012-05-31 12:52:43 +0000112 virtual void clearStencil() SK_OVERRIDE;
113 virtual void clearStencilClip(const GrIRect& rect,
114 bool insideClip) SK_OVERRIDE;
bsalomon@google.com64aef2b2012-06-11 15:36:13 +0000115 virtual bool flushGraphicsState(DrawType) SK_OVERRIDE;
bsalomon@google.com5739d2c2012-05-31 15:07:19 +0000116
bsalomon@google.com1c13c962011-02-14 16:51:21 +0000117 // binds texture unit in GL
bsalomon@google.com8531c1c2011-01-13 19:52:45 +0000118 void setTextureUnit(int unitIdx);
reed@google.comac10a2d2010-12-22 21:39:39 +0000119
bsalomon@google.com880b8fc2013-02-19 20:17:28 +0000120 // Sets up vertex attribute pointers and strides. On return indexOffsetInBytes gives the offset
121 // an into the index buffer. It does not account for drawInfo.startIndex() but rather the start
122 // index is relative to the returned offset.
123 void setupGeometry(const DrawInfo& info, size_t* indexOffsetInBytes);
124 // binds appropriate vertex and index buffers. It also returns offsets for the vertex and index
125 // buffers. These offsets account for placement within a pool buffer or CPU-side addresses for
126 // use with buffer 0. They do not account for start values in the DrawInfo (which is not passed
127 // here). The vertex buffer that contains the vertex data is returned. It is not necessarily
128 // bound.
129 GrGLVertexBuffer* setBuffers(bool indexed, size_t* vertexOffsetInBytes, size_t* indexOffsetInBytes);
bsalomon@google.com7acdb8e2011-02-11 14:07:02 +0000130
bsalomon@google.com86c1f712011-10-12 14:54:26 +0000131 // Subclasses should call this to flush the blend state.
bsalomon@google.com74749cd2013-01-30 16:12:41 +0000132 // The params should be the final coefficients to apply
bsalomon@google.com86c1f712011-10-12 14:54:26 +0000133 // (after any blending optimizations or dual source blending considerations
134 // have been accounted for).
bsalomon@google.com02ddc8b2013-01-28 15:35:28 +0000135 void flushBlend(bool isLines, GrBlendCoeff srcCoeff, GrBlendCoeff dstCoeff);
bsalomon@google.com271cffc2011-05-20 14:13:56 +0000136
robertphillips@google.com6177e692013-02-28 20:16:25 +0000137 bool hasExtension(const char* ext) const { return fGLContext.info().hasExtension(ext); }
bsalomon@google.com96399942012-02-13 14:39:16 +0000138
robertphillips@google.com6177e692013-02-28 20:16:25 +0000139 const GrGLContext& glContext() const { return fGLContext; }
bsalomon@google.com2c17fcd2011-07-06 17:47:02 +0000140
bsalomon@google.com271cffc2011-05-20 14:13:56 +0000141 static bool BlendCoeffReferencesConstant(GrBlendCoeff coeff);
bsalomon@google.com080773c2011-03-15 19:09:25 +0000142
bsalomon@google.comc1d2a582012-06-01 15:08:19 +0000143 class ProgramCache : public ::GrNoncopyable {
144 public:
robertphillips@google.com6177e692013-02-28 20:16:25 +0000145 ProgramCache(const GrGLContext& gl);
bsalomon@google.com5739d2c2012-05-31 15:07:19 +0000146
bsalomon@google.comc1d2a582012-06-01 15:08:19 +0000147 void abandon();
bsalomon@google.com2eaaefd2012-10-29 19:51:22 +0000148 GrGLProgram* getProgram(const GrGLProgram::Desc& desc, const GrEffectStage* stages[]);
bsalomon@google.comc1d2a582012-06-01 15:08:19 +0000149 private:
150 enum {
bsalomon@google.com91207482013-02-12 21:45:24 +0000151 kKeySize = sizeof(GrGLProgram::Desc),
bsalomon@google.com9ba4fa62012-07-16 17:36:28 +0000152 // We may actually have kMaxEntries+1 shaders in the GL context because we create a new
153 // shader before evicting from the cache.
bsalomon@google.comc1d2a582012-06-01 15:08:19 +0000154 kMaxEntries = 32
155 };
156
157 class Entry;
bsalomon@google.com9ba4fa62012-07-16 17:36:28 +0000158 // The value of the hash key is based on the ProgramDesc.
159 typedef GrTBinHashKey<Entry, kKeySize> ProgramHashKey;
bsalomon@google.comc1d2a582012-06-01 15:08:19 +0000160
161 class Entry : public ::GrNoncopyable {
162 public:
bsalomon@google.com9ba4fa62012-07-16 17:36:28 +0000163 Entry() : fProgram(NULL), fLRUStamp(0) {}
164 Entry& operator = (const Entry& entry) {
165 GrSafeRef(entry.fProgram.get());
166 fProgram.reset(entry.fProgram.get());
167 fKey = entry.fKey;
168 fLRUStamp = entry.fLRUStamp;
169 return *this;
170 }
bsalomon@google.comc1d2a582012-06-01 15:08:19 +0000171 int compare(const ProgramHashKey& key) const {
172 return fKey.compare(key);
173 }
174
175 public:
bsalomon@google.com9ba4fa62012-07-16 17:36:28 +0000176 SkAutoTUnref<GrGLProgram> fProgram;
177 ProgramHashKey fKey;
178 unsigned int fLRUStamp; // Move outside entry?
bsalomon@google.comc1d2a582012-06-01 15:08:19 +0000179 };
180
181 GrTHashTable<Entry, ProgramHashKey, 8> fHashCache;
182
183 Entry fEntries[kMaxEntries];
184 int fCount;
185 unsigned int fCurrLRUStamp;
robertphillips@google.com6177e692013-02-28 20:16:25 +0000186 const GrGLContext& fGL;
bsalomon@google.comc1d2a582012-06-01 15:08:19 +0000187 };
bsalomon@google.com5739d2c2012-05-31 15:07:19 +0000188
bsalomon@google.com6a51dcb2013-02-13 16:03:51 +0000189 // sets the matrix for path stenciling (uses the GL fixed pipe matrices)
190 void flushPathStencilMatrix();
bsalomon@google.com5739d2c2012-05-31 15:07:19 +0000191
bsalomon@google.comc96cb3a2012-06-04 19:31:00 +0000192 // flushes dithering, color-mask, and face culling stat
193 void flushMiscFixedFunctionState();
194
bsalomon@google.coma3201942012-06-21 19:58:20 +0000195 // flushes the scissor. see the note on flushBoundTextureAndParams about
196 // flushing the scissor after that function is called.
197 void flushScissor();
198
bsalomon@google.com67e78c92012-10-17 13:36:14 +0000199 // Inits GrDrawTarget::Caps, subclass may enable additional caps.
bsalomon@google.com18c9c192011-09-22 21:01:31 +0000200 void initCaps();
201
202 void initFSAASupport();
bsalomon@google.com6aa25c32011-04-27 19:55:29 +0000203
bsalomon@google.com2c17fcd2011-07-06 17:47:02 +0000204 // determines valid stencil formats
bsalomon@google.com18c9c192011-09-22 21:01:31 +0000205 void initStencilFormats();
bsalomon@google.com2c17fcd2011-07-06 17:47:02 +0000206
bsalomon@google.com8531c1c2011-01-13 19:52:45 +0000207 void setSpareTextureUnit();
reed@google.comac10a2d2010-12-22 21:39:39 +0000208
bsalomon@google.com8295dc12011-05-02 12:53:34 +0000209 // bound is region that may be modified and therefore has to be resolved.
210 // NULL means whole target. Can be an empty rect.
211 void flushRenderTarget(const GrIRect* bound);
bsalomon@google.comded4f4b2012-06-28 18:48:06 +0000212 void flushStencil(DrawType);
213 void flushAAState(DrawType);
bsalomon@google.com0650e812011-04-08 18:07:53 +0000214
bsalomon@google.com280e99f2012-01-05 16:17:38 +0000215 bool configToGLFormats(GrPixelConfig config,
216 bool getSizedInternal,
217 GrGLenum* internalFormat,
218 GrGLenum* externalFormat,
219 GrGLenum* externalType);
bsalomon@google.com6f379512011-11-16 20:36:03 +0000220 // helper for onCreateTexture and writeTexturePixels
bsalomon@google.com136f55b2011-11-28 18:34:44 +0000221 bool uploadTexData(const GrGLTexture::Desc& desc,
bsalomon@google.com1e0e6072011-11-28 18:49:37 +0000222 bool isNewTexture,
bsalomon@google.com6f379512011-11-16 20:36:03 +0000223 int left, int top, int width, int height,
224 GrPixelConfig dataConfig,
225 const void* data,
226 size_t rowBytes);
bsalomon@google.com0650e812011-04-08 18:07:53 +0000227
bsalomon@google.com81c3f8d2011-08-03 15:18:33 +0000228 bool createRenderTargetObjects(int width, int height,
229 GrGLuint texID,
230 GrGLRenderTarget::Desc* desc);
231
robertphillips@google.com99a5ac02012-04-10 19:26:38 +0000232 void fillInConfigRenderableTable();
233
robertphillips@google.com6177e692013-02-28 20:16:25 +0000234 GrGLContext fGLContext;
bsalomon@google.com2c17fcd2011-07-06 17:47:02 +0000235
bsalomon@google.com5739d2c2012-05-31 15:07:19 +0000236 // GL program-related state
237 ProgramCache* fProgramCache;
bsalomon@google.com9ba4fa62012-07-16 17:36:28 +0000238 SkAutoTUnref<GrGLProgram> fCurrentProgram;
bsalomon@google.com49209392012-06-05 15:13:46 +0000239
240 ///////////////////////////////////////////////////////////////////////////
241 ///@name Caching of GL State
242 ///@{
243 int fHWActiveTextureUnitIdx;
bsalomon@google.com5739d2c2012-05-31 15:07:19 +0000244 GrGLuint fHWProgramID;
bsalomon@google.com91207482013-02-12 21:45:24 +0000245
246 GrGLProgram::SharedGLState fSharedGLProgramState;
bsalomon@google.com5739d2c2012-05-31 15:07:19 +0000247
bsalomon@google.com49209392012-06-05 15:13:46 +0000248 enum TriState {
249 kNo_TriState,
250 kYes_TriState,
251 kUnknown_TriState
252 };
253
bsalomon@google.coma3201942012-06-21 19:58:20 +0000254 // last scissor / viewport scissor state seen by the GL.
255 struct {
256 TriState fEnabled;
257 GrGLIRect fRect;
258 void invalidate() {
259 fEnabled = kUnknown_TriState;
260 fRect.invalidate();
261 }
262 } fHWScissorSettings;
263
264 GrGLIRect fHWViewport;
265
bsalomon@google.com880b8fc2013-02-19 20:17:28 +0000266 /**
267 * Tracks bound vertex and index buffers and vertex attrib array state.
268 */
269 class HWGeometryState {
270 public:
271 HWGeometryState() { fAttribArrayCount = 0; this->invalidate();}
272
273 void setMaxAttribArrays(int max) {
274 fAttribArrayCount = max;
275 fAttribArrays.reset(max);
276 for (int i = 0; i < fAttribArrayCount; ++i) {
277 fAttribArrays[i].invalidate();
278 }
279 }
280
281 void invalidate() {
282 fBoundVertexBufferIDIsValid = false;
283 fBoundIndexBufferIDIsValid = false;
284 for (int i = 0; i < fAttribArrayCount; ++i) {
285 fAttribArrays[i].invalidate();
286 }
287 }
288
bsalomon@google.come49ad452013-02-20 19:33:20 +0000289 void notifyVertexBufferDelete(GrGLuint id) {
bsalomon@google.com880b8fc2013-02-19 20:17:28 +0000290 if (0 != id) {
291 if (this->isVertexBufferIDBound(id)) {
292 // deleting bound buffer does implied bind to 0
293 this->setVertexBufferID(0);
294 }
295 for (int i = 0; i < fAttribArrayCount; ++i) {
robertphillips@google.com37ebe3f2013-03-04 20:03:44 +0000296 if (fAttribArrays[i].isVertexBufferIDBound(id)) {
bsalomon@google.com880b8fc2013-02-19 20:17:28 +0000297 fAttribArrays[i].invalidate();
298 }
299 }
300 }
301 }
302
bsalomon@google.come49ad452013-02-20 19:33:20 +0000303 void notifyIndexBufferDelete(GrGLuint id) {
bsalomon@google.com880b8fc2013-02-19 20:17:28 +0000304 if (0 != id) {
305 if (this->isIndexBufferIDBound(id)) {
306 // deleting bound buffer does implied bind to 0
307 this->setIndexBufferID(0);
308 }
309 }
310 }
311
312 void setVertexBufferID(GrGLuint id) {
313 fBoundVertexBufferIDIsValid = true;
314 fBoundVertexBufferID = id;
315 }
316
317 void setIndexBufferID(GrGLuint id) {
318 fBoundIndexBufferIDIsValid = true;
319 fBoundIndexBufferID = id;
320 }
321
322 bool isVertexBufferIDBound(GrGLuint id) const {
323 return fBoundVertexBufferIDIsValid && id == fBoundVertexBufferID;
324 }
325
326 bool isIndexBufferIDBound(GrGLuint id) const {
327 return fBoundIndexBufferIDIsValid && id == fBoundIndexBufferID;
328 }
329
330 void setAttribArray(const GrGpuGL* gpu,
331 int index,
332 GrGLVertexBuffer* vertexBuffer,
333 GrGLint size,
334 GrGLenum type,
335 GrGLboolean normalized,
336 GrGLsizei stride,
337 GrGLvoid* offset) {
338 GrAssert(index >= 0 && index < fAttribArrayCount);
339 AttribArray* attrib = fAttribArrays.get() + index;
340 attrib->set(gpu, this, index, vertexBuffer, size, type, normalized, stride, offset);
341 }
342
343 void disableUnusedAttribArrays(const GrGpuGL* gpu,
344 uint32_t usedAttribIndexMask) {
345 for (int i = 0; i < fAttribArrayCount; ++i) {
346 if (!(usedAttribIndexMask & (1 << i))) {
347 fAttribArrays[i].disable(gpu, i);
348 }
349 }
350 }
351
352 private:
353 GrGLuint fBoundVertexBufferID;
354 GrGLuint fBoundIndexBufferID;
355 bool fBoundVertexBufferIDIsValid;
356 bool fBoundIndexBufferIDIsValid;
357
358 struct AttribArray {
359 public:
360 void set(const GrGpuGL* gpu,
361 HWGeometryState* geoState,
362 int index,
363 GrGLVertexBuffer* vertexBuffer,
364 GrGLint size,
365 GrGLenum type,
366 GrGLboolean normalized,
367 GrGLsizei stride,
368 GrGLvoid* offset);
369
370 void disable(const GrGpuGL* gpu, int index) {
371 if (!fEnableIsValid || fEnabled) {
372 GR_GL_CALL(gpu->glInterface(), DisableVertexAttribArray(index));
373 fEnableIsValid = true;
374 fEnabled = false;
375 }
376 }
377
378 void invalidate() {
379 fEnableIsValid = false;
380 fAttribPointerIsValid = false;
381 }
382
robertphillips@google.com37ebe3f2013-03-04 20:03:44 +0000383 bool isVertexBufferIDBound(GrGLuint id) const {
384 return fAttribPointerIsValid && id == fVertexBufferID;
385 }
bsalomon@google.com880b8fc2013-02-19 20:17:28 +0000386 private:
387 bool fEnableIsValid;
388 bool fAttribPointerIsValid;
389 bool fEnabled;
390 GrGLuint fVertexBufferID;
391 GrGLint fSize;
392 GrGLenum fType;
393 GrGLboolean fNormalized;
394 GrGLsizei fStride;
395 GrGLvoid* fOffset;
396 };
397 SkAutoTArray<AttribArray> fAttribArrays;
398 int fAttribArrayCount;
bsalomon@google.com49209392012-06-05 15:13:46 +0000399 } fHWGeometryState;
bsalomon@google.com5782d712011-01-21 21:03:59 +0000400
bsalomon@google.coma4d8fc22012-05-21 13:21:46 +0000401 struct {
402 GrBlendCoeff fSrcCoeff;
403 GrBlendCoeff fDstCoeff;
404 GrColor fConstColor;
405 bool fConstColorValid;
406 TriState fEnabled;
407
408 void invalidate() {
bsalomon@google.com47059542012-06-06 20:51:20 +0000409 fSrcCoeff = kInvalid_GrBlendCoeff;
410 fDstCoeff = kInvalid_GrBlendCoeff;
bsalomon@google.coma4d8fc22012-05-21 13:21:46 +0000411 fConstColorValid = false;
412 fEnabled = kUnknown_TriState;
413 }
414 } fHWBlendState;
415
bsalomon@google.com4d5f3fe2012-05-21 17:11:44 +0000416 struct {
417 TriState fMSAAEnabled;
418 TriState fSmoothLineEnabled;
419 void invalidate() {
420 fMSAAEnabled = kUnknown_TriState;
421 fSmoothLineEnabled = kUnknown_TriState;
422 }
423 } fHWAAState;
424
bsalomon@google.comded4f4b2012-06-28 18:48:06 +0000425
bsalomon@google.com6a51dcb2013-02-13 16:03:51 +0000426 GrGLProgram::MatrixState fHWPathStencilMatrixState;
bsalomon@google.com457b8a32012-05-21 21:19:58 +0000427
bsalomon@google.com6a51dcb2013-02-13 16:03:51 +0000428 GrStencilSettings fHWStencilSettings;
429 TriState fHWStencilTestEnabled;
430
431 GrDrawState::DrawFace fHWDrawFace;
432 TriState fHWWriteToColor;
433 TriState fHWDitherEnabled;
434 GrRenderTarget* fHWBoundRenderTarget;
435 GrTexture* fHWBoundTextures[GrDrawState::kNumStages];
bsalomon@google.com49209392012-06-05 15:13:46 +0000436 ///@}
bsalomon@google.com978c8c62012-05-21 14:45:49 +0000437
bsalomon@google.comfe676522011-06-17 18:12:21 +0000438 // we record what stencil format worked last time to hopefully exit early
439 // from our loop that tries stencil formats and calls check fb status.
440 int fLastSuccessfulStencilFmtIdx;
441
bsalomon@google.com18c9c192011-09-22 21:01:31 +0000442 bool fPrintedCaps;
443
reed@google.comac10a2d2010-12-22 21:39:39 +0000444 typedef GrGpu INHERITED;
445};
446
bsalomon@google.coma7f84e12011-03-10 14:13:19 +0000447#endif