Chromium Code Reviews| Index: src/gpu/gl/GrGLCaps.cpp |
| diff --git a/src/gpu/gl/GrGLCaps.cpp b/src/gpu/gl/GrGLCaps.cpp |
| index 4a62c5acaab1ce370545f9b11d991153260d0e3f..9e9a21ff9195a797f4fe41645cdb9e5430a240a6 100644 |
| --- a/src/gpu/gl/GrGLCaps.cpp |
| +++ b/src/gpu/gl/GrGLCaps.cpp |
| @@ -48,6 +48,8 @@ void GrGLCaps::reset() { |
| fIsCoreProfile = false; |
| fFullClearIsFree = false; |
| fDropsTileOnZeroDivide = false; |
| + |
| + fReadPixelsSupportedCache.clear(); |
| } |
| GrGLCaps::GrGLCaps(const GrGLCaps& caps) : GrDrawTargetCaps() { |
| @@ -485,7 +487,7 @@ void GrGLCaps::initConfigTexturableTable(const GrGLContextInfo& ctxInfo, const G |
| // First check version for support |
| if (kGL_GrGLStandard == standard) { |
| hasETC1 = hasCompressTex2D && |
| - (version >= GR_GL_VER(4, 3) || |
| + (version >= GR_GL_VER(4, 3) || |
| ctxInfo.hasExtension("GL_ARB_ES3_compatibility")); |
| } else { |
| hasETC1 = hasCompressTex2D && |
| @@ -541,7 +543,7 @@ void GrGLCaps::initConfigTexturableTable(const GrGLContextInfo& ctxInfo, const G |
| } |
| } |
| -bool GrGLCaps::readPixelsSupported(const GrGLInterface* intf, |
| +bool GrGLCaps::doReadPixelsSupported(const GrGLInterface* intf, |
| GrGLenum format, |
|
bsalomon
2014/07/07 13:31:10
can you realign the params?
Rémi Piotaix
2014/07/07 18:10:16
Done.
|
| GrGLenum type) const { |
| if (GR_GL_RGBA == format && GR_GL_UNSIGNED_BYTE == type) { |
| @@ -570,6 +572,26 @@ bool GrGLCaps::readPixelsSupported(const GrGLInterface* intf, |
| return (GrGLenum)otherFormat == format && (GrGLenum)otherType == type; |
| } |
| +bool GrGLCaps::readPixelsSupported(const GrGLInterface* intf, |
| + GrGLenum format, |
| + GrGLenum type, |
| + GrGLenum currFboFormat) const { |
| + |
| + ReadPixelsSupportedFormatsKey key = {format, type, currFboFormat}; |
| + |
| + ReadPixelsSupportedFormats* cachedValue = fReadPixelsSupportedCache.find(key); |
| + |
| + if (NULL == cachedValue) { |
| + bool value = doReadPixelsSupported(intf, format, type); |
| + ReadPixelsSupportedFormats newElement(key, value); |
| + fReadPixelsSupportedCache.put(newElement); |
| + |
| + return newElement.value(); |
| + } |
| + |
| + return cachedValue->value(); |
| +} |
| + |
| void GrGLCaps::initFSAASupport(const GrGLContextInfo& ctxInfo, const GrGLInterface* gli) { |
| fMSFBOType = kNone_MSFBOType; |
| @@ -798,3 +820,17 @@ SkString GrGLCaps::dump() const { |
| r.appendf("Drops tile on zero divide: %s\n", (fDropsTileOnZeroDivide ? "YES" : "NO")); |
| return r; |
| } |
| + |
| +//Computes a hash based on the three values in the key struct |
| +// bits 31------------15---------7---------------0 |
| +// fFormat(15:0) fType(7:0) fFboFormat(7:0) |
| +uint32_t GrGLCaps::ReadPixelsSupportedFormats::Hash(const ReadPixelsSupportedFormatsKey& key) { |
| + // fFormat has different values like 0x190X or 0x8XXX: 16 bits are required |
| + uint32_t hash = ((static_cast<uint32_t>(key.fFormat) & 0xFFFF) << 16); |
| + // fType is 0x14XX: 8 lower bits are enough |
| + hash |= ((static_cast<uint32_t>(key.fType) & 0xFF) << 8); |
| + // fFboFormat is enum GrPixelConfig which has less than 15 values: 8 bits OK |
| + hash |= (static_cast<uint32_t>(key.fFboFormat) & 0xFF); |
| + |
| + return hash; |
| +} |