blob: fb65fa329771b91be6f5ac4e7903b83e30742c08 [file] [log] [blame]
Shannon Woods53a94a82014-06-24 15:20:36 -04001//
2// Copyright (c) 2014 The ANGLE Project Authors. All rights reserved.
3// Use of this source code is governed by a BSD-style license that can be
4// found in the LICENSE file.
5//
6
7// State.cpp: Implements the State class, encapsulating raw GL state.
8
Geoff Lang2b5420c2014-11-19 14:20:15 -05009#include "libANGLE/State.h"
Shannon Woods53a94a82014-06-24 15:20:36 -040010
Sami Väisänene45e53b2016-05-25 10:36:04 +030011#include <string.h>
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -070012#include <limits>
Sami Väisänene45e53b2016-05-25 10:36:04 +030013
Jamie Madill20e005b2017-04-07 14:19:22 -040014#include "common/bitset_utils.h"
Sami Väisänene45e53b2016-05-25 10:36:04 +030015#include "common/mathutil.h"
jchen10a99ed552017-09-22 08:10:32 +080016#include "common/matrix_utils.h"
Jamie Madillcd0a0a32018-10-18 18:41:57 -040017#include "libANGLE/Buffer.h"
Geoff Lang2b5420c2014-11-19 14:20:15 -050018#include "libANGLE/Caps.h"
jchen10a99ed552017-09-22 08:10:32 +080019#include "libANGLE/Context.h"
Geoff Lang70d0f492015-12-10 17:45:46 -050020#include "libANGLE/Debug.h"
Geoff Lang2b5420c2014-11-19 14:20:15 -050021#include "libANGLE/Framebuffer.h"
22#include "libANGLE/FramebufferAttachment.h"
23#include "libANGLE/Query.h"
24#include "libANGLE/VertexArray.h"
25#include "libANGLE/formatutils.h"
jchen10a99ed552017-09-22 08:10:32 +080026#include "libANGLE/queryconversions.h"
Lingfeng Yangabb09f12018-04-16 10:43:53 -070027#include "libANGLE/queryutils.h"
Geoff Lang4751aab2017-10-30 15:14:52 -040028#include "libANGLE/renderer/ContextImpl.h"
Jamie Madillf668a4b2018-09-23 17:01:20 -040029#include "libANGLE/renderer/TextureImpl.h"
Shannon Woods53a94a82014-06-24 15:20:36 -040030
Corentin Wallezad3ae902018-03-09 13:40:42 -050031namespace gl
32{
33
Olli Etuahobbf1c102016-06-28 13:31:33 +030034namespace
35{
Corentin Wallezad3ae902018-03-09 13:40:42 -050036bool GetAlternativeQueryType(QueryType type, QueryType *alternativeType)
Olli Etuahobbf1c102016-06-28 13:31:33 +030037{
Corentin Wallezad3ae902018-03-09 13:40:42 -050038 switch (type)
39 {
40 case QueryType::AnySamples:
41 *alternativeType = QueryType::AnySamplesConservative;
42 return true;
43 case QueryType::AnySamplesConservative:
44 *alternativeType = QueryType::AnySamples;
45 return true;
46 default:
47 return false;
48 }
Olli Etuahobbf1c102016-06-28 13:31:33 +030049}
50
Jamie Madillca8eda42018-10-18 18:41:56 -040051// Mapping from a buffer binding type to a dirty bit type.
52constexpr angle::PackedEnumMap<BufferBinding, size_t> kBufferBindingDirtyBits = {{
Jamie Madill752d2202018-11-27 13:29:48 -050053 {BufferBinding::AtomicCounter, State::DIRTY_BIT_ATOMIC_COUNTER_BUFFER_BINDING},
54 {BufferBinding::DispatchIndirect, State::DIRTY_BIT_DISPATCH_INDIRECT_BUFFER_BINDING},
55 {BufferBinding::DrawIndirect, State::DIRTY_BIT_DRAW_INDIRECT_BUFFER_BINDING},
56 {BufferBinding::PixelPack, State::DIRTY_BIT_PACK_BUFFER_BINDING},
57 {BufferBinding::PixelUnpack, State::DIRTY_BIT_UNPACK_BUFFER_BINDING},
58 {BufferBinding::ShaderStorage, State::DIRTY_BIT_SHADER_STORAGE_BUFFER_BINDING},
59 {BufferBinding::Uniform, State::DIRTY_BIT_UNIFORM_BUFFER_BINDINGS},
Jamie Madillca8eda42018-10-18 18:41:56 -040060}};
61
62// Returns a buffer binding function depending on if a dirty bit is set.
63template <BufferBinding Target>
Jamie Madill752d2202018-11-27 13:29:48 -050064constexpr std::pair<BufferBinding, State::BufferBindingSetter> GetBufferBindingSetter()
Jamie Madillca8eda42018-10-18 18:41:56 -040065{
Jamie Madill752d2202018-11-27 13:29:48 -050066 return std::make_pair(Target, kBufferBindingDirtyBits[Target] != 0
67 ? &State::setGenericBufferBindingWithBit<Target>
68 : &State::setGenericBufferBinding<Target>);
Jamie Madillca8eda42018-10-18 18:41:56 -040069}
Jamie Madillc3dc5d42018-12-30 12:12:04 -050070
71template <typename T>
72using ContextStateMember = T *(State::*);
73
74template <typename T>
75T *AllocateOrGetSharedResourceManager(const State *shareContextState, ContextStateMember<T> member)
76{
77 if (shareContextState)
78 {
79 T *resourceManager = (*shareContextState).*member;
80 resourceManager->addRef();
81 return resourceManager;
82 }
83 else
84 {
85 return new T();
86 }
87}
88
89TextureManager *AllocateOrGetSharedTextureManager(const State *shareContextState,
90 TextureManager *shareTextures,
91 ContextStateMember<TextureManager> member)
92{
93 if (shareContextState)
94 {
95 TextureManager *textureManager = (*shareContextState).*member;
96 ASSERT(shareTextures == nullptr || textureManager == shareTextures);
97 textureManager->addRef();
98 return textureManager;
99 }
100 else if (shareTextures)
101 {
102 TextureManager *textureManager = shareTextures;
103 textureManager->addRef();
104 return textureManager;
105 }
106 else
107 {
108 return new TextureManager();
109 }
110}
Jamie Madillb980c562018-11-27 11:34:27 -0500111} // namespace
Olli Etuahobbf1c102016-06-28 13:31:33 +0300112
Jamie Madillbf5177d2018-08-21 12:58:20 -0400113template <typename BindingT, typename... ArgsT>
Jamie Madillca8eda42018-10-18 18:41:56 -0400114ANGLE_INLINE void UpdateNonTFBufferBinding(const Context *context,
115 BindingT *binding,
116 Buffer *buffer,
117 ArgsT... args)
James Darpiniane8a93c62018-01-04 18:02:24 -0800118{
Jamie Madillca8eda42018-10-18 18:41:56 -0400119 Buffer *oldBuffer = binding->get();
120 if (oldBuffer)
121 {
122 oldBuffer->onNonTFBindingChanged(-1);
123 oldBuffer->release(context);
124 }
125 binding->assign(buffer, args...);
126 if (buffer)
127 {
128 buffer->addRef();
129 buffer->onNonTFBindingChanged(1);
130 }
Jamie Madillbf5177d2018-08-21 12:58:20 -0400131}
132
133template <typename BindingT, typename... ArgsT>
134void UpdateTFBufferBinding(const Context *context, BindingT *binding, bool indexed, ArgsT... args)
135{
136 if (binding->get())
137 (*binding)->onTFBindingChanged(context, false, indexed);
138 binding->set(context, args...);
139 if (binding->get())
140 (*binding)->onTFBindingChanged(context, true, indexed);
James Darpiniane8a93c62018-01-04 18:02:24 -0800141}
142
143void UpdateBufferBinding(const Context *context,
Jamie Madillbf5177d2018-08-21 12:58:20 -0400144 BindingPointer<Buffer> *binding,
James Darpiniane8a93c62018-01-04 18:02:24 -0800145 Buffer *buffer,
Jamie Madillbf5177d2018-08-21 12:58:20 -0400146 BufferBinding target)
James Darpiniane8a93c62018-01-04 18:02:24 -0800147{
Jamie Madillbf5177d2018-08-21 12:58:20 -0400148 if (target == BufferBinding::TransformFeedback)
149 {
150 UpdateTFBufferBinding(context, binding, false, buffer);
151 }
152 else
153 {
154 UpdateNonTFBufferBinding(context, binding, buffer);
155 }
156}
157
158void UpdateIndexedBufferBinding(const Context *context,
159 OffsetBindingPointer<Buffer> *binding,
160 Buffer *buffer,
161 BufferBinding target,
162 GLintptr offset,
163 GLsizeiptr size)
164{
165 if (target == BufferBinding::TransformFeedback)
166 {
167 UpdateTFBufferBinding(context, binding, true, buffer, offset, size);
168 }
169 else
170 {
171 UpdateNonTFBufferBinding(context, binding, buffer, offset, size);
172 }
James Darpiniane8a93c62018-01-04 18:02:24 -0800173}
174
Jamie Madillca8eda42018-10-18 18:41:56 -0400175// These template functions must be defined before they are instantiated in kBufferSetters.
176template <BufferBinding Target>
177void State::setGenericBufferBindingWithBit(const Context *context, Buffer *buffer)
178{
179 UpdateNonTFBufferBinding(context, &mBoundBuffers[Target], buffer);
180 mDirtyBits.set(kBufferBindingDirtyBits[Target]);
181}
182
183template <BufferBinding Target>
184void State::setGenericBufferBinding(const Context *context, Buffer *buffer)
185{
186 UpdateNonTFBufferBinding(context, &mBoundBuffers[Target], buffer);
187}
188
189template <>
190void State::setGenericBufferBinding<BufferBinding::TransformFeedback>(const Context *context,
191 Buffer *buffer)
192{
193 UpdateTFBufferBinding(context, &mBoundBuffers[BufferBinding::TransformFeedback], false, buffer);
194}
195
196template <>
197void State::setGenericBufferBinding<BufferBinding::ElementArray>(const Context *context,
198 Buffer *buffer)
199{
200 Buffer *oldBuffer = mVertexArray->mState.mElementArrayBuffer.get();
201 if (oldBuffer)
202 {
Jamie Madillcd0a0a32018-10-18 18:41:57 -0400203 oldBuffer->removeObserver(&mVertexArray->mState.mElementArrayBuffer);
Jamie Madillca8eda42018-10-18 18:41:56 -0400204 oldBuffer->onNonTFBindingChanged(-1);
205 oldBuffer->release(context);
206 }
207 mVertexArray->mState.mElementArrayBuffer.assign(buffer);
208 if (buffer)
209 {
Jamie Madillcd0a0a32018-10-18 18:41:57 -0400210 buffer->addObserver(&mVertexArray->mState.mElementArrayBuffer);
Jamie Madillca8eda42018-10-18 18:41:56 -0400211 buffer->onNonTFBindingChanged(1);
212 buffer->addRef();
213 }
Jamie Madillca8eda42018-10-18 18:41:56 -0400214 mVertexArray->mDirtyBits.set(VertexArray::DIRTY_BIT_ELEMENT_ARRAY_BUFFER);
Jamie Madillc1fd7372018-10-26 22:48:39 -0400215 mVertexArray->mIndexRangeCache.invalidate();
Jamie Madillca8eda42018-10-18 18:41:56 -0400216 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
217}
218
219const angle::PackedEnumMap<BufferBinding, State::BufferBindingSetter> State::kBufferSetters = {{
220 GetBufferBindingSetter<BufferBinding::Array>(),
221 GetBufferBindingSetter<BufferBinding::AtomicCounter>(),
222 GetBufferBindingSetter<BufferBinding::CopyRead>(),
223 GetBufferBindingSetter<BufferBinding::CopyWrite>(),
224 GetBufferBindingSetter<BufferBinding::DispatchIndirect>(),
225 GetBufferBindingSetter<BufferBinding::DrawIndirect>(),
226 GetBufferBindingSetter<BufferBinding::ElementArray>(),
227 GetBufferBindingSetter<BufferBinding::PixelPack>(),
228 GetBufferBindingSetter<BufferBinding::PixelUnpack>(),
229 GetBufferBindingSetter<BufferBinding::ShaderStorage>(),
230 GetBufferBindingSetter<BufferBinding::TransformFeedback>(),
231 GetBufferBindingSetter<BufferBinding::Uniform>(),
232}};
233
Jamie Madillc3dc5d42018-12-30 12:12:04 -0500234State::State(ContextID contextIn,
235 const State *shareContextState,
236 TextureManager *shareTextures,
237 const Version &clientVersion,
238 bool debug,
Geoff Lang4fb8a8b2018-06-01 16:47:57 -0400239 bool bindGeneratesResource,
240 bool clientArraysEnabled,
241 bool robustResourceInit,
242 bool programBinaryCacheEnabled)
Jamie Madillc3dc5d42018-12-30 12:12:04 -0500243 : mClientVersion(clientVersion),
244 mContext(contextIn),
245 mBufferManager(AllocateOrGetSharedResourceManager(shareContextState, &State::mBufferManager)),
246 mShaderProgramManager(
247 AllocateOrGetSharedResourceManager(shareContextState, &State::mShaderProgramManager)),
248 mTextureManager(AllocateOrGetSharedTextureManager(shareContextState,
249 shareTextures,
250 &State::mTextureManager)),
251 mRenderbufferManager(
252 AllocateOrGetSharedResourceManager(shareContextState, &State::mRenderbufferManager)),
253 mSamplerManager(
254 AllocateOrGetSharedResourceManager(shareContextState, &State::mSamplerManager)),
255 mSyncManager(AllocateOrGetSharedResourceManager(shareContextState, &State::mSyncManager)),
256 mPathManager(AllocateOrGetSharedResourceManager(shareContextState, &State::mPathManager)),
257 mFramebufferManager(new FramebufferManager()),
258 mProgramPipelineManager(new ProgramPipelineManager()),
259 mMaxDrawBuffers(0),
Jamie Madille79b1e12015-11-04 16:36:37 -0500260 mMaxCombinedTextureImageUnits(0),
261 mDepthClearValue(0),
262 mStencilClearValue(0),
263 mScissorTest(false),
264 mSampleCoverage(false),
265 mSampleCoverageValue(0),
266 mSampleCoverageInvert(false),
Jiawei Shaodb342272017-09-27 10:21:45 +0800267 mSampleMask(false),
268 mMaxSampleMaskWords(0),
Jamie Madille79b1e12015-11-04 16:36:37 -0500269 mStencilRef(0),
270 mStencilBackRef(0),
271 mLineWidth(0),
272 mGenerateMipmapHint(GL_NONE),
273 mFragmentShaderDerivativeHint(GL_NONE),
Geoff Lang4fb8a8b2018-06-01 16:47:57 -0400274 mBindGeneratesResource(bindGeneratesResource),
275 mClientArraysEnabled(clientArraysEnabled),
Jamie Madille79b1e12015-11-04 16:36:37 -0500276 mNearZ(0),
277 mFarZ(0),
278 mReadFramebuffer(nullptr),
279 mDrawFramebuffer(nullptr),
280 mProgram(nullptr),
281 mVertexArray(nullptr),
282 mActiveSampler(0),
Jamie Madill4787d702018-08-08 15:49:26 -0400283 mActiveTexturesCache{},
James Darpiniane4109f22018-12-13 16:25:53 -0800284 mTexturesIncompatibleWithSamplers(0),
Sami Väisänen74c23472016-05-09 17:30:30 +0300285 mPrimitiveRestart(false),
Geoff Lang4fb8a8b2018-06-01 16:47:57 -0400286 mDebug(debug),
Sami Väisänen74c23472016-05-09 17:30:30 +0300287 mMultiSampling(false),
Geoff Lang1d2c41d2016-10-19 16:14:46 -0700288 mSampleAlphaToOne(false),
Jamie Madille08a1d32017-03-07 17:24:06 -0500289 mFramebufferSRGB(true),
Geoff Lang4fb8a8b2018-06-01 16:47:57 -0400290 mRobustResourceInit(robustResourceInit),
jchen1082af6202018-06-22 10:59:52 +0800291 mProgramBinaryCacheEnabled(programBinaryCacheEnabled),
292 mMaxShaderCompilerThreads(std::numeric_limits<GLuint>::max())
Jamie Madillb980c562018-11-27 11:34:27 -0500293{}
Geoff Lang76b10c92014-09-05 16:28:14 -0400294
Jamie Madillb980c562018-11-27 11:34:27 -0500295State::~State() {}
Geoff Lang76b10c92014-09-05 16:28:14 -0400296
Jamie Madill6c43a012018-08-08 15:49:27 -0400297void State::initialize(Context *context)
Geoff Lang76b10c92014-09-05 16:28:14 -0400298{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700299 const Caps &caps = context->getCaps();
300 const Extensions &extensions = context->getExtensions();
Geoff Lang4751aab2017-10-30 15:14:52 -0400301 const Extensions &nativeExtensions = context->getImplementation()->getNativeExtensions();
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700302 const Version &clientVersion = context->getClientVersion();
Jamie Madill4928b7c2017-06-20 12:57:39 -0400303
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700304 mMaxDrawBuffers = caps.maxDrawBuffers;
Shannon Woods2df6a602014-09-26 16:12:07 -0400305 mMaxCombinedTextureImageUnits = caps.maxCombinedTextureImageUnits;
Shannon Woods53a94a82014-06-24 15:20:36 -0400306
Jamie Madillf75ab352015-03-16 10:46:52 -0400307 setColorClearValue(0.0f, 0.0f, 0.0f, 0.0f);
Shannon Woods53a94a82014-06-24 15:20:36 -0400308
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700309 mDepthClearValue = 1.0f;
Shannon Woods53a94a82014-06-24 15:20:36 -0400310 mStencilClearValue = 0;
311
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700312 mScissorTest = false;
313 mScissor.x = 0;
314 mScissor.y = 0;
315 mScissor.width = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400316 mScissor.height = 0;
317
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700318 mBlendColor.red = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400319 mBlendColor.green = 0;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700320 mBlendColor.blue = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400321 mBlendColor.alpha = 0;
322
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700323 mStencilRef = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400324 mStencilBackRef = 0;
325
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700326 mSampleCoverage = false;
327 mSampleCoverageValue = 1.0f;
Shannon Woods53a94a82014-06-24 15:20:36 -0400328 mSampleCoverageInvert = false;
Jiawei Shaodb342272017-09-27 10:21:45 +0800329
330 mMaxSampleMaskWords = caps.maxSampleMaskWords;
331 mSampleMask = false;
332 mSampleMaskValues.fill(~GLbitfield(0));
333
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700334 mGenerateMipmapHint = GL_DONT_CARE;
Shannon Woods53a94a82014-06-24 15:20:36 -0400335 mFragmentShaderDerivativeHint = GL_DONT_CARE;
336
337 mLineWidth = 1.0f;
338
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700339 mViewport.x = 0;
340 mViewport.y = 0;
341 mViewport.width = 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400342 mViewport.height = 0;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700343 mNearZ = 0.0f;
344 mFarZ = 1.0f;
Shannon Woods53a94a82014-06-24 15:20:36 -0400345
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700346 mBlend.colorMaskRed = true;
Shannon Woods53a94a82014-06-24 15:20:36 -0400347 mBlend.colorMaskGreen = true;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700348 mBlend.colorMaskBlue = true;
Shannon Woods53a94a82014-06-24 15:20:36 -0400349 mBlend.colorMaskAlpha = true;
350
Geoff Lang76b10c92014-09-05 16:28:14 -0400351 mActiveSampler = 0;
352
Shannon Woods23e05002014-09-22 19:07:27 -0400353 mVertexAttribCurrentValues.resize(caps.maxVertexAttributes);
Shannon Woods53a94a82014-06-24 15:20:36 -0400354
Brandon Jonesc405ae72017-12-06 14:15:03 -0800355 // Set all indexes in state attributes type mask to float (default)
356 for (int i = 0; i < MAX_VERTEX_ATTRIBS; i++)
357 {
Jamie Madill6e18a232019-01-16 13:27:14 -0500358 SetComponentTypeMask(ComponentType::Float, i, &mCurrentValuesTypeMask);
Brandon Jonesc405ae72017-12-06 14:15:03 -0800359 }
360
Geoff Lang4dc3af02016-11-18 14:09:27 -0500361 mUniformBuffers.resize(caps.maxUniformBufferBindings);
Shannon Woodsf3acaf92014-09-23 18:07:11 -0400362
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800363 mSamplerTextures[TextureType::_2D].resize(caps.maxCombinedTextureImageUnits);
364 mSamplerTextures[TextureType::CubeMap].resize(caps.maxCombinedTextureImageUnits);
Geoff Langeb66a6e2016-10-31 13:06:12 -0400365 if (clientVersion >= Version(3, 0))
Shannon Woods53a94a82014-06-24 15:20:36 -0400366 {
Geoff Lang76b10c92014-09-05 16:28:14 -0400367 // TODO: These could also be enabled via extension
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800368 mSamplerTextures[TextureType::_2DArray].resize(caps.maxCombinedTextureImageUnits);
369 mSamplerTextures[TextureType::_3D].resize(caps.maxCombinedTextureImageUnits);
Shannon Woods53a94a82014-06-24 15:20:36 -0400370 }
Yizhou Jiang7818a852018-09-06 15:02:04 +0800371 if (clientVersion >= Version(3, 1) || nativeExtensions.textureMultisample)
372 {
373 mSamplerTextures[TextureType::_2DMultisample].resize(caps.maxCombinedTextureImageUnits);
374 }
Geoff Lang3b573612016-10-31 14:08:10 -0400375 if (clientVersion >= Version(3, 1))
376 {
Olli Etuahod310a432018-08-24 15:40:23 +0300377 mSamplerTextures[TextureType::_2DMultisampleArray].resize(
378 caps.maxCombinedTextureImageUnits);
Jiajia Qin6eafb042016-12-27 17:04:07 +0800379
380 mAtomicCounterBuffers.resize(caps.maxAtomicCounterBufferBindings);
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800381 mShaderStorageBuffers.resize(caps.maxShaderStorageBufferBindings);
Xinghua Cao65ec0b22017-03-28 16:10:52 +0800382 mImageUnits.resize(caps.maxImageUnits);
Geoff Lang3b573612016-10-31 14:08:10 -0400383 }
Geoff Lang4751aab2017-10-30 15:14:52 -0400384 if (nativeExtensions.textureRectangle)
Corentin Wallez13c0dd42017-07-04 18:27:01 -0400385 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800386 mSamplerTextures[TextureType::Rectangle].resize(caps.maxCombinedTextureImageUnits);
Corentin Wallez13c0dd42017-07-04 18:27:01 -0400387 }
Geoff Lang4751aab2017-10-30 15:14:52 -0400388 if (nativeExtensions.eglImageExternal || nativeExtensions.eglStreamConsumerExternal)
Ian Ewellbda75592016-04-18 17:25:54 -0400389 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800390 mSamplerTextures[TextureType::External].resize(caps.maxCombinedTextureImageUnits);
Ian Ewellbda75592016-04-18 17:25:54 -0400391 }
Jamie Madill81c2e252017-09-09 23:32:46 -0400392 mCompleteTextureBindings.reserve(caps.maxCombinedTextureImageUnits);
393 for (uint32_t textureIndex = 0; textureIndex < caps.maxCombinedTextureImageUnits;
394 ++textureIndex)
395 {
Jamie Madill6c43a012018-08-08 15:49:27 -0400396 mCompleteTextureBindings.emplace_back(context, textureIndex);
Jamie Madill81c2e252017-09-09 23:32:46 -0400397 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400398
Geoff Lang76b10c92014-09-05 16:28:14 -0400399 mSamplers.resize(caps.maxCombinedTextureImageUnits);
Shannon Woods53a94a82014-06-24 15:20:36 -0400400
Corentin Wallezad3ae902018-03-09 13:40:42 -0500401 for (QueryType type : angle::AllEnums<QueryType>())
402 {
403 mActiveQueries[type].set(context, nullptr);
404 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400405
Ian Ewell3ffd78b2016-01-22 16:09:42 -0500406 mProgram = nullptr;
Shannon Woods53a94a82014-06-24 15:20:36 -0400407
Ian Ewell3ffd78b2016-01-22 16:09:42 -0500408 mReadFramebuffer = nullptr;
409 mDrawFramebuffer = nullptr;
Jamie Madillb4b53c52015-02-03 15:22:48 -0500410
411 mPrimitiveRestart = false;
Geoff Lang70d0f492015-12-10 17:45:46 -0500412
Geoff Lang70d0f492015-12-10 17:45:46 -0500413 mDebug.setMaxLoggedMessages(extensions.maxDebugLoggedMessages);
Sami Väisänen74c23472016-05-09 17:30:30 +0300414
Geoff Lang488130e2017-09-27 13:53:11 -0400415 mMultiSampling = true;
416 mSampleAlphaToOne = false;
Sami Väisänena797e062016-05-12 15:23:40 +0300417
418 mCoverageModulation = GL_NONE;
Sami Väisänene45e53b2016-05-25 10:36:04 +0300419
420 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixProj);
421 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixMV);
422 mPathStencilFunc = GL_ALWAYS;
423 mPathStencilRef = 0;
424 mPathStencilMask = std::numeric_limits<GLuint>::max();
Jamie Madille08a1d32017-03-07 17:24:06 -0500425
Lingfeng Yangdbb9c532018-02-25 19:58:24 -0800426 // GLES1 emulation: Initialize state for GLES1 if version
427 // applies
428 if (clientVersion < Version(2, 0))
429 {
Lingfeng Yange547aac2018-04-05 09:39:20 -0700430 mGLES1State.initialize(context, this);
Lingfeng Yangdbb9c532018-02-25 19:58:24 -0800431 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400432}
433
Jamie Madill6c1f6712017-02-14 19:08:04 -0500434void State::reset(const Context *context)
Shannon Woods53a94a82014-06-24 15:20:36 -0400435{
Jamie Madill8693bdb2017-09-02 15:32:14 -0400436 for (auto &bindingVec : mSamplerTextures)
Shannon Woods53a94a82014-06-24 15:20:36 -0400437 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800438 for (size_t textureIdx = 0; textureIdx < bindingVec.size(); textureIdx++)
Shannon Woods53a94a82014-06-24 15:20:36 -0400439 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -0800440 bindingVec[textureIdx].set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400441 }
442 }
Geoff Lang76b10c92014-09-05 16:28:14 -0400443 for (size_t samplerIdx = 0; samplerIdx < mSamplers.size(); samplerIdx++)
444 {
Jamie Madill4928b7c2017-06-20 12:57:39 -0400445 mSamplers[samplerIdx].set(context, nullptr);
Geoff Lang76b10c92014-09-05 16:28:14 -0400446 }
Shannon Woods53a94a82014-06-24 15:20:36 -0400447
Xinghua Cao65ec0b22017-03-28 16:10:52 +0800448 for (auto &imageUnit : mImageUnits)
449 {
450 imageUnit.texture.set(context, nullptr);
451 imageUnit.level = 0;
452 imageUnit.layered = false;
453 imageUnit.layer = 0;
454 imageUnit.access = GL_READ_ONLY;
455 imageUnit.format = GL_R32UI;
456 }
457
Jamie Madill4928b7c2017-06-20 12:57:39 -0400458 mRenderbuffer.set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400459
Corentin Wallez336129f2017-10-17 15:55:40 -0400460 for (auto type : angle::AllEnums<BufferBinding>())
461 {
Jamie Madillbf5177d2018-08-21 12:58:20 -0400462 UpdateBufferBinding(context, &mBoundBuffers[type], nullptr, type);
Corentin Wallez336129f2017-10-17 15:55:40 -0400463 }
464
Geoff Lang7dd2e102014-11-10 15:19:26 -0500465 if (mProgram)
466 {
Jamie Madill6c1f6712017-02-14 19:08:04 -0500467 mProgram->release(context);
Geoff Lang7dd2e102014-11-10 15:19:26 -0500468 }
Yunchao Hed7297bf2017-04-19 15:27:10 +0800469 mProgram = nullptr;
Geoff Lang7dd2e102014-11-10 15:19:26 -0500470
Yunchao Hea336b902017-08-02 16:05:21 +0800471 mProgramPipeline.set(context, nullptr);
472
James Darpiniane8a93c62018-01-04 18:02:24 -0800473 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -0400474 mTransformFeedback->onBindingChanged(context, false);
Jamie Madill4928b7c2017-06-20 12:57:39 -0400475 mTransformFeedback.set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400476
Corentin Wallezad3ae902018-03-09 13:40:42 -0500477 for (QueryType type : angle::AllEnums<QueryType>())
Shannon Woods53a94a82014-06-24 15:20:36 -0400478 {
Corentin Wallezad3ae902018-03-09 13:40:42 -0500479 mActiveQueries[type].set(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -0400480 }
481
Corentin Wallez336129f2017-10-17 15:55:40 -0400482 for (auto &buf : mUniformBuffers)
Shannon Woods53a94a82014-06-24 15:20:36 -0400483 {
Jamie Madillbf5177d2018-08-21 12:58:20 -0400484 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::Uniform, 0, 0);
Shannon Woods53a94a82014-06-24 15:20:36 -0400485 }
486
Jiajia Qin6eafb042016-12-27 17:04:07 +0800487 for (auto &buf : mAtomicCounterBuffers)
488 {
Jamie Madillbf5177d2018-08-21 12:58:20 -0400489 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::AtomicCounter, 0, 0);
Jiajia Qin6eafb042016-12-27 17:04:07 +0800490 }
491
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800492 for (auto &buf : mShaderStorageBuffers)
493 {
Jamie Madillbf5177d2018-08-21 12:58:20 -0400494 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::ShaderStorage, 0, 0);
Jiajia Qinf546e7d2017-03-27 14:12:59 +0800495 }
496
Sami Väisänene45e53b2016-05-25 10:36:04 +0300497 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixProj);
498 angle::Matrix<GLfloat>::setToIdentity(mPathMatrixMV);
499 mPathStencilFunc = GL_ALWAYS;
500 mPathStencilRef = 0;
501 mPathStencilMask = std::numeric_limits<GLuint>::max();
502
Jamie Madill1b94d432015-08-07 13:23:23 -0400503 setAllDirtyBits();
Shannon Woods53a94a82014-06-24 15:20:36 -0400504}
505
Jamie Madille3bb6b72018-10-03 17:51:15 -0400506ANGLE_INLINE void State::unsetActiveTextures(ActiveTextureMask textureMask)
507{
508 // Unset any relevant bound textures.
509 for (size_t textureIndex : mProgram->getActiveSamplersMask())
510 {
511 mActiveTexturesCache[textureIndex] = nullptr;
512 mCompleteTextureBindings[textureIndex].reset();
513 }
514}
515
Jamie Madille3e680c2018-12-03 17:49:08 -0500516ANGLE_INLINE void State::updateActiveTextureState(const Context *context,
517 size_t textureIndex,
518 const Sampler *sampler,
519 Texture *texture)
520{
521 if (!texture->isSamplerComplete(context, sampler))
522 {
523 mActiveTexturesCache[textureIndex] = nullptr;
524 }
525 else
526 {
527 mActiveTexturesCache[textureIndex] = texture;
528
529 if (texture->hasAnyDirtyBit())
530 {
531 setTextureDirty(textureIndex);
532 }
533
Jamie Madill132d15c2018-11-30 15:25:38 -0500534 if (mRobustResourceInit && texture->initState() == InitState::MayNeedInit)
Jamie Madille3e680c2018-12-03 17:49:08 -0500535 {
Jamie Madill132d15c2018-11-30 15:25:38 -0500536 mDirtyObjects.set(DIRTY_OBJECT_TEXTURES_INIT);
Jamie Madille3e680c2018-12-03 17:49:08 -0500537 }
538 }
539
James Darpiniane4109f22018-12-13 16:25:53 -0800540 mTexturesIncompatibleWithSamplers[textureIndex] =
541 !texture->getTextureState().compatibleWithSamplerFormat(
542 mProgram->getState().getSamplerFormatForTextureUnitIndex(textureIndex));
543
Jamie Madille3e680c2018-12-03 17:49:08 -0500544 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
545}
546
547ANGLE_INLINE void State::updateActiveTexture(const Context *context,
548 size_t textureIndex,
549 Texture *texture)
Jamie Madille3bb6b72018-10-03 17:51:15 -0400550{
551 const Sampler *sampler = mSamplers[textureIndex].get();
552
Jamie Madille3e680c2018-12-03 17:49:08 -0500553 mCompleteTextureBindings[textureIndex].bind(texture);
554
Jamie Madille3bb6b72018-10-03 17:51:15 -0400555 if (!texture)
556 {
557 mActiveTexturesCache[textureIndex] = nullptr;
Jamie Madille3e680c2018-12-03 17:49:08 -0500558 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
559 return;
Jamie Madille3bb6b72018-10-03 17:51:15 -0400560 }
561
Jamie Madille3e680c2018-12-03 17:49:08 -0500562 updateActiveTextureState(context, textureIndex, sampler, texture);
Jamie Madille3bb6b72018-10-03 17:51:15 -0400563}
564
Shannon Woods53a94a82014-06-24 15:20:36 -0400565const RasterizerState &State::getRasterizerState() const
566{
567 return mRasterizer;
568}
569
570const BlendState &State::getBlendState() const
571{
572 return mBlend;
573}
574
575const DepthStencilState &State::getDepthStencilState() const
576{
577 return mDepthStencil;
578}
579
Jamie Madillf75ab352015-03-16 10:46:52 -0400580void State::setColorClearValue(float red, float green, float blue, float alpha)
Shannon Woods53a94a82014-06-24 15:20:36 -0400581{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700582 mColorClearValue.red = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400583 mColorClearValue.green = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700584 mColorClearValue.blue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400585 mColorClearValue.alpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400586 mDirtyBits.set(DIRTY_BIT_CLEAR_COLOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400587}
588
Jamie Madillf75ab352015-03-16 10:46:52 -0400589void State::setDepthClearValue(float depth)
Shannon Woods53a94a82014-06-24 15:20:36 -0400590{
591 mDepthClearValue = depth;
Jamie Madill1b94d432015-08-07 13:23:23 -0400592 mDirtyBits.set(DIRTY_BIT_CLEAR_DEPTH);
Shannon Woods53a94a82014-06-24 15:20:36 -0400593}
594
Jamie Madillf75ab352015-03-16 10:46:52 -0400595void State::setStencilClearValue(int stencil)
Shannon Woods53a94a82014-06-24 15:20:36 -0400596{
597 mStencilClearValue = stencil;
Jamie Madill1b94d432015-08-07 13:23:23 -0400598 mDirtyBits.set(DIRTY_BIT_CLEAR_STENCIL);
Shannon Woods53a94a82014-06-24 15:20:36 -0400599}
600
Shannon Woods53a94a82014-06-24 15:20:36 -0400601void State::setColorMask(bool red, bool green, bool blue, bool alpha)
602{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700603 mBlend.colorMaskRed = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400604 mBlend.colorMaskGreen = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700605 mBlend.colorMaskBlue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400606 mBlend.colorMaskAlpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400607 mDirtyBits.set(DIRTY_BIT_COLOR_MASK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400608}
609
610void State::setDepthMask(bool mask)
611{
612 mDepthStencil.depthMask = mask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400613 mDirtyBits.set(DIRTY_BIT_DEPTH_MASK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400614}
615
Shannon Woods53a94a82014-06-24 15:20:36 -0400616void State::setRasterizerDiscard(bool enabled)
617{
618 mRasterizer.rasterizerDiscard = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400619 mDirtyBits.set(DIRTY_BIT_RASTERIZER_DISCARD_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400620}
621
Shannon Woods53a94a82014-06-24 15:20:36 -0400622void State::setCullFace(bool enabled)
623{
624 mRasterizer.cullFace = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400625 mDirtyBits.set(DIRTY_BIT_CULL_FACE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400626}
627
Corentin Wallez2e568cf2017-09-18 17:05:22 -0400628void State::setCullMode(CullFaceMode mode)
Shannon Woods53a94a82014-06-24 15:20:36 -0400629{
630 mRasterizer.cullMode = mode;
Jamie Madill1b94d432015-08-07 13:23:23 -0400631 mDirtyBits.set(DIRTY_BIT_CULL_FACE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400632}
633
634void State::setFrontFace(GLenum front)
635{
636 mRasterizer.frontFace = front;
Jamie Madill1b94d432015-08-07 13:23:23 -0400637 mDirtyBits.set(DIRTY_BIT_FRONT_FACE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400638}
639
Shannon Woods53a94a82014-06-24 15:20:36 -0400640void State::setDepthTest(bool enabled)
641{
642 mDepthStencil.depthTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400643 mDirtyBits.set(DIRTY_BIT_DEPTH_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400644}
645
646void State::setDepthFunc(GLenum depthFunc)
647{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700648 mDepthStencil.depthFunc = depthFunc;
649 mDirtyBits.set(DIRTY_BIT_DEPTH_FUNC);
Shannon Woods53a94a82014-06-24 15:20:36 -0400650}
651
652void State::setDepthRange(float zNear, float zFar)
653{
654 mNearZ = zNear;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700655 mFarZ = zFar;
Jamie Madill1b94d432015-08-07 13:23:23 -0400656 mDirtyBits.set(DIRTY_BIT_DEPTH_RANGE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400657}
658
Shannon Woods53a94a82014-06-24 15:20:36 -0400659void State::setBlend(bool enabled)
660{
661 mBlend.blend = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400662 mDirtyBits.set(DIRTY_BIT_BLEND_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400663}
664
665void State::setBlendFactors(GLenum sourceRGB, GLenum destRGB, GLenum sourceAlpha, GLenum destAlpha)
666{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700667 mBlend.sourceBlendRGB = sourceRGB;
668 mBlend.destBlendRGB = destRGB;
Shannon Woods53a94a82014-06-24 15:20:36 -0400669 mBlend.sourceBlendAlpha = sourceAlpha;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700670 mBlend.destBlendAlpha = destAlpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400671 mDirtyBits.set(DIRTY_BIT_BLEND_FUNCS);
Shannon Woods53a94a82014-06-24 15:20:36 -0400672}
673
674void State::setBlendColor(float red, float green, float blue, float alpha)
675{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700676 mBlendColor.red = red;
Shannon Woods53a94a82014-06-24 15:20:36 -0400677 mBlendColor.green = green;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700678 mBlendColor.blue = blue;
Shannon Woods53a94a82014-06-24 15:20:36 -0400679 mBlendColor.alpha = alpha;
Jamie Madill1b94d432015-08-07 13:23:23 -0400680 mDirtyBits.set(DIRTY_BIT_BLEND_COLOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400681}
682
683void State::setBlendEquation(GLenum rgbEquation, GLenum alphaEquation)
684{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700685 mBlend.blendEquationRGB = rgbEquation;
Shannon Woods53a94a82014-06-24 15:20:36 -0400686 mBlend.blendEquationAlpha = alphaEquation;
Jamie Madill1b94d432015-08-07 13:23:23 -0400687 mDirtyBits.set(DIRTY_BIT_BLEND_EQUATIONS);
Shannon Woods53a94a82014-06-24 15:20:36 -0400688}
689
Shannon Woods53a94a82014-06-24 15:20:36 -0400690void State::setStencilTest(bool enabled)
691{
692 mDepthStencil.stencilTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400693 mDirtyBits.set(DIRTY_BIT_STENCIL_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400694}
695
696void State::setStencilParams(GLenum stencilFunc, GLint stencilRef, GLuint stencilMask)
697{
698 mDepthStencil.stencilFunc = stencilFunc;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700699 mStencilRef = (stencilRef > 0) ? stencilRef : 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400700 mDepthStencil.stencilMask = stencilMask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400701 mDirtyBits.set(DIRTY_BIT_STENCIL_FUNCS_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400702}
703
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700704void State::setStencilBackParams(GLenum stencilBackFunc,
705 GLint stencilBackRef,
706 GLuint stencilBackMask)
Shannon Woods53a94a82014-06-24 15:20:36 -0400707{
708 mDepthStencil.stencilBackFunc = stencilBackFunc;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700709 mStencilBackRef = (stencilBackRef > 0) ? stencilBackRef : 0;
Shannon Woods53a94a82014-06-24 15:20:36 -0400710 mDepthStencil.stencilBackMask = stencilBackMask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400711 mDirtyBits.set(DIRTY_BIT_STENCIL_FUNCS_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400712}
713
714void State::setStencilWritemask(GLuint stencilWritemask)
715{
716 mDepthStencil.stencilWritemask = stencilWritemask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400717 mDirtyBits.set(DIRTY_BIT_STENCIL_WRITEMASK_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400718}
719
720void State::setStencilBackWritemask(GLuint stencilBackWritemask)
721{
722 mDepthStencil.stencilBackWritemask = stencilBackWritemask;
Jamie Madill1b94d432015-08-07 13:23:23 -0400723 mDirtyBits.set(DIRTY_BIT_STENCIL_WRITEMASK_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400724}
725
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700726void State::setStencilOperations(GLenum stencilFail,
727 GLenum stencilPassDepthFail,
728 GLenum stencilPassDepthPass)
Shannon Woods53a94a82014-06-24 15:20:36 -0400729{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700730 mDepthStencil.stencilFail = stencilFail;
Shannon Woods53a94a82014-06-24 15:20:36 -0400731 mDepthStencil.stencilPassDepthFail = stencilPassDepthFail;
732 mDepthStencil.stencilPassDepthPass = stencilPassDepthPass;
Jamie Madill1b94d432015-08-07 13:23:23 -0400733 mDirtyBits.set(DIRTY_BIT_STENCIL_OPS_FRONT);
Shannon Woods53a94a82014-06-24 15:20:36 -0400734}
735
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700736void State::setStencilBackOperations(GLenum stencilBackFail,
737 GLenum stencilBackPassDepthFail,
738 GLenum stencilBackPassDepthPass)
Shannon Woods53a94a82014-06-24 15:20:36 -0400739{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700740 mDepthStencil.stencilBackFail = stencilBackFail;
Shannon Woods53a94a82014-06-24 15:20:36 -0400741 mDepthStencil.stencilBackPassDepthFail = stencilBackPassDepthFail;
742 mDepthStencil.stencilBackPassDepthPass = stencilBackPassDepthPass;
Jamie Madill1b94d432015-08-07 13:23:23 -0400743 mDirtyBits.set(DIRTY_BIT_STENCIL_OPS_BACK);
Shannon Woods53a94a82014-06-24 15:20:36 -0400744}
745
Shannon Woods53a94a82014-06-24 15:20:36 -0400746void State::setPolygonOffsetFill(bool enabled)
747{
Jamie Madill1b94d432015-08-07 13:23:23 -0400748 mRasterizer.polygonOffsetFill = enabled;
749 mDirtyBits.set(DIRTY_BIT_POLYGON_OFFSET_FILL_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400750}
751
752void State::setPolygonOffsetParams(GLfloat factor, GLfloat units)
753{
754 // An application can pass NaN values here, so handle this gracefully
755 mRasterizer.polygonOffsetFactor = factor != factor ? 0.0f : factor;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700756 mRasterizer.polygonOffsetUnits = units != units ? 0.0f : units;
Jamie Madill1b94d432015-08-07 13:23:23 -0400757 mDirtyBits.set(DIRTY_BIT_POLYGON_OFFSET);
Shannon Woods53a94a82014-06-24 15:20:36 -0400758}
759
Shannon Woods53a94a82014-06-24 15:20:36 -0400760void State::setSampleAlphaToCoverage(bool enabled)
761{
762 mBlend.sampleAlphaToCoverage = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400763 mDirtyBits.set(DIRTY_BIT_SAMPLE_ALPHA_TO_COVERAGE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400764}
765
Shannon Woods53a94a82014-06-24 15:20:36 -0400766void State::setSampleCoverage(bool enabled)
767{
768 mSampleCoverage = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400769 mDirtyBits.set(DIRTY_BIT_SAMPLE_COVERAGE_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400770}
771
772void State::setSampleCoverageParams(GLclampf value, bool invert)
773{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700774 mSampleCoverageValue = value;
Shannon Woods53a94a82014-06-24 15:20:36 -0400775 mSampleCoverageInvert = invert;
Jamie Madill1b94d432015-08-07 13:23:23 -0400776 mDirtyBits.set(DIRTY_BIT_SAMPLE_COVERAGE);
Shannon Woods53a94a82014-06-24 15:20:36 -0400777}
778
Jiawei Shaodb342272017-09-27 10:21:45 +0800779void State::setSampleMaskEnabled(bool enabled)
780{
781 mSampleMask = enabled;
782 mDirtyBits.set(DIRTY_BIT_SAMPLE_MASK_ENABLED);
783}
784
785void State::setSampleMaskParams(GLuint maskNumber, GLbitfield mask)
786{
787 ASSERT(maskNumber < mMaxSampleMaskWords);
788 mSampleMaskValues[maskNumber] = mask;
Jamie Madillc67323a2017-11-02 23:11:41 -0400789 // TODO(jmadill): Use a child dirty bit if we ever use more than two words.
790 mDirtyBits.set(DIRTY_BIT_SAMPLE_MASK);
Jiawei Shaodb342272017-09-27 10:21:45 +0800791}
792
Sami Väisänen74c23472016-05-09 17:30:30 +0300793void State::setSampleAlphaToOne(bool enabled)
794{
795 mSampleAlphaToOne = enabled;
796 mDirtyBits.set(DIRTY_BIT_SAMPLE_ALPHA_TO_ONE);
797}
798
Sami Väisänen74c23472016-05-09 17:30:30 +0300799void State::setMultisampling(bool enabled)
800{
801 mMultiSampling = enabled;
802 mDirtyBits.set(DIRTY_BIT_MULTISAMPLING);
803}
804
Shannon Woods53a94a82014-06-24 15:20:36 -0400805void State::setScissorTest(bool enabled)
806{
807 mScissorTest = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400808 mDirtyBits.set(DIRTY_BIT_SCISSOR_TEST_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400809}
810
811void State::setScissorParams(GLint x, GLint y, GLsizei width, GLsizei height)
812{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700813 mScissor.x = x;
814 mScissor.y = y;
815 mScissor.width = width;
Shannon Woods53a94a82014-06-24 15:20:36 -0400816 mScissor.height = height;
Jamie Madill1b94d432015-08-07 13:23:23 -0400817 mDirtyBits.set(DIRTY_BIT_SCISSOR);
Shannon Woods53a94a82014-06-24 15:20:36 -0400818}
819
Shannon Woods53a94a82014-06-24 15:20:36 -0400820void State::setDither(bool enabled)
821{
822 mBlend.dither = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400823 mDirtyBits.set(DIRTY_BIT_DITHER_ENABLED);
Shannon Woods53a94a82014-06-24 15:20:36 -0400824}
825
Jamie Madillb4b53c52015-02-03 15:22:48 -0500826void State::setPrimitiveRestart(bool enabled)
827{
828 mPrimitiveRestart = enabled;
Jamie Madill1b94d432015-08-07 13:23:23 -0400829 mDirtyBits.set(DIRTY_BIT_PRIMITIVE_RESTART_ENABLED);
Jamie Madillb4b53c52015-02-03 15:22:48 -0500830}
831
Shannon Woods53a94a82014-06-24 15:20:36 -0400832void State::setEnableFeature(GLenum feature, bool enabled)
833{
834 switch (feature)
835 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700836 case GL_MULTISAMPLE_EXT:
837 setMultisampling(enabled);
838 break;
839 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
840 setSampleAlphaToOne(enabled);
841 break;
842 case GL_CULL_FACE:
843 setCullFace(enabled);
844 break;
845 case GL_POLYGON_OFFSET_FILL:
846 setPolygonOffsetFill(enabled);
847 break;
848 case GL_SAMPLE_ALPHA_TO_COVERAGE:
849 setSampleAlphaToCoverage(enabled);
850 break;
851 case GL_SAMPLE_COVERAGE:
852 setSampleCoverage(enabled);
853 break;
854 case GL_SCISSOR_TEST:
855 setScissorTest(enabled);
856 break;
857 case GL_STENCIL_TEST:
858 setStencilTest(enabled);
859 break;
860 case GL_DEPTH_TEST:
861 setDepthTest(enabled);
862 break;
863 case GL_BLEND:
864 setBlend(enabled);
865 break;
866 case GL_DITHER:
867 setDither(enabled);
868 break;
869 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
870 setPrimitiveRestart(enabled);
871 break;
872 case GL_RASTERIZER_DISCARD:
873 setRasterizerDiscard(enabled);
874 break;
875 case GL_SAMPLE_MASK:
876 setSampleMaskEnabled(enabled);
877 break;
878 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
879 mDebug.setOutputSynchronous(enabled);
880 break;
881 case GL_DEBUG_OUTPUT:
882 mDebug.setOutputEnabled(enabled);
883 break;
884 case GL_FRAMEBUFFER_SRGB_EXT:
885 setFramebufferSRGB(enabled);
886 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -0700887
888 // GLES1 emulation
889 case GL_ALPHA_TEST:
890 mGLES1State.mAlphaTestEnabled = enabled;
891 break;
Lingfeng Yang23dc90b2018-04-23 09:01:49 -0700892 case GL_TEXTURE_2D:
893 mGLES1State.mTexUnitEnables[mActiveSampler].set(TextureType::_2D, enabled);
894 break;
895 case GL_TEXTURE_CUBE_MAP:
896 mGLES1State.mTexUnitEnables[mActiveSampler].set(TextureType::CubeMap, enabled);
897 break;
Lingfeng Yangd0febe72018-05-17 22:36:52 -0700898 case GL_LIGHTING:
899 mGLES1State.mLightingEnabled = enabled;
900 break;
901 case GL_LIGHT0:
902 case GL_LIGHT1:
903 case GL_LIGHT2:
904 case GL_LIGHT3:
905 case GL_LIGHT4:
906 case GL_LIGHT5:
907 case GL_LIGHT6:
908 case GL_LIGHT7:
909 mGLES1State.mLights[feature - GL_LIGHT0].enabled = enabled;
910 break;
911 case GL_NORMALIZE:
912 mGLES1State.mNormalizeEnabled = enabled;
913 break;
914 case GL_RESCALE_NORMAL:
915 mGLES1State.mRescaleNormalEnabled = enabled;
916 break;
917 case GL_COLOR_MATERIAL:
918 mGLES1State.mColorMaterialEnabled = enabled;
919 break;
Lingfeng Yang060088a2018-05-30 20:40:57 -0700920 case GL_CLIP_PLANE0:
921 case GL_CLIP_PLANE1:
922 case GL_CLIP_PLANE2:
923 case GL_CLIP_PLANE3:
924 case GL_CLIP_PLANE4:
925 case GL_CLIP_PLANE5:
926 mGLES1State.mClipPlanes[feature - GL_CLIP_PLANE0].enabled = enabled;
927 break;
Lingfeng Yang7ba3f422018-06-01 09:43:04 -0700928 case GL_FOG:
929 mGLES1State.mFogEnabled = enabled;
930 break;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -0700931 case GL_POINT_SMOOTH:
932 mGLES1State.mPointSmoothEnabled = enabled;
933 break;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -0700934 case GL_LINE_SMOOTH:
935 mGLES1State.mLineSmoothEnabled = enabled;
936 break;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -0700937 case GL_POINT_SPRITE_OES:
938 mGLES1State.mPointSpriteEnabled = enabled;
939 break;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -0700940 case GL_COLOR_LOGIC_OP:
941 mGLES1State.mLogicOpEnabled = enabled;
942 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700943 default:
944 UNREACHABLE();
Shannon Woods53a94a82014-06-24 15:20:36 -0400945 }
946}
947
Jamie Madilldfde6ab2016-06-09 07:07:18 -0700948bool State::getEnableFeature(GLenum feature) const
Shannon Woods53a94a82014-06-24 15:20:36 -0400949{
950 switch (feature)
951 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -0700952 case GL_MULTISAMPLE_EXT:
953 return isMultisamplingEnabled();
954 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
955 return isSampleAlphaToOneEnabled();
956 case GL_CULL_FACE:
957 return isCullFaceEnabled();
958 case GL_POLYGON_OFFSET_FILL:
959 return isPolygonOffsetFillEnabled();
960 case GL_SAMPLE_ALPHA_TO_COVERAGE:
961 return isSampleAlphaToCoverageEnabled();
962 case GL_SAMPLE_COVERAGE:
963 return isSampleCoverageEnabled();
964 case GL_SCISSOR_TEST:
965 return isScissorTestEnabled();
966 case GL_STENCIL_TEST:
967 return isStencilTestEnabled();
968 case GL_DEPTH_TEST:
969 return isDepthTestEnabled();
970 case GL_BLEND:
971 return isBlendEnabled();
972 case GL_DITHER:
973 return isDitherEnabled();
974 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
975 return isPrimitiveRestartEnabled();
976 case GL_RASTERIZER_DISCARD:
977 return isRasterizerDiscardEnabled();
978 case GL_SAMPLE_MASK:
979 return isSampleMaskEnabled();
980 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
981 return mDebug.isOutputSynchronous();
982 case GL_DEBUG_OUTPUT:
983 return mDebug.isOutputEnabled();
984 case GL_BIND_GENERATES_RESOURCE_CHROMIUM:
985 return isBindGeneratesResourceEnabled();
986 case GL_CLIENT_ARRAYS_ANGLE:
987 return areClientArraysEnabled();
988 case GL_FRAMEBUFFER_SRGB_EXT:
989 return getFramebufferSRGB();
990 case GL_ROBUST_RESOURCE_INITIALIZATION_ANGLE:
991 return mRobustResourceInit;
992 case GL_PROGRAM_CACHE_ENABLED_ANGLE:
993 return mProgramBinaryCacheEnabled;
Jamie Madillc43be722017-07-13 16:22:14 -0400994
Lingfeng Yang13b708f2018-03-21 12:14:10 -0700995 // GLES1 emulation
996 case GL_ALPHA_TEST:
997 return mGLES1State.mAlphaTestEnabled;
Lingfeng Yang01074432018-04-16 10:19:51 -0700998 case GL_VERTEX_ARRAY:
999 return mGLES1State.mVertexArrayEnabled;
1000 case GL_NORMAL_ARRAY:
1001 return mGLES1State.mNormalArrayEnabled;
1002 case GL_COLOR_ARRAY:
1003 return mGLES1State.mColorArrayEnabled;
1004 case GL_POINT_SIZE_ARRAY_OES:
1005 return mGLES1State.mPointSizeArrayEnabled;
1006 case GL_TEXTURE_COORD_ARRAY:
1007 return mGLES1State.mTexCoordArrayEnabled[mGLES1State.mClientActiveTexture];
Lingfeng Yang23dc90b2018-04-23 09:01:49 -07001008 case GL_TEXTURE_2D:
1009 return mGLES1State.mTexUnitEnables[mActiveSampler].test(TextureType::_2D);
1010 case GL_TEXTURE_CUBE_MAP:
1011 return mGLES1State.mTexUnitEnables[mActiveSampler].test(TextureType::CubeMap);
Lingfeng Yangd0febe72018-05-17 22:36:52 -07001012 case GL_LIGHTING:
1013 return mGLES1State.mLightingEnabled;
1014 case GL_LIGHT0:
1015 case GL_LIGHT1:
1016 case GL_LIGHT2:
1017 case GL_LIGHT3:
1018 case GL_LIGHT4:
1019 case GL_LIGHT5:
1020 case GL_LIGHT6:
1021 case GL_LIGHT7:
1022 return mGLES1State.mLights[feature - GL_LIGHT0].enabled;
1023 case GL_NORMALIZE:
1024 return mGLES1State.mNormalizeEnabled;
1025 case GL_RESCALE_NORMAL:
1026 return mGLES1State.mRescaleNormalEnabled;
1027 case GL_COLOR_MATERIAL:
1028 return mGLES1State.mColorMaterialEnabled;
Lingfeng Yang060088a2018-05-30 20:40:57 -07001029 case GL_CLIP_PLANE0:
1030 case GL_CLIP_PLANE1:
1031 case GL_CLIP_PLANE2:
1032 case GL_CLIP_PLANE3:
1033 case GL_CLIP_PLANE4:
1034 case GL_CLIP_PLANE5:
1035 return mGLES1State.mClipPlanes[feature - GL_CLIP_PLANE0].enabled;
Lingfeng Yang7ba3f422018-06-01 09:43:04 -07001036 case GL_FOG:
1037 return mGLES1State.mFogEnabled;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -07001038 case GL_POINT_SMOOTH:
1039 return mGLES1State.mPointSmoothEnabled;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -07001040 case GL_LINE_SMOOTH:
1041 return mGLES1State.mLineSmoothEnabled;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -07001042 case GL_POINT_SPRITE_OES:
1043 return mGLES1State.mPointSpriteEnabled;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -07001044 case GL_COLOR_LOGIC_OP:
1045 return mGLES1State.mLogicOpEnabled;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001046 default:
1047 UNREACHABLE();
1048 return false;
Shannon Woods53a94a82014-06-24 15:20:36 -04001049 }
1050}
1051
1052void State::setLineWidth(GLfloat width)
1053{
1054 mLineWidth = width;
Jamie Madill1b94d432015-08-07 13:23:23 -04001055 mDirtyBits.set(DIRTY_BIT_LINE_WIDTH);
Shannon Woods53a94a82014-06-24 15:20:36 -04001056}
1057
1058void State::setGenerateMipmapHint(GLenum hint)
1059{
1060 mGenerateMipmapHint = hint;
Jamie Madill1b94d432015-08-07 13:23:23 -04001061 mDirtyBits.set(DIRTY_BIT_GENERATE_MIPMAP_HINT);
Shannon Woods53a94a82014-06-24 15:20:36 -04001062}
1063
1064void State::setFragmentShaderDerivativeHint(GLenum hint)
1065{
1066 mFragmentShaderDerivativeHint = hint;
Jamie Madill1b94d432015-08-07 13:23:23 -04001067 mDirtyBits.set(DIRTY_BIT_SHADER_DERIVATIVE_HINT);
Shannon Woods53a94a82014-06-24 15:20:36 -04001068 // TODO: Propagate the hint to shader translator so we can write
1069 // ddx, ddx_coarse, or ddx_fine depending on the hint.
1070 // Ignore for now. It is valid for implementations to ignore hint.
1071}
1072
1073void State::setViewportParams(GLint x, GLint y, GLsizei width, GLsizei height)
1074{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001075 mViewport.x = x;
1076 mViewport.y = y;
1077 mViewport.width = width;
Shannon Woods53a94a82014-06-24 15:20:36 -04001078 mViewport.height = height;
Jamie Madill1b94d432015-08-07 13:23:23 -04001079 mDirtyBits.set(DIRTY_BIT_VIEWPORT);
Shannon Woods53a94a82014-06-24 15:20:36 -04001080}
1081
Shannon Woods53a94a82014-06-24 15:20:36 -04001082void State::setActiveSampler(unsigned int active)
1083{
1084 mActiveSampler = active;
1085}
1086
Jamie Madille3e680c2018-12-03 17:49:08 -05001087void State::setSamplerTexture(const Context *context, TextureType type, Texture *texture)
Shannon Woods53a94a82014-06-24 15:20:36 -04001088{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001089 mSamplerTextures[type][mActiveSampler].set(context, texture);
Jamie Madill14246812018-10-03 17:51:16 -04001090
1091 if (mProgram && mProgram->getActiveSamplersMask()[mActiveSampler] &&
1092 mProgram->getActiveSamplerTypes()[mActiveSampler] == type)
1093 {
Jamie Madille3e680c2018-12-03 17:49:08 -05001094 updateActiveTexture(context, mActiveSampler, texture);
Jamie Madill14246812018-10-03 17:51:16 -04001095 }
1096
Jamie Madill81c2e252017-09-09 23:32:46 -04001097 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
Shannon Woods53a94a82014-06-24 15:20:36 -04001098}
1099
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001100Texture *State::getTargetTexture(TextureType type) const
Jamie Madillc29968b2016-01-20 11:17:23 -05001101{
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001102 return getSamplerTexture(static_cast<unsigned int>(mActiveSampler), type);
Jamie Madillc29968b2016-01-20 11:17:23 -05001103}
1104
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001105GLuint State::getSamplerTextureId(unsigned int sampler, TextureType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001106{
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001107 ASSERT(sampler < mSamplerTextures[type].size());
1108 return mSamplerTextures[type][sampler].id();
Shannon Woods53a94a82014-06-24 15:20:36 -04001109}
1110
Jamie Madilla02315b2017-02-23 14:14:47 -05001111void State::detachTexture(const Context *context, const TextureMap &zeroTextures, GLuint texture)
Shannon Woods53a94a82014-06-24 15:20:36 -04001112{
1113 // Textures have a detach method on State rather than a simple
1114 // removeBinding, because the zero/null texture objects are managed
1115 // separately, and don't have to go through the Context's maps or
1116 // the ResourceManager.
1117
1118 // [OpenGL ES 2.0.24] section 3.8 page 84:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001119 // If a texture object is deleted, it is as if all texture units which are bound to that texture
1120 // object are rebound to texture object zero
Shannon Woods53a94a82014-06-24 15:20:36 -04001121
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001122 for (TextureType type : angle::AllEnums<TextureType>())
Shannon Woods53a94a82014-06-24 15:20:36 -04001123 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001124 TextureBindingVector &textureVector = mSamplerTextures[type];
Jamie Madill81c2e252017-09-09 23:32:46 -04001125 for (BindingPointer<Texture> &binding : textureVector)
Shannon Woods53a94a82014-06-24 15:20:36 -04001126 {
Geoff Lang76b10c92014-09-05 16:28:14 -04001127 if (binding.id() == texture)
Shannon Woods53a94a82014-06-24 15:20:36 -04001128 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001129 Texture *zeroTexture = zeroTextures[type].get();
1130 ASSERT(zeroTexture != nullptr);
Jamie Madille6382c32014-11-07 15:05:26 -05001131 // Zero textures are the "default" textures instead of NULL
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001132 binding.set(context, zeroTexture);
Jamie Madill81c2e252017-09-09 23:32:46 -04001133 mDirtyBits.set(DIRTY_BIT_TEXTURE_BINDINGS);
Shannon Woods53a94a82014-06-24 15:20:36 -04001134 }
1135 }
1136 }
1137
Xinghua Cao65ec0b22017-03-28 16:10:52 +08001138 for (auto &bindingImageUnit : mImageUnits)
1139 {
1140 if (bindingImageUnit.texture.id() == texture)
1141 {
1142 bindingImageUnit.texture.set(context, nullptr);
1143 bindingImageUnit.level = 0;
1144 bindingImageUnit.layered = false;
1145 bindingImageUnit.layer = 0;
1146 bindingImageUnit.access = GL_READ_ONLY;
1147 bindingImageUnit.format = GL_R32UI;
1148 break;
1149 }
1150 }
1151
Shannon Woods53a94a82014-06-24 15:20:36 -04001152 // [OpenGL ES 2.0.24] section 4.4 page 112:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001153 // If a texture object is deleted while its image is attached to the currently bound
1154 // framebuffer, then it is as if Texture2DAttachment had been called, with a texture of 0, for
1155 // each attachment point to which this image was attached in the currently bound framebuffer.
Shannon Woods53a94a82014-06-24 15:20:36 -04001156
Jamie Madill8693bdb2017-09-02 15:32:14 -04001157 if (mReadFramebuffer && mReadFramebuffer->detachTexture(context, texture))
Shannon Woods53a94a82014-06-24 15:20:36 -04001158 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001159 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -04001160 }
1161
Jamie Madill8693bdb2017-09-02 15:32:14 -04001162 if (mDrawFramebuffer && mDrawFramebuffer->detachTexture(context, texture))
Shannon Woods53a94a82014-06-24 15:20:36 -04001163 {
Jamie Madillef9fcd92018-11-28 14:03:59 -05001164 setDrawFramebufferDirty();
Shannon Woods53a94a82014-06-24 15:20:36 -04001165 }
1166}
1167
Jamie Madill4928b7c2017-06-20 12:57:39 -04001168void State::initializeZeroTextures(const Context *context, const TextureMap &zeroTextures)
Jamie Madille6382c32014-11-07 15:05:26 -05001169{
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001170 for (TextureType type : angle::AllEnums<TextureType>())
Jamie Madille6382c32014-11-07 15:05:26 -05001171 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001172 for (size_t textureUnit = 0; textureUnit < mSamplerTextures[type].size(); ++textureUnit)
Jamie Madille6382c32014-11-07 15:05:26 -05001173 {
Corentin Wallezf0e89be2017-11-08 14:00:32 -08001174 mSamplerTextures[type][textureUnit].set(context, zeroTextures[type].get());
Jamie Madille6382c32014-11-07 15:05:26 -05001175 }
1176 }
1177}
1178
Jamie Madill4928b7c2017-06-20 12:57:39 -04001179void State::setSamplerBinding(const Context *context, GLuint textureUnit, Sampler *sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001180{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001181 mSamplers[textureUnit].set(context, sampler);
Jamie Madill81c2e252017-09-09 23:32:46 -04001182 mDirtyBits.set(DIRTY_BIT_SAMPLER_BINDINGS);
Jamie Madille25b8002018-09-20 13:39:49 -04001183 // This is overly conservative as it assumes the sampler has never been bound.
1184 setSamplerDirty(textureUnit);
Jamie Madille3e680c2018-12-03 17:49:08 -05001185 onActiveTextureChange(context, textureUnit);
Shannon Woods53a94a82014-06-24 15:20:36 -04001186}
1187
Jamie Madill4928b7c2017-06-20 12:57:39 -04001188void State::detachSampler(const Context *context, GLuint sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001189{
1190 // [OpenGL ES 3.0.2] section 3.8.2 pages 123-124:
1191 // If a sampler object that is currently bound to one or more texture units is
1192 // deleted, it is as though BindSampler is called once for each texture unit to
1193 // which the sampler is bound, with unit set to the texture unit and sampler set to zero.
Jamie Madill81c2e252017-09-09 23:32:46 -04001194 for (BindingPointer<Sampler> &samplerBinding : mSamplers)
Shannon Woods53a94a82014-06-24 15:20:36 -04001195 {
Geoff Lang76b10c92014-09-05 16:28:14 -04001196 if (samplerBinding.id() == sampler)
Shannon Woods53a94a82014-06-24 15:20:36 -04001197 {
Jamie Madill4928b7c2017-06-20 12:57:39 -04001198 samplerBinding.set(context, nullptr);
Jamie Madill81c2e252017-09-09 23:32:46 -04001199 mDirtyBits.set(DIRTY_BIT_SAMPLER_BINDINGS);
Shannon Woods53a94a82014-06-24 15:20:36 -04001200 }
1201 }
1202}
1203
Jamie Madill4928b7c2017-06-20 12:57:39 -04001204void State::setRenderbufferBinding(const Context *context, Renderbuffer *renderbuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001205{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001206 mRenderbuffer.set(context, renderbuffer);
Jamie Madill8693bdb2017-09-02 15:32:14 -04001207 mDirtyBits.set(DIRTY_BIT_RENDERBUFFER_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001208}
1209
Jamie Madilla02315b2017-02-23 14:14:47 -05001210void State::detachRenderbuffer(const Context *context, GLuint renderbuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001211{
1212 // [OpenGL ES 2.0.24] section 4.4 page 109:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001213 // If a renderbuffer that is currently bound to RENDERBUFFER is deleted, it is as though
1214 // BindRenderbuffer had been executed with the target RENDERBUFFER and name of zero.
Shannon Woods53a94a82014-06-24 15:20:36 -04001215
1216 if (mRenderbuffer.id() == renderbuffer)
1217 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001218 setRenderbufferBinding(context, nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001219 }
1220
1221 // [OpenGL ES 2.0.24] section 4.4 page 111:
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001222 // If a renderbuffer object is deleted while its image is attached to the currently bound
1223 // framebuffer, then it is as if FramebufferRenderbuffer had been called, with a renderbuffer of
1224 // 0, for each attachment point to which this image was attached in the currently bound
1225 // framebuffer.
Shannon Woods53a94a82014-06-24 15:20:36 -04001226
1227 Framebuffer *readFramebuffer = mReadFramebuffer;
1228 Framebuffer *drawFramebuffer = mDrawFramebuffer;
1229
Jamie Madill8693bdb2017-09-02 15:32:14 -04001230 if (readFramebuffer && readFramebuffer->detachRenderbuffer(context, renderbuffer))
Shannon Woods53a94a82014-06-24 15:20:36 -04001231 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001232 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
Shannon Woods53a94a82014-06-24 15:20:36 -04001233 }
1234
1235 if (drawFramebuffer && drawFramebuffer != readFramebuffer)
1236 {
Jamie Madill8693bdb2017-09-02 15:32:14 -04001237 if (drawFramebuffer->detachRenderbuffer(context, renderbuffer))
1238 {
Jamie Madillef9fcd92018-11-28 14:03:59 -05001239 setDrawFramebufferDirty();
Jamie Madill8693bdb2017-09-02 15:32:14 -04001240 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001241 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001242}
1243
1244void State::setReadFramebufferBinding(Framebuffer *framebuffer)
1245{
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001246 if (mReadFramebuffer == framebuffer)
1247 return;
1248
Shannon Woods53a94a82014-06-24 15:20:36 -04001249 mReadFramebuffer = framebuffer;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001250 mDirtyBits.set(DIRTY_BIT_READ_FRAMEBUFFER_BINDING);
1251
1252 if (mReadFramebuffer && mReadFramebuffer->hasAnyDirtyBit())
1253 {
1254 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
1255 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001256}
1257
1258void State::setDrawFramebufferBinding(Framebuffer *framebuffer)
1259{
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001260 if (mDrawFramebuffer == framebuffer)
1261 return;
1262
Shannon Woods53a94a82014-06-24 15:20:36 -04001263 mDrawFramebuffer = framebuffer;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001264 mDirtyBits.set(DIRTY_BIT_DRAW_FRAMEBUFFER_BINDING);
1265
Jamie Madillef9fcd92018-11-28 14:03:59 -05001266 if (mDrawFramebuffer)
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001267 {
Jamie Madillef9fcd92018-11-28 14:03:59 -05001268 if (mDrawFramebuffer->hasAnyDirtyBit())
1269 {
1270 mDirtyObjects.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
1271 }
1272
1273 if (mRobustResourceInit && mDrawFramebuffer->hasResourceThatNeedsInit())
1274 {
1275 mDirtyObjects.set(DIRTY_OBJECT_DRAW_ATTACHMENTS);
1276 }
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001277 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001278}
1279
1280Framebuffer *State::getTargetFramebuffer(GLenum target) const
1281{
1282 switch (target)
1283 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001284 case GL_READ_FRAMEBUFFER_ANGLE:
1285 return mReadFramebuffer;
1286 case GL_DRAW_FRAMEBUFFER_ANGLE:
1287 case GL_FRAMEBUFFER:
1288 return mDrawFramebuffer;
1289 default:
1290 UNREACHABLE();
Yunchao Hef81ce4a2017-04-24 10:49:17 +08001291 return nullptr;
Shannon Woods53a94a82014-06-24 15:20:36 -04001292 }
1293}
1294
Shannon Woods53a94a82014-06-24 15:20:36 -04001295bool State::removeReadFramebufferBinding(GLuint framebuffer)
1296{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001297 if (mReadFramebuffer != nullptr && mReadFramebuffer->id() == framebuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001298 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001299 setReadFramebufferBinding(nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001300 return true;
1301 }
1302
1303 return false;
1304}
1305
1306bool State::removeDrawFramebufferBinding(GLuint framebuffer)
1307{
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001308 if (mReadFramebuffer != nullptr && mDrawFramebuffer->id() == framebuffer)
Shannon Woods53a94a82014-06-24 15:20:36 -04001309 {
Jamie Madill60ec6ea2016-01-22 15:27:19 -05001310 setDrawFramebufferBinding(nullptr);
Shannon Woods53a94a82014-06-24 15:20:36 -04001311 return true;
1312 }
1313
1314 return false;
1315}
1316
Jamie Madill7267aa62018-04-17 15:28:21 -04001317void State::setVertexArrayBinding(const Context *context, VertexArray *vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001318{
James Darpiniane8a93c62018-01-04 18:02:24 -08001319 if (mVertexArray == vertexArray)
1320 return;
1321 if (mVertexArray)
Jamie Madillbf5177d2018-08-21 12:58:20 -04001322 mVertexArray->onBindingChanged(context, -1);
Shannon Woods53a94a82014-06-24 15:20:36 -04001323 mVertexArray = vertexArray;
James Darpiniane8a93c62018-01-04 18:02:24 -08001324 if (vertexArray)
Jamie Madillbf5177d2018-08-21 12:58:20 -04001325 vertexArray->onBindingChanged(context, 1);
Jamie Madill0b9e9032015-08-17 11:51:52 +00001326 mDirtyBits.set(DIRTY_BIT_VERTEX_ARRAY_BINDING);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001327
1328 if (mVertexArray && mVertexArray->hasAnyDirtyBit())
1329 {
1330 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1331 }
Shannon Woods53a94a82014-06-24 15:20:36 -04001332}
1333
Jamie Madill7267aa62018-04-17 15:28:21 -04001334bool State::removeVertexArrayBinding(const Context *context, GLuint vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001335{
James Darpiniane8a93c62018-01-04 18:02:24 -08001336 if (mVertexArray && mVertexArray->id() == vertexArray)
Shannon Woods53a94a82014-06-24 15:20:36 -04001337 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001338 mVertexArray->onBindingChanged(context, -1);
Yunchao Hed7297bf2017-04-19 15:27:10 +08001339 mVertexArray = nullptr;
Jamie Madill0b9e9032015-08-17 11:51:52 +00001340 mDirtyBits.set(DIRTY_BIT_VERTEX_ARRAY_BINDING);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001341 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001342 return true;
1343 }
1344
1345 return false;
1346}
1347
Markus Tavenrath774fe562018-11-18 14:14:49 +01001348GLuint State::getVertexArrayId() const
1349{
1350 ASSERT(mVertexArray != nullptr);
1351 return mVertexArray->id();
1352}
1353
Jamie Madill4928b7c2017-06-20 12:57:39 -04001354void State::bindVertexBuffer(const Context *context,
1355 GLuint bindingIndex,
Shao80957d92017-02-20 21:25:59 +08001356 Buffer *boundBuffer,
1357 GLintptr offset,
1358 GLsizei stride)
1359{
Jamie Madill4928b7c2017-06-20 12:57:39 -04001360 getVertexArray()->bindVertexBuffer(context, bindingIndex, boundBuffer, offset, stride);
Shao80957d92017-02-20 21:25:59 +08001361 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1362}
1363
Shaodde78e82017-05-22 14:13:27 +08001364void State::setVertexAttribBinding(const Context *context, GLuint attribIndex, GLuint bindingIndex)
Shao80957d92017-02-20 21:25:59 +08001365{
Shaodde78e82017-05-22 14:13:27 +08001366 getVertexArray()->setVertexAttribBinding(context, attribIndex, bindingIndex);
Shao80957d92017-02-20 21:25:59 +08001367 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1368}
1369
1370void State::setVertexAttribFormat(GLuint attribIndex,
1371 GLint size,
Jamie Madilldd34b3b2019-01-16 09:59:54 -05001372 VertexAttribType type,
Shao80957d92017-02-20 21:25:59 +08001373 bool normalized,
1374 bool pureInteger,
1375 GLuint relativeOffset)
1376{
1377 getVertexArray()->setVertexAttribFormat(attribIndex, size, type, normalized, pureInteger,
1378 relativeOffset);
1379 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1380}
1381
1382void State::setVertexBindingDivisor(GLuint bindingIndex, GLuint divisor)
1383{
1384 getVertexArray()->setVertexBindingDivisor(bindingIndex, divisor);
1385 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
1386}
1387
Jamie Madill6f755b22018-10-09 12:48:54 -04001388angle::Result State::setProgram(const Context *context, Program *newProgram)
Shannon Woods53a94a82014-06-24 15:20:36 -04001389{
Geoff Lang7dd2e102014-11-10 15:19:26 -05001390 if (mProgram != newProgram)
Shannon Woods53a94a82014-06-24 15:20:36 -04001391 {
Geoff Lang7dd2e102014-11-10 15:19:26 -05001392 if (mProgram)
1393 {
Jamie Madille3bb6b72018-10-03 17:51:15 -04001394 unsetActiveTextures(mProgram->getActiveSamplersMask());
Jamie Madill6c1f6712017-02-14 19:08:04 -05001395 mProgram->release(context);
Geoff Lang7dd2e102014-11-10 15:19:26 -05001396 }
1397
1398 mProgram = newProgram;
1399
1400 if (mProgram)
1401 {
1402 newProgram->addRef();
Jamie Madille3bb6b72018-10-03 17:51:15 -04001403 ANGLE_TRY(onProgramExecutableChange(context, newProgram));
Geoff Lang7dd2e102014-11-10 15:19:26 -05001404 }
Jamie Madilldf836ff2018-10-01 10:36:24 -04001405
1406 // Note that rendering is undefined if glUseProgram(0) is called. But ANGLE will generate
1407 // an error if the app tries to draw in this case.
1408
Jamie Madilla779b612017-07-24 11:46:05 -04001409 mDirtyBits.set(DIRTY_BIT_PROGRAM_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001410 }
Jamie Madille3bb6b72018-10-03 17:51:15 -04001411
Jamie Madill7c985f52018-11-29 18:16:17 -05001412 return angle::Result::Continue;
Shannon Woods53a94a82014-06-24 15:20:36 -04001413}
1414
Jamie Madill4928b7c2017-06-20 12:57:39 -04001415void State::setTransformFeedbackBinding(const Context *context,
1416 TransformFeedback *transformFeedback)
Shannon Woods53a94a82014-06-24 15:20:36 -04001417{
James Darpiniane8a93c62018-01-04 18:02:24 -08001418 if (transformFeedback == mTransformFeedback.get())
1419 return;
1420 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -04001421 mTransformFeedback->onBindingChanged(context, false);
Jamie Madill4928b7c2017-06-20 12:57:39 -04001422 mTransformFeedback.set(context, transformFeedback);
James Darpiniane8a93c62018-01-04 18:02:24 -08001423 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -04001424 mTransformFeedback->onBindingChanged(context, true);
Geoff Langded79232017-11-28 15:21:11 -05001425 mDirtyBits.set(DIRTY_BIT_TRANSFORM_FEEDBACK_BINDING);
Shannon Woods53a94a82014-06-24 15:20:36 -04001426}
1427
Jamie Madill4928b7c2017-06-20 12:57:39 -04001428bool State::removeTransformFeedbackBinding(const Context *context, GLuint transformFeedback)
Shannon Woods53a94a82014-06-24 15:20:36 -04001429{
1430 if (mTransformFeedback.id() == transformFeedback)
1431 {
James Darpiniane8a93c62018-01-04 18:02:24 -08001432 if (mTransformFeedback.get())
Jamie Madill7267aa62018-04-17 15:28:21 -04001433 mTransformFeedback->onBindingChanged(context, false);
Jamie Madill4928b7c2017-06-20 12:57:39 -04001434 mTransformFeedback.set(context, nullptr);
Corentin Walleza2257da2016-04-19 16:43:12 -04001435 return true;
Shannon Woods53a94a82014-06-24 15:20:36 -04001436 }
Corentin Walleza2257da2016-04-19 16:43:12 -04001437
1438 return false;
Shannon Woods53a94a82014-06-24 15:20:36 -04001439}
1440
Yunchao Hea336b902017-08-02 16:05:21 +08001441void State::setProgramPipelineBinding(const Context *context, ProgramPipeline *pipeline)
1442{
1443 mProgramPipeline.set(context, pipeline);
1444}
1445
1446void State::detachProgramPipeline(const Context *context, GLuint pipeline)
1447{
1448 mProgramPipeline.set(context, nullptr);
1449}
1450
Corentin Wallezad3ae902018-03-09 13:40:42 -05001451bool State::isQueryActive(QueryType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001452{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001453 const Query *query = mActiveQueries[type].get();
1454 if (query != nullptr)
Shannon Woods53a94a82014-06-24 15:20:36 -04001455 {
Corentin Wallezad3ae902018-03-09 13:40:42 -05001456 return true;
1457 }
1458
1459 QueryType alternativeType;
1460 if (GetAlternativeQueryType(type, &alternativeType))
1461 {
1462 query = mActiveQueries[alternativeType].get();
1463 return query != nullptr;
Ian Ewell3ffd78b2016-01-22 16:09:42 -05001464 }
1465
1466 return false;
1467}
1468
1469bool State::isQueryActive(Query *query) const
1470{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001471 for (auto &queryPointer : mActiveQueries)
Ian Ewell3ffd78b2016-01-22 16:09:42 -05001472 {
Corentin Wallezad3ae902018-03-09 13:40:42 -05001473 if (queryPointer.get() == query)
Shannon Woods53a94a82014-06-24 15:20:36 -04001474 {
1475 return true;
1476 }
1477 }
1478
1479 return false;
1480}
1481
Corentin Wallezad3ae902018-03-09 13:40:42 -05001482void State::setActiveQuery(const Context *context, QueryType type, Query *query)
Shannon Woods53a94a82014-06-24 15:20:36 -04001483{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001484 mActiveQueries[type].set(context, query);
Shannon Woods53a94a82014-06-24 15:20:36 -04001485}
1486
Corentin Wallezad3ae902018-03-09 13:40:42 -05001487GLuint State::getActiveQueryId(QueryType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001488{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001489 const Query *query = getActiveQuery(type);
Shannon Woods53a94a82014-06-24 15:20:36 -04001490 return (query ? query->id() : 0u);
1491}
1492
Corentin Wallezad3ae902018-03-09 13:40:42 -05001493Query *State::getActiveQuery(QueryType type) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001494{
Corentin Wallezad3ae902018-03-09 13:40:42 -05001495 return mActiveQueries[type].get();
Shannon Woods53a94a82014-06-24 15:20:36 -04001496}
1497
Geoff Lang91002262018-12-12 16:05:24 -05001498angle::Result State::setIndexedBufferBinding(const Context *context,
1499 BufferBinding target,
1500 GLuint index,
1501 Buffer *buffer,
1502 GLintptr offset,
1503 GLsizeiptr size)
Jiajia Qin9d7d0b12016-11-29 16:30:31 +08001504{
Corentin Wallez336129f2017-10-17 15:55:40 -04001505 setBufferBinding(context, target, buffer);
Jiajia Qin9d7d0b12016-11-29 16:30:31 +08001506
Corentin Wallez336129f2017-10-17 15:55:40 -04001507 switch (target)
1508 {
1509 case BufferBinding::TransformFeedback:
Geoff Lang91002262018-12-12 16:05:24 -05001510 ANGLE_TRY(mTransformFeedback->bindIndexedBuffer(context, index, buffer, offset, size));
James Darpiniane8a93c62018-01-04 18:02:24 -08001511 setBufferBinding(context, target, buffer);
Corentin Wallez336129f2017-10-17 15:55:40 -04001512 break;
1513 case BufferBinding::Uniform:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001514 UpdateIndexedBufferBinding(context, &mUniformBuffers[index], buffer, target, offset,
1515 size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001516 break;
1517 case BufferBinding::AtomicCounter:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001518 UpdateIndexedBufferBinding(context, &mAtomicCounterBuffers[index], buffer, target,
1519 offset, size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001520 break;
1521 case BufferBinding::ShaderStorage:
Jamie Madillbf5177d2018-08-21 12:58:20 -04001522 UpdateIndexedBufferBinding(context, &mShaderStorageBuffers[index], buffer, target,
1523 offset, size);
Corentin Wallez336129f2017-10-17 15:55:40 -04001524 break;
1525 default:
1526 UNREACHABLE();
1527 break;
1528 }
Geoff Lang91002262018-12-12 16:05:24 -05001529
1530 return angle::Result::Continue;
Shannon Woods53a94a82014-06-24 15:20:36 -04001531}
1532
Geoff Lang5d124a62015-09-15 13:03:27 -04001533const OffsetBindingPointer<Buffer> &State::getIndexedUniformBuffer(size_t index) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001534{
Shannon Woodsf3acaf92014-09-23 18:07:11 -04001535 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
Geoff Lang5d124a62015-09-15 13:03:27 -04001536 return mUniformBuffers[index];
Gregoire Payen de La Garanderie68694e92015-03-24 14:03:37 +00001537}
1538
Jiajia Qin6eafb042016-12-27 17:04:07 +08001539const OffsetBindingPointer<Buffer> &State::getIndexedAtomicCounterBuffer(size_t index) const
1540{
1541 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
1542 return mAtomicCounterBuffers[index];
1543}
1544
Jiajia Qinf546e7d2017-03-27 14:12:59 +08001545const OffsetBindingPointer<Buffer> &State::getIndexedShaderStorageBuffer(size_t index) const
1546{
1547 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
1548 return mShaderStorageBuffers[index];
1549}
1550
Corentin Wallez336129f2017-10-17 15:55:40 -04001551Buffer *State::getTargetBuffer(BufferBinding target) const
Shannon Woods53a94a82014-06-24 15:20:36 -04001552{
1553 switch (target)
1554 {
Corentin Wallez336129f2017-10-17 15:55:40 -04001555 case BufferBinding::ElementArray:
Jamie Madillcd0a0a32018-10-18 18:41:57 -04001556 return getVertexArray()->getElementArrayBuffer();
Corentin Wallez336129f2017-10-17 15:55:40 -04001557 default:
1558 return mBoundBuffers[target].get();
Shannon Woods53a94a82014-06-24 15:20:36 -04001559 }
1560}
1561
Geoff Lang91002262018-12-12 16:05:24 -05001562angle::Result State::detachBuffer(const Context *context, const Buffer *buffer)
Yuly Novikov5807a532015-12-03 13:01:22 -05001563{
James Darpinian4d9d4832018-03-13 12:43:28 -07001564 if (!buffer->isBound())
1565 {
Geoff Lang91002262018-12-12 16:05:24 -05001566 return angle::Result::Continue;
James Darpinian4d9d4832018-03-13 12:43:28 -07001567 }
1568 GLuint bufferName = buffer->id();
James Darpiniane8a93c62018-01-04 18:02:24 -08001569 for (auto target : angle::AllEnums<BufferBinding>())
Yuly Novikov5807a532015-12-03 13:01:22 -05001570 {
James Darpiniane8a93c62018-01-04 18:02:24 -08001571 if (mBoundBuffers[target].id() == bufferName)
Yuly Novikov5807a532015-12-03 13:01:22 -05001572 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001573 UpdateBufferBinding(context, &mBoundBuffers[target], nullptr, target);
Yuly Novikov5807a532015-12-03 13:01:22 -05001574 }
1575 }
1576
1577 TransformFeedback *curTransformFeedback = getCurrentTransformFeedback();
1578 if (curTransformFeedback)
1579 {
Geoff Lang91002262018-12-12 16:05:24 -05001580 ANGLE_TRY(curTransformFeedback->detachBuffer(context, bufferName));
Yuly Novikov5807a532015-12-03 13:01:22 -05001581 }
1582
Jamie Madill4928b7c2017-06-20 12:57:39 -04001583 getVertexArray()->detachBuffer(context, bufferName);
James Darpiniane8a93c62018-01-04 18:02:24 -08001584
1585 for (auto &buf : mUniformBuffers)
1586 {
1587 if (buf.id() == bufferName)
1588 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001589 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::Uniform, 0, 0);
James Darpiniane8a93c62018-01-04 18:02:24 -08001590 }
1591 }
1592
1593 for (auto &buf : mAtomicCounterBuffers)
1594 {
1595 if (buf.id() == bufferName)
1596 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001597 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::AtomicCounter, 0, 0);
James Darpiniane8a93c62018-01-04 18:02:24 -08001598 }
1599 }
1600
1601 for (auto &buf : mShaderStorageBuffers)
1602 {
1603 if (buf.id() == bufferName)
1604 {
Jamie Madillbf5177d2018-08-21 12:58:20 -04001605 UpdateIndexedBufferBinding(context, &buf, nullptr, BufferBinding::ShaderStorage, 0, 0);
James Darpiniane8a93c62018-01-04 18:02:24 -08001606 }
1607 }
Geoff Lang91002262018-12-12 16:05:24 -05001608
1609 return angle::Result::Continue;
Yuly Novikov5807a532015-12-03 13:01:22 -05001610}
1611
Shannon Woods53a94a82014-06-24 15:20:36 -04001612void State::setEnableVertexAttribArray(unsigned int attribNum, bool enabled)
1613{
1614 getVertexArray()->enableAttribute(attribNum, enabled);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001615 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001616}
1617
1618void State::setVertexAttribf(GLuint index, const GLfloat values[4])
1619{
Shannon Woods23e05002014-09-22 19:07:27 -04001620 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001621 mVertexAttribCurrentValues[index].setFloatValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001622 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1623 mDirtyCurrentValues.set(index);
Jamie Madill6e18a232019-01-16 13:27:14 -05001624 SetComponentTypeMask(ComponentType::Float, index, &mCurrentValuesTypeMask);
Shannon Woods53a94a82014-06-24 15:20:36 -04001625}
1626
1627void State::setVertexAttribu(GLuint index, const GLuint values[4])
1628{
Shannon Woods23e05002014-09-22 19:07:27 -04001629 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001630 mVertexAttribCurrentValues[index].setUnsignedIntValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001631 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1632 mDirtyCurrentValues.set(index);
Jamie Madill6e18a232019-01-16 13:27:14 -05001633 SetComponentTypeMask(ComponentType::UnsignedInt, index, &mCurrentValuesTypeMask);
Shannon Woods53a94a82014-06-24 15:20:36 -04001634}
1635
1636void State::setVertexAttribi(GLuint index, const GLint values[4])
1637{
Shannon Woods23e05002014-09-22 19:07:27 -04001638 ASSERT(static_cast<size_t>(index) < mVertexAttribCurrentValues.size());
Shannon Woods53a94a82014-06-24 15:20:36 -04001639 mVertexAttribCurrentValues[index].setIntValues(values);
Jamie Madillc67323a2017-11-02 23:11:41 -04001640 mDirtyBits.set(DIRTY_BIT_CURRENT_VALUES);
1641 mDirtyCurrentValues.set(index);
Jamie Madill6e18a232019-01-16 13:27:14 -05001642 SetComponentTypeMask(ComponentType::Int, index, &mCurrentValuesTypeMask);
Shannon Woods53a94a82014-06-24 15:20:36 -04001643}
1644
Shaodde78e82017-05-22 14:13:27 +08001645void State::setVertexAttribDivisor(const Context *context, GLuint index, GLuint divisor)
Jamie Madill0b9e9032015-08-17 11:51:52 +00001646{
Shaodde78e82017-05-22 14:13:27 +08001647 getVertexArray()->setVertexAttribDivisor(context, index, divisor);
Jamie Madillc9d442d2016-01-20 11:17:24 -05001648 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
Shannon Woods53a94a82014-06-24 15:20:36 -04001649}
1650
Shannon Woods53a94a82014-06-24 15:20:36 -04001651const void *State::getVertexAttribPointer(unsigned int attribNum) const
1652{
1653 return getVertexArray()->getVertexAttribute(attribNum).pointer;
1654}
1655
1656void State::setPackAlignment(GLint alignment)
1657{
1658 mPack.alignment = alignment;
Jamie Madillc67323a2017-11-02 23:11:41 -04001659 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001660}
1661
Shannon Woods53a94a82014-06-24 15:20:36 -04001662void State::setPackReverseRowOrder(bool reverseRowOrder)
1663{
1664 mPack.reverseRowOrder = reverseRowOrder;
Jamie Madillc67323a2017-11-02 23:11:41 -04001665 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001666}
1667
Minmin Gongadff67b2015-10-14 10:34:45 -04001668void State::setPackRowLength(GLint rowLength)
1669{
1670 mPack.rowLength = rowLength;
Jamie Madillc67323a2017-11-02 23:11:41 -04001671 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001672}
1673
Minmin Gongadff67b2015-10-14 10:34:45 -04001674void State::setPackSkipRows(GLint skipRows)
1675{
1676 mPack.skipRows = skipRows;
Jamie Madillc67323a2017-11-02 23:11:41 -04001677 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001678}
1679
Minmin Gongadff67b2015-10-14 10:34:45 -04001680void State::setPackSkipPixels(GLint skipPixels)
1681{
1682 mPack.skipPixels = skipPixels;
Jamie Madillc67323a2017-11-02 23:11:41 -04001683 mDirtyBits.set(DIRTY_BIT_PACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001684}
1685
Shannon Woods53a94a82014-06-24 15:20:36 -04001686void State::setUnpackAlignment(GLint alignment)
1687{
1688 mUnpack.alignment = alignment;
Jamie Madillc67323a2017-11-02 23:11:41 -04001689 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Shannon Woods53a94a82014-06-24 15:20:36 -04001690}
1691
Minmin Gongb8aee3b2015-01-27 14:42:36 -08001692void State::setUnpackRowLength(GLint rowLength)
1693{
1694 mUnpack.rowLength = rowLength;
Jamie Madillc67323a2017-11-02 23:11:41 -04001695 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongb8aee3b2015-01-27 14:42:36 -08001696}
1697
Minmin Gongadff67b2015-10-14 10:34:45 -04001698void State::setUnpackImageHeight(GLint imageHeight)
1699{
1700 mUnpack.imageHeight = imageHeight;
Jamie Madillc67323a2017-11-02 23:11:41 -04001701 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001702}
1703
Minmin Gongadff67b2015-10-14 10:34:45 -04001704void State::setUnpackSkipImages(GLint skipImages)
1705{
1706 mUnpack.skipImages = skipImages;
Jamie Madillc67323a2017-11-02 23:11:41 -04001707 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001708}
1709
Minmin Gongadff67b2015-10-14 10:34:45 -04001710void State::setUnpackSkipRows(GLint skipRows)
1711{
1712 mUnpack.skipRows = skipRows;
Jamie Madillc67323a2017-11-02 23:11:41 -04001713 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001714}
1715
Minmin Gongadff67b2015-10-14 10:34:45 -04001716void State::setUnpackSkipPixels(GLint skipPixels)
1717{
1718 mUnpack.skipPixels = skipPixels;
Jamie Madillc67323a2017-11-02 23:11:41 -04001719 mDirtyBits.set(DIRTY_BIT_UNPACK_STATE);
Minmin Gongadff67b2015-10-14 10:34:45 -04001720}
1721
Sami Väisänena797e062016-05-12 15:23:40 +03001722void State::setCoverageModulation(GLenum components)
1723{
1724 mCoverageModulation = components;
1725 mDirtyBits.set(DIRTY_BIT_COVERAGE_MODULATION);
1726}
1727
Sami Väisänene45e53b2016-05-25 10:36:04 +03001728void State::loadPathRenderingMatrix(GLenum matrixMode, const GLfloat *matrix)
1729{
1730 if (matrixMode == GL_PATH_MODELVIEW_CHROMIUM)
1731 {
1732 memcpy(mPathMatrixMV, matrix, 16 * sizeof(GLfloat));
jchen10bb2f2c42018-09-16 09:47:38 +08001733 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING);
Sami Väisänene45e53b2016-05-25 10:36:04 +03001734 }
1735 else if (matrixMode == GL_PATH_PROJECTION_CHROMIUM)
1736 {
1737 memcpy(mPathMatrixProj, matrix, 16 * sizeof(GLfloat));
jchen10bb2f2c42018-09-16 09:47:38 +08001738 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING);
Sami Väisänene45e53b2016-05-25 10:36:04 +03001739 }
1740 else
1741 {
1742 UNREACHABLE();
1743 }
1744}
1745
1746const GLfloat *State::getPathRenderingMatrix(GLenum which) const
1747{
1748 if (which == GL_PATH_MODELVIEW_MATRIX_CHROMIUM)
1749 {
1750 return mPathMatrixMV;
1751 }
1752 else if (which == GL_PATH_PROJECTION_MATRIX_CHROMIUM)
1753 {
1754 return mPathMatrixProj;
1755 }
1756
1757 UNREACHABLE();
1758 return nullptr;
1759}
1760
1761void State::setPathStencilFunc(GLenum func, GLint ref, GLuint mask)
1762{
1763 mPathStencilFunc = func;
1764 mPathStencilRef = ref;
1765 mPathStencilMask = mask;
jchen10bb2f2c42018-09-16 09:47:38 +08001766 mDirtyBits.set(DIRTY_BIT_PATH_RENDERING);
Sami Väisänene45e53b2016-05-25 10:36:04 +03001767}
1768
Geoff Lang1d2c41d2016-10-19 16:14:46 -07001769void State::setFramebufferSRGB(bool sRGB)
1770{
1771 mFramebufferSRGB = sRGB;
1772 mDirtyBits.set(DIRTY_BIT_FRAMEBUFFER_SRGB);
1773}
1774
jchen1082af6202018-06-22 10:59:52 +08001775void State::setMaxShaderCompilerThreads(GLuint count)
1776{
1777 mMaxShaderCompilerThreads = count;
1778}
1779
Shannon Woods53a94a82014-06-24 15:20:36 -04001780void State::getBooleanv(GLenum pname, GLboolean *params)
1781{
1782 switch (pname)
1783 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001784 case GL_SAMPLE_COVERAGE_INVERT:
1785 *params = mSampleCoverageInvert;
1786 break;
1787 case GL_DEPTH_WRITEMASK:
1788 *params = mDepthStencil.depthMask;
1789 break;
1790 case GL_COLOR_WRITEMASK:
1791 params[0] = mBlend.colorMaskRed;
1792 params[1] = mBlend.colorMaskGreen;
1793 params[2] = mBlend.colorMaskBlue;
1794 params[3] = mBlend.colorMaskAlpha;
1795 break;
1796 case GL_CULL_FACE:
1797 *params = mRasterizer.cullFace;
1798 break;
1799 case GL_POLYGON_OFFSET_FILL:
1800 *params = mRasterizer.polygonOffsetFill;
1801 break;
1802 case GL_SAMPLE_ALPHA_TO_COVERAGE:
1803 *params = mBlend.sampleAlphaToCoverage;
1804 break;
1805 case GL_SAMPLE_COVERAGE:
1806 *params = mSampleCoverage;
1807 break;
1808 case GL_SAMPLE_MASK:
1809 *params = mSampleMask;
1810 break;
1811 case GL_SCISSOR_TEST:
1812 *params = mScissorTest;
1813 break;
1814 case GL_STENCIL_TEST:
1815 *params = mDepthStencil.stencilTest;
1816 break;
1817 case GL_DEPTH_TEST:
1818 *params = mDepthStencil.depthTest;
1819 break;
1820 case GL_BLEND:
1821 *params = mBlend.blend;
1822 break;
1823 case GL_DITHER:
1824 *params = mBlend.dither;
1825 break;
1826 case GL_TRANSFORM_FEEDBACK_ACTIVE:
1827 *params = getCurrentTransformFeedback()->isActive() ? GL_TRUE : GL_FALSE;
1828 break;
1829 case GL_TRANSFORM_FEEDBACK_PAUSED:
1830 *params = getCurrentTransformFeedback()->isPaused() ? GL_TRUE : GL_FALSE;
1831 break;
1832 case GL_PRIMITIVE_RESTART_FIXED_INDEX:
1833 *params = mPrimitiveRestart;
1834 break;
1835 case GL_RASTERIZER_DISCARD:
1836 *params = isRasterizerDiscardEnabled() ? GL_TRUE : GL_FALSE;
1837 break;
1838 case GL_DEBUG_OUTPUT_SYNCHRONOUS:
1839 *params = mDebug.isOutputSynchronous() ? GL_TRUE : GL_FALSE;
1840 break;
1841 case GL_DEBUG_OUTPUT:
1842 *params = mDebug.isOutputEnabled() ? GL_TRUE : GL_FALSE;
1843 break;
1844 case GL_MULTISAMPLE_EXT:
1845 *params = mMultiSampling;
1846 break;
1847 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
1848 *params = mSampleAlphaToOne;
1849 break;
1850 case GL_BIND_GENERATES_RESOURCE_CHROMIUM:
1851 *params = isBindGeneratesResourceEnabled() ? GL_TRUE : GL_FALSE;
1852 break;
1853 case GL_CLIENT_ARRAYS_ANGLE:
1854 *params = areClientArraysEnabled() ? GL_TRUE : GL_FALSE;
1855 break;
1856 case GL_FRAMEBUFFER_SRGB_EXT:
1857 *params = getFramebufferSRGB() ? GL_TRUE : GL_FALSE;
1858 break;
1859 case GL_ROBUST_RESOURCE_INITIALIZATION_ANGLE:
1860 *params = mRobustResourceInit ? GL_TRUE : GL_FALSE;
1861 break;
1862 case GL_PROGRAM_CACHE_ENABLED_ANGLE:
1863 *params = mProgramBinaryCacheEnabled ? GL_TRUE : GL_FALSE;
1864 break;
Lingfeng Yangd0febe72018-05-17 22:36:52 -07001865 case GL_LIGHT_MODEL_TWO_SIDE:
1866 *params = IsLightModelTwoSided(&mGLES1State);
1867 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001868 default:
1869 UNREACHABLE();
1870 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04001871 }
1872}
1873
1874void State::getFloatv(GLenum pname, GLfloat *params)
1875{
1876 // Please note: DEPTH_CLEAR_VALUE is included in our internal getFloatv implementation
1877 // because it is stored as a float, despite the fact that the GL ES 2.0 spec names
1878 // GetIntegerv as its native query function. As it would require conversion in any
1879 // case, this should make no difference to the calling application.
1880 switch (pname)
1881 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001882 case GL_LINE_WIDTH:
1883 *params = mLineWidth;
1884 break;
1885 case GL_SAMPLE_COVERAGE_VALUE:
1886 *params = mSampleCoverageValue;
1887 break;
1888 case GL_DEPTH_CLEAR_VALUE:
1889 *params = mDepthClearValue;
1890 break;
1891 case GL_POLYGON_OFFSET_FACTOR:
1892 *params = mRasterizer.polygonOffsetFactor;
1893 break;
1894 case GL_POLYGON_OFFSET_UNITS:
1895 *params = mRasterizer.polygonOffsetUnits;
1896 break;
1897 case GL_DEPTH_RANGE:
1898 params[0] = mNearZ;
1899 params[1] = mFarZ;
1900 break;
1901 case GL_COLOR_CLEAR_VALUE:
1902 params[0] = mColorClearValue.red;
1903 params[1] = mColorClearValue.green;
1904 params[2] = mColorClearValue.blue;
1905 params[3] = mColorClearValue.alpha;
1906 break;
1907 case GL_BLEND_COLOR:
1908 params[0] = mBlendColor.red;
1909 params[1] = mBlendColor.green;
1910 params[2] = mBlendColor.blue;
1911 params[3] = mBlendColor.alpha;
1912 break;
1913 case GL_MULTISAMPLE_EXT:
1914 *params = static_cast<GLfloat>(mMultiSampling);
1915 break;
1916 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
1917 *params = static_cast<GLfloat>(mSampleAlphaToOne);
1918 break;
1919 case GL_COVERAGE_MODULATION_CHROMIUM:
1920 params[0] = static_cast<GLfloat>(mCoverageModulation);
1921 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -07001922 case GL_ALPHA_TEST_REF:
1923 *params = mGLES1State.mAlphaTestRef;
1924 break;
Lingfeng Yanga43994c2018-03-29 07:21:41 -07001925 case GL_CURRENT_COLOR:
1926 {
1927 const auto &color = mGLES1State.mCurrentColor;
1928 params[0] = color.red;
1929 params[1] = color.green;
1930 params[2] = color.blue;
1931 params[3] = color.alpha;
1932 break;
1933 }
Lingfeng Yang5a7e61b2018-03-29 16:50:32 -07001934 case GL_CURRENT_NORMAL:
1935 {
1936 const auto &normal = mGLES1State.mCurrentNormal;
1937 params[0] = normal[0];
1938 params[1] = normal[1];
1939 params[2] = normal[2];
1940 break;
1941 }
Lingfeng Yang038dd532018-03-29 17:31:52 -07001942 case GL_CURRENT_TEXTURE_COORDS:
1943 {
1944 const auto &texcoord = mGLES1State.mCurrentTextureCoords[mActiveSampler];
1945 params[0] = texcoord.s;
1946 params[1] = texcoord.t;
1947 params[2] = texcoord.r;
1948 params[3] = texcoord.q;
1949 break;
1950 }
Lingfeng Yang3a41af62018-04-09 07:28:56 -07001951 case GL_MODELVIEW_MATRIX:
1952 memcpy(params, mGLES1State.mModelviewMatrices.back().data(), 16 * sizeof(GLfloat));
1953 break;
1954 case GL_PROJECTION_MATRIX:
1955 memcpy(params, mGLES1State.mProjectionMatrices.back().data(), 16 * sizeof(GLfloat));
1956 break;
1957 case GL_TEXTURE_MATRIX:
1958 memcpy(params, mGLES1State.mTextureMatrices[mActiveSampler].back().data(),
1959 16 * sizeof(GLfloat));
1960 break;
Lingfeng Yangd0febe72018-05-17 22:36:52 -07001961 case GL_LIGHT_MODEL_AMBIENT:
1962 GetLightModelParameters(&mGLES1State, pname, params);
1963 break;
Lingfeng Yang7ba3f422018-06-01 09:43:04 -07001964 case GL_FOG_MODE:
1965 case GL_FOG_DENSITY:
1966 case GL_FOG_START:
1967 case GL_FOG_END:
1968 case GL_FOG_COLOR:
1969 GetFogParameters(&mGLES1State, pname, params);
1970 break;
Lingfeng Yang9c4c0922018-06-13 09:29:00 -07001971 case GL_POINT_SIZE:
1972 GetPointSize(&mGLES1State, params);
1973 break;
1974 case GL_POINT_SIZE_MIN:
1975 case GL_POINT_SIZE_MAX:
1976 case GL_POINT_FADE_THRESHOLD_SIZE:
1977 case GL_POINT_DISTANCE_ATTENUATION:
1978 GetPointParameter(&mGLES1State, FromGLenum<PointParameter>(pname), params);
1979 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07001980 default:
1981 UNREACHABLE();
1982 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04001983 }
1984}
1985
Jamie Madill526392d2018-11-16 09:35:14 -05001986angle::Result State::getIntegerv(const Context *context, GLenum pname, GLint *params)
Shannon Woods53a94a82014-06-24 15:20:36 -04001987{
1988 if (pname >= GL_DRAW_BUFFER0_EXT && pname <= GL_DRAW_BUFFER15_EXT)
1989 {
Geoff Lang3e922062018-11-15 11:26:29 -05001990 size_t drawBuffer = (pname - GL_DRAW_BUFFER0_EXT);
1991 ASSERT(drawBuffer < mMaxDrawBuffers);
Shannon Woods53a94a82014-06-24 15:20:36 -04001992 Framebuffer *framebuffer = mDrawFramebuffer;
Geoff Lang3e922062018-11-15 11:26:29 -05001993 // The default framebuffer may have fewer draw buffer states than a user-created one. The
1994 // user is always allowed to query up to GL_MAX_DRAWBUFFERS so just return GL_NONE here if
1995 // the draw buffer is out of range for this framebuffer.
1996 *params = drawBuffer < framebuffer->getDrawbufferStateCount()
1997 ? framebuffer->getDrawBufferState(drawBuffer)
1998 : GL_NONE;
Jamie Madill7c985f52018-11-29 18:16:17 -05001999 return angle::Result::Continue;
Shannon Woods53a94a82014-06-24 15:20:36 -04002000 }
2001
2002 // Please note: DEPTH_CLEAR_VALUE is not included in our internal getIntegerv implementation
2003 // because it is stored as a float, despite the fact that the GL ES 2.0 spec names
2004 // GetIntegerv as its native query function. As it would require conversion in any
2005 // case, this should make no difference to the calling application. You may find it in
2006 // State::getFloatv.
2007 switch (pname)
2008 {
Corentin Wallez336129f2017-10-17 15:55:40 -04002009 case GL_ARRAY_BUFFER_BINDING:
2010 *params = mBoundBuffers[BufferBinding::Array].id();
2011 break;
2012 case GL_DRAW_INDIRECT_BUFFER_BINDING:
2013 *params = mBoundBuffers[BufferBinding::DrawIndirect].id();
2014 break;
2015 case GL_ELEMENT_ARRAY_BUFFER_BINDING:
Jamie Madillcd0a0a32018-10-18 18:41:57 -04002016 {
2017 Buffer *elementArrayBuffer = getVertexArray()->getElementArrayBuffer();
2018 *params = elementArrayBuffer ? elementArrayBuffer->id() : 0;
Corentin Wallez336129f2017-10-17 15:55:40 -04002019 break;
Jamie Madillcd0a0a32018-10-18 18:41:57 -04002020 }
Jamie Madill690c8eb2018-03-12 15:20:03 -04002021 case GL_DRAW_FRAMEBUFFER_BINDING:
2022 static_assert(GL_DRAW_FRAMEBUFFER_BINDING == GL_DRAW_FRAMEBUFFER_BINDING_ANGLE,
2023 "Enum mismatch");
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002024 *params = mDrawFramebuffer->id();
2025 break;
Jamie Madill690c8eb2018-03-12 15:20:03 -04002026 case GL_READ_FRAMEBUFFER_BINDING:
2027 static_assert(GL_READ_FRAMEBUFFER_BINDING == GL_READ_FRAMEBUFFER_BINDING_ANGLE,
2028 "Enum mismatch");
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002029 *params = mReadFramebuffer->id();
2030 break;
2031 case GL_RENDERBUFFER_BINDING:
2032 *params = mRenderbuffer.id();
2033 break;
2034 case GL_VERTEX_ARRAY_BINDING:
2035 *params = mVertexArray->id();
2036 break;
2037 case GL_CURRENT_PROGRAM:
2038 *params = mProgram ? mProgram->id() : 0;
2039 break;
2040 case GL_PACK_ALIGNMENT:
2041 *params = mPack.alignment;
2042 break;
2043 case GL_PACK_REVERSE_ROW_ORDER_ANGLE:
2044 *params = mPack.reverseRowOrder;
2045 break;
2046 case GL_PACK_ROW_LENGTH:
2047 *params = mPack.rowLength;
2048 break;
2049 case GL_PACK_SKIP_ROWS:
2050 *params = mPack.skipRows;
2051 break;
2052 case GL_PACK_SKIP_PIXELS:
2053 *params = mPack.skipPixels;
2054 break;
2055 case GL_UNPACK_ALIGNMENT:
2056 *params = mUnpack.alignment;
2057 break;
2058 case GL_UNPACK_ROW_LENGTH:
2059 *params = mUnpack.rowLength;
2060 break;
2061 case GL_UNPACK_IMAGE_HEIGHT:
2062 *params = mUnpack.imageHeight;
2063 break;
2064 case GL_UNPACK_SKIP_IMAGES:
2065 *params = mUnpack.skipImages;
2066 break;
2067 case GL_UNPACK_SKIP_ROWS:
2068 *params = mUnpack.skipRows;
2069 break;
2070 case GL_UNPACK_SKIP_PIXELS:
2071 *params = mUnpack.skipPixels;
2072 break;
2073 case GL_GENERATE_MIPMAP_HINT:
2074 *params = mGenerateMipmapHint;
2075 break;
2076 case GL_FRAGMENT_SHADER_DERIVATIVE_HINT_OES:
2077 *params = mFragmentShaderDerivativeHint;
2078 break;
2079 case GL_ACTIVE_TEXTURE:
2080 *params = (static_cast<GLint>(mActiveSampler) + GL_TEXTURE0);
2081 break;
2082 case GL_STENCIL_FUNC:
2083 *params = mDepthStencil.stencilFunc;
2084 break;
2085 case GL_STENCIL_REF:
2086 *params = mStencilRef;
2087 break;
2088 case GL_STENCIL_VALUE_MASK:
2089 *params = CastMaskValue(context, mDepthStencil.stencilMask);
2090 break;
2091 case GL_STENCIL_BACK_FUNC:
2092 *params = mDepthStencil.stencilBackFunc;
2093 break;
2094 case GL_STENCIL_BACK_REF:
2095 *params = mStencilBackRef;
2096 break;
2097 case GL_STENCIL_BACK_VALUE_MASK:
2098 *params = CastMaskValue(context, mDepthStencil.stencilBackMask);
2099 break;
2100 case GL_STENCIL_FAIL:
2101 *params = mDepthStencil.stencilFail;
2102 break;
2103 case GL_STENCIL_PASS_DEPTH_FAIL:
2104 *params = mDepthStencil.stencilPassDepthFail;
2105 break;
2106 case GL_STENCIL_PASS_DEPTH_PASS:
2107 *params = mDepthStencil.stencilPassDepthPass;
2108 break;
2109 case GL_STENCIL_BACK_FAIL:
2110 *params = mDepthStencil.stencilBackFail;
2111 break;
2112 case GL_STENCIL_BACK_PASS_DEPTH_FAIL:
2113 *params = mDepthStencil.stencilBackPassDepthFail;
2114 break;
2115 case GL_STENCIL_BACK_PASS_DEPTH_PASS:
2116 *params = mDepthStencil.stencilBackPassDepthPass;
2117 break;
2118 case GL_DEPTH_FUNC:
2119 *params = mDepthStencil.depthFunc;
2120 break;
2121 case GL_BLEND_SRC_RGB:
2122 *params = mBlend.sourceBlendRGB;
2123 break;
2124 case GL_BLEND_SRC_ALPHA:
2125 *params = mBlend.sourceBlendAlpha;
2126 break;
2127 case GL_BLEND_DST_RGB:
2128 *params = mBlend.destBlendRGB;
2129 break;
2130 case GL_BLEND_DST_ALPHA:
2131 *params = mBlend.destBlendAlpha;
2132 break;
2133 case GL_BLEND_EQUATION_RGB:
2134 *params = mBlend.blendEquationRGB;
2135 break;
2136 case GL_BLEND_EQUATION_ALPHA:
2137 *params = mBlend.blendEquationAlpha;
2138 break;
2139 case GL_STENCIL_WRITEMASK:
2140 *params = CastMaskValue(context, mDepthStencil.stencilWritemask);
2141 break;
2142 case GL_STENCIL_BACK_WRITEMASK:
2143 *params = CastMaskValue(context, mDepthStencil.stencilBackWritemask);
2144 break;
2145 case GL_STENCIL_CLEAR_VALUE:
2146 *params = mStencilClearValue;
2147 break;
2148 case GL_IMPLEMENTATION_COLOR_READ_TYPE:
Jamie Madill690c8eb2018-03-12 15:20:03 -04002149 ANGLE_TRY(mReadFramebuffer->getImplementationColorReadType(
2150 context, reinterpret_cast<GLenum *>(params)));
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002151 break;
2152 case GL_IMPLEMENTATION_COLOR_READ_FORMAT:
Jamie Madill690c8eb2018-03-12 15:20:03 -04002153 ANGLE_TRY(mReadFramebuffer->getImplementationColorReadFormat(
2154 context, reinterpret_cast<GLenum *>(params)));
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002155 break;
2156 case GL_SAMPLE_BUFFERS:
2157 case GL_SAMPLES:
Shannon Woods53a94a82014-06-24 15:20:36 -04002158 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002159 Framebuffer *framebuffer = mDrawFramebuffer;
Jamie Madill427064d2018-04-13 16:20:34 -04002160 if (framebuffer->isComplete(context))
Shannon Woods53a94a82014-06-24 15:20:36 -04002161 {
Jamie Madill427064d2018-04-13 16:20:34 -04002162 GLint samples = framebuffer->getSamples(context);
Shannon Woods53a94a82014-06-24 15:20:36 -04002163 switch (pname)
2164 {
Jamie Madilla0016b72017-07-14 14:30:46 -04002165 case GL_SAMPLE_BUFFERS:
Jamie Madille98b1b52018-03-08 09:47:23 -05002166 if (samples != 0)
Jamie Madilla0016b72017-07-14 14:30:46 -04002167 {
2168 *params = 1;
2169 }
2170 else
2171 {
2172 *params = 0;
2173 }
2174 break;
2175 case GL_SAMPLES:
Jamie Madille98b1b52018-03-08 09:47:23 -05002176 *params = samples;
Jamie Madilla0016b72017-07-14 14:30:46 -04002177 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002178 }
2179 }
2180 else
2181 {
2182 *params = 0;
2183 }
2184 }
2185 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002186 case GL_VIEWPORT:
2187 params[0] = mViewport.x;
2188 params[1] = mViewport.y;
2189 params[2] = mViewport.width;
2190 params[3] = mViewport.height;
2191 break;
2192 case GL_SCISSOR_BOX:
2193 params[0] = mScissor.x;
2194 params[1] = mScissor.y;
2195 params[2] = mScissor.width;
2196 params[3] = mScissor.height;
2197 break;
2198 case GL_CULL_FACE_MODE:
2199 *params = ToGLenum(mRasterizer.cullMode);
2200 break;
2201 case GL_FRONT_FACE:
2202 *params = mRasterizer.frontFace;
2203 break;
2204 case GL_RED_BITS:
2205 case GL_GREEN_BITS:
2206 case GL_BLUE_BITS:
2207 case GL_ALPHA_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002208 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002209 Framebuffer *framebuffer = getDrawFramebuffer();
2210 const FramebufferAttachment *colorbuffer = framebuffer->getFirstColorbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002211
2212 if (colorbuffer)
2213 {
2214 switch (pname)
2215 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002216 case GL_RED_BITS:
2217 *params = colorbuffer->getRedSize();
2218 break;
2219 case GL_GREEN_BITS:
2220 *params = colorbuffer->getGreenSize();
2221 break;
2222 case GL_BLUE_BITS:
2223 *params = colorbuffer->getBlueSize();
2224 break;
2225 case GL_ALPHA_BITS:
2226 *params = colorbuffer->getAlphaSize();
2227 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002228 }
2229 }
2230 else
2231 {
2232 *params = 0;
2233 }
2234 }
2235 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002236 case GL_DEPTH_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002237 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002238 const Framebuffer *framebuffer = getDrawFramebuffer();
2239 const FramebufferAttachment *depthbuffer = framebuffer->getDepthbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002240
2241 if (depthbuffer)
2242 {
2243 *params = depthbuffer->getDepthSize();
2244 }
2245 else
2246 {
2247 *params = 0;
2248 }
2249 }
2250 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002251 case GL_STENCIL_BITS:
Shannon Woods53a94a82014-06-24 15:20:36 -04002252 {
Jamie Madill81c2e252017-09-09 23:32:46 -04002253 const Framebuffer *framebuffer = getDrawFramebuffer();
2254 const FramebufferAttachment *stencilbuffer = framebuffer->getStencilbuffer();
Shannon Woods53a94a82014-06-24 15:20:36 -04002255
2256 if (stencilbuffer)
2257 {
2258 *params = stencilbuffer->getStencilSize();
2259 }
2260 else
2261 {
2262 *params = 0;
2263 }
2264 }
2265 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002266 case GL_TEXTURE_BINDING_2D:
2267 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2268 *params =
2269 getSamplerTextureId(static_cast<unsigned int>(mActiveSampler), TextureType::_2D);
2270 break;
2271 case GL_TEXTURE_BINDING_RECTANGLE_ANGLE:
2272 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2273 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2274 TextureType::Rectangle);
2275 break;
2276 case GL_TEXTURE_BINDING_CUBE_MAP:
2277 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2278 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2279 TextureType::CubeMap);
2280 break;
2281 case GL_TEXTURE_BINDING_3D:
2282 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2283 *params =
2284 getSamplerTextureId(static_cast<unsigned int>(mActiveSampler), TextureType::_3D);
2285 break;
2286 case GL_TEXTURE_BINDING_2D_ARRAY:
2287 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2288 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2289 TextureType::_2DArray);
2290 break;
2291 case GL_TEXTURE_BINDING_2D_MULTISAMPLE:
2292 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2293 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2294 TextureType::_2DMultisample);
2295 break;
Olli Etuahodff32a02018-08-28 14:35:50 +03002296 case GL_TEXTURE_BINDING_2D_MULTISAMPLE_ARRAY:
2297 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2298 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2299 TextureType::_2DMultisampleArray);
2300 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002301 case GL_TEXTURE_BINDING_EXTERNAL_OES:
2302 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2303 *params = getSamplerTextureId(static_cast<unsigned int>(mActiveSampler),
2304 TextureType::External);
2305 break;
2306 case GL_UNIFORM_BUFFER_BINDING:
2307 *params = mBoundBuffers[BufferBinding::Uniform].id();
2308 break;
2309 case GL_TRANSFORM_FEEDBACK_BINDING:
2310 *params = mTransformFeedback.id();
2311 break;
2312 case GL_TRANSFORM_FEEDBACK_BUFFER_BINDING:
2313 *params = mBoundBuffers[BufferBinding::TransformFeedback].id();
2314 break;
2315 case GL_COPY_READ_BUFFER_BINDING:
2316 *params = mBoundBuffers[BufferBinding::CopyRead].id();
2317 break;
2318 case GL_COPY_WRITE_BUFFER_BINDING:
2319 *params = mBoundBuffers[BufferBinding::CopyWrite].id();
2320 break;
2321 case GL_PIXEL_PACK_BUFFER_BINDING:
2322 *params = mBoundBuffers[BufferBinding::PixelPack].id();
2323 break;
2324 case GL_PIXEL_UNPACK_BUFFER_BINDING:
2325 *params = mBoundBuffers[BufferBinding::PixelUnpack].id();
2326 break;
2327 case GL_READ_BUFFER:
2328 *params = mReadFramebuffer->getReadBufferState();
2329 break;
2330 case GL_SAMPLER_BINDING:
2331 ASSERT(mActiveSampler < mMaxCombinedTextureImageUnits);
2332 *params = getSamplerId(static_cast<GLuint>(mActiveSampler));
2333 break;
2334 case GL_DEBUG_LOGGED_MESSAGES:
2335 *params = static_cast<GLint>(mDebug.getMessageCount());
2336 break;
2337 case GL_DEBUG_NEXT_LOGGED_MESSAGE_LENGTH:
2338 *params = static_cast<GLint>(mDebug.getNextMessageLength());
2339 break;
2340 case GL_DEBUG_GROUP_STACK_DEPTH:
2341 *params = static_cast<GLint>(mDebug.getGroupStackDepth());
2342 break;
2343 case GL_MULTISAMPLE_EXT:
2344 *params = static_cast<GLint>(mMultiSampling);
2345 break;
2346 case GL_SAMPLE_ALPHA_TO_ONE_EXT:
2347 *params = static_cast<GLint>(mSampleAlphaToOne);
2348 break;
2349 case GL_COVERAGE_MODULATION_CHROMIUM:
2350 *params = static_cast<GLint>(mCoverageModulation);
2351 break;
2352 case GL_ATOMIC_COUNTER_BUFFER_BINDING:
2353 *params = mBoundBuffers[BufferBinding::AtomicCounter].id();
2354 break;
2355 case GL_SHADER_STORAGE_BUFFER_BINDING:
2356 *params = mBoundBuffers[BufferBinding::ShaderStorage].id();
2357 break;
2358 case GL_DISPATCH_INDIRECT_BUFFER_BINDING:
2359 *params = mBoundBuffers[BufferBinding::DispatchIndirect].id();
2360 break;
Lingfeng Yang13b708f2018-03-21 12:14:10 -07002361 case GL_ALPHA_TEST_FUNC:
2362 *params = ToGLenum(mGLES1State.mAlphaTestFunc);
2363 break;
Lingfeng Yang96310cd2018-03-28 11:56:28 -07002364 case GL_CLIENT_ACTIVE_TEXTURE:
2365 *params = mGLES1State.mClientActiveTexture + GL_TEXTURE0;
2366 break;
Lingfeng Yangd2488ab2018-04-04 09:25:48 -07002367 case GL_MATRIX_MODE:
2368 *params = ToGLenum(mGLES1State.mMatrixMode);
2369 break;
Lingfeng Yanga0cfa872018-05-30 21:12:17 -07002370 case GL_SHADE_MODEL:
2371 *params = ToGLenum(mGLES1State.mShadeModel);
2372 break;
Lingfeng Yang6e5bf362018-08-15 09:53:17 -07002373 case GL_MODELVIEW_STACK_DEPTH:
2374 case GL_PROJECTION_STACK_DEPTH:
2375 case GL_TEXTURE_STACK_DEPTH:
2376 *params = mGLES1State.getCurrentMatrixStackDepth(pname);
2377 break;
2378 case GL_LOGIC_OP_MODE:
2379 *params = ToGLenum(mGLES1State.mLogicOp);
2380 break;
2381 case GL_BLEND_SRC:
2382 *params = mBlend.sourceBlendRGB;
2383 break;
2384 case GL_BLEND_DST:
2385 *params = mBlend.destBlendRGB;
2386 break;
2387 case GL_PERSPECTIVE_CORRECTION_HINT:
2388 case GL_POINT_SMOOTH_HINT:
2389 case GL_LINE_SMOOTH_HINT:
2390 case GL_FOG_HINT:
2391 *params = mGLES1State.getHint(pname);
2392 break;
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002393 default:
2394 UNREACHABLE();
2395 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002396 }
Jamie Madille98b1b52018-03-08 09:47:23 -05002397
Jamie Madill7c985f52018-11-29 18:16:17 -05002398 return angle::Result::Continue;
Shannon Woods53a94a82014-06-24 15:20:36 -04002399}
2400
Lingfeng Yangabb09f12018-04-16 10:43:53 -07002401void State::getPointerv(const Context *context, GLenum pname, void **params) const
Geoff Lang70d0f492015-12-10 17:45:46 -05002402{
2403 switch (pname)
2404 {
2405 case GL_DEBUG_CALLBACK_FUNCTION:
2406 *params = reinterpret_cast<void *>(mDebug.getCallback());
2407 break;
2408 case GL_DEBUG_CALLBACK_USER_PARAM:
2409 *params = const_cast<void *>(mDebug.getUserParam());
2410 break;
Lingfeng Yangabb09f12018-04-16 10:43:53 -07002411 case GL_VERTEX_ARRAY_POINTER:
2412 case GL_NORMAL_ARRAY_POINTER:
2413 case GL_COLOR_ARRAY_POINTER:
2414 case GL_TEXTURE_COORD_ARRAY_POINTER:
2415 case GL_POINT_SIZE_ARRAY_POINTER_OES:
2416 QueryVertexAttribPointerv(getVertexArray()->getVertexAttribute(
2417 context->vertexArrayIndex(ParamToVertexArrayType(pname))),
2418 GL_VERTEX_ATTRIB_ARRAY_POINTER, params);
2419 return;
Geoff Lang70d0f492015-12-10 17:45:46 -05002420 default:
2421 UNREACHABLE();
2422 break;
2423 }
2424}
2425
Martin Radev66fb8202016-07-28 11:45:20 +03002426void State::getIntegeri_v(GLenum target, GLuint index, GLint *data)
Shannon Woods53a94a82014-06-24 15:20:36 -04002427{
2428 switch (target)
2429 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002430 case GL_TRANSFORM_FEEDBACK_BUFFER_BINDING:
2431 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2432 *data = mTransformFeedback->getIndexedBuffer(index).id();
2433 break;
2434 case GL_UNIFORM_BUFFER_BINDING:
2435 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2436 *data = mUniformBuffers[index].id();
2437 break;
2438 case GL_ATOMIC_COUNTER_BUFFER_BINDING:
2439 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2440 *data = mAtomicCounterBuffers[index].id();
2441 break;
2442 case GL_SHADER_STORAGE_BUFFER_BINDING:
2443 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2444 *data = mShaderStorageBuffers[index].id();
2445 break;
2446 case GL_VERTEX_BINDING_BUFFER:
2447 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2448 *data = mVertexArray->getVertexBinding(index).getBuffer().id();
2449 break;
2450 case GL_VERTEX_BINDING_DIVISOR:
2451 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2452 *data = mVertexArray->getVertexBinding(index).getDivisor();
2453 break;
2454 case GL_VERTEX_BINDING_OFFSET:
2455 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2456 *data = static_cast<GLuint>(mVertexArray->getVertexBinding(index).getOffset());
2457 break;
2458 case GL_VERTEX_BINDING_STRIDE:
2459 ASSERT(static_cast<size_t>(index) < mVertexArray->getMaxBindings());
2460 *data = mVertexArray->getVertexBinding(index).getStride();
2461 break;
2462 case GL_SAMPLE_MASK_VALUE:
2463 ASSERT(static_cast<size_t>(index) < mSampleMaskValues.size());
2464 *data = mSampleMaskValues[index];
2465 break;
2466 case GL_IMAGE_BINDING_NAME:
2467 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2468 *data = mImageUnits[index].texture.id();
2469 break;
2470 case GL_IMAGE_BINDING_LEVEL:
2471 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2472 *data = mImageUnits[index].level;
2473 break;
2474 case GL_IMAGE_BINDING_LAYER:
2475 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2476 *data = mImageUnits[index].layer;
2477 break;
2478 case GL_IMAGE_BINDING_ACCESS:
2479 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2480 *data = mImageUnits[index].access;
2481 break;
2482 case GL_IMAGE_BINDING_FORMAT:
2483 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2484 *data = mImageUnits[index].format;
2485 break;
2486 default:
2487 UNREACHABLE();
2488 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002489 }
Shannon Woods53a94a82014-06-24 15:20:36 -04002490}
2491
Martin Radev66fb8202016-07-28 11:45:20 +03002492void State::getInteger64i_v(GLenum target, GLuint index, GLint64 *data)
Shannon Woods53a94a82014-06-24 15:20:36 -04002493{
2494 switch (target)
2495 {
Lingfeng Yang54ef3ad2018-03-12 08:31:12 -07002496 case GL_TRANSFORM_FEEDBACK_BUFFER_START:
2497 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2498 *data = mTransformFeedback->getIndexedBuffer(index).getOffset();
2499 break;
2500 case GL_TRANSFORM_FEEDBACK_BUFFER_SIZE:
2501 ASSERT(static_cast<size_t>(index) < mTransformFeedback->getIndexedBufferCount());
2502 *data = mTransformFeedback->getIndexedBuffer(index).getSize();
2503 break;
2504 case GL_UNIFORM_BUFFER_START:
2505 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2506 *data = mUniformBuffers[index].getOffset();
2507 break;
2508 case GL_UNIFORM_BUFFER_SIZE:
2509 ASSERT(static_cast<size_t>(index) < mUniformBuffers.size());
2510 *data = mUniformBuffers[index].getSize();
2511 break;
2512 case GL_ATOMIC_COUNTER_BUFFER_START:
2513 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2514 *data = mAtomicCounterBuffers[index].getOffset();
2515 break;
2516 case GL_ATOMIC_COUNTER_BUFFER_SIZE:
2517 ASSERT(static_cast<size_t>(index) < mAtomicCounterBuffers.size());
2518 *data = mAtomicCounterBuffers[index].getSize();
2519 break;
2520 case GL_SHADER_STORAGE_BUFFER_START:
2521 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2522 *data = mShaderStorageBuffers[index].getOffset();
2523 break;
2524 case GL_SHADER_STORAGE_BUFFER_SIZE:
2525 ASSERT(static_cast<size_t>(index) < mShaderStorageBuffers.size());
2526 *data = mShaderStorageBuffers[index].getSize();
2527 break;
2528 default:
2529 UNREACHABLE();
2530 break;
Shannon Woods53a94a82014-06-24 15:20:36 -04002531 }
Martin Radev66fb8202016-07-28 11:45:20 +03002532}
Shannon Woods53a94a82014-06-24 15:20:36 -04002533
Martin Radev66fb8202016-07-28 11:45:20 +03002534void State::getBooleani_v(GLenum target, GLuint index, GLboolean *data)
2535{
Xinghua Cao9c8e1a32017-12-06 17:59:58 +08002536 switch (target)
2537 {
2538 case GL_IMAGE_BINDING_LAYERED:
2539 ASSERT(static_cast<size_t>(index) < mImageUnits.size());
2540 *data = mImageUnits[index].layered;
2541 break;
2542 default:
2543 UNREACHABLE();
2544 break;
2545 }
Shannon Woods53a94a82014-06-24 15:20:36 -04002546}
2547
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002548angle::Result State::syncReadFramebuffer(const Context *context)
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002549{
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002550 ASSERT(mReadFramebuffer);
2551 return mReadFramebuffer->syncState(context);
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002552}
2553
Jamie Madillef9fcd92018-11-28 14:03:59 -05002554angle::Result State::syncDrawFramebuffer(const Context *context)
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002555{
2556 ASSERT(mDrawFramebuffer);
2557 return mDrawFramebuffer->syncState(context);
2558}
2559
Jamie Madillef9fcd92018-11-28 14:03:59 -05002560angle::Result State::syncDrawAttachments(const Context *context)
2561{
2562 ASSERT(mDrawFramebuffer);
2563 ASSERT(!mDrawFramebuffer->hasAnyDirtyBit());
2564 ASSERT(mRobustResourceInit);
2565 return mDrawFramebuffer->ensureDrawAttachmentsInitialized(context);
2566}
2567
Jamie Madille3e680c2018-12-03 17:49:08 -05002568angle::Result State::syncTextures(const Context *context)
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002569{
Jamie Madille3e680c2018-12-03 17:49:08 -05002570 if (mDirtyTextures.none())
Jamie Madill7c985f52018-11-29 18:16:17 -05002571 return angle::Result::Continue;
Jamie Madille3e680c2018-12-03 17:49:08 -05002572
2573 for (size_t textureIndex : mDirtyTextures)
2574 {
2575 Texture *texture = mActiveTexturesCache[textureIndex];
2576 if (texture && texture->hasAnyDirtyBit())
2577 {
2578 ANGLE_TRY(texture->syncState(context));
2579 }
2580 }
2581
2582 mDirtyTextures.reset();
Jamie Madill7c985f52018-11-29 18:16:17 -05002583 return angle::Result::Continue;
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002584}
2585
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002586angle::Result State::syncSamplers(const Context *context)
Jamie Madille25b8002018-09-20 13:39:49 -04002587{
2588 if (mDirtySamplers.none())
Jamie Madill7c985f52018-11-29 18:16:17 -05002589 return angle::Result::Continue;
Jamie Madille25b8002018-09-20 13:39:49 -04002590
Jamie Madille25b8002018-09-20 13:39:49 -04002591 for (size_t samplerIndex : mDirtySamplers)
2592 {
2593 BindingPointer<Sampler> &sampler = mSamplers[samplerIndex];
2594 if (sampler.get())
2595 {
2596 sampler->syncState(context);
2597 }
2598 }
2599
2600 mDirtySamplers.reset();
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002601
Jamie Madill7c985f52018-11-29 18:16:17 -05002602 return angle::Result::Continue;
Jamie Madille25b8002018-09-20 13:39:49 -04002603}
2604
Jamie Madille3e680c2018-12-03 17:49:08 -05002605angle::Result State::syncVertexArray(const Context *context)
Jamie Madill81c2e252017-09-09 23:32:46 -04002606{
Jamie Madille3e680c2018-12-03 17:49:08 -05002607 ASSERT(mVertexArray);
2608 return mVertexArray->syncState(context);
2609}
Jamie Madill81c2e252017-09-09 23:32:46 -04002610
Jamie Madille3e680c2018-12-03 17:49:08 -05002611angle::Result State::syncProgram(const Context *context)
2612{
2613 return mProgram->syncState(context);
Jamie Madill81c2e252017-09-09 23:32:46 -04002614}
2615
Jamie Madill132d15c2018-11-30 15:25:38 -05002616angle::Result State::syncTexturesInit(const Context *context)
2617{
2618 ASSERT(mRobustResourceInit);
2619
2620 if (!mProgram)
Jamie Madill7c985f52018-11-29 18:16:17 -05002621 return angle::Result::Continue;
Jamie Madill132d15c2018-11-30 15:25:38 -05002622
2623 for (size_t textureUnitIndex : mProgram->getActiveSamplersMask())
2624 {
2625 Texture *texture = mActiveTexturesCache[textureUnitIndex];
2626 if (texture)
2627 {
2628 ANGLE_TRY(texture->ensureInitialized(context));
2629 }
2630 }
Jamie Madill7c985f52018-11-29 18:16:17 -05002631 return angle::Result::Continue;
Jamie Madill132d15c2018-11-30 15:25:38 -05002632}
2633
2634angle::Result State::syncImagesInit(const Context *context)
2635{
2636 ASSERT(mRobustResourceInit);
2637 ASSERT(mProgram);
2638 for (size_t imageUnitIndex : mProgram->getActiveImagesMask())
2639 {
2640 Texture *texture = mImageUnits[imageUnitIndex].texture.get();
2641 if (texture)
2642 {
2643 ANGLE_TRY(texture->ensureInitialized(context));
2644 }
2645 }
Jamie Madill7c985f52018-11-29 18:16:17 -05002646 return angle::Result::Continue;
Jamie Madill132d15c2018-11-30 15:25:38 -05002647}
2648
Jamie Madill6f755b22018-10-09 12:48:54 -04002649angle::Result State::syncDirtyObject(const Context *context, GLenum target)
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002650{
2651 DirtyObjects localSet;
2652
2653 switch (target)
2654 {
2655 case GL_READ_FRAMEBUFFER:
2656 localSet.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2657 break;
2658 case GL_DRAW_FRAMEBUFFER:
2659 localSet.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2660 break;
2661 case GL_FRAMEBUFFER:
2662 localSet.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2663 localSet.set(DIRTY_OBJECT_DRAW_FRAMEBUFFER);
2664 break;
2665 case GL_VERTEX_ARRAY:
2666 localSet.set(DIRTY_OBJECT_VERTEX_ARRAY);
2667 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002668 case GL_TEXTURE:
Jamie Madille3e680c2018-12-03 17:49:08 -05002669 localSet.set(DIRTY_OBJECT_TEXTURES);
Jamie Madille25b8002018-09-20 13:39:49 -04002670 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002671 case GL_SAMPLER:
Jamie Madille25b8002018-09-20 13:39:49 -04002672 localSet.set(DIRTY_OBJECT_SAMPLERS);
Jamie Madill70aeda42018-08-20 12:17:40 -04002673 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002674 case GL_PROGRAM:
Jamie Madill70aeda42018-08-20 12:17:40 -04002675 localSet.set(DIRTY_OBJECT_PROGRAM);
Jamie Madill81c2e252017-09-09 23:32:46 -04002676 break;
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002677 }
2678
Jamie Madillbc918e72018-03-08 09:47:21 -05002679 return syncDirtyObjects(context, localSet);
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002680}
2681
2682void State::setObjectDirty(GLenum target)
2683{
2684 switch (target)
2685 {
2686 case GL_READ_FRAMEBUFFER:
2687 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
2688 break;
2689 case GL_DRAW_FRAMEBUFFER:
Jamie Madillef9fcd92018-11-28 14:03:59 -05002690 setDrawFramebufferDirty();
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002691 break;
2692 case GL_FRAMEBUFFER:
2693 mDirtyObjects.set(DIRTY_OBJECT_READ_FRAMEBUFFER);
Jamie Madillef9fcd92018-11-28 14:03:59 -05002694 setDrawFramebufferDirty();
Jamie Madill60ec6ea2016-01-22 15:27:19 -05002695 break;
2696 case GL_VERTEX_ARRAY:
2697 mDirtyObjects.set(DIRTY_OBJECT_VERTEX_ARRAY);
2698 break;
Jamie Madill81c2e252017-09-09 23:32:46 -04002699 case GL_PROGRAM:
Jamie Madill70aeda42018-08-20 12:17:40 -04002700 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM);
Jamie Madille3e680c2018-12-03 17:49:08 -05002701 break;
2702 default:
Jamie Madill81c2e252017-09-09 23:32:46 -04002703 break;
Jamie Madilla779b612017-07-24 11:46:05 -04002704 }
2705}
2706
Jamie Madill6f755b22018-10-09 12:48:54 -04002707angle::Result State::onProgramExecutableChange(const Context *context, Program *program)
Jamie Madilla779b612017-07-24 11:46:05 -04002708{
2709 // OpenGL Spec:
2710 // "If LinkProgram or ProgramBinary successfully re-links a program object
2711 // that was already in use as a result of a previous call to UseProgram, then the
2712 // generated executable code will be installed as part of the current rendering state."
Jamie Madilldf836ff2018-10-01 10:36:24 -04002713 ASSERT(program->isLinked());
2714
2715 mDirtyBits.set(DIRTY_BIT_PROGRAM_EXECUTABLE);
Jamie Madill956ab4d2018-10-10 16:13:03 -04002716
2717 if (program->hasAnyDirtyBit())
2718 {
2719 mDirtyObjects.set(DIRTY_OBJECT_PROGRAM);
2720 }
Jamie Madille3bb6b72018-10-03 17:51:15 -04002721
2722 // Set any bound textures.
2723 const ActiveTextureTypeArray &textureTypes = program->getActiveSamplerTypes();
2724 for (size_t textureIndex : program->getActiveSamplersMask())
2725 {
2726 TextureType type = textureTypes[textureIndex];
2727
2728 // This can happen if there is a conflicting texture type.
2729 if (type == TextureType::InvalidEnum)
2730 continue;
2731
2732 Texture *texture = mSamplerTextures[type][textureIndex].get();
Jamie Madille3e680c2018-12-03 17:49:08 -05002733 updateActiveTexture(context, textureIndex, texture);
Jamie Madille3bb6b72018-10-03 17:51:15 -04002734 }
2735
2736 for (size_t imageUnitIndex : program->getActiveImagesMask())
2737 {
2738 Texture *image = mImageUnits[imageUnitIndex].texture.get();
2739 if (!image)
2740 continue;
2741
2742 if (image->hasAnyDirtyBit())
2743 {
2744 ANGLE_TRY(image->syncState(context));
2745 }
2746
Jamie Madill132d15c2018-11-30 15:25:38 -05002747 if (mRobustResourceInit && image->initState() == InitState::MayNeedInit)
Jamie Madille3bb6b72018-10-03 17:51:15 -04002748 {
Jamie Madill132d15c2018-11-30 15:25:38 -05002749 mDirtyObjects.set(DIRTY_OBJECT_IMAGES_INIT);
Jamie Madille3bb6b72018-10-03 17:51:15 -04002750 }
2751 }
2752
Jamie Madill7c985f52018-11-29 18:16:17 -05002753 return angle::Result::Continue;
Shannon Woods53a94a82014-06-24 15:20:36 -04002754}
Jamie Madillc9d442d2016-01-20 11:17:24 -05002755
Jamie Madille3e680c2018-12-03 17:49:08 -05002756void State::setTextureDirty(size_t textureUnitIndex)
2757{
2758 mDirtyObjects.set(DIRTY_OBJECT_TEXTURES);
2759 mDirtyTextures.set(textureUnitIndex);
2760}
2761
Jamie Madille25b8002018-09-20 13:39:49 -04002762void State::setSamplerDirty(size_t samplerIndex)
2763{
2764 mDirtyObjects.set(DIRTY_OBJECT_SAMPLERS);
2765 mDirtySamplers.set(samplerIndex);
2766}
2767
Xinghua Cao65ec0b22017-03-28 16:10:52 +08002768void State::setImageUnit(const Context *context,
Will Harris63aa0e52018-09-05 16:15:46 -07002769 size_t unit,
Xinghua Cao65ec0b22017-03-28 16:10:52 +08002770 Texture *texture,
2771 GLint level,
2772 GLboolean layered,
2773 GLint layer,
2774 GLenum access,
2775 GLenum format)
2776{
2777 mImageUnits[unit].texture.set(context, texture);
2778 mImageUnits[unit].level = level;
2779 mImageUnits[unit].layered = layered;
2780 mImageUnits[unit].layer = layer;
2781 mImageUnits[unit].access = access;
2782 mImageUnits[unit].format = format;
jchen1099118c12018-09-10 16:28:51 +08002783 mDirtyBits.set(DIRTY_BIT_IMAGE_BINDINGS);
Jamie Madille3e680c2018-12-03 17:49:08 -05002784
2785 onImageStateChange(context, unit);
Xinghua Cao65ec0b22017-03-28 16:10:52 +08002786}
2787
Jamie Madill81c2e252017-09-09 23:32:46 -04002788// Handle a dirty texture event.
Jamie Madille3e680c2018-12-03 17:49:08 -05002789void State::onActiveTextureChange(const Context *context, size_t textureUnit)
Jamie Madill81c2e252017-09-09 23:32:46 -04002790{
Jamie Madille3e680c2018-12-03 17:49:08 -05002791 if (mProgram)
Geoff Lange51ba632017-11-21 11:45:25 -05002792 {
Jamie Madille3e680c2018-12-03 17:49:08 -05002793 TextureType type = mProgram->getActiveSamplerTypes()[textureUnit];
2794 if (type != TextureType::InvalidEnum)
2795 {
2796 Texture *activeTexture = mSamplerTextures[type][textureUnit].get();
2797 updateActiveTexture(context, textureUnit, activeTexture);
2798 }
2799 }
2800}
2801
2802void State::onActiveTextureStateChange(const Context *context, size_t textureUnit)
2803{
2804 if (mProgram)
2805 {
2806 TextureType type = mProgram->getActiveSamplerTypes()[textureUnit];
2807 if (type != TextureType::InvalidEnum)
2808 {
2809 Texture *activeTexture = mSamplerTextures[type][textureUnit].get();
2810 const Sampler *sampler = mSamplers[textureUnit].get();
2811 updateActiveTextureState(context, textureUnit, sampler, activeTexture);
2812 }
2813 }
2814}
2815
2816void State::onImageStateChange(const Context *context, size_t unit)
2817{
2818 if (mProgram)
2819 {
2820 const ImageUnit &image = mImageUnits[unit];
2821 ASSERT(image.texture.get());
Jamie Madill132d15c2018-11-30 15:25:38 -05002822 if (mRobustResourceInit && image.texture->initState() == InitState::MayNeedInit)
Jamie Madille3e680c2018-12-03 17:49:08 -05002823 {
Jamie Madill132d15c2018-11-30 15:25:38 -05002824 mDirtyObjects.set(DIRTY_OBJECT_IMAGES_INIT);
Jamie Madille3e680c2018-12-03 17:49:08 -05002825 }
Geoff Lange51ba632017-11-21 11:45:25 -05002826 }
Jamie Madill81c2e252017-09-09 23:32:46 -04002827}
2828
Jamie Madill6d32cef2018-08-14 02:34:28 -04002829void State::onUniformBufferStateChange(size_t uniformBufferIndex)
2830{
2831 // This could be represented by a different dirty bit. Using the same one keeps it simple.
2832 mDirtyBits.set(DIRTY_BIT_UNIFORM_BUFFER_BINDINGS);
2833}
2834
Jamie Madillc67323a2017-11-02 23:11:41 -04002835AttributesMask State::getAndResetDirtyCurrentValues() const
2836{
2837 AttributesMask retVal = mDirtyCurrentValues;
2838 mDirtyCurrentValues.reset();
2839 return retVal;
2840}
2841
Markus Tavenrathf7f8c512018-11-18 15:56:45 +01002842constexpr State::DirtyObjectHandler State::kDirtyObjectHandlers[DIRTY_OBJECT_MAX];
2843
Jamie Madillc9d442d2016-01-20 11:17:24 -05002844} // namespace gl