blob: 6a2454a8eab59e2a9d57c8bc4dbeda02a4b98fa1 [file] [log] [blame]
Shannon Woods53a94a82014-06-24 15:20:36 -04001//
2// Copyright (c) 2014 The ANGLE Project Authors. All rights reserved.
3// Use of this source code is governed by a BSD-style license that can be
4// found in the LICENSE file.
5//
6
7// State.cpp: Implements the State class, encapsulating raw GL state.
8
Geoff Lang2b5420c2014-11-19 14:20:15 -05009#include "libANGLE/State.h"
Shannon Woods53a94a82014-06-24 15:20:36 -040010
Sami Väisänene45e53b2016-05-25 10:36:04 +030011#include <string.h>
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -070012#include <limits>
Sami Väisänene45e53b2016-05-25 10:36:04 +030013
Jamie Madill20e005b2017-04-07 14:19:22 -040014#include "common/bitset_utils.h"
Sami Väisänene45e53b2016-05-25 10:36:04 +030015#include "common/mathutil.h"
jchen10a99ed552017-09-22 08:10:32 +080016#include "common/matrix_utils.h"
Jamie Madillcd0a0a32018-10-18 18:41:57 -040017#include "libANGLE/Buffer.h"
Geoff Lang2b5420c2014-11-19 14:20:15 -050018#include "libANGLE/Caps.h"
jchen10a99ed552017-09-22 08:10:32 +080019#include "libANGLE/Context.h"
Geoff Lang70d0f492015-12-10 17:45:46 -050020#include "libANGLE/Debug.h"
Geoff Lang2b5420c2014-11-19 14:20:15 -050021#include "libANGLE/Framebuffer.h"
22#include "libANGLE/FramebufferAttachment.h"
23#include "libANGLE/Query.h"
24#include "libANGLE/VertexArray.h"
25#include "libANGLE/formatutils.h"
jchen10a99ed552017-09-22 08:10:32 +080026#include "libANGLE/queryconversions.h"
Lingfeng Yangabb09f12018-04-16 10:43:53 -070027#include "libANGLE/queryutils.h"
Geoff Lang4751aab2017-10-30 15:14:52 -040028#include "libANGLE/renderer/ContextImpl.h"
Jamie Madillf668a4b2018-09-23 17:01:20 -040029#include "libANGLE/renderer/TextureImpl.h"
Shannon Woods53a94a82014-06-24 15:20:36 -040030
Corentin Wallezad3ae902018-03-09 13:40:42 -050031namespace gl
32{
33
Olli Etuahobbf1c102016-06-28 13:31:33 +030034namespace
35{
Corentin Wallezad3ae902018-03-09 13:40:42 -050036bool GetAlternativeQueryType(QueryType type, QueryType *alternativeType)
Olli Etuahobbf1c102016-06-28 13:31:33 +030037{
Corentin Wallezad3ae902018-03-09 13:40:42 -050038 switch (type)
39 {
40 case QueryType::AnySamples:
41 *alternativeType = QueryType::AnySamplesConservative;
42 return true;
43 case QueryType::AnySamplesConservative:
44 *alternativeType = QueryType::AnySamples;
45 return true;
46 default:
47 return false;
48 }
Olli Etuahobbf1c102016-06-28 13:31:33 +030049}
50
Jamie Madillca8eda42018-10-18 18:41:56 -040051// Mapping from a buffer binding type to a dirty bit type.
52constexpr angle::PackedEnumMap<BufferBinding, size_t> kBufferBindingDirtyBits = {{
Jamie Madill752d2202018-11-27 13:29:48 -050053 {BufferBinding::AtomicCounter, State::DIRTY_BIT_ATOMIC_COUNTER_BUFFER_BINDING},
54 {BufferBinding::DispatchIndirect, State::DIRTY_BIT_DISPATCH_INDIRECT_BUFFER_BINDING},
55 {BufferBinding::DrawIndirect, State::DIRTY_BIT_DRAW_INDIRECT_BUFFER_BINDING},
56 {BufferBinding::PixelPack, State::DIRTY_BIT_PACK_BUFFER_BINDING},
57 {BufferBinding::PixelUnpack, State::DIRTY_BIT_UNPACK_BUFFER_BINDING},
58 {BufferBinding::ShaderStorage, State::DIRTY_BIT_SHADER_STORAGE_BUFFER_BINDING},
59 {BufferBinding::Uniform, State::DIRTY_BIT_UNIFORM_BUFFER_BINDINGS},
Jamie Madillca8eda42018-10-18 18:41:56 -040060}};
61
62// Returns a buffer binding function depending on if a dirty bit is set.
63template <BufferBinding Target>
Jamie Madill752d2202018-11-27 13:29:48 -050064constexpr std::pair<BufferBinding, State::BufferBindingSetter> GetBufferBindingSetter()
Jamie Madillca8eda42018-10-18 18:41:56 -040065{
Jamie Madill752d2202018-11-27 13:29:48 -050066 return std::make_pair(Target, kBufferBindingDirtyBits[Target] != 0
67 ? &State::setGenericBufferBindingWithBit<Target>
68 : &State::setGenericBufferBinding<Target>);
Jamie Madillca8eda42018-10-18 18:41:56 -040069}
Jamie Madillb980c562018-11-27 11:34:27 -050070} // namespace
Olli Etuahobbf1c102016-06-28 13:31:33 +030071
Jamie Madillbf5177d2018-08-21 12:58:20 -040072template <typename BindingT, typename... ArgsT>
Jamie Madillca8eda42018-10-18 18:41:56 -040073ANGLE_INLINE void UpdateNonTFBufferBinding(const Context *context,
74 BindingT *binding,
75 Buffer *buffer,
76 ArgsT... args)
James Darpiniane8a93c62018-01-04 18:02:24 -080077{
Jamie Madillca8eda42018-10-18 18:41:56 -040078 Buffer *oldBuffer = binding->get();
79 if (oldBuffer)
80 {
81 oldBuffer->onNonTFBindingChanged(-1);
82 oldBuffer->release(context);
83 }
84 binding->assign(buffer, args...);
85 if (buffer)
86 {
87 buffer->addRef();
88 buffer->onNonTFBindingChanged(1);
89 }
Jamie Madillbf5177d2018-08-21 12:58:20 -040090}
91
92template <typename BindingT, typename... ArgsT>
93void UpdateTFBufferBinding(const Context *context, BindingT *binding, bool indexed, ArgsT... args)
94{
95 if (binding->get())
96 (*binding)->onTFBindingChanged(context, false, indexed);
97 binding->set(context, args...);
98 if (binding->get())
99 (*binding)->onTFBindingChanged(context, true, indexed);
James Darpiniane8a93c62018-01-04 18:02:24 -0800100}
101
102void UpdateBufferBinding(const Context *context,
Jamie Madillbf5177d2018-08-21 12:58:20 -0400103 BindingPointer<Buffer> *binding,
James Darpiniane8a93c62018-01-04 18:02:24 -0800104 Buffer *buffer,
Jamie Madillbf5177d2018-08-21 12:58:20 -0400105 BufferBinding target)
James Darpiniane8a93c62018-01-04 18:02:24 -0800106{
Jamie Madillbf5177d2018-08-21 12:58:20 -0400107 if (target == BufferBinding::TransformFeedback)
108 {
109 UpdateTFBufferBinding(context, binding, false, buffer);
110 }
111 else
112 {
113 UpdateNonTFBufferBinding(context, binding, buffer);
114 }
115}
116
117void UpdateIndexedBufferBinding(const Context *context,
118 OffsetBindingPointer<Buffer> *binding,
119 Buffer *buffer,
120 BufferBinding target,
121 GLintptr offset,
122 GLsizeiptr size)
123{
124 if (target == BufferBinding::TransformFeedback)
125 {
126 UpdateTFBufferBinding(context, binding, true, buffer, offset, size);
127 }
128 else
129 {
130 UpdateNonTFBufferBinding(context, binding, buffer, offset, size);
131 }
James Darpiniane8a93c62018-01-04 18:02:24 -0800132}
133
Jamie Madillca8eda42018-10-18 18:41:56 -0400134// These template functions must be defined before they are instantiated in kBufferSetters.
135template <BufferBinding Target>
136void State::setGenericBufferBindingWithBit(const Context *context, Buffer *buffer)
137{
138 UpdateNonTFBufferBinding(context, &mBoundBuffers[Target], buffer);
139 mDirtyBits.set(kBufferBindingDirtyBits[Target]);
140}
141
142template <BufferBinding Target>
143void State::setGenericBufferBinding(const Context *context, Buffer *buffer)
144{
145 UpdateNonTFBufferBinding(context, &mBoundBuffers[Target], buffer);
146}
147
148template <>
149void State::setGenericBufferBinding<BufferBinding::TransformFeedback>(const Context *context,
150 Buffer *buffer)
151{
152 UpdateTFBufferBinding(context, &mBoundBuffers[BufferBinding::TransformFeedback], false, buffer);
153}
154
155template <>
156void State::setGenericBufferBinding<BufferBinding::ElementArray>(const Context *context,
157 Buffer *buffer)
158{
159 Buffer *oldBuffer = mVertexArray->mState.mElementArrayBuffer.get();
160 if (oldBuffer)
161 {
Jamie Madillcd0a0a32018-10-18 18:41:57 -0400162 oldBuffer->removeObserver(&mVertexArray->mState.mElementArrayBuffer);
Jamie Madillca8eda42018-10-18 18:41:56 -0400163 oldBuffer->onNonTFBindingChanged(-1);
164 oldBuffer->release(context);
165 }
166 mVertexArray->mState.mElementArrayBuffer.assign(buffer);
167 if (buffer)
168 {
Jamie Madillcd0a0a32018-10-18 18:41:57 -0400169 buffer->addObserver(&mVertexArray->mState.mElementArrayBuffer);
Jamie Madillca8eda42018-10-18 18:41:56 -0400170 buffer->onNonTFBindingChanged(1);
171 buffer->addRef();
172 }
Jamie Madillca8eda42018-10-18 18:41:56 -0400173 mVertexArray->mDirtyBits.set(VertexArray::DIRTY_BIT_ELEMENT_ARRAY_BUFFER);
Jamie Madillc1fd7372018-10-26 22:48:39 -0400174 mVertexArray->mIndexRangeCache.invalidate();
Jamie Madillca8eda42018-10-18 18:41:56 -0400175 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
176}
177
178const angle::PackedEnumMap<BufferBinding, State::BufferBindingSetter> State::kBufferSetters = {{
179 GetBufferBindingSetter<BufferBinding::Array>(),
180 GetBufferBindingSetter<BufferBinding::AtomicCounter>(),
181 GetBufferBindingSetter<BufferBinding::CopyRead>(),
182 GetBufferBindingSetter<BufferBinding::CopyWrite>(),
183 GetBufferBindingSetter<BufferBinding::DispatchIndirect>(),
184 GetBufferBindingSetter<BufferBinding::DrawIndirect>(),
185 GetBufferBindingSetter<BufferBinding::ElementArray>(),
186 GetBufferBindingSetter<BufferBinding::PixelPack>(),
187 GetBufferBindingSetter<BufferBinding::PixelUnpack>(),
188 GetBufferBindingSetter<BufferBinding::ShaderStorage>(),
189 GetBufferBindingSetter<BufferBinding::TransformFeedback>(),
190 GetBufferBindingSetter<BufferBinding::Uniform>(),
191}};
192
Geoff Lang4fb8a8b2018-06-01 16:47:57 -0400193State::State(bool debug,
194 bool bindGeneratesResource,
195 bool clientArraysEnabled,
196 bool robustResourceInit,
197 bool programBinaryCacheEnabled)
Jamie Madille79b1e12015-11-04 16:36:37 -0500198 : mMaxDrawBuffers(0),
199 mMaxCombinedTextureImageUnits(0),
200 mDepthClearValue(0),
201 mStencilClearValue(0),
202 mScissorTest(false),
203 mSampleCoverage(false),
204 mSampleCoverageValue(0),
205 mSampleCoverageInvert(false),
Jiawei Shaodb342272017-09-27 10:21:45 +0800206 mSampleMask(false),
207 mMaxSampleMaskWords(0),
Jamie Madille79b1e12015-11-04 16:36:37 -0500208 mStencilRef(0),
209 mStencilBackRef(0),
210 mLineWidth(0),
211 mGenerateMipmapHint(GL_NONE),
212 mFragmentShaderDerivativeHint(GL_NONE),
Geoff Lang4fb8a8b2018-06-01 16:47:57 -0400213 mBindGeneratesResource(bindGeneratesResource),
214 mClientArraysEnabled(clientArraysEnabled),
Jamie Madille79b1e12015-11-04 16:36:37 -0500215 mNearZ(0),
216 mFarZ(0),
217 mReadFramebuffer(nullptr),
218 mDrawFramebuffer(nullptr),
219 mProgram(nullptr),
220 mVertexArray(nullptr),
221 mActiveSampler(0),
Jamie Madill4787d702018-08-08 15:49:26 -0400222 mActiveTexturesCache{},
Sami Väisänen74c23472016-05-09 17:30:30 +0300223 mPrimitiveRestart(false),
Geoff Lang4fb8a8b2018-06-01 16:47:57 -0400224 mDebug(debug),
Sami Väisänen74c23472016-05-09 17:30:30 +0300225 mMultiSampling(false),
Geoff Lang1d2c41d2016-10-19 16:14:46 -0700226 mSampleAlphaToOne(false),
Jamie Madille08a1d32017-03-07 17:24:06 -0500227 mFramebufferSRGB(true),
Geoff Lang4fb8a8b2018-06-01 16:47:57 -0400228 mRobustResourceInit(robustResourceInit),
jchen1082af6202018-06-22 10:59:52 +0800229 mProgramBinaryCacheEnabled(programBinaryCacheEnabled),
230 mMaxShaderCompilerThreads(std::numeric_limits<GLuint>::max())
Jamie Madillb980c562018-11-27 11:34:27 -0500231{}
Geoff Lang76b10c92014-09-05 16:28:14 -0400232
Jamie Madillb980c562018-11-27 11:34:27 -0500233State::~State() {}
Geoff Lang76b10c92014-09-05 16:28:14 -0400234
Jamie Madill6c43a012018-08-08 15:49:27 -0400235void State::initialize(Context *context)
Geoff Lang76b10c92014-09-05 16:28:14 -0400236{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700237 const Caps &caps = context->getCaps();
238 const Extensions &extensions = context->getExtensions();
Geoff Lang4751aab2017-10-30 15:14:52 -0400239 const Extensions &nativeExtensions = context->getImplementation()->getNativeExtensions();
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700240 const Version &clientVersion = context->getClientVersion();
Jamie Madill4928b7c2017-06-20 12:57:39 -0400241
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700242 mMaxDrawBuffers = caps.maxDrawBuffers;
Shannon Woods2df6a602014-09-26 16:12:07 -0400243 mMaxCombinedTextureImageUnits = caps.maxCombinedTextureImageUnits;
Shannon Woods53a94a82014-06-24 15:20:36 -0400244
Jamie Madillf75ab352015-03-16 10:46:52 -0400245 setColorClearValue(0.0f, 0.0f, 0.0f, 0.0f);
Shannon Woods53a94a82014-06-24 15:20:36 -0400246
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700247 mDepthClearValue = 1.0f;
Shannon Woods53a94a82014-06-24 15:20:36 -0400248 mStencilClearValue = 0;
249
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700250 mScissorTest = false;
251 mScissor.x = 0;
252 mScissor.y = 0;
253 mScissor.width = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400254 mScissor.height = 0;
255
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700256 mBlendColor.red = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400257 mBlendColor.green = 0;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700258 mBlendColor.blue = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400259 mBlendColor.alpha = 0;
260
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700261 mStencilRef = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400262 mStencilBackRef = 0;
263
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700264 mSampleCoverage = false;
265 mSampleCoverageValue = 1.0f;
Shannon Woods53a94a82014-06-24 15:20:36 -0400266 mSampleCoverageInvert = false;
Jiawei Shaodb342272017-09-27 10:21:45 +0800267
268 mMaxSampleMaskWords = caps.maxSampleMaskWords;
269 mSampleMask = false;
270 mSampleMaskValues.fill(~GLbitfield(0));
271
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700272 mGenerateMipmapHint = GL_DONT_CARE;
Shannon Woods53a94a82014-06-24 15:20:36 -0400273 mFragmentShaderDerivativeHint = GL_DONT_CARE;
274
275 mLineWidth = 1.0f;
276
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700277 mViewport.x = 0;
278 mViewport.y = 0;
279 mViewport.width = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400280 mViewport.height = 0;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700281 mNearZ = 0.0f;
282 mFarZ = 1.0f;
Shannon Woods53a94a82014-06-24 15:20:36 -0400283
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700284 mBlend.colorMaskRed = true;
Shannon Woods53a94a82014-06-24 15:20:36 -0400285 mBlend.colorMaskGreen = true;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700286 mBlend.colorMaskBlue = true;
Shannon Woods53a94a82014-06-24 15:20:36 -0400287 mBlend.colorMaskAlpha = true;
288
Geoff Lang76b10c92014-09-05 16:28:14 -0400289 mActiveSampler = 0;
290
Shannon Woods23e05002014-09-22 19:07:27 -0400291 mVertexAttribCurrentValues.resize(caps.maxVertexAttributes);
Shannon Woods53a94a82014-06-24 15:20:36 -0400292
Brandon Jonesc405ae72017-12-06 14:15:03 -0800293 // Set all indexes in state attributes type mask to float (default)
294 for (int i = 0; i < MAX_VERTEX_ATTRIBS; i++)
295 {
296 mCurrentValuesTypeMask.setIndex(GL_FLOAT, i);
297 }
298
Geoff Lang4dc3af02016-11-18 14:09:27 -0500299 mUniformBuffers.resize(caps.maxUniformBufferBindings);
Shannon Woodsf3acaf92014-09-23 18:07:11 -0400300
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800301 mSamplerTextures[TextureType::_2D].resize(caps.maxCombinedTextureImageUnits);
302 mSamplerTextures[TextureType::CubeMap].resize(caps.maxCombinedTextureImageUnits);
Geoff Langeb66a6e2016-10-31 13:06:12 -0400303 if (clientVersion >= Version(3, 0))
Shannon Woods53a94a82014-06-24 15:20:36 -0400304 {
Geoff Lang76b10c92014-09-05 16:28:14 -0400305 // TODO: These could also be enabled via extension
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800306 mSamplerTextures[TextureType::_2DArray].resize(caps.maxCombinedTextureImageUnits);
307 mSamplerTextures[TextureType::_3D].resize(caps.maxCombinedTextureImageUnits);
Shannon Woods53a94a82014-06-24 15:20:36 -0400308 }
Yizhou Jiang7818a852018-09-06 15:02:04 +0800309 if (clientVersion >= Version(3, 1) || nativeExtensions.textureMultisample)
310 {
311 mSamplerTextures[TextureType::_2DMultisample].resize(caps.maxCombinedTextureImageUnits);
312 }
Geoff Lang3b573612016-10-31 14:08:10 -0400313 if (clientVersion >= Version(3, 1))
314 {
Olli Etuahod310a432018-08-24 15:40:23 +0300315 mSamplerTextures[TextureType::_2DMultisampleArray].resize(
316 caps.maxCombinedTextureImageUnits);
Jiajia Qin6eafb042016-12-27 17:04:07 +0800317
318 mAtomicCounterBuffers.resize(caps.maxAtomicCounterBufferBindings);
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800319 mShaderStorageBuffers.resize(caps.maxShaderStorageBufferBindings);
Xinghua Cao65ec0b22017-03-28 16:10:52 +0800320 mImageUnits.resize(caps.maxImageUnits);
Geoff Lang3b573612016-10-31 14:08:10 -0400321 }
Geoff Lang4751aab2017-10-30 15:14:52 -0400322 if (nativeExtensions.textureRectangle)
Corentin Wallez13c0dd42017-07-04 18:27:01 -0400323 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800324 mSamplerTextures[TextureType::Rectangle].resize(caps.maxCombinedTextureImageUnits);
Corentin Wallez13c0dd42017-07-04 18:27:01 -0400325 }
Geoff Lang4751aab2017-10-30 15:14:52 -0400326 if (nativeExtensions.eglImageExternal || nativeExtensions.eglStreamConsumerExternal)
Ian Ewellbda75592016-04-18 17:25:54 -0400327 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800328 mSamplerTextures[TextureType::External].resize(caps.maxCombinedTextureImageUnits);
Ian Ewellbda75592016-04-18 17:25:54 -0400329 }
Jamie Madill81c2e252017-09-09 23:32:46 -0400330 mCompleteTextureBindings.reserve(caps.maxCombinedTextureImageUnits);
331 for (uint32_t textureIndex = 0; textureIndex < caps.maxCombinedTextureImageUnits;
332 ++textureIndex)
333 {
Jamie Madill6c43a012018-08-08 15:49:27 -0400334 mCompleteTextureBindings.emplace_back(context, textureIndex);
Jamie Madill81c2e252017-09-09 23:32:46 -0400335 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400336
Geoff Lang76b10c92014-09-05 16:28:14 -0400337 mSamplers.resize(caps.maxCombinedTextureImageUnits);
Shannon Woods53a94a82014-06-24 15:20:36 -0400338
Corentin Wallezad3ae902018-03-09 13:40:42 -0500339 for (QueryType type : angle::AllEnums<QueryType>())
340 {
341 mActiveQueries[type].set(context, nullptr);
342 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400343
Ian Ewell3ffd78b2016-01-22 16:09:42 -0500344 mProgram = nullptr;
Shannon Woods53a94a82014-06-24 15:20:36 -0400345
Ian Ewell3ffd78b2016-01-22 16:09:42 -0500346 mReadFramebuffer = nullptr;
347 mDrawFramebuffer = nullptr;
Jamie Madillb4b53c52015-02-03 15:22:48 -0500348
349 mPrimitiveRestart = false;
Geoff Lang70d0f492015-12-10 17:45:46 -0500350
Geoff Lang70d0f492015-12-10 17:45:46 -0500351 mDebug.setMaxLoggedMessages(extensions.maxDebugLoggedMessages);
Sami Väisänen74c23472016-05-09 17:30:30 +0300352
Geoff Lang488130e2017-09-27 13:53:11 -0400353 mMultiSampling = true;
354 mSampleAlphaToOne = false;
Sami Väisänena797e062016-05-12 15:23:40 +0300355
356 mCoverageModulation = GL_NONE;
Sami Väisänene45e53b2016-05-25 10:36:04 +0300357
358 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixProj);
359 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixMV);
360 mPathStencilFunc = GL_ALWAYS;
361 mPathStencilRef = 0;
362 mPathStencilMask = std::numeric_limits<GLuint>::max();
Jamie Madille08a1d32017-03-07 17:24:06 -0500363
Lingfeng Yangdbb9c532018-02-25 19:58:24 -0800364 // GLES1 emulation: Initialize state for GLES1 if version
365 // applies
366 if (clientVersion < Version(2, 0))
367 {
Lingfeng Yange547aac2018-04-05 09:39:20 -0700368 mGLES1State.initialize(context, this);
Lingfeng Yangdbb9c532018-02-25 19:58:24 -0800369 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400370}
371
Jamie Madill6c1f6712017-02-14 19:08:04 -0500372void State::reset(const Context *context)
Shannon Woods53a94a82014-06-24 15:20:36 -0400373{
Jamie Madill8693bdb2017-09-02 15:32:14 -0400374 for (auto &bindingVec : mSamplerTextures)
Shannon Woods53a94a82014-06-24 15:20:36 -0400375 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800376 for (size_t textureIdx = 0; textureIdx < bindingVec.size(); textureIdx++)
Shannon Woods53a94a82014-06-24 15:20:36 -0400377 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800378 bindingVec[textureIdx].set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400379 }
380 }
Geoff Lang76b10c92014-09-05 16:28:14 -0400381 for (size_t samplerIdx = 0; samplerIdx < mSamplers.size(); samplerIdx++)
382 {
Jamie Madill4928b7c2017-06-20 12:57:39 -0400383 mSamplers[samplerIdx].set(context, nullptr);
Geoff Lang76b10c92014-09-05 16:28:14 -0400384 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400385
Xinghua Cao65ec0b22017-03-28 16:10:52 +0800386 for (auto &imageUnit : mImageUnits)
387 {
388 imageUnit.texture.set(context, nullptr);
389 imageUnit.level = 0;
390 imageUnit.layered = false;
391 imageUnit.layer = 0;
392 imageUnit.access = GL_READ_ONLY;
393 imageUnit.format = GL_R32UI;
394 }
395
Jamie Madill4928b7c2017-06-20 12:57:39 -0400396 mRenderbuffer.set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400397
Corentin Wallez336129f2017-10-17 15:55:40 -0400398 for (auto type : angle::AllEnums<BufferBinding>())
399 {
Jamie Madillbf5177d2018-08-21 12:58:20 -0400400 UpdateBufferBinding(context, &mBoundBuffers[type], nullptr, type);
Corentin Wallez336129f2017-10-17 15:55:40 -0400401 }
402
Geoff Lang7dd2e102014-11-10 15:19:26 -0500403 if (mProgram)
404 {
Jamie Madill6c1f6712017-02-14 19:08:04 -0500405 mProgram->release(context);
Geoff Lang7dd2e102014-11-10 15:19:26 -0500406 }
Yunchao Hed7297bf2017-04-19 15:27:10 +0800407 mProgram = nullptr;
Geoff Lang7dd2e102014-11-10 15:19:26 -0500408
Yunchao Hea336b902017-08-02 16:05:21 +0800409 mProgramPipeline.set(context, nullptr);
410
James Darpiniane8a93c62018-01-04 18:02:24 -0800411 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -0400412 mTransformFeedback->onBindingChanged(context, false);
Jamie Madill4928b7c2017-06-20 12:57:39 -0400413 mTransformFeedback.set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400414
Corentin Wallezad3ae902018-03-09 13:40:42 -0500415 for (QueryType type : angle::AllEnums<QueryType>())
Shannon Woods53a94a82014-06-24 15:20:36 -0400416 {
Corentin Wallezad3ae902018-03-09 13:40:42 -0500417 mActiveQueries[type].set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400418 }
419
Corentin Wallez336129f2017-10-17 15:55:40 -0400420 for (auto &buf : mUniformBuffers)
Shannon Woods53a94a82014-06-24 15:20:36 -0400421 {
Jamie Madillbf5177d2018-08-21 12:58:20 -0400422 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::Uniform, 0, 0);
Shannon Woods53a94a82014-06-24 15:20:36 -0400423 }
424
Jiajia Qin6eafb042016-12-27 17:04:07 +0800425 for (auto &buf : mAtomicCounterBuffers)
426 {
Jamie Madillbf5177d2018-08-21 12:58:20 -0400427 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::AtomicCounter, 0, 0);
Jiajia Qin6eafb042016-12-27 17:04:07 +0800428 }
429
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800430 for (auto &buf : mShaderStorageBuffers)
431 {
Jamie Madillbf5177d2018-08-21 12:58:20 -0400432 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::ShaderStorage, 0, 0);
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800433 }
434
Sami Väisänene45e53b2016-05-25 10:36:04 +0300435 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixProj);
436 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixMV);
437 mPathStencilFunc = GL_ALWAYS;
438 mPathStencilRef = 0;
439 mPathStencilMask = std::numeric_limits<GLuint>::max();
440
Jamie Madill1b94d432015-08-07 13:23:23 -0400441 setAllDirtyBits();
Shannon Woods53a94a82014-06-24 15:20:36 -0400442}
443
Jamie Madille3bb6b72018-10-03 17:51:15 -0400444ANGLE_INLINE void State::unsetActiveTextures(ActiveTextureMask textureMask)
445{
446 // Unset any relevant bound textures.
447 for (size_t textureIndex : mProgram->getActiveSamplersMask())
448 {
449 mActiveTexturesCache[textureIndex] = nullptr;
450 mCompleteTextureBindings[textureIndex].reset();
451 }
452}
453
Jamie Madille3e680c2018-12-03 17:49:08 -0500454ANGLE_INLINE void State::updateActiveTextureState(const Context *context,
455 size_t textureIndex,
456 const Sampler *sampler,
457 Texture *texture)
458{
459 if (!texture->isSamplerComplete(context, sampler))
460 {
461 mActiveTexturesCache[textureIndex] = nullptr;
462 }
463 else
464 {
465 mActiveTexturesCache[textureIndex] = texture;
466
467 if (texture->hasAnyDirtyBit())
468 {
469 setTextureDirty(textureIndex);
470 }
471
Jamie Madill132d15c2018-11-30 15:25:38 -0500472 if (mRobustResourceInit && texture->initState() == InitState::MayNeedInit)
Jamie Madille3e680c2018-12-03 17:49:08 -0500473 {
Jamie Madill132d15c2018-11-30 15:25:38 -0500474 mDirtyObjects.set(DIRTY_OBJECT_TEXTURES_INIT);
Jamie Madille3e680c2018-12-03 17:49:08 -0500475 }
476 }
477
478 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
479}
480
481ANGLE_INLINE void State::updateActiveTexture(const Context *context,
482 size_t textureIndex,
483 Texture *texture)
Jamie Madille3bb6b72018-10-03 17:51:15 -0400484{
485 const Sampler *sampler = mSamplers[textureIndex].get();
486
Jamie Madille3e680c2018-12-03 17:49:08 -0500487 mCompleteTextureBindings[textureIndex].bind(texture);
488
Jamie Madille3bb6b72018-10-03 17:51:15 -0400489 if (!texture)
490 {
491 mActiveTexturesCache[textureIndex] = nullptr;
Jamie Madille3e680c2018-12-03 17:49:08 -0500492 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
493 return;
Jamie Madille3bb6b72018-10-03 17:51:15 -0400494 }
495
Jamie Madille3e680c2018-12-03 17:49:08 -0500496 updateActiveTextureState(context, textureIndex, sampler, texture);
Jamie Madille3bb6b72018-10-03 17:51:15 -0400497}
498
Shannon Woods53a94a82014-06-24 15:20:36 -0400499const RasterizerState &State::getRasterizerState() const
500{
501 return mRasterizer;
502}
503
504const BlendState &State::getBlendState() const
505{
506 return mBlend;
507}
508
509const DepthStencilState &State::getDepthStencilState() const
510{
511 return mDepthStencil;
512}
513
Jamie Madillf75ab352015-03-16 10:46:52 -0400514void State::setColorClearValue(float red, float green, float blue, float alpha)
Shannon Woods53a94a82014-06-24 15:20:36 -0400515{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700516 mColorClearValue.red = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400517 mColorClearValue.green = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700518 mColorClearValue.blue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400519 mColorClearValue.alpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400520 mDirtyBits.set(DIRTY_BIT_CLEAR_COLOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400521}
522
Jamie Madillf75ab352015-03-16 10:46:52 -0400523void State::setDepthClearValue(float depth)
Shannon Woods53a94a82014-06-24 15:20:36 -0400524{
525 mDepthClearValue = depth;
Jamie Madill1b94d432015-08-07 13:23:23 -0400526 mDirtyBits.set(DIRTY_BIT_CLEAR_DEPTH);
Shannon Woods53a94a82014-06-24 15:20:36 -0400527}
528
Jamie Madillf75ab352015-03-16 10:46:52 -0400529void State::setStencilClearValue(int stencil)
Shannon Woods53a94a82014-06-24 15:20:36 -0400530{
531 mStencilClearValue = stencil;
Jamie Madill1b94d432015-08-07 13:23:23 -0400532 mDirtyBits.set(DIRTY_BIT_CLEAR_STENCIL);
Shannon Woods53a94a82014-06-24 15:20:36 -0400533}
534
Shannon Woods53a94a82014-06-24 15:20:36 -0400535void State::setColorMask(bool red, bool green, bool blue, bool alpha)
536{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700537 mBlend.colorMaskRed = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400538 mBlend.colorMaskGreen = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700539 mBlend.colorMaskBlue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400540 mBlend.colorMaskAlpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400541 mDirtyBits.set(DIRTY_BIT_COLOR_MASK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400542}
543
544void State::setDepthMask(bool mask)
545{
546 mDepthStencil.depthMask = mask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400547 mDirtyBits.set(DIRTY_BIT_DEPTH_MASK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400548}
549
Shannon Woods53a94a82014-06-24 15:20:36 -0400550void State::setRasterizerDiscard(bool enabled)
551{
552 mRasterizer.rasterizerDiscard = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400553 mDirtyBits.set(DIRTY_BIT_RASTERIZER_DISCARD_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400554}
555
Shannon Woods53a94a82014-06-24 15:20:36 -0400556void State::setCullFace(bool enabled)
557{
558 mRasterizer.cullFace = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400559 mDirtyBits.set(DIRTY_BIT_CULL_FACE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400560}
561
Corentin Wallez2e568cf2017-09-18 17:05:22 -0400562void State::setCullMode(CullFaceMode mode)
Shannon Woods53a94a82014-06-24 15:20:36 -0400563{
564 mRasterizer.cullMode = mode;
Jamie Madill1b94d432015-08-07 13:23:23 -0400565 mDirtyBits.set(DIRTY_BIT_CULL_FACE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400566}
567
568void State::setFrontFace(GLenum front)
569{
570 mRasterizer.frontFace = front;
Jamie Madill1b94d432015-08-07 13:23:23 -0400571 mDirtyBits.set(DIRTY_BIT_FRONT_FACE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400572}
573
Shannon Woods53a94a82014-06-24 15:20:36 -0400574void State::setDepthTest(bool enabled)
575{
576 mDepthStencil.depthTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400577 mDirtyBits.set(DIRTY_BIT_DEPTH_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400578}
579
580void State::setDepthFunc(GLenum depthFunc)
581{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700582 mDepthStencil.depthFunc = depthFunc;
583 mDirtyBits.set(DIRTY_BIT_DEPTH_FUNC);
Shannon Woods53a94a82014-06-24 15:20:36 -0400584}
585
586void State::setDepthRange(float zNear, float zFar)
587{
588 mNearZ = zNear;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700589 mFarZ = zFar;
Jamie Madill1b94d432015-08-07 13:23:23 -0400590 mDirtyBits.set(DIRTY_BIT_DEPTH_RANGE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400591}
592
Shannon Woods53a94a82014-06-24 15:20:36 -0400593void State::setBlend(bool enabled)
594{
595 mBlend.blend = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400596 mDirtyBits.set(DIRTY_BIT_BLEND_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400597}
598
599void State::setBlendFactors(GLenum sourceRGB, GLenum destRGB, GLenum sourceAlpha, GLenum destAlpha)
600{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700601 mBlend.sourceBlendRGB = sourceRGB;
602 mBlend.destBlendRGB = destRGB;
Shannon Woods53a94a82014-06-24 15:20:36 -0400603 mBlend.sourceBlendAlpha = sourceAlpha;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700604 mBlend.destBlendAlpha = destAlpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400605 mDirtyBits.set(DIRTY_BIT_BLEND_FUNCS);
Shannon Woods53a94a82014-06-24 15:20:36 -0400606}
607
608void State::setBlendColor(float red, float green, float blue, float alpha)
609{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700610 mBlendColor.red = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400611 mBlendColor.green = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700612 mBlendColor.blue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400613 mBlendColor.alpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400614 mDirtyBits.set(DIRTY_BIT_BLEND_COLOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400615}
616
617void State::setBlendEquation(GLenum rgbEquation, GLenum alphaEquation)
618{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700619 mBlend.blendEquationRGB = rgbEquation;
Shannon Woods53a94a82014-06-24 15:20:36 -0400620 mBlend.blendEquationAlpha = alphaEquation;
Jamie Madill1b94d432015-08-07 13:23:23 -0400621 mDirtyBits.set(DIRTY_BIT_BLEND_EQUATIONS);
Shannon Woods53a94a82014-06-24 15:20:36 -0400622}
623
Shannon Woods53a94a82014-06-24 15:20:36 -0400624void State::setStencilTest(bool enabled)
625{
626 mDepthStencil.stencilTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400627 mDirtyBits.set(DIRTY_BIT_STENCIL_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400628}
629
630void State::setStencilParams(GLenum stencilFunc, GLint stencilRef, GLuint stencilMask)
631{
632 mDepthStencil.stencilFunc = stencilFunc;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700633 mStencilRef = (stencilRef > 0) ? stencilRef : 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400634 mDepthStencil.stencilMask = stencilMask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400635 mDirtyBits.set(DIRTY_BIT_STENCIL_FUNCS_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400636}
637
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700638void State::setStencilBackParams(GLenum stencilBackFunc,
639 GLint stencilBackRef,
640 GLuint stencilBackMask)
Shannon Woods53a94a82014-06-24 15:20:36 -0400641{
642 mDepthStencil.stencilBackFunc = stencilBackFunc;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700643 mStencilBackRef = (stencilBackRef > 0) ? stencilBackRef : 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400644 mDepthStencil.stencilBackMask = stencilBackMask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400645 mDirtyBits.set(DIRTY_BIT_STENCIL_FUNCS_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400646}
647
648void State::setStencilWritemask(GLuint stencilWritemask)
649{
650 mDepthStencil.stencilWritemask = stencilWritemask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400651 mDirtyBits.set(DIRTY_BIT_STENCIL_WRITEMASK_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400652}
653
654void State::setStencilBackWritemask(GLuint stencilBackWritemask)
655{
656 mDepthStencil.stencilBackWritemask = stencilBackWritemask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400657 mDirtyBits.set(DIRTY_BIT_STENCIL_WRITEMASK_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400658}
659
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700660void State::setStencilOperations(GLenum stencilFail,
661 GLenum stencilPassDepthFail,
662 GLenum stencilPassDepthPass)
Shannon Woods53a94a82014-06-24 15:20:36 -0400663{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700664 mDepthStencil.stencilFail = stencilFail;
Shannon Woods53a94a82014-06-24 15:20:36 -0400665 mDepthStencil.stencilPassDepthFail = stencilPassDepthFail;
666 mDepthStencil.stencilPassDepthPass = stencilPassDepthPass;
Jamie Madill1b94d432015-08-07 13:23:23 -0400667 mDirtyBits.set(DIRTY_BIT_STENCIL_OPS_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400668}
669
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700670void State::setStencilBackOperations(GLenum stencilBackFail,
671 GLenum stencilBackPassDepthFail,
672 GLenum stencilBackPassDepthPass)
Shannon Woods53a94a82014-06-24 15:20:36 -0400673{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700674 mDepthStencil.stencilBackFail = stencilBackFail;
Shannon Woods53a94a82014-06-24 15:20:36 -0400675 mDepthStencil.stencilBackPassDepthFail = stencilBackPassDepthFail;
676 mDepthStencil.stencilBackPassDepthPass = stencilBackPassDepthPass;
Jamie Madill1b94d432015-08-07 13:23:23 -0400677 mDirtyBits.set(DIRTY_BIT_STENCIL_OPS_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400678}
679
Shannon Woods53a94a82014-06-24 15:20:36 -0400680void State::setPolygonOffsetFill(bool enabled)
681{
Jamie Madill1b94d432015-08-07 13:23:23 -0400682 mRasterizer.polygonOffsetFill = enabled;
683 mDirtyBits.set(DIRTY_BIT_POLYGON_OFFSET_FILL_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400684}
685
686void State::setPolygonOffsetParams(GLfloat factor, GLfloat units)
687{
688 // An application can pass NaN values here, so handle this gracefully
689 mRasterizer.polygonOffsetFactor = factor != factor ? 0.0f : factor;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700690 mRasterizer.polygonOffsetUnits = units != units ? 0.0f : units;
Jamie Madill1b94d432015-08-07 13:23:23 -0400691 mDirtyBits.set(DIRTY_BIT_POLYGON_OFFSET);
Shannon Woods53a94a82014-06-24 15:20:36 -0400692}
693
Shannon Woods53a94a82014-06-24 15:20:36 -0400694void State::setSampleAlphaToCoverage(bool enabled)
695{
696 mBlend.sampleAlphaToCoverage = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400697 mDirtyBits.set(DIRTY_BIT_SAMPLE_ALPHA_TO_COVERAGE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400698}
699
Shannon Woods53a94a82014-06-24 15:20:36 -0400700void State::setSampleCoverage(bool enabled)
701{
702 mSampleCoverage = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400703 mDirtyBits.set(DIRTY_BIT_SAMPLE_COVERAGE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400704}
705
706void State::setSampleCoverageParams(GLclampf value, bool invert)
707{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700708 mSampleCoverageValue = value;
Shannon Woods53a94a82014-06-24 15:20:36 -0400709 mSampleCoverageInvert = invert;
Jamie Madill1b94d432015-08-07 13:23:23 -0400710 mDirtyBits.set(DIRTY_BIT_SAMPLE_COVERAGE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400711}
712
Jiawei Shaodb342272017-09-27 10:21:45 +0800713void State::setSampleMaskEnabled(bool enabled)
714{
715 mSampleMask = enabled;
716 mDirtyBits.set(DIRTY_BIT_SAMPLE_MASK_ENABLED);
717}
718
719void State::setSampleMaskParams(GLuint maskNumber, GLbitfield mask)
720{
721 ASSERT(maskNumber < mMaxSampleMaskWords);
722 mSampleMaskValues[maskNumber] = mask;
Jamie Madillc67323a2017-11-02 23:11:41 -0400723 // TODO(jmadill): Use a child dirty bit if we ever use more than two words.
724 mDirtyBits.set(DIRTY_BIT_SAMPLE_MASK);
Jiawei Shaodb342272017-09-27 10:21:45 +0800725}
726
Sami Väisänen74c23472016-05-09 17:30:30 +0300727void State::setSampleAlphaToOne(bool enabled)
728{
729 mSampleAlphaToOne = enabled;
730 mDirtyBits.set(DIRTY_BIT_SAMPLE_ALPHA_TO_ONE);
731}
732
Sami Väisänen74c23472016-05-09 17:30:30 +0300733void State::setMultisampling(bool enabled)
734{
735 mMultiSampling = enabled;
736 mDirtyBits.set(DIRTY_BIT_MULTISAMPLING);
737}
738
Shannon Woods53a94a82014-06-24 15:20:36 -0400739void State::setScissorTest(bool enabled)
740{
741 mScissorTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400742 mDirtyBits.set(DIRTY_BIT_SCISSOR_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400743}
744
745void State::setScissorParams(GLint x, GLint y, GLsizei width, GLsizei height)
746{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700747 mScissor.x = x;
748 mScissor.y = y;
749 mScissor.width = width;
Shannon Woods53a94a82014-06-24 15:20:36 -0400750 mScissor.height = height;
Jamie Madill1b94d432015-08-07 13:23:23 -0400751 mDirtyBits.set(DIRTY_BIT_SCISSOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400752}
753
Shannon Woods53a94a82014-06-24 15:20:36 -0400754void State::setDither(bool enabled)
755{
756 mBlend.dither = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400757 mDirtyBits.set(DIRTY_BIT_DITHER_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400758}
759
Jamie Madillb4b53c52015-02-03 15:22:48 -0500760void State::setPrimitiveRestart(bool enabled)
761{
762 mPrimitiveRestart = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400763 mDirtyBits.set(DIRTY_BIT_PRIMITIVE_RESTART_ENABLED);
Jamie Madillb4b53c52015-02-03 15:22:48 -0500764}
765
Shannon Woods53a94a82014-06-24 15:20:36 -0400766void State::setEnableFeature(GLenum feature, bool enabled)
767{
768 switch (feature)
769 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700770 case GL_MULTISAMPLE_EXT:
771 setMultisampling(enabled);
772 break;
773 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
774 setSampleAlphaToOne(enabled);
775 break;
776 case GL_CULL_FACE:
777 setCullFace(enabled);
778 break;
779 case GL_POLYGON_OFFSET_FILL:
780 setPolygonOffsetFill(enabled);
781 break;
782 case GL_SAMPLE_ALPHA_TO_COVERAGE:
783 setSampleAlphaToCoverage(enabled);
784 break;
785 case GL_SAMPLE_COVERAGE:
786 setSampleCoverage(enabled);
787 break;
788 case GL_SCISSOR_TEST:
789 setScissorTest(enabled);
790 break;
791 case GL_STENCIL_TEST:
792 setStencilTest(enabled);
793 break;
794 case GL_DEPTH_TEST:
795 setDepthTest(enabled);
796 break;
797 case GL_BLEND:
798 setBlend(enabled);
799 break;
800 case GL_DITHER:
801 setDither(enabled);
802 break;
803 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
804 setPrimitiveRestart(enabled);
805 break;
806 case GL_RASTERIZER_DISCARD:
807 setRasterizerDiscard(enabled);
808 break;
809 case GL_SAMPLE_MASK:
810 setSampleMaskEnabled(enabled);
811 break;
812 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
813 mDebug.setOutputSynchronous(enabled);
814 break;
815 case GL_DEBUG_OUTPUT:
816 mDebug.setOutputEnabled(enabled);
817 break;
818 case GL_FRAMEBUFFER_SRGB_EXT:
819 setFramebufferSRGB(enabled);
820 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -0700821
822 // GLES1 emulation
823 case GL_ALPHA_TEST:
824 mGLES1State.mAlphaTestEnabled = enabled;
825 break;
Lingfeng Yang23dc90b2018-04-23 09:01:49 -0700826 case GL_TEXTURE_2D:
827 mGLES1State.mTexUnitEnables[mActiveSampler].set(TextureType::_2D, enabled);
828 break;
829 case GL_TEXTURE_CUBE_MAP:
830 mGLES1State.mTexUnitEnables[mActiveSampler].set(TextureType::CubeMap, enabled);
831 break;
Lingfeng Yangd0febe72018-05-17 22:36:52 -0700832 case GL_LIGHTING:
833 mGLES1State.mLightingEnabled = enabled;
834 break;
835 case GL_LIGHT0:
836 case GL_LIGHT1:
837 case GL_LIGHT2:
838 case GL_LIGHT3:
839 case GL_LIGHT4:
840 case GL_LIGHT5:
841 case GL_LIGHT6:
842 case GL_LIGHT7:
843 mGLES1State.mLights[feature - GL_LIGHT0].enabled = enabled;
844 break;
845 case GL_NORMALIZE:
846 mGLES1State.mNormalizeEnabled = enabled;
847 break;
848 case GL_RESCALE_NORMAL:
849 mGLES1State.mRescaleNormalEnabled = enabled;
850 break;
851 case GL_COLOR_MATERIAL:
852 mGLES1State.mColorMaterialEnabled = enabled;
853 break;
Lingfeng Yang060088a2018-05-30 20:40:57 -0700854 case GL_CLIP_PLANE0:
855 case GL_CLIP_PLANE1:
856 case GL_CLIP_PLANE2:
857 case GL_CLIP_PLANE3:
858 case GL_CLIP_PLANE4:
859 case GL_CLIP_PLANE5:
860 mGLES1State.mClipPlanes[feature - GL_CLIP_PLANE0].enabled = enabled;
861 break;
Lingfeng Yang7ba3f422018-06-01 09:43:04 -0700862 case GL_FOG:
863 mGLES1State.mFogEnabled = enabled;
864 break;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -0700865 case GL_POINT_SMOOTH:
866 mGLES1State.mPointSmoothEnabled = enabled;
867 break;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -0700868 case GL_LINE_SMOOTH:
869 mGLES1State.mLineSmoothEnabled = enabled;
870 break;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -0700871 case GL_POINT_SPRITE_OES:
872 mGLES1State.mPointSpriteEnabled = enabled;
873 break;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -0700874 case GL_COLOR_LOGIC_OP:
875 mGLES1State.mLogicOpEnabled = enabled;
876 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700877 default:
878 UNREACHABLE();
Shannon Woods53a94a82014-06-24 15:20:36 -0400879 }
880}
881
Jamie Madilldfde6ab2016-06-09 07:07:18 -0700882bool State::getEnableFeature(GLenum feature) const
Shannon Woods53a94a82014-06-24 15:20:36 -0400883{
884 switch (feature)
885 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700886 case GL_MULTISAMPLE_EXT:
887 return isMultisamplingEnabled();
888 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
889 return isSampleAlphaToOneEnabled();
890 case GL_CULL_FACE:
891 return isCullFaceEnabled();
892 case GL_POLYGON_OFFSET_FILL:
893 return isPolygonOffsetFillEnabled();
894 case GL_SAMPLE_ALPHA_TO_COVERAGE:
895 return isSampleAlphaToCoverageEnabled();
896 case GL_SAMPLE_COVERAGE:
897 return isSampleCoverageEnabled();
898 case GL_SCISSOR_TEST:
899 return isScissorTestEnabled();
900 case GL_STENCIL_TEST:
901 return isStencilTestEnabled();
902 case GL_DEPTH_TEST:
903 return isDepthTestEnabled();
904 case GL_BLEND:
905 return isBlendEnabled();
906 case GL_DITHER:
907 return isDitherEnabled();
908 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
909 return isPrimitiveRestartEnabled();
910 case GL_RASTERIZER_DISCARD:
911 return isRasterizerDiscardEnabled();
912 case GL_SAMPLE_MASK:
913 return isSampleMaskEnabled();
914 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
915 return mDebug.isOutputSynchronous();
916 case GL_DEBUG_OUTPUT:
917 return mDebug.isOutputEnabled();
918 case GL_BIND_GENERATES_RESOURCE_CHROMIUM:
919 return isBindGeneratesResourceEnabled();
920 case GL_CLIENT_ARRAYS_ANGLE:
921 return areClientArraysEnabled();
922 case GL_FRAMEBUFFER_SRGB_EXT:
923 return getFramebufferSRGB();
924 case GL_ROBUST_RESOURCE_INITIALIZATION_ANGLE:
925 return mRobustResourceInit;
926 case GL_PROGRAM_CACHE_ENABLED_ANGLE:
927 return mProgramBinaryCacheEnabled;
Jamie Madillc43be722017-07-13 16:22:14 -0400928
Lingfeng Yang13b708f2018-03-21 12:14:10 -0700929 // GLES1 emulation
930 case GL_ALPHA_TEST:
931 return mGLES1State.mAlphaTestEnabled;
Lingfeng Yang01074432018-04-16 10:19:51 -0700932 case GL_VERTEX_ARRAY:
933 return mGLES1State.mVertexArrayEnabled;
934 case GL_NORMAL_ARRAY:
935 return mGLES1State.mNormalArrayEnabled;
936 case GL_COLOR_ARRAY:
937 return mGLES1State.mColorArrayEnabled;
938 case GL_POINT_SIZE_ARRAY_OES:
939 return mGLES1State.mPointSizeArrayEnabled;
940 case GL_TEXTURE_COORD_ARRAY:
941 return mGLES1State.mTexCoordArrayEnabled[mGLES1State.mClientActiveTexture];
Lingfeng Yang23dc90b2018-04-23 09:01:49 -0700942 case GL_TEXTURE_2D:
943 return mGLES1State.mTexUnitEnables[mActiveSampler].test(TextureType::_2D);
944 case GL_TEXTURE_CUBE_MAP:
945 return mGLES1State.mTexUnitEnables[mActiveSampler].test(TextureType::CubeMap);
Lingfeng Yangd0febe72018-05-17 22:36:52 -0700946 case GL_LIGHTING:
947 return mGLES1State.mLightingEnabled;
948 case GL_LIGHT0:
949 case GL_LIGHT1:
950 case GL_LIGHT2:
951 case GL_LIGHT3:
952 case GL_LIGHT4:
953 case GL_LIGHT5:
954 case GL_LIGHT6:
955 case GL_LIGHT7:
956 return mGLES1State.mLights[feature - GL_LIGHT0].enabled;
957 case GL_NORMALIZE:
958 return mGLES1State.mNormalizeEnabled;
959 case GL_RESCALE_NORMAL:
960 return mGLES1State.mRescaleNormalEnabled;
961 case GL_COLOR_MATERIAL:
962 return mGLES1State.mColorMaterialEnabled;
Lingfeng Yang060088a2018-05-30 20:40:57 -0700963 case GL_CLIP_PLANE0:
964 case GL_CLIP_PLANE1:
965 case GL_CLIP_PLANE2:
966 case GL_CLIP_PLANE3:
967 case GL_CLIP_PLANE4:
968 case GL_CLIP_PLANE5:
969 return mGLES1State.mClipPlanes[feature - GL_CLIP_PLANE0].enabled;
Lingfeng Yang7ba3f422018-06-01 09:43:04 -0700970 case GL_FOG:
971 return mGLES1State.mFogEnabled;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -0700972 case GL_POINT_SMOOTH:
973 return mGLES1State.mPointSmoothEnabled;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -0700974 case GL_LINE_SMOOTH:
975 return mGLES1State.mLineSmoothEnabled;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -0700976 case GL_POINT_SPRITE_OES:
977 return mGLES1State.mPointSpriteEnabled;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -0700978 case GL_COLOR_LOGIC_OP:
979 return mGLES1State.mLogicOpEnabled;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700980 default:
981 UNREACHABLE();
982 return false;
Shannon Woods53a94a82014-06-24 15:20:36 -0400983 }
984}
985
986void State::setLineWidth(GLfloat width)
987{
988 mLineWidth = width;
Jamie Madill1b94d432015-08-07 13:23:23 -0400989 mDirtyBits.set(DIRTY_BIT_LINE_WIDTH);
Shannon Woods53a94a82014-06-24 15:20:36 -0400990}
991
992void State::setGenerateMipmapHint(GLenum hint)
993{
994 mGenerateMipmapHint = hint;
Jamie Madill1b94d432015-08-07 13:23:23 -0400995 mDirtyBits.set(DIRTY_BIT_GENERATE_MIPMAP_HINT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400996}
997
998void State::setFragmentShaderDerivativeHint(GLenum hint)
999{
1000 mFragmentShaderDerivativeHint = hint;
Jamie Madill1b94d432015-08-07 13:23:23 -04001001 mDirtyBits.set(DIRTY_BIT_SHADER_DERIVATIVE_HINT);
Shannon Woods53a94a82014-06-24 15:20:36 -04001002 // TODO: Propagate the hint to shader translator so we can write
1003 // ddx, ddx_coarse, or ddx_fine depending on the hint.
1004 // Ignore for now. It is valid for implementations to ignore hint.
1005}
1006
1007void State::setViewportParams(GLint x, GLint y, GLsizei width, GLsizei height)
1008{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001009 mViewport.x = x;
1010 mViewport.y = y;
1011 mViewport.width = width;
Shannon Woods53a94a82014-06-24 15:20:36 -04001012 mViewport.height = height;
Jamie Madill1b94d432015-08-07 13:23:23 -04001013 mDirtyBits.set(DIRTY_BIT_VIEWPORT);
Shannon Woods53a94a82014-06-24 15:20:36 -04001014}
1015
Shannon Woods53a94a82014-06-24 15:20:36 -04001016void State::setActiveSampler(unsigned int active)
1017{
1018 mActiveSampler = active;
1019}
1020
Jamie Madille3e680c2018-12-03 17:49:08 -05001021void State::setSamplerTexture(const Context *context, TextureType type, Texture *texture)
Shannon Woods53a94a82014-06-24 15:20:36 -04001022{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001023 mSamplerTextures[type][mActiveSampler].set(context, texture);
Jamie Madill14246812018-10-03 17:51:16 -04001024
1025 if (mProgram && mProgram->getActiveSamplersMask()[mActiveSampler] &&
1026 mProgram->getActiveSamplerTypes()[mActiveSampler] == type)
1027 {
Jamie Madille3e680c2018-12-03 17:49:08 -05001028 updateActiveTexture(context, mActiveSampler, texture);
Jamie Madill14246812018-10-03 17:51:16 -04001029 }
1030
Jamie Madill81c2e252017-09-09 23:32:46 -04001031 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
Shannon Woods53a94a82014-06-24 15:20:36 -04001032}
1033
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001034Texture *State::getTargetTexture(TextureType type) const
Jamie Madillc29968b2016-01-20 11:17:23 -05001035{
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001036 return getSamplerTexture(static_cast<unsigned int>(mActiveSampler), type);
Jamie Madillc29968b2016-01-20 11:17:23 -05001037}
1038
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001039GLuint State::getSamplerTextureId(unsigned int sampler, TextureType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001040{
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001041 ASSERT(sampler < mSamplerTextures[type].size());
1042 return mSamplerTextures[type][sampler].id();
Shannon Woods53a94a82014-06-24 15:20:36 -04001043}
1044
Jamie Madilla02315b2017-02-23 14:14:47 -05001045void State::detachTexture(const Context *context, const TextureMap &zeroTextures, GLuint texture)
Shannon Woods53a94a82014-06-24 15:20:36 -04001046{
1047 // Textures have a detach method on State rather than a simple
1048 // removeBinding, because the zero/null texture objects are managed
1049 // separately, and don't have to go through the Context's maps or
1050 // the ResourceManager.
1051
1052 // [OpenGL ES 2.0.24] section 3.8 page 84:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001053 // If a texture object is deleted, it is as if all texture units which are bound to that texture
1054 // object are rebound to texture object zero
Shannon Woods53a94a82014-06-24 15:20:36 -04001055
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001056 for (TextureType type : angle::AllEnums<TextureType>())
Shannon Woods53a94a82014-06-24 15:20:36 -04001057 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001058 TextureBindingVector &textureVector = mSamplerTextures[type];
Jamie Madill81c2e252017-09-09 23:32:46 -04001059 for (BindingPointer<Texture> &binding : textureVector)
Shannon Woods53a94a82014-06-24 15:20:36 -04001060 {
Geoff Lang76b10c92014-09-05 16:28:14 -04001061 if (binding.id() == texture)
Shannon Woods53a94a82014-06-24 15:20:36 -04001062 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001063 Texture *zeroTexture = zeroTextures[type].get();
1064 ASSERT(zeroTexture != nullptr);
Jamie Madille6382c32014-11-07 15:05:26 -05001065 // Zero textures are the "default" textures instead of NULL
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001066 binding.set(context, zeroTexture);
Jamie Madill81c2e252017-09-09 23:32:46 -04001067 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
Shannon Woods53a94a82014-06-24 15:20:36 -04001068 }
1069 }
1070 }
1071
Xinghua Cao65ec0b22017-03-28 16:10:52 +08001072 for (auto &bindingImageUnit : mImageUnits)
1073 {
1074 if (bindingImageUnit.texture.id() == texture)
1075 {
1076 bindingImageUnit.texture.set(context, nullptr);
1077 bindingImageUnit.level = 0;
1078 bindingImageUnit.layered = false;
1079 bindingImageUnit.layer = 0;
1080 bindingImageUnit.access = GL_READ_ONLY;
1081 bindingImageUnit.format = GL_R32UI;
1082 break;
1083 }
1084 }
1085
Shannon Woods53a94a82014-06-24 15:20:36 -04001086 // [OpenGL ES 2.0.24] section 4.4 page 112:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001087 // If a texture object is deleted while its image is attached to the currently bound
1088 // framebuffer, then it is as if Texture2DAttachment had been called, with a texture of 0, for
1089 // each attachment point to which this image was attached in the currently bound framebuffer.
Shannon Woods53a94a82014-06-24 15:20:36 -04001090
Jamie Madill8693bdb2017-09-02 15:32:14 -04001091 if (mReadFramebuffer && mReadFramebuffer->detachTexture(context, texture))
Shannon Woods53a94a82014-06-24 15:20:36 -04001092 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001093 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -04001094 }
1095
Jamie Madill8693bdb2017-09-02 15:32:14 -04001096 if (mDrawFramebuffer && mDrawFramebuffer->detachTexture(context, texture))
Shannon Woods53a94a82014-06-24 15:20:36 -04001097 {
Jamie Madillef9fcd92018-11-28 14:03:59 -05001098 setDrawFramebufferDirty();
Shannon Woods53a94a82014-06-24 15:20:36 -04001099 }
1100}
1101
Jamie Madill4928b7c2017-06-20 12:57:39 -04001102void State::initializeZeroTextures(const Context *context, const TextureMap &zeroTextures)
Jamie Madille6382c32014-11-07 15:05:26 -05001103{
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001104 for (TextureType type : angle::AllEnums<TextureType>())
Jamie Madille6382c32014-11-07 15:05:26 -05001105 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001106 for (size_t textureUnit = 0; textureUnit < mSamplerTextures[type].size(); ++textureUnit)
Jamie Madille6382c32014-11-07 15:05:26 -05001107 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001108 mSamplerTextures[type][textureUnit].set(context, zeroTextures[type].get());
Jamie Madille6382c32014-11-07 15:05:26 -05001109 }
1110 }
1111}
1112
Jamie Madill4928b7c2017-06-20 12:57:39 -04001113void State::setSamplerBinding(const Context *context, GLuint textureUnit, Sampler *sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001114{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001115 mSamplers[textureUnit].set(context, sampler);
Jamie Madill81c2e252017-09-09 23:32:46 -04001116 mDirtyBits.set(DIRTY_BIT_SAMPLER_BINDINGS);
Jamie Madille25b8002018-09-20 13:39:49 -04001117 // This is overly conservative as it assumes the sampler has never been bound.
1118 setSamplerDirty(textureUnit);
Jamie Madille3e680c2018-12-03 17:49:08 -05001119 onActiveTextureChange(context, textureUnit);
Shannon Woods53a94a82014-06-24 15:20:36 -04001120}
1121
Jamie Madill4928b7c2017-06-20 12:57:39 -04001122void State::detachSampler(const Context *context, GLuint sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001123{
1124 // [OpenGL ES 3.0.2] section 3.8.2 pages 123-124:
1125 // If a sampler object that is currently bound to one or more texture units is
1126 // deleted, it is as though BindSampler is called once for each texture unit to
1127 // which the sampler is bound, with unit set to the texture unit and sampler set to zero.
Jamie Madill81c2e252017-09-09 23:32:46 -04001128 for (BindingPointer<Sampler> &samplerBinding : mSamplers)
Shannon Woods53a94a82014-06-24 15:20:36 -04001129 {
Geoff Lang76b10c92014-09-05 16:28:14 -04001130 if (samplerBinding.id() == sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001131 {
Jamie Madill4928b7c2017-06-20 12:57:39 -04001132 samplerBinding.set(context, nullptr);
Jamie Madill81c2e252017-09-09 23:32:46 -04001133 mDirtyBits.set(DIRTY_BIT_SAMPLER_BINDINGS);
Shannon Woods53a94a82014-06-24 15:20:36 -04001134 }
1135 }
1136}
1137
Jamie Madill4928b7c2017-06-20 12:57:39 -04001138void State::setRenderbufferBinding(const Context *context, Renderbuffer *renderbuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001139{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001140 mRenderbuffer.set(context, renderbuffer);
Jamie Madill8693bdb2017-09-02 15:32:14 -04001141 mDirtyBits.set(DIRTY_BIT_RENDERBUFFER_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001142}
1143
Jamie Madilla02315b2017-02-23 14:14:47 -05001144void State::detachRenderbuffer(const Context *context, GLuint renderbuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001145{
1146 // [OpenGL ES 2.0.24] section 4.4 page 109:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001147 // If a renderbuffer that is currently bound to RENDERBUFFER is deleted, it is as though
1148 // BindRenderbuffer had been executed with the target RENDERBUFFER and name of zero.
Shannon Woods53a94a82014-06-24 15:20:36 -04001149
1150 if (mRenderbuffer.id() == renderbuffer)
1151 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001152 setRenderbufferBinding(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001153 }
1154
1155 // [OpenGL ES 2.0.24] section 4.4 page 111:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001156 // If a renderbuffer object is deleted while its image is attached to the currently bound
1157 // framebuffer, then it is as if FramebufferRenderbuffer had been called, with a renderbuffer of
1158 // 0, for each attachment point to which this image was attached in the currently bound
1159 // framebuffer.
Shannon Woods53a94a82014-06-24 15:20:36 -04001160
1161 Framebuffer *readFramebuffer = mReadFramebuffer;
1162 Framebuffer *drawFramebuffer = mDrawFramebuffer;
1163
Jamie Madill8693bdb2017-09-02 15:32:14 -04001164 if (readFramebuffer && readFramebuffer->detachRenderbuffer(context, renderbuffer))
Shannon Woods53a94a82014-06-24 15:20:36 -04001165 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001166 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -04001167 }
1168
1169 if (drawFramebuffer && drawFramebuffer != readFramebuffer)
1170 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001171 if (drawFramebuffer->detachRenderbuffer(context, renderbuffer))
1172 {
Jamie Madillef9fcd92018-11-28 14:03:59 -05001173 setDrawFramebufferDirty();
Jamie Madill8693bdb2017-09-02 15:32:14 -04001174 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001175 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001176}
1177
1178void State::setReadFramebufferBinding(Framebuffer *framebuffer)
1179{
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001180 if (mReadFramebuffer == framebuffer)
1181 return;
1182
Shannon Woods53a94a82014-06-24 15:20:36 -04001183 mReadFramebuffer = framebuffer;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001184 mDirtyBits.set(DIRTY_BIT_READ_FRAMEBUFFER_BINDING);
1185
1186 if (mReadFramebuffer && mReadFramebuffer->hasAnyDirtyBit())
1187 {
1188 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
1189 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001190}
1191
1192void State::setDrawFramebufferBinding(Framebuffer *framebuffer)
1193{
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001194 if (mDrawFramebuffer == framebuffer)
1195 return;
1196
Shannon Woods53a94a82014-06-24 15:20:36 -04001197 mDrawFramebuffer = framebuffer;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001198 mDirtyBits.set(DIRTY_BIT_DRAW_FRAMEBUFFER_BINDING);
1199
Jamie Madillef9fcd92018-11-28 14:03:59 -05001200 if (mDrawFramebuffer)
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001201 {
Jamie Madillef9fcd92018-11-28 14:03:59 -05001202 if (mDrawFramebuffer->hasAnyDirtyBit())
1203 {
1204 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
1205 }
1206
1207 if (mRobustResourceInit && mDrawFramebuffer->hasResourceThatNeedsInit())
1208 {
1209 mDirtyObjects.set(DIRTY_OBJECT_DRAW_ATTACHMENTS);
1210 }
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001211 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001212}
1213
1214Framebuffer *State::getTargetFramebuffer(GLenum target) const
1215{
1216 switch (target)
1217 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001218 case GL_READ_FRAMEBUFFER_ANGLE:
1219 return mReadFramebuffer;
1220 case GL_DRAW_FRAMEBUFFER_ANGLE:
1221 case GL_FRAMEBUFFER:
1222 return mDrawFramebuffer;
1223 default:
1224 UNREACHABLE();
Yunchao Hef81ce4a2017-04-24 10:49:17 +08001225 return nullptr;
Shannon Woods53a94a82014-06-24 15:20:36 -04001226 }
1227}
1228
Shannon Woods53a94a82014-06-24 15:20:36 -04001229bool State::removeReadFramebufferBinding(GLuint framebuffer)
1230{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001231 if (mReadFramebuffer != nullptr && mReadFramebuffer->id() == framebuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001232 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001233 setReadFramebufferBinding(nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001234 return true;
1235 }
1236
1237 return false;
1238}
1239
1240bool State::removeDrawFramebufferBinding(GLuint framebuffer)
1241{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001242 if (mReadFramebuffer != nullptr && mDrawFramebuffer->id() == framebuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001243 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001244 setDrawFramebufferBinding(nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001245 return true;
1246 }
1247
1248 return false;
1249}
1250
Jamie Madill7267aa62018-04-17 15:28:21 -04001251void State::setVertexArrayBinding(const Context *context, VertexArray *vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001252{
James Darpiniane8a93c62018-01-04 18:02:24 -08001253 if (mVertexArray == vertexArray)
1254 return;
1255 if (mVertexArray)
Jamie Madillbf5177d2018-08-21 12:58:20 -04001256 mVertexArray->onBindingChanged(context, -1);
Shannon Woods53a94a82014-06-24 15:20:36 -04001257 mVertexArray = vertexArray;
James Darpiniane8a93c62018-01-04 18:02:24 -08001258 if (vertexArray)
Jamie Madillbf5177d2018-08-21 12:58:20 -04001259 vertexArray->onBindingChanged(context, 1);
Jamie Madill0b9e9032015-08-17 11:51:52 +00001260 mDirtyBits.set(DIRTY_BIT_VERTEX_ARRAY_BINDING);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001261
1262 if (mVertexArray && mVertexArray->hasAnyDirtyBit())
1263 {
1264 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1265 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001266}
1267
Jamie Madill7267aa62018-04-17 15:28:21 -04001268bool State::removeVertexArrayBinding(const Context *context, GLuint vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001269{
James Darpiniane8a93c62018-01-04 18:02:24 -08001270 if (mVertexArray && mVertexArray->id() == vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001271 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001272 mVertexArray->onBindingChanged(context, -1);
Yunchao Hed7297bf2017-04-19 15:27:10 +08001273 mVertexArray = nullptr;
Jamie Madill0b9e9032015-08-17 11:51:52 +00001274 mDirtyBits.set(DIRTY_BIT_VERTEX_ARRAY_BINDING);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001275 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001276 return true;
1277 }
1278
1279 return false;
1280}
1281
Markus Tavenrath774fe562018-11-18 14:14:49 +01001282GLuint State::getVertexArrayId() const
1283{
1284 ASSERT(mVertexArray != nullptr);
1285 return mVertexArray->id();
1286}
1287
Jamie Madill4928b7c2017-06-20 12:57:39 -04001288void State::bindVertexBuffer(const Context *context,
1289 GLuint bindingIndex,
Shao80957d92017-02-20 21:25:59 +08001290 Buffer *boundBuffer,
1291 GLintptr offset,
1292 GLsizei stride)
1293{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001294 getVertexArray()->bindVertexBuffer(context, bindingIndex, boundBuffer, offset, stride);
Shao80957d92017-02-20 21:25:59 +08001295 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1296}
1297
Shaodde78e82017-05-22 14:13:27 +08001298void State::setVertexAttribBinding(const Context *context, GLuint attribIndex, GLuint bindingIndex)
Shao80957d92017-02-20 21:25:59 +08001299{
Shaodde78e82017-05-22 14:13:27 +08001300 getVertexArray()->setVertexAttribBinding(context, attribIndex, bindingIndex);
Shao80957d92017-02-20 21:25:59 +08001301 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1302}
1303
1304void State::setVertexAttribFormat(GLuint attribIndex,
1305 GLint size,
1306 GLenum type,
1307 bool normalized,
1308 bool pureInteger,
1309 GLuint relativeOffset)
1310{
1311 getVertexArray()->setVertexAttribFormat(attribIndex, size, type, normalized, pureInteger,
1312 relativeOffset);
1313 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1314}
1315
1316void State::setVertexBindingDivisor(GLuint bindingIndex, GLuint divisor)
1317{
1318 getVertexArray()->setVertexBindingDivisor(bindingIndex, divisor);
1319 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1320}
1321
Jamie Madill6f755b22018-10-09 12:48:54 -04001322angle::Result State::setProgram(const Context *context, Program *newProgram)
Shannon Woods53a94a82014-06-24 15:20:36 -04001323{
Geoff Lang7dd2e102014-11-10 15:19:26 -05001324 if (mProgram != newProgram)
Shannon Woods53a94a82014-06-24 15:20:36 -04001325 {
Geoff Lang7dd2e102014-11-10 15:19:26 -05001326 if (mProgram)
1327 {
Jamie Madille3bb6b72018-10-03 17:51:15 -04001328 unsetActiveTextures(mProgram->getActiveSamplersMask());
Jamie Madill6c1f6712017-02-14 19:08:04 -05001329 mProgram->release(context);
Geoff Lang7dd2e102014-11-10 15:19:26 -05001330 }
1331
1332 mProgram = newProgram;
1333
1334 if (mProgram)
1335 {
1336 newProgram->addRef();
Jamie Madille3bb6b72018-10-03 17:51:15 -04001337 ANGLE_TRY(onProgramExecutableChange(context, newProgram));
Geoff Lang7dd2e102014-11-10 15:19:26 -05001338 }
Jamie Madilldf836ff2018-10-01 10:36:24 -04001339
1340 // Note that rendering is undefined if glUseProgram(0) is called. But ANGLE will generate
1341 // an error if the app tries to draw in this case.
1342
Jamie Madilla779b612017-07-24 11:46:05 -04001343 mDirtyBits.set(DIRTY_BIT_PROGRAM_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001344 }
Jamie Madille3bb6b72018-10-03 17:51:15 -04001345
Jamie Madill7c985f52018-11-29 18:16:17 -05001346 return angle::Result::Continue;
Shannon Woods53a94a82014-06-24 15:20:36 -04001347}
1348
Jamie Madill4928b7c2017-06-20 12:57:39 -04001349void State::setTransformFeedbackBinding(const Context *context,
1350 TransformFeedback *transformFeedback)
Shannon Woods53a94a82014-06-24 15:20:36 -04001351{
James Darpiniane8a93c62018-01-04 18:02:24 -08001352 if (transformFeedback == mTransformFeedback.get())
1353 return;
1354 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -04001355 mTransformFeedback->onBindingChanged(context, false);
Jamie Madill4928b7c2017-06-20 12:57:39 -04001356 mTransformFeedback.set(context, transformFeedback);
James Darpiniane8a93c62018-01-04 18:02:24 -08001357 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -04001358 mTransformFeedback->onBindingChanged(context, true);
Geoff Langded79232017-11-28 15:21:11 -05001359 mDirtyBits.set(DIRTY_BIT_TRANSFORM_FEEDBACK_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001360}
1361
Jamie Madill4928b7c2017-06-20 12:57:39 -04001362bool State::removeTransformFeedbackBinding(const Context *context, GLuint transformFeedback)
Shannon Woods53a94a82014-06-24 15:20:36 -04001363{
1364 if (mTransformFeedback.id() == transformFeedback)
1365 {
James Darpiniane8a93c62018-01-04 18:02:24 -08001366 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -04001367 mTransformFeedback->onBindingChanged(context, false);
Jamie Madill4928b7c2017-06-20 12:57:39 -04001368 mTransformFeedback.set(context, nullptr);
Corentin Walleza2257da2016-04-19 16:43:12 -04001369 return true;
Shannon Woods53a94a82014-06-24 15:20:36 -04001370 }
Corentin Walleza2257da2016-04-19 16:43:12 -04001371
1372 return false;
Shannon Woods53a94a82014-06-24 15:20:36 -04001373}
1374
Yunchao Hea336b902017-08-02 16:05:21 +08001375void State::setProgramPipelineBinding(const Context *context, ProgramPipeline *pipeline)
1376{
1377 mProgramPipeline.set(context, pipeline);
1378}
1379
1380void State::detachProgramPipeline(const Context *context, GLuint pipeline)
1381{
1382 mProgramPipeline.set(context, nullptr);
1383}
1384
Corentin Wallezad3ae902018-03-09 13:40:42 -05001385bool State::isQueryActive(QueryType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001386{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001387 const Query *query = mActiveQueries[type].get();
1388 if (query != nullptr)
Shannon Woods53a94a82014-06-24 15:20:36 -04001389 {
Corentin Wallezad3ae902018-03-09 13:40:42 -05001390 return true;
1391 }
1392
1393 QueryType alternativeType;
1394 if (GetAlternativeQueryType(type, &alternativeType))
1395 {
1396 query = mActiveQueries[alternativeType].get();
1397 return query != nullptr;
Ian Ewell3ffd78b2016-01-22 16:09:42 -05001398 }
1399
1400 return false;
1401}
1402
1403bool State::isQueryActive(Query *query) const
1404{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001405 for (auto &queryPointer : mActiveQueries)
Ian Ewell3ffd78b2016-01-22 16:09:42 -05001406 {
Corentin Wallezad3ae902018-03-09 13:40:42 -05001407 if (queryPointer.get() == query)
Shannon Woods53a94a82014-06-24 15:20:36 -04001408 {
1409 return true;
1410 }
1411 }
1412
1413 return false;
1414}
1415
Corentin Wallezad3ae902018-03-09 13:40:42 -05001416void State::setActiveQuery(const Context *context, QueryType type, Query *query)
Shannon Woods53a94a82014-06-24 15:20:36 -04001417{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001418 mActiveQueries[type].set(context, query);
Shannon Woods53a94a82014-06-24 15:20:36 -04001419}
1420
Corentin Wallezad3ae902018-03-09 13:40:42 -05001421GLuint State::getActiveQueryId(QueryType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001422{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001423 const Query *query = getActiveQuery(type);
Shannon Woods53a94a82014-06-24 15:20:36 -04001424 return (query ? query->id() : 0u);
1425}
1426
Corentin Wallezad3ae902018-03-09 13:40:42 -05001427Query *State::getActiveQuery(QueryType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001428{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001429 return mActiveQueries[type].get();
Shannon Woods53a94a82014-06-24 15:20:36 -04001430}
1431
Corentin Wallez336129f2017-10-17 15:55:40 -04001432void State::setIndexedBufferBinding(const Context *context,
1433 BufferBinding target,
1434 GLuint index,
1435 Buffer *buffer,
1436 GLintptr offset,
1437 GLsizeiptr size)
Jiajia Qin9d7d0b12016-11-29 16:30:31 +08001438{
Corentin Wallez336129f2017-10-17 15:55:40 -04001439 setBufferBinding(context, target, buffer);
Jiajia Qin9d7d0b12016-11-29 16:30:31 +08001440
Corentin Wallez336129f2017-10-17 15:55:40 -04001441 switch (target)
1442 {
1443 case BufferBinding::TransformFeedback:
1444 mTransformFeedback->bindIndexedBuffer(context, index, buffer, offset, size);
James Darpiniane8a93c62018-01-04 18:02:24 -08001445 setBufferBinding(context, target, buffer);
Corentin Wallez336129f2017-10-17 15:55:40 -04001446 break;
1447 case BufferBinding::Uniform:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001448 UpdateIndexedBufferBinding(context, &mUniformBuffers[index], buffer, target, offset,
1449 size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001450 break;
1451 case BufferBinding::AtomicCounter:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001452 UpdateIndexedBufferBinding(context, &mAtomicCounterBuffers[index], buffer, target,
1453 offset, size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001454 break;
1455 case BufferBinding::ShaderStorage:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001456 UpdateIndexedBufferBinding(context, &mShaderStorageBuffers[index], buffer, target,
1457 offset, size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001458 break;
1459 default:
1460 UNREACHABLE();
1461 break;
1462 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001463}
1464
Geoff Lang5d124a62015-09-15 13:03:27 -04001465const OffsetBindingPointer<Buffer> &State::getIndexedUniformBuffer(size_t index) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001466{
Shannon Woodsf3acaf92014-09-23 18:07:11 -04001467 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
Geoff Lang5d124a62015-09-15 13:03:27 -04001468 return mUniformBuffers[index];
Gregoire Payen de La Garanderie68694e92015-03-24 14:03:37 +00001469}
1470
Jiajia Qin6eafb042016-12-27 17:04:07 +08001471const OffsetBindingPointer<Buffer> &State::getIndexedAtomicCounterBuffer(size_t index) const
1472{
1473 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
1474 return mAtomicCounterBuffers[index];
1475}
1476
Jiajia Qinf546e7d2017-03-27 14:12:59 +08001477const OffsetBindingPointer<Buffer> &State::getIndexedShaderStorageBuffer(size_t index) const
1478{
1479 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
1480 return mShaderStorageBuffers[index];
1481}
1482
Corentin Wallez336129f2017-10-17 15:55:40 -04001483Buffer *State::getTargetBuffer(BufferBinding target) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001484{
1485 switch (target)
1486 {
Corentin Wallez336129f2017-10-17 15:55:40 -04001487 case BufferBinding::ElementArray:
Jamie Madillcd0a0a32018-10-18 18:41:57 -04001488 return getVertexArray()->getElementArrayBuffer();
Corentin Wallez336129f2017-10-17 15:55:40 -04001489 default:
1490 return mBoundBuffers[target].get();
Shannon Woods53a94a82014-06-24 15:20:36 -04001491 }
1492}
1493
James Darpinian4d9d4832018-03-13 12:43:28 -07001494void State::detachBuffer(const Context *context, const Buffer *buffer)
Yuly Novikov5807a532015-12-03 13:01:22 -05001495{
James Darpinian4d9d4832018-03-13 12:43:28 -07001496 if (!buffer->isBound())
1497 {
1498 return;
1499 }
1500 GLuint bufferName = buffer->id();
James Darpiniane8a93c62018-01-04 18:02:24 -08001501 for (auto target : angle::AllEnums<BufferBinding>())
Yuly Novikov5807a532015-12-03 13:01:22 -05001502 {
James Darpiniane8a93c62018-01-04 18:02:24 -08001503 if (mBoundBuffers[target].id() == bufferName)
Yuly Novikov5807a532015-12-03 13:01:22 -05001504 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001505 UpdateBufferBinding(context, &mBoundBuffers[target], nullptr, target);
Yuly Novikov5807a532015-12-03 13:01:22 -05001506 }
1507 }
1508
1509 TransformFeedback *curTransformFeedback = getCurrentTransformFeedback();
1510 if (curTransformFeedback)
1511 {
Jamie Madill4928b7c2017-06-20 12:57:39 -04001512 curTransformFeedback->detachBuffer(context, bufferName);
Yuly Novikov5807a532015-12-03 13:01:22 -05001513 }
1514
Jamie Madill4928b7c2017-06-20 12:57:39 -04001515 getVertexArray()->detachBuffer(context, bufferName);
James Darpiniane8a93c62018-01-04 18:02:24 -08001516
1517 for (auto &buf : mUniformBuffers)
1518 {
1519 if (buf.id() == bufferName)
1520 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001521 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::Uniform, 0, 0);
James Darpiniane8a93c62018-01-04 18:02:24 -08001522 }
1523 }
1524
1525 for (auto &buf : mAtomicCounterBuffers)
1526 {
1527 if (buf.id() == bufferName)
1528 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001529 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::AtomicCounter, 0, 0);
James Darpiniane8a93c62018-01-04 18:02:24 -08001530 }
1531 }
1532
1533 for (auto &buf : mShaderStorageBuffers)
1534 {
1535 if (buf.id() == bufferName)
1536 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001537 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::ShaderStorage, 0, 0);
James Darpiniane8a93c62018-01-04 18:02:24 -08001538 }
1539 }
Yuly Novikov5807a532015-12-03 13:01:22 -05001540}
1541
Shannon Woods53a94a82014-06-24 15:20:36 -04001542void State::setEnableVertexAttribArray(unsigned int attribNum, bool enabled)
1543{
1544 getVertexArray()->enableAttribute(attribNum, enabled);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001545 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001546}
1547
1548void State::setVertexAttribf(GLuint index, const GLfloat values[4])
1549{
Shannon Woods23e05002014-09-22 19:07:27 -04001550 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001551 mVertexAttribCurrentValues[index].setFloatValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001552 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1553 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001554 mCurrentValuesTypeMask.setIndex(GL_FLOAT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001555}
1556
1557void State::setVertexAttribu(GLuint index, const GLuint values[4])
1558{
Shannon Woods23e05002014-09-22 19:07:27 -04001559 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001560 mVertexAttribCurrentValues[index].setUnsignedIntValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001561 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1562 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001563 mCurrentValuesTypeMask.setIndex(GL_UNSIGNED_INT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001564}
1565
1566void State::setVertexAttribi(GLuint index, const GLint values[4])
1567{
Shannon Woods23e05002014-09-22 19:07:27 -04001568 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001569 mVertexAttribCurrentValues[index].setIntValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001570 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1571 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001572 mCurrentValuesTypeMask.setIndex(GL_INT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001573}
1574
Shaodde78e82017-05-22 14:13:27 +08001575void State::setVertexAttribPointer(const Context *context,
1576 unsigned int attribNum,
1577 Buffer *boundBuffer,
1578 GLint size,
1579 GLenum type,
1580 bool normalized,
1581 bool pureInteger,
1582 GLsizei stride,
1583 const void *pointer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001584{
Shaodde78e82017-05-22 14:13:27 +08001585 getVertexArray()->setVertexAttribPointer(context, attribNum, boundBuffer, size, type,
1586 normalized, pureInteger, stride, pointer);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001587 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Jamie Madill0b9e9032015-08-17 11:51:52 +00001588}
1589
Shaodde78e82017-05-22 14:13:27 +08001590void State::setVertexAttribDivisor(const Context *context, GLuint index, GLuint divisor)
Jamie Madill0b9e9032015-08-17 11:51:52 +00001591{
Shaodde78e82017-05-22 14:13:27 +08001592 getVertexArray()->setVertexAttribDivisor(context, index, divisor);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001593 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001594}
1595
Shannon Woods53a94a82014-06-24 15:20:36 -04001596const void *State::getVertexAttribPointer(unsigned int attribNum) const
1597{
1598 return getVertexArray()->getVertexAttribute(attribNum).pointer;
1599}
1600
1601void State::setPackAlignment(GLint alignment)
1602{
1603 mPack.alignment = alignment;
Jamie Madillc67323a2017-11-02 23:11:41 -04001604 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001605}
1606
Shannon Woods53a94a82014-06-24 15:20:36 -04001607void State::setPackReverseRowOrder(bool reverseRowOrder)
1608{
1609 mPack.reverseRowOrder = reverseRowOrder;
Jamie Madillc67323a2017-11-02 23:11:41 -04001610 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001611}
1612
Minmin Gongadff67b2015-10-14 10:34:45 -04001613void State::setPackRowLength(GLint rowLength)
1614{
1615 mPack.rowLength = rowLength;
Jamie Madillc67323a2017-11-02 23:11:41 -04001616 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001617}
1618
Minmin Gongadff67b2015-10-14 10:34:45 -04001619void State::setPackSkipRows(GLint skipRows)
1620{
1621 mPack.skipRows = skipRows;
Jamie Madillc67323a2017-11-02 23:11:41 -04001622 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001623}
1624
Minmin Gongadff67b2015-10-14 10:34:45 -04001625void State::setPackSkipPixels(GLint skipPixels)
1626{
1627 mPack.skipPixels = skipPixels;
Jamie Madillc67323a2017-11-02 23:11:41 -04001628 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001629}
1630
Shannon Woods53a94a82014-06-24 15:20:36 -04001631void State::setUnpackAlignment(GLint alignment)
1632{
1633 mUnpack.alignment = alignment;
Jamie Madillc67323a2017-11-02 23:11:41 -04001634 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001635}
1636
Minmin Gongb8aee3b2015-01-27 14:42:36 -08001637void State::setUnpackRowLength(GLint rowLength)
1638{
1639 mUnpack.rowLength = rowLength;
Jamie Madillc67323a2017-11-02 23:11:41 -04001640 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongb8aee3b2015-01-27 14:42:36 -08001641}
1642
Minmin Gongadff67b2015-10-14 10:34:45 -04001643void State::setUnpackImageHeight(GLint imageHeight)
1644{
1645 mUnpack.imageHeight = imageHeight;
Jamie Madillc67323a2017-11-02 23:11:41 -04001646 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001647}
1648
Minmin Gongadff67b2015-10-14 10:34:45 -04001649void State::setUnpackSkipImages(GLint skipImages)
1650{
1651 mUnpack.skipImages = skipImages;
Jamie Madillc67323a2017-11-02 23:11:41 -04001652 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001653}
1654
Minmin Gongadff67b2015-10-14 10:34:45 -04001655void State::setUnpackSkipRows(GLint skipRows)
1656{
1657 mUnpack.skipRows = skipRows;
Jamie Madillc67323a2017-11-02 23:11:41 -04001658 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001659}
1660
Minmin Gongadff67b2015-10-14 10:34:45 -04001661void State::setUnpackSkipPixels(GLint skipPixels)
1662{
1663 mUnpack.skipPixels = skipPixels;
Jamie Madillc67323a2017-11-02 23:11:41 -04001664 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001665}
1666
Sami Väisänena797e062016-05-12 15:23:40 +03001667void State::setCoverageModulation(GLenum components)
1668{
1669 mCoverageModulation = components;
1670 mDirtyBits.set(DIRTY_BIT_COVERAGE_MODULATION);
1671}
1672
Sami Väisänene45e53b2016-05-25 10:36:04 +03001673void State::loadPathRenderingMatrix(GLenum matrixMode, const GLfloat *matrix)
1674{
1675 if (matrixMode == GL_PATH_MODELVIEW_CHROMIUM)
1676 {
1677 memcpy(mPathMatrixMV, matrix, 16 * sizeof(GLfloat));
jchen10bb2f2c42018-09-16 09:47:38 +08001678 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING);
Sami Väisänene45e53b2016-05-25 10:36:04 +03001679 }
1680 else if (matrixMode == GL_PATH_PROJECTION_CHROMIUM)
1681 {
1682 memcpy(mPathMatrixProj, matrix, 16 * sizeof(GLfloat));
jchen10bb2f2c42018-09-16 09:47:38 +08001683 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING);
Sami Väisänene45e53b2016-05-25 10:36:04 +03001684 }
1685 else
1686 {
1687 UNREACHABLE();
1688 }
1689}
1690
1691const GLfloat *State::getPathRenderingMatrix(GLenum which) const
1692{
1693 if (which == GL_PATH_MODELVIEW_MATRIX_CHROMIUM)
1694 {
1695 return mPathMatrixMV;
1696 }
1697 else if (which == GL_PATH_PROJECTION_MATRIX_CHROMIUM)
1698 {
1699 return mPathMatrixProj;
1700 }
1701
1702 UNREACHABLE();
1703 return nullptr;
1704}
1705
1706void State::setPathStencilFunc(GLenum func, GLint ref, GLuint mask)
1707{
1708 mPathStencilFunc = func;
1709 mPathStencilRef = ref;
1710 mPathStencilMask = mask;
jchen10bb2f2c42018-09-16 09:47:38 +08001711 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING);
Sami Väisänene45e53b2016-05-25 10:36:04 +03001712}
1713
Geoff Lang1d2c41d2016-10-19 16:14:46 -07001714void State::setFramebufferSRGB(bool sRGB)
1715{
1716 mFramebufferSRGB = sRGB;
1717 mDirtyBits.set(DIRTY_BIT_FRAMEBUFFER_SRGB);
1718}
1719
jchen1082af6202018-06-22 10:59:52 +08001720void State::setMaxShaderCompilerThreads(GLuint count)
1721{
1722 mMaxShaderCompilerThreads = count;
1723}
1724
Shannon Woods53a94a82014-06-24 15:20:36 -04001725void State::getBooleanv(GLenum pname, GLboolean *params)
1726{
1727 switch (pname)
1728 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001729 case GL_SAMPLE_COVERAGE_INVERT:
1730 *params = mSampleCoverageInvert;
1731 break;
1732 case GL_DEPTH_WRITEMASK:
1733 *params = mDepthStencil.depthMask;
1734 break;
1735 case GL_COLOR_WRITEMASK:
1736 params[0] = mBlend.colorMaskRed;
1737 params[1] = mBlend.colorMaskGreen;
1738 params[2] = mBlend.colorMaskBlue;
1739 params[3] = mBlend.colorMaskAlpha;
1740 break;
1741 case GL_CULL_FACE:
1742 *params = mRasterizer.cullFace;
1743 break;
1744 case GL_POLYGON_OFFSET_FILL:
1745 *params = mRasterizer.polygonOffsetFill;
1746 break;
1747 case GL_SAMPLE_ALPHA_TO_COVERAGE:
1748 *params = mBlend.sampleAlphaToCoverage;
1749 break;
1750 case GL_SAMPLE_COVERAGE:
1751 *params = mSampleCoverage;
1752 break;
1753 case GL_SAMPLE_MASK:
1754 *params = mSampleMask;
1755 break;
1756 case GL_SCISSOR_TEST:
1757 *params = mScissorTest;
1758 break;
1759 case GL_STENCIL_TEST:
1760 *params = mDepthStencil.stencilTest;
1761 break;
1762 case GL_DEPTH_TEST:
1763 *params = mDepthStencil.depthTest;
1764 break;
1765 case GL_BLEND:
1766 *params = mBlend.blend;
1767 break;
1768 case GL_DITHER:
1769 *params = mBlend.dither;
1770 break;
1771 case GL_TRANSFORM_FEEDBACK_ACTIVE:
1772 *params = getCurrentTransformFeedback()->isActive() ? GL_TRUE : GL_FALSE;
1773 break;
1774 case GL_TRANSFORM_FEEDBACK_PAUSED:
1775 *params = getCurrentTransformFeedback()->isPaused() ? GL_TRUE : GL_FALSE;
1776 break;
1777 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
1778 *params = mPrimitiveRestart;
1779 break;
1780 case GL_RASTERIZER_DISCARD:
1781 *params = isRasterizerDiscardEnabled() ? GL_TRUE : GL_FALSE;
1782 break;
1783 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
1784 *params = mDebug.isOutputSynchronous() ? GL_TRUE : GL_FALSE;
1785 break;
1786 case GL_DEBUG_OUTPUT:
1787 *params = mDebug.isOutputEnabled() ? GL_TRUE : GL_FALSE;
1788 break;
1789 case GL_MULTISAMPLE_EXT:
1790 *params = mMultiSampling;
1791 break;
1792 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
1793 *params = mSampleAlphaToOne;
1794 break;
1795 case GL_BIND_GENERATES_RESOURCE_CHROMIUM:
1796 *params = isBindGeneratesResourceEnabled() ? GL_TRUE : GL_FALSE;
1797 break;
1798 case GL_CLIENT_ARRAYS_ANGLE:
1799 *params = areClientArraysEnabled() ? GL_TRUE : GL_FALSE;
1800 break;
1801 case GL_FRAMEBUFFER_SRGB_EXT:
1802 *params = getFramebufferSRGB() ? GL_TRUE : GL_FALSE;
1803 break;
1804 case GL_ROBUST_RESOURCE_INITIALIZATION_ANGLE:
1805 *params = mRobustResourceInit ? GL_TRUE : GL_FALSE;
1806 break;
1807 case GL_PROGRAM_CACHE_ENABLED_ANGLE:
1808 *params = mProgramBinaryCacheEnabled ? GL_TRUE : GL_FALSE;
1809 break;
Lingfeng Yangd0febe72018-05-17 22:36:52 -07001810 case GL_LIGHT_MODEL_TWO_SIDE:
1811 *params = IsLightModelTwoSided(&mGLES1State);
1812 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001813 default:
1814 UNREACHABLE();
1815 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04001816 }
1817}
1818
1819void State::getFloatv(GLenum pname, GLfloat *params)
1820{
1821 // Please note: DEPTH_CLEAR_VALUE is included in our internal getFloatv implementation
1822 // because it is stored as a float, despite the fact that the GL ES 2.0 spec names
1823 // GetIntegerv as its native query function. As it would require conversion in any
1824 // case, this should make no difference to the calling application.
1825 switch (pname)
1826 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001827 case GL_LINE_WIDTH:
1828 *params = mLineWidth;
1829 break;
1830 case GL_SAMPLE_COVERAGE_VALUE:
1831 *params = mSampleCoverageValue;
1832 break;
1833 case GL_DEPTH_CLEAR_VALUE:
1834 *params = mDepthClearValue;
1835 break;
1836 case GL_POLYGON_OFFSET_FACTOR:
1837 *params = mRasterizer.polygonOffsetFactor;
1838 break;
1839 case GL_POLYGON_OFFSET_UNITS:
1840 *params = mRasterizer.polygonOffsetUnits;
1841 break;
1842 case GL_DEPTH_RANGE:
1843 params[0] = mNearZ;
1844 params[1] = mFarZ;
1845 break;
1846 case GL_COLOR_CLEAR_VALUE:
1847 params[0] = mColorClearValue.red;
1848 params[1] = mColorClearValue.green;
1849 params[2] = mColorClearValue.blue;
1850 params[3] = mColorClearValue.alpha;
1851 break;
1852 case GL_BLEND_COLOR:
1853 params[0] = mBlendColor.red;
1854 params[1] = mBlendColor.green;
1855 params[2] = mBlendColor.blue;
1856 params[3] = mBlendColor.alpha;
1857 break;
1858 case GL_MULTISAMPLE_EXT:
1859 *params = static_cast<GLfloat>(mMultiSampling);
1860 break;
1861 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
1862 *params = static_cast<GLfloat>(mSampleAlphaToOne);
1863 break;
1864 case GL_COVERAGE_MODULATION_CHROMIUM:
1865 params[0] = static_cast<GLfloat>(mCoverageModulation);
1866 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -07001867 case GL_ALPHA_TEST_REF:
1868 *params = mGLES1State.mAlphaTestRef;
1869 break;
Lingfeng Yanga43994c2018-03-29 07:21:41 -07001870 case GL_CURRENT_COLOR:
1871 {
1872 const auto &color = mGLES1State.mCurrentColor;
1873 params[0] = color.red;
1874 params[1] = color.green;
1875 params[2] = color.blue;
1876 params[3] = color.alpha;
1877 break;
1878 }
Lingfeng Yang5a7e61b2018-03-29 16:50:32 -07001879 case GL_CURRENT_NORMAL:
1880 {
1881 const auto &normal = mGLES1State.mCurrentNormal;
1882 params[0] = normal[0];
1883 params[1] = normal[1];
1884 params[2] = normal[2];
1885 break;
1886 }
Lingfeng Yang038dd532018-03-29 17:31:52 -07001887 case GL_CURRENT_TEXTURE_COORDS:
1888 {
1889 const auto &texcoord = mGLES1State.mCurrentTextureCoords[mActiveSampler];
1890 params[0] = texcoord.s;
1891 params[1] = texcoord.t;
1892 params[2] = texcoord.r;
1893 params[3] = texcoord.q;
1894 break;
1895 }
Lingfeng Yang3a41af62018-04-09 07:28:56 -07001896 case GL_MODELVIEW_MATRIX:
1897 memcpy(params, mGLES1State.mModelviewMatrices.back().data(), 16 * sizeof(GLfloat));
1898 break;
1899 case GL_PROJECTION_MATRIX:
1900 memcpy(params, mGLES1State.mProjectionMatrices.back().data(), 16 * sizeof(GLfloat));
1901 break;
1902 case GL_TEXTURE_MATRIX:
1903 memcpy(params, mGLES1State.mTextureMatrices[mActiveSampler].back().data(),
1904 16 * sizeof(GLfloat));
1905 break;
Lingfeng Yangd0febe72018-05-17 22:36:52 -07001906 case GL_LIGHT_MODEL_AMBIENT:
1907 GetLightModelParameters(&mGLES1State, pname, params);
1908 break;
Lingfeng Yang7ba3f422018-06-01 09:43:04 -07001909 case GL_FOG_MODE:
1910 case GL_FOG_DENSITY:
1911 case GL_FOG_START:
1912 case GL_FOG_END:
1913 case GL_FOG_COLOR:
1914 GetFogParameters(&mGLES1State, pname, params);
1915 break;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -07001916 case GL_POINT_SIZE:
1917 GetPointSize(&mGLES1State, params);
1918 break;
1919 case GL_POINT_SIZE_MIN:
1920 case GL_POINT_SIZE_MAX:
1921 case GL_POINT_FADE_THRESHOLD_SIZE:
1922 case GL_POINT_DISTANCE_ATTENUATION:
1923 GetPointParameter(&mGLES1State, FromGLenum<PointParameter>(pname), params);
1924 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001925 default:
1926 UNREACHABLE();
1927 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04001928 }
1929}
1930
Jamie Madill526392d2018-11-16 09:35:14 -05001931angle::Result State::getIntegerv(const Context *context, GLenum pname, GLint *params)
Shannon Woods53a94a82014-06-24 15:20:36 -04001932{
1933 if (pname >= GL_DRAW_BUFFER0_EXT && pname <= GL_DRAW_BUFFER15_EXT)
1934 {
Geoff Lang3e922062018-11-15 11:26:29 -05001935 size_t drawBuffer = (pname - GL_DRAW_BUFFER0_EXT);
1936 ASSERT(drawBuffer < mMaxDrawBuffers);
Shannon Woods53a94a82014-06-24 15:20:36 -04001937 Framebuffer *framebuffer = mDrawFramebuffer;
Geoff Lang3e922062018-11-15 11:26:29 -05001938 // The default framebuffer may have fewer draw buffer states than a user-created one. The
1939 // user is always allowed to query up to GL_MAX_DRAWBUFFERS so just return GL_NONE here if
1940 // the draw buffer is out of range for this framebuffer.
1941 *params = drawBuffer < framebuffer->getDrawbufferStateCount()
1942 ? framebuffer->getDrawBufferState(drawBuffer)
1943 : GL_NONE;
Jamie Madill7c985f52018-11-29 18:16:17 -05001944 return angle::Result::Continue;
Shannon Woods53a94a82014-06-24 15:20:36 -04001945 }
1946
1947 // Please note: DEPTH_CLEAR_VALUE is not included in our internal getIntegerv implementation
1948 // because it is stored as a float, despite the fact that the GL ES 2.0 spec names
1949 // GetIntegerv as its native query function. As it would require conversion in any
1950 // case, this should make no difference to the calling application. You may find it in
1951 // State::getFloatv.
1952 switch (pname)
1953 {
Corentin Wallez336129f2017-10-17 15:55:40 -04001954 case GL_ARRAY_BUFFER_BINDING:
1955 *params = mBoundBuffers[BufferBinding::Array].id();
1956 break;
1957 case GL_DRAW_INDIRECT_BUFFER_BINDING:
1958 *params = mBoundBuffers[BufferBinding::DrawIndirect].id();
1959 break;
1960 case GL_ELEMENT_ARRAY_BUFFER_BINDING:
Jamie Madillcd0a0a32018-10-18 18:41:57 -04001961 {
1962 Buffer *elementArrayBuffer = getVertexArray()->getElementArrayBuffer();
1963 *params = elementArrayBuffer ? elementArrayBuffer->id() : 0;
Corentin Wallez336129f2017-10-17 15:55:40 -04001964 break;
Jamie Madillcd0a0a32018-10-18 18:41:57 -04001965 }
Jamie Madill690c8eb2018-03-12 15:20:03 -04001966 case GL_DRAW_FRAMEBUFFER_BINDING:
1967 static_assert(GL_DRAW_FRAMEBUFFER_BINDING == GL_DRAW_FRAMEBUFFER_BINDING_ANGLE,
1968 "Enum mismatch");
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001969 *params = mDrawFramebuffer->id();
1970 break;
Jamie Madill690c8eb2018-03-12 15:20:03 -04001971 case GL_READ_FRAMEBUFFER_BINDING:
1972 static_assert(GL_READ_FRAMEBUFFER_BINDING == GL_READ_FRAMEBUFFER_BINDING_ANGLE,
1973 "Enum mismatch");
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001974 *params = mReadFramebuffer->id();
1975 break;
1976 case GL_RENDERBUFFER_BINDING:
1977 *params = mRenderbuffer.id();
1978 break;
1979 case GL_VERTEX_ARRAY_BINDING:
1980 *params = mVertexArray->id();
1981 break;
1982 case GL_CURRENT_PROGRAM:
1983 *params = mProgram ? mProgram->id() : 0;
1984 break;
1985 case GL_PACK_ALIGNMENT:
1986 *params = mPack.alignment;
1987 break;
1988 case GL_PACK_REVERSE_ROW_ORDER_ANGLE:
1989 *params = mPack.reverseRowOrder;
1990 break;
1991 case GL_PACK_ROW_LENGTH:
1992 *params = mPack.rowLength;
1993 break;
1994 case GL_PACK_SKIP_ROWS:
1995 *params = mPack.skipRows;
1996 break;
1997 case GL_PACK_SKIP_PIXELS:
1998 *params = mPack.skipPixels;
1999 break;
2000 case GL_UNPACK_ALIGNMENT:
2001 *params = mUnpack.alignment;
2002 break;
2003 case GL_UNPACK_ROW_LENGTH:
2004 *params = mUnpack.rowLength;
2005 break;
2006 case GL_UNPACK_IMAGE_HEIGHT:
2007 *params = mUnpack.imageHeight;
2008 break;
2009 case GL_UNPACK_SKIP_IMAGES:
2010 *params = mUnpack.skipImages;
2011 break;
2012 case GL_UNPACK_SKIP_ROWS:
2013 *params = mUnpack.skipRows;
2014 break;
2015 case GL_UNPACK_SKIP_PIXELS:
2016 *params = mUnpack.skipPixels;
2017 break;
2018 case GL_GENERATE_MIPMAP_HINT:
2019 *params = mGenerateMipmapHint;
2020 break;
2021 case GL_FRAGMENT_SHADER_DERIVATIVE_HINT_OES:
2022 *params = mFragmentShaderDerivativeHint;
2023 break;
2024 case GL_ACTIVE_TEXTURE:
2025 *params = (static_cast<GLint>(mActiveSampler) + GL_TEXTURE0);
2026 break;
2027 case GL_STENCIL_FUNC:
2028 *params = mDepthStencil.stencilFunc;
2029 break;
2030 case GL_STENCIL_REF:
2031 *params = mStencilRef;
2032 break;
2033 case GL_STENCIL_VALUE_MASK:
2034 *params = CastMaskValue(context, mDepthStencil.stencilMask);
2035 break;
2036 case GL_STENCIL_BACK_FUNC:
2037 *params = mDepthStencil.stencilBackFunc;
2038 break;
2039 case GL_STENCIL_BACK_REF:
2040 *params = mStencilBackRef;
2041 break;
2042 case GL_STENCIL_BACK_VALUE_MASK:
2043 *params = CastMaskValue(context, mDepthStencil.stencilBackMask);
2044 break;
2045 case GL_STENCIL_FAIL:
2046 *params = mDepthStencil.stencilFail;
2047 break;
2048 case GL_STENCIL_PASS_DEPTH_FAIL:
2049 *params = mDepthStencil.stencilPassDepthFail;
2050 break;
2051 case GL_STENCIL_PASS_DEPTH_PASS:
2052 *params = mDepthStencil.stencilPassDepthPass;
2053 break;
2054 case GL_STENCIL_BACK_FAIL:
2055 *params = mDepthStencil.stencilBackFail;
2056 break;
2057 case GL_STENCIL_BACK_PASS_DEPTH_FAIL:
2058 *params = mDepthStencil.stencilBackPassDepthFail;
2059 break;
2060 case GL_STENCIL_BACK_PASS_DEPTH_PASS:
2061 *params = mDepthStencil.stencilBackPassDepthPass;
2062 break;
2063 case GL_DEPTH_FUNC:
2064 *params = mDepthStencil.depthFunc;
2065 break;
2066 case GL_BLEND_SRC_RGB:
2067 *params = mBlend.sourceBlendRGB;
2068 break;
2069 case GL_BLEND_SRC_ALPHA:
2070 *params = mBlend.sourceBlendAlpha;
2071 break;
2072 case GL_BLEND_DST_RGB:
2073 *params = mBlend.destBlendRGB;
2074 break;
2075 case GL_BLEND_DST_ALPHA:
2076 *params = mBlend.destBlendAlpha;
2077 break;
2078 case GL_BLEND_EQUATION_RGB:
2079 *params = mBlend.blendEquationRGB;
2080 break;
2081 case GL_BLEND_EQUATION_ALPHA:
2082 *params = mBlend.blendEquationAlpha;
2083 break;
2084 case GL_STENCIL_WRITEMASK:
2085 *params = CastMaskValue(context, mDepthStencil.stencilWritemask);
2086 break;
2087 case GL_STENCIL_BACK_WRITEMASK:
2088 *params = CastMaskValue(context, mDepthStencil.stencilBackWritemask);
2089 break;
2090 case GL_STENCIL_CLEAR_VALUE:
2091 *params = mStencilClearValue;
2092 break;
2093 case GL_IMPLEMENTATION_COLOR_READ_TYPE:
Jamie Madill690c8eb2018-03-12 15:20:03 -04002094 ANGLE_TRY(mReadFramebuffer->getImplementationColorReadType(
2095 context, reinterpret_cast<GLenum *>(params)));
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002096 break;
2097 case GL_IMPLEMENTATION_COLOR_READ_FORMAT:
Jamie Madill690c8eb2018-03-12 15:20:03 -04002098 ANGLE_TRY(mReadFramebuffer->getImplementationColorReadFormat(
2099 context, reinterpret_cast<GLenum *>(params)));
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002100 break;
2101 case GL_SAMPLE_BUFFERS:
2102 case GL_SAMPLES:
Shannon Woods53a94a82014-06-24 15:20:36 -04002103 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002104 Framebuffer *framebuffer = mDrawFramebuffer;
Jamie Madill427064d2018-04-13 16:20:34 -04002105 if (framebuffer->isComplete(context))
Shannon Woods53a94a82014-06-24 15:20:36 -04002106 {
Jamie Madill427064d2018-04-13 16:20:34 -04002107 GLint samples = framebuffer->getSamples(context);
Shannon Woods53a94a82014-06-24 15:20:36 -04002108 switch (pname)
2109 {
Jamie Madilla0016b72017-07-14 14:30:46 -04002110 case GL_SAMPLE_BUFFERS:
Jamie Madille98b1b52018-03-08 09:47:23 -05002111 if (samples != 0)
Jamie Madilla0016b72017-07-14 14:30:46 -04002112 {
2113 *params = 1;
2114 }
2115 else
2116 {
2117 *params = 0;
2118 }
2119 break;
2120 case GL_SAMPLES:
Jamie Madille98b1b52018-03-08 09:47:23 -05002121 *params = samples;
Jamie Madilla0016b72017-07-14 14:30:46 -04002122 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002123 }
2124 }
2125 else
2126 {
2127 *params = 0;
2128 }
2129 }
2130 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002131 case GL_VIEWPORT:
2132 params[0] = mViewport.x;
2133 params[1] = mViewport.y;
2134 params[2] = mViewport.width;
2135 params[3] = mViewport.height;
2136 break;
2137 case GL_SCISSOR_BOX:
2138 params[0] = mScissor.x;
2139 params[1] = mScissor.y;
2140 params[2] = mScissor.width;
2141 params[3] = mScissor.height;
2142 break;
2143 case GL_CULL_FACE_MODE:
2144 *params = ToGLenum(mRasterizer.cullMode);
2145 break;
2146 case GL_FRONT_FACE:
2147 *params = mRasterizer.frontFace;
2148 break;
2149 case GL_RED_BITS:
2150 case GL_GREEN_BITS:
2151 case GL_BLUE_BITS:
2152 case GL_ALPHA_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002153 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002154 Framebuffer *framebuffer = getDrawFramebuffer();
2155 const FramebufferAttachment *colorbuffer = framebuffer->getFirstColorbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002156
2157 if (colorbuffer)
2158 {
2159 switch (pname)
2160 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002161 case GL_RED_BITS:
2162 *params = colorbuffer->getRedSize();
2163 break;
2164 case GL_GREEN_BITS:
2165 *params = colorbuffer->getGreenSize();
2166 break;
2167 case GL_BLUE_BITS:
2168 *params = colorbuffer->getBlueSize();
2169 break;
2170 case GL_ALPHA_BITS:
2171 *params = colorbuffer->getAlphaSize();
2172 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002173 }
2174 }
2175 else
2176 {
2177 *params = 0;
2178 }
2179 }
2180 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002181 case GL_DEPTH_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002182 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002183 const Framebuffer *framebuffer = getDrawFramebuffer();
2184 const FramebufferAttachment *depthbuffer = framebuffer->getDepthbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002185
2186 if (depthbuffer)
2187 {
2188 *params = depthbuffer->getDepthSize();
2189 }
2190 else
2191 {
2192 *params = 0;
2193 }
2194 }
2195 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002196 case GL_STENCIL_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002197 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002198 const Framebuffer *framebuffer = getDrawFramebuffer();
2199 const FramebufferAttachment *stencilbuffer = framebuffer->getStencilbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002200
2201 if (stencilbuffer)
2202 {
2203 *params = stencilbuffer->getStencilSize();
2204 }
2205 else
2206 {
2207 *params = 0;
2208 }
2209 }
2210 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002211 case GL_TEXTURE_BINDING_2D:
2212 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2213 *params =
2214 getSamplerTextureId(static_cast<unsigned int>(mActiveSampler), TextureType::_2D);
2215 break;
2216 case GL_TEXTURE_BINDING_RECTANGLE_ANGLE:
2217 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2218 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2219 TextureType::Rectangle);
2220 break;
2221 case GL_TEXTURE_BINDING_CUBE_MAP:
2222 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2223 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2224 TextureType::CubeMap);
2225 break;
2226 case GL_TEXTURE_BINDING_3D:
2227 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2228 *params =
2229 getSamplerTextureId(static_cast<unsigned int>(mActiveSampler), TextureType::_3D);
2230 break;
2231 case GL_TEXTURE_BINDING_2D_ARRAY:
2232 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2233 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2234 TextureType::_2DArray);
2235 break;
2236 case GL_TEXTURE_BINDING_2D_MULTISAMPLE:
2237 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2238 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2239 TextureType::_2DMultisample);
2240 break;
Olli Etuahodff32a02018-08-28 14:35:50 +03002241 case GL_TEXTURE_BINDING_2D_MULTISAMPLE_ARRAY:
2242 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2243 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2244 TextureType::_2DMultisampleArray);
2245 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002246 case GL_TEXTURE_BINDING_EXTERNAL_OES:
2247 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2248 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2249 TextureType::External);
2250 break;
2251 case GL_UNIFORM_BUFFER_BINDING:
2252 *params = mBoundBuffers[BufferBinding::Uniform].id();
2253 break;
2254 case GL_TRANSFORM_FEEDBACK_BINDING:
2255 *params = mTransformFeedback.id();
2256 break;
2257 case GL_TRANSFORM_FEEDBACK_BUFFER_BINDING:
2258 *params = mBoundBuffers[BufferBinding::TransformFeedback].id();
2259 break;
2260 case GL_COPY_READ_BUFFER_BINDING:
2261 *params = mBoundBuffers[BufferBinding::CopyRead].id();
2262 break;
2263 case GL_COPY_WRITE_BUFFER_BINDING:
2264 *params = mBoundBuffers[BufferBinding::CopyWrite].id();
2265 break;
2266 case GL_PIXEL_PACK_BUFFER_BINDING:
2267 *params = mBoundBuffers[BufferBinding::PixelPack].id();
2268 break;
2269 case GL_PIXEL_UNPACK_BUFFER_BINDING:
2270 *params = mBoundBuffers[BufferBinding::PixelUnpack].id();
2271 break;
2272 case GL_READ_BUFFER:
2273 *params = mReadFramebuffer->getReadBufferState();
2274 break;
2275 case GL_SAMPLER_BINDING:
2276 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2277 *params = getSamplerId(static_cast<GLuint>(mActiveSampler));
2278 break;
2279 case GL_DEBUG_LOGGED_MESSAGES:
2280 *params = static_cast<GLint>(mDebug.getMessageCount());
2281 break;
2282 case GL_DEBUG_NEXT_LOGGED_MESSAGE_LENGTH:
2283 *params = static_cast<GLint>(mDebug.getNextMessageLength());
2284 break;
2285 case GL_DEBUG_GROUP_STACK_DEPTH:
2286 *params = static_cast<GLint>(mDebug.getGroupStackDepth());
2287 break;
2288 case GL_MULTISAMPLE_EXT:
2289 *params = static_cast<GLint>(mMultiSampling);
2290 break;
2291 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
2292 *params = static_cast<GLint>(mSampleAlphaToOne);
2293 break;
2294 case GL_COVERAGE_MODULATION_CHROMIUM:
2295 *params = static_cast<GLint>(mCoverageModulation);
2296 break;
2297 case GL_ATOMIC_COUNTER_BUFFER_BINDING:
2298 *params = mBoundBuffers[BufferBinding::AtomicCounter].id();
2299 break;
2300 case GL_SHADER_STORAGE_BUFFER_BINDING:
2301 *params = mBoundBuffers[BufferBinding::ShaderStorage].id();
2302 break;
2303 case GL_DISPATCH_INDIRECT_BUFFER_BINDING:
2304 *params = mBoundBuffers[BufferBinding::DispatchIndirect].id();
2305 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -07002306 case GL_ALPHA_TEST_FUNC:
2307 *params = ToGLenum(mGLES1State.mAlphaTestFunc);
2308 break;
Lingfeng Yang96310cd2018-03-28 11:56:28 -07002309 case GL_CLIENT_ACTIVE_TEXTURE:
2310 *params = mGLES1State.mClientActiveTexture + GL_TEXTURE0;
2311 break;
Lingfeng Yangd2488ab2018-04-04 09:25:48 -07002312 case GL_MATRIX_MODE:
2313 *params = ToGLenum(mGLES1State.mMatrixMode);
2314 break;
Lingfeng Yanga0cfa872018-05-30 21:12:17 -07002315 case GL_SHADE_MODEL:
2316 *params = ToGLenum(mGLES1State.mShadeModel);
2317 break;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -07002318 case GL_MODELVIEW_STACK_DEPTH:
2319 case GL_PROJECTION_STACK_DEPTH:
2320 case GL_TEXTURE_STACK_DEPTH:
2321 *params = mGLES1State.getCurrentMatrixStackDepth(pname);
2322 break;
2323 case GL_LOGIC_OP_MODE:
2324 *params = ToGLenum(mGLES1State.mLogicOp);
2325 break;
2326 case GL_BLEND_SRC:
2327 *params = mBlend.sourceBlendRGB;
2328 break;
2329 case GL_BLEND_DST:
2330 *params = mBlend.destBlendRGB;
2331 break;
2332 case GL_PERSPECTIVE_CORRECTION_HINT:
2333 case GL_POINT_SMOOTH_HINT:
2334 case GL_LINE_SMOOTH_HINT:
2335 case GL_FOG_HINT:
2336 *params = mGLES1State.getHint(pname);
2337 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002338 default:
2339 UNREACHABLE();
2340 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002341 }
Jamie Madille98b1b52018-03-08 09:47:23 -05002342
Jamie Madill7c985f52018-11-29 18:16:17 -05002343 return angle::Result::Continue;
Shannon Woods53a94a82014-06-24 15:20:36 -04002344}
2345
Lingfeng Yangabb09f12018-04-16 10:43:53 -07002346void State::getPointerv(const Context *context, GLenum pname, void **params) const
Geoff Lang70d0f492015-12-10 17:45:46 -05002347{
2348 switch (pname)
2349 {
2350 case GL_DEBUG_CALLBACK_FUNCTION:
2351 *params = reinterpret_cast<void *>(mDebug.getCallback());
2352 break;
2353 case GL_DEBUG_CALLBACK_USER_PARAM:
2354 *params = const_cast<void *>(mDebug.getUserParam());
2355 break;
Lingfeng Yangabb09f12018-04-16 10:43:53 -07002356 case GL_VERTEX_ARRAY_POINTER:
2357 case GL_NORMAL_ARRAY_POINTER:
2358 case GL_COLOR_ARRAY_POINTER:
2359 case GL_TEXTURE_COORD_ARRAY_POINTER:
2360 case GL_POINT_SIZE_ARRAY_POINTER_OES:
2361 QueryVertexAttribPointerv(getVertexArray()->getVertexAttribute(
2362 context->vertexArrayIndex(ParamToVertexArrayType(pname))),
2363 GL_VERTEX_ATTRIB_ARRAY_POINTER, params);
2364 return;
Geoff Lang70d0f492015-12-10 17:45:46 -05002365 default:
2366 UNREACHABLE();
2367 break;
2368 }
2369}
2370
Martin Radev66fb8202016-07-28 11:45:20 +03002371void State::getIntegeri_v(GLenum target, GLuint index, GLint *data)
Shannon Woods53a94a82014-06-24 15:20:36 -04002372{
2373 switch (target)
2374 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002375 case GL_TRANSFORM_FEEDBACK_BUFFER_BINDING:
2376 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2377 *data = mTransformFeedback->getIndexedBuffer(index).id();
2378 break;
2379 case GL_UNIFORM_BUFFER_BINDING:
2380 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2381 *data = mUniformBuffers[index].id();
2382 break;
2383 case GL_ATOMIC_COUNTER_BUFFER_BINDING:
2384 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2385 *data = mAtomicCounterBuffers[index].id();
2386 break;
2387 case GL_SHADER_STORAGE_BUFFER_BINDING:
2388 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2389 *data = mShaderStorageBuffers[index].id();
2390 break;
2391 case GL_VERTEX_BINDING_BUFFER:
2392 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2393 *data = mVertexArray->getVertexBinding(index).getBuffer().id();
2394 break;
2395 case GL_VERTEX_BINDING_DIVISOR:
2396 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2397 *data = mVertexArray->getVertexBinding(index).getDivisor();
2398 break;
2399 case GL_VERTEX_BINDING_OFFSET:
2400 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2401 *data = static_cast<GLuint>(mVertexArray->getVertexBinding(index).getOffset());
2402 break;
2403 case GL_VERTEX_BINDING_STRIDE:
2404 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2405 *data = mVertexArray->getVertexBinding(index).getStride();
2406 break;
2407 case GL_SAMPLE_MASK_VALUE:
2408 ASSERT(static_cast<size_t>(index) < mSampleMaskValues.size());
2409 *data = mSampleMaskValues[index];
2410 break;
2411 case GL_IMAGE_BINDING_NAME:
2412 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2413 *data = mImageUnits[index].texture.id();
2414 break;
2415 case GL_IMAGE_BINDING_LEVEL:
2416 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2417 *data = mImageUnits[index].level;
2418 break;
2419 case GL_IMAGE_BINDING_LAYER:
2420 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2421 *data = mImageUnits[index].layer;
2422 break;
2423 case GL_IMAGE_BINDING_ACCESS:
2424 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2425 *data = mImageUnits[index].access;
2426 break;
2427 case GL_IMAGE_BINDING_FORMAT:
2428 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2429 *data = mImageUnits[index].format;
2430 break;
2431 default:
2432 UNREACHABLE();
2433 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002434 }
Shannon Woods53a94a82014-06-24 15:20:36 -04002435}
2436
Martin Radev66fb8202016-07-28 11:45:20 +03002437void State::getInteger64i_v(GLenum target, GLuint index, GLint64 *data)
Shannon Woods53a94a82014-06-24 15:20:36 -04002438{
2439 switch (target)
2440 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002441 case GL_TRANSFORM_FEEDBACK_BUFFER_START:
2442 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2443 *data = mTransformFeedback->getIndexedBuffer(index).getOffset();
2444 break;
2445 case GL_TRANSFORM_FEEDBACK_BUFFER_SIZE:
2446 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2447 *data = mTransformFeedback->getIndexedBuffer(index).getSize();
2448 break;
2449 case GL_UNIFORM_BUFFER_START:
2450 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2451 *data = mUniformBuffers[index].getOffset();
2452 break;
2453 case GL_UNIFORM_BUFFER_SIZE:
2454 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2455 *data = mUniformBuffers[index].getSize();
2456 break;
2457 case GL_ATOMIC_COUNTER_BUFFER_START:
2458 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2459 *data = mAtomicCounterBuffers[index].getOffset();
2460 break;
2461 case GL_ATOMIC_COUNTER_BUFFER_SIZE:
2462 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2463 *data = mAtomicCounterBuffers[index].getSize();
2464 break;
2465 case GL_SHADER_STORAGE_BUFFER_START:
2466 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2467 *data = mShaderStorageBuffers[index].getOffset();
2468 break;
2469 case GL_SHADER_STORAGE_BUFFER_SIZE:
2470 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2471 *data = mShaderStorageBuffers[index].getSize();
2472 break;
2473 default:
2474 UNREACHABLE();
2475 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002476 }
Martin Radev66fb8202016-07-28 11:45:20 +03002477}
Shannon Woods53a94a82014-06-24 15:20:36 -04002478
Martin Radev66fb8202016-07-28 11:45:20 +03002479void State::getBooleani_v(GLenum target, GLuint index, GLboolean *data)
2480{
Xinghua Cao9c8e1a32017-12-06 17:59:58 +08002481 switch (target)
2482 {
2483 case GL_IMAGE_BINDING_LAYERED:
2484 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2485 *data = mImageUnits[index].layered;
2486 break;
2487 default:
2488 UNREACHABLE();
2489 break;
2490 }
Shannon Woods53a94a82014-06-24 15:20:36 -04002491}
2492
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002493angle::Result State::syncReadFramebuffer(const Context *context)
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002494{
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002495 ASSERT(mReadFramebuffer);
2496 return mReadFramebuffer->syncState(context);
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002497}
2498
Jamie Madillef9fcd92018-11-28 14:03:59 -05002499angle::Result State::syncDrawFramebuffer(const Context *context)
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002500{
2501 ASSERT(mDrawFramebuffer);
2502 return mDrawFramebuffer->syncState(context);
2503}
2504
Jamie Madillef9fcd92018-11-28 14:03:59 -05002505angle::Result State::syncDrawAttachments(const Context *context)
2506{
2507 ASSERT(mDrawFramebuffer);
2508 ASSERT(!mDrawFramebuffer->hasAnyDirtyBit());
2509 ASSERT(mRobustResourceInit);
2510 return mDrawFramebuffer->ensureDrawAttachmentsInitialized(context);
2511}
2512
Jamie Madille3e680c2018-12-03 17:49:08 -05002513angle::Result State::syncTextures(const Context *context)
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002514{
Jamie Madille3e680c2018-12-03 17:49:08 -05002515 if (mDirtyTextures.none())
Jamie Madill7c985f52018-11-29 18:16:17 -05002516 return angle::Result::Continue;
Jamie Madille3e680c2018-12-03 17:49:08 -05002517
2518 for (size_t textureIndex : mDirtyTextures)
2519 {
2520 Texture *texture = mActiveTexturesCache[textureIndex];
2521 if (texture && texture->hasAnyDirtyBit())
2522 {
2523 ANGLE_TRY(texture->syncState(context));
2524 }
2525 }
2526
2527 mDirtyTextures.reset();
Jamie Madill7c985f52018-11-29 18:16:17 -05002528 return angle::Result::Continue;
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002529}
2530
Jamie Madille3e680c2018-12-03 17:49:08 -05002531angle::Result State::syncImages(const Context *context)
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002532{
Jamie Madille3e680c2018-12-03 17:49:08 -05002533 if (mDirtyImages.none())
Jamie Madill7c985f52018-11-29 18:16:17 -05002534 return angle::Result::Continue;
Jamie Madille3e680c2018-12-03 17:49:08 -05002535
2536 for (size_t imageUnitIndex : mDirtyImages)
2537 {
2538 Texture *texture = mImageUnits[imageUnitIndex].texture.get();
2539 if (texture && texture->hasAnyDirtyBit())
2540 {
2541 ANGLE_TRY(texture->syncState(context));
2542 }
2543 }
2544
Jamie Madill7c985f52018-11-29 18:16:17 -05002545 return angle::Result::Continue;
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002546}
2547
2548angle::Result State::syncSamplers(const Context *context)
Jamie Madille25b8002018-09-20 13:39:49 -04002549{
2550 if (mDirtySamplers.none())
Jamie Madill7c985f52018-11-29 18:16:17 -05002551 return angle::Result::Continue;
Jamie Madille25b8002018-09-20 13:39:49 -04002552
Jamie Madille25b8002018-09-20 13:39:49 -04002553 for (size_t samplerIndex : mDirtySamplers)
2554 {
2555 BindingPointer<Sampler> &sampler = mSamplers[samplerIndex];
2556 if (sampler.get())
2557 {
2558 sampler->syncState(context);
2559 }
2560 }
2561
2562 mDirtySamplers.reset();
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002563
Jamie Madill7c985f52018-11-29 18:16:17 -05002564 return angle::Result::Continue;
Jamie Madille25b8002018-09-20 13:39:49 -04002565}
2566
Jamie Madille3e680c2018-12-03 17:49:08 -05002567angle::Result State::syncVertexArray(const Context *context)
Jamie Madill81c2e252017-09-09 23:32:46 -04002568{
Jamie Madille3e680c2018-12-03 17:49:08 -05002569 ASSERT(mVertexArray);
2570 return mVertexArray->syncState(context);
2571}
Jamie Madill81c2e252017-09-09 23:32:46 -04002572
Jamie Madille3e680c2018-12-03 17:49:08 -05002573angle::Result State::syncProgram(const Context *context)
2574{
2575 return mProgram->syncState(context);
Jamie Madill81c2e252017-09-09 23:32:46 -04002576}
2577
Jamie Madill132d15c2018-11-30 15:25:38 -05002578angle::Result State::syncTexturesInit(const Context *context)
2579{
2580 ASSERT(mRobustResourceInit);
2581
2582 if (!mProgram)
Jamie Madill7c985f52018-11-29 18:16:17 -05002583 return angle::Result::Continue;
Jamie Madill132d15c2018-11-30 15:25:38 -05002584
2585 for (size_t textureUnitIndex : mProgram->getActiveSamplersMask())
2586 {
2587 Texture *texture = mActiveTexturesCache[textureUnitIndex];
2588 if (texture)
2589 {
2590 ANGLE_TRY(texture->ensureInitialized(context));
2591 }
2592 }
Jamie Madill7c985f52018-11-29 18:16:17 -05002593 return angle::Result::Continue;
Jamie Madill132d15c2018-11-30 15:25:38 -05002594}
2595
2596angle::Result State::syncImagesInit(const Context *context)
2597{
2598 ASSERT(mRobustResourceInit);
2599 ASSERT(mProgram);
2600 for (size_t imageUnitIndex : mProgram->getActiveImagesMask())
2601 {
2602 Texture *texture = mImageUnits[imageUnitIndex].texture.get();
2603 if (texture)
2604 {
2605 ANGLE_TRY(texture->ensureInitialized(context));
2606 }
2607 }
Jamie Madill7c985f52018-11-29 18:16:17 -05002608 return angle::Result::Continue;
Jamie Madill132d15c2018-11-30 15:25:38 -05002609}
2610
Jamie Madill6f755b22018-10-09 12:48:54 -04002611angle::Result State::syncDirtyObject(const Context *context, GLenum target)
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002612{
2613 DirtyObjects localSet;
2614
2615 switch (target)
2616 {
2617 case GL_READ_FRAMEBUFFER:
2618 localSet.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2619 break;
2620 case GL_DRAW_FRAMEBUFFER:
2621 localSet.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2622 break;
2623 case GL_FRAMEBUFFER:
2624 localSet.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2625 localSet.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2626 break;
2627 case GL_VERTEX_ARRAY:
2628 localSet.set(DIRTY_OBJECT_VERTEX_ARRAY);
2629 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002630 case GL_TEXTURE:
Jamie Madille3e680c2018-12-03 17:49:08 -05002631 localSet.set(DIRTY_OBJECT_TEXTURES);
Jamie Madille25b8002018-09-20 13:39:49 -04002632 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002633 case GL_SAMPLER:
Jamie Madille25b8002018-09-20 13:39:49 -04002634 localSet.set(DIRTY_OBJECT_SAMPLERS);
Jamie Madill70aeda42018-08-20 12:17:40 -04002635 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002636 case GL_PROGRAM:
Jamie Madill70aeda42018-08-20 12:17:40 -04002637 localSet.set(DIRTY_OBJECT_PROGRAM);
Jamie Madill81c2e252017-09-09 23:32:46 -04002638 break;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002639 }
2640
Jamie Madillbc918e72018-03-08 09:47:21 -05002641 return syncDirtyObjects(context, localSet);
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002642}
2643
2644void State::setObjectDirty(GLenum target)
2645{
2646 switch (target)
2647 {
2648 case GL_READ_FRAMEBUFFER:
2649 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2650 break;
2651 case GL_DRAW_FRAMEBUFFER:
Jamie Madillef9fcd92018-11-28 14:03:59 -05002652 setDrawFramebufferDirty();
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002653 break;
2654 case GL_FRAMEBUFFER:
2655 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
Jamie Madillef9fcd92018-11-28 14:03:59 -05002656 setDrawFramebufferDirty();
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002657 break;
2658 case GL_VERTEX_ARRAY:
2659 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
2660 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002661 case GL_PROGRAM:
Jamie Madill70aeda42018-08-20 12:17:40 -04002662 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM);
Jamie Madille3e680c2018-12-03 17:49:08 -05002663 break;
2664 default:
Jamie Madill81c2e252017-09-09 23:32:46 -04002665 break;
Jamie Madilla779b612017-07-24 11:46:05 -04002666 }
2667}
2668
Jamie Madill6f755b22018-10-09 12:48:54 -04002669angle::Result State::onProgramExecutableChange(const Context *context, Program *program)
Jamie Madilla779b612017-07-24 11:46:05 -04002670{
2671 // OpenGL Spec:
2672 // "If LinkProgram or ProgramBinary successfully re-links a program object
2673 // that was already in use as a result of a previous call to UseProgram, then the
2674 // generated executable code will be installed as part of the current rendering state."
Jamie Madilldf836ff2018-10-01 10:36:24 -04002675 ASSERT(program->isLinked());
2676
2677 mDirtyBits.set(DIRTY_BIT_PROGRAM_EXECUTABLE);
Jamie Madill956ab4d2018-10-10 16:13:03 -04002678
2679 if (program->hasAnyDirtyBit())
2680 {
2681 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM);
2682 }
Jamie Madille3bb6b72018-10-03 17:51:15 -04002683
2684 // Set any bound textures.
2685 const ActiveTextureTypeArray &textureTypes = program->getActiveSamplerTypes();
2686 for (size_t textureIndex : program->getActiveSamplersMask())
2687 {
2688 TextureType type = textureTypes[textureIndex];
2689
2690 // This can happen if there is a conflicting texture type.
2691 if (type == TextureType::InvalidEnum)
2692 continue;
2693
2694 Texture *texture = mSamplerTextures[type][textureIndex].get();
Jamie Madille3e680c2018-12-03 17:49:08 -05002695 updateActiveTexture(context, textureIndex, texture);
Jamie Madille3bb6b72018-10-03 17:51:15 -04002696 }
2697
2698 for (size_t imageUnitIndex : program->getActiveImagesMask())
2699 {
2700 Texture *image = mImageUnits[imageUnitIndex].texture.get();
2701 if (!image)
2702 continue;
2703
2704 if (image->hasAnyDirtyBit())
2705 {
2706 ANGLE_TRY(image->syncState(context));
2707 }
2708
Jamie Madill132d15c2018-11-30 15:25:38 -05002709 if (mRobustResourceInit && image->initState() == InitState::MayNeedInit)
Jamie Madille3bb6b72018-10-03 17:51:15 -04002710 {
Jamie Madill132d15c2018-11-30 15:25:38 -05002711 mDirtyObjects.set(DIRTY_OBJECT_IMAGES_INIT);
Jamie Madille3bb6b72018-10-03 17:51:15 -04002712 }
2713 }
2714
Jamie Madill7c985f52018-11-29 18:16:17 -05002715 return angle::Result::Continue;
Shannon Woods53a94a82014-06-24 15:20:36 -04002716}
Jamie Madillc9d442d2016-01-20 11:17:24 -05002717
Jamie Madille3e680c2018-12-03 17:49:08 -05002718void State::setTextureDirty(size_t textureUnitIndex)
2719{
2720 mDirtyObjects.set(DIRTY_OBJECT_TEXTURES);
2721 mDirtyTextures.set(textureUnitIndex);
2722}
2723
Jamie Madille25b8002018-09-20 13:39:49 -04002724void State::setSamplerDirty(size_t samplerIndex)
2725{
2726 mDirtyObjects.set(DIRTY_OBJECT_SAMPLERS);
2727 mDirtySamplers.set(samplerIndex);
2728}
2729
Xinghua Cao65ec0b22017-03-28 16:10:52 +08002730void State::setImageUnit(const Context *context,
Will Harris63aa0e52018-09-05 16:15:46 -07002731 size_t unit,
Xinghua Cao65ec0b22017-03-28 16:10:52 +08002732 Texture *texture,
2733 GLint level,
2734 GLboolean layered,
2735 GLint layer,
2736 GLenum access,
2737 GLenum format)
2738{
2739 mImageUnits[unit].texture.set(context, texture);
2740 mImageUnits[unit].level = level;
2741 mImageUnits[unit].layered = layered;
2742 mImageUnits[unit].layer = layer;
2743 mImageUnits[unit].access = access;
2744 mImageUnits[unit].format = format;
jchen1099118c12018-09-10 16:28:51 +08002745 mDirtyBits.set(DIRTY_BIT_IMAGE_BINDINGS);
Jamie Madille3e680c2018-12-03 17:49:08 -05002746
2747 onImageStateChange(context, unit);
Xinghua Cao65ec0b22017-03-28 16:10:52 +08002748}
2749
Jamie Madill81c2e252017-09-09 23:32:46 -04002750// Handle a dirty texture event.
Jamie Madille3e680c2018-12-03 17:49:08 -05002751void State::onActiveTextureChange(const Context *context, size_t textureUnit)
Jamie Madill81c2e252017-09-09 23:32:46 -04002752{
Jamie Madille3e680c2018-12-03 17:49:08 -05002753 if (mProgram)
Geoff Lange51ba632017-11-21 11:45:25 -05002754 {
Jamie Madille3e680c2018-12-03 17:49:08 -05002755 TextureType type = mProgram->getActiveSamplerTypes()[textureUnit];
2756 if (type != TextureType::InvalidEnum)
2757 {
2758 Texture *activeTexture = mSamplerTextures[type][textureUnit].get();
2759 updateActiveTexture(context, textureUnit, activeTexture);
2760 }
2761 }
2762}
2763
2764void State::onActiveTextureStateChange(const Context *context, size_t textureUnit)
2765{
2766 if (mProgram)
2767 {
2768 TextureType type = mProgram->getActiveSamplerTypes()[textureUnit];
2769 if (type != TextureType::InvalidEnum)
2770 {
2771 Texture *activeTexture = mSamplerTextures[type][textureUnit].get();
2772 const Sampler *sampler = mSamplers[textureUnit].get();
2773 updateActiveTextureState(context, textureUnit, sampler, activeTexture);
2774 }
2775 }
2776}
2777
2778void State::onImageStateChange(const Context *context, size_t unit)
2779{
2780 if (mProgram)
2781 {
2782 const ImageUnit &image = mImageUnits[unit];
2783 ASSERT(image.texture.get());
2784 if (image.texture->hasAnyDirtyBit())
2785 {
2786 mDirtyImages.set(unit);
2787 }
2788
Jamie Madill132d15c2018-11-30 15:25:38 -05002789 if (mRobustResourceInit && image.texture->initState() == InitState::MayNeedInit)
Jamie Madille3e680c2018-12-03 17:49:08 -05002790 {
Jamie Madill132d15c2018-11-30 15:25:38 -05002791 mDirtyObjects.set(DIRTY_OBJECT_IMAGES_INIT);
Jamie Madille3e680c2018-12-03 17:49:08 -05002792 }
Geoff Lange51ba632017-11-21 11:45:25 -05002793 }
Jamie Madill81c2e252017-09-09 23:32:46 -04002794}
2795
Jamie Madill6d32cef2018-08-14 02:34:28 -04002796void State::onUniformBufferStateChange(size_t uniformBufferIndex)
2797{
2798 // This could be represented by a different dirty bit. Using the same one keeps it simple.
2799 mDirtyBits.set(DIRTY_BIT_UNIFORM_BUFFER_BINDINGS);
2800}
2801
Jamie Madillc67323a2017-11-02 23:11:41 -04002802AttributesMask State::getAndResetDirtyCurrentValues() const
2803{
2804 AttributesMask retVal = mDirtyCurrentValues;
2805 mDirtyCurrentValues.reset();
2806 return retVal;
2807}
2808
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002809constexpr State::DirtyObjectHandler State::kDirtyObjectHandlers[DIRTY_OBJECT_MAX];
2810
Jamie Madillc9d442d2016-01-20 11:17:24 -05002811} // namespace gl