From a4d8fc24736e77fd8c588c4be63e3c15a4154860 Mon Sep 17 00:00:00 2001 From: "bsalomon@google.com" Date: Mon, 21 May 2012 13:21:46 +0000 Subject: Stop using GrDrawState to track GPU's blend state git-svn-id: http://skia.googlecode.com/svn/trunk@4007 2bbb7eff-a529-9590-31e7-b0007b416f81 --- include/gpu/GrTypes.h | 2 ++ src/gpu/gl/GrGpuGL.cpp | 48 ++++++++++++++++++++++-------------------------- src/gpu/gl/GrGpuGL.h | 23 +++++++++++++++++++++-- 3 files changed, 45 insertions(+), 28 deletions(-) diff --git a/include/gpu/GrTypes.h b/include/gpu/GrTypes.h index e3e5357075..0486cbf734 100644 --- a/include/gpu/GrTypes.h +++ b/include/gpu/GrTypes.h @@ -225,6 +225,8 @@ static inline bool GrIsPrimTypeTris(GrPrimitiveType type) { * Coeffecients for alpha-blending. */ enum GrBlendCoeff { + kInvalid_BlendCoeff = -1, + kZero_BlendCoeff, //glCaps().print(); } - // We detect cases when blending is effectively off - fHWBlendDisabled = false; - GL_CALL(Enable(GR_GL_BLEND)); - // we don't use the zb at all GL_CALL(Disable(GR_GL_DEPTH_TEST)); GL_CALL(DepthMask(GR_GL_FALSE)); @@ -486,11 +482,7 @@ void GrGpuGL::onResetContext() { // invalid fActiveTextureUnitIdx = -1; - // illegal values - fHWDrawState.setBlendFunc((GrBlendCoeff)0xFF, (GrBlendCoeff)0xFF); - - fHWDrawState.setBlendConstant(0x00000000); - GL_CALL(BlendColor(0,0,0,0)); + fHWBlendState.invalidate(); fHWDrawState.setColor(GrColor_ILLEGAL); @@ -1976,15 +1968,16 @@ void GrGpuGL::flushBlend(GrPrimitiveType type, GrBlendCoeff srcCoeff, GrBlendCoeff dstCoeff) { if (GrIsPrimTypeLines(type) && this->willUseHWAALines()) { - if (fHWBlendDisabled) { + if (kYes_TriState != fHWBlendState.fEnabled) { GL_CALL(Enable(GR_GL_BLEND)); - fHWBlendDisabled = false; + fHWBlendState.fEnabled = kYes_TriState; } - if (kSA_BlendCoeff != fHWDrawState.getSrcBlendCoeff() || - kISA_BlendCoeff != fHWDrawState.getDstBlendCoeff()) { + if (kSA_BlendCoeff != fHWBlendState.fSrcCoeff || + kISA_BlendCoeff != fHWBlendState.fDstCoeff) { GL_CALL(BlendFunc(gXfermodeCoeff2Blend[kSA_BlendCoeff], gXfermodeCoeff2Blend[kISA_BlendCoeff])); - fHWDrawState.setBlendFunc(kSA_BlendCoeff, kISA_BlendCoeff); + fHWBlendState.fSrcCoeff = kSA_BlendCoeff; + fHWBlendState.fDstCoeff = kISA_BlendCoeff; } } else { // any optimization to disable blending should @@ -1992,25 +1985,28 @@ void GrGpuGL::flushBlend(GrPrimitiveType type, // to (1, 0). bool blendOff = kOne_BlendCoeff == srcCoeff && kZero_BlendCoeff == dstCoeff; - if (fHWBlendDisabled != blendOff) { - if (blendOff) { + if (blendOff) { + if (kNo_TriState != fHWBlendState.fEnabled) { GL_CALL(Disable(GR_GL_BLEND)); - } else { + fHWBlendState.fEnabled = kNo_TriState; + } + } else { + if (kYes_TriState != fHWBlendState.fEnabled) { GL_CALL(Enable(GR_GL_BLEND)); + fHWBlendState.fEnabled = kYes_TriState; } - fHWBlendDisabled = blendOff; - } - if (!blendOff) { - if (fHWDrawState.getSrcBlendCoeff() != srcCoeff || - fHWDrawState.getDstBlendCoeff() != dstCoeff) { + if (fHWBlendState.fSrcCoeff != srcCoeff || + fHWBlendState.fDstCoeff != dstCoeff) { GL_CALL(BlendFunc(gXfermodeCoeff2Blend[srcCoeff], gXfermodeCoeff2Blend[dstCoeff])); - fHWDrawState.setBlendFunc(srcCoeff, dstCoeff); + fHWBlendState.fSrcCoeff = srcCoeff; + fHWBlendState.fDstCoeff = dstCoeff; } GrColor blendConst = this->getDrawState().getBlendConstant(); if ((BlendCoeffReferencesConstant(srcCoeff) || BlendCoeffReferencesConstant(dstCoeff)) && - fHWDrawState.getBlendConstant() != blendConst) { + (!fHWBlendState.fConstColorValid || + fHWBlendState.fConstColor != blendConst)) { float c[] = { GrColorUnpackR(blendConst) / 255.f, @@ -2019,12 +2015,12 @@ void GrGpuGL::flushBlend(GrPrimitiveType type, GrColorUnpackA(blendConst) / 255.f }; GL_CALL(BlendColor(c[0], c[1], c[2], c[3])); - fHWDrawState.setBlendConstant(blendConst); + fHWBlendState.fConstColor = blendConst; + fHWBlendState.fConstColorValid = true; } } } } - namespace { unsigned gr_to_gl_filter(GrSamplerState::Filter filter) { diff --git a/src/gpu/gl/GrGpuGL.h b/src/gpu/gl/GrGpuGL.h index b22b44f204..d5c9c27fa5 100644 --- a/src/gpu/gl/GrGpuGL.h +++ b/src/gpu/gl/GrGpuGL.h @@ -50,6 +50,12 @@ public: protected: GrGpuGL(const GrGLContextInfo& ctxInfo); + enum TriState { + kNo_TriState, + kYes_TriState, + kUnknown_TriState + }; + struct { size_t fVertexOffset; GrVertexLayout fVertexLayout; @@ -242,10 +248,23 @@ private: GrGLContextInfo fGLContextInfo; - bool fHWBlendDisabled; - int fActiveTextureUnitIdx; + struct { + GrBlendCoeff fSrcCoeff; + GrBlendCoeff fDstCoeff; + GrColor fConstColor; + bool fConstColorValid; + TriState fEnabled; + + void invalidate() { + fSrcCoeff = kInvalid_BlendCoeff; + fDstCoeff = kInvalid_BlendCoeff; + fConstColorValid = false; + fEnabled = kUnknown_TriState; + } + } fHWBlendState; + // we record what stencil format worked last time to hopefully exit early // from our loop that tries stencil formats and calls check fb status. int fLastSuccessfulStencilFmtIdx; -- cgit v1.2.3