OLD | NEW |
---|---|
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "gpu/command_buffer/service/vertex_attrib_manager.h" | 5 #include "gpu/command_buffer/service/vertex_attrib_manager.h" |
6 | 6 |
7 #include <stdint.h> | 7 #include <stdint.h> |
8 | 8 |
9 #include <list> | 9 #include <list> |
10 | 10 |
(...skipping 109 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
120 glDeleteVertexArraysOES(1, &service_id_); | 120 glDeleteVertexArraysOES(1, &service_id_); |
121 } | 121 } |
122 manager_->StopTracking(this); | 122 manager_->StopTracking(this); |
123 manager_ = NULL; | 123 manager_ = NULL; |
124 } | 124 } |
125 } | 125 } |
126 | 126 |
127 void VertexAttribManager::Initialize(uint32_t max_vertex_attribs, | 127 void VertexAttribManager::Initialize(uint32_t max_vertex_attribs, |
128 bool init_attribs) { | 128 bool init_attribs) { |
129 vertex_attribs_.resize(max_vertex_attribs); | 129 vertex_attribs_.resize(max_vertex_attribs); |
130 max_vertex_attribs_ = max_vertex_attribs; | 130 uint32_t packed_size = max_vertex_attribs / 16; |
131 uint32_t packed_size = max_vertex_attribs_ / 16; | 131 packed_size += (max_vertex_attribs % 16 == 0) ? 0 : 1; |
piman
2016/07/25 20:04:04
nit: ditto, uint32_t packed_size = (max_vertex_att
| |
132 packed_size += (max_vertex_attribs_ % 16 == 0) ? 0 : 1; | |
133 attrib_base_type_mask_.resize(packed_size); | 132 attrib_base_type_mask_.resize(packed_size); |
134 attrib_enabled_mask_.resize(packed_size); | 133 attrib_enabled_mask_.resize(packed_size); |
135 | 134 |
136 for (uint32_t ii = 0; ii < packed_size; ++ii) { | 135 for (uint32_t ii = 0; ii < packed_size; ++ii) { |
137 attrib_enabled_mask_[ii] = 0u; | 136 attrib_enabled_mask_[ii] = 0u; |
138 attrib_base_type_mask_[ii] = 0u; | 137 attrib_base_type_mask_[ii] = 0u; |
139 } | 138 } |
140 | 139 |
141 for (uint32_t vv = 0; vv < vertex_attribs_.size(); ++vv) { | 140 for (uint32_t vv = 0; vv < vertex_attribs_.size(); ++vv) { |
142 vertex_attribs_[vv].set_index(vv); | 141 vertex_attribs_[vv].set_index(vv); |
143 vertex_attribs_[vv].SetList(&disabled_vertex_attribs_); | 142 vertex_attribs_[vv].SetList(&disabled_vertex_attribs_); |
144 | 143 |
145 if (init_attribs) { | 144 if (init_attribs) { |
146 glVertexAttrib4f(vv, 0.0f, 0.0f, 0.0f, 1.0f); | 145 glVertexAttrib4f(vv, 0.0f, 0.0f, 0.0f, 1.0f); |
147 } | 146 } |
148 } | 147 } |
149 } | 148 } |
150 | 149 |
151 void VertexAttribManager::SetElementArrayBuffer(Buffer* buffer) { | 150 void VertexAttribManager::SetElementArrayBuffer(Buffer* buffer) { |
152 element_array_buffer_ = buffer; | 151 element_array_buffer_ = buffer; |
153 } | 152 } |
154 | 153 |
155 bool VertexAttribManager::Enable(GLuint index, bool enable) { | 154 bool VertexAttribManager::Enable(GLuint index, bool enable) { |
156 if (index >= vertex_attribs_.size()) { | 155 if (index >= vertex_attribs_.size()) { |
157 return false; | 156 return false; |
158 } | 157 } |
159 | 158 |
160 DCHECK(index < max_vertex_attribs_); | |
161 GLuint shift_bits = (index % 16) * 2; | |
162 if (enable) { | |
163 attrib_enabled_mask_[index / 16] |= (0x3 << shift_bits); | |
164 } else { | |
165 attrib_enabled_mask_[index / 16] &= ~(0x3 << shift_bits); | |
166 } | |
167 | |
168 VertexAttrib& info = vertex_attribs_[index]; | 159 VertexAttrib& info = vertex_attribs_[index]; |
169 if (info.enabled() != enable) { | 160 if (info.enabled() != enable) { |
170 info.set_enabled(enable); | 161 info.set_enabled(enable); |
171 info.SetList(enable ? &enabled_vertex_attribs_ : &disabled_vertex_attribs_); | 162 info.SetList(enable ? &enabled_vertex_attribs_ : &disabled_vertex_attribs_); |
163 GLuint shift_bits = (index % 16) * 2; | |
Zhenyao Mo
2016/07/23 16:10:40
We only need to do this if the glEnableDisable cal
yunchao
2016/07/24 04:52:13
Acknowledged.
| |
164 if (enable) { | |
165 attrib_enabled_mask_[index / 16] |= (0x3 << shift_bits); | |
166 } else { | |
167 attrib_enabled_mask_[index / 16] &= ~(0x3 << shift_bits); | |
168 } | |
172 } | 169 } |
173 return true; | 170 return true; |
174 } | 171 } |
175 | 172 |
176 void VertexAttribManager::Unbind(Buffer* buffer) { | 173 void VertexAttribManager::Unbind(Buffer* buffer) { |
177 if (element_array_buffer_.get() == buffer) { | 174 if (element_array_buffer_.get() == buffer) { |
178 element_array_buffer_ = NULL; | 175 element_array_buffer_ = NULL; |
179 } | 176 } |
180 for (uint32_t vv = 0; vv < vertex_attribs_.size(); ++vv) { | 177 for (uint32_t vv = 0; vv < vertex_attribs_.size(); ++vv) { |
181 vertex_attribs_[vv].Unbind(buffer); | 178 vertex_attribs_[vv].Unbind(buffer); |
(...skipping 112 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
294 if (current_buffer_id != kInitialBufferId) { | 291 if (current_buffer_id != kInitialBufferId) { |
295 // Restore the buffer binding. | 292 // Restore the buffer binding. |
296 decoder->RestoreBufferBindings(); | 293 decoder->RestoreBufferBindings(); |
297 } | 294 } |
298 | 295 |
299 return true; | 296 return true; |
300 } | 297 } |
301 | 298 |
302 } // namespace gles2 | 299 } // namespace gles2 |
303 } // namespace gpu | 300 } // namespace gpu |
OLD | NEW |