blob: efeb8bf6f9853ee04336aab92630990563d0795d [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 = {{
53 0, /* Array */
54 State::DIRTY_BIT_ATOMIC_COUNTER_BUFFER_BINDING, /* AtomicCounter */
55 0, /* CopyRead */
56 0, /* CopyWrite */
57 State::DIRTY_BIT_DISPATCH_INDIRECT_BUFFER_BINDING, /* DispatchIndirect */
58 State::DIRTY_BIT_DRAW_INDIRECT_BUFFER_BINDING, /* DrawIndirect */
59 0, /* ElementArray */
60 State::DIRTY_BIT_PACK_BUFFER_BINDING, /* PixelPack */
61 State::DIRTY_BIT_UNPACK_BUFFER_BINDING, /* PixelUnpack */
62 State::DIRTY_BIT_SHADER_STORAGE_BUFFER_BINDING, /* ShaderStorage */
63 0, /* TransformFeedback */
64 State::DIRTY_BIT_UNIFORM_BUFFER_BINDINGS, /* Uniform */
65}};
66
67// Returns a buffer binding function depending on if a dirty bit is set.
68template <BufferBinding Target>
69constexpr State::BufferBindingSetter GetBufferBindingSetter()
70{
71 return kBufferBindingDirtyBits[Target] != 0 ? &State::setGenericBufferBindingWithBit<Target>
72 : &State::setGenericBufferBinding<Target>;
73}
Jamie Madillb980c562018-11-27 11:34:27 -050074} // namespace
Olli Etuahobbf1c102016-06-28 13:31:33 +030075
Jamie Madillbf5177d2018-08-21 12:58:20 -040076template <typename BindingT, typename... ArgsT>
Jamie Madillca8eda42018-10-18 18:41:56 -040077ANGLE_INLINE void UpdateNonTFBufferBinding(const Context *context,
78 BindingT *binding,
79 Buffer *buffer,
80 ArgsT... args)
James Darpiniane8a93c62018-01-04 18:02:24 -080081{
Jamie Madillca8eda42018-10-18 18:41:56 -040082 Buffer *oldBuffer = binding->get();
83 if (oldBuffer)
84 {
85 oldBuffer->onNonTFBindingChanged(-1);
86 oldBuffer->release(context);
87 }
88 binding->assign(buffer, args...);
89 if (buffer)
90 {
91 buffer->addRef();
92 buffer->onNonTFBindingChanged(1);
93 }
Jamie Madillbf5177d2018-08-21 12:58:20 -040094}
95
96template <typename BindingT, typename... ArgsT>
97void UpdateTFBufferBinding(const Context *context, BindingT *binding, bool indexed, ArgsT... args)
98{
99 if (binding->get())
100 (*binding)->onTFBindingChanged(context, false, indexed);
101 binding->set(context, args...);
102 if (binding->get())
103 (*binding)->onTFBindingChanged(context, true, indexed);
James Darpiniane8a93c62018-01-04 18:02:24 -0800104}
105
106void UpdateBufferBinding(const Context *context,
Jamie Madillbf5177d2018-08-21 12:58:20 -0400107 BindingPointer<Buffer> *binding,
James Darpiniane8a93c62018-01-04 18:02:24 -0800108 Buffer *buffer,
Jamie Madillbf5177d2018-08-21 12:58:20 -0400109 BufferBinding target)
James Darpiniane8a93c62018-01-04 18:02:24 -0800110{
Jamie Madillbf5177d2018-08-21 12:58:20 -0400111 if (target == BufferBinding::TransformFeedback)
112 {
113 UpdateTFBufferBinding(context, binding, false, buffer);
114 }
115 else
116 {
117 UpdateNonTFBufferBinding(context, binding, buffer);
118 }
119}
120
121void UpdateIndexedBufferBinding(const Context *context,
122 OffsetBindingPointer<Buffer> *binding,
123 Buffer *buffer,
124 BufferBinding target,
125 GLintptr offset,
126 GLsizeiptr size)
127{
128 if (target == BufferBinding::TransformFeedback)
129 {
130 UpdateTFBufferBinding(context, binding, true, buffer, offset, size);
131 }
132 else
133 {
134 UpdateNonTFBufferBinding(context, binding, buffer, offset, size);
135 }
James Darpiniane8a93c62018-01-04 18:02:24 -0800136}
137
Jamie Madillca8eda42018-10-18 18:41:56 -0400138// These template functions must be defined before they are instantiated in kBufferSetters.
139template <BufferBinding Target>
140void State::setGenericBufferBindingWithBit(const Context *context, Buffer *buffer)
141{
142 UpdateNonTFBufferBinding(context, &mBoundBuffers[Target], buffer);
143 mDirtyBits.set(kBufferBindingDirtyBits[Target]);
144}
145
146template <BufferBinding Target>
147void State::setGenericBufferBinding(const Context *context, Buffer *buffer)
148{
149 UpdateNonTFBufferBinding(context, &mBoundBuffers[Target], buffer);
150}
151
152template <>
153void State::setGenericBufferBinding<BufferBinding::TransformFeedback>(const Context *context,
154 Buffer *buffer)
155{
156 UpdateTFBufferBinding(context, &mBoundBuffers[BufferBinding::TransformFeedback], false, buffer);
157}
158
159template <>
160void State::setGenericBufferBinding<BufferBinding::ElementArray>(const Context *context,
161 Buffer *buffer)
162{
163 Buffer *oldBuffer = mVertexArray->mState.mElementArrayBuffer.get();
164 if (oldBuffer)
165 {
Jamie Madillcd0a0a32018-10-18 18:41:57 -0400166 oldBuffer->removeObserver(&mVertexArray->mState.mElementArrayBuffer);
Jamie Madillca8eda42018-10-18 18:41:56 -0400167 oldBuffer->onNonTFBindingChanged(-1);
168 oldBuffer->release(context);
169 }
170 mVertexArray->mState.mElementArrayBuffer.assign(buffer);
171 if (buffer)
172 {
Jamie Madillcd0a0a32018-10-18 18:41:57 -0400173 buffer->addObserver(&mVertexArray->mState.mElementArrayBuffer);
Jamie Madillca8eda42018-10-18 18:41:56 -0400174 buffer->onNonTFBindingChanged(1);
175 buffer->addRef();
176 }
Jamie Madillca8eda42018-10-18 18:41:56 -0400177 mVertexArray->mDirtyBits.set(VertexArray::DIRTY_BIT_ELEMENT_ARRAY_BUFFER);
Jamie Madillc1fd7372018-10-26 22:48:39 -0400178 mVertexArray->mIndexRangeCache.invalidate();
Jamie Madillca8eda42018-10-18 18:41:56 -0400179 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
180}
181
182const angle::PackedEnumMap<BufferBinding, State::BufferBindingSetter> State::kBufferSetters = {{
183 GetBufferBindingSetter<BufferBinding::Array>(),
184 GetBufferBindingSetter<BufferBinding::AtomicCounter>(),
185 GetBufferBindingSetter<BufferBinding::CopyRead>(),
186 GetBufferBindingSetter<BufferBinding::CopyWrite>(),
187 GetBufferBindingSetter<BufferBinding::DispatchIndirect>(),
188 GetBufferBindingSetter<BufferBinding::DrawIndirect>(),
189 GetBufferBindingSetter<BufferBinding::ElementArray>(),
190 GetBufferBindingSetter<BufferBinding::PixelPack>(),
191 GetBufferBindingSetter<BufferBinding::PixelUnpack>(),
192 GetBufferBindingSetter<BufferBinding::ShaderStorage>(),
193 GetBufferBindingSetter<BufferBinding::TransformFeedback>(),
194 GetBufferBindingSetter<BufferBinding::Uniform>(),
195}};
196
Geoff Lang4fb8a8b2018-06-01 16:47:57 -0400197State::State(bool debug,
198 bool bindGeneratesResource,
199 bool clientArraysEnabled,
200 bool robustResourceInit,
201 bool programBinaryCacheEnabled)
Jamie Madille79b1e12015-11-04 16:36:37 -0500202 : mMaxDrawBuffers(0),
203 mMaxCombinedTextureImageUnits(0),
204 mDepthClearValue(0),
205 mStencilClearValue(0),
206 mScissorTest(false),
207 mSampleCoverage(false),
208 mSampleCoverageValue(0),
209 mSampleCoverageInvert(false),
Jiawei Shaodb342272017-09-27 10:21:45 +0800210 mSampleMask(false),
211 mMaxSampleMaskWords(0),
Jamie Madille79b1e12015-11-04 16:36:37 -0500212 mStencilRef(0),
213 mStencilBackRef(0),
214 mLineWidth(0),
215 mGenerateMipmapHint(GL_NONE),
216 mFragmentShaderDerivativeHint(GL_NONE),
Geoff Lang4fb8a8b2018-06-01 16:47:57 -0400217 mBindGeneratesResource(bindGeneratesResource),
218 mClientArraysEnabled(clientArraysEnabled),
Jamie Madille79b1e12015-11-04 16:36:37 -0500219 mNearZ(0),
220 mFarZ(0),
221 mReadFramebuffer(nullptr),
222 mDrawFramebuffer(nullptr),
223 mProgram(nullptr),
224 mVertexArray(nullptr),
225 mActiveSampler(0),
Jamie Madill4787d702018-08-08 15:49:26 -0400226 mActiveTexturesCache{},
227 mCachedTexturesInitState(InitState::MayNeedInit),
Qin Jiajia47f6dd02018-08-10 13:36:32 +0800228 mCachedImageTexturesInitState(InitState::MayNeedInit),
Sami Väisänen74c23472016-05-09 17:30:30 +0300229 mPrimitiveRestart(false),
Geoff Lang4fb8a8b2018-06-01 16:47:57 -0400230 mDebug(debug),
Sami Väisänen74c23472016-05-09 17:30:30 +0300231 mMultiSampling(false),
Geoff Lang1d2c41d2016-10-19 16:14:46 -0700232 mSampleAlphaToOne(false),
Jamie Madille08a1d32017-03-07 17:24:06 -0500233 mFramebufferSRGB(true),
Geoff Lang4fb8a8b2018-06-01 16:47:57 -0400234 mRobustResourceInit(robustResourceInit),
jchen1082af6202018-06-22 10:59:52 +0800235 mProgramBinaryCacheEnabled(programBinaryCacheEnabled),
236 mMaxShaderCompilerThreads(std::numeric_limits<GLuint>::max())
Jamie Madillb980c562018-11-27 11:34:27 -0500237{}
Geoff Lang76b10c92014-09-05 16:28:14 -0400238
Jamie Madillb980c562018-11-27 11:34:27 -0500239State::~State() {}
Geoff Lang76b10c92014-09-05 16:28:14 -0400240
Jamie Madill6c43a012018-08-08 15:49:27 -0400241void State::initialize(Context *context)
Geoff Lang76b10c92014-09-05 16:28:14 -0400242{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700243 const Caps &caps = context->getCaps();
244 const Extensions &extensions = context->getExtensions();
Geoff Lang4751aab2017-10-30 15:14:52 -0400245 const Extensions &nativeExtensions = context->getImplementation()->getNativeExtensions();
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700246 const Version &clientVersion = context->getClientVersion();
Jamie Madill4928b7c2017-06-20 12:57:39 -0400247
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700248 mMaxDrawBuffers = caps.maxDrawBuffers;
Shannon Woods2df6a602014-09-26 16:12:07 -0400249 mMaxCombinedTextureImageUnits = caps.maxCombinedTextureImageUnits;
Shannon Woods53a94a82014-06-24 15:20:36 -0400250
Jamie Madillf75ab352015-03-16 10:46:52 -0400251 setColorClearValue(0.0f, 0.0f, 0.0f, 0.0f);
Shannon Woods53a94a82014-06-24 15:20:36 -0400252
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700253 mDepthClearValue = 1.0f;
Shannon Woods53a94a82014-06-24 15:20:36 -0400254 mStencilClearValue = 0;
255
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700256 mScissorTest = false;
257 mScissor.x = 0;
258 mScissor.y = 0;
259 mScissor.width = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400260 mScissor.height = 0;
261
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700262 mBlendColor.red = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400263 mBlendColor.green = 0;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700264 mBlendColor.blue = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400265 mBlendColor.alpha = 0;
266
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700267 mStencilRef = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400268 mStencilBackRef = 0;
269
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700270 mSampleCoverage = false;
271 mSampleCoverageValue = 1.0f;
Shannon Woods53a94a82014-06-24 15:20:36 -0400272 mSampleCoverageInvert = false;
Jiawei Shaodb342272017-09-27 10:21:45 +0800273
274 mMaxSampleMaskWords = caps.maxSampleMaskWords;
275 mSampleMask = false;
276 mSampleMaskValues.fill(~GLbitfield(0));
277
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700278 mGenerateMipmapHint = GL_DONT_CARE;
Shannon Woods53a94a82014-06-24 15:20:36 -0400279 mFragmentShaderDerivativeHint = GL_DONT_CARE;
280
281 mLineWidth = 1.0f;
282
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700283 mViewport.x = 0;
284 mViewport.y = 0;
285 mViewport.width = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400286 mViewport.height = 0;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700287 mNearZ = 0.0f;
288 mFarZ = 1.0f;
Shannon Woods53a94a82014-06-24 15:20:36 -0400289
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700290 mBlend.colorMaskRed = true;
Shannon Woods53a94a82014-06-24 15:20:36 -0400291 mBlend.colorMaskGreen = true;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700292 mBlend.colorMaskBlue = true;
Shannon Woods53a94a82014-06-24 15:20:36 -0400293 mBlend.colorMaskAlpha = true;
294
Geoff Lang76b10c92014-09-05 16:28:14 -0400295 mActiveSampler = 0;
296
Shannon Woods23e05002014-09-22 19:07:27 -0400297 mVertexAttribCurrentValues.resize(caps.maxVertexAttributes);
Shannon Woods53a94a82014-06-24 15:20:36 -0400298
Brandon Jonesc405ae72017-12-06 14:15:03 -0800299 // Set all indexes in state attributes type mask to float (default)
300 for (int i = 0; i < MAX_VERTEX_ATTRIBS; i++)
301 {
302 mCurrentValuesTypeMask.setIndex(GL_FLOAT, i);
303 }
304
Geoff Lang4dc3af02016-11-18 14:09:27 -0500305 mUniformBuffers.resize(caps.maxUniformBufferBindings);
Shannon Woodsf3acaf92014-09-23 18:07:11 -0400306
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800307 mSamplerTextures[TextureType::_2D].resize(caps.maxCombinedTextureImageUnits);
308 mSamplerTextures[TextureType::CubeMap].resize(caps.maxCombinedTextureImageUnits);
Geoff Langeb66a6e2016-10-31 13:06:12 -0400309 if (clientVersion >= Version(3, 0))
Shannon Woods53a94a82014-06-24 15:20:36 -0400310 {
Geoff Lang76b10c92014-09-05 16:28:14 -0400311 // TODO: These could also be enabled via extension
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800312 mSamplerTextures[TextureType::_2DArray].resize(caps.maxCombinedTextureImageUnits);
313 mSamplerTextures[TextureType::_3D].resize(caps.maxCombinedTextureImageUnits);
Shannon Woods53a94a82014-06-24 15:20:36 -0400314 }
Yizhou Jiang7818a852018-09-06 15:02:04 +0800315 if (clientVersion >= Version(3, 1) || nativeExtensions.textureMultisample)
316 {
317 mSamplerTextures[TextureType::_2DMultisample].resize(caps.maxCombinedTextureImageUnits);
318 }
Geoff Lang3b573612016-10-31 14:08:10 -0400319 if (clientVersion >= Version(3, 1))
320 {
Olli Etuahod310a432018-08-24 15:40:23 +0300321 mSamplerTextures[TextureType::_2DMultisampleArray].resize(
322 caps.maxCombinedTextureImageUnits);
Jiajia Qin6eafb042016-12-27 17:04:07 +0800323
324 mAtomicCounterBuffers.resize(caps.maxAtomicCounterBufferBindings);
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800325 mShaderStorageBuffers.resize(caps.maxShaderStorageBufferBindings);
Xinghua Cao65ec0b22017-03-28 16:10:52 +0800326 mImageUnits.resize(caps.maxImageUnits);
Geoff Lang3b573612016-10-31 14:08:10 -0400327 }
Geoff Lang4751aab2017-10-30 15:14:52 -0400328 if (nativeExtensions.textureRectangle)
Corentin Wallez13c0dd42017-07-04 18:27:01 -0400329 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800330 mSamplerTextures[TextureType::Rectangle].resize(caps.maxCombinedTextureImageUnits);
Corentin Wallez13c0dd42017-07-04 18:27:01 -0400331 }
Geoff Lang4751aab2017-10-30 15:14:52 -0400332 if (nativeExtensions.eglImageExternal || nativeExtensions.eglStreamConsumerExternal)
Ian Ewellbda75592016-04-18 17:25:54 -0400333 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800334 mSamplerTextures[TextureType::External].resize(caps.maxCombinedTextureImageUnits);
Ian Ewellbda75592016-04-18 17:25:54 -0400335 }
Jamie Madill81c2e252017-09-09 23:32:46 -0400336 mCompleteTextureBindings.reserve(caps.maxCombinedTextureImageUnits);
Yizhou Jiang7818a852018-09-06 15:02:04 +0800337 mCachedTexturesInitState = InitState::MayNeedInit;
Qin Jiajia47f6dd02018-08-10 13:36:32 +0800338 mCachedImageTexturesInitState = InitState::MayNeedInit;
Jamie Madill81c2e252017-09-09 23:32:46 -0400339 for (uint32_t textureIndex = 0; textureIndex < caps.maxCombinedTextureImageUnits;
340 ++textureIndex)
341 {
Jamie Madill6c43a012018-08-08 15:49:27 -0400342 mCompleteTextureBindings.emplace_back(context, textureIndex);
Jamie Madill81c2e252017-09-09 23:32:46 -0400343 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400344
Geoff Lang76b10c92014-09-05 16:28:14 -0400345 mSamplers.resize(caps.maxCombinedTextureImageUnits);
Shannon Woods53a94a82014-06-24 15:20:36 -0400346
Corentin Wallezad3ae902018-03-09 13:40:42 -0500347 for (QueryType type : angle::AllEnums<QueryType>())
348 {
349 mActiveQueries[type].set(context, nullptr);
350 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400351
Ian Ewell3ffd78b2016-01-22 16:09:42 -0500352 mProgram = nullptr;
Shannon Woods53a94a82014-06-24 15:20:36 -0400353
Ian Ewell3ffd78b2016-01-22 16:09:42 -0500354 mReadFramebuffer = nullptr;
355 mDrawFramebuffer = nullptr;
Jamie Madillb4b53c52015-02-03 15:22:48 -0500356
357 mPrimitiveRestart = false;
Geoff Lang70d0f492015-12-10 17:45:46 -0500358
Geoff Lang70d0f492015-12-10 17:45:46 -0500359 mDebug.setMaxLoggedMessages(extensions.maxDebugLoggedMessages);
Sami Väisänen74c23472016-05-09 17:30:30 +0300360
Geoff Lang488130e2017-09-27 13:53:11 -0400361 mMultiSampling = true;
362 mSampleAlphaToOne = false;
Sami Väisänena797e062016-05-12 15:23:40 +0300363
364 mCoverageModulation = GL_NONE;
Sami Väisänene45e53b2016-05-25 10:36:04 +0300365
366 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixProj);
367 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixMV);
368 mPathStencilFunc = GL_ALWAYS;
369 mPathStencilRef = 0;
370 mPathStencilMask = std::numeric_limits<GLuint>::max();
Jamie Madille08a1d32017-03-07 17:24:06 -0500371
Lingfeng Yangdbb9c532018-02-25 19:58:24 -0800372 // GLES1 emulation: Initialize state for GLES1 if version
373 // applies
374 if (clientVersion < Version(2, 0))
375 {
Lingfeng Yange547aac2018-04-05 09:39:20 -0700376 mGLES1State.initialize(context, this);
Lingfeng Yangdbb9c532018-02-25 19:58:24 -0800377 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400378}
379
Jamie Madill6c1f6712017-02-14 19:08:04 -0500380void State::reset(const Context *context)
Shannon Woods53a94a82014-06-24 15:20:36 -0400381{
Jamie Madill8693bdb2017-09-02 15:32:14 -0400382 for (auto &bindingVec : mSamplerTextures)
Shannon Woods53a94a82014-06-24 15:20:36 -0400383 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800384 for (size_t textureIdx = 0; textureIdx < bindingVec.size(); textureIdx++)
Shannon Woods53a94a82014-06-24 15:20:36 -0400385 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800386 bindingVec[textureIdx].set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400387 }
388 }
Geoff Lang76b10c92014-09-05 16:28:14 -0400389 for (size_t samplerIdx = 0; samplerIdx < mSamplers.size(); samplerIdx++)
390 {
Jamie Madill4928b7c2017-06-20 12:57:39 -0400391 mSamplers[samplerIdx].set(context, nullptr);
Geoff Lang76b10c92014-09-05 16:28:14 -0400392 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400393
Xinghua Cao65ec0b22017-03-28 16:10:52 +0800394 for (auto &imageUnit : mImageUnits)
395 {
396 imageUnit.texture.set(context, nullptr);
397 imageUnit.level = 0;
398 imageUnit.layered = false;
399 imageUnit.layer = 0;
400 imageUnit.access = GL_READ_ONLY;
401 imageUnit.format = GL_R32UI;
402 }
403
Jamie Madill4928b7c2017-06-20 12:57:39 -0400404 mRenderbuffer.set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400405
Corentin Wallez336129f2017-10-17 15:55:40 -0400406 for (auto type : angle::AllEnums<BufferBinding>())
407 {
Jamie Madillbf5177d2018-08-21 12:58:20 -0400408 UpdateBufferBinding(context, &mBoundBuffers[type], nullptr, type);
Corentin Wallez336129f2017-10-17 15:55:40 -0400409 }
410
Geoff Lang7dd2e102014-11-10 15:19:26 -0500411 if (mProgram)
412 {
Jamie Madill6c1f6712017-02-14 19:08:04 -0500413 mProgram->release(context);
Geoff Lang7dd2e102014-11-10 15:19:26 -0500414 }
Yunchao Hed7297bf2017-04-19 15:27:10 +0800415 mProgram = nullptr;
Geoff Lang7dd2e102014-11-10 15:19:26 -0500416
Yunchao Hea336b902017-08-02 16:05:21 +0800417 mProgramPipeline.set(context, nullptr);
418
James Darpiniane8a93c62018-01-04 18:02:24 -0800419 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -0400420 mTransformFeedback->onBindingChanged(context, false);
Jamie Madill4928b7c2017-06-20 12:57:39 -0400421 mTransformFeedback.set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400422
Corentin Wallezad3ae902018-03-09 13:40:42 -0500423 for (QueryType type : angle::AllEnums<QueryType>())
Shannon Woods53a94a82014-06-24 15:20:36 -0400424 {
Corentin Wallezad3ae902018-03-09 13:40:42 -0500425 mActiveQueries[type].set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400426 }
427
Corentin Wallez336129f2017-10-17 15:55:40 -0400428 for (auto &buf : mUniformBuffers)
Shannon Woods53a94a82014-06-24 15:20:36 -0400429 {
Jamie Madillbf5177d2018-08-21 12:58:20 -0400430 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::Uniform, 0, 0);
Shannon Woods53a94a82014-06-24 15:20:36 -0400431 }
432
Jiajia Qin6eafb042016-12-27 17:04:07 +0800433 for (auto &buf : mAtomicCounterBuffers)
434 {
Jamie Madillbf5177d2018-08-21 12:58:20 -0400435 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::AtomicCounter, 0, 0);
Jiajia Qin6eafb042016-12-27 17:04:07 +0800436 }
437
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800438 for (auto &buf : mShaderStorageBuffers)
439 {
Jamie Madillbf5177d2018-08-21 12:58:20 -0400440 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::ShaderStorage, 0, 0);
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800441 }
442
Sami Väisänene45e53b2016-05-25 10:36:04 +0300443 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixProj);
444 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixMV);
445 mPathStencilFunc = GL_ALWAYS;
446 mPathStencilRef = 0;
447 mPathStencilMask = std::numeric_limits<GLuint>::max();
448
Jamie Madill1b94d432015-08-07 13:23:23 -0400449 setAllDirtyBits();
Shannon Woods53a94a82014-06-24 15:20:36 -0400450}
451
Jamie Madille3bb6b72018-10-03 17:51:15 -0400452ANGLE_INLINE void State::unsetActiveTextures(ActiveTextureMask textureMask)
453{
454 // Unset any relevant bound textures.
455 for (size_t textureIndex : mProgram->getActiveSamplersMask())
456 {
457 mActiveTexturesCache[textureIndex] = nullptr;
458 mCompleteTextureBindings[textureIndex].reset();
459 }
460}
461
Jamie Madill6f755b22018-10-09 12:48:54 -0400462ANGLE_INLINE angle::Result State::updateActiveTexture(const Context *context,
463 size_t textureIndex,
464 Texture *texture)
Jamie Madille3bb6b72018-10-03 17:51:15 -0400465{
466 const Sampler *sampler = mSamplers[textureIndex].get();
467
468 if (!texture)
469 {
470 mActiveTexturesCache[textureIndex] = nullptr;
471 mCompleteTextureBindings[textureIndex].bind(nullptr);
Jamie Madill6f755b22018-10-09 12:48:54 -0400472 return angle::Result::Continue();
Jamie Madille3bb6b72018-10-03 17:51:15 -0400473 }
474
Jamie Madill31116732018-10-09 18:30:01 -0400475 mCompleteTextureBindings[textureIndex].bind(texture->getImplementation());
Jamie Madille3bb6b72018-10-03 17:51:15 -0400476
477 if (!texture->isSamplerComplete(context, sampler))
478 {
479 mActiveTexturesCache[textureIndex] = nullptr;
Jamie Madill6f755b22018-10-09 12:48:54 -0400480 return angle::Result::Continue();
Jamie Madille3bb6b72018-10-03 17:51:15 -0400481 }
482
483 mActiveTexturesCache[textureIndex] = texture;
484
485 if (texture->hasAnyDirtyBit())
486 {
487 ANGLE_TRY(texture->syncState(context));
488 }
489
490 if (texture->initState() == InitState::MayNeedInit)
491 {
492 mCachedTexturesInitState = InitState::MayNeedInit;
493 }
494
Jamie Madill6f755b22018-10-09 12:48:54 -0400495 return angle::Result::Continue();
Jamie Madille3bb6b72018-10-03 17:51:15 -0400496}
497
Shannon Woods53a94a82014-06-24 15:20:36 -0400498const RasterizerState &State::getRasterizerState() const
499{
500 return mRasterizer;
501}
502
503const BlendState &State::getBlendState() const
504{
505 return mBlend;
506}
507
508const DepthStencilState &State::getDepthStencilState() const
509{
510 return mDepthStencil;
511}
512
Jamie Madillf75ab352015-03-16 10:46:52 -0400513void State::setColorClearValue(float red, float green, float blue, float alpha)
Shannon Woods53a94a82014-06-24 15:20:36 -0400514{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700515 mColorClearValue.red = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400516 mColorClearValue.green = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700517 mColorClearValue.blue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400518 mColorClearValue.alpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400519 mDirtyBits.set(DIRTY_BIT_CLEAR_COLOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400520}
521
Jamie Madillf75ab352015-03-16 10:46:52 -0400522void State::setDepthClearValue(float depth)
Shannon Woods53a94a82014-06-24 15:20:36 -0400523{
524 mDepthClearValue = depth;
Jamie Madill1b94d432015-08-07 13:23:23 -0400525 mDirtyBits.set(DIRTY_BIT_CLEAR_DEPTH);
Shannon Woods53a94a82014-06-24 15:20:36 -0400526}
527
Jamie Madillf75ab352015-03-16 10:46:52 -0400528void State::setStencilClearValue(int stencil)
Shannon Woods53a94a82014-06-24 15:20:36 -0400529{
530 mStencilClearValue = stencil;
Jamie Madill1b94d432015-08-07 13:23:23 -0400531 mDirtyBits.set(DIRTY_BIT_CLEAR_STENCIL);
Shannon Woods53a94a82014-06-24 15:20:36 -0400532}
533
Shannon Woods53a94a82014-06-24 15:20:36 -0400534void State::setColorMask(bool red, bool green, bool blue, bool alpha)
535{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700536 mBlend.colorMaskRed = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400537 mBlend.colorMaskGreen = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700538 mBlend.colorMaskBlue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400539 mBlend.colorMaskAlpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400540 mDirtyBits.set(DIRTY_BIT_COLOR_MASK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400541}
542
543void State::setDepthMask(bool mask)
544{
545 mDepthStencil.depthMask = mask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400546 mDirtyBits.set(DIRTY_BIT_DEPTH_MASK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400547}
548
Shannon Woods53a94a82014-06-24 15:20:36 -0400549void State::setRasterizerDiscard(bool enabled)
550{
551 mRasterizer.rasterizerDiscard = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400552 mDirtyBits.set(DIRTY_BIT_RASTERIZER_DISCARD_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400553}
554
Shannon Woods53a94a82014-06-24 15:20:36 -0400555void State::setCullFace(bool enabled)
556{
557 mRasterizer.cullFace = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400558 mDirtyBits.set(DIRTY_BIT_CULL_FACE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400559}
560
Corentin Wallez2e568cf2017-09-18 17:05:22 -0400561void State::setCullMode(CullFaceMode mode)
Shannon Woods53a94a82014-06-24 15:20:36 -0400562{
563 mRasterizer.cullMode = mode;
Jamie Madill1b94d432015-08-07 13:23:23 -0400564 mDirtyBits.set(DIRTY_BIT_CULL_FACE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400565}
566
567void State::setFrontFace(GLenum front)
568{
569 mRasterizer.frontFace = front;
Jamie Madill1b94d432015-08-07 13:23:23 -0400570 mDirtyBits.set(DIRTY_BIT_FRONT_FACE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400571}
572
Shannon Woods53a94a82014-06-24 15:20:36 -0400573void State::setDepthTest(bool enabled)
574{
575 mDepthStencil.depthTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400576 mDirtyBits.set(DIRTY_BIT_DEPTH_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400577}
578
579void State::setDepthFunc(GLenum depthFunc)
580{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700581 mDepthStencil.depthFunc = depthFunc;
582 mDirtyBits.set(DIRTY_BIT_DEPTH_FUNC);
Shannon Woods53a94a82014-06-24 15:20:36 -0400583}
584
585void State::setDepthRange(float zNear, float zFar)
586{
587 mNearZ = zNear;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700588 mFarZ = zFar;
Jamie Madill1b94d432015-08-07 13:23:23 -0400589 mDirtyBits.set(DIRTY_BIT_DEPTH_RANGE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400590}
591
Shannon Woods53a94a82014-06-24 15:20:36 -0400592void State::setBlend(bool enabled)
593{
594 mBlend.blend = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400595 mDirtyBits.set(DIRTY_BIT_BLEND_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400596}
597
598void State::setBlendFactors(GLenum sourceRGB, GLenum destRGB, GLenum sourceAlpha, GLenum destAlpha)
599{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700600 mBlend.sourceBlendRGB = sourceRGB;
601 mBlend.destBlendRGB = destRGB;
Shannon Woods53a94a82014-06-24 15:20:36 -0400602 mBlend.sourceBlendAlpha = sourceAlpha;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700603 mBlend.destBlendAlpha = destAlpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400604 mDirtyBits.set(DIRTY_BIT_BLEND_FUNCS);
Shannon Woods53a94a82014-06-24 15:20:36 -0400605}
606
607void State::setBlendColor(float red, float green, float blue, float alpha)
608{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700609 mBlendColor.red = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400610 mBlendColor.green = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700611 mBlendColor.blue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400612 mBlendColor.alpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400613 mDirtyBits.set(DIRTY_BIT_BLEND_COLOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400614}
615
616void State::setBlendEquation(GLenum rgbEquation, GLenum alphaEquation)
617{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700618 mBlend.blendEquationRGB = rgbEquation;
Shannon Woods53a94a82014-06-24 15:20:36 -0400619 mBlend.blendEquationAlpha = alphaEquation;
Jamie Madill1b94d432015-08-07 13:23:23 -0400620 mDirtyBits.set(DIRTY_BIT_BLEND_EQUATIONS);
Shannon Woods53a94a82014-06-24 15:20:36 -0400621}
622
Shannon Woods53a94a82014-06-24 15:20:36 -0400623void State::setStencilTest(bool enabled)
624{
625 mDepthStencil.stencilTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400626 mDirtyBits.set(DIRTY_BIT_STENCIL_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400627}
628
629void State::setStencilParams(GLenum stencilFunc, GLint stencilRef, GLuint stencilMask)
630{
631 mDepthStencil.stencilFunc = stencilFunc;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700632 mStencilRef = (stencilRef > 0) ? stencilRef : 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400633 mDepthStencil.stencilMask = stencilMask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400634 mDirtyBits.set(DIRTY_BIT_STENCIL_FUNCS_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400635}
636
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700637void State::setStencilBackParams(GLenum stencilBackFunc,
638 GLint stencilBackRef,
639 GLuint stencilBackMask)
Shannon Woods53a94a82014-06-24 15:20:36 -0400640{
641 mDepthStencil.stencilBackFunc = stencilBackFunc;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700642 mStencilBackRef = (stencilBackRef > 0) ? stencilBackRef : 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400643 mDepthStencil.stencilBackMask = stencilBackMask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400644 mDirtyBits.set(DIRTY_BIT_STENCIL_FUNCS_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400645}
646
647void State::setStencilWritemask(GLuint stencilWritemask)
648{
649 mDepthStencil.stencilWritemask = stencilWritemask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400650 mDirtyBits.set(DIRTY_BIT_STENCIL_WRITEMASK_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400651}
652
653void State::setStencilBackWritemask(GLuint stencilBackWritemask)
654{
655 mDepthStencil.stencilBackWritemask = stencilBackWritemask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400656 mDirtyBits.set(DIRTY_BIT_STENCIL_WRITEMASK_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400657}
658
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700659void State::setStencilOperations(GLenum stencilFail,
660 GLenum stencilPassDepthFail,
661 GLenum stencilPassDepthPass)
Shannon Woods53a94a82014-06-24 15:20:36 -0400662{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700663 mDepthStencil.stencilFail = stencilFail;
Shannon Woods53a94a82014-06-24 15:20:36 -0400664 mDepthStencil.stencilPassDepthFail = stencilPassDepthFail;
665 mDepthStencil.stencilPassDepthPass = stencilPassDepthPass;
Jamie Madill1b94d432015-08-07 13:23:23 -0400666 mDirtyBits.set(DIRTY_BIT_STENCIL_OPS_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400667}
668
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700669void State::setStencilBackOperations(GLenum stencilBackFail,
670 GLenum stencilBackPassDepthFail,
671 GLenum stencilBackPassDepthPass)
Shannon Woods53a94a82014-06-24 15:20:36 -0400672{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700673 mDepthStencil.stencilBackFail = stencilBackFail;
Shannon Woods53a94a82014-06-24 15:20:36 -0400674 mDepthStencil.stencilBackPassDepthFail = stencilBackPassDepthFail;
675 mDepthStencil.stencilBackPassDepthPass = stencilBackPassDepthPass;
Jamie Madill1b94d432015-08-07 13:23:23 -0400676 mDirtyBits.set(DIRTY_BIT_STENCIL_OPS_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400677}
678
Shannon Woods53a94a82014-06-24 15:20:36 -0400679void State::setPolygonOffsetFill(bool enabled)
680{
Jamie Madill1b94d432015-08-07 13:23:23 -0400681 mRasterizer.polygonOffsetFill = enabled;
682 mDirtyBits.set(DIRTY_BIT_POLYGON_OFFSET_FILL_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400683}
684
685void State::setPolygonOffsetParams(GLfloat factor, GLfloat units)
686{
687 // An application can pass NaN values here, so handle this gracefully
688 mRasterizer.polygonOffsetFactor = factor != factor ? 0.0f : factor;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700689 mRasterizer.polygonOffsetUnits = units != units ? 0.0f : units;
Jamie Madill1b94d432015-08-07 13:23:23 -0400690 mDirtyBits.set(DIRTY_BIT_POLYGON_OFFSET);
Shannon Woods53a94a82014-06-24 15:20:36 -0400691}
692
Shannon Woods53a94a82014-06-24 15:20:36 -0400693void State::setSampleAlphaToCoverage(bool enabled)
694{
695 mBlend.sampleAlphaToCoverage = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400696 mDirtyBits.set(DIRTY_BIT_SAMPLE_ALPHA_TO_COVERAGE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400697}
698
Shannon Woods53a94a82014-06-24 15:20:36 -0400699void State::setSampleCoverage(bool enabled)
700{
701 mSampleCoverage = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400702 mDirtyBits.set(DIRTY_BIT_SAMPLE_COVERAGE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400703}
704
705void State::setSampleCoverageParams(GLclampf value, bool invert)
706{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700707 mSampleCoverageValue = value;
Shannon Woods53a94a82014-06-24 15:20:36 -0400708 mSampleCoverageInvert = invert;
Jamie Madill1b94d432015-08-07 13:23:23 -0400709 mDirtyBits.set(DIRTY_BIT_SAMPLE_COVERAGE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400710}
711
Jiawei Shaodb342272017-09-27 10:21:45 +0800712void State::setSampleMaskEnabled(bool enabled)
713{
714 mSampleMask = enabled;
715 mDirtyBits.set(DIRTY_BIT_SAMPLE_MASK_ENABLED);
716}
717
718void State::setSampleMaskParams(GLuint maskNumber, GLbitfield mask)
719{
720 ASSERT(maskNumber < mMaxSampleMaskWords);
721 mSampleMaskValues[maskNumber] = mask;
Jamie Madillc67323a2017-11-02 23:11:41 -0400722 // TODO(jmadill): Use a child dirty bit if we ever use more than two words.
723 mDirtyBits.set(DIRTY_BIT_SAMPLE_MASK);
Jiawei Shaodb342272017-09-27 10:21:45 +0800724}
725
Sami Väisänen74c23472016-05-09 17:30:30 +0300726void State::setSampleAlphaToOne(bool enabled)
727{
728 mSampleAlphaToOne = enabled;
729 mDirtyBits.set(DIRTY_BIT_SAMPLE_ALPHA_TO_ONE);
730}
731
Sami Väisänen74c23472016-05-09 17:30:30 +0300732void State::setMultisampling(bool enabled)
733{
734 mMultiSampling = enabled;
735 mDirtyBits.set(DIRTY_BIT_MULTISAMPLING);
736}
737
Shannon Woods53a94a82014-06-24 15:20:36 -0400738void State::setScissorTest(bool enabled)
739{
740 mScissorTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400741 mDirtyBits.set(DIRTY_BIT_SCISSOR_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400742}
743
744void State::setScissorParams(GLint x, GLint y, GLsizei width, GLsizei height)
745{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700746 mScissor.x = x;
747 mScissor.y = y;
748 mScissor.width = width;
Shannon Woods53a94a82014-06-24 15:20:36 -0400749 mScissor.height = height;
Jamie Madill1b94d432015-08-07 13:23:23 -0400750 mDirtyBits.set(DIRTY_BIT_SCISSOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400751}
752
Shannon Woods53a94a82014-06-24 15:20:36 -0400753void State::setDither(bool enabled)
754{
755 mBlend.dither = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400756 mDirtyBits.set(DIRTY_BIT_DITHER_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400757}
758
Jamie Madillb4b53c52015-02-03 15:22:48 -0500759void State::setPrimitiveRestart(bool enabled)
760{
761 mPrimitiveRestart = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400762 mDirtyBits.set(DIRTY_BIT_PRIMITIVE_RESTART_ENABLED);
Jamie Madillb4b53c52015-02-03 15:22:48 -0500763}
764
Shannon Woods53a94a82014-06-24 15:20:36 -0400765void State::setEnableFeature(GLenum feature, bool enabled)
766{
767 switch (feature)
768 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700769 case GL_MULTISAMPLE_EXT:
770 setMultisampling(enabled);
771 break;
772 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
773 setSampleAlphaToOne(enabled);
774 break;
775 case GL_CULL_FACE:
776 setCullFace(enabled);
777 break;
778 case GL_POLYGON_OFFSET_FILL:
779 setPolygonOffsetFill(enabled);
780 break;
781 case GL_SAMPLE_ALPHA_TO_COVERAGE:
782 setSampleAlphaToCoverage(enabled);
783 break;
784 case GL_SAMPLE_COVERAGE:
785 setSampleCoverage(enabled);
786 break;
787 case GL_SCISSOR_TEST:
788 setScissorTest(enabled);
789 break;
790 case GL_STENCIL_TEST:
791 setStencilTest(enabled);
792 break;
793 case GL_DEPTH_TEST:
794 setDepthTest(enabled);
795 break;
796 case GL_BLEND:
797 setBlend(enabled);
798 break;
799 case GL_DITHER:
800 setDither(enabled);
801 break;
802 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
803 setPrimitiveRestart(enabled);
804 break;
805 case GL_RASTERIZER_DISCARD:
806 setRasterizerDiscard(enabled);
807 break;
808 case GL_SAMPLE_MASK:
809 setSampleMaskEnabled(enabled);
810 break;
811 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
812 mDebug.setOutputSynchronous(enabled);
813 break;
814 case GL_DEBUG_OUTPUT:
815 mDebug.setOutputEnabled(enabled);
816 break;
817 case GL_FRAMEBUFFER_SRGB_EXT:
818 setFramebufferSRGB(enabled);
819 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -0700820
821 // GLES1 emulation
822 case GL_ALPHA_TEST:
823 mGLES1State.mAlphaTestEnabled = enabled;
824 break;
Lingfeng Yang23dc90b2018-04-23 09:01:49 -0700825 case GL_TEXTURE_2D:
826 mGLES1State.mTexUnitEnables[mActiveSampler].set(TextureType::_2D, enabled);
827 break;
828 case GL_TEXTURE_CUBE_MAP:
829 mGLES1State.mTexUnitEnables[mActiveSampler].set(TextureType::CubeMap, enabled);
830 break;
Lingfeng Yangd0febe72018-05-17 22:36:52 -0700831 case GL_LIGHTING:
832 mGLES1State.mLightingEnabled = enabled;
833 break;
834 case GL_LIGHT0:
835 case GL_LIGHT1:
836 case GL_LIGHT2:
837 case GL_LIGHT3:
838 case GL_LIGHT4:
839 case GL_LIGHT5:
840 case GL_LIGHT6:
841 case GL_LIGHT7:
842 mGLES1State.mLights[feature - GL_LIGHT0].enabled = enabled;
843 break;
844 case GL_NORMALIZE:
845 mGLES1State.mNormalizeEnabled = enabled;
846 break;
847 case GL_RESCALE_NORMAL:
848 mGLES1State.mRescaleNormalEnabled = enabled;
849 break;
850 case GL_COLOR_MATERIAL:
851 mGLES1State.mColorMaterialEnabled = enabled;
852 break;
Lingfeng Yang060088a2018-05-30 20:40:57 -0700853 case GL_CLIP_PLANE0:
854 case GL_CLIP_PLANE1:
855 case GL_CLIP_PLANE2:
856 case GL_CLIP_PLANE3:
857 case GL_CLIP_PLANE4:
858 case GL_CLIP_PLANE5:
859 mGLES1State.mClipPlanes[feature - GL_CLIP_PLANE0].enabled = enabled;
860 break;
Lingfeng Yang7ba3f422018-06-01 09:43:04 -0700861 case GL_FOG:
862 mGLES1State.mFogEnabled = enabled;
863 break;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -0700864 case GL_POINT_SMOOTH:
865 mGLES1State.mPointSmoothEnabled = enabled;
866 break;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -0700867 case GL_LINE_SMOOTH:
868 mGLES1State.mLineSmoothEnabled = enabled;
869 break;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -0700870 case GL_POINT_SPRITE_OES:
871 mGLES1State.mPointSpriteEnabled = enabled;
872 break;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -0700873 case GL_COLOR_LOGIC_OP:
874 mGLES1State.mLogicOpEnabled = enabled;
875 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700876 default:
877 UNREACHABLE();
Shannon Woods53a94a82014-06-24 15:20:36 -0400878 }
879}
880
Jamie Madilldfde6ab2016-06-09 07:07:18 -0700881bool State::getEnableFeature(GLenum feature) const
Shannon Woods53a94a82014-06-24 15:20:36 -0400882{
883 switch (feature)
884 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700885 case GL_MULTISAMPLE_EXT:
886 return isMultisamplingEnabled();
887 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
888 return isSampleAlphaToOneEnabled();
889 case GL_CULL_FACE:
890 return isCullFaceEnabled();
891 case GL_POLYGON_OFFSET_FILL:
892 return isPolygonOffsetFillEnabled();
893 case GL_SAMPLE_ALPHA_TO_COVERAGE:
894 return isSampleAlphaToCoverageEnabled();
895 case GL_SAMPLE_COVERAGE:
896 return isSampleCoverageEnabled();
897 case GL_SCISSOR_TEST:
898 return isScissorTestEnabled();
899 case GL_STENCIL_TEST:
900 return isStencilTestEnabled();
901 case GL_DEPTH_TEST:
902 return isDepthTestEnabled();
903 case GL_BLEND:
904 return isBlendEnabled();
905 case GL_DITHER:
906 return isDitherEnabled();
907 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
908 return isPrimitiveRestartEnabled();
909 case GL_RASTERIZER_DISCARD:
910 return isRasterizerDiscardEnabled();
911 case GL_SAMPLE_MASK:
912 return isSampleMaskEnabled();
913 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
914 return mDebug.isOutputSynchronous();
915 case GL_DEBUG_OUTPUT:
916 return mDebug.isOutputEnabled();
917 case GL_BIND_GENERATES_RESOURCE_CHROMIUM:
918 return isBindGeneratesResourceEnabled();
919 case GL_CLIENT_ARRAYS_ANGLE:
920 return areClientArraysEnabled();
921 case GL_FRAMEBUFFER_SRGB_EXT:
922 return getFramebufferSRGB();
923 case GL_ROBUST_RESOURCE_INITIALIZATION_ANGLE:
924 return mRobustResourceInit;
925 case GL_PROGRAM_CACHE_ENABLED_ANGLE:
926 return mProgramBinaryCacheEnabled;
Jamie Madillc43be722017-07-13 16:22:14 -0400927
Lingfeng Yang13b708f2018-03-21 12:14:10 -0700928 // GLES1 emulation
929 case GL_ALPHA_TEST:
930 return mGLES1State.mAlphaTestEnabled;
Lingfeng Yang01074432018-04-16 10:19:51 -0700931 case GL_VERTEX_ARRAY:
932 return mGLES1State.mVertexArrayEnabled;
933 case GL_NORMAL_ARRAY:
934 return mGLES1State.mNormalArrayEnabled;
935 case GL_COLOR_ARRAY:
936 return mGLES1State.mColorArrayEnabled;
937 case GL_POINT_SIZE_ARRAY_OES:
938 return mGLES1State.mPointSizeArrayEnabled;
939 case GL_TEXTURE_COORD_ARRAY:
940 return mGLES1State.mTexCoordArrayEnabled[mGLES1State.mClientActiveTexture];
Lingfeng Yang23dc90b2018-04-23 09:01:49 -0700941 case GL_TEXTURE_2D:
942 return mGLES1State.mTexUnitEnables[mActiveSampler].test(TextureType::_2D);
943 case GL_TEXTURE_CUBE_MAP:
944 return mGLES1State.mTexUnitEnables[mActiveSampler].test(TextureType::CubeMap);
Lingfeng Yangd0febe72018-05-17 22:36:52 -0700945 case GL_LIGHTING:
946 return mGLES1State.mLightingEnabled;
947 case GL_LIGHT0:
948 case GL_LIGHT1:
949 case GL_LIGHT2:
950 case GL_LIGHT3:
951 case GL_LIGHT4:
952 case GL_LIGHT5:
953 case GL_LIGHT6:
954 case GL_LIGHT7:
955 return mGLES1State.mLights[feature - GL_LIGHT0].enabled;
956 case GL_NORMALIZE:
957 return mGLES1State.mNormalizeEnabled;
958 case GL_RESCALE_NORMAL:
959 return mGLES1State.mRescaleNormalEnabled;
960 case GL_COLOR_MATERIAL:
961 return mGLES1State.mColorMaterialEnabled;
Lingfeng Yang060088a2018-05-30 20:40:57 -0700962 case GL_CLIP_PLANE0:
963 case GL_CLIP_PLANE1:
964 case GL_CLIP_PLANE2:
965 case GL_CLIP_PLANE3:
966 case GL_CLIP_PLANE4:
967 case GL_CLIP_PLANE5:
968 return mGLES1State.mClipPlanes[feature - GL_CLIP_PLANE0].enabled;
Lingfeng Yang7ba3f422018-06-01 09:43:04 -0700969 case GL_FOG:
970 return mGLES1State.mFogEnabled;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -0700971 case GL_POINT_SMOOTH:
972 return mGLES1State.mPointSmoothEnabled;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -0700973 case GL_LINE_SMOOTH:
974 return mGLES1State.mLineSmoothEnabled;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -0700975 case GL_POINT_SPRITE_OES:
976 return mGLES1State.mPointSpriteEnabled;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -0700977 case GL_COLOR_LOGIC_OP:
978 return mGLES1State.mLogicOpEnabled;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700979 default:
980 UNREACHABLE();
981 return false;
Shannon Woods53a94a82014-06-24 15:20:36 -0400982 }
983}
984
985void State::setLineWidth(GLfloat width)
986{
987 mLineWidth = width;
Jamie Madill1b94d432015-08-07 13:23:23 -0400988 mDirtyBits.set(DIRTY_BIT_LINE_WIDTH);
Shannon Woods53a94a82014-06-24 15:20:36 -0400989}
990
991void State::setGenerateMipmapHint(GLenum hint)
992{
993 mGenerateMipmapHint = hint;
Jamie Madill1b94d432015-08-07 13:23:23 -0400994 mDirtyBits.set(DIRTY_BIT_GENERATE_MIPMAP_HINT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400995}
996
997void State::setFragmentShaderDerivativeHint(GLenum hint)
998{
999 mFragmentShaderDerivativeHint = hint;
Jamie Madill1b94d432015-08-07 13:23:23 -04001000 mDirtyBits.set(DIRTY_BIT_SHADER_DERIVATIVE_HINT);
Shannon Woods53a94a82014-06-24 15:20:36 -04001001 // TODO: Propagate the hint to shader translator so we can write
1002 // ddx, ddx_coarse, or ddx_fine depending on the hint.
1003 // Ignore for now. It is valid for implementations to ignore hint.
1004}
1005
1006void State::setViewportParams(GLint x, GLint y, GLsizei width, GLsizei height)
1007{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001008 mViewport.x = x;
1009 mViewport.y = y;
1010 mViewport.width = width;
Shannon Woods53a94a82014-06-24 15:20:36 -04001011 mViewport.height = height;
Jamie Madill1b94d432015-08-07 13:23:23 -04001012 mDirtyBits.set(DIRTY_BIT_VIEWPORT);
Shannon Woods53a94a82014-06-24 15:20:36 -04001013}
1014
Shannon Woods53a94a82014-06-24 15:20:36 -04001015void State::setActiveSampler(unsigned int active)
1016{
1017 mActiveSampler = active;
1018}
1019
Jamie Madill526392d2018-11-16 09:35:14 -05001020angle::Result State::setSamplerTexture(const Context *context, TextureType type, Texture *texture)
Shannon Woods53a94a82014-06-24 15:20:36 -04001021{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001022 mSamplerTextures[type][mActiveSampler].set(context, texture);
Jamie Madill14246812018-10-03 17:51:16 -04001023
1024 if (mProgram && mProgram->getActiveSamplersMask()[mActiveSampler] &&
1025 mProgram->getActiveSamplerTypes()[mActiveSampler] == type)
1026 {
1027 ANGLE_TRY(updateActiveTexture(context, mActiveSampler, texture));
1028 }
1029
Jamie Madill81c2e252017-09-09 23:32:46 -04001030 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
Jamie Madill14246812018-10-03 17:51:16 -04001031
Jamie Madill526392d2018-11-16 09:35:14 -05001032 return angle::Result::Continue();
Shannon Woods53a94a82014-06-24 15:20:36 -04001033}
1034
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001035Texture *State::getTargetTexture(TextureType type) const
Jamie Madillc29968b2016-01-20 11:17:23 -05001036{
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001037 return getSamplerTexture(static_cast<unsigned int>(mActiveSampler), type);
Jamie Madillc29968b2016-01-20 11:17:23 -05001038}
1039
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001040GLuint State::getSamplerTextureId(unsigned int sampler, TextureType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001041{
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001042 ASSERT(sampler < mSamplerTextures[type].size());
1043 return mSamplerTextures[type][sampler].id();
Shannon Woods53a94a82014-06-24 15:20:36 -04001044}
1045
Jamie Madilla02315b2017-02-23 14:14:47 -05001046void State::detachTexture(const Context *context, const TextureMap &zeroTextures, GLuint texture)
Shannon Woods53a94a82014-06-24 15:20:36 -04001047{
1048 // Textures have a detach method on State rather than a simple
1049 // removeBinding, because the zero/null texture objects are managed
1050 // separately, and don't have to go through the Context's maps or
1051 // the ResourceManager.
1052
1053 // [OpenGL ES 2.0.24] section 3.8 page 84:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001054 // If a texture object is deleted, it is as if all texture units which are bound to that texture
1055 // object are rebound to texture object zero
Shannon Woods53a94a82014-06-24 15:20:36 -04001056
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001057 for (TextureType type : angle::AllEnums<TextureType>())
Shannon Woods53a94a82014-06-24 15:20:36 -04001058 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001059 TextureBindingVector &textureVector = mSamplerTextures[type];
Jamie Madill81c2e252017-09-09 23:32:46 -04001060 for (BindingPointer<Texture> &binding : textureVector)
Shannon Woods53a94a82014-06-24 15:20:36 -04001061 {
Geoff Lang76b10c92014-09-05 16:28:14 -04001062 if (binding.id() == texture)
Shannon Woods53a94a82014-06-24 15:20:36 -04001063 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001064 Texture *zeroTexture = zeroTextures[type].get();
1065 ASSERT(zeroTexture != nullptr);
Jamie Madille6382c32014-11-07 15:05:26 -05001066 // Zero textures are the "default" textures instead of NULL
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001067 binding.set(context, zeroTexture);
Jamie Madill81c2e252017-09-09 23:32:46 -04001068 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
Shannon Woods53a94a82014-06-24 15:20:36 -04001069 }
1070 }
1071 }
1072
Xinghua Cao65ec0b22017-03-28 16:10:52 +08001073 for (auto &bindingImageUnit : mImageUnits)
1074 {
1075 if (bindingImageUnit.texture.id() == texture)
1076 {
1077 bindingImageUnit.texture.set(context, nullptr);
1078 bindingImageUnit.level = 0;
1079 bindingImageUnit.layered = false;
1080 bindingImageUnit.layer = 0;
1081 bindingImageUnit.access = GL_READ_ONLY;
1082 bindingImageUnit.format = GL_R32UI;
1083 break;
1084 }
1085 }
1086
Shannon Woods53a94a82014-06-24 15:20:36 -04001087 // [OpenGL ES 2.0.24] section 4.4 page 112:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001088 // If a texture object is deleted while its image is attached to the currently bound
1089 // framebuffer, then it is as if Texture2DAttachment had been called, with a texture of 0, for
1090 // each attachment point to which this image was attached in the currently bound framebuffer.
Shannon Woods53a94a82014-06-24 15:20:36 -04001091
Jamie Madill8693bdb2017-09-02 15:32:14 -04001092 if (mReadFramebuffer && mReadFramebuffer->detachTexture(context, texture))
Shannon Woods53a94a82014-06-24 15:20:36 -04001093 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001094 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -04001095 }
1096
Jamie Madill8693bdb2017-09-02 15:32:14 -04001097 if (mDrawFramebuffer && mDrawFramebuffer->detachTexture(context, texture))
Shannon Woods53a94a82014-06-24 15:20:36 -04001098 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001099 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -04001100 }
1101}
1102
Jamie Madill4928b7c2017-06-20 12:57:39 -04001103void State::initializeZeroTextures(const Context *context, const TextureMap &zeroTextures)
Jamie Madille6382c32014-11-07 15:05:26 -05001104{
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001105 for (TextureType type : angle::AllEnums<TextureType>())
Jamie Madille6382c32014-11-07 15:05:26 -05001106 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001107 for (size_t textureUnit = 0; textureUnit < mSamplerTextures[type].size(); ++textureUnit)
Jamie Madille6382c32014-11-07 15:05:26 -05001108 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001109 mSamplerTextures[type][textureUnit].set(context, zeroTextures[type].get());
Jamie Madille6382c32014-11-07 15:05:26 -05001110 }
1111 }
1112}
1113
Jamie Madill4928b7c2017-06-20 12:57:39 -04001114void State::setSamplerBinding(const Context *context, GLuint textureUnit, Sampler *sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001115{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001116 mSamplers[textureUnit].set(context, sampler);
Jamie Madill81c2e252017-09-09 23:32:46 -04001117 mDirtyBits.set(DIRTY_BIT_SAMPLER_BINDINGS);
1118 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Jamie Madille25b8002018-09-20 13:39:49 -04001119 // This is overly conservative as it assumes the sampler has never been bound.
1120 setSamplerDirty(textureUnit);
Shannon Woods53a94a82014-06-24 15:20:36 -04001121}
1122
Jamie Madill4928b7c2017-06-20 12:57:39 -04001123void State::detachSampler(const Context *context, GLuint sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001124{
1125 // [OpenGL ES 3.0.2] section 3.8.2 pages 123-124:
1126 // If a sampler object that is currently bound to one or more texture units is
1127 // deleted, it is as though BindSampler is called once for each texture unit to
1128 // which the sampler is bound, with unit set to the texture unit and sampler set to zero.
Jamie Madill81c2e252017-09-09 23:32:46 -04001129 for (BindingPointer<Sampler> &samplerBinding : mSamplers)
Shannon Woods53a94a82014-06-24 15:20:36 -04001130 {
Geoff Lang76b10c92014-09-05 16:28:14 -04001131 if (samplerBinding.id() == sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001132 {
Jamie Madill4928b7c2017-06-20 12:57:39 -04001133 samplerBinding.set(context, nullptr);
Jamie Madill81c2e252017-09-09 23:32:46 -04001134 mDirtyBits.set(DIRTY_BIT_SAMPLER_BINDINGS);
Shannon Woods53a94a82014-06-24 15:20:36 -04001135 }
1136 }
1137}
1138
Jamie Madill4928b7c2017-06-20 12:57:39 -04001139void State::setRenderbufferBinding(const Context *context, Renderbuffer *renderbuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001140{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001141 mRenderbuffer.set(context, renderbuffer);
Jamie Madill8693bdb2017-09-02 15:32:14 -04001142 mDirtyBits.set(DIRTY_BIT_RENDERBUFFER_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001143}
1144
Jamie Madilla02315b2017-02-23 14:14:47 -05001145void State::detachRenderbuffer(const Context *context, GLuint renderbuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001146{
1147 // [OpenGL ES 2.0.24] section 4.4 page 109:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001148 // If a renderbuffer that is currently bound to RENDERBUFFER is deleted, it is as though
1149 // BindRenderbuffer had been executed with the target RENDERBUFFER and name of zero.
Shannon Woods53a94a82014-06-24 15:20:36 -04001150
1151 if (mRenderbuffer.id() == renderbuffer)
1152 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001153 setRenderbufferBinding(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001154 }
1155
1156 // [OpenGL ES 2.0.24] section 4.4 page 111:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001157 // If a renderbuffer object is deleted while its image is attached to the currently bound
1158 // framebuffer, then it is as if FramebufferRenderbuffer had been called, with a renderbuffer of
1159 // 0, for each attachment point to which this image was attached in the currently bound
1160 // framebuffer.
Shannon Woods53a94a82014-06-24 15:20:36 -04001161
1162 Framebuffer *readFramebuffer = mReadFramebuffer;
1163 Framebuffer *drawFramebuffer = mDrawFramebuffer;
1164
Jamie Madill8693bdb2017-09-02 15:32:14 -04001165 if (readFramebuffer && readFramebuffer->detachRenderbuffer(context, renderbuffer))
Shannon Woods53a94a82014-06-24 15:20:36 -04001166 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001167 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -04001168 }
1169
1170 if (drawFramebuffer && drawFramebuffer != readFramebuffer)
1171 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001172 if (drawFramebuffer->detachRenderbuffer(context, renderbuffer))
1173 {
1174 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
1175 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001176 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001177}
1178
1179void State::setReadFramebufferBinding(Framebuffer *framebuffer)
1180{
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001181 if (mReadFramebuffer == framebuffer)
1182 return;
1183
Shannon Woods53a94a82014-06-24 15:20:36 -04001184 mReadFramebuffer = framebuffer;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001185 mDirtyBits.set(DIRTY_BIT_READ_FRAMEBUFFER_BINDING);
1186
1187 if (mReadFramebuffer && mReadFramebuffer->hasAnyDirtyBit())
1188 {
1189 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
1190 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001191}
1192
1193void State::setDrawFramebufferBinding(Framebuffer *framebuffer)
1194{
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001195 if (mDrawFramebuffer == framebuffer)
1196 return;
1197
Shannon Woods53a94a82014-06-24 15:20:36 -04001198 mDrawFramebuffer = framebuffer;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001199 mDirtyBits.set(DIRTY_BIT_DRAW_FRAMEBUFFER_BINDING);
1200
1201 if (mDrawFramebuffer && mDrawFramebuffer->hasAnyDirtyBit())
1202 {
1203 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
1204 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001205}
1206
1207Framebuffer *State::getTargetFramebuffer(GLenum target) const
1208{
1209 switch (target)
1210 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001211 case GL_READ_FRAMEBUFFER_ANGLE:
1212 return mReadFramebuffer;
1213 case GL_DRAW_FRAMEBUFFER_ANGLE:
1214 case GL_FRAMEBUFFER:
1215 return mDrawFramebuffer;
1216 default:
1217 UNREACHABLE();
Yunchao Hef81ce4a2017-04-24 10:49:17 +08001218 return nullptr;
Shannon Woods53a94a82014-06-24 15:20:36 -04001219 }
1220}
1221
Shannon Woods53a94a82014-06-24 15:20:36 -04001222bool State::removeReadFramebufferBinding(GLuint framebuffer)
1223{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001224 if (mReadFramebuffer != nullptr && mReadFramebuffer->id() == framebuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001225 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001226 setReadFramebufferBinding(nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001227 return true;
1228 }
1229
1230 return false;
1231}
1232
1233bool State::removeDrawFramebufferBinding(GLuint framebuffer)
1234{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001235 if (mReadFramebuffer != nullptr && mDrawFramebuffer->id() == framebuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001236 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001237 setDrawFramebufferBinding(nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001238 return true;
1239 }
1240
1241 return false;
1242}
1243
Jamie Madill7267aa62018-04-17 15:28:21 -04001244void State::setVertexArrayBinding(const Context *context, VertexArray *vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001245{
James Darpiniane8a93c62018-01-04 18:02:24 -08001246 if (mVertexArray == vertexArray)
1247 return;
1248 if (mVertexArray)
Jamie Madillbf5177d2018-08-21 12:58:20 -04001249 mVertexArray->onBindingChanged(context, -1);
Shannon Woods53a94a82014-06-24 15:20:36 -04001250 mVertexArray = vertexArray;
James Darpiniane8a93c62018-01-04 18:02:24 -08001251 if (vertexArray)
Jamie Madillbf5177d2018-08-21 12:58:20 -04001252 vertexArray->onBindingChanged(context, 1);
Jamie Madill0b9e9032015-08-17 11:51:52 +00001253 mDirtyBits.set(DIRTY_BIT_VERTEX_ARRAY_BINDING);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001254
1255 if (mVertexArray && mVertexArray->hasAnyDirtyBit())
1256 {
1257 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1258 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001259}
1260
Jamie Madill7267aa62018-04-17 15:28:21 -04001261bool State::removeVertexArrayBinding(const Context *context, GLuint vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001262{
James Darpiniane8a93c62018-01-04 18:02:24 -08001263 if (mVertexArray && mVertexArray->id() == vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001264 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001265 mVertexArray->onBindingChanged(context, -1);
Yunchao Hed7297bf2017-04-19 15:27:10 +08001266 mVertexArray = nullptr;
Jamie Madill0b9e9032015-08-17 11:51:52 +00001267 mDirtyBits.set(DIRTY_BIT_VERTEX_ARRAY_BINDING);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001268 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001269 return true;
1270 }
1271
1272 return false;
1273}
1274
Markus Tavenrath774fe562018-11-18 14:14:49 +01001275GLuint State::getVertexArrayId() const
1276{
1277 ASSERT(mVertexArray != nullptr);
1278 return mVertexArray->id();
1279}
1280
Jamie Madill4928b7c2017-06-20 12:57:39 -04001281void State::bindVertexBuffer(const Context *context,
1282 GLuint bindingIndex,
Shao80957d92017-02-20 21:25:59 +08001283 Buffer *boundBuffer,
1284 GLintptr offset,
1285 GLsizei stride)
1286{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001287 getVertexArray()->bindVertexBuffer(context, bindingIndex, boundBuffer, offset, stride);
Shao80957d92017-02-20 21:25:59 +08001288 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1289}
1290
Shaodde78e82017-05-22 14:13:27 +08001291void State::setVertexAttribBinding(const Context *context, GLuint attribIndex, GLuint bindingIndex)
Shao80957d92017-02-20 21:25:59 +08001292{
Shaodde78e82017-05-22 14:13:27 +08001293 getVertexArray()->setVertexAttribBinding(context, attribIndex, bindingIndex);
Shao80957d92017-02-20 21:25:59 +08001294 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1295}
1296
1297void State::setVertexAttribFormat(GLuint attribIndex,
1298 GLint size,
1299 GLenum type,
1300 bool normalized,
1301 bool pureInteger,
1302 GLuint relativeOffset)
1303{
1304 getVertexArray()->setVertexAttribFormat(attribIndex, size, type, normalized, pureInteger,
1305 relativeOffset);
1306 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1307}
1308
1309void State::setVertexBindingDivisor(GLuint bindingIndex, GLuint divisor)
1310{
1311 getVertexArray()->setVertexBindingDivisor(bindingIndex, divisor);
1312 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1313}
1314
Jamie Madill6f755b22018-10-09 12:48:54 -04001315angle::Result State::setProgram(const Context *context, Program *newProgram)
Shannon Woods53a94a82014-06-24 15:20:36 -04001316{
Geoff Lang7dd2e102014-11-10 15:19:26 -05001317 if (mProgram != newProgram)
Shannon Woods53a94a82014-06-24 15:20:36 -04001318 {
Geoff Lang7dd2e102014-11-10 15:19:26 -05001319 if (mProgram)
1320 {
Jamie Madille3bb6b72018-10-03 17:51:15 -04001321 unsetActiveTextures(mProgram->getActiveSamplersMask());
Jamie Madill6c1f6712017-02-14 19:08:04 -05001322 mProgram->release(context);
Geoff Lang7dd2e102014-11-10 15:19:26 -05001323 }
1324
1325 mProgram = newProgram;
1326
1327 if (mProgram)
1328 {
1329 newProgram->addRef();
Jamie Madille3bb6b72018-10-03 17:51:15 -04001330 ANGLE_TRY(onProgramExecutableChange(context, newProgram));
Geoff Lang7dd2e102014-11-10 15:19:26 -05001331 }
Jamie Madilldf836ff2018-10-01 10:36:24 -04001332
1333 // Note that rendering is undefined if glUseProgram(0) is called. But ANGLE will generate
1334 // an error if the app tries to draw in this case.
1335
Jamie Madilla779b612017-07-24 11:46:05 -04001336 mDirtyBits.set(DIRTY_BIT_PROGRAM_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001337 }
Jamie Madille3bb6b72018-10-03 17:51:15 -04001338
Jamie Madill6f755b22018-10-09 12:48:54 -04001339 return angle::Result::Continue();
Shannon Woods53a94a82014-06-24 15:20:36 -04001340}
1341
Jamie Madill4928b7c2017-06-20 12:57:39 -04001342void State::setTransformFeedbackBinding(const Context *context,
1343 TransformFeedback *transformFeedback)
Shannon Woods53a94a82014-06-24 15:20:36 -04001344{
James Darpiniane8a93c62018-01-04 18:02:24 -08001345 if (transformFeedback == mTransformFeedback.get())
1346 return;
1347 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -04001348 mTransformFeedback->onBindingChanged(context, false);
Jamie Madill4928b7c2017-06-20 12:57:39 -04001349 mTransformFeedback.set(context, transformFeedback);
James Darpiniane8a93c62018-01-04 18:02:24 -08001350 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -04001351 mTransformFeedback->onBindingChanged(context, true);
Geoff Langded79232017-11-28 15:21:11 -05001352 mDirtyBits.set(DIRTY_BIT_TRANSFORM_FEEDBACK_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001353}
1354
Jamie Madill4928b7c2017-06-20 12:57:39 -04001355bool State::removeTransformFeedbackBinding(const Context *context, GLuint transformFeedback)
Shannon Woods53a94a82014-06-24 15:20:36 -04001356{
1357 if (mTransformFeedback.id() == transformFeedback)
1358 {
James Darpiniane8a93c62018-01-04 18:02:24 -08001359 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -04001360 mTransformFeedback->onBindingChanged(context, false);
Jamie Madill4928b7c2017-06-20 12:57:39 -04001361 mTransformFeedback.set(context, nullptr);
Corentin Walleza2257da2016-04-19 16:43:12 -04001362 return true;
Shannon Woods53a94a82014-06-24 15:20:36 -04001363 }
Corentin Walleza2257da2016-04-19 16:43:12 -04001364
1365 return false;
Shannon Woods53a94a82014-06-24 15:20:36 -04001366}
1367
Yunchao Hea336b902017-08-02 16:05:21 +08001368void State::setProgramPipelineBinding(const Context *context, ProgramPipeline *pipeline)
1369{
1370 mProgramPipeline.set(context, pipeline);
1371}
1372
1373void State::detachProgramPipeline(const Context *context, GLuint pipeline)
1374{
1375 mProgramPipeline.set(context, nullptr);
1376}
1377
Corentin Wallezad3ae902018-03-09 13:40:42 -05001378bool State::isQueryActive(QueryType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001379{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001380 const Query *query = mActiveQueries[type].get();
1381 if (query != nullptr)
Shannon Woods53a94a82014-06-24 15:20:36 -04001382 {
Corentin Wallezad3ae902018-03-09 13:40:42 -05001383 return true;
1384 }
1385
1386 QueryType alternativeType;
1387 if (GetAlternativeQueryType(type, &alternativeType))
1388 {
1389 query = mActiveQueries[alternativeType].get();
1390 return query != nullptr;
Ian Ewell3ffd78b2016-01-22 16:09:42 -05001391 }
1392
1393 return false;
1394}
1395
1396bool State::isQueryActive(Query *query) const
1397{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001398 for (auto &queryPointer : mActiveQueries)
Ian Ewell3ffd78b2016-01-22 16:09:42 -05001399 {
Corentin Wallezad3ae902018-03-09 13:40:42 -05001400 if (queryPointer.get() == query)
Shannon Woods53a94a82014-06-24 15:20:36 -04001401 {
1402 return true;
1403 }
1404 }
1405
1406 return false;
1407}
1408
Corentin Wallezad3ae902018-03-09 13:40:42 -05001409void State::setActiveQuery(const Context *context, QueryType type, Query *query)
Shannon Woods53a94a82014-06-24 15:20:36 -04001410{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001411 mActiveQueries[type].set(context, query);
Shannon Woods53a94a82014-06-24 15:20:36 -04001412}
1413
Corentin Wallezad3ae902018-03-09 13:40:42 -05001414GLuint State::getActiveQueryId(QueryType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001415{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001416 const Query *query = getActiveQuery(type);
Shannon Woods53a94a82014-06-24 15:20:36 -04001417 return (query ? query->id() : 0u);
1418}
1419
Corentin Wallezad3ae902018-03-09 13:40:42 -05001420Query *State::getActiveQuery(QueryType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001421{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001422 return mActiveQueries[type].get();
Shannon Woods53a94a82014-06-24 15:20:36 -04001423}
1424
Corentin Wallez336129f2017-10-17 15:55:40 -04001425void State::setIndexedBufferBinding(const Context *context,
1426 BufferBinding target,
1427 GLuint index,
1428 Buffer *buffer,
1429 GLintptr offset,
1430 GLsizeiptr size)
Jiajia Qin9d7d0b12016-11-29 16:30:31 +08001431{
Corentin Wallez336129f2017-10-17 15:55:40 -04001432 setBufferBinding(context, target, buffer);
Jiajia Qin9d7d0b12016-11-29 16:30:31 +08001433
Corentin Wallez336129f2017-10-17 15:55:40 -04001434 switch (target)
1435 {
1436 case BufferBinding::TransformFeedback:
1437 mTransformFeedback->bindIndexedBuffer(context, index, buffer, offset, size);
James Darpiniane8a93c62018-01-04 18:02:24 -08001438 setBufferBinding(context, target, buffer);
Corentin Wallez336129f2017-10-17 15:55:40 -04001439 break;
1440 case BufferBinding::Uniform:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001441 UpdateIndexedBufferBinding(context, &mUniformBuffers[index], buffer, target, offset,
1442 size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001443 break;
1444 case BufferBinding::AtomicCounter:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001445 UpdateIndexedBufferBinding(context, &mAtomicCounterBuffers[index], buffer, target,
1446 offset, size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001447 break;
1448 case BufferBinding::ShaderStorage:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001449 UpdateIndexedBufferBinding(context, &mShaderStorageBuffers[index], buffer, target,
1450 offset, size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001451 break;
1452 default:
1453 UNREACHABLE();
1454 break;
1455 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001456}
1457
Geoff Lang5d124a62015-09-15 13:03:27 -04001458const OffsetBindingPointer<Buffer> &State::getIndexedUniformBuffer(size_t index) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001459{
Shannon Woodsf3acaf92014-09-23 18:07:11 -04001460 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
Geoff Lang5d124a62015-09-15 13:03:27 -04001461 return mUniformBuffers[index];
Gregoire Payen de La Garanderie68694e92015-03-24 14:03:37 +00001462}
1463
Jiajia Qin6eafb042016-12-27 17:04:07 +08001464const OffsetBindingPointer<Buffer> &State::getIndexedAtomicCounterBuffer(size_t index) const
1465{
1466 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
1467 return mAtomicCounterBuffers[index];
1468}
1469
Jiajia Qinf546e7d2017-03-27 14:12:59 +08001470const OffsetBindingPointer<Buffer> &State::getIndexedShaderStorageBuffer(size_t index) const
1471{
1472 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
1473 return mShaderStorageBuffers[index];
1474}
1475
Corentin Wallez336129f2017-10-17 15:55:40 -04001476Buffer *State::getTargetBuffer(BufferBinding target) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001477{
1478 switch (target)
1479 {
Corentin Wallez336129f2017-10-17 15:55:40 -04001480 case BufferBinding::ElementArray:
Jamie Madillcd0a0a32018-10-18 18:41:57 -04001481 return getVertexArray()->getElementArrayBuffer();
Corentin Wallez336129f2017-10-17 15:55:40 -04001482 default:
1483 return mBoundBuffers[target].get();
Shannon Woods53a94a82014-06-24 15:20:36 -04001484 }
1485}
1486
James Darpinian4d9d4832018-03-13 12:43:28 -07001487void State::detachBuffer(const Context *context, const Buffer *buffer)
Yuly Novikov5807a532015-12-03 13:01:22 -05001488{
James Darpinian4d9d4832018-03-13 12:43:28 -07001489 if (!buffer->isBound())
1490 {
1491 return;
1492 }
1493 GLuint bufferName = buffer->id();
James Darpiniane8a93c62018-01-04 18:02:24 -08001494 for (auto target : angle::AllEnums<BufferBinding>())
Yuly Novikov5807a532015-12-03 13:01:22 -05001495 {
James Darpiniane8a93c62018-01-04 18:02:24 -08001496 if (mBoundBuffers[target].id() == bufferName)
Yuly Novikov5807a532015-12-03 13:01:22 -05001497 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001498 UpdateBufferBinding(context, &mBoundBuffers[target], nullptr, target);
Yuly Novikov5807a532015-12-03 13:01:22 -05001499 }
1500 }
1501
1502 TransformFeedback *curTransformFeedback = getCurrentTransformFeedback();
1503 if (curTransformFeedback)
1504 {
Jamie Madill4928b7c2017-06-20 12:57:39 -04001505 curTransformFeedback->detachBuffer(context, bufferName);
Yuly Novikov5807a532015-12-03 13:01:22 -05001506 }
1507
Jamie Madill4928b7c2017-06-20 12:57:39 -04001508 getVertexArray()->detachBuffer(context, bufferName);
James Darpiniane8a93c62018-01-04 18:02:24 -08001509
1510 for (auto &buf : mUniformBuffers)
1511 {
1512 if (buf.id() == bufferName)
1513 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001514 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::Uniform, 0, 0);
James Darpiniane8a93c62018-01-04 18:02:24 -08001515 }
1516 }
1517
1518 for (auto &buf : mAtomicCounterBuffers)
1519 {
1520 if (buf.id() == bufferName)
1521 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001522 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::AtomicCounter, 0, 0);
James Darpiniane8a93c62018-01-04 18:02:24 -08001523 }
1524 }
1525
1526 for (auto &buf : mShaderStorageBuffers)
1527 {
1528 if (buf.id() == bufferName)
1529 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001530 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::ShaderStorage, 0, 0);
James Darpiniane8a93c62018-01-04 18:02:24 -08001531 }
1532 }
Yuly Novikov5807a532015-12-03 13:01:22 -05001533}
1534
Shannon Woods53a94a82014-06-24 15:20:36 -04001535void State::setEnableVertexAttribArray(unsigned int attribNum, bool enabled)
1536{
1537 getVertexArray()->enableAttribute(attribNum, enabled);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001538 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001539}
1540
1541void State::setVertexAttribf(GLuint index, const GLfloat values[4])
1542{
Shannon Woods23e05002014-09-22 19:07:27 -04001543 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001544 mVertexAttribCurrentValues[index].setFloatValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001545 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1546 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001547 mCurrentValuesTypeMask.setIndex(GL_FLOAT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001548}
1549
1550void State::setVertexAttribu(GLuint index, const GLuint values[4])
1551{
Shannon Woods23e05002014-09-22 19:07:27 -04001552 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001553 mVertexAttribCurrentValues[index].setUnsignedIntValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001554 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1555 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001556 mCurrentValuesTypeMask.setIndex(GL_UNSIGNED_INT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001557}
1558
1559void State::setVertexAttribi(GLuint index, const GLint values[4])
1560{
Shannon Woods23e05002014-09-22 19:07:27 -04001561 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001562 mVertexAttribCurrentValues[index].setIntValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001563 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1564 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001565 mCurrentValuesTypeMask.setIndex(GL_INT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001566}
1567
Shaodde78e82017-05-22 14:13:27 +08001568void State::setVertexAttribPointer(const Context *context,
1569 unsigned int attribNum,
1570 Buffer *boundBuffer,
1571 GLint size,
1572 GLenum type,
1573 bool normalized,
1574 bool pureInteger,
1575 GLsizei stride,
1576 const void *pointer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001577{
Shaodde78e82017-05-22 14:13:27 +08001578 getVertexArray()->setVertexAttribPointer(context, attribNum, boundBuffer, size, type,
1579 normalized, pureInteger, stride, pointer);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001580 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Jamie Madill0b9e9032015-08-17 11:51:52 +00001581}
1582
Shaodde78e82017-05-22 14:13:27 +08001583void State::setVertexAttribDivisor(const Context *context, GLuint index, GLuint divisor)
Jamie Madill0b9e9032015-08-17 11:51:52 +00001584{
Shaodde78e82017-05-22 14:13:27 +08001585 getVertexArray()->setVertexAttribDivisor(context, index, divisor);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001586 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001587}
1588
Shannon Woods53a94a82014-06-24 15:20:36 -04001589const void *State::getVertexAttribPointer(unsigned int attribNum) const
1590{
1591 return getVertexArray()->getVertexAttribute(attribNum).pointer;
1592}
1593
1594void State::setPackAlignment(GLint alignment)
1595{
1596 mPack.alignment = alignment;
Jamie Madillc67323a2017-11-02 23:11:41 -04001597 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001598}
1599
Shannon Woods53a94a82014-06-24 15:20:36 -04001600void State::setPackReverseRowOrder(bool reverseRowOrder)
1601{
1602 mPack.reverseRowOrder = reverseRowOrder;
Jamie Madillc67323a2017-11-02 23:11:41 -04001603 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001604}
1605
Minmin Gongadff67b2015-10-14 10:34:45 -04001606void State::setPackRowLength(GLint rowLength)
1607{
1608 mPack.rowLength = rowLength;
Jamie Madillc67323a2017-11-02 23:11:41 -04001609 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001610}
1611
Minmin Gongadff67b2015-10-14 10:34:45 -04001612void State::setPackSkipRows(GLint skipRows)
1613{
1614 mPack.skipRows = skipRows;
Jamie Madillc67323a2017-11-02 23:11:41 -04001615 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001616}
1617
Minmin Gongadff67b2015-10-14 10:34:45 -04001618void State::setPackSkipPixels(GLint skipPixels)
1619{
1620 mPack.skipPixels = skipPixels;
Jamie Madillc67323a2017-11-02 23:11:41 -04001621 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001622}
1623
Shannon Woods53a94a82014-06-24 15:20:36 -04001624void State::setUnpackAlignment(GLint alignment)
1625{
1626 mUnpack.alignment = alignment;
Jamie Madillc67323a2017-11-02 23:11:41 -04001627 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001628}
1629
Minmin Gongb8aee3b2015-01-27 14:42:36 -08001630void State::setUnpackRowLength(GLint rowLength)
1631{
1632 mUnpack.rowLength = rowLength;
Jamie Madillc67323a2017-11-02 23:11:41 -04001633 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongb8aee3b2015-01-27 14:42:36 -08001634}
1635
Minmin Gongadff67b2015-10-14 10:34:45 -04001636void State::setUnpackImageHeight(GLint imageHeight)
1637{
1638 mUnpack.imageHeight = imageHeight;
Jamie Madillc67323a2017-11-02 23:11:41 -04001639 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001640}
1641
Minmin Gongadff67b2015-10-14 10:34:45 -04001642void State::setUnpackSkipImages(GLint skipImages)
1643{
1644 mUnpack.skipImages = skipImages;
Jamie Madillc67323a2017-11-02 23:11:41 -04001645 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001646}
1647
Minmin Gongadff67b2015-10-14 10:34:45 -04001648void State::setUnpackSkipRows(GLint skipRows)
1649{
1650 mUnpack.skipRows = skipRows;
Jamie Madillc67323a2017-11-02 23:11:41 -04001651 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001652}
1653
Minmin Gongadff67b2015-10-14 10:34:45 -04001654void State::setUnpackSkipPixels(GLint skipPixels)
1655{
1656 mUnpack.skipPixels = skipPixels;
Jamie Madillc67323a2017-11-02 23:11:41 -04001657 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001658}
1659
Sami Väisänena797e062016-05-12 15:23:40 +03001660void State::setCoverageModulation(GLenum components)
1661{
1662 mCoverageModulation = components;
1663 mDirtyBits.set(DIRTY_BIT_COVERAGE_MODULATION);
1664}
1665
Sami Väisänene45e53b2016-05-25 10:36:04 +03001666void State::loadPathRenderingMatrix(GLenum matrixMode, const GLfloat *matrix)
1667{
1668 if (matrixMode == GL_PATH_MODELVIEW_CHROMIUM)
1669 {
1670 memcpy(mPathMatrixMV, matrix, 16 * sizeof(GLfloat));
jchen10bb2f2c42018-09-16 09:47:38 +08001671 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING);
Sami Väisänene45e53b2016-05-25 10:36:04 +03001672 }
1673 else if (matrixMode == GL_PATH_PROJECTION_CHROMIUM)
1674 {
1675 memcpy(mPathMatrixProj, matrix, 16 * sizeof(GLfloat));
jchen10bb2f2c42018-09-16 09:47:38 +08001676 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING);
Sami Väisänene45e53b2016-05-25 10:36:04 +03001677 }
1678 else
1679 {
1680 UNREACHABLE();
1681 }
1682}
1683
1684const GLfloat *State::getPathRenderingMatrix(GLenum which) const
1685{
1686 if (which == GL_PATH_MODELVIEW_MATRIX_CHROMIUM)
1687 {
1688 return mPathMatrixMV;
1689 }
1690 else if (which == GL_PATH_PROJECTION_MATRIX_CHROMIUM)
1691 {
1692 return mPathMatrixProj;
1693 }
1694
1695 UNREACHABLE();
1696 return nullptr;
1697}
1698
1699void State::setPathStencilFunc(GLenum func, GLint ref, GLuint mask)
1700{
1701 mPathStencilFunc = func;
1702 mPathStencilRef = ref;
1703 mPathStencilMask = mask;
jchen10bb2f2c42018-09-16 09:47:38 +08001704 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING);
Sami Väisänene45e53b2016-05-25 10:36:04 +03001705}
1706
Geoff Lang1d2c41d2016-10-19 16:14:46 -07001707void State::setFramebufferSRGB(bool sRGB)
1708{
1709 mFramebufferSRGB = sRGB;
1710 mDirtyBits.set(DIRTY_BIT_FRAMEBUFFER_SRGB);
1711}
1712
jchen1082af6202018-06-22 10:59:52 +08001713void State::setMaxShaderCompilerThreads(GLuint count)
1714{
1715 mMaxShaderCompilerThreads = count;
1716}
1717
Shannon Woods53a94a82014-06-24 15:20:36 -04001718void State::getBooleanv(GLenum pname, GLboolean *params)
1719{
1720 switch (pname)
1721 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001722 case GL_SAMPLE_COVERAGE_INVERT:
1723 *params = mSampleCoverageInvert;
1724 break;
1725 case GL_DEPTH_WRITEMASK:
1726 *params = mDepthStencil.depthMask;
1727 break;
1728 case GL_COLOR_WRITEMASK:
1729 params[0] = mBlend.colorMaskRed;
1730 params[1] = mBlend.colorMaskGreen;
1731 params[2] = mBlend.colorMaskBlue;
1732 params[3] = mBlend.colorMaskAlpha;
1733 break;
1734 case GL_CULL_FACE:
1735 *params = mRasterizer.cullFace;
1736 break;
1737 case GL_POLYGON_OFFSET_FILL:
1738 *params = mRasterizer.polygonOffsetFill;
1739 break;
1740 case GL_SAMPLE_ALPHA_TO_COVERAGE:
1741 *params = mBlend.sampleAlphaToCoverage;
1742 break;
1743 case GL_SAMPLE_COVERAGE:
1744 *params = mSampleCoverage;
1745 break;
1746 case GL_SAMPLE_MASK:
1747 *params = mSampleMask;
1748 break;
1749 case GL_SCISSOR_TEST:
1750 *params = mScissorTest;
1751 break;
1752 case GL_STENCIL_TEST:
1753 *params = mDepthStencil.stencilTest;
1754 break;
1755 case GL_DEPTH_TEST:
1756 *params = mDepthStencil.depthTest;
1757 break;
1758 case GL_BLEND:
1759 *params = mBlend.blend;
1760 break;
1761 case GL_DITHER:
1762 *params = mBlend.dither;
1763 break;
1764 case GL_TRANSFORM_FEEDBACK_ACTIVE:
1765 *params = getCurrentTransformFeedback()->isActive() ? GL_TRUE : GL_FALSE;
1766 break;
1767 case GL_TRANSFORM_FEEDBACK_PAUSED:
1768 *params = getCurrentTransformFeedback()->isPaused() ? GL_TRUE : GL_FALSE;
1769 break;
1770 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
1771 *params = mPrimitiveRestart;
1772 break;
1773 case GL_RASTERIZER_DISCARD:
1774 *params = isRasterizerDiscardEnabled() ? GL_TRUE : GL_FALSE;
1775 break;
1776 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
1777 *params = mDebug.isOutputSynchronous() ? GL_TRUE : GL_FALSE;
1778 break;
1779 case GL_DEBUG_OUTPUT:
1780 *params = mDebug.isOutputEnabled() ? GL_TRUE : GL_FALSE;
1781 break;
1782 case GL_MULTISAMPLE_EXT:
1783 *params = mMultiSampling;
1784 break;
1785 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
1786 *params = mSampleAlphaToOne;
1787 break;
1788 case GL_BIND_GENERATES_RESOURCE_CHROMIUM:
1789 *params = isBindGeneratesResourceEnabled() ? GL_TRUE : GL_FALSE;
1790 break;
1791 case GL_CLIENT_ARRAYS_ANGLE:
1792 *params = areClientArraysEnabled() ? GL_TRUE : GL_FALSE;
1793 break;
1794 case GL_FRAMEBUFFER_SRGB_EXT:
1795 *params = getFramebufferSRGB() ? GL_TRUE : GL_FALSE;
1796 break;
1797 case GL_ROBUST_RESOURCE_INITIALIZATION_ANGLE:
1798 *params = mRobustResourceInit ? GL_TRUE : GL_FALSE;
1799 break;
1800 case GL_PROGRAM_CACHE_ENABLED_ANGLE:
1801 *params = mProgramBinaryCacheEnabled ? GL_TRUE : GL_FALSE;
1802 break;
Lingfeng Yangd0febe72018-05-17 22:36:52 -07001803 case GL_LIGHT_MODEL_TWO_SIDE:
1804 *params = IsLightModelTwoSided(&mGLES1State);
1805 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001806 default:
1807 UNREACHABLE();
1808 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04001809 }
1810}
1811
1812void State::getFloatv(GLenum pname, GLfloat *params)
1813{
1814 // Please note: DEPTH_CLEAR_VALUE is included in our internal getFloatv implementation
1815 // because it is stored as a float, despite the fact that the GL ES 2.0 spec names
1816 // GetIntegerv as its native query function. As it would require conversion in any
1817 // case, this should make no difference to the calling application.
1818 switch (pname)
1819 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001820 case GL_LINE_WIDTH:
1821 *params = mLineWidth;
1822 break;
1823 case GL_SAMPLE_COVERAGE_VALUE:
1824 *params = mSampleCoverageValue;
1825 break;
1826 case GL_DEPTH_CLEAR_VALUE:
1827 *params = mDepthClearValue;
1828 break;
1829 case GL_POLYGON_OFFSET_FACTOR:
1830 *params = mRasterizer.polygonOffsetFactor;
1831 break;
1832 case GL_POLYGON_OFFSET_UNITS:
1833 *params = mRasterizer.polygonOffsetUnits;
1834 break;
1835 case GL_DEPTH_RANGE:
1836 params[0] = mNearZ;
1837 params[1] = mFarZ;
1838 break;
1839 case GL_COLOR_CLEAR_VALUE:
1840 params[0] = mColorClearValue.red;
1841 params[1] = mColorClearValue.green;
1842 params[2] = mColorClearValue.blue;
1843 params[3] = mColorClearValue.alpha;
1844 break;
1845 case GL_BLEND_COLOR:
1846 params[0] = mBlendColor.red;
1847 params[1] = mBlendColor.green;
1848 params[2] = mBlendColor.blue;
1849 params[3] = mBlendColor.alpha;
1850 break;
1851 case GL_MULTISAMPLE_EXT:
1852 *params = static_cast<GLfloat>(mMultiSampling);
1853 break;
1854 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
1855 *params = static_cast<GLfloat>(mSampleAlphaToOne);
1856 break;
1857 case GL_COVERAGE_MODULATION_CHROMIUM:
1858 params[0] = static_cast<GLfloat>(mCoverageModulation);
1859 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -07001860 case GL_ALPHA_TEST_REF:
1861 *params = mGLES1State.mAlphaTestRef;
1862 break;
Lingfeng Yanga43994c2018-03-29 07:21:41 -07001863 case GL_CURRENT_COLOR:
1864 {
1865 const auto &color = mGLES1State.mCurrentColor;
1866 params[0] = color.red;
1867 params[1] = color.green;
1868 params[2] = color.blue;
1869 params[3] = color.alpha;
1870 break;
1871 }
Lingfeng Yang5a7e61b2018-03-29 16:50:32 -07001872 case GL_CURRENT_NORMAL:
1873 {
1874 const auto &normal = mGLES1State.mCurrentNormal;
1875 params[0] = normal[0];
1876 params[1] = normal[1];
1877 params[2] = normal[2];
1878 break;
1879 }
Lingfeng Yang038dd532018-03-29 17:31:52 -07001880 case GL_CURRENT_TEXTURE_COORDS:
1881 {
1882 const auto &texcoord = mGLES1State.mCurrentTextureCoords[mActiveSampler];
1883 params[0] = texcoord.s;
1884 params[1] = texcoord.t;
1885 params[2] = texcoord.r;
1886 params[3] = texcoord.q;
1887 break;
1888 }
Lingfeng Yang3a41af62018-04-09 07:28:56 -07001889 case GL_MODELVIEW_MATRIX:
1890 memcpy(params, mGLES1State.mModelviewMatrices.back().data(), 16 * sizeof(GLfloat));
1891 break;
1892 case GL_PROJECTION_MATRIX:
1893 memcpy(params, mGLES1State.mProjectionMatrices.back().data(), 16 * sizeof(GLfloat));
1894 break;
1895 case GL_TEXTURE_MATRIX:
1896 memcpy(params, mGLES1State.mTextureMatrices[mActiveSampler].back().data(),
1897 16 * sizeof(GLfloat));
1898 break;
Lingfeng Yangd0febe72018-05-17 22:36:52 -07001899 case GL_LIGHT_MODEL_AMBIENT:
1900 GetLightModelParameters(&mGLES1State, pname, params);
1901 break;
Lingfeng Yang7ba3f422018-06-01 09:43:04 -07001902 case GL_FOG_MODE:
1903 case GL_FOG_DENSITY:
1904 case GL_FOG_START:
1905 case GL_FOG_END:
1906 case GL_FOG_COLOR:
1907 GetFogParameters(&mGLES1State, pname, params);
1908 break;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -07001909 case GL_POINT_SIZE:
1910 GetPointSize(&mGLES1State, params);
1911 break;
1912 case GL_POINT_SIZE_MIN:
1913 case GL_POINT_SIZE_MAX:
1914 case GL_POINT_FADE_THRESHOLD_SIZE:
1915 case GL_POINT_DISTANCE_ATTENUATION:
1916 GetPointParameter(&mGLES1State, FromGLenum<PointParameter>(pname), params);
1917 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001918 default:
1919 UNREACHABLE();
1920 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04001921 }
1922}
1923
Jamie Madill526392d2018-11-16 09:35:14 -05001924angle::Result State::getIntegerv(const Context *context, GLenum pname, GLint *params)
Shannon Woods53a94a82014-06-24 15:20:36 -04001925{
1926 if (pname >= GL_DRAW_BUFFER0_EXT && pname <= GL_DRAW_BUFFER15_EXT)
1927 {
Geoff Lang3e922062018-11-15 11:26:29 -05001928 size_t drawBuffer = (pname - GL_DRAW_BUFFER0_EXT);
1929 ASSERT(drawBuffer < mMaxDrawBuffers);
Shannon Woods53a94a82014-06-24 15:20:36 -04001930 Framebuffer *framebuffer = mDrawFramebuffer;
Geoff Lang3e922062018-11-15 11:26:29 -05001931 // The default framebuffer may have fewer draw buffer states than a user-created one. The
1932 // user is always allowed to query up to GL_MAX_DRAWBUFFERS so just return GL_NONE here if
1933 // the draw buffer is out of range for this framebuffer.
1934 *params = drawBuffer < framebuffer->getDrawbufferStateCount()
1935 ? framebuffer->getDrawBufferState(drawBuffer)
1936 : GL_NONE;
Jamie Madill526392d2018-11-16 09:35:14 -05001937 return angle::Result::Continue();
Shannon Woods53a94a82014-06-24 15:20:36 -04001938 }
1939
1940 // Please note: DEPTH_CLEAR_VALUE is not included in our internal getIntegerv implementation
1941 // because it is stored as a float, despite the fact that the GL ES 2.0 spec names
1942 // GetIntegerv as its native query function. As it would require conversion in any
1943 // case, this should make no difference to the calling application. You may find it in
1944 // State::getFloatv.
1945 switch (pname)
1946 {
Corentin Wallez336129f2017-10-17 15:55:40 -04001947 case GL_ARRAY_BUFFER_BINDING:
1948 *params = mBoundBuffers[BufferBinding::Array].id();
1949 break;
1950 case GL_DRAW_INDIRECT_BUFFER_BINDING:
1951 *params = mBoundBuffers[BufferBinding::DrawIndirect].id();
1952 break;
1953 case GL_ELEMENT_ARRAY_BUFFER_BINDING:
Jamie Madillcd0a0a32018-10-18 18:41:57 -04001954 {
1955 Buffer *elementArrayBuffer = getVertexArray()->getElementArrayBuffer();
1956 *params = elementArrayBuffer ? elementArrayBuffer->id() : 0;
Corentin Wallez336129f2017-10-17 15:55:40 -04001957 break;
Jamie Madillcd0a0a32018-10-18 18:41:57 -04001958 }
Jamie Madill690c8eb2018-03-12 15:20:03 -04001959 case GL_DRAW_FRAMEBUFFER_BINDING:
1960 static_assert(GL_DRAW_FRAMEBUFFER_BINDING == GL_DRAW_FRAMEBUFFER_BINDING_ANGLE,
1961 "Enum mismatch");
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001962 *params = mDrawFramebuffer->id();
1963 break;
Jamie Madill690c8eb2018-03-12 15:20:03 -04001964 case GL_READ_FRAMEBUFFER_BINDING:
1965 static_assert(GL_READ_FRAMEBUFFER_BINDING == GL_READ_FRAMEBUFFER_BINDING_ANGLE,
1966 "Enum mismatch");
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001967 *params = mReadFramebuffer->id();
1968 break;
1969 case GL_RENDERBUFFER_BINDING:
1970 *params = mRenderbuffer.id();
1971 break;
1972 case GL_VERTEX_ARRAY_BINDING:
1973 *params = mVertexArray->id();
1974 break;
1975 case GL_CURRENT_PROGRAM:
1976 *params = mProgram ? mProgram->id() : 0;
1977 break;
1978 case GL_PACK_ALIGNMENT:
1979 *params = mPack.alignment;
1980 break;
1981 case GL_PACK_REVERSE_ROW_ORDER_ANGLE:
1982 *params = mPack.reverseRowOrder;
1983 break;
1984 case GL_PACK_ROW_LENGTH:
1985 *params = mPack.rowLength;
1986 break;
1987 case GL_PACK_SKIP_ROWS:
1988 *params = mPack.skipRows;
1989 break;
1990 case GL_PACK_SKIP_PIXELS:
1991 *params = mPack.skipPixels;
1992 break;
1993 case GL_UNPACK_ALIGNMENT:
1994 *params = mUnpack.alignment;
1995 break;
1996 case GL_UNPACK_ROW_LENGTH:
1997 *params = mUnpack.rowLength;
1998 break;
1999 case GL_UNPACK_IMAGE_HEIGHT:
2000 *params = mUnpack.imageHeight;
2001 break;
2002 case GL_UNPACK_SKIP_IMAGES:
2003 *params = mUnpack.skipImages;
2004 break;
2005 case GL_UNPACK_SKIP_ROWS:
2006 *params = mUnpack.skipRows;
2007 break;
2008 case GL_UNPACK_SKIP_PIXELS:
2009 *params = mUnpack.skipPixels;
2010 break;
2011 case GL_GENERATE_MIPMAP_HINT:
2012 *params = mGenerateMipmapHint;
2013 break;
2014 case GL_FRAGMENT_SHADER_DERIVATIVE_HINT_OES:
2015 *params = mFragmentShaderDerivativeHint;
2016 break;
2017 case GL_ACTIVE_TEXTURE:
2018 *params = (static_cast<GLint>(mActiveSampler) + GL_TEXTURE0);
2019 break;
2020 case GL_STENCIL_FUNC:
2021 *params = mDepthStencil.stencilFunc;
2022 break;
2023 case GL_STENCIL_REF:
2024 *params = mStencilRef;
2025 break;
2026 case GL_STENCIL_VALUE_MASK:
2027 *params = CastMaskValue(context, mDepthStencil.stencilMask);
2028 break;
2029 case GL_STENCIL_BACK_FUNC:
2030 *params = mDepthStencil.stencilBackFunc;
2031 break;
2032 case GL_STENCIL_BACK_REF:
2033 *params = mStencilBackRef;
2034 break;
2035 case GL_STENCIL_BACK_VALUE_MASK:
2036 *params = CastMaskValue(context, mDepthStencil.stencilBackMask);
2037 break;
2038 case GL_STENCIL_FAIL:
2039 *params = mDepthStencil.stencilFail;
2040 break;
2041 case GL_STENCIL_PASS_DEPTH_FAIL:
2042 *params = mDepthStencil.stencilPassDepthFail;
2043 break;
2044 case GL_STENCIL_PASS_DEPTH_PASS:
2045 *params = mDepthStencil.stencilPassDepthPass;
2046 break;
2047 case GL_STENCIL_BACK_FAIL:
2048 *params = mDepthStencil.stencilBackFail;
2049 break;
2050 case GL_STENCIL_BACK_PASS_DEPTH_FAIL:
2051 *params = mDepthStencil.stencilBackPassDepthFail;
2052 break;
2053 case GL_STENCIL_BACK_PASS_DEPTH_PASS:
2054 *params = mDepthStencil.stencilBackPassDepthPass;
2055 break;
2056 case GL_DEPTH_FUNC:
2057 *params = mDepthStencil.depthFunc;
2058 break;
2059 case GL_BLEND_SRC_RGB:
2060 *params = mBlend.sourceBlendRGB;
2061 break;
2062 case GL_BLEND_SRC_ALPHA:
2063 *params = mBlend.sourceBlendAlpha;
2064 break;
2065 case GL_BLEND_DST_RGB:
2066 *params = mBlend.destBlendRGB;
2067 break;
2068 case GL_BLEND_DST_ALPHA:
2069 *params = mBlend.destBlendAlpha;
2070 break;
2071 case GL_BLEND_EQUATION_RGB:
2072 *params = mBlend.blendEquationRGB;
2073 break;
2074 case GL_BLEND_EQUATION_ALPHA:
2075 *params = mBlend.blendEquationAlpha;
2076 break;
2077 case GL_STENCIL_WRITEMASK:
2078 *params = CastMaskValue(context, mDepthStencil.stencilWritemask);
2079 break;
2080 case GL_STENCIL_BACK_WRITEMASK:
2081 *params = CastMaskValue(context, mDepthStencil.stencilBackWritemask);
2082 break;
2083 case GL_STENCIL_CLEAR_VALUE:
2084 *params = mStencilClearValue;
2085 break;
2086 case GL_IMPLEMENTATION_COLOR_READ_TYPE:
Jamie Madill690c8eb2018-03-12 15:20:03 -04002087 ANGLE_TRY(mReadFramebuffer->getImplementationColorReadType(
2088 context, reinterpret_cast<GLenum *>(params)));
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002089 break;
2090 case GL_IMPLEMENTATION_COLOR_READ_FORMAT:
Jamie Madill690c8eb2018-03-12 15:20:03 -04002091 ANGLE_TRY(mReadFramebuffer->getImplementationColorReadFormat(
2092 context, reinterpret_cast<GLenum *>(params)));
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002093 break;
2094 case GL_SAMPLE_BUFFERS:
2095 case GL_SAMPLES:
Shannon Woods53a94a82014-06-24 15:20:36 -04002096 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002097 Framebuffer *framebuffer = mDrawFramebuffer;
Jamie Madill427064d2018-04-13 16:20:34 -04002098 if (framebuffer->isComplete(context))
Shannon Woods53a94a82014-06-24 15:20:36 -04002099 {
Jamie Madill427064d2018-04-13 16:20:34 -04002100 GLint samples = framebuffer->getSamples(context);
Shannon Woods53a94a82014-06-24 15:20:36 -04002101 switch (pname)
2102 {
Jamie Madilla0016b72017-07-14 14:30:46 -04002103 case GL_SAMPLE_BUFFERS:
Jamie Madille98b1b52018-03-08 09:47:23 -05002104 if (samples != 0)
Jamie Madilla0016b72017-07-14 14:30:46 -04002105 {
2106 *params = 1;
2107 }
2108 else
2109 {
2110 *params = 0;
2111 }
2112 break;
2113 case GL_SAMPLES:
Jamie Madille98b1b52018-03-08 09:47:23 -05002114 *params = samples;
Jamie Madilla0016b72017-07-14 14:30:46 -04002115 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002116 }
2117 }
2118 else
2119 {
2120 *params = 0;
2121 }
2122 }
2123 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002124 case GL_VIEWPORT:
2125 params[0] = mViewport.x;
2126 params[1] = mViewport.y;
2127 params[2] = mViewport.width;
2128 params[3] = mViewport.height;
2129 break;
2130 case GL_SCISSOR_BOX:
2131 params[0] = mScissor.x;
2132 params[1] = mScissor.y;
2133 params[2] = mScissor.width;
2134 params[3] = mScissor.height;
2135 break;
2136 case GL_CULL_FACE_MODE:
2137 *params = ToGLenum(mRasterizer.cullMode);
2138 break;
2139 case GL_FRONT_FACE:
2140 *params = mRasterizer.frontFace;
2141 break;
2142 case GL_RED_BITS:
2143 case GL_GREEN_BITS:
2144 case GL_BLUE_BITS:
2145 case GL_ALPHA_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002146 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002147 Framebuffer *framebuffer = getDrawFramebuffer();
2148 const FramebufferAttachment *colorbuffer = framebuffer->getFirstColorbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002149
2150 if (colorbuffer)
2151 {
2152 switch (pname)
2153 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002154 case GL_RED_BITS:
2155 *params = colorbuffer->getRedSize();
2156 break;
2157 case GL_GREEN_BITS:
2158 *params = colorbuffer->getGreenSize();
2159 break;
2160 case GL_BLUE_BITS:
2161 *params = colorbuffer->getBlueSize();
2162 break;
2163 case GL_ALPHA_BITS:
2164 *params = colorbuffer->getAlphaSize();
2165 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002166 }
2167 }
2168 else
2169 {
2170 *params = 0;
2171 }
2172 }
2173 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002174 case GL_DEPTH_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002175 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002176 const Framebuffer *framebuffer = getDrawFramebuffer();
2177 const FramebufferAttachment *depthbuffer = framebuffer->getDepthbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002178
2179 if (depthbuffer)
2180 {
2181 *params = depthbuffer->getDepthSize();
2182 }
2183 else
2184 {
2185 *params = 0;
2186 }
2187 }
2188 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002189 case GL_STENCIL_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002190 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002191 const Framebuffer *framebuffer = getDrawFramebuffer();
2192 const FramebufferAttachment *stencilbuffer = framebuffer->getStencilbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002193
2194 if (stencilbuffer)
2195 {
2196 *params = stencilbuffer->getStencilSize();
2197 }
2198 else
2199 {
2200 *params = 0;
2201 }
2202 }
2203 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002204 case GL_TEXTURE_BINDING_2D:
2205 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2206 *params =
2207 getSamplerTextureId(static_cast<unsigned int>(mActiveSampler), TextureType::_2D);
2208 break;
2209 case GL_TEXTURE_BINDING_RECTANGLE_ANGLE:
2210 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2211 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2212 TextureType::Rectangle);
2213 break;
2214 case GL_TEXTURE_BINDING_CUBE_MAP:
2215 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2216 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2217 TextureType::CubeMap);
2218 break;
2219 case GL_TEXTURE_BINDING_3D:
2220 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2221 *params =
2222 getSamplerTextureId(static_cast<unsigned int>(mActiveSampler), TextureType::_3D);
2223 break;
2224 case GL_TEXTURE_BINDING_2D_ARRAY:
2225 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2226 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2227 TextureType::_2DArray);
2228 break;
2229 case GL_TEXTURE_BINDING_2D_MULTISAMPLE:
2230 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2231 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2232 TextureType::_2DMultisample);
2233 break;
Olli Etuahodff32a02018-08-28 14:35:50 +03002234 case GL_TEXTURE_BINDING_2D_MULTISAMPLE_ARRAY:
2235 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2236 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2237 TextureType::_2DMultisampleArray);
2238 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002239 case GL_TEXTURE_BINDING_EXTERNAL_OES:
2240 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2241 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2242 TextureType::External);
2243 break;
2244 case GL_UNIFORM_BUFFER_BINDING:
2245 *params = mBoundBuffers[BufferBinding::Uniform].id();
2246 break;
2247 case GL_TRANSFORM_FEEDBACK_BINDING:
2248 *params = mTransformFeedback.id();
2249 break;
2250 case GL_TRANSFORM_FEEDBACK_BUFFER_BINDING:
2251 *params = mBoundBuffers[BufferBinding::TransformFeedback].id();
2252 break;
2253 case GL_COPY_READ_BUFFER_BINDING:
2254 *params = mBoundBuffers[BufferBinding::CopyRead].id();
2255 break;
2256 case GL_COPY_WRITE_BUFFER_BINDING:
2257 *params = mBoundBuffers[BufferBinding::CopyWrite].id();
2258 break;
2259 case GL_PIXEL_PACK_BUFFER_BINDING:
2260 *params = mBoundBuffers[BufferBinding::PixelPack].id();
2261 break;
2262 case GL_PIXEL_UNPACK_BUFFER_BINDING:
2263 *params = mBoundBuffers[BufferBinding::PixelUnpack].id();
2264 break;
2265 case GL_READ_BUFFER:
2266 *params = mReadFramebuffer->getReadBufferState();
2267 break;
2268 case GL_SAMPLER_BINDING:
2269 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2270 *params = getSamplerId(static_cast<GLuint>(mActiveSampler));
2271 break;
2272 case GL_DEBUG_LOGGED_MESSAGES:
2273 *params = static_cast<GLint>(mDebug.getMessageCount());
2274 break;
2275 case GL_DEBUG_NEXT_LOGGED_MESSAGE_LENGTH:
2276 *params = static_cast<GLint>(mDebug.getNextMessageLength());
2277 break;
2278 case GL_DEBUG_GROUP_STACK_DEPTH:
2279 *params = static_cast<GLint>(mDebug.getGroupStackDepth());
2280 break;
2281 case GL_MULTISAMPLE_EXT:
2282 *params = static_cast<GLint>(mMultiSampling);
2283 break;
2284 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
2285 *params = static_cast<GLint>(mSampleAlphaToOne);
2286 break;
2287 case GL_COVERAGE_MODULATION_CHROMIUM:
2288 *params = static_cast<GLint>(mCoverageModulation);
2289 break;
2290 case GL_ATOMIC_COUNTER_BUFFER_BINDING:
2291 *params = mBoundBuffers[BufferBinding::AtomicCounter].id();
2292 break;
2293 case GL_SHADER_STORAGE_BUFFER_BINDING:
2294 *params = mBoundBuffers[BufferBinding::ShaderStorage].id();
2295 break;
2296 case GL_DISPATCH_INDIRECT_BUFFER_BINDING:
2297 *params = mBoundBuffers[BufferBinding::DispatchIndirect].id();
2298 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -07002299 case GL_ALPHA_TEST_FUNC:
2300 *params = ToGLenum(mGLES1State.mAlphaTestFunc);
2301 break;
Lingfeng Yang96310cd2018-03-28 11:56:28 -07002302 case GL_CLIENT_ACTIVE_TEXTURE:
2303 *params = mGLES1State.mClientActiveTexture + GL_TEXTURE0;
2304 break;
Lingfeng Yangd2488ab2018-04-04 09:25:48 -07002305 case GL_MATRIX_MODE:
2306 *params = ToGLenum(mGLES1State.mMatrixMode);
2307 break;
Lingfeng Yanga0cfa872018-05-30 21:12:17 -07002308 case GL_SHADE_MODEL:
2309 *params = ToGLenum(mGLES1State.mShadeModel);
2310 break;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -07002311 case GL_MODELVIEW_STACK_DEPTH:
2312 case GL_PROJECTION_STACK_DEPTH:
2313 case GL_TEXTURE_STACK_DEPTH:
2314 *params = mGLES1State.getCurrentMatrixStackDepth(pname);
2315 break;
2316 case GL_LOGIC_OP_MODE:
2317 *params = ToGLenum(mGLES1State.mLogicOp);
2318 break;
2319 case GL_BLEND_SRC:
2320 *params = mBlend.sourceBlendRGB;
2321 break;
2322 case GL_BLEND_DST:
2323 *params = mBlend.destBlendRGB;
2324 break;
2325 case GL_PERSPECTIVE_CORRECTION_HINT:
2326 case GL_POINT_SMOOTH_HINT:
2327 case GL_LINE_SMOOTH_HINT:
2328 case GL_FOG_HINT:
2329 *params = mGLES1State.getHint(pname);
2330 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002331 default:
2332 UNREACHABLE();
2333 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002334 }
Jamie Madille98b1b52018-03-08 09:47:23 -05002335
Jamie Madill526392d2018-11-16 09:35:14 -05002336 return angle::Result::Continue();
Shannon Woods53a94a82014-06-24 15:20:36 -04002337}
2338
Lingfeng Yangabb09f12018-04-16 10:43:53 -07002339void State::getPointerv(const Context *context, GLenum pname, void **params) const
Geoff Lang70d0f492015-12-10 17:45:46 -05002340{
2341 switch (pname)
2342 {
2343 case GL_DEBUG_CALLBACK_FUNCTION:
2344 *params = reinterpret_cast<void *>(mDebug.getCallback());
2345 break;
2346 case GL_DEBUG_CALLBACK_USER_PARAM:
2347 *params = const_cast<void *>(mDebug.getUserParam());
2348 break;
Lingfeng Yangabb09f12018-04-16 10:43:53 -07002349 case GL_VERTEX_ARRAY_POINTER:
2350 case GL_NORMAL_ARRAY_POINTER:
2351 case GL_COLOR_ARRAY_POINTER:
2352 case GL_TEXTURE_COORD_ARRAY_POINTER:
2353 case GL_POINT_SIZE_ARRAY_POINTER_OES:
2354 QueryVertexAttribPointerv(getVertexArray()->getVertexAttribute(
2355 context->vertexArrayIndex(ParamToVertexArrayType(pname))),
2356 GL_VERTEX_ATTRIB_ARRAY_POINTER, params);
2357 return;
Geoff Lang70d0f492015-12-10 17:45:46 -05002358 default:
2359 UNREACHABLE();
2360 break;
2361 }
2362}
2363
Martin Radev66fb8202016-07-28 11:45:20 +03002364void State::getIntegeri_v(GLenum target, GLuint index, GLint *data)
Shannon Woods53a94a82014-06-24 15:20:36 -04002365{
2366 switch (target)
2367 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002368 case GL_TRANSFORM_FEEDBACK_BUFFER_BINDING:
2369 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2370 *data = mTransformFeedback->getIndexedBuffer(index).id();
2371 break;
2372 case GL_UNIFORM_BUFFER_BINDING:
2373 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2374 *data = mUniformBuffers[index].id();
2375 break;
2376 case GL_ATOMIC_COUNTER_BUFFER_BINDING:
2377 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2378 *data = mAtomicCounterBuffers[index].id();
2379 break;
2380 case GL_SHADER_STORAGE_BUFFER_BINDING:
2381 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2382 *data = mShaderStorageBuffers[index].id();
2383 break;
2384 case GL_VERTEX_BINDING_BUFFER:
2385 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2386 *data = mVertexArray->getVertexBinding(index).getBuffer().id();
2387 break;
2388 case GL_VERTEX_BINDING_DIVISOR:
2389 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2390 *data = mVertexArray->getVertexBinding(index).getDivisor();
2391 break;
2392 case GL_VERTEX_BINDING_OFFSET:
2393 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2394 *data = static_cast<GLuint>(mVertexArray->getVertexBinding(index).getOffset());
2395 break;
2396 case GL_VERTEX_BINDING_STRIDE:
2397 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2398 *data = mVertexArray->getVertexBinding(index).getStride();
2399 break;
2400 case GL_SAMPLE_MASK_VALUE:
2401 ASSERT(static_cast<size_t>(index) < mSampleMaskValues.size());
2402 *data = mSampleMaskValues[index];
2403 break;
2404 case GL_IMAGE_BINDING_NAME:
2405 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2406 *data = mImageUnits[index].texture.id();
2407 break;
2408 case GL_IMAGE_BINDING_LEVEL:
2409 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2410 *data = mImageUnits[index].level;
2411 break;
2412 case GL_IMAGE_BINDING_LAYER:
2413 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2414 *data = mImageUnits[index].layer;
2415 break;
2416 case GL_IMAGE_BINDING_ACCESS:
2417 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2418 *data = mImageUnits[index].access;
2419 break;
2420 case GL_IMAGE_BINDING_FORMAT:
2421 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2422 *data = mImageUnits[index].format;
2423 break;
2424 default:
2425 UNREACHABLE();
2426 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002427 }
Shannon Woods53a94a82014-06-24 15:20:36 -04002428}
2429
Martin Radev66fb8202016-07-28 11:45:20 +03002430void State::getInteger64i_v(GLenum target, GLuint index, GLint64 *data)
Shannon Woods53a94a82014-06-24 15:20:36 -04002431{
2432 switch (target)
2433 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002434 case GL_TRANSFORM_FEEDBACK_BUFFER_START:
2435 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2436 *data = mTransformFeedback->getIndexedBuffer(index).getOffset();
2437 break;
2438 case GL_TRANSFORM_FEEDBACK_BUFFER_SIZE:
2439 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2440 *data = mTransformFeedback->getIndexedBuffer(index).getSize();
2441 break;
2442 case GL_UNIFORM_BUFFER_START:
2443 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2444 *data = mUniformBuffers[index].getOffset();
2445 break;
2446 case GL_UNIFORM_BUFFER_SIZE:
2447 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2448 *data = mUniformBuffers[index].getSize();
2449 break;
2450 case GL_ATOMIC_COUNTER_BUFFER_START:
2451 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2452 *data = mAtomicCounterBuffers[index].getOffset();
2453 break;
2454 case GL_ATOMIC_COUNTER_BUFFER_SIZE:
2455 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2456 *data = mAtomicCounterBuffers[index].getSize();
2457 break;
2458 case GL_SHADER_STORAGE_BUFFER_START:
2459 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2460 *data = mShaderStorageBuffers[index].getOffset();
2461 break;
2462 case GL_SHADER_STORAGE_BUFFER_SIZE:
2463 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2464 *data = mShaderStorageBuffers[index].getSize();
2465 break;
2466 default:
2467 UNREACHABLE();
2468 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002469 }
Martin Radev66fb8202016-07-28 11:45:20 +03002470}
Shannon Woods53a94a82014-06-24 15:20:36 -04002471
Martin Radev66fb8202016-07-28 11:45:20 +03002472void State::getBooleani_v(GLenum target, GLuint index, GLboolean *data)
2473{
Xinghua Cao9c8e1a32017-12-06 17:59:58 +08002474 switch (target)
2475 {
2476 case GL_IMAGE_BINDING_LAYERED:
2477 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2478 *data = mImageUnits[index].layered;
2479 break;
2480 default:
2481 UNREACHABLE();
2482 break;
2483 }
Shannon Woods53a94a82014-06-24 15:20:36 -04002484}
2485
Jamie Madill9e63a812018-11-16 12:30:04 +00002486angle::Result State::syncDirtyObjects(const Context *context, const DirtyObjects &bitset)
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002487{
Jamie Madill9e63a812018-11-16 12:30:04 +00002488 const DirtyObjects &dirtyObjects = mDirtyObjects & bitset;
2489 for (auto dirtyObject : dirtyObjects)
Jamie Madillc9d442d2016-01-20 11:17:24 -05002490 {
2491 switch (dirtyObject)
2492 {
2493 case DIRTY_OBJECT_READ_FRAMEBUFFER:
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002494 ASSERT(mReadFramebuffer);
Jamie Madill19fa1c62018-03-08 09:47:21 -05002495 ANGLE_TRY(mReadFramebuffer->syncState(context));
Jamie Madillc9d442d2016-01-20 11:17:24 -05002496 break;
2497 case DIRTY_OBJECT_DRAW_FRAMEBUFFER:
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002498 ASSERT(mDrawFramebuffer);
Jamie Madill19fa1c62018-03-08 09:47:21 -05002499 ANGLE_TRY(mDrawFramebuffer->syncState(context));
Jamie Madillc9d442d2016-01-20 11:17:24 -05002500 break;
2501 case DIRTY_OBJECT_VERTEX_ARRAY:
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002502 ASSERT(mVertexArray);
Frank Henigman0af5b862018-03-27 20:19:33 -04002503 ANGLE_TRY(mVertexArray->syncState(context));
Jamie Madillc9d442d2016-01-20 11:17:24 -05002504 break;
Jamie Madille25b8002018-09-20 13:39:49 -04002505 case DIRTY_OBJECT_SAMPLERS:
2506 syncSamplers(context);
2507 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002508 case DIRTY_OBJECT_PROGRAM_TEXTURES:
Luc Ferron4bba74f2018-04-19 14:40:45 -04002509 ANGLE_TRY(syncProgramTextures(context));
Jamie Madill81c2e252017-09-09 23:32:46 -04002510 break;
Jamie Madill70aeda42018-08-20 12:17:40 -04002511 case DIRTY_OBJECT_PROGRAM:
2512 ANGLE_TRY(mProgram->syncState(context));
2513 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002514
Jamie Madillc9d442d2016-01-20 11:17:24 -05002515 default:
2516 UNREACHABLE();
2517 break;
2518 }
2519 }
2520
Jiajia Qin5ae6ee42018-03-06 17:39:42 +08002521 mDirtyObjects &= ~dirtyObjects;
Jamie Madill6f755b22018-10-09 12:48:54 -04002522 return angle::Result::Continue();
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002523}
2524
Jamie Madille25b8002018-09-20 13:39:49 -04002525void State::syncSamplers(const Context *context)
2526{
2527 if (mDirtySamplers.none())
2528 return;
2529
2530 // This could be optimized by tracking which samplers are dirty.
2531 for (size_t samplerIndex : mDirtySamplers)
2532 {
2533 BindingPointer<Sampler> &sampler = mSamplers[samplerIndex];
2534 if (sampler.get())
2535 {
2536 sampler->syncState(context);
2537 }
2538 }
2539
2540 mDirtySamplers.reset();
2541}
2542
Jamie Madill6f755b22018-10-09 12:48:54 -04002543angle::Result State::syncProgramTextures(const Context *context)
Jamie Madill81c2e252017-09-09 23:32:46 -04002544{
Jamie Madill81c2e252017-09-09 23:32:46 -04002545 // TODO(jmadill): Fine-grained updates.
2546 if (!mProgram)
2547 {
Jamie Madill6f755b22018-10-09 12:48:54 -04002548 return angle::Result::Continue();
Jamie Madill81c2e252017-09-09 23:32:46 -04002549 }
2550
2551 ASSERT(mDirtyObjects[DIRTY_OBJECT_PROGRAM_TEXTURES]);
2552 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
2553
Jamie Madill0f80ed82017-09-19 00:24:56 -04002554 ActiveTextureMask newActiveTextures;
2555
Geoff Lange51ba632017-11-21 11:45:25 -05002556 // Initialize to the 'Initialized' state and set to 'MayNeedInit' if any texture is not
2557 // initialized.
Yizhou Jiang7818a852018-09-06 15:02:04 +08002558 mCachedTexturesInitState = InitState::Initialized;
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002559 mCachedImageTexturesInitState = InitState::Initialized;
Geoff Lange51ba632017-11-21 11:45:25 -05002560
Jamie Madill7e4eff12018-08-08 15:49:26 -04002561 const ActiveTextureMask &activeTextures = mProgram->getActiveSamplersMask();
2562 const ActiveTextureArray<TextureType> &textureTypes = mProgram->getActiveSamplerTypes();
2563
2564 for (size_t textureUnitIndex : activeTextures)
Jamie Madill81c2e252017-09-09 23:32:46 -04002565 {
Jamie Madill7e4eff12018-08-08 15:49:26 -04002566 TextureType textureType = textureTypes[textureUnitIndex];
Jamie Madill81c2e252017-09-09 23:32:46 -04002567
jchen1090f466a2018-08-13 15:05:25 +08002568 Texture *texture =
2569 getSamplerTexture(static_cast<unsigned int>(textureUnitIndex), textureType);
Jamie Madill7e4eff12018-08-08 15:49:26 -04002570 ASSERT(static_cast<size_t>(textureUnitIndex) < newActiveTextures.size());
2571
2572 ASSERT(texture);
2573
Jamie Madill7e4eff12018-08-08 15:49:26 -04002574 newActiveTextures.set(textureUnitIndex);
Jamie Madille3bb6b72018-10-03 17:51:15 -04002575 ANGLE_TRY(updateActiveTexture(context, textureUnitIndex, texture));
Jamie Madill81c2e252017-09-09 23:32:46 -04002576 }
Jamie Madill0f80ed82017-09-19 00:24:56 -04002577
2578 // Unset now missing textures.
Jamie Madill7e4eff12018-08-08 15:49:26 -04002579 ActiveTextureMask negativeMask = activeTextures & ~newActiveTextures;
Jamie Madill0f80ed82017-09-19 00:24:56 -04002580 if (negativeMask.any())
2581 {
Jamie Madille3bb6b72018-10-03 17:51:15 -04002582 unsetActiveTextures(negativeMask);
Jamie Madill0f80ed82017-09-19 00:24:56 -04002583 }
Luc Ferron4bba74f2018-04-19 14:40:45 -04002584
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002585 for (size_t imageUnitIndex : mProgram->getActiveImagesMask())
2586 {
2587 Texture *texture = mImageUnits[imageUnitIndex].texture.get();
2588 if (!texture)
2589 {
2590 continue;
2591 }
Jamie Madillf668a4b2018-09-23 17:01:20 -04002592 if (texture->hasAnyDirtyBit())
2593 {
2594 ANGLE_TRY(texture->syncState(context));
2595 }
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002596 if (texture->initState() == InitState::MayNeedInit)
2597 {
2598 mCachedImageTexturesInitState = InitState::MayNeedInit;
2599 }
2600 }
2601
Jamie Madill6f755b22018-10-09 12:48:54 -04002602 return angle::Result::Continue();
Jamie Madill81c2e252017-09-09 23:32:46 -04002603}
2604
Jamie Madill6f755b22018-10-09 12:48:54 -04002605angle::Result State::syncDirtyObject(const Context *context, GLenum target)
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002606{
2607 DirtyObjects localSet;
2608
2609 switch (target)
2610 {
2611 case GL_READ_FRAMEBUFFER:
2612 localSet.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2613 break;
2614 case GL_DRAW_FRAMEBUFFER:
2615 localSet.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2616 break;
2617 case GL_FRAMEBUFFER:
2618 localSet.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2619 localSet.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2620 break;
2621 case GL_VERTEX_ARRAY:
2622 localSet.set(DIRTY_OBJECT_VERTEX_ARRAY);
2623 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002624 case GL_TEXTURE:
Jamie Madille25b8002018-09-20 13:39:49 -04002625 localSet.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
2626 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002627 case GL_SAMPLER:
Jamie Madill70aeda42018-08-20 12:17:40 -04002628 localSet.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Jamie Madille25b8002018-09-20 13:39:49 -04002629 localSet.set(DIRTY_OBJECT_SAMPLERS);
Jamie Madill70aeda42018-08-20 12:17:40 -04002630 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002631 case GL_PROGRAM:
2632 localSet.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Jamie Madill70aeda42018-08-20 12:17:40 -04002633 localSet.set(DIRTY_OBJECT_PROGRAM);
Jamie Madill81c2e252017-09-09 23:32:46 -04002634 break;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002635 }
2636
Jamie Madillbc918e72018-03-08 09:47:21 -05002637 return syncDirtyObjects(context, localSet);
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002638}
2639
2640void State::setObjectDirty(GLenum target)
2641{
2642 switch (target)
2643 {
2644 case GL_READ_FRAMEBUFFER:
2645 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2646 break;
2647 case GL_DRAW_FRAMEBUFFER:
2648 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2649 break;
2650 case GL_FRAMEBUFFER:
2651 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2652 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2653 break;
2654 case GL_VERTEX_ARRAY:
2655 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
2656 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002657 case GL_TEXTURE:
Jamie Madill70aeda42018-08-20 12:17:40 -04002658 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
2659 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
2660 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002661 case GL_PROGRAM:
2662 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Jamie Madill70aeda42018-08-20 12:17:40 -04002663 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM);
Jamie Madill81c2e252017-09-09 23:32:46 -04002664 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
2665 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();
2695 ANGLE_TRY(updateActiveTexture(context, textureIndex, texture));
2696 }
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
2709 if (image->initState() == InitState::MayNeedInit)
2710 {
2711 mCachedImageTexturesInitState = InitState::MayNeedInit;
2712 }
2713 }
2714
Jamie Madill6f755b22018-10-09 12:48:54 -04002715 return angle::Result::Continue();
Shannon Woods53a94a82014-06-24 15:20:36 -04002716}
Jamie Madillc9d442d2016-01-20 11:17:24 -05002717
Jamie Madille25b8002018-09-20 13:39:49 -04002718void State::setSamplerDirty(size_t samplerIndex)
2719{
2720 mDirtyObjects.set(DIRTY_OBJECT_SAMPLERS);
2721 mDirtySamplers.set(samplerIndex);
2722}
2723
Xinghua Cao65ec0b22017-03-28 16:10:52 +08002724void State::setImageUnit(const Context *context,
Will Harris63aa0e52018-09-05 16:15:46 -07002725 size_t unit,
Xinghua Cao65ec0b22017-03-28 16:10:52 +08002726 Texture *texture,
2727 GLint level,
2728 GLboolean layered,
2729 GLint layer,
2730 GLenum access,
2731 GLenum format)
2732{
2733 mImageUnits[unit].texture.set(context, texture);
2734 mImageUnits[unit].level = level;
2735 mImageUnits[unit].layered = layered;
2736 mImageUnits[unit].layer = layer;
2737 mImageUnits[unit].access = access;
2738 mImageUnits[unit].format = format;
jchen1099118c12018-09-10 16:28:51 +08002739 mDirtyBits.set(DIRTY_BIT_IMAGE_BINDINGS);
Xinghua Cao65ec0b22017-03-28 16:10:52 +08002740}
2741
Jamie Madill81c2e252017-09-09 23:32:46 -04002742// Handle a dirty texture event.
Jamie Madill6c43a012018-08-08 15:49:27 -04002743void State::onActiveTextureStateChange(size_t textureIndex)
Jamie Madill81c2e252017-09-09 23:32:46 -04002744{
2745 // Conservatively assume all textures are dirty.
2746 // TODO(jmadill): More fine-grained update.
2747 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Geoff Lange51ba632017-11-21 11:45:25 -05002748
Jamie Madill6c43a012018-08-08 15:49:27 -04002749 if (!mActiveTexturesCache[textureIndex] ||
2750 mActiveTexturesCache[textureIndex]->initState() == InitState::MayNeedInit)
Geoff Lange51ba632017-11-21 11:45:25 -05002751 {
2752 mCachedTexturesInitState = InitState::MayNeedInit;
2753 }
Jamie Madill81c2e252017-09-09 23:32:46 -04002754}
2755
Jamie Madill6d32cef2018-08-14 02:34:28 -04002756void State::onUniformBufferStateChange(size_t uniformBufferIndex)
2757{
2758 // This could be represented by a different dirty bit. Using the same one keeps it simple.
2759 mDirtyBits.set(DIRTY_BIT_UNIFORM_BUFFER_BINDINGS);
2760}
2761
Jamie Madill6f755b22018-10-09 12:48:54 -04002762angle::Result State::clearUnclearedActiveTextures(const Context *context)
Jamie Madill05b35b22017-10-03 09:01:44 -04002763{
Jamie Madilla59fc192017-11-02 12:57:58 -04002764 ASSERT(mRobustResourceInit);
Geoff Lang9bf86f02018-07-26 11:46:34 -04002765 ASSERT(!mDirtyObjects[DIRTY_OBJECT_PROGRAM_TEXTURES]);
Geoff Langd4fff502017-09-22 11:28:28 -04002766
Jamie Madill7e4eff12018-08-08 15:49:26 -04002767 if (!mProgram)
Jamie Madill6f755b22018-10-09 12:48:54 -04002768 return angle::Result::Continue();
Jamie Madill7e4eff12018-08-08 15:49:26 -04002769
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002770 if (mCachedTexturesInitState != InitState::Initialized)
Jamie Madill05b35b22017-10-03 09:01:44 -04002771 {
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002772 for (size_t textureUnitIndex : mProgram->getActiveSamplersMask())
Jamie Madill05b35b22017-10-03 09:01:44 -04002773 {
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002774 Texture *texture = mActiveTexturesCache[textureUnitIndex];
2775 if (texture)
2776 {
2777 ANGLE_TRY(texture->ensureInitialized(context));
2778 }
Jamie Madill05b35b22017-10-03 09:01:44 -04002779 }
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002780 mCachedTexturesInitState = InitState::Initialized;
Jamie Madill05b35b22017-10-03 09:01:44 -04002781 }
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002782 if (mCachedImageTexturesInitState != InitState::Initialized)
2783 {
2784 for (size_t imageUnitIndex : mProgram->getActiveImagesMask())
2785 {
2786 Texture *texture = mImageUnits[imageUnitIndex].texture.get();
2787 if (texture)
2788 {
2789 ANGLE_TRY(texture->ensureInitialized(context));
2790 }
2791 }
2792 mCachedImageTexturesInitState = InitState::Initialized;
2793 }
Jamie Madill6f755b22018-10-09 12:48:54 -04002794 return angle::Result::Continue();
Jamie Madill05b35b22017-10-03 09:01:44 -04002795}
2796
Jamie Madillc67323a2017-11-02 23:11:41 -04002797AttributesMask State::getAndResetDirtyCurrentValues() const
2798{
2799 AttributesMask retVal = mDirtyCurrentValues;
2800 mDirtyCurrentValues.reset();
2801 return retVal;
2802}
2803
Jamie Madillc9d442d2016-01-20 11:17:24 -05002804} // namespace gl