Index: src/gpu/GrGpu.cpp |
diff --git a/src/gpu/GrGpu.cpp b/src/gpu/GrGpu.cpp |
index 65100489f4b7ad01c94b83734440334bdd46a65d..1f01e124bf74a973348ad62706454482aaef2af6 100644 |
--- a/src/gpu/GrGpu.cpp |
+++ b/src/gpu/GrGpu.cpp |
@@ -164,39 +164,6 @@ |
return this->onCreateIndexBuffer(size, dynamic); |
} |
-GrIndexBuffer* GrGpu::createInstancedIndexBuffer(const uint16_t* pattern, |
- int patternSize, |
- int reps, |
- int vertCount, |
- bool isDynamic) { |
- size_t bufferSize = patternSize * reps * sizeof(uint16_t); |
- GrGpu* me = const_cast<GrGpu*>(this); |
- GrIndexBuffer* buffer = me->createIndexBuffer(bufferSize, isDynamic); |
- if (buffer) { |
- uint16_t* data = (uint16_t*) buffer->map(); |
- bool useTempData = (NULL == data); |
- if (useTempData) { |
- data = SkNEW_ARRAY(uint16_t, reps * patternSize); |
- } |
- for (int i = 0; i < reps; ++i) { |
- int baseIdx = i * patternSize; |
- uint16_t baseVert = (uint16_t)(i * vertCount); |
- for (int j = 0; j < patternSize; ++j) { |
- data[baseIdx+j] = baseVert + pattern[j]; |
- } |
- } |
- if (useTempData) { |
- if (!buffer->updateData(data, bufferSize)) { |
- SkFAIL("Can't get indices into buffer!"); |
- } |
- SkDELETE_ARRAY(data); |
- } else { |
- buffer->unmap(); |
- } |
- } |
- return buffer; |
-} |
- |
void GrGpu::clear(const SkIRect* rect, |
GrColor color, |
bool canIgnoreRect, |
@@ -279,18 +246,39 @@ |
GR_STATIC_ASSERT(4 * MAX_QUADS <= 65535); |
-static const uint16_t gQuadIndexPattern[] = { |
- 0, 1, 2, 0, 2, 3 |
-}; |
+static inline void fill_indices(uint16_t* indices, int quadCount) { |
+ for (int i = 0; i < quadCount; ++i) { |
+ indices[6 * i + 0] = 4 * i + 0; |
+ indices[6 * i + 1] = 4 * i + 1; |
+ indices[6 * i + 2] = 4 * i + 2; |
+ indices[6 * i + 3] = 4 * i + 0; |
+ indices[6 * i + 4] = 4 * i + 2; |
+ indices[6 * i + 5] = 4 * i + 3; |
+ } |
+} |
const GrIndexBuffer* GrGpu::getQuadIndexBuffer() const { |
if (NULL == fQuadIndexBuffer || fQuadIndexBuffer->wasDestroyed()) { |
SkSafeUnref(fQuadIndexBuffer); |
+ static const int SIZE = sizeof(uint16_t) * 6 * MAX_QUADS; |
GrGpu* me = const_cast<GrGpu*>(this); |
- fQuadIndexBuffer = me->createInstancedIndexBuffer(gQuadIndexPattern, |
- 6, |
- MAX_QUADS, |
- 4); |
+ fQuadIndexBuffer = me->createIndexBuffer(SIZE, false); |
+ if (fQuadIndexBuffer) { |
+ uint16_t* indices = (uint16_t*)fQuadIndexBuffer->map(); |
+ if (indices) { |
+ fill_indices(indices, MAX_QUADS); |
+ fQuadIndexBuffer->unmap(); |
+ } else { |
+ indices = (uint16_t*)sk_malloc_throw(SIZE); |
+ fill_indices(indices, MAX_QUADS); |
+ if (!fQuadIndexBuffer->updateData(indices, SIZE)) { |
+ fQuadIndexBuffer->unref(); |
+ fQuadIndexBuffer = NULL; |
+ SkFAIL("Can't get indices into buffer!"); |
+ } |
+ sk_free(indices); |
+ } |
+ } |
} |
return fQuadIndexBuffer; |