| 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 #include "GrGpuGL.h" | 8 #include "GrGpuGL.h" |
| 9 | 9 |
| 10 #include "builders/GrGLProgramBuilder.h" | 10 #include "builders/GrGLProgramBuilder.h" |
| (...skipping 73 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 84 SkDELETE(fEntries[i]); | 84 SkDELETE(fEntries[i]); |
| 85 } | 85 } |
| 86 fCount = 0; | 86 fCount = 0; |
| 87 } | 87 } |
| 88 | 88 |
| 89 int GrGpuGL::ProgramCache::search(const GrProgramDesc& desc) const { | 89 int GrGpuGL::ProgramCache::search(const GrProgramDesc& desc) const { |
| 90 ProgDescLess less; | 90 ProgDescLess less; |
| 91 return SkTSearch(fEntries, fCount, desc, sizeof(Entry*), less); | 91 return SkTSearch(fEntries, fCount, desc, sizeof(Entry*), less); |
| 92 } | 92 } |
| 93 | 93 |
| 94 GrGLProgram* GrGpuGL::ProgramCache::getProgram(const GrOptDrawState& optState, D
rawType type) { | 94 GrGLProgram* GrGpuGL::ProgramCache::getProgram(const GrOptDrawState& optState, |
| 95 const GrProgramDesc& desc, |
| 96 DrawType type) { |
| 95 #ifdef PROGRAM_CACHE_STATS | 97 #ifdef PROGRAM_CACHE_STATS |
| 96 ++fTotalRequests; | 98 ++fTotalRequests; |
| 97 #endif | 99 #endif |
| 98 | 100 |
| 99 Entry* entry = NULL; | 101 Entry* entry = NULL; |
| 100 | 102 |
| 101 uint32_t hashIdx = optState.programDesc().getChecksum(); | 103 uint32_t hashIdx = desc.getChecksum(); |
| 102 hashIdx ^= hashIdx >> 16; | 104 hashIdx ^= hashIdx >> 16; |
| 103 if (kHashBits <= 8) { | 105 if (kHashBits <= 8) { |
| 104 hashIdx ^= hashIdx >> 8; | 106 hashIdx ^= hashIdx >> 8; |
| 105 } | 107 } |
| 106 hashIdx &=((1 << kHashBits) - 1); | 108 hashIdx &=((1 << kHashBits) - 1); |
| 107 Entry* hashedEntry = fHashTable[hashIdx]; | 109 Entry* hashedEntry = fHashTable[hashIdx]; |
| 108 if (hashedEntry && hashedEntry->fProgram->getDesc() == optState.programDesc(
)) { | 110 if (hashedEntry && hashedEntry->fProgram->getDesc() == desc) { |
| 109 SkASSERT(hashedEntry->fProgram); | 111 SkASSERT(hashedEntry->fProgram); |
| 110 entry = hashedEntry; | 112 entry = hashedEntry; |
| 111 } | 113 } |
| 112 | 114 |
| 113 int entryIdx; | 115 int entryIdx; |
| 114 if (NULL == entry) { | 116 if (NULL == entry) { |
| 115 entryIdx = this->search(optState.programDesc()); | 117 entryIdx = this->search(desc); |
| 116 if (entryIdx >= 0) { | 118 if (entryIdx >= 0) { |
| 117 entry = fEntries[entryIdx]; | 119 entry = fEntries[entryIdx]; |
| 118 #ifdef PROGRAM_CACHE_STATS | 120 #ifdef PROGRAM_CACHE_STATS |
| 119 ++fHashMisses; | 121 ++fHashMisses; |
| 120 #endif | 122 #endif |
| 121 } | 123 } |
| 122 } | 124 } |
| 123 | 125 |
| 124 if (NULL == entry) { | 126 if (NULL == entry) { |
| 125 // We have a cache miss | 127 // We have a cache miss |
| 126 #ifdef PROGRAM_CACHE_STATS | 128 #ifdef PROGRAM_CACHE_STATS |
| 127 ++fCacheMisses; | 129 ++fCacheMisses; |
| 128 #endif | 130 #endif |
| 129 GrGLProgram* program = GrGLProgramBuilder::CreateProgram(optState, type,
fGpu); | 131 GrGLProgram* program = GrGLProgramBuilder::CreateProgram(optState, desc,
type, fGpu); |
| 130 if (NULL == program) { | 132 if (NULL == program) { |
| 131 return NULL; | 133 return NULL; |
| 132 } | 134 } |
| 133 int purgeIdx = 0; | 135 int purgeIdx = 0; |
| 134 if (fCount < kMaxEntries) { | 136 if (fCount < kMaxEntries) { |
| 135 entry = SkNEW(Entry); | 137 entry = SkNEW(Entry); |
| 136 purgeIdx = fCount++; | 138 purgeIdx = fCount++; |
| 137 fEntries[purgeIdx] = entry; | 139 fEntries[purgeIdx] = entry; |
| 138 } else { | 140 } else { |
| 139 SkASSERT(fCount == kMaxEntries); | 141 SkASSERT(fCount == kMaxEntries); |
| (...skipping 54 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 194 } | 196 } |
| 195 } | 197 } |
| 196 ++fCurrLRUStamp; | 198 ++fCurrLRUStamp; |
| 197 return entry->fProgram; | 199 return entry->fProgram; |
| 198 } | 200 } |
| 199 | 201 |
| 200 //////////////////////////////////////////////////////////////////////////////// | 202 //////////////////////////////////////////////////////////////////////////////// |
| 201 | 203 |
| 202 #define GL_CALL(X) GR_GL_CALL(this->glInterface(), X) | 204 #define GL_CALL(X) GR_GL_CALL(this->glInterface(), X) |
| 203 | 205 |
| 204 bool GrGpuGL::flushGraphicsState(const GrOptDrawState& optState, DrawType type)
{ | 206 bool GrGpuGL::flushGraphicsState(const GrOptDrawState& optState, |
| 207 const GrProgramDesc& desc, |
| 208 DrawType type) { |
| 205 // GrGpu::setupClipAndFlushState should have already checked this and bailed
if not true. | 209 // GrGpu::setupClipAndFlushState should have already checked this and bailed
if not true. |
| 206 SkASSERT(optState.getRenderTarget()); | 210 SkASSERT(optState.getRenderTarget()); |
| 207 | 211 |
| 208 if (kStencilPath_DrawType == type) { | 212 if (kStencilPath_DrawType == type) { |
| 209 const GrRenderTarget* rt = optState.getRenderTarget(); | 213 const GrRenderTarget* rt = optState.getRenderTarget(); |
| 210 SkISize size; | 214 SkISize size; |
| 211 size.set(rt->width(), rt->height()); | 215 size.set(rt->width(), rt->height()); |
| 212 this->glPathRendering()->setProjectionMatrix(optState.getViewMatrix(), s
ize, rt->origin()); | 216 this->glPathRendering()->setProjectionMatrix(optState.getViewMatrix(), s
ize, rt->origin()); |
| 213 } else { | 217 } else { |
| 214 this->flushMiscFixedFunctionState(optState); | 218 this->flushMiscFixedFunctionState(optState); |
| 215 | 219 |
| 216 GrBlendCoeff srcCoeff = optState.getSrcBlendCoeff(); | 220 GrBlendCoeff srcCoeff = optState.getSrcBlendCoeff(); |
| 217 GrBlendCoeff dstCoeff = optState.getDstBlendCoeff(); | 221 GrBlendCoeff dstCoeff = optState.getDstBlendCoeff(); |
| 218 | 222 |
| 219 fCurrentProgram.reset(fProgramCache->getProgram(optState, type)); | 223 fCurrentProgram.reset(fProgramCache->getProgram(optState, desc, type)); |
| 220 if (NULL == fCurrentProgram.get()) { | 224 if (NULL == fCurrentProgram.get()) { |
| 221 SkDEBUGFAIL("Failed to create program!"); | 225 SkDEBUGFAIL("Failed to create program!"); |
| 222 return false; | 226 return false; |
| 223 } | 227 } |
| 224 | 228 |
| 225 fCurrentProgram.get()->ref(); | 229 fCurrentProgram.get()->ref(); |
| 226 | 230 |
| 227 GrGLuint programID = fCurrentProgram->programID(); | 231 GrGLuint programID = fCurrentProgram->programID(); |
| 228 if (fHWProgramID != programID) { | 232 if (fHWProgramID != programID) { |
| 229 GL_CALL(UseProgram(programID)); | 233 GL_CALL(UseProgram(programID)); |
| (...skipping 65 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 295 GrGLAttribTypeToLayout(attribType).fNormalized, | 299 GrGLAttribTypeToLayout(attribType).fNormalized, |
| 296 stride, | 300 stride, |
| 297 reinterpret_cast<GrGLvoid*>(vertexOffsetInBytes + o
ffset)); | 301 reinterpret_cast<GrGLvoid*>(vertexOffsetInBytes + o
ffset)); |
| 298 offset += attribs[attribIndex].fOffset; | 302 offset += attribs[attribIndex].fOffset; |
| 299 } | 303 } |
| 300 attribState->disableUnusedArrays(this, usedAttribArraysMask); | 304 attribState->disableUnusedArrays(this, usedAttribArraysMask); |
| 301 } | 305 } |
| 302 } | 306 } |
| 303 | 307 |
| 304 void GrGpuGL::buildProgramDesc(const GrOptDrawState& optState, | 308 void GrGpuGL::buildProgramDesc(const GrOptDrawState& optState, |
| 305 const GrProgramDesc::DescInfo& descInfo, | |
| 306 GrGpu::DrawType drawType, | 309 GrGpu::DrawType drawType, |
| 307 GrProgramDesc* desc) { | 310 GrProgramDesc* desc) { |
| 308 if (!GrGLProgramDescBuilder::Build(optState, descInfo, drawType, this, desc)
) { | 311 if (!GrGLProgramDescBuilder::Build(optState, drawType, this, desc)) { |
| 309 SkDEBUGFAIL("Failed to generate GL program descriptor"); | 312 SkDEBUGFAIL("Failed to generate GL program descriptor"); |
| 310 } | 313 } |
| 311 } | 314 } |
| OLD | NEW |