blob: 82cffaaec489223f45586b6817fc7012f89d61ab [file] [log] [blame]
reed@google.comac10a2d2010-12-22 21:39:39 +00001/*
2 Copyright 2010 Google Inc.
3
4 Licensed under the Apache License, Version 2.0 (the "License");
5 you may not use this file except in compliance with the License.
6 You may obtain a copy of the License at
7
8 http://www.apache.org/licenses/LICENSE-2.0
9
10 Unless required by applicable law or agreed to in writing, software
11 distributed under the License is distributed on an "AS IS" BASIS,
12 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 See the License for the specific language governing permissions and
14 limitations under the License.
15 */
16
17
18#include "GrGLIndexBuffer.h"
19#include "GrGpuGL.h"
20
21GrGLIndexBuffer::GrGLIndexBuffer(GLuint id, GrGpuGL* gl, uint32_t sizeInBytes,
22 bool dynamic) :
23 INHERITED(sizeInBytes, dynamic),
24 fGL(gl),
25 fBufferID(id),
26 fLockPtr(NULL) {
27}
28
29GLuint GrGLIndexBuffer::bufferID() const {
30 return fBufferID;
31}
32
33GrGLIndexBuffer::~GrGLIndexBuffer() {
34 // make sure we've not been abandoned
35 if (fBufferID) {
36 fGL->notifyIndexBufferDelete(this);
37 GR_GL(DeleteBuffers(1, &fBufferID));
38 }
39}
40
41void GrGLIndexBuffer::abandon() {
42 fBufferID = 0;
43 fGL = NULL;
44 fLockPtr = NULL;
45}
46
47void* GrGLIndexBuffer::lock() {
48 GrAssert(fBufferID);
49 GrAssert(!isLocked());
50 if (fGL->supportsBufferLocking()) {
51 GR_GL(BindBuffer(GL_ELEMENT_ARRAY_BUFFER, fBufferID));
52 fGL->notifyIndexBufferBind(this);
53 // call bufferData with null ptr to allow driver to perform renaming
54 // If this call is removed revisit updateData to be sure it doesn't
55 // leave buffer undersized (as it currently does).
56 GR_GL(BufferData(GL_ELEMENT_ARRAY_BUFFER, size(), NULL,
57 dynamic() ? GL_DYNAMIC_DRAW : GL_STATIC_DRAW));
58 fLockPtr = GR_GLEXT(fGL->extensions(),
59 MapBuffer(GL_ELEMENT_ARRAY_BUFFER, GR_WRITE_ONLY));
60
61 return fLockPtr;
62 }
63 return NULL;
64}
65
66void GrGLIndexBuffer::unlock() {
67 GrAssert(fBufferID);
68 GrAssert(isLocked());
69
70 if (fGL->supportsBufferLocking()) {
71 GR_GL(BindBuffer(GL_ELEMENT_ARRAY_BUFFER, fBufferID));
72 fGL->notifyIndexBufferBind(this);
73 GR_GLEXT(fGL->extensions(),
74 UnmapBuffer(GL_ELEMENT_ARRAY_BUFFER));
75 fLockPtr = NULL;
76 }
77}
78
79bool GrGLIndexBuffer::isLocked() const {
80 GrAssert(fBufferID);
81#if GR_DEBUG
82 if (fGL->supportsBufferLocking()) {
83 GLint mapped;
84 GR_GL(BindBuffer(GL_ELEMENT_ARRAY_BUFFER, fBufferID));
85 fGL->notifyIndexBufferBind(this);
86 GR_GL(GetBufferParameteriv(GL_ELEMENT_ARRAY_BUFFER,
87 GR_BUFFER_MAPPED, &mapped));
88 GrAssert(!!mapped == !!fLockPtr);
89 }
90#endif
91 return NULL != fLockPtr;
92}
93
94bool GrGLIndexBuffer::updateData(const void* src, uint32_t srcSizeInBytes) {
95 GrAssert(fBufferID);
96 GrAssert(!isLocked());
97 if (srcSizeInBytes > size()) {
98 return false;
99 }
100 GR_GL(BindBuffer(GL_ELEMENT_ARRAY_BUFFER, fBufferID));
101 fGL->notifyIndexBufferBind(this);
102 GR_GL(BufferData(GL_ELEMENT_ARRAY_BUFFER, srcSizeInBytes, src,
103 dynamic() ? GL_DYNAMIC_DRAW : GL_STATIC_DRAW));
104 return true;
105}
106