blob: aa096b5b213ff41541f7b8c0e60d9dddc2ca64f8 [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"
Geoff Lang2b5420c2014-11-19 14:20:15 -050017#include "libANGLE/Caps.h"
jchen10a99ed552017-09-22 08:10:32 +080018#include "libANGLE/Context.h"
Geoff Lang70d0f492015-12-10 17:45:46 -050019#include "libANGLE/Debug.h"
Geoff Lang2b5420c2014-11-19 14:20:15 -050020#include "libANGLE/Framebuffer.h"
21#include "libANGLE/FramebufferAttachment.h"
22#include "libANGLE/Query.h"
23#include "libANGLE/VertexArray.h"
24#include "libANGLE/formatutils.h"
jchen10a99ed552017-09-22 08:10:32 +080025#include "libANGLE/queryconversions.h"
Lingfeng Yangabb09f12018-04-16 10:43:53 -070026#include "libANGLE/queryutils.h"
Geoff Lang4751aab2017-10-30 15:14:52 -040027#include "libANGLE/renderer/ContextImpl.h"
Jamie Madillf668a4b2018-09-23 17:01:20 -040028#include "libANGLE/renderer/TextureImpl.h"
Shannon Woods53a94a82014-06-24 15:20:36 -040029
Corentin Wallezad3ae902018-03-09 13:40:42 -050030namespace gl
31{
32
Olli Etuahobbf1c102016-06-28 13:31:33 +030033namespace
34{
Corentin Wallezad3ae902018-03-09 13:40:42 -050035bool GetAlternativeQueryType(QueryType type, QueryType *alternativeType)
Olli Etuahobbf1c102016-06-28 13:31:33 +030036{
Corentin Wallezad3ae902018-03-09 13:40:42 -050037 switch (type)
38 {
39 case QueryType::AnySamples:
40 *alternativeType = QueryType::AnySamplesConservative;
41 return true;
42 case QueryType::AnySamplesConservative:
43 *alternativeType = QueryType::AnySamples;
44 return true;
45 default:
46 return false;
47 }
Olli Etuahobbf1c102016-06-28 13:31:33 +030048}
49
Jamie Madillca8eda42018-10-18 18:41:56 -040050// Mapping from a buffer binding type to a dirty bit type.
51constexpr angle::PackedEnumMap<BufferBinding, size_t> kBufferBindingDirtyBits = {{
52 0, /* Array */
53 State::DIRTY_BIT_ATOMIC_COUNTER_BUFFER_BINDING, /* AtomicCounter */
54 0, /* CopyRead */
55 0, /* CopyWrite */
56 State::DIRTY_BIT_DISPATCH_INDIRECT_BUFFER_BINDING, /* DispatchIndirect */
57 State::DIRTY_BIT_DRAW_INDIRECT_BUFFER_BINDING, /* DrawIndirect */
58 0, /* ElementArray */
59 State::DIRTY_BIT_PACK_BUFFER_BINDING, /* PixelPack */
60 State::DIRTY_BIT_UNPACK_BUFFER_BINDING, /* PixelUnpack */
61 State::DIRTY_BIT_SHADER_STORAGE_BUFFER_BINDING, /* ShaderStorage */
62 0, /* TransformFeedback */
63 State::DIRTY_BIT_UNIFORM_BUFFER_BINDINGS, /* Uniform */
64}};
65
66// Returns a buffer binding function depending on if a dirty bit is set.
67template <BufferBinding Target>
68constexpr State::BufferBindingSetter GetBufferBindingSetter()
69{
70 return kBufferBindingDirtyBits[Target] != 0 ? &State::setGenericBufferBindingWithBit<Target>
71 : &State::setGenericBufferBinding<Target>;
72}
Olli Etuahobbf1c102016-06-28 13:31:33 +030073} // anonymous namepace
74
Jamie Madillbf5177d2018-08-21 12:58:20 -040075template <typename BindingT, typename... ArgsT>
Jamie Madillca8eda42018-10-18 18:41:56 -040076ANGLE_INLINE void UpdateNonTFBufferBinding(const Context *context,
77 BindingT *binding,
78 Buffer *buffer,
79 ArgsT... args)
James Darpiniane8a93c62018-01-04 18:02:24 -080080{
Jamie Madillca8eda42018-10-18 18:41:56 -040081 Buffer *oldBuffer = binding->get();
82 if (oldBuffer)
83 {
84 oldBuffer->onNonTFBindingChanged(-1);
85 oldBuffer->release(context);
86 }
87 binding->assign(buffer, args...);
88 if (buffer)
89 {
90 buffer->addRef();
91 buffer->onNonTFBindingChanged(1);
92 }
Jamie Madillbf5177d2018-08-21 12:58:20 -040093}
94
95template <typename BindingT, typename... ArgsT>
96void UpdateTFBufferBinding(const Context *context, BindingT *binding, bool indexed, ArgsT... args)
97{
98 if (binding->get())
99 (*binding)->onTFBindingChanged(context, false, indexed);
100 binding->set(context, args...);
101 if (binding->get())
102 (*binding)->onTFBindingChanged(context, true, indexed);
James Darpiniane8a93c62018-01-04 18:02:24 -0800103}
104
105void UpdateBufferBinding(const Context *context,
Jamie Madillbf5177d2018-08-21 12:58:20 -0400106 BindingPointer<Buffer> *binding,
James Darpiniane8a93c62018-01-04 18:02:24 -0800107 Buffer *buffer,
Jamie Madillbf5177d2018-08-21 12:58:20 -0400108 BufferBinding target)
James Darpiniane8a93c62018-01-04 18:02:24 -0800109{
Jamie Madillbf5177d2018-08-21 12:58:20 -0400110 if (target == BufferBinding::TransformFeedback)
111 {
112 UpdateTFBufferBinding(context, binding, false, buffer);
113 }
114 else
115 {
116 UpdateNonTFBufferBinding(context, binding, buffer);
117 }
118}
119
120void UpdateIndexedBufferBinding(const Context *context,
121 OffsetBindingPointer<Buffer> *binding,
122 Buffer *buffer,
123 BufferBinding target,
124 GLintptr offset,
125 GLsizeiptr size)
126{
127 if (target == BufferBinding::TransformFeedback)
128 {
129 UpdateTFBufferBinding(context, binding, true, buffer, offset, size);
130 }
131 else
132 {
133 UpdateNonTFBufferBinding(context, binding, buffer, offset, size);
134 }
James Darpiniane8a93c62018-01-04 18:02:24 -0800135}
136
Jamie Madillca8eda42018-10-18 18:41:56 -0400137// These template functions must be defined before they are instantiated in kBufferSetters.
138template <BufferBinding Target>
139void State::setGenericBufferBindingWithBit(const Context *context, Buffer *buffer)
140{
141 UpdateNonTFBufferBinding(context, &mBoundBuffers[Target], buffer);
142 mDirtyBits.set(kBufferBindingDirtyBits[Target]);
143}
144
145template <BufferBinding Target>
146void State::setGenericBufferBinding(const Context *context, Buffer *buffer)
147{
148 UpdateNonTFBufferBinding(context, &mBoundBuffers[Target], buffer);
149}
150
151template <>
152void State::setGenericBufferBinding<BufferBinding::TransformFeedback>(const Context *context,
153 Buffer *buffer)
154{
155 UpdateTFBufferBinding(context, &mBoundBuffers[BufferBinding::TransformFeedback], false, buffer);
156}
157
158template <>
159void State::setGenericBufferBinding<BufferBinding::ElementArray>(const Context *context,
160 Buffer *buffer)
161{
162 Buffer *oldBuffer = mVertexArray->mState.mElementArrayBuffer.get();
163 if (oldBuffer)
164 {
165 oldBuffer->onNonTFBindingChanged(-1);
166 oldBuffer->release(context);
167 }
168 mVertexArray->mState.mElementArrayBuffer.assign(buffer);
Jamie Madill472ddc82018-10-18 18:41:56 -0400169 mVertexArray->mElementArrayBufferObserverBinding.bind(buffer);
Jamie Madillca8eda42018-10-18 18:41:56 -0400170 if (buffer)
171 {
Jamie Madillca8eda42018-10-18 18:41:56 -0400172 buffer->onNonTFBindingChanged(1);
173 buffer->addRef();
174 }
Jamie Madillca8eda42018-10-18 18:41:56 -0400175 mVertexArray->mDirtyBits.set(VertexArray::DIRTY_BIT_ELEMENT_ARRAY_BUFFER);
176 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
177}
178
179const angle::PackedEnumMap<BufferBinding, State::BufferBindingSetter> State::kBufferSetters = {{
180 GetBufferBindingSetter<BufferBinding::Array>(),
181 GetBufferBindingSetter<BufferBinding::AtomicCounter>(),
182 GetBufferBindingSetter<BufferBinding::CopyRead>(),
183 GetBufferBindingSetter<BufferBinding::CopyWrite>(),
184 GetBufferBindingSetter<BufferBinding::DispatchIndirect>(),
185 GetBufferBindingSetter<BufferBinding::DrawIndirect>(),
186 GetBufferBindingSetter<BufferBinding::ElementArray>(),
187 GetBufferBindingSetter<BufferBinding::PixelPack>(),
188 GetBufferBindingSetter<BufferBinding::PixelUnpack>(),
189 GetBufferBindingSetter<BufferBinding::ShaderStorage>(),
190 GetBufferBindingSetter<BufferBinding::TransformFeedback>(),
191 GetBufferBindingSetter<BufferBinding::Uniform>(),
192}};
193
Geoff Lang4fb8a8b2018-06-01 16:47:57 -0400194State::State(bool debug,
195 bool bindGeneratesResource,
196 bool clientArraysEnabled,
197 bool robustResourceInit,
198 bool programBinaryCacheEnabled)
Jamie Madille79b1e12015-11-04 16:36:37 -0500199 : mMaxDrawBuffers(0),
200 mMaxCombinedTextureImageUnits(0),
201 mDepthClearValue(0),
202 mStencilClearValue(0),
203 mScissorTest(false),
204 mSampleCoverage(false),
205 mSampleCoverageValue(0),
206 mSampleCoverageInvert(false),
Jiawei Shaodb342272017-09-27 10:21:45 +0800207 mSampleMask(false),
208 mMaxSampleMaskWords(0),
Jamie Madille79b1e12015-11-04 16:36:37 -0500209 mStencilRef(0),
210 mStencilBackRef(0),
211 mLineWidth(0),
212 mGenerateMipmapHint(GL_NONE),
213 mFragmentShaderDerivativeHint(GL_NONE),
Geoff Lang4fb8a8b2018-06-01 16:47:57 -0400214 mBindGeneratesResource(bindGeneratesResource),
215 mClientArraysEnabled(clientArraysEnabled),
Jamie Madille79b1e12015-11-04 16:36:37 -0500216 mNearZ(0),
217 mFarZ(0),
218 mReadFramebuffer(nullptr),
219 mDrawFramebuffer(nullptr),
220 mProgram(nullptr),
221 mVertexArray(nullptr),
222 mActiveSampler(0),
Jamie Madill4787d702018-08-08 15:49:26 -0400223 mActiveTexturesCache{},
224 mCachedTexturesInitState(InitState::MayNeedInit),
Qin Jiajia47f6dd02018-08-10 13:36:32 +0800225 mCachedImageTexturesInitState(InitState::MayNeedInit),
Sami Väisänen74c23472016-05-09 17:30:30 +0300226 mPrimitiveRestart(false),
Geoff Lang4fb8a8b2018-06-01 16:47:57 -0400227 mDebug(debug),
Sami Väisänen74c23472016-05-09 17:30:30 +0300228 mMultiSampling(false),
Geoff Lang1d2c41d2016-10-19 16:14:46 -0700229 mSampleAlphaToOne(false),
Jamie Madille08a1d32017-03-07 17:24:06 -0500230 mFramebufferSRGB(true),
Geoff Lang4fb8a8b2018-06-01 16:47:57 -0400231 mRobustResourceInit(robustResourceInit),
jchen1082af6202018-06-22 10:59:52 +0800232 mProgramBinaryCacheEnabled(programBinaryCacheEnabled),
233 mMaxShaderCompilerThreads(std::numeric_limits<GLuint>::max())
Shannon Woods53a94a82014-06-24 15:20:36 -0400234{
Geoff Lang76b10c92014-09-05 16:28:14 -0400235}
236
Lingfeng Yang13b708f2018-03-21 12:14:10 -0700237State::~State()
238{
239}
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 }
Geoff Lang3b573612016-10-31 14:08:10 -0400315 if (clientVersion >= Version(3, 1))
316 {
Olli Etuahod310a432018-08-24 15:40:23 +0300317 // TODO(http://anglebug.com/2775): These could also be enabled via extension
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800318 mSamplerTextures[TextureType::_2DMultisample].resize(caps.maxCombinedTextureImageUnits);
Olli Etuahod310a432018-08-24 15:40:23 +0300319 mSamplerTextures[TextureType::_2DMultisampleArray].resize(
320 caps.maxCombinedTextureImageUnits);
Jiajia Qin6eafb042016-12-27 17:04:07 +0800321
322 mAtomicCounterBuffers.resize(caps.maxAtomicCounterBufferBindings);
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800323 mShaderStorageBuffers.resize(caps.maxShaderStorageBufferBindings);
Xinghua Cao65ec0b22017-03-28 16:10:52 +0800324 mImageUnits.resize(caps.maxImageUnits);
Geoff Lang3b573612016-10-31 14:08:10 -0400325 }
Geoff Lang4751aab2017-10-30 15:14:52 -0400326 if (nativeExtensions.textureRectangle)
Corentin Wallez13c0dd42017-07-04 18:27:01 -0400327 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800328 mSamplerTextures[TextureType::Rectangle].resize(caps.maxCombinedTextureImageUnits);
Corentin Wallez13c0dd42017-07-04 18:27:01 -0400329 }
Geoff Lang4751aab2017-10-30 15:14:52 -0400330 if (nativeExtensions.eglImageExternal || nativeExtensions.eglStreamConsumerExternal)
Ian Ewellbda75592016-04-18 17:25:54 -0400331 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800332 mSamplerTextures[TextureType::External].resize(caps.maxCombinedTextureImageUnits);
Ian Ewellbda75592016-04-18 17:25:54 -0400333 }
Jamie Madill81c2e252017-09-09 23:32:46 -0400334 mCompleteTextureBindings.reserve(caps.maxCombinedTextureImageUnits);
Geoff Lange51ba632017-11-21 11:45:25 -0500335 mCachedTexturesInitState = InitState::MayNeedInit;
Qin Jiajia47f6dd02018-08-10 13:36:32 +0800336 mCachedImageTexturesInitState = InitState::MayNeedInit;
Jamie Madill81c2e252017-09-09 23:32:46 -0400337 for (uint32_t textureIndex = 0; textureIndex < caps.maxCombinedTextureImageUnits;
338 ++textureIndex)
339 {
Jamie Madill6c43a012018-08-08 15:49:27 -0400340 mCompleteTextureBindings.emplace_back(context, textureIndex);
Jamie Madill81c2e252017-09-09 23:32:46 -0400341 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400342
Geoff Lang76b10c92014-09-05 16:28:14 -0400343 mSamplers.resize(caps.maxCombinedTextureImageUnits);
Shannon Woods53a94a82014-06-24 15:20:36 -0400344
Corentin Wallezad3ae902018-03-09 13:40:42 -0500345 for (QueryType type : angle::AllEnums<QueryType>())
346 {
347 mActiveQueries[type].set(context, nullptr);
348 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400349
Ian Ewell3ffd78b2016-01-22 16:09:42 -0500350 mProgram = nullptr;
Shannon Woods53a94a82014-06-24 15:20:36 -0400351
Ian Ewell3ffd78b2016-01-22 16:09:42 -0500352 mReadFramebuffer = nullptr;
353 mDrawFramebuffer = nullptr;
Jamie Madillb4b53c52015-02-03 15:22:48 -0500354
355 mPrimitiveRestart = false;
Geoff Lang70d0f492015-12-10 17:45:46 -0500356
Geoff Lang70d0f492015-12-10 17:45:46 -0500357 mDebug.setMaxLoggedMessages(extensions.maxDebugLoggedMessages);
Sami Väisänen74c23472016-05-09 17:30:30 +0300358
Geoff Lang488130e2017-09-27 13:53:11 -0400359 mMultiSampling = true;
360 mSampleAlphaToOne = false;
Sami Väisänena797e062016-05-12 15:23:40 +0300361
362 mCoverageModulation = GL_NONE;
Sami Väisänene45e53b2016-05-25 10:36:04 +0300363
364 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixProj);
365 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixMV);
366 mPathStencilFunc = GL_ALWAYS;
367 mPathStencilRef = 0;
368 mPathStencilMask = std::numeric_limits<GLuint>::max();
Jamie Madille08a1d32017-03-07 17:24:06 -0500369
Lingfeng Yangdbb9c532018-02-25 19:58:24 -0800370 // GLES1 emulation: Initialize state for GLES1 if version
371 // applies
372 if (clientVersion < Version(2, 0))
373 {
Lingfeng Yange547aac2018-04-05 09:39:20 -0700374 mGLES1State.initialize(context, this);
Lingfeng Yangdbb9c532018-02-25 19:58:24 -0800375 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400376}
377
Jamie Madill6c1f6712017-02-14 19:08:04 -0500378void State::reset(const Context *context)
Shannon Woods53a94a82014-06-24 15:20:36 -0400379{
Jamie Madill8693bdb2017-09-02 15:32:14 -0400380 for (auto &bindingVec : mSamplerTextures)
Shannon Woods53a94a82014-06-24 15:20:36 -0400381 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800382 for (size_t textureIdx = 0; textureIdx < bindingVec.size(); textureIdx++)
Shannon Woods53a94a82014-06-24 15:20:36 -0400383 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800384 bindingVec[textureIdx].set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400385 }
386 }
Geoff Lang76b10c92014-09-05 16:28:14 -0400387 for (size_t samplerIdx = 0; samplerIdx < mSamplers.size(); samplerIdx++)
388 {
Jamie Madill4928b7c2017-06-20 12:57:39 -0400389 mSamplers[samplerIdx].set(context, nullptr);
Geoff Lang76b10c92014-09-05 16:28:14 -0400390 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400391
Xinghua Cao65ec0b22017-03-28 16:10:52 +0800392 for (auto &imageUnit : mImageUnits)
393 {
394 imageUnit.texture.set(context, nullptr);
395 imageUnit.level = 0;
396 imageUnit.layered = false;
397 imageUnit.layer = 0;
398 imageUnit.access = GL_READ_ONLY;
399 imageUnit.format = GL_R32UI;
400 }
401
Jamie Madill4928b7c2017-06-20 12:57:39 -0400402 mRenderbuffer.set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400403
Corentin Wallez336129f2017-10-17 15:55:40 -0400404 for (auto type : angle::AllEnums<BufferBinding>())
405 {
Jamie Madillbf5177d2018-08-21 12:58:20 -0400406 UpdateBufferBinding(context, &mBoundBuffers[type], nullptr, type);
Corentin Wallez336129f2017-10-17 15:55:40 -0400407 }
408
Geoff Lang7dd2e102014-11-10 15:19:26 -0500409 if (mProgram)
410 {
Jamie Madill6c1f6712017-02-14 19:08:04 -0500411 mProgram->release(context);
Geoff Lang7dd2e102014-11-10 15:19:26 -0500412 }
Yunchao Hed7297bf2017-04-19 15:27:10 +0800413 mProgram = nullptr;
Geoff Lang7dd2e102014-11-10 15:19:26 -0500414
Yunchao Hea336b902017-08-02 16:05:21 +0800415 mProgramPipeline.set(context, nullptr);
416
James Darpiniane8a93c62018-01-04 18:02:24 -0800417 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -0400418 mTransformFeedback->onBindingChanged(context, false);
Jamie Madill4928b7c2017-06-20 12:57:39 -0400419 mTransformFeedback.set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400420
Corentin Wallezad3ae902018-03-09 13:40:42 -0500421 for (QueryType type : angle::AllEnums<QueryType>())
Shannon Woods53a94a82014-06-24 15:20:36 -0400422 {
Corentin Wallezad3ae902018-03-09 13:40:42 -0500423 mActiveQueries[type].set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400424 }
425
Corentin Wallez336129f2017-10-17 15:55:40 -0400426 for (auto &buf : mUniformBuffers)
Shannon Woods53a94a82014-06-24 15:20:36 -0400427 {
Jamie Madillbf5177d2018-08-21 12:58:20 -0400428 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::Uniform, 0, 0);
Shannon Woods53a94a82014-06-24 15:20:36 -0400429 }
430
Jiajia Qin6eafb042016-12-27 17:04:07 +0800431 for (auto &buf : mAtomicCounterBuffers)
432 {
Jamie Madillbf5177d2018-08-21 12:58:20 -0400433 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::AtomicCounter, 0, 0);
Jiajia Qin6eafb042016-12-27 17:04:07 +0800434 }
435
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800436 for (auto &buf : mShaderStorageBuffers)
437 {
Jamie Madillbf5177d2018-08-21 12:58:20 -0400438 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::ShaderStorage, 0, 0);
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800439 }
440
Sami Väisänene45e53b2016-05-25 10:36:04 +0300441 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixProj);
442 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixMV);
443 mPathStencilFunc = GL_ALWAYS;
444 mPathStencilRef = 0;
445 mPathStencilMask = std::numeric_limits<GLuint>::max();
446
Jamie Madill1b94d432015-08-07 13:23:23 -0400447 setAllDirtyBits();
Shannon Woods53a94a82014-06-24 15:20:36 -0400448}
449
Jamie Madille3bb6b72018-10-03 17:51:15 -0400450ANGLE_INLINE void State::unsetActiveTextures(ActiveTextureMask textureMask)
451{
452 // Unset any relevant bound textures.
453 for (size_t textureIndex : mProgram->getActiveSamplersMask())
454 {
455 mActiveTexturesCache[textureIndex] = nullptr;
456 mCompleteTextureBindings[textureIndex].reset();
457 }
458}
459
Jamie Madill6f755b22018-10-09 12:48:54 -0400460ANGLE_INLINE angle::Result State::updateActiveTexture(const Context *context,
461 size_t textureIndex,
462 Texture *texture)
Jamie Madille3bb6b72018-10-03 17:51:15 -0400463{
464 const Sampler *sampler = mSamplers[textureIndex].get();
465
466 if (!texture)
467 {
468 mActiveTexturesCache[textureIndex] = nullptr;
469 mCompleteTextureBindings[textureIndex].bind(nullptr);
Jamie Madill6f755b22018-10-09 12:48:54 -0400470 return angle::Result::Continue();
Jamie Madille3bb6b72018-10-03 17:51:15 -0400471 }
472
Jamie Madill31116732018-10-09 18:30:01 -0400473 mCompleteTextureBindings[textureIndex].bind(texture->getImplementation());
Jamie Madille3bb6b72018-10-03 17:51:15 -0400474
475 if (!texture->isSamplerComplete(context, sampler))
476 {
477 mActiveTexturesCache[textureIndex] = nullptr;
Jamie Madill6f755b22018-10-09 12:48:54 -0400478 return angle::Result::Continue();
Jamie Madille3bb6b72018-10-03 17:51:15 -0400479 }
480
481 mActiveTexturesCache[textureIndex] = texture;
482
483 if (texture->hasAnyDirtyBit())
484 {
485 ANGLE_TRY(texture->syncState(context));
486 }
487
488 if (texture->initState() == InitState::MayNeedInit)
489 {
490 mCachedTexturesInitState = InitState::MayNeedInit;
491 }
492
Jamie Madill6f755b22018-10-09 12:48:54 -0400493 return angle::Result::Continue();
Jamie Madille3bb6b72018-10-03 17:51:15 -0400494}
495
Shannon Woods53a94a82014-06-24 15:20:36 -0400496const RasterizerState &State::getRasterizerState() const
497{
498 return mRasterizer;
499}
500
501const BlendState &State::getBlendState() const
502{
503 return mBlend;
504}
505
506const DepthStencilState &State::getDepthStencilState() const
507{
508 return mDepthStencil;
509}
510
Jamie Madillf75ab352015-03-16 10:46:52 -0400511void State::setColorClearValue(float red, float green, float blue, float alpha)
Shannon Woods53a94a82014-06-24 15:20:36 -0400512{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700513 mColorClearValue.red = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400514 mColorClearValue.green = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700515 mColorClearValue.blue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400516 mColorClearValue.alpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400517 mDirtyBits.set(DIRTY_BIT_CLEAR_COLOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400518}
519
Jamie Madillf75ab352015-03-16 10:46:52 -0400520void State::setDepthClearValue(float depth)
Shannon Woods53a94a82014-06-24 15:20:36 -0400521{
522 mDepthClearValue = depth;
Jamie Madill1b94d432015-08-07 13:23:23 -0400523 mDirtyBits.set(DIRTY_BIT_CLEAR_DEPTH);
Shannon Woods53a94a82014-06-24 15:20:36 -0400524}
525
Jamie Madillf75ab352015-03-16 10:46:52 -0400526void State::setStencilClearValue(int stencil)
Shannon Woods53a94a82014-06-24 15:20:36 -0400527{
528 mStencilClearValue = stencil;
Jamie Madill1b94d432015-08-07 13:23:23 -0400529 mDirtyBits.set(DIRTY_BIT_CLEAR_STENCIL);
Shannon Woods53a94a82014-06-24 15:20:36 -0400530}
531
Shannon Woods53a94a82014-06-24 15:20:36 -0400532void State::setColorMask(bool red, bool green, bool blue, bool alpha)
533{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700534 mBlend.colorMaskRed = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400535 mBlend.colorMaskGreen = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700536 mBlend.colorMaskBlue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400537 mBlend.colorMaskAlpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400538 mDirtyBits.set(DIRTY_BIT_COLOR_MASK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400539}
540
541void State::setDepthMask(bool mask)
542{
543 mDepthStencil.depthMask = mask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400544 mDirtyBits.set(DIRTY_BIT_DEPTH_MASK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400545}
546
547bool State::isRasterizerDiscardEnabled() const
548{
549 return mRasterizer.rasterizerDiscard;
550}
551
552void State::setRasterizerDiscard(bool enabled)
553{
554 mRasterizer.rasterizerDiscard = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400555 mDirtyBits.set(DIRTY_BIT_RASTERIZER_DISCARD_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400556}
557
558bool State::isCullFaceEnabled() const
559{
560 return mRasterizer.cullFace;
561}
562
563void State::setCullFace(bool enabled)
564{
565 mRasterizer.cullFace = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400566 mDirtyBits.set(DIRTY_BIT_CULL_FACE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400567}
568
Corentin Wallez2e568cf2017-09-18 17:05:22 -0400569void State::setCullMode(CullFaceMode mode)
Shannon Woods53a94a82014-06-24 15:20:36 -0400570{
571 mRasterizer.cullMode = mode;
Jamie Madill1b94d432015-08-07 13:23:23 -0400572 mDirtyBits.set(DIRTY_BIT_CULL_FACE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400573}
574
575void State::setFrontFace(GLenum front)
576{
577 mRasterizer.frontFace = front;
Jamie Madill1b94d432015-08-07 13:23:23 -0400578 mDirtyBits.set(DIRTY_BIT_FRONT_FACE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400579}
580
581bool State::isDepthTestEnabled() const
582{
583 return mDepthStencil.depthTest;
584}
585
586void State::setDepthTest(bool enabled)
587{
588 mDepthStencil.depthTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400589 mDirtyBits.set(DIRTY_BIT_DEPTH_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400590}
591
592void State::setDepthFunc(GLenum depthFunc)
593{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700594 mDepthStencil.depthFunc = depthFunc;
595 mDirtyBits.set(DIRTY_BIT_DEPTH_FUNC);
Shannon Woods53a94a82014-06-24 15:20:36 -0400596}
597
598void State::setDepthRange(float zNear, float zFar)
599{
600 mNearZ = zNear;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700601 mFarZ = zFar;
Jamie Madill1b94d432015-08-07 13:23:23 -0400602 mDirtyBits.set(DIRTY_BIT_DEPTH_RANGE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400603}
604
Geoff Langd42f5b82015-04-16 14:03:29 -0400605float State::getNearPlane() const
Shannon Woods53a94a82014-06-24 15:20:36 -0400606{
Geoff Langd42f5b82015-04-16 14:03:29 -0400607 return mNearZ;
608}
609
610float State::getFarPlane() const
611{
612 return mFarZ;
Shannon Woods53a94a82014-06-24 15:20:36 -0400613}
614
615bool State::isBlendEnabled() const
616{
617 return mBlend.blend;
618}
619
620void State::setBlend(bool enabled)
621{
622 mBlend.blend = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400623 mDirtyBits.set(DIRTY_BIT_BLEND_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400624}
625
626void State::setBlendFactors(GLenum sourceRGB, GLenum destRGB, GLenum sourceAlpha, GLenum destAlpha)
627{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700628 mBlend.sourceBlendRGB = sourceRGB;
629 mBlend.destBlendRGB = destRGB;
Shannon Woods53a94a82014-06-24 15:20:36 -0400630 mBlend.sourceBlendAlpha = sourceAlpha;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700631 mBlend.destBlendAlpha = destAlpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400632 mDirtyBits.set(DIRTY_BIT_BLEND_FUNCS);
Shannon Woods53a94a82014-06-24 15:20:36 -0400633}
634
635void State::setBlendColor(float red, float green, float blue, float alpha)
636{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700637 mBlendColor.red = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400638 mBlendColor.green = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700639 mBlendColor.blue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400640 mBlendColor.alpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400641 mDirtyBits.set(DIRTY_BIT_BLEND_COLOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400642}
643
644void State::setBlendEquation(GLenum rgbEquation, GLenum alphaEquation)
645{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700646 mBlend.blendEquationRGB = rgbEquation;
Shannon Woods53a94a82014-06-24 15:20:36 -0400647 mBlend.blendEquationAlpha = alphaEquation;
Jamie Madill1b94d432015-08-07 13:23:23 -0400648 mDirtyBits.set(DIRTY_BIT_BLEND_EQUATIONS);
Shannon Woods53a94a82014-06-24 15:20:36 -0400649}
650
651const ColorF &State::getBlendColor() const
652{
653 return mBlendColor;
654}
655
656bool State::isStencilTestEnabled() const
657{
658 return mDepthStencil.stencilTest;
659}
660
661void State::setStencilTest(bool enabled)
662{
663 mDepthStencil.stencilTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400664 mDirtyBits.set(DIRTY_BIT_STENCIL_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400665}
666
667void State::setStencilParams(GLenum stencilFunc, GLint stencilRef, GLuint stencilMask)
668{
669 mDepthStencil.stencilFunc = stencilFunc;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700670 mStencilRef = (stencilRef > 0) ? stencilRef : 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400671 mDepthStencil.stencilMask = stencilMask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400672 mDirtyBits.set(DIRTY_BIT_STENCIL_FUNCS_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400673}
674
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700675void State::setStencilBackParams(GLenum stencilBackFunc,
676 GLint stencilBackRef,
677 GLuint stencilBackMask)
Shannon Woods53a94a82014-06-24 15:20:36 -0400678{
679 mDepthStencil.stencilBackFunc = stencilBackFunc;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700680 mStencilBackRef = (stencilBackRef > 0) ? stencilBackRef : 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400681 mDepthStencil.stencilBackMask = stencilBackMask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400682 mDirtyBits.set(DIRTY_BIT_STENCIL_FUNCS_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400683}
684
685void State::setStencilWritemask(GLuint stencilWritemask)
686{
687 mDepthStencil.stencilWritemask = stencilWritemask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400688 mDirtyBits.set(DIRTY_BIT_STENCIL_WRITEMASK_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400689}
690
691void State::setStencilBackWritemask(GLuint stencilBackWritemask)
692{
693 mDepthStencil.stencilBackWritemask = stencilBackWritemask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400694 mDirtyBits.set(DIRTY_BIT_STENCIL_WRITEMASK_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400695}
696
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700697void State::setStencilOperations(GLenum stencilFail,
698 GLenum stencilPassDepthFail,
699 GLenum stencilPassDepthPass)
Shannon Woods53a94a82014-06-24 15:20:36 -0400700{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700701 mDepthStencil.stencilFail = stencilFail;
Shannon Woods53a94a82014-06-24 15:20:36 -0400702 mDepthStencil.stencilPassDepthFail = stencilPassDepthFail;
703 mDepthStencil.stencilPassDepthPass = stencilPassDepthPass;
Jamie Madill1b94d432015-08-07 13:23:23 -0400704 mDirtyBits.set(DIRTY_BIT_STENCIL_OPS_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400705}
706
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700707void State::setStencilBackOperations(GLenum stencilBackFail,
708 GLenum stencilBackPassDepthFail,
709 GLenum stencilBackPassDepthPass)
Shannon Woods53a94a82014-06-24 15:20:36 -0400710{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700711 mDepthStencil.stencilBackFail = stencilBackFail;
Shannon Woods53a94a82014-06-24 15:20:36 -0400712 mDepthStencil.stencilBackPassDepthFail = stencilBackPassDepthFail;
713 mDepthStencil.stencilBackPassDepthPass = stencilBackPassDepthPass;
Jamie Madill1b94d432015-08-07 13:23:23 -0400714 mDirtyBits.set(DIRTY_BIT_STENCIL_OPS_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400715}
716
717GLint State::getStencilRef() const
718{
719 return mStencilRef;
720}
721
722GLint State::getStencilBackRef() const
723{
724 return mStencilBackRef;
725}
726
727bool State::isPolygonOffsetFillEnabled() const
728{
729 return mRasterizer.polygonOffsetFill;
730}
731
732void State::setPolygonOffsetFill(bool enabled)
733{
Jamie Madill1b94d432015-08-07 13:23:23 -0400734 mRasterizer.polygonOffsetFill = enabled;
735 mDirtyBits.set(DIRTY_BIT_POLYGON_OFFSET_FILL_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400736}
737
738void State::setPolygonOffsetParams(GLfloat factor, GLfloat units)
739{
740 // An application can pass NaN values here, so handle this gracefully
741 mRasterizer.polygonOffsetFactor = factor != factor ? 0.0f : factor;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700742 mRasterizer.polygonOffsetUnits = units != units ? 0.0f : units;
Jamie Madill1b94d432015-08-07 13:23:23 -0400743 mDirtyBits.set(DIRTY_BIT_POLYGON_OFFSET);
Shannon Woods53a94a82014-06-24 15:20:36 -0400744}
745
746bool State::isSampleAlphaToCoverageEnabled() const
747{
748 return mBlend.sampleAlphaToCoverage;
749}
750
751void State::setSampleAlphaToCoverage(bool enabled)
752{
753 mBlend.sampleAlphaToCoverage = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400754 mDirtyBits.set(DIRTY_BIT_SAMPLE_ALPHA_TO_COVERAGE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400755}
756
757bool State::isSampleCoverageEnabled() const
758{
759 return mSampleCoverage;
760}
761
762void State::setSampleCoverage(bool enabled)
763{
764 mSampleCoverage = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400765 mDirtyBits.set(DIRTY_BIT_SAMPLE_COVERAGE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400766}
767
768void State::setSampleCoverageParams(GLclampf value, bool invert)
769{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700770 mSampleCoverageValue = value;
Shannon Woods53a94a82014-06-24 15:20:36 -0400771 mSampleCoverageInvert = invert;
Jamie Madill1b94d432015-08-07 13:23:23 -0400772 mDirtyBits.set(DIRTY_BIT_SAMPLE_COVERAGE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400773}
774
Geoff Lang0fbb6002015-04-16 11:11:53 -0400775GLclampf State::getSampleCoverageValue() const
Shannon Woods53a94a82014-06-24 15:20:36 -0400776{
Geoff Lang0fbb6002015-04-16 11:11:53 -0400777 return mSampleCoverageValue;
778}
Shannon Woods53a94a82014-06-24 15:20:36 -0400779
Geoff Lang0fbb6002015-04-16 11:11:53 -0400780bool State::getSampleCoverageInvert() const
781{
782 return mSampleCoverageInvert;
Shannon Woods53a94a82014-06-24 15:20:36 -0400783}
784
Jiawei Shaodb342272017-09-27 10:21:45 +0800785bool State::isSampleMaskEnabled() const
786{
787 return mSampleMask;
788}
789
790void State::setSampleMaskEnabled(bool enabled)
791{
792 mSampleMask = enabled;
793 mDirtyBits.set(DIRTY_BIT_SAMPLE_MASK_ENABLED);
794}
795
796void State::setSampleMaskParams(GLuint maskNumber, GLbitfield mask)
797{
798 ASSERT(maskNumber < mMaxSampleMaskWords);
799 mSampleMaskValues[maskNumber] = mask;
Jamie Madillc67323a2017-11-02 23:11:41 -0400800 // TODO(jmadill): Use a child dirty bit if we ever use more than two words.
801 mDirtyBits.set(DIRTY_BIT_SAMPLE_MASK);
Jiawei Shaodb342272017-09-27 10:21:45 +0800802}
803
804GLbitfield State::getSampleMaskWord(GLuint maskNumber) const
805{
806 ASSERT(maskNumber < mMaxSampleMaskWords);
807 return mSampleMaskValues[maskNumber];
808}
809
810GLuint State::getMaxSampleMaskWords() const
811{
812 return mMaxSampleMaskWords;
813}
814
Sami Väisänen74c23472016-05-09 17:30:30 +0300815void State::setSampleAlphaToOne(bool enabled)
816{
817 mSampleAlphaToOne = enabled;
818 mDirtyBits.set(DIRTY_BIT_SAMPLE_ALPHA_TO_ONE);
819}
820
821bool State::isSampleAlphaToOneEnabled() const
822{
823 return mSampleAlphaToOne;
824}
825
826void State::setMultisampling(bool enabled)
827{
828 mMultiSampling = enabled;
829 mDirtyBits.set(DIRTY_BIT_MULTISAMPLING);
830}
831
832bool State::isMultisamplingEnabled() const
833{
834 return mMultiSampling;
835}
836
Shannon Woods53a94a82014-06-24 15:20:36 -0400837bool State::isScissorTestEnabled() const
838{
839 return mScissorTest;
840}
841
842void State::setScissorTest(bool enabled)
843{
844 mScissorTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400845 mDirtyBits.set(DIRTY_BIT_SCISSOR_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400846}
847
848void State::setScissorParams(GLint x, GLint y, GLsizei width, GLsizei height)
849{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700850 mScissor.x = x;
851 mScissor.y = y;
852 mScissor.width = width;
Shannon Woods53a94a82014-06-24 15:20:36 -0400853 mScissor.height = height;
Jamie Madill1b94d432015-08-07 13:23:23 -0400854 mDirtyBits.set(DIRTY_BIT_SCISSOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400855}
856
857const Rectangle &State::getScissor() const
858{
859 return mScissor;
860}
861
862bool State::isDitherEnabled() const
863{
864 return mBlend.dither;
865}
866
867void State::setDither(bool enabled)
868{
869 mBlend.dither = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400870 mDirtyBits.set(DIRTY_BIT_DITHER_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400871}
872
Jamie Madillb4b53c52015-02-03 15:22:48 -0500873bool State::isPrimitiveRestartEnabled() const
874{
875 return mPrimitiveRestart;
876}
877
878void State::setPrimitiveRestart(bool enabled)
879{
880 mPrimitiveRestart = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400881 mDirtyBits.set(DIRTY_BIT_PRIMITIVE_RESTART_ENABLED);
Jamie Madillb4b53c52015-02-03 15:22:48 -0500882}
883
Shannon Woods53a94a82014-06-24 15:20:36 -0400884void State::setEnableFeature(GLenum feature, bool enabled)
885{
886 switch (feature)
887 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700888 case GL_MULTISAMPLE_EXT:
889 setMultisampling(enabled);
890 break;
891 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
892 setSampleAlphaToOne(enabled);
893 break;
894 case GL_CULL_FACE:
895 setCullFace(enabled);
896 break;
897 case GL_POLYGON_OFFSET_FILL:
898 setPolygonOffsetFill(enabled);
899 break;
900 case GL_SAMPLE_ALPHA_TO_COVERAGE:
901 setSampleAlphaToCoverage(enabled);
902 break;
903 case GL_SAMPLE_COVERAGE:
904 setSampleCoverage(enabled);
905 break;
906 case GL_SCISSOR_TEST:
907 setScissorTest(enabled);
908 break;
909 case GL_STENCIL_TEST:
910 setStencilTest(enabled);
911 break;
912 case GL_DEPTH_TEST:
913 setDepthTest(enabled);
914 break;
915 case GL_BLEND:
916 setBlend(enabled);
917 break;
918 case GL_DITHER:
919 setDither(enabled);
920 break;
921 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
922 setPrimitiveRestart(enabled);
923 break;
924 case GL_RASTERIZER_DISCARD:
925 setRasterizerDiscard(enabled);
926 break;
927 case GL_SAMPLE_MASK:
928 setSampleMaskEnabled(enabled);
929 break;
930 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
931 mDebug.setOutputSynchronous(enabled);
932 break;
933 case GL_DEBUG_OUTPUT:
934 mDebug.setOutputEnabled(enabled);
935 break;
936 case GL_FRAMEBUFFER_SRGB_EXT:
937 setFramebufferSRGB(enabled);
938 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -0700939
940 // GLES1 emulation
941 case GL_ALPHA_TEST:
942 mGLES1State.mAlphaTestEnabled = enabled;
943 break;
Lingfeng Yang23dc90b2018-04-23 09:01:49 -0700944 case GL_TEXTURE_2D:
945 mGLES1State.mTexUnitEnables[mActiveSampler].set(TextureType::_2D, enabled);
946 break;
947 case GL_TEXTURE_CUBE_MAP:
948 mGLES1State.mTexUnitEnables[mActiveSampler].set(TextureType::CubeMap, enabled);
949 break;
Lingfeng Yangd0febe72018-05-17 22:36:52 -0700950 case GL_LIGHTING:
951 mGLES1State.mLightingEnabled = enabled;
952 break;
953 case GL_LIGHT0:
954 case GL_LIGHT1:
955 case GL_LIGHT2:
956 case GL_LIGHT3:
957 case GL_LIGHT4:
958 case GL_LIGHT5:
959 case GL_LIGHT6:
960 case GL_LIGHT7:
961 mGLES1State.mLights[feature - GL_LIGHT0].enabled = enabled;
962 break;
963 case GL_NORMALIZE:
964 mGLES1State.mNormalizeEnabled = enabled;
965 break;
966 case GL_RESCALE_NORMAL:
967 mGLES1State.mRescaleNormalEnabled = enabled;
968 break;
969 case GL_COLOR_MATERIAL:
970 mGLES1State.mColorMaterialEnabled = enabled;
971 break;
Lingfeng Yang060088a2018-05-30 20:40:57 -0700972 case GL_CLIP_PLANE0:
973 case GL_CLIP_PLANE1:
974 case GL_CLIP_PLANE2:
975 case GL_CLIP_PLANE3:
976 case GL_CLIP_PLANE4:
977 case GL_CLIP_PLANE5:
978 mGLES1State.mClipPlanes[feature - GL_CLIP_PLANE0].enabled = enabled;
979 break;
Lingfeng Yang7ba3f422018-06-01 09:43:04 -0700980 case GL_FOG:
981 mGLES1State.mFogEnabled = enabled;
982 break;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -0700983 case GL_POINT_SMOOTH:
984 mGLES1State.mPointSmoothEnabled = enabled;
985 break;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -0700986 case GL_LINE_SMOOTH:
987 mGLES1State.mLineSmoothEnabled = enabled;
988 break;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -0700989 case GL_POINT_SPRITE_OES:
990 mGLES1State.mPointSpriteEnabled = enabled;
991 break;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -0700992 case GL_COLOR_LOGIC_OP:
993 mGLES1State.mLogicOpEnabled = enabled;
994 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700995 default:
996 UNREACHABLE();
Shannon Woods53a94a82014-06-24 15:20:36 -0400997 }
998}
999
Jamie Madilldfde6ab2016-06-09 07:07:18 -07001000bool State::getEnableFeature(GLenum feature) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001001{
1002 switch (feature)
1003 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001004 case GL_MULTISAMPLE_EXT:
1005 return isMultisamplingEnabled();
1006 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
1007 return isSampleAlphaToOneEnabled();
1008 case GL_CULL_FACE:
1009 return isCullFaceEnabled();
1010 case GL_POLYGON_OFFSET_FILL:
1011 return isPolygonOffsetFillEnabled();
1012 case GL_SAMPLE_ALPHA_TO_COVERAGE:
1013 return isSampleAlphaToCoverageEnabled();
1014 case GL_SAMPLE_COVERAGE:
1015 return isSampleCoverageEnabled();
1016 case GL_SCISSOR_TEST:
1017 return isScissorTestEnabled();
1018 case GL_STENCIL_TEST:
1019 return isStencilTestEnabled();
1020 case GL_DEPTH_TEST:
1021 return isDepthTestEnabled();
1022 case GL_BLEND:
1023 return isBlendEnabled();
1024 case GL_DITHER:
1025 return isDitherEnabled();
1026 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
1027 return isPrimitiveRestartEnabled();
1028 case GL_RASTERIZER_DISCARD:
1029 return isRasterizerDiscardEnabled();
1030 case GL_SAMPLE_MASK:
1031 return isSampleMaskEnabled();
1032 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
1033 return mDebug.isOutputSynchronous();
1034 case GL_DEBUG_OUTPUT:
1035 return mDebug.isOutputEnabled();
1036 case GL_BIND_GENERATES_RESOURCE_CHROMIUM:
1037 return isBindGeneratesResourceEnabled();
1038 case GL_CLIENT_ARRAYS_ANGLE:
1039 return areClientArraysEnabled();
1040 case GL_FRAMEBUFFER_SRGB_EXT:
1041 return getFramebufferSRGB();
1042 case GL_ROBUST_RESOURCE_INITIALIZATION_ANGLE:
1043 return mRobustResourceInit;
1044 case GL_PROGRAM_CACHE_ENABLED_ANGLE:
1045 return mProgramBinaryCacheEnabled;
Jamie Madillc43be722017-07-13 16:22:14 -04001046
Lingfeng Yang13b708f2018-03-21 12:14:10 -07001047 // GLES1 emulation
1048 case GL_ALPHA_TEST:
1049 return mGLES1State.mAlphaTestEnabled;
Lingfeng Yang01074432018-04-16 10:19:51 -07001050 case GL_VERTEX_ARRAY:
1051 return mGLES1State.mVertexArrayEnabled;
1052 case GL_NORMAL_ARRAY:
1053 return mGLES1State.mNormalArrayEnabled;
1054 case GL_COLOR_ARRAY:
1055 return mGLES1State.mColorArrayEnabled;
1056 case GL_POINT_SIZE_ARRAY_OES:
1057 return mGLES1State.mPointSizeArrayEnabled;
1058 case GL_TEXTURE_COORD_ARRAY:
1059 return mGLES1State.mTexCoordArrayEnabled[mGLES1State.mClientActiveTexture];
Lingfeng Yang23dc90b2018-04-23 09:01:49 -07001060 case GL_TEXTURE_2D:
1061 return mGLES1State.mTexUnitEnables[mActiveSampler].test(TextureType::_2D);
1062 case GL_TEXTURE_CUBE_MAP:
1063 return mGLES1State.mTexUnitEnables[mActiveSampler].test(TextureType::CubeMap);
Lingfeng Yangd0febe72018-05-17 22:36:52 -07001064 case GL_LIGHTING:
1065 return mGLES1State.mLightingEnabled;
1066 case GL_LIGHT0:
1067 case GL_LIGHT1:
1068 case GL_LIGHT2:
1069 case GL_LIGHT3:
1070 case GL_LIGHT4:
1071 case GL_LIGHT5:
1072 case GL_LIGHT6:
1073 case GL_LIGHT7:
1074 return mGLES1State.mLights[feature - GL_LIGHT0].enabled;
1075 case GL_NORMALIZE:
1076 return mGLES1State.mNormalizeEnabled;
1077 case GL_RESCALE_NORMAL:
1078 return mGLES1State.mRescaleNormalEnabled;
1079 case GL_COLOR_MATERIAL:
1080 return mGLES1State.mColorMaterialEnabled;
Lingfeng Yang060088a2018-05-30 20:40:57 -07001081 case GL_CLIP_PLANE0:
1082 case GL_CLIP_PLANE1:
1083 case GL_CLIP_PLANE2:
1084 case GL_CLIP_PLANE3:
1085 case GL_CLIP_PLANE4:
1086 case GL_CLIP_PLANE5:
1087 return mGLES1State.mClipPlanes[feature - GL_CLIP_PLANE0].enabled;
Lingfeng Yang7ba3f422018-06-01 09:43:04 -07001088 case GL_FOG:
1089 return mGLES1State.mFogEnabled;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -07001090 case GL_POINT_SMOOTH:
1091 return mGLES1State.mPointSmoothEnabled;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -07001092 case GL_LINE_SMOOTH:
1093 return mGLES1State.mLineSmoothEnabled;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -07001094 case GL_POINT_SPRITE_OES:
1095 return mGLES1State.mPointSpriteEnabled;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -07001096 case GL_COLOR_LOGIC_OP:
1097 return mGLES1State.mLogicOpEnabled;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001098 default:
1099 UNREACHABLE();
1100 return false;
Shannon Woods53a94a82014-06-24 15:20:36 -04001101 }
1102}
1103
1104void State::setLineWidth(GLfloat width)
1105{
1106 mLineWidth = width;
Jamie Madill1b94d432015-08-07 13:23:23 -04001107 mDirtyBits.set(DIRTY_BIT_LINE_WIDTH);
Shannon Woods53a94a82014-06-24 15:20:36 -04001108}
1109
Geoff Lang4b3f4162015-04-16 13:22:05 -04001110float State::getLineWidth() const
1111{
1112 return mLineWidth;
1113}
1114
Shannon Woods53a94a82014-06-24 15:20:36 -04001115void State::setGenerateMipmapHint(GLenum hint)
1116{
1117 mGenerateMipmapHint = hint;
Jamie Madill1b94d432015-08-07 13:23:23 -04001118 mDirtyBits.set(DIRTY_BIT_GENERATE_MIPMAP_HINT);
Shannon Woods53a94a82014-06-24 15:20:36 -04001119}
1120
1121void State::setFragmentShaderDerivativeHint(GLenum hint)
1122{
1123 mFragmentShaderDerivativeHint = hint;
Jamie Madill1b94d432015-08-07 13:23:23 -04001124 mDirtyBits.set(DIRTY_BIT_SHADER_DERIVATIVE_HINT);
Shannon Woods53a94a82014-06-24 15:20:36 -04001125 // TODO: Propagate the hint to shader translator so we can write
1126 // ddx, ddx_coarse, or ddx_fine depending on the hint.
1127 // Ignore for now. It is valid for implementations to ignore hint.
1128}
1129
Geoff Langfeb8c682017-02-13 16:07:35 -05001130bool State::areClientArraysEnabled() const
1131{
1132 return mClientArraysEnabled;
1133}
1134
Shannon Woods53a94a82014-06-24 15:20:36 -04001135void State::setViewportParams(GLint x, GLint y, GLsizei width, GLsizei height)
1136{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001137 mViewport.x = x;
1138 mViewport.y = y;
1139 mViewport.width = width;
Shannon Woods53a94a82014-06-24 15:20:36 -04001140 mViewport.height = height;
Jamie Madill1b94d432015-08-07 13:23:23 -04001141 mDirtyBits.set(DIRTY_BIT_VIEWPORT);
Shannon Woods53a94a82014-06-24 15:20:36 -04001142}
1143
1144const Rectangle &State::getViewport() const
1145{
1146 return mViewport;
1147}
1148
1149void State::setActiveSampler(unsigned int active)
1150{
1151 mActiveSampler = active;
1152}
1153
1154unsigned int State::getActiveSampler() const
1155{
Cooper Partin4d61f7e2015-08-12 10:56:50 -07001156 return static_cast<unsigned int>(mActiveSampler);
Shannon Woods53a94a82014-06-24 15:20:36 -04001157}
1158
Jamie Madill14246812018-10-03 17:51:16 -04001159Error State::setSamplerTexture(const Context *context, TextureType type, Texture *texture)
Shannon Woods53a94a82014-06-24 15:20:36 -04001160{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001161 mSamplerTextures[type][mActiveSampler].set(context, texture);
Jamie Madill14246812018-10-03 17:51:16 -04001162
1163 if (mProgram && mProgram->getActiveSamplersMask()[mActiveSampler] &&
1164 mProgram->getActiveSamplerTypes()[mActiveSampler] == type)
1165 {
1166 ANGLE_TRY(updateActiveTexture(context, mActiveSampler, texture));
1167 }
1168
Jamie Madill81c2e252017-09-09 23:32:46 -04001169 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
Jamie Madill14246812018-10-03 17:51:16 -04001170
1171 return NoError();
Shannon Woods53a94a82014-06-24 15:20:36 -04001172}
1173
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001174Texture *State::getTargetTexture(TextureType type) const
Jamie Madillc29968b2016-01-20 11:17:23 -05001175{
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001176 return getSamplerTexture(static_cast<unsigned int>(mActiveSampler), type);
Jamie Madillc29968b2016-01-20 11:17:23 -05001177}
1178
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001179GLuint State::getSamplerTextureId(unsigned int sampler, TextureType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001180{
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001181 ASSERT(sampler < mSamplerTextures[type].size());
1182 return mSamplerTextures[type][sampler].id();
Shannon Woods53a94a82014-06-24 15:20:36 -04001183}
1184
Jamie Madilla02315b2017-02-23 14:14:47 -05001185void State::detachTexture(const Context *context, const TextureMap &zeroTextures, GLuint texture)
Shannon Woods53a94a82014-06-24 15:20:36 -04001186{
1187 // Textures have a detach method on State rather than a simple
1188 // removeBinding, because the zero/null texture objects are managed
1189 // separately, and don't have to go through the Context's maps or
1190 // the ResourceManager.
1191
1192 // [OpenGL ES 2.0.24] section 3.8 page 84:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001193 // If a texture object is deleted, it is as if all texture units which are bound to that texture
1194 // object are rebound to texture object zero
Shannon Woods53a94a82014-06-24 15:20:36 -04001195
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001196 for (TextureType type : angle::AllEnums<TextureType>())
Shannon Woods53a94a82014-06-24 15:20:36 -04001197 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001198 TextureBindingVector &textureVector = mSamplerTextures[type];
Jamie Madill81c2e252017-09-09 23:32:46 -04001199 for (BindingPointer<Texture> &binding : textureVector)
Shannon Woods53a94a82014-06-24 15:20:36 -04001200 {
Geoff Lang76b10c92014-09-05 16:28:14 -04001201 if (binding.id() == texture)
Shannon Woods53a94a82014-06-24 15:20:36 -04001202 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001203 Texture *zeroTexture = zeroTextures[type].get();
1204 ASSERT(zeroTexture != nullptr);
Jamie Madille6382c32014-11-07 15:05:26 -05001205 // Zero textures are the "default" textures instead of NULL
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001206 binding.set(context, zeroTexture);
Jamie Madill81c2e252017-09-09 23:32:46 -04001207 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
Shannon Woods53a94a82014-06-24 15:20:36 -04001208 }
1209 }
1210 }
1211
Xinghua Cao65ec0b22017-03-28 16:10:52 +08001212 for (auto &bindingImageUnit : mImageUnits)
1213 {
1214 if (bindingImageUnit.texture.id() == texture)
1215 {
1216 bindingImageUnit.texture.set(context, nullptr);
1217 bindingImageUnit.level = 0;
1218 bindingImageUnit.layered = false;
1219 bindingImageUnit.layer = 0;
1220 bindingImageUnit.access = GL_READ_ONLY;
1221 bindingImageUnit.format = GL_R32UI;
1222 break;
1223 }
1224 }
1225
Shannon Woods53a94a82014-06-24 15:20:36 -04001226 // [OpenGL ES 2.0.24] section 4.4 page 112:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001227 // If a texture object is deleted while its image is attached to the currently bound
1228 // framebuffer, then it is as if Texture2DAttachment had been called, with a texture of 0, for
1229 // each attachment point to which this image was attached in the currently bound framebuffer.
Shannon Woods53a94a82014-06-24 15:20:36 -04001230
Jamie Madill8693bdb2017-09-02 15:32:14 -04001231 if (mReadFramebuffer && mReadFramebuffer->detachTexture(context, texture))
Shannon Woods53a94a82014-06-24 15:20:36 -04001232 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001233 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -04001234 }
1235
Jamie Madill8693bdb2017-09-02 15:32:14 -04001236 if (mDrawFramebuffer && mDrawFramebuffer->detachTexture(context, texture))
Shannon Woods53a94a82014-06-24 15:20:36 -04001237 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001238 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -04001239 }
1240}
1241
Jamie Madill4928b7c2017-06-20 12:57:39 -04001242void State::initializeZeroTextures(const Context *context, const TextureMap &zeroTextures)
Jamie Madille6382c32014-11-07 15:05:26 -05001243{
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001244 for (TextureType type : angle::AllEnums<TextureType>())
Jamie Madille6382c32014-11-07 15:05:26 -05001245 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001246 for (size_t textureUnit = 0; textureUnit < mSamplerTextures[type].size(); ++textureUnit)
Jamie Madille6382c32014-11-07 15:05:26 -05001247 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001248 mSamplerTextures[type][textureUnit].set(context, zeroTextures[type].get());
Jamie Madille6382c32014-11-07 15:05:26 -05001249 }
1250 }
1251}
1252
Jamie Madill4928b7c2017-06-20 12:57:39 -04001253void State::setSamplerBinding(const Context *context, GLuint textureUnit, Sampler *sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001254{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001255 mSamplers[textureUnit].set(context, sampler);
Jamie Madill81c2e252017-09-09 23:32:46 -04001256 mDirtyBits.set(DIRTY_BIT_SAMPLER_BINDINGS);
1257 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Jamie Madille25b8002018-09-20 13:39:49 -04001258 // This is overly conservative as it assumes the sampler has never been bound.
1259 setSamplerDirty(textureUnit);
Shannon Woods53a94a82014-06-24 15:20:36 -04001260}
1261
1262GLuint State::getSamplerId(GLuint textureUnit) const
1263{
Geoff Lang76b10c92014-09-05 16:28:14 -04001264 ASSERT(textureUnit < mSamplers.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001265 return mSamplers[textureUnit].id();
1266}
1267
Jamie Madill4928b7c2017-06-20 12:57:39 -04001268void State::detachSampler(const Context *context, GLuint sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001269{
1270 // [OpenGL ES 3.0.2] section 3.8.2 pages 123-124:
1271 // If a sampler object that is currently bound to one or more texture units is
1272 // deleted, it is as though BindSampler is called once for each texture unit to
1273 // which the sampler is bound, with unit set to the texture unit and sampler set to zero.
Jamie Madill81c2e252017-09-09 23:32:46 -04001274 for (BindingPointer<Sampler> &samplerBinding : mSamplers)
Shannon Woods53a94a82014-06-24 15:20:36 -04001275 {
Geoff Lang76b10c92014-09-05 16:28:14 -04001276 if (samplerBinding.id() == sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001277 {
Jamie Madill4928b7c2017-06-20 12:57:39 -04001278 samplerBinding.set(context, nullptr);
Jamie Madill81c2e252017-09-09 23:32:46 -04001279 mDirtyBits.set(DIRTY_BIT_SAMPLER_BINDINGS);
Shannon Woods53a94a82014-06-24 15:20:36 -04001280 }
1281 }
1282}
1283
Jamie Madill4928b7c2017-06-20 12:57:39 -04001284void State::setRenderbufferBinding(const Context *context, Renderbuffer *renderbuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001285{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001286 mRenderbuffer.set(context, renderbuffer);
Jamie Madill8693bdb2017-09-02 15:32:14 -04001287 mDirtyBits.set(DIRTY_BIT_RENDERBUFFER_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001288}
1289
1290GLuint State::getRenderbufferId() const
1291{
1292 return mRenderbuffer.id();
1293}
1294
Jamie Madilldfde6ab2016-06-09 07:07:18 -07001295Renderbuffer *State::getCurrentRenderbuffer() const
Shannon Woods53a94a82014-06-24 15:20:36 -04001296{
1297 return mRenderbuffer.get();
1298}
1299
Jamie Madilla02315b2017-02-23 14:14:47 -05001300void State::detachRenderbuffer(const Context *context, GLuint renderbuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001301{
1302 // [OpenGL ES 2.0.24] section 4.4 page 109:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001303 // If a renderbuffer that is currently bound to RENDERBUFFER is deleted, it is as though
1304 // BindRenderbuffer had been executed with the target RENDERBUFFER and name of zero.
Shannon Woods53a94a82014-06-24 15:20:36 -04001305
1306 if (mRenderbuffer.id() == renderbuffer)
1307 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001308 setRenderbufferBinding(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001309 }
1310
1311 // [OpenGL ES 2.0.24] section 4.4 page 111:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001312 // If a renderbuffer object is deleted while its image is attached to the currently bound
1313 // framebuffer, then it is as if FramebufferRenderbuffer had been called, with a renderbuffer of
1314 // 0, for each attachment point to which this image was attached in the currently bound
1315 // framebuffer.
Shannon Woods53a94a82014-06-24 15:20:36 -04001316
1317 Framebuffer *readFramebuffer = mReadFramebuffer;
1318 Framebuffer *drawFramebuffer = mDrawFramebuffer;
1319
Jamie Madill8693bdb2017-09-02 15:32:14 -04001320 if (readFramebuffer && readFramebuffer->detachRenderbuffer(context, renderbuffer))
Shannon Woods53a94a82014-06-24 15:20:36 -04001321 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001322 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -04001323 }
1324
1325 if (drawFramebuffer && drawFramebuffer != readFramebuffer)
1326 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001327 if (drawFramebuffer->detachRenderbuffer(context, renderbuffer))
1328 {
1329 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
1330 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001331 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001332}
1333
1334void State::setReadFramebufferBinding(Framebuffer *framebuffer)
1335{
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001336 if (mReadFramebuffer == framebuffer)
1337 return;
1338
Shannon Woods53a94a82014-06-24 15:20:36 -04001339 mReadFramebuffer = framebuffer;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001340 mDirtyBits.set(DIRTY_BIT_READ_FRAMEBUFFER_BINDING);
1341
1342 if (mReadFramebuffer && mReadFramebuffer->hasAnyDirtyBit())
1343 {
1344 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
1345 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001346}
1347
1348void State::setDrawFramebufferBinding(Framebuffer *framebuffer)
1349{
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001350 if (mDrawFramebuffer == framebuffer)
1351 return;
1352
Shannon Woods53a94a82014-06-24 15:20:36 -04001353 mDrawFramebuffer = framebuffer;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001354 mDirtyBits.set(DIRTY_BIT_DRAW_FRAMEBUFFER_BINDING);
1355
1356 if (mDrawFramebuffer && mDrawFramebuffer->hasAnyDirtyBit())
1357 {
1358 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
1359 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001360}
1361
1362Framebuffer *State::getTargetFramebuffer(GLenum target) const
1363{
1364 switch (target)
1365 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001366 case GL_READ_FRAMEBUFFER_ANGLE:
1367 return mReadFramebuffer;
1368 case GL_DRAW_FRAMEBUFFER_ANGLE:
1369 case GL_FRAMEBUFFER:
1370 return mDrawFramebuffer;
1371 default:
1372 UNREACHABLE();
Yunchao Hef81ce4a2017-04-24 10:49:17 +08001373 return nullptr;
Shannon Woods53a94a82014-06-24 15:20:36 -04001374 }
1375}
1376
Jamie Madill51f40ec2016-06-15 14:06:00 -04001377Framebuffer *State::getReadFramebuffer() const
Shannon Woods53a94a82014-06-24 15:20:36 -04001378{
1379 return mReadFramebuffer;
1380}
1381
Shannon Woods53a94a82014-06-24 15:20:36 -04001382bool State::removeReadFramebufferBinding(GLuint framebuffer)
1383{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001384 if (mReadFramebuffer != nullptr && mReadFramebuffer->id() == framebuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001385 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001386 setReadFramebufferBinding(nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001387 return true;
1388 }
1389
1390 return false;
1391}
1392
1393bool State::removeDrawFramebufferBinding(GLuint framebuffer)
1394{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001395 if (mReadFramebuffer != nullptr && mDrawFramebuffer->id() == framebuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001396 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001397 setDrawFramebufferBinding(nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001398 return true;
1399 }
1400
1401 return false;
1402}
1403
Jamie Madill7267aa62018-04-17 15:28:21 -04001404void State::setVertexArrayBinding(const Context *context, VertexArray *vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001405{
James Darpiniane8a93c62018-01-04 18:02:24 -08001406 if (mVertexArray == vertexArray)
1407 return;
1408 if (mVertexArray)
Jamie Madillbf5177d2018-08-21 12:58:20 -04001409 mVertexArray->onBindingChanged(context, -1);
Shannon Woods53a94a82014-06-24 15:20:36 -04001410 mVertexArray = vertexArray;
James Darpiniane8a93c62018-01-04 18:02:24 -08001411 if (vertexArray)
Jamie Madillbf5177d2018-08-21 12:58:20 -04001412 vertexArray->onBindingChanged(context, 1);
Jamie Madill0b9e9032015-08-17 11:51:52 +00001413 mDirtyBits.set(DIRTY_BIT_VERTEX_ARRAY_BINDING);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001414
1415 if (mVertexArray && mVertexArray->hasAnyDirtyBit())
1416 {
1417 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1418 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001419}
1420
1421GLuint State::getVertexArrayId() const
1422{
Yunchao He4f285442017-04-21 12:15:49 +08001423 ASSERT(mVertexArray != nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001424 return mVertexArray->id();
1425}
1426
Jamie Madill7267aa62018-04-17 15:28:21 -04001427bool State::removeVertexArrayBinding(const Context *context, GLuint vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001428{
James Darpiniane8a93c62018-01-04 18:02:24 -08001429 if (mVertexArray && mVertexArray->id() == vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001430 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001431 mVertexArray->onBindingChanged(context, -1);
Yunchao Hed7297bf2017-04-19 15:27:10 +08001432 mVertexArray = nullptr;
Jamie Madill0b9e9032015-08-17 11:51:52 +00001433 mDirtyBits.set(DIRTY_BIT_VERTEX_ARRAY_BINDING);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001434 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001435 return true;
1436 }
1437
1438 return false;
1439}
1440
Jamie Madill4928b7c2017-06-20 12:57:39 -04001441void State::bindVertexBuffer(const Context *context,
1442 GLuint bindingIndex,
Shao80957d92017-02-20 21:25:59 +08001443 Buffer *boundBuffer,
1444 GLintptr offset,
1445 GLsizei stride)
1446{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001447 getVertexArray()->bindVertexBuffer(context, bindingIndex, boundBuffer, offset, stride);
Shao80957d92017-02-20 21:25:59 +08001448 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1449}
1450
Shaodde78e82017-05-22 14:13:27 +08001451void State::setVertexAttribBinding(const Context *context, GLuint attribIndex, GLuint bindingIndex)
Shao80957d92017-02-20 21:25:59 +08001452{
Shaodde78e82017-05-22 14:13:27 +08001453 getVertexArray()->setVertexAttribBinding(context, attribIndex, bindingIndex);
Shao80957d92017-02-20 21:25:59 +08001454 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1455}
1456
1457void State::setVertexAttribFormat(GLuint attribIndex,
1458 GLint size,
1459 GLenum type,
1460 bool normalized,
1461 bool pureInteger,
1462 GLuint relativeOffset)
1463{
1464 getVertexArray()->setVertexAttribFormat(attribIndex, size, type, normalized, pureInteger,
1465 relativeOffset);
1466 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1467}
1468
1469void State::setVertexBindingDivisor(GLuint bindingIndex, GLuint divisor)
1470{
1471 getVertexArray()->setVertexBindingDivisor(bindingIndex, divisor);
1472 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1473}
1474
Jamie Madill6f755b22018-10-09 12:48:54 -04001475angle::Result State::setProgram(const Context *context, Program *newProgram)
Shannon Woods53a94a82014-06-24 15:20:36 -04001476{
Geoff Lang7dd2e102014-11-10 15:19:26 -05001477 if (mProgram != newProgram)
Shannon Woods53a94a82014-06-24 15:20:36 -04001478 {
Geoff Lang7dd2e102014-11-10 15:19:26 -05001479 if (mProgram)
1480 {
Jamie Madille3bb6b72018-10-03 17:51:15 -04001481 unsetActiveTextures(mProgram->getActiveSamplersMask());
Jamie Madill6c1f6712017-02-14 19:08:04 -05001482 mProgram->release(context);
Geoff Lang7dd2e102014-11-10 15:19:26 -05001483 }
1484
1485 mProgram = newProgram;
1486
1487 if (mProgram)
1488 {
1489 newProgram->addRef();
Jamie Madille3bb6b72018-10-03 17:51:15 -04001490 ANGLE_TRY(onProgramExecutableChange(context, newProgram));
Geoff Lang7dd2e102014-11-10 15:19:26 -05001491 }
Jamie Madilldf836ff2018-10-01 10:36:24 -04001492
1493 // Note that rendering is undefined if glUseProgram(0) is called. But ANGLE will generate
1494 // an error if the app tries to draw in this case.
1495
Jamie Madilla779b612017-07-24 11:46:05 -04001496 mDirtyBits.set(DIRTY_BIT_PROGRAM_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001497 }
Jamie Madille3bb6b72018-10-03 17:51:15 -04001498
Jamie Madill6f755b22018-10-09 12:48:54 -04001499 return angle::Result::Continue();
Shannon Woods53a94a82014-06-24 15:20:36 -04001500}
1501
Jamie Madill4928b7c2017-06-20 12:57:39 -04001502void State::setTransformFeedbackBinding(const Context *context,
1503 TransformFeedback *transformFeedback)
Shannon Woods53a94a82014-06-24 15:20:36 -04001504{
James Darpiniane8a93c62018-01-04 18:02:24 -08001505 if (transformFeedback == mTransformFeedback.get())
1506 return;
1507 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -04001508 mTransformFeedback->onBindingChanged(context, false);
Jamie Madill4928b7c2017-06-20 12:57:39 -04001509 mTransformFeedback.set(context, transformFeedback);
James Darpiniane8a93c62018-01-04 18:02:24 -08001510 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -04001511 mTransformFeedback->onBindingChanged(context, true);
Geoff Langded79232017-11-28 15:21:11 -05001512 mDirtyBits.set(DIRTY_BIT_TRANSFORM_FEEDBACK_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001513}
1514
Jamie Madill4928b7c2017-06-20 12:57:39 -04001515bool State::removeTransformFeedbackBinding(const Context *context, GLuint transformFeedback)
Shannon Woods53a94a82014-06-24 15:20:36 -04001516{
1517 if (mTransformFeedback.id() == transformFeedback)
1518 {
James Darpiniane8a93c62018-01-04 18:02:24 -08001519 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -04001520 mTransformFeedback->onBindingChanged(context, false);
Jamie Madill4928b7c2017-06-20 12:57:39 -04001521 mTransformFeedback.set(context, nullptr);
Corentin Walleza2257da2016-04-19 16:43:12 -04001522 return true;
Shannon Woods53a94a82014-06-24 15:20:36 -04001523 }
Corentin Walleza2257da2016-04-19 16:43:12 -04001524
1525 return false;
Shannon Woods53a94a82014-06-24 15:20:36 -04001526}
1527
Yunchao Hea336b902017-08-02 16:05:21 +08001528void State::setProgramPipelineBinding(const Context *context, ProgramPipeline *pipeline)
1529{
1530 mProgramPipeline.set(context, pipeline);
1531}
1532
1533void State::detachProgramPipeline(const Context *context, GLuint pipeline)
1534{
1535 mProgramPipeline.set(context, nullptr);
1536}
1537
Corentin Wallezad3ae902018-03-09 13:40:42 -05001538bool State::isQueryActive(QueryType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001539{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001540 const Query *query = mActiveQueries[type].get();
1541 if (query != nullptr)
Shannon Woods53a94a82014-06-24 15:20:36 -04001542 {
Corentin Wallezad3ae902018-03-09 13:40:42 -05001543 return true;
1544 }
1545
1546 QueryType alternativeType;
1547 if (GetAlternativeQueryType(type, &alternativeType))
1548 {
1549 query = mActiveQueries[alternativeType].get();
1550 return query != nullptr;
Ian Ewell3ffd78b2016-01-22 16:09:42 -05001551 }
1552
1553 return false;
1554}
1555
1556bool State::isQueryActive(Query *query) const
1557{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001558 for (auto &queryPointer : mActiveQueries)
Ian Ewell3ffd78b2016-01-22 16:09:42 -05001559 {
Corentin Wallezad3ae902018-03-09 13:40:42 -05001560 if (queryPointer.get() == query)
Shannon Woods53a94a82014-06-24 15:20:36 -04001561 {
1562 return true;
1563 }
1564 }
1565
1566 return false;
1567}
1568
Corentin Wallezad3ae902018-03-09 13:40:42 -05001569void State::setActiveQuery(const Context *context, QueryType type, Query *query)
Shannon Woods53a94a82014-06-24 15:20:36 -04001570{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001571 mActiveQueries[type].set(context, query);
Shannon Woods53a94a82014-06-24 15:20:36 -04001572}
1573
Corentin Wallezad3ae902018-03-09 13:40:42 -05001574GLuint State::getActiveQueryId(QueryType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001575{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001576 const Query *query = getActiveQuery(type);
Shannon Woods53a94a82014-06-24 15:20:36 -04001577 return (query ? query->id() : 0u);
1578}
1579
Corentin Wallezad3ae902018-03-09 13:40:42 -05001580Query *State::getActiveQuery(QueryType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001581{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001582 return mActiveQueries[type].get();
Shannon Woods53a94a82014-06-24 15:20:36 -04001583}
1584
Corentin Wallez336129f2017-10-17 15:55:40 -04001585void State::setIndexedBufferBinding(const Context *context,
1586 BufferBinding target,
1587 GLuint index,
1588 Buffer *buffer,
1589 GLintptr offset,
1590 GLsizeiptr size)
Jiajia Qin9d7d0b12016-11-29 16:30:31 +08001591{
Corentin Wallez336129f2017-10-17 15:55:40 -04001592 setBufferBinding(context, target, buffer);
Jiajia Qin9d7d0b12016-11-29 16:30:31 +08001593
Corentin Wallez336129f2017-10-17 15:55:40 -04001594 switch (target)
1595 {
1596 case BufferBinding::TransformFeedback:
1597 mTransformFeedback->bindIndexedBuffer(context, index, buffer, offset, size);
James Darpiniane8a93c62018-01-04 18:02:24 -08001598 setBufferBinding(context, target, buffer);
Corentin Wallez336129f2017-10-17 15:55:40 -04001599 break;
1600 case BufferBinding::Uniform:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001601 UpdateIndexedBufferBinding(context, &mUniformBuffers[index], buffer, target, offset,
1602 size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001603 break;
1604 case BufferBinding::AtomicCounter:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001605 UpdateIndexedBufferBinding(context, &mAtomicCounterBuffers[index], buffer, target,
1606 offset, size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001607 break;
1608 case BufferBinding::ShaderStorage:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001609 UpdateIndexedBufferBinding(context, &mShaderStorageBuffers[index], buffer, target,
1610 offset, size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001611 break;
1612 default:
1613 UNREACHABLE();
1614 break;
1615 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001616}
1617
Geoff Lang5d124a62015-09-15 13:03:27 -04001618const OffsetBindingPointer<Buffer> &State::getIndexedUniformBuffer(size_t index) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001619{
Shannon Woodsf3acaf92014-09-23 18:07:11 -04001620 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
Geoff Lang5d124a62015-09-15 13:03:27 -04001621 return mUniformBuffers[index];
Gregoire Payen de La Garanderie68694e92015-03-24 14:03:37 +00001622}
1623
Jiajia Qin6eafb042016-12-27 17:04:07 +08001624const OffsetBindingPointer<Buffer> &State::getIndexedAtomicCounterBuffer(size_t index) const
1625{
1626 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
1627 return mAtomicCounterBuffers[index];
1628}
1629
Jiajia Qinf546e7d2017-03-27 14:12:59 +08001630const OffsetBindingPointer<Buffer> &State::getIndexedShaderStorageBuffer(size_t index) const
1631{
1632 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
1633 return mShaderStorageBuffers[index];
1634}
1635
Corentin Wallez336129f2017-10-17 15:55:40 -04001636Buffer *State::getTargetBuffer(BufferBinding target) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001637{
1638 switch (target)
1639 {
Corentin Wallez336129f2017-10-17 15:55:40 -04001640 case BufferBinding::ElementArray:
1641 return getVertexArray()->getElementArrayBuffer().get();
Corentin Wallez336129f2017-10-17 15:55:40 -04001642 default:
1643 return mBoundBuffers[target].get();
Shannon Woods53a94a82014-06-24 15:20:36 -04001644 }
1645}
1646
James Darpinian4d9d4832018-03-13 12:43:28 -07001647void State::detachBuffer(const Context *context, const Buffer *buffer)
Yuly Novikov5807a532015-12-03 13:01:22 -05001648{
James Darpinian4d9d4832018-03-13 12:43:28 -07001649 if (!buffer->isBound())
1650 {
1651 return;
1652 }
1653 GLuint bufferName = buffer->id();
James Darpiniane8a93c62018-01-04 18:02:24 -08001654 for (auto target : angle::AllEnums<BufferBinding>())
Yuly Novikov5807a532015-12-03 13:01:22 -05001655 {
James Darpiniane8a93c62018-01-04 18:02:24 -08001656 if (mBoundBuffers[target].id() == bufferName)
Yuly Novikov5807a532015-12-03 13:01:22 -05001657 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001658 UpdateBufferBinding(context, &mBoundBuffers[target], nullptr, target);
Yuly Novikov5807a532015-12-03 13:01:22 -05001659 }
1660 }
1661
1662 TransformFeedback *curTransformFeedback = getCurrentTransformFeedback();
1663 if (curTransformFeedback)
1664 {
Jamie Madill4928b7c2017-06-20 12:57:39 -04001665 curTransformFeedback->detachBuffer(context, bufferName);
Yuly Novikov5807a532015-12-03 13:01:22 -05001666 }
1667
Jamie Madill4928b7c2017-06-20 12:57:39 -04001668 getVertexArray()->detachBuffer(context, bufferName);
James Darpiniane8a93c62018-01-04 18:02:24 -08001669
1670 for (auto &buf : mUniformBuffers)
1671 {
1672 if (buf.id() == bufferName)
1673 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001674 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::Uniform, 0, 0);
James Darpiniane8a93c62018-01-04 18:02:24 -08001675 }
1676 }
1677
1678 for (auto &buf : mAtomicCounterBuffers)
1679 {
1680 if (buf.id() == bufferName)
1681 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001682 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::AtomicCounter, 0, 0);
James Darpiniane8a93c62018-01-04 18:02:24 -08001683 }
1684 }
1685
1686 for (auto &buf : mShaderStorageBuffers)
1687 {
1688 if (buf.id() == bufferName)
1689 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001690 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::ShaderStorage, 0, 0);
James Darpiniane8a93c62018-01-04 18:02:24 -08001691 }
1692 }
Yuly Novikov5807a532015-12-03 13:01:22 -05001693}
1694
Shannon Woods53a94a82014-06-24 15:20:36 -04001695void State::setEnableVertexAttribArray(unsigned int attribNum, bool enabled)
1696{
1697 getVertexArray()->enableAttribute(attribNum, enabled);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001698 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001699}
1700
1701void State::setVertexAttribf(GLuint index, const GLfloat values[4])
1702{
Shannon Woods23e05002014-09-22 19:07:27 -04001703 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001704 mVertexAttribCurrentValues[index].setFloatValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001705 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1706 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001707 mCurrentValuesTypeMask.setIndex(GL_FLOAT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001708}
1709
1710void State::setVertexAttribu(GLuint index, const GLuint values[4])
1711{
Shannon Woods23e05002014-09-22 19:07:27 -04001712 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001713 mVertexAttribCurrentValues[index].setUnsignedIntValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001714 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1715 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001716 mCurrentValuesTypeMask.setIndex(GL_UNSIGNED_INT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001717}
1718
1719void State::setVertexAttribi(GLuint index, const GLint values[4])
1720{
Shannon Woods23e05002014-09-22 19:07:27 -04001721 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001722 mVertexAttribCurrentValues[index].setIntValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001723 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1724 mDirtyCurrentValues.set(index);
Brandon Jonesc405ae72017-12-06 14:15:03 -08001725 mCurrentValuesTypeMask.setIndex(GL_INT, index);
Shannon Woods53a94a82014-06-24 15:20:36 -04001726}
1727
Shaodde78e82017-05-22 14:13:27 +08001728void State::setVertexAttribPointer(const Context *context,
1729 unsigned int attribNum,
1730 Buffer *boundBuffer,
1731 GLint size,
1732 GLenum type,
1733 bool normalized,
1734 bool pureInteger,
1735 GLsizei stride,
1736 const void *pointer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001737{
Shaodde78e82017-05-22 14:13:27 +08001738 getVertexArray()->setVertexAttribPointer(context, attribNum, boundBuffer, size, type,
1739 normalized, pureInteger, stride, pointer);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001740 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Jamie Madill0b9e9032015-08-17 11:51:52 +00001741}
1742
Shaodde78e82017-05-22 14:13:27 +08001743void State::setVertexAttribDivisor(const Context *context, GLuint index, GLuint divisor)
Jamie Madill0b9e9032015-08-17 11:51:52 +00001744{
Shaodde78e82017-05-22 14:13:27 +08001745 getVertexArray()->setVertexAttribDivisor(context, index, divisor);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001746 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001747}
1748
Jamie Madill6de51852017-04-12 09:53:01 -04001749const VertexAttribCurrentValueData &State::getVertexAttribCurrentValue(size_t attribNum) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001750{
Jamie Madill6de51852017-04-12 09:53:01 -04001751 ASSERT(attribNum < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001752 return mVertexAttribCurrentValues[attribNum];
1753}
1754
Jamie Madillcac94a92017-11-10 10:09:32 -05001755const std::vector<VertexAttribCurrentValueData> &State::getVertexAttribCurrentValues() const
1756{
1757 return mVertexAttribCurrentValues;
1758}
1759
Shannon Woods53a94a82014-06-24 15:20:36 -04001760const void *State::getVertexAttribPointer(unsigned int attribNum) const
1761{
1762 return getVertexArray()->getVertexAttribute(attribNum).pointer;
1763}
1764
1765void State::setPackAlignment(GLint alignment)
1766{
1767 mPack.alignment = alignment;
Jamie Madillc67323a2017-11-02 23:11:41 -04001768 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001769}
1770
1771GLint State::getPackAlignment() const
1772{
1773 return mPack.alignment;
1774}
1775
1776void State::setPackReverseRowOrder(bool reverseRowOrder)
1777{
1778 mPack.reverseRowOrder = reverseRowOrder;
Jamie Madillc67323a2017-11-02 23:11:41 -04001779 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001780}
1781
1782bool State::getPackReverseRowOrder() const
1783{
1784 return mPack.reverseRowOrder;
1785}
1786
Minmin Gongadff67b2015-10-14 10:34:45 -04001787void State::setPackRowLength(GLint rowLength)
1788{
1789 mPack.rowLength = rowLength;
Jamie Madillc67323a2017-11-02 23:11:41 -04001790 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001791}
1792
1793GLint State::getPackRowLength() const
1794{
1795 return mPack.rowLength;
1796}
1797
1798void State::setPackSkipRows(GLint skipRows)
1799{
1800 mPack.skipRows = skipRows;
Jamie Madillc67323a2017-11-02 23:11:41 -04001801 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001802}
1803
1804GLint State::getPackSkipRows() const
1805{
1806 return mPack.skipRows;
1807}
1808
1809void State::setPackSkipPixels(GLint skipPixels)
1810{
1811 mPack.skipPixels = skipPixels;
Jamie Madillc67323a2017-11-02 23:11:41 -04001812 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001813}
1814
1815GLint State::getPackSkipPixels() const
1816{
1817 return mPack.skipPixels;
1818}
1819
Shannon Woods53a94a82014-06-24 15:20:36 -04001820const PixelPackState &State::getPackState() const
1821{
1822 return mPack;
1823}
1824
Jamie Madill87de3622015-03-16 10:41:44 -04001825PixelPackState &State::getPackState()
1826{
1827 return mPack;
1828}
1829
Shannon Woods53a94a82014-06-24 15:20:36 -04001830void State::setUnpackAlignment(GLint alignment)
1831{
1832 mUnpack.alignment = alignment;
Jamie Madillc67323a2017-11-02 23:11:41 -04001833 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001834}
1835
1836GLint State::getUnpackAlignment() const
1837{
1838 return mUnpack.alignment;
1839}
1840
Minmin Gongb8aee3b2015-01-27 14:42:36 -08001841void State::setUnpackRowLength(GLint rowLength)
1842{
1843 mUnpack.rowLength = rowLength;
Jamie Madillc67323a2017-11-02 23:11:41 -04001844 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongb8aee3b2015-01-27 14:42:36 -08001845}
1846
1847GLint State::getUnpackRowLength() const
1848{
1849 return mUnpack.rowLength;
1850}
1851
Minmin Gongadff67b2015-10-14 10:34:45 -04001852void State::setUnpackImageHeight(GLint imageHeight)
1853{
1854 mUnpack.imageHeight = imageHeight;
Jamie Madillc67323a2017-11-02 23:11:41 -04001855 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001856}
1857
1858GLint State::getUnpackImageHeight() const
1859{
1860 return mUnpack.imageHeight;
1861}
1862
1863void State::setUnpackSkipImages(GLint skipImages)
1864{
1865 mUnpack.skipImages = skipImages;
Jamie Madillc67323a2017-11-02 23:11:41 -04001866 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001867}
1868
1869GLint State::getUnpackSkipImages() const
1870{
1871 return mUnpack.skipImages;
1872}
1873
1874void State::setUnpackSkipRows(GLint skipRows)
1875{
1876 mUnpack.skipRows = skipRows;
Jamie Madillc67323a2017-11-02 23:11:41 -04001877 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001878}
1879
1880GLint State::getUnpackSkipRows() const
1881{
1882 return mUnpack.skipRows;
1883}
1884
1885void State::setUnpackSkipPixels(GLint skipPixels)
1886{
1887 mUnpack.skipPixels = skipPixels;
Jamie Madillc67323a2017-11-02 23:11:41 -04001888 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001889}
1890
1891GLint State::getUnpackSkipPixels() const
1892{
1893 return mUnpack.skipPixels;
1894}
1895
Shannon Woods53a94a82014-06-24 15:20:36 -04001896const PixelUnpackState &State::getUnpackState() const
1897{
1898 return mUnpack;
1899}
1900
Jamie Madill67102f02015-03-16 10:41:42 -04001901PixelUnpackState &State::getUnpackState()
1902{
1903 return mUnpack;
1904}
1905
Geoff Lang70d0f492015-12-10 17:45:46 -05001906const Debug &State::getDebug() const
1907{
1908 return mDebug;
1909}
1910
1911Debug &State::getDebug()
1912{
1913 return mDebug;
1914}
1915
Sami Väisänena797e062016-05-12 15:23:40 +03001916void State::setCoverageModulation(GLenum components)
1917{
1918 mCoverageModulation = components;
1919 mDirtyBits.set(DIRTY_BIT_COVERAGE_MODULATION);
1920}
1921
1922GLenum State::getCoverageModulation() const
1923{
1924 return mCoverageModulation;
1925}
1926
Sami Väisänene45e53b2016-05-25 10:36:04 +03001927void State::loadPathRenderingMatrix(GLenum matrixMode, const GLfloat *matrix)
1928{
1929 if (matrixMode == GL_PATH_MODELVIEW_CHROMIUM)
1930 {
1931 memcpy(mPathMatrixMV, matrix, 16 * sizeof(GLfloat));
jchen10bb2f2c42018-09-16 09:47:38 +08001932 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING);
Sami Väisänene45e53b2016-05-25 10:36:04 +03001933 }
1934 else if (matrixMode == GL_PATH_PROJECTION_CHROMIUM)
1935 {
1936 memcpy(mPathMatrixProj, matrix, 16 * sizeof(GLfloat));
jchen10bb2f2c42018-09-16 09:47:38 +08001937 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING);
Sami Väisänene45e53b2016-05-25 10:36:04 +03001938 }
1939 else
1940 {
1941 UNREACHABLE();
1942 }
1943}
1944
1945const GLfloat *State::getPathRenderingMatrix(GLenum which) const
1946{
1947 if (which == GL_PATH_MODELVIEW_MATRIX_CHROMIUM)
1948 {
1949 return mPathMatrixMV;
1950 }
1951 else if (which == GL_PATH_PROJECTION_MATRIX_CHROMIUM)
1952 {
1953 return mPathMatrixProj;
1954 }
1955
1956 UNREACHABLE();
1957 return nullptr;
1958}
1959
1960void State::setPathStencilFunc(GLenum func, GLint ref, GLuint mask)
1961{
1962 mPathStencilFunc = func;
1963 mPathStencilRef = ref;
1964 mPathStencilMask = mask;
jchen10bb2f2c42018-09-16 09:47:38 +08001965 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING);
Sami Väisänene45e53b2016-05-25 10:36:04 +03001966}
1967
1968GLenum State::getPathStencilFunc() const
1969{
1970 return mPathStencilFunc;
1971}
1972
1973GLint State::getPathStencilRef() const
1974{
1975 return mPathStencilRef;
1976}
1977
1978GLuint State::getPathStencilMask() const
1979{
1980 return mPathStencilMask;
1981}
1982
Geoff Lang1d2c41d2016-10-19 16:14:46 -07001983void State::setFramebufferSRGB(bool sRGB)
1984{
1985 mFramebufferSRGB = sRGB;
1986 mDirtyBits.set(DIRTY_BIT_FRAMEBUFFER_SRGB);
1987}
1988
1989bool State::getFramebufferSRGB() const
1990{
1991 return mFramebufferSRGB;
1992}
1993
jchen1082af6202018-06-22 10:59:52 +08001994void State::setMaxShaderCompilerThreads(GLuint count)
1995{
1996 mMaxShaderCompilerThreads = count;
1997}
1998
1999GLuint State::getMaxShaderCompilerThreads() const
2000{
2001 return mMaxShaderCompilerThreads;
2002}
2003
Shannon Woods53a94a82014-06-24 15:20:36 -04002004void State::getBooleanv(GLenum pname, GLboolean *params)
2005{
2006 switch (pname)
2007 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002008 case GL_SAMPLE_COVERAGE_INVERT:
2009 *params = mSampleCoverageInvert;
2010 break;
2011 case GL_DEPTH_WRITEMASK:
2012 *params = mDepthStencil.depthMask;
2013 break;
2014 case GL_COLOR_WRITEMASK:
2015 params[0] = mBlend.colorMaskRed;
2016 params[1] = mBlend.colorMaskGreen;
2017 params[2] = mBlend.colorMaskBlue;
2018 params[3] = mBlend.colorMaskAlpha;
2019 break;
2020 case GL_CULL_FACE:
2021 *params = mRasterizer.cullFace;
2022 break;
2023 case GL_POLYGON_OFFSET_FILL:
2024 *params = mRasterizer.polygonOffsetFill;
2025 break;
2026 case GL_SAMPLE_ALPHA_TO_COVERAGE:
2027 *params = mBlend.sampleAlphaToCoverage;
2028 break;
2029 case GL_SAMPLE_COVERAGE:
2030 *params = mSampleCoverage;
2031 break;
2032 case GL_SAMPLE_MASK:
2033 *params = mSampleMask;
2034 break;
2035 case GL_SCISSOR_TEST:
2036 *params = mScissorTest;
2037 break;
2038 case GL_STENCIL_TEST:
2039 *params = mDepthStencil.stencilTest;
2040 break;
2041 case GL_DEPTH_TEST:
2042 *params = mDepthStencil.depthTest;
2043 break;
2044 case GL_BLEND:
2045 *params = mBlend.blend;
2046 break;
2047 case GL_DITHER:
2048 *params = mBlend.dither;
2049 break;
2050 case GL_TRANSFORM_FEEDBACK_ACTIVE:
2051 *params = getCurrentTransformFeedback()->isActive() ? GL_TRUE : GL_FALSE;
2052 break;
2053 case GL_TRANSFORM_FEEDBACK_PAUSED:
2054 *params = getCurrentTransformFeedback()->isPaused() ? GL_TRUE : GL_FALSE;
2055 break;
2056 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
2057 *params = mPrimitiveRestart;
2058 break;
2059 case GL_RASTERIZER_DISCARD:
2060 *params = isRasterizerDiscardEnabled() ? GL_TRUE : GL_FALSE;
2061 break;
2062 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
2063 *params = mDebug.isOutputSynchronous() ? GL_TRUE : GL_FALSE;
2064 break;
2065 case GL_DEBUG_OUTPUT:
2066 *params = mDebug.isOutputEnabled() ? GL_TRUE : GL_FALSE;
2067 break;
2068 case GL_MULTISAMPLE_EXT:
2069 *params = mMultiSampling;
2070 break;
2071 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
2072 *params = mSampleAlphaToOne;
2073 break;
2074 case GL_BIND_GENERATES_RESOURCE_CHROMIUM:
2075 *params = isBindGeneratesResourceEnabled() ? GL_TRUE : GL_FALSE;
2076 break;
2077 case GL_CLIENT_ARRAYS_ANGLE:
2078 *params = areClientArraysEnabled() ? GL_TRUE : GL_FALSE;
2079 break;
2080 case GL_FRAMEBUFFER_SRGB_EXT:
2081 *params = getFramebufferSRGB() ? GL_TRUE : GL_FALSE;
2082 break;
2083 case GL_ROBUST_RESOURCE_INITIALIZATION_ANGLE:
2084 *params = mRobustResourceInit ? GL_TRUE : GL_FALSE;
2085 break;
2086 case GL_PROGRAM_CACHE_ENABLED_ANGLE:
2087 *params = mProgramBinaryCacheEnabled ? GL_TRUE : GL_FALSE;
2088 break;
Lingfeng Yangd0febe72018-05-17 22:36:52 -07002089 case GL_LIGHT_MODEL_TWO_SIDE:
2090 *params = IsLightModelTwoSided(&mGLES1State);
2091 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002092 default:
2093 UNREACHABLE();
2094 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002095 }
2096}
2097
2098void State::getFloatv(GLenum pname, GLfloat *params)
2099{
2100 // Please note: DEPTH_CLEAR_VALUE is included in our internal getFloatv implementation
2101 // because it is stored as a float, despite the fact that the GL ES 2.0 spec names
2102 // GetIntegerv as its native query function. As it would require conversion in any
2103 // case, this should make no difference to the calling application.
2104 switch (pname)
2105 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002106 case GL_LINE_WIDTH:
2107 *params = mLineWidth;
2108 break;
2109 case GL_SAMPLE_COVERAGE_VALUE:
2110 *params = mSampleCoverageValue;
2111 break;
2112 case GL_DEPTH_CLEAR_VALUE:
2113 *params = mDepthClearValue;
2114 break;
2115 case GL_POLYGON_OFFSET_FACTOR:
2116 *params = mRasterizer.polygonOffsetFactor;
2117 break;
2118 case GL_POLYGON_OFFSET_UNITS:
2119 *params = mRasterizer.polygonOffsetUnits;
2120 break;
2121 case GL_DEPTH_RANGE:
2122 params[0] = mNearZ;
2123 params[1] = mFarZ;
2124 break;
2125 case GL_COLOR_CLEAR_VALUE:
2126 params[0] = mColorClearValue.red;
2127 params[1] = mColorClearValue.green;
2128 params[2] = mColorClearValue.blue;
2129 params[3] = mColorClearValue.alpha;
2130 break;
2131 case GL_BLEND_COLOR:
2132 params[0] = mBlendColor.red;
2133 params[1] = mBlendColor.green;
2134 params[2] = mBlendColor.blue;
2135 params[3] = mBlendColor.alpha;
2136 break;
2137 case GL_MULTISAMPLE_EXT:
2138 *params = static_cast<GLfloat>(mMultiSampling);
2139 break;
2140 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
2141 *params = static_cast<GLfloat>(mSampleAlphaToOne);
2142 break;
2143 case GL_COVERAGE_MODULATION_CHROMIUM:
2144 params[0] = static_cast<GLfloat>(mCoverageModulation);
2145 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -07002146 case GL_ALPHA_TEST_REF:
2147 *params = mGLES1State.mAlphaTestRef;
2148 break;
Lingfeng Yanga43994c2018-03-29 07:21:41 -07002149 case GL_CURRENT_COLOR:
2150 {
2151 const auto &color = mGLES1State.mCurrentColor;
2152 params[0] = color.red;
2153 params[1] = color.green;
2154 params[2] = color.blue;
2155 params[3] = color.alpha;
2156 break;
2157 }
Lingfeng Yang5a7e61b2018-03-29 16:50:32 -07002158 case GL_CURRENT_NORMAL:
2159 {
2160 const auto &normal = mGLES1State.mCurrentNormal;
2161 params[0] = normal[0];
2162 params[1] = normal[1];
2163 params[2] = normal[2];
2164 break;
2165 }
Lingfeng Yang038dd532018-03-29 17:31:52 -07002166 case GL_CURRENT_TEXTURE_COORDS:
2167 {
2168 const auto &texcoord = mGLES1State.mCurrentTextureCoords[mActiveSampler];
2169 params[0] = texcoord.s;
2170 params[1] = texcoord.t;
2171 params[2] = texcoord.r;
2172 params[3] = texcoord.q;
2173 break;
2174 }
Lingfeng Yang3a41af62018-04-09 07:28:56 -07002175 case GL_MODELVIEW_MATRIX:
2176 memcpy(params, mGLES1State.mModelviewMatrices.back().data(), 16 * sizeof(GLfloat));
2177 break;
2178 case GL_PROJECTION_MATRIX:
2179 memcpy(params, mGLES1State.mProjectionMatrices.back().data(), 16 * sizeof(GLfloat));
2180 break;
2181 case GL_TEXTURE_MATRIX:
2182 memcpy(params, mGLES1State.mTextureMatrices[mActiveSampler].back().data(),
2183 16 * sizeof(GLfloat));
2184 break;
Lingfeng Yangd0febe72018-05-17 22:36:52 -07002185 case GL_LIGHT_MODEL_AMBIENT:
2186 GetLightModelParameters(&mGLES1State, pname, params);
2187 break;
Lingfeng Yang7ba3f422018-06-01 09:43:04 -07002188 case GL_FOG_MODE:
2189 case GL_FOG_DENSITY:
2190 case GL_FOG_START:
2191 case GL_FOG_END:
2192 case GL_FOG_COLOR:
2193 GetFogParameters(&mGLES1State, pname, params);
2194 break;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -07002195 case GL_POINT_SIZE:
2196 GetPointSize(&mGLES1State, params);
2197 break;
2198 case GL_POINT_SIZE_MIN:
2199 case GL_POINT_SIZE_MAX:
2200 case GL_POINT_FADE_THRESHOLD_SIZE:
2201 case GL_POINT_DISTANCE_ATTENUATION:
2202 GetPointParameter(&mGLES1State, FromGLenum<PointParameter>(pname), params);
2203 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002204 default:
2205 UNREACHABLE();
2206 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002207 }
2208}
2209
Jamie Madille98b1b52018-03-08 09:47:23 -05002210Error State::getIntegerv(const Context *context, GLenum pname, GLint *params)
Shannon Woods53a94a82014-06-24 15:20:36 -04002211{
2212 if (pname >= GL_DRAW_BUFFER0_EXT && pname <= GL_DRAW_BUFFER15_EXT)
2213 {
2214 unsigned int colorAttachment = (pname - GL_DRAW_BUFFER0_EXT);
Shannon Woods2df6a602014-09-26 16:12:07 -04002215 ASSERT(colorAttachment < mMaxDrawBuffers);
Shannon Woods53a94a82014-06-24 15:20:36 -04002216 Framebuffer *framebuffer = mDrawFramebuffer;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002217 *params = framebuffer->getDrawBufferState(colorAttachment);
Jamie Madille98b1b52018-03-08 09:47:23 -05002218 return NoError();
Shannon Woods53a94a82014-06-24 15:20:36 -04002219 }
2220
2221 // Please note: DEPTH_CLEAR_VALUE is not included in our internal getIntegerv implementation
2222 // because it is stored as a float, despite the fact that the GL ES 2.0 spec names
2223 // GetIntegerv as its native query function. As it would require conversion in any
2224 // case, this should make no difference to the calling application. You may find it in
2225 // State::getFloatv.
2226 switch (pname)
2227 {
Corentin Wallez336129f2017-10-17 15:55:40 -04002228 case GL_ARRAY_BUFFER_BINDING:
2229 *params = mBoundBuffers[BufferBinding::Array].id();
2230 break;
2231 case GL_DRAW_INDIRECT_BUFFER_BINDING:
2232 *params = mBoundBuffers[BufferBinding::DrawIndirect].id();
2233 break;
2234 case GL_ELEMENT_ARRAY_BUFFER_BINDING:
2235 *params = getVertexArray()->getElementArrayBuffer().id();
2236 break;
Jamie Madill690c8eb2018-03-12 15:20:03 -04002237 case GL_DRAW_FRAMEBUFFER_BINDING:
2238 static_assert(GL_DRAW_FRAMEBUFFER_BINDING == GL_DRAW_FRAMEBUFFER_BINDING_ANGLE,
2239 "Enum mismatch");
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002240 *params = mDrawFramebuffer->id();
2241 break;
Jamie Madill690c8eb2018-03-12 15:20:03 -04002242 case GL_READ_FRAMEBUFFER_BINDING:
2243 static_assert(GL_READ_FRAMEBUFFER_BINDING == GL_READ_FRAMEBUFFER_BINDING_ANGLE,
2244 "Enum mismatch");
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002245 *params = mReadFramebuffer->id();
2246 break;
2247 case GL_RENDERBUFFER_BINDING:
2248 *params = mRenderbuffer.id();
2249 break;
2250 case GL_VERTEX_ARRAY_BINDING:
2251 *params = mVertexArray->id();
2252 break;
2253 case GL_CURRENT_PROGRAM:
2254 *params = mProgram ? mProgram->id() : 0;
2255 break;
2256 case GL_PACK_ALIGNMENT:
2257 *params = mPack.alignment;
2258 break;
2259 case GL_PACK_REVERSE_ROW_ORDER_ANGLE:
2260 *params = mPack.reverseRowOrder;
2261 break;
2262 case GL_PACK_ROW_LENGTH:
2263 *params = mPack.rowLength;
2264 break;
2265 case GL_PACK_SKIP_ROWS:
2266 *params = mPack.skipRows;
2267 break;
2268 case GL_PACK_SKIP_PIXELS:
2269 *params = mPack.skipPixels;
2270 break;
2271 case GL_UNPACK_ALIGNMENT:
2272 *params = mUnpack.alignment;
2273 break;
2274 case GL_UNPACK_ROW_LENGTH:
2275 *params = mUnpack.rowLength;
2276 break;
2277 case GL_UNPACK_IMAGE_HEIGHT:
2278 *params = mUnpack.imageHeight;
2279 break;
2280 case GL_UNPACK_SKIP_IMAGES:
2281 *params = mUnpack.skipImages;
2282 break;
2283 case GL_UNPACK_SKIP_ROWS:
2284 *params = mUnpack.skipRows;
2285 break;
2286 case GL_UNPACK_SKIP_PIXELS:
2287 *params = mUnpack.skipPixels;
2288 break;
2289 case GL_GENERATE_MIPMAP_HINT:
2290 *params = mGenerateMipmapHint;
2291 break;
2292 case GL_FRAGMENT_SHADER_DERIVATIVE_HINT_OES:
2293 *params = mFragmentShaderDerivativeHint;
2294 break;
2295 case GL_ACTIVE_TEXTURE:
2296 *params = (static_cast<GLint>(mActiveSampler) + GL_TEXTURE0);
2297 break;
2298 case GL_STENCIL_FUNC:
2299 *params = mDepthStencil.stencilFunc;
2300 break;
2301 case GL_STENCIL_REF:
2302 *params = mStencilRef;
2303 break;
2304 case GL_STENCIL_VALUE_MASK:
2305 *params = CastMaskValue(context, mDepthStencil.stencilMask);
2306 break;
2307 case GL_STENCIL_BACK_FUNC:
2308 *params = mDepthStencil.stencilBackFunc;
2309 break;
2310 case GL_STENCIL_BACK_REF:
2311 *params = mStencilBackRef;
2312 break;
2313 case GL_STENCIL_BACK_VALUE_MASK:
2314 *params = CastMaskValue(context, mDepthStencil.stencilBackMask);
2315 break;
2316 case GL_STENCIL_FAIL:
2317 *params = mDepthStencil.stencilFail;
2318 break;
2319 case GL_STENCIL_PASS_DEPTH_FAIL:
2320 *params = mDepthStencil.stencilPassDepthFail;
2321 break;
2322 case GL_STENCIL_PASS_DEPTH_PASS:
2323 *params = mDepthStencil.stencilPassDepthPass;
2324 break;
2325 case GL_STENCIL_BACK_FAIL:
2326 *params = mDepthStencil.stencilBackFail;
2327 break;
2328 case GL_STENCIL_BACK_PASS_DEPTH_FAIL:
2329 *params = mDepthStencil.stencilBackPassDepthFail;
2330 break;
2331 case GL_STENCIL_BACK_PASS_DEPTH_PASS:
2332 *params = mDepthStencil.stencilBackPassDepthPass;
2333 break;
2334 case GL_DEPTH_FUNC:
2335 *params = mDepthStencil.depthFunc;
2336 break;
2337 case GL_BLEND_SRC_RGB:
2338 *params = mBlend.sourceBlendRGB;
2339 break;
2340 case GL_BLEND_SRC_ALPHA:
2341 *params = mBlend.sourceBlendAlpha;
2342 break;
2343 case GL_BLEND_DST_RGB:
2344 *params = mBlend.destBlendRGB;
2345 break;
2346 case GL_BLEND_DST_ALPHA:
2347 *params = mBlend.destBlendAlpha;
2348 break;
2349 case GL_BLEND_EQUATION_RGB:
2350 *params = mBlend.blendEquationRGB;
2351 break;
2352 case GL_BLEND_EQUATION_ALPHA:
2353 *params = mBlend.blendEquationAlpha;
2354 break;
2355 case GL_STENCIL_WRITEMASK:
2356 *params = CastMaskValue(context, mDepthStencil.stencilWritemask);
2357 break;
2358 case GL_STENCIL_BACK_WRITEMASK:
2359 *params = CastMaskValue(context, mDepthStencil.stencilBackWritemask);
2360 break;
2361 case GL_STENCIL_CLEAR_VALUE:
2362 *params = mStencilClearValue;
2363 break;
2364 case GL_IMPLEMENTATION_COLOR_READ_TYPE:
Jamie Madill690c8eb2018-03-12 15:20:03 -04002365 ANGLE_TRY(mReadFramebuffer->getImplementationColorReadType(
2366 context, reinterpret_cast<GLenum *>(params)));
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002367 break;
2368 case GL_IMPLEMENTATION_COLOR_READ_FORMAT:
Jamie Madill690c8eb2018-03-12 15:20:03 -04002369 ANGLE_TRY(mReadFramebuffer->getImplementationColorReadFormat(
2370 context, reinterpret_cast<GLenum *>(params)));
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002371 break;
2372 case GL_SAMPLE_BUFFERS:
2373 case GL_SAMPLES:
Shannon Woods53a94a82014-06-24 15:20:36 -04002374 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002375 Framebuffer *framebuffer = mDrawFramebuffer;
Jamie Madill427064d2018-04-13 16:20:34 -04002376 if (framebuffer->isComplete(context))
Shannon Woods53a94a82014-06-24 15:20:36 -04002377 {
Jamie Madill427064d2018-04-13 16:20:34 -04002378 GLint samples = framebuffer->getSamples(context);
Shannon Woods53a94a82014-06-24 15:20:36 -04002379 switch (pname)
2380 {
Jamie Madilla0016b72017-07-14 14:30:46 -04002381 case GL_SAMPLE_BUFFERS:
Jamie Madille98b1b52018-03-08 09:47:23 -05002382 if (samples != 0)
Jamie Madilla0016b72017-07-14 14:30:46 -04002383 {
2384 *params = 1;
2385 }
2386 else
2387 {
2388 *params = 0;
2389 }
2390 break;
2391 case GL_SAMPLES:
Jamie Madille98b1b52018-03-08 09:47:23 -05002392 *params = samples;
Jamie Madilla0016b72017-07-14 14:30:46 -04002393 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002394 }
2395 }
2396 else
2397 {
2398 *params = 0;
2399 }
2400 }
2401 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002402 case GL_VIEWPORT:
2403 params[0] = mViewport.x;
2404 params[1] = mViewport.y;
2405 params[2] = mViewport.width;
2406 params[3] = mViewport.height;
2407 break;
2408 case GL_SCISSOR_BOX:
2409 params[0] = mScissor.x;
2410 params[1] = mScissor.y;
2411 params[2] = mScissor.width;
2412 params[3] = mScissor.height;
2413 break;
2414 case GL_CULL_FACE_MODE:
2415 *params = ToGLenum(mRasterizer.cullMode);
2416 break;
2417 case GL_FRONT_FACE:
2418 *params = mRasterizer.frontFace;
2419 break;
2420 case GL_RED_BITS:
2421 case GL_GREEN_BITS:
2422 case GL_BLUE_BITS:
2423 case GL_ALPHA_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002424 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002425 Framebuffer *framebuffer = getDrawFramebuffer();
2426 const FramebufferAttachment *colorbuffer = framebuffer->getFirstColorbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002427
2428 if (colorbuffer)
2429 {
2430 switch (pname)
2431 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002432 case GL_RED_BITS:
2433 *params = colorbuffer->getRedSize();
2434 break;
2435 case GL_GREEN_BITS:
2436 *params = colorbuffer->getGreenSize();
2437 break;
2438 case GL_BLUE_BITS:
2439 *params = colorbuffer->getBlueSize();
2440 break;
2441 case GL_ALPHA_BITS:
2442 *params = colorbuffer->getAlphaSize();
2443 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002444 }
2445 }
2446 else
2447 {
2448 *params = 0;
2449 }
2450 }
2451 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002452 case GL_DEPTH_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002453 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002454 const Framebuffer *framebuffer = getDrawFramebuffer();
2455 const FramebufferAttachment *depthbuffer = framebuffer->getDepthbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002456
2457 if (depthbuffer)
2458 {
2459 *params = depthbuffer->getDepthSize();
2460 }
2461 else
2462 {
2463 *params = 0;
2464 }
2465 }
2466 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002467 case GL_STENCIL_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002468 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002469 const Framebuffer *framebuffer = getDrawFramebuffer();
2470 const FramebufferAttachment *stencilbuffer = framebuffer->getStencilbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002471
2472 if (stencilbuffer)
2473 {
2474 *params = stencilbuffer->getStencilSize();
2475 }
2476 else
2477 {
2478 *params = 0;
2479 }
2480 }
2481 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002482 case GL_TEXTURE_BINDING_2D:
2483 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2484 *params =
2485 getSamplerTextureId(static_cast<unsigned int>(mActiveSampler), TextureType::_2D);
2486 break;
2487 case GL_TEXTURE_BINDING_RECTANGLE_ANGLE:
2488 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2489 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2490 TextureType::Rectangle);
2491 break;
2492 case GL_TEXTURE_BINDING_CUBE_MAP:
2493 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2494 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2495 TextureType::CubeMap);
2496 break;
2497 case GL_TEXTURE_BINDING_3D:
2498 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2499 *params =
2500 getSamplerTextureId(static_cast<unsigned int>(mActiveSampler), TextureType::_3D);
2501 break;
2502 case GL_TEXTURE_BINDING_2D_ARRAY:
2503 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2504 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2505 TextureType::_2DArray);
2506 break;
2507 case GL_TEXTURE_BINDING_2D_MULTISAMPLE:
2508 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2509 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2510 TextureType::_2DMultisample);
2511 break;
Olli Etuahodff32a02018-08-28 14:35:50 +03002512 case GL_TEXTURE_BINDING_2D_MULTISAMPLE_ARRAY:
2513 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2514 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2515 TextureType::_2DMultisampleArray);
2516 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002517 case GL_TEXTURE_BINDING_EXTERNAL_OES:
2518 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2519 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2520 TextureType::External);
2521 break;
2522 case GL_UNIFORM_BUFFER_BINDING:
2523 *params = mBoundBuffers[BufferBinding::Uniform].id();
2524 break;
2525 case GL_TRANSFORM_FEEDBACK_BINDING:
2526 *params = mTransformFeedback.id();
2527 break;
2528 case GL_TRANSFORM_FEEDBACK_BUFFER_BINDING:
2529 *params = mBoundBuffers[BufferBinding::TransformFeedback].id();
2530 break;
2531 case GL_COPY_READ_BUFFER_BINDING:
2532 *params = mBoundBuffers[BufferBinding::CopyRead].id();
2533 break;
2534 case GL_COPY_WRITE_BUFFER_BINDING:
2535 *params = mBoundBuffers[BufferBinding::CopyWrite].id();
2536 break;
2537 case GL_PIXEL_PACK_BUFFER_BINDING:
2538 *params = mBoundBuffers[BufferBinding::PixelPack].id();
2539 break;
2540 case GL_PIXEL_UNPACK_BUFFER_BINDING:
2541 *params = mBoundBuffers[BufferBinding::PixelUnpack].id();
2542 break;
2543 case GL_READ_BUFFER:
2544 *params = mReadFramebuffer->getReadBufferState();
2545 break;
2546 case GL_SAMPLER_BINDING:
2547 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2548 *params = getSamplerId(static_cast<GLuint>(mActiveSampler));
2549 break;
2550 case GL_DEBUG_LOGGED_MESSAGES:
2551 *params = static_cast<GLint>(mDebug.getMessageCount());
2552 break;
2553 case GL_DEBUG_NEXT_LOGGED_MESSAGE_LENGTH:
2554 *params = static_cast<GLint>(mDebug.getNextMessageLength());
2555 break;
2556 case GL_DEBUG_GROUP_STACK_DEPTH:
2557 *params = static_cast<GLint>(mDebug.getGroupStackDepth());
2558 break;
2559 case GL_MULTISAMPLE_EXT:
2560 *params = static_cast<GLint>(mMultiSampling);
2561 break;
2562 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
2563 *params = static_cast<GLint>(mSampleAlphaToOne);
2564 break;
2565 case GL_COVERAGE_MODULATION_CHROMIUM:
2566 *params = static_cast<GLint>(mCoverageModulation);
2567 break;
2568 case GL_ATOMIC_COUNTER_BUFFER_BINDING:
2569 *params = mBoundBuffers[BufferBinding::AtomicCounter].id();
2570 break;
2571 case GL_SHADER_STORAGE_BUFFER_BINDING:
2572 *params = mBoundBuffers[BufferBinding::ShaderStorage].id();
2573 break;
2574 case GL_DISPATCH_INDIRECT_BUFFER_BINDING:
2575 *params = mBoundBuffers[BufferBinding::DispatchIndirect].id();
2576 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -07002577 case GL_ALPHA_TEST_FUNC:
2578 *params = ToGLenum(mGLES1State.mAlphaTestFunc);
2579 break;
Lingfeng Yang96310cd2018-03-28 11:56:28 -07002580 case GL_CLIENT_ACTIVE_TEXTURE:
2581 *params = mGLES1State.mClientActiveTexture + GL_TEXTURE0;
2582 break;
Lingfeng Yangd2488ab2018-04-04 09:25:48 -07002583 case GL_MATRIX_MODE:
2584 *params = ToGLenum(mGLES1State.mMatrixMode);
2585 break;
Lingfeng Yanga0cfa872018-05-30 21:12:17 -07002586 case GL_SHADE_MODEL:
2587 *params = ToGLenum(mGLES1State.mShadeModel);
2588 break;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -07002589 case GL_MODELVIEW_STACK_DEPTH:
2590 case GL_PROJECTION_STACK_DEPTH:
2591 case GL_TEXTURE_STACK_DEPTH:
2592 *params = mGLES1State.getCurrentMatrixStackDepth(pname);
2593 break;
2594 case GL_LOGIC_OP_MODE:
2595 *params = ToGLenum(mGLES1State.mLogicOp);
2596 break;
2597 case GL_BLEND_SRC:
2598 *params = mBlend.sourceBlendRGB;
2599 break;
2600 case GL_BLEND_DST:
2601 *params = mBlend.destBlendRGB;
2602 break;
2603 case GL_PERSPECTIVE_CORRECTION_HINT:
2604 case GL_POINT_SMOOTH_HINT:
2605 case GL_LINE_SMOOTH_HINT:
2606 case GL_FOG_HINT:
2607 *params = mGLES1State.getHint(pname);
2608 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002609 default:
2610 UNREACHABLE();
2611 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002612 }
Jamie Madille98b1b52018-03-08 09:47:23 -05002613
2614 return NoError();
Shannon Woods53a94a82014-06-24 15:20:36 -04002615}
2616
Lingfeng Yangabb09f12018-04-16 10:43:53 -07002617void State::getPointerv(const Context *context, GLenum pname, void **params) const
Geoff Lang70d0f492015-12-10 17:45:46 -05002618{
2619 switch (pname)
2620 {
2621 case GL_DEBUG_CALLBACK_FUNCTION:
2622 *params = reinterpret_cast<void *>(mDebug.getCallback());
2623 break;
2624 case GL_DEBUG_CALLBACK_USER_PARAM:
2625 *params = const_cast<void *>(mDebug.getUserParam());
2626 break;
Lingfeng Yangabb09f12018-04-16 10:43:53 -07002627 case GL_VERTEX_ARRAY_POINTER:
2628 case GL_NORMAL_ARRAY_POINTER:
2629 case GL_COLOR_ARRAY_POINTER:
2630 case GL_TEXTURE_COORD_ARRAY_POINTER:
2631 case GL_POINT_SIZE_ARRAY_POINTER_OES:
2632 QueryVertexAttribPointerv(getVertexArray()->getVertexAttribute(
2633 context->vertexArrayIndex(ParamToVertexArrayType(pname))),
2634 GL_VERTEX_ATTRIB_ARRAY_POINTER, params);
2635 return;
Geoff Lang70d0f492015-12-10 17:45:46 -05002636 default:
2637 UNREACHABLE();
2638 break;
2639 }
2640}
2641
Martin Radev66fb8202016-07-28 11:45:20 +03002642void State::getIntegeri_v(GLenum target, GLuint index, GLint *data)
Shannon Woods53a94a82014-06-24 15:20:36 -04002643{
2644 switch (target)
2645 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002646 case GL_TRANSFORM_FEEDBACK_BUFFER_BINDING:
2647 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2648 *data = mTransformFeedback->getIndexedBuffer(index).id();
2649 break;
2650 case GL_UNIFORM_BUFFER_BINDING:
2651 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2652 *data = mUniformBuffers[index].id();
2653 break;
2654 case GL_ATOMIC_COUNTER_BUFFER_BINDING:
2655 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2656 *data = mAtomicCounterBuffers[index].id();
2657 break;
2658 case GL_SHADER_STORAGE_BUFFER_BINDING:
2659 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2660 *data = mShaderStorageBuffers[index].id();
2661 break;
2662 case GL_VERTEX_BINDING_BUFFER:
2663 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2664 *data = mVertexArray->getVertexBinding(index).getBuffer().id();
2665 break;
2666 case GL_VERTEX_BINDING_DIVISOR:
2667 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2668 *data = mVertexArray->getVertexBinding(index).getDivisor();
2669 break;
2670 case GL_VERTEX_BINDING_OFFSET:
2671 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2672 *data = static_cast<GLuint>(mVertexArray->getVertexBinding(index).getOffset());
2673 break;
2674 case GL_VERTEX_BINDING_STRIDE:
2675 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2676 *data = mVertexArray->getVertexBinding(index).getStride();
2677 break;
2678 case GL_SAMPLE_MASK_VALUE:
2679 ASSERT(static_cast<size_t>(index) < mSampleMaskValues.size());
2680 *data = mSampleMaskValues[index];
2681 break;
2682 case GL_IMAGE_BINDING_NAME:
2683 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2684 *data = mImageUnits[index].texture.id();
2685 break;
2686 case GL_IMAGE_BINDING_LEVEL:
2687 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2688 *data = mImageUnits[index].level;
2689 break;
2690 case GL_IMAGE_BINDING_LAYER:
2691 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2692 *data = mImageUnits[index].layer;
2693 break;
2694 case GL_IMAGE_BINDING_ACCESS:
2695 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2696 *data = mImageUnits[index].access;
2697 break;
2698 case GL_IMAGE_BINDING_FORMAT:
2699 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2700 *data = mImageUnits[index].format;
2701 break;
2702 default:
2703 UNREACHABLE();
2704 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002705 }
Shannon Woods53a94a82014-06-24 15:20:36 -04002706}
2707
Martin Radev66fb8202016-07-28 11:45:20 +03002708void State::getInteger64i_v(GLenum target, GLuint index, GLint64 *data)
Shannon Woods53a94a82014-06-24 15:20:36 -04002709{
2710 switch (target)
2711 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002712 case GL_TRANSFORM_FEEDBACK_BUFFER_START:
2713 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2714 *data = mTransformFeedback->getIndexedBuffer(index).getOffset();
2715 break;
2716 case GL_TRANSFORM_FEEDBACK_BUFFER_SIZE:
2717 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2718 *data = mTransformFeedback->getIndexedBuffer(index).getSize();
2719 break;
2720 case GL_UNIFORM_BUFFER_START:
2721 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2722 *data = mUniformBuffers[index].getOffset();
2723 break;
2724 case GL_UNIFORM_BUFFER_SIZE:
2725 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2726 *data = mUniformBuffers[index].getSize();
2727 break;
2728 case GL_ATOMIC_COUNTER_BUFFER_START:
2729 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2730 *data = mAtomicCounterBuffers[index].getOffset();
2731 break;
2732 case GL_ATOMIC_COUNTER_BUFFER_SIZE:
2733 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2734 *data = mAtomicCounterBuffers[index].getSize();
2735 break;
2736 case GL_SHADER_STORAGE_BUFFER_START:
2737 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2738 *data = mShaderStorageBuffers[index].getOffset();
2739 break;
2740 case GL_SHADER_STORAGE_BUFFER_SIZE:
2741 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2742 *data = mShaderStorageBuffers[index].getSize();
2743 break;
2744 default:
2745 UNREACHABLE();
2746 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002747 }
Martin Radev66fb8202016-07-28 11:45:20 +03002748}
Shannon Woods53a94a82014-06-24 15:20:36 -04002749
Martin Radev66fb8202016-07-28 11:45:20 +03002750void State::getBooleani_v(GLenum target, GLuint index, GLboolean *data)
2751{
Xinghua Cao9c8e1a32017-12-06 17:59:58 +08002752 switch (target)
2753 {
2754 case GL_IMAGE_BINDING_LAYERED:
2755 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2756 *data = mImageUnits[index].layered;
2757 break;
2758 default:
2759 UNREACHABLE();
2760 break;
2761 }
Shannon Woods53a94a82014-06-24 15:20:36 -04002762}
2763
Jamie Madill6f755b22018-10-09 12:48:54 -04002764angle::Result State::syncDirtyObjects(const Context *context, const DirtyObjects &bitset)
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002765{
Jiajia Qin5ae6ee42018-03-06 17:39:42 +08002766 const DirtyObjects &dirtyObjects = mDirtyObjects & bitset;
2767 for (auto dirtyObject : dirtyObjects)
Jamie Madillc9d442d2016-01-20 11:17:24 -05002768 {
2769 switch (dirtyObject)
2770 {
2771 case DIRTY_OBJECT_READ_FRAMEBUFFER:
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002772 ASSERT(mReadFramebuffer);
Jamie Madill19fa1c62018-03-08 09:47:21 -05002773 ANGLE_TRY(mReadFramebuffer->syncState(context));
Jamie Madillc9d442d2016-01-20 11:17:24 -05002774 break;
2775 case DIRTY_OBJECT_DRAW_FRAMEBUFFER:
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002776 ASSERT(mDrawFramebuffer);
Jamie Madill19fa1c62018-03-08 09:47:21 -05002777 ANGLE_TRY(mDrawFramebuffer->syncState(context));
Jamie Madillc9d442d2016-01-20 11:17:24 -05002778 break;
2779 case DIRTY_OBJECT_VERTEX_ARRAY:
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002780 ASSERT(mVertexArray);
Frank Henigman0af5b862018-03-27 20:19:33 -04002781 ANGLE_TRY(mVertexArray->syncState(context));
Jamie Madillc9d442d2016-01-20 11:17:24 -05002782 break;
Jamie Madille25b8002018-09-20 13:39:49 -04002783 case DIRTY_OBJECT_SAMPLERS:
2784 syncSamplers(context);
2785 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002786 case DIRTY_OBJECT_PROGRAM_TEXTURES:
Luc Ferron4bba74f2018-04-19 14:40:45 -04002787 ANGLE_TRY(syncProgramTextures(context));
Jamie Madill81c2e252017-09-09 23:32:46 -04002788 break;
Jamie Madill70aeda42018-08-20 12:17:40 -04002789 case DIRTY_OBJECT_PROGRAM:
2790 ANGLE_TRY(mProgram->syncState(context));
2791 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002792
Jamie Madillc9d442d2016-01-20 11:17:24 -05002793 default:
2794 UNREACHABLE();
2795 break;
2796 }
2797 }
2798
Jiajia Qin5ae6ee42018-03-06 17:39:42 +08002799 mDirtyObjects &= ~dirtyObjects;
Jamie Madill6f755b22018-10-09 12:48:54 -04002800 return angle::Result::Continue();
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002801}
2802
Jamie Madille25b8002018-09-20 13:39:49 -04002803void State::syncSamplers(const Context *context)
2804{
2805 if (mDirtySamplers.none())
2806 return;
2807
2808 // This could be optimized by tracking which samplers are dirty.
2809 for (size_t samplerIndex : mDirtySamplers)
2810 {
2811 BindingPointer<Sampler> &sampler = mSamplers[samplerIndex];
2812 if (sampler.get())
2813 {
2814 sampler->syncState(context);
2815 }
2816 }
2817
2818 mDirtySamplers.reset();
2819}
2820
Jamie Madill6f755b22018-10-09 12:48:54 -04002821angle::Result State::syncProgramTextures(const Context *context)
Jamie Madill81c2e252017-09-09 23:32:46 -04002822{
Jamie Madill81c2e252017-09-09 23:32:46 -04002823 // TODO(jmadill): Fine-grained updates.
2824 if (!mProgram)
2825 {
Jamie Madill6f755b22018-10-09 12:48:54 -04002826 return angle::Result::Continue();
Jamie Madill81c2e252017-09-09 23:32:46 -04002827 }
2828
2829 ASSERT(mDirtyObjects[DIRTY_OBJECT_PROGRAM_TEXTURES]);
2830 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
2831
Jamie Madill0f80ed82017-09-19 00:24:56 -04002832 ActiveTextureMask newActiveTextures;
2833
Geoff Lange51ba632017-11-21 11:45:25 -05002834 // Initialize to the 'Initialized' state and set to 'MayNeedInit' if any texture is not
2835 // initialized.
2836 mCachedTexturesInitState = InitState::Initialized;
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002837 mCachedImageTexturesInitState = InitState::Initialized;
Geoff Lange51ba632017-11-21 11:45:25 -05002838
Jamie Madill7e4eff12018-08-08 15:49:26 -04002839 const ActiveTextureMask &activeTextures = mProgram->getActiveSamplersMask();
2840 const ActiveTextureArray<TextureType> &textureTypes = mProgram->getActiveSamplerTypes();
2841
2842 for (size_t textureUnitIndex : activeTextures)
Jamie Madill81c2e252017-09-09 23:32:46 -04002843 {
Jamie Madill7e4eff12018-08-08 15:49:26 -04002844 TextureType textureType = textureTypes[textureUnitIndex];
Jamie Madill81c2e252017-09-09 23:32:46 -04002845
jchen1090f466a2018-08-13 15:05:25 +08002846 Texture *texture =
2847 getSamplerTexture(static_cast<unsigned int>(textureUnitIndex), textureType);
Jamie Madill7e4eff12018-08-08 15:49:26 -04002848 ASSERT(static_cast<size_t>(textureUnitIndex) < newActiveTextures.size());
2849
2850 ASSERT(texture);
2851
Jamie Madill7e4eff12018-08-08 15:49:26 -04002852 newActiveTextures.set(textureUnitIndex);
Jamie Madille3bb6b72018-10-03 17:51:15 -04002853 ANGLE_TRY(updateActiveTexture(context, textureUnitIndex, texture));
Jamie Madill81c2e252017-09-09 23:32:46 -04002854 }
Jamie Madill0f80ed82017-09-19 00:24:56 -04002855
2856 // Unset now missing textures.
Jamie Madill7e4eff12018-08-08 15:49:26 -04002857 ActiveTextureMask negativeMask = activeTextures & ~newActiveTextures;
Jamie Madill0f80ed82017-09-19 00:24:56 -04002858 if (negativeMask.any())
2859 {
Jamie Madille3bb6b72018-10-03 17:51:15 -04002860 unsetActiveTextures(negativeMask);
Jamie Madill0f80ed82017-09-19 00:24:56 -04002861 }
Luc Ferron4bba74f2018-04-19 14:40:45 -04002862
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002863 for (size_t imageUnitIndex : mProgram->getActiveImagesMask())
2864 {
2865 Texture *texture = mImageUnits[imageUnitIndex].texture.get();
2866 if (!texture)
2867 {
2868 continue;
2869 }
Jamie Madillf668a4b2018-09-23 17:01:20 -04002870 if (texture->hasAnyDirtyBit())
2871 {
2872 ANGLE_TRY(texture->syncState(context));
2873 }
Qin Jiajia47f6dd02018-08-10 13:36:32 +08002874 if (texture->initState() == InitState::MayNeedInit)
2875 {
2876 mCachedImageTexturesInitState = InitState::MayNeedInit;
2877 }
2878 }
2879
Jamie Madill6f755b22018-10-09 12:48:54 -04002880 return angle::Result::Continue();
Jamie Madill81c2e252017-09-09 23:32:46 -04002881}
2882
Jamie Madill6f755b22018-10-09 12:48:54 -04002883angle::Result State::syncDirtyObject(const Context *context, GLenum target)
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002884{
2885 DirtyObjects localSet;
2886
2887 switch (target)
2888 {
2889 case GL_READ_FRAMEBUFFER:
2890 localSet.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2891 break;
2892 case GL_DRAW_FRAMEBUFFER:
2893 localSet.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2894 break;
2895 case GL_FRAMEBUFFER:
2896 localSet.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2897 localSet.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2898 break;
2899 case GL_VERTEX_ARRAY:
2900 localSet.set(DIRTY_OBJECT_VERTEX_ARRAY);
2901 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002902 case GL_TEXTURE:
Jamie Madille25b8002018-09-20 13:39:49 -04002903 localSet.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
2904 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002905 case GL_SAMPLER:
Jamie Madill70aeda42018-08-20 12:17:40 -04002906 localSet.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Jamie Madille25b8002018-09-20 13:39:49 -04002907 localSet.set(DIRTY_OBJECT_SAMPLERS);
Jamie Madill70aeda42018-08-20 12:17:40 -04002908 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002909 case GL_PROGRAM:
2910 localSet.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Jamie Madill70aeda42018-08-20 12:17:40 -04002911 localSet.set(DIRTY_OBJECT_PROGRAM);
Jamie Madill81c2e252017-09-09 23:32:46 -04002912 break;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002913 }
2914
Jamie Madillbc918e72018-03-08 09:47:21 -05002915 return syncDirtyObjects(context, localSet);
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002916}
2917
2918void State::setObjectDirty(GLenum target)
2919{
2920 switch (target)
2921 {
2922 case GL_READ_FRAMEBUFFER:
2923 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2924 break;
2925 case GL_DRAW_FRAMEBUFFER:
2926 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2927 break;
2928 case GL_FRAMEBUFFER:
2929 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2930 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2931 break;
2932 case GL_VERTEX_ARRAY:
2933 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
2934 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002935 case GL_TEXTURE:
Jamie Madill70aeda42018-08-20 12:17:40 -04002936 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
2937 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
2938 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002939 case GL_PROGRAM:
2940 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Jamie Madill70aeda42018-08-20 12:17:40 -04002941 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM);
Jamie Madill81c2e252017-09-09 23:32:46 -04002942 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
2943 break;
Jamie Madilla779b612017-07-24 11:46:05 -04002944 }
2945}
2946
Jamie Madill6f755b22018-10-09 12:48:54 -04002947angle::Result State::onProgramExecutableChange(const Context *context, Program *program)
Jamie Madilla779b612017-07-24 11:46:05 -04002948{
2949 // OpenGL Spec:
2950 // "If LinkProgram or ProgramBinary successfully re-links a program object
2951 // that was already in use as a result of a previous call to UseProgram, then the
2952 // generated executable code will be installed as part of the current rendering state."
Jamie Madilldf836ff2018-10-01 10:36:24 -04002953 ASSERT(program->isLinked());
2954
2955 mDirtyBits.set(DIRTY_BIT_PROGRAM_EXECUTABLE);
Jamie Madill956ab4d2018-10-10 16:13:03 -04002956
2957 if (program->hasAnyDirtyBit())
2958 {
2959 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM);
2960 }
Jamie Madille3bb6b72018-10-03 17:51:15 -04002961
2962 // Set any bound textures.
2963 const ActiveTextureTypeArray &textureTypes = program->getActiveSamplerTypes();
2964 for (size_t textureIndex : program->getActiveSamplersMask())
2965 {
2966 TextureType type = textureTypes[textureIndex];
2967
2968 // This can happen if there is a conflicting texture type.
2969 if (type == TextureType::InvalidEnum)
2970 continue;
2971
2972 Texture *texture = mSamplerTextures[type][textureIndex].get();
2973 ANGLE_TRY(updateActiveTexture(context, textureIndex, texture));
2974 }
2975
2976 for (size_t imageUnitIndex : program->getActiveImagesMask())
2977 {
2978 Texture *image = mImageUnits[imageUnitIndex].texture.get();
2979 if (!image)
2980 continue;
2981
2982 if (image->hasAnyDirtyBit())
2983 {
2984 ANGLE_TRY(image->syncState(context));
2985 }
2986
2987 if (image->initState() == InitState::MayNeedInit)
2988 {
2989 mCachedImageTexturesInitState = InitState::MayNeedInit;
2990 }
2991 }
2992
Jamie Madill6f755b22018-10-09 12:48:54 -04002993 return angle::Result::Continue();
Shannon Woods53a94a82014-06-24 15:20:36 -04002994}
Jamie Madillc9d442d2016-01-20 11:17:24 -05002995
Jamie Madille25b8002018-09-20 13:39:49 -04002996void State::setSamplerDirty(size_t samplerIndex)
2997{
2998 mDirtyObjects.set(DIRTY_OBJECT_SAMPLERS);
2999 mDirtySamplers.set(samplerIndex);
3000}
3001
Xinghua Cao65ec0b22017-03-28 16:10:52 +08003002void State::setImageUnit(const Context *context,
Will Harris63aa0e52018-09-05 16:15:46 -07003003 size_t unit,
Xinghua Cao65ec0b22017-03-28 16:10:52 +08003004 Texture *texture,
3005 GLint level,
3006 GLboolean layered,
3007 GLint layer,
3008 GLenum access,
3009 GLenum format)
3010{
3011 mImageUnits[unit].texture.set(context, texture);
3012 mImageUnits[unit].level = level;
3013 mImageUnits[unit].layered = layered;
3014 mImageUnits[unit].layer = layer;
3015 mImageUnits[unit].access = access;
3016 mImageUnits[unit].format = format;
jchen1099118c12018-09-10 16:28:51 +08003017 mDirtyBits.set(DIRTY_BIT_IMAGE_BINDINGS);
Xinghua Cao65ec0b22017-03-28 16:10:52 +08003018}
3019
Will Harris63aa0e52018-09-05 16:15:46 -07003020const ImageUnit &State::getImageUnit(size_t unit) const
Xinghua Cao65ec0b22017-03-28 16:10:52 +08003021{
3022 return mImageUnits[unit];
3023}
3024
Jamie Madill81c2e252017-09-09 23:32:46 -04003025// Handle a dirty texture event.
Jamie Madill6c43a012018-08-08 15:49:27 -04003026void State::onActiveTextureStateChange(size_t textureIndex)
Jamie Madill81c2e252017-09-09 23:32:46 -04003027{
3028 // Conservatively assume all textures are dirty.
3029 // TODO(jmadill): More fine-grained update.
3030 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM_TEXTURES);
Geoff Lange51ba632017-11-21 11:45:25 -05003031
Jamie Madill6c43a012018-08-08 15:49:27 -04003032 if (!mActiveTexturesCache[textureIndex] ||
3033 mActiveTexturesCache[textureIndex]->initState() == InitState::MayNeedInit)
Geoff Lange51ba632017-11-21 11:45:25 -05003034 {
3035 mCachedTexturesInitState = InitState::MayNeedInit;
3036 }
Jamie Madill81c2e252017-09-09 23:32:46 -04003037}
3038
Jamie Madill6d32cef2018-08-14 02:34:28 -04003039void State::onUniformBufferStateChange(size_t uniformBufferIndex)
3040{
3041 // This could be represented by a different dirty bit. Using the same one keeps it simple.
3042 mDirtyBits.set(DIRTY_BIT_UNIFORM_BUFFER_BINDINGS);
3043}
3044
Jamie Madill6f755b22018-10-09 12:48:54 -04003045angle::Result State::clearUnclearedActiveTextures(const Context *context)
Jamie Madill05b35b22017-10-03 09:01:44 -04003046{
Jamie Madilla59fc192017-11-02 12:57:58 -04003047 ASSERT(mRobustResourceInit);
Geoff Lang9bf86f02018-07-26 11:46:34 -04003048 ASSERT(!mDirtyObjects[DIRTY_OBJECT_PROGRAM_TEXTURES]);
Geoff Langd4fff502017-09-22 11:28:28 -04003049
Jamie Madill7e4eff12018-08-08 15:49:26 -04003050 if (!mProgram)
Jamie Madill6f755b22018-10-09 12:48:54 -04003051 return angle::Result::Continue();
Jamie Madill7e4eff12018-08-08 15:49:26 -04003052
Qin Jiajia47f6dd02018-08-10 13:36:32 +08003053 if (mCachedTexturesInitState != InitState::Initialized)
Jamie Madill05b35b22017-10-03 09:01:44 -04003054 {
Qin Jiajia47f6dd02018-08-10 13:36:32 +08003055 for (size_t textureUnitIndex : mProgram->getActiveSamplersMask())
Jamie Madill05b35b22017-10-03 09:01:44 -04003056 {
Qin Jiajia47f6dd02018-08-10 13:36:32 +08003057 Texture *texture = mActiveTexturesCache[textureUnitIndex];
3058 if (texture)
3059 {
3060 ANGLE_TRY(texture->ensureInitialized(context));
3061 }
Jamie Madill05b35b22017-10-03 09:01:44 -04003062 }
Qin Jiajia47f6dd02018-08-10 13:36:32 +08003063 mCachedTexturesInitState = InitState::Initialized;
Jamie Madill05b35b22017-10-03 09:01:44 -04003064 }
Qin Jiajia47f6dd02018-08-10 13:36:32 +08003065 if (mCachedImageTexturesInitState != InitState::Initialized)
3066 {
3067 for (size_t imageUnitIndex : mProgram->getActiveImagesMask())
3068 {
3069 Texture *texture = mImageUnits[imageUnitIndex].texture.get();
3070 if (texture)
3071 {
3072 ANGLE_TRY(texture->ensureInitialized(context));
3073 }
3074 }
3075 mCachedImageTexturesInitState = InitState::Initialized;
3076 }
Jamie Madill6f755b22018-10-09 12:48:54 -04003077 return angle::Result::Continue();
Jamie Madill05b35b22017-10-03 09:01:44 -04003078}
3079
Jamie Madillc67323a2017-11-02 23:11:41 -04003080AttributesMask State::getAndResetDirtyCurrentValues() const
3081{
3082 AttributesMask retVal = mDirtyCurrentValues;
3083 mDirtyCurrentValues.reset();
3084 return retVal;
3085}
3086
James Darpiniane8a93c62018-01-04 18:02:24 -08003087bool State::isCurrentTransformFeedback(const TransformFeedback *tf) const
3088{
3089 return tf == mTransformFeedback.get();
3090}
Jamie Madillc9d442d2016-01-20 11:17:24 -05003091} // namespace gl